Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Group wallets by protocol and service #57

Merged
merged 56 commits into from
Jun 7, 2022
Merged
Show file tree
Hide file tree
Changes from 36 commits
Commits
Show all changes
56 commits
Select commit Hold shift + click to select a range
07b502d
Group wallets by protocol and service
nicomiicro May 25, 2022
ac2ff71
Fix camelCase
nicomiicro May 26, 2022
b694432
Merge branch 'master' into ui/rearrange-multiwalletmodal-to-divide-by…
nicomiicro May 26, 2022
1277d68
Use void instead of catch
nicomiicro May 26, 2022
a3809ba
Prefer null over undefined
nicomiicro May 26, 2022
e0cb57f
Remove unnecessary Fragment
nicomiicro May 26, 2022
9db4edd
Rename addHelpTextToMetaMaskInfo to addMetamaskEcosystemInfo
nicomiicro May 26, 2022
fb26351
Fix wallet icons in MultiConnectButton
nicomiicro May 26, 2022
ab71b61
Remove curried function
nicomiicro May 26, 2022
be9e6b3
Fix curried function implementation
nicomiicro May 26, 2022
4426977
Merge branch 'master' into ui/rearrange-multiwalletmodal-to-divide-by…
nicomiicro May 27, 2022
9ea2223
Merge branch 'ui/rm-wormhole-form' into ui/rearrange-multiwalletmodal…
nicomiicro May 27, 2022
37c382d
Remove chain from EvmWalletAdapter constructor
nicomiicro May 27, 2022
4b96f6c
Add useWalletService for wallet adapters per service/protocol
nicomiicro May 27, 2022
5181495
Merge branch 'master' into ui/rearrange-multiwalletmodal-to-divide-by…
nicomiicro May 27, 2022
aca8a32
Simplify walletService state and move notifications out of the store
nicomiicro May 30, 2022
71429bc
Rename useWalletService to useWalletAdapter
nicomiicro May 30, 2022
a1fa3bf
Add useWalletSevice hook
nicomiicro May 30, 2022
1715741
Disconnect previous adapter if exists
nicomiicro May 30, 2022
a3641c7
Move useWalletsMonitor to its own component
nicomiicro May 30, 2022
817e253
Update EVM logo and protocol names
nicomiicro May 30, 2022
9c5b82e
Lint order of imports
nicomiicro May 30, 2022
2f9da4c
Use EVM instead of Ethereum Virtual Machine
nicomiicro May 30, 2022
35b377e
Revert imports in selectors
nicomiicro May 30, 2022
7cfbc8d
Display wallets count/icons
nicomiicro May 30, 2022
783b8f8
DRY up ecosystems and use filterMap
nicomiicro May 30, 2022
4f0ba66
Remove unnecessary Map
nicomiicro May 30, 2022
e982f53
Remove ecosystem icons from connect button
nicomiicro May 31, 2022
943300c
Add ecosystem icons to home page
nicomiicro May 31, 2022
39c258e
Rename type in useWalletService
nicomiicro May 31, 2022
7318734
Access useWalletAdapter state via selectors
nicomiicro May 31, 2022
d0c0e8f
Update ecosystem icons in HomePage
nicomiicro May 31, 2022
1bd1c22
Add tests for useWalletAdapter
nicomiicro May 31, 2022
af0988a
Add tests for useWalletsMonitor
nicomiicro May 31, 2022
601d4d2
Add tests for useWalletService
nicomiicro May 31, 2022
3c9aada
Revert unnecessary access modifier change
nicomiicro May 31, 2022
732ee0c
Capitalize MetaMask
nicomiicro Jun 2, 2022
5460327
Don't throw error if wallet adapter is missing
nicomiicro Jun 2, 2022
a573c3f
Use root models import
nicomiicro Jun 2, 2022
3ab0e5d
Remove unused useMemo
nicomiicro Jun 2, 2022
03a7bad
Use root models import
nicomiicro Jun 3, 2022
c2fbeb2
Pass adapter to useWalletAdapter.connectService
nicomiicro Jun 3, 2022
9633352
Fix camel case issue
nicomiicro Jun 3, 2022
c3cd50f
Disable eslint "functional/immutable-data" in test files
nicomiicro Jun 3, 2022
93b796c
Remove unused object modification
nicomiicro Jun 3, 2022
c355ccd
Remove unnecessary eslint-disable comment
nicomiicro Jun 3, 2022
87f61d5
Remove shorten address format from test expectation
nicomiicro Jun 3, 2022
e1adce9
DRY up connect buttons
nicomiicro Jun 6, 2022
b2b90fd
List EVM chains in a popover
nicomiicro Jun 6, 2022
656aecc
Remove white EuiPanel from home page chains
nicomiicro Jun 6, 2022
590ec4f
Merge branch 'master' into ui/rearrange-multiwalletmodal-to-divide-by…
nicomiicro Jun 6, 2022
38e7e8f
Remove unused imports
nicomiicro Jun 6, 2022
5b60ec8
Remove unused parameter from useWalletAdapter connectService
nicomiicro Jun 6, 2022
8a0d64f
DRY up promoted ecosystems in home page
nicomiicro Jun 7, 2022
18e8024
Add isEcosystemEnabled helper
nicomiicro Jun 7, 2022
e3d7c31
Filter enabled ecosystems in MultiWalletModal
nicomiicro Jun 7, 2022
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
2 changes: 2 additions & 0 deletions apps/ui/src/App.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -7,6 +7,7 @@ import "./App.scss";
import { AppCrashed, NewVersionAlert } from "./components/AppCrashed";
import { Layout } from "./components/Layout";
import Notification from "./components/Notification";
import WalletsMonitor from "./components/WalletsMonitor";
import { AppContext } from "./contexts";
import CollectiblesPage from "./pages/CollectiblesPage";
import HelpPage from "./pages/HelpPage";
Expand Down Expand Up @@ -102,6 +103,7 @@ function App(): ReactElement {
</AppContext>
</Router>
<Notification />
<WalletsMonitor />
</Sentry.ErrorBoundary>
);
}
Expand Down
14 changes: 14 additions & 0 deletions apps/ui/src/components/ConnectButton.scss
Original file line number Diff line number Diff line change
Expand Up @@ -21,3 +21,17 @@
border: none;
}
}

.multiConnectButton {
img {
margin: 0 3px;

&:first-of-type {
margin-left: 0;
}

&:last-of-type {
margin-right: 6px;
}
}
}
76 changes: 40 additions & 36 deletions apps/ui/src/components/ConnectButton.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -5,15 +5,11 @@ import { useState } from "react";
import shallow from "zustand/shallow.js";

import { EcosystemId } from "../config";
import { selectConfig } from "../core/selectors";
import { useEnvironment } from "../core/store";
import { selectConfig, selectWalletAdapterApi } from "../core/selectors";
import { useEnvironment, useWalletAdapter } from "../core/store";
import { useWallets } from "../hooks";
import AVALANCHE_SVG from "../images/ecosystems/avalanche.svg";
import BSC_SVG from "../images/ecosystems/bsc.svg";
import ETHEREUM_SVG from "../images/ecosystems/ethereum.svg";
import POLYGON_SVG from "../images/ecosystems/polygon.svg";
import SOLANA_SVG from "../images/ecosystems/solana.svg";
import { shortenAddress } from "../utils";
import type { WalletService } from "../models";
import { deduplicate, isNotNull, shortenAddress } from "../utils";

import { MultiWalletModal } from "./MultiWalletModal";

Expand All @@ -29,15 +25,19 @@ export const ConnectButton = ({
...rest
}: ConnectButtonProps): ReactElement => {
const { ecosystems } = useEnvironment(selectConfig, shallow);
const { disconnectService } = useWalletAdapter(
selectWalletAdapterApi,
shallow,
);
if (ecosystemId === EcosystemId.Terra) {
throw new Error("Unsupported ecosystem");
}
const ecosystem = ecosystems[ecosystemId];
const wallets = useWallets();
const { connected, select, address, wallet } = wallets[ecosystemId];
const { connected, select, address } = wallets[ecosystemId];

const disconnect = (): void => {
void wallet?.disconnect();
void disconnectService(ecosystem.protocol);
};

const handleClick = connected ? disconnect : select;
Expand Down Expand Up @@ -81,49 +81,53 @@ export const MultiConnectButton = ({
const openModal = (): void => setIsWalletModalOpen(true);

const {
solana: { connected: isSolanaConnected },
ethereum: { connected: isEthereumConnected },
bsc: { connected: isBscConnected },
avalanche: { connected: isAvalancheConnected },
polygon: { connected: isPolygonConnected },
solana: { connected: isSolanaConnected, service: solanaService },
ethereum: { connected: isEthereumConnected, service: ethereumService },
bsc: { connected: isBscConnected, service: bscService },
avalanche: { connected: isAvalancheConnected, service: avalanceService },
polygon: { connected: isPolygonConnected, service: polygonService },
} = useWallets();
const connectedStatuses = [
isSolanaConnected,
isEthereumConnected,
isBscConnected,
isAvalancheConnected,
isPolygonConnected,
];
const nConnected = connectedStatuses.filter(Boolean).length;
const connectedServices = [
isSolanaConnected ? solanaService : null,
isEthereumConnected ? ethereumService : null,
isBscConnected ? bscService : null,
isAvalancheConnected ? avalanceService : null,
isPolygonConnected ? polygonService : null,
].filter(isNotNull);

const uniqueServices = deduplicate<string, WalletService>(
(walletService) => walletService.id,
connectedServices,
);
const nConnected = uniqueServices.length;

const label =
nConnected > 0 ? (
<>
{isSolanaConnected && <EuiIcon type={SOLANA_SVG} size="l" />}
{isEthereumConnected && <EuiIcon type={ETHEREUM_SVG} size="l" />}
{isBscConnected && <EuiIcon type={BSC_SVG} size="l" />}
{isAvalancheConnected && <EuiIcon type={AVALANCHE_SVG} size="l" />}
{isPolygonConnected && <EuiIcon type={POLYGON_SVG} size="l" />}
{uniqueServices.map((walletService) => (
<EuiIcon
key={walletService.id}
type={walletService.info.icon}
size="l"
/>
))}
&nbsp;{nConnected}
<span>&nbsp;connected</span>
</>
) : (
<>
<EuiIcon type={SOLANA_SVG} size="l" />
<EuiIcon type={ETHEREUM_SVG} size="l" />
<EuiIcon type={BSC_SVG} size="l" />
{/* TODO: Consider adding these:
<EuiIcon type={AVALANCHE_SVG} size="l" />
<EuiIcon type={POLYGON_SVG} size="l" /> */}
&nbsp;
<EuiShowFor sizes={["xs"]}>Connect</EuiShowFor>
<EuiHideFor sizes={["xs"]}>Connect Wallets</EuiHideFor>
</>
);

return (
<>
<EuiButton onClick={openModal} {...rest}>
<EuiButton
onClick={openModal}
{...rest}
className={`multiConnectButton ${rest.className ?? ""}`}
wormat marked this conversation as resolved.
Show resolved Hide resolved
>
{label}
</EuiButton>
{isWalletModalOpen && <MultiWalletModal handleClose={closeModal} />}
Expand Down
15 changes: 15 additions & 0 deletions apps/ui/src/components/MultiWalletModal.scss
Original file line number Diff line number Diff line change
@@ -0,0 +1,15 @@
.walletServiceButton {
white-space: nowrap;

&__ecosystems {
margin: 10px 0 0 30px;

& > li {
margin-bottom: 15px;

img {
margin-right: 15px;
}
}
}
}
Loading