Skip to content

Commit

Permalink
Merge pull request #547 from lidofinance/develop
Browse files Browse the repository at this point in the history
Develop to main
  • Loading branch information
itaven authored Nov 22, 2024
2 parents 1ab4b3c + c1e4723 commit 5156cd6
Show file tree
Hide file tree
Showing 7 changed files with 199 additions and 337 deletions.
7 changes: 5 additions & 2 deletions consts/matomo-wallets-events.ts
Original file line number Diff line number Diff line change
@@ -1,6 +1,7 @@
import { MatomoEventType, trackEvent } from '@lidofinance/analytics-matomo';
import { Metrics } from 'reef-knot/connect-wallet-modal';
import { MetricsProp } from '@reef-knot/types';
import { WalletIdsEthereum } from 'reef-knot/wallets';
import { MATOMO_CLICK_EVENTS } from './matomo-click-events';

export const enum MATOMO_WALLETS_EVENTS_TYPES {
onClickAmbire = 'onClickAmbire',
Expand Down Expand Up @@ -206,7 +207,7 @@ export const MATOMO_WALLETS_EVENTS: Record<
const getMetricHandler = (event: Parameters<typeof trackEvent>) => () =>
trackEvent(...event);

export const walletsMetrics: Metrics<WalletIdsEthereum> = {
export const walletsMetrics: MetricsProp<WalletIdsEthereum> = {
events: {
click: {
handlers: {
Expand All @@ -230,6 +231,8 @@ export const walletsMetrics: Metrics<WalletIdsEthereum> = {
MATOMO_WALLETS_EVENTS.onClickBrowser,
),
binanceWallet: getMetricHandler(MATOMO_WALLETS_EVENTS.onClickBinance),
walletsLess: getMetricHandler(MATOMO_CLICK_EVENTS.clickShowLessWallets),
walletsMore: getMetricHandler(MATOMO_CLICK_EVENTS.clickShowMoreWallets),
},
},
connect: {
Expand Down

This file was deleted.

1 change: 0 additions & 1 deletion modules/web3/web3-provider/connect-wallet-modal/index.ts

This file was deleted.

77 changes: 45 additions & 32 deletions modules/web3/web3-provider/web3-provider.tsx
Original file line number Diff line number Diff line change
@@ -1,19 +1,20 @@
import { FC, PropsWithChildren, useEffect, useMemo } from 'react';
import { QueryClient, QueryClientProvider } from '@tanstack/react-query';
import { WagmiProvider, createConfig, useConnections } from 'wagmi';
import { WagmiProvider, useConnections } from 'wagmi';
import * as wagmiChains from 'wagmi/chains';
import { ReefKnotProvider, getDefaultConfig } from 'reef-knot/core-react';
import {
AutoConnect,
ReefKnot,
getWalletsDataList,
} from 'reef-knot/core-react';
import { WalletsListEthereum } from 'reef-knot/wallets';
ReefKnotWalletsModal,
getDefaultWalletsModalConfig,
} from 'reef-knot/connect-wallet-modal';
import { WalletIdsEthereum, WalletsListEthereum } from 'reef-knot/wallets';
import { useThemeToggle } from '@lidofinance/lido-ui';

import { config } from 'config';
import { useUserConfig } from 'config/user-config';
import { useGetRpcUrlByChainId } from 'config/rpc';
import { CHAINS } from 'consts/chains';
import { ConnectWalletModal } from './connect-wallet-modal';
import { walletsMetrics } from 'consts/matomo-wallets-events';

import { useWeb3Transport } from './use-web3-transport';
import { LidoSDKProvider } from './lido-sdk';
Expand All @@ -22,6 +23,11 @@ import { SupportL1Chains } from './dapp-chain';

type ChainsList = [wagmiChains.Chain, ...wagmiChains.Chain[]];

const WALLETS_PINNED: WalletIdsEthereum[] = [
'binanceWallet',
'browserExtension',
];

export const wagmiChainMap = Object.values(wagmiChains).reduce(
(acc, chain) => {
acc[chain.id] = chain;
Expand All @@ -45,6 +51,7 @@ export const Web3Provider: FC<PropsWithChildren> = ({ children }) => {
walletconnectProjectId,
isWalletConnectionAllowed,
} = useUserConfig();
const { themeName } = useThemeToggle();

const { supportedChains, defaultChain } = useMemo(() => {
// must preserve order of supportedChainIds
Expand Down Expand Up @@ -72,34 +79,42 @@ export const Web3Provider: FC<PropsWithChildren> = ({ children }) => {
),
[supportedChainIds, getRpcUrlByChainId],
);

const { walletsDataList } = useMemo(() => {
return getWalletsDataList({
walletsList: WalletsListEthereum,
rpc: backendRPC,
walletconnectProjectId,
defaultChain,
});
}, [backendRPC, defaultChain, walletconnectProjectId]);

const { transportMap, onActiveConnection } = useWeb3Transport(
supportedChains,
backendRPC,
);

const wagmiConfig = useMemo(() => {
return createConfig({
const { wagmiConfig, reefKnotConfig, walletsModalConfig } = useMemo(() => {
return getDefaultConfig({
// Reef-Knot config args
rpc: backendRPC,
defaultChain: defaultChain,
walletconnectProjectId,
walletsList: WalletsListEthereum,

// Wagmi config args
transports: transportMap,
chains: supportedChains,
autoConnect: isWalletConnectionAllowed,
ssr: true,
connectors: [],
pollingInterval: config.PROVIDER_POLLING_INTERVAL,
batch: {
multicall: false,
},
multiInjectedProviderDiscovery: false,
pollingInterval: config.PROVIDER_POLLING_INTERVAL,
transports: transportMap,

// Wallets config args
...getDefaultWalletsModalConfig(),
metrics: walletsMetrics,
walletsPinned: WALLETS_PINNED,
});
}, [supportedChains, transportMap]);
}, [
backendRPC,
supportedChains,
defaultChain,
walletconnectProjectId,
isWalletConnectionAllowed,
transportMap,
]);

const [activeConnection] = useConnections({ config: wagmiConfig });

Expand All @@ -111,19 +126,17 @@ export const Web3Provider: FC<PropsWithChildren> = ({ children }) => {
// default wagmi autoConnect, MUST be false in our case, because we use custom autoConnect from Reef Knot
<WagmiProvider config={wagmiConfig} reconnectOnMount={false}>
<QueryClientProvider client={queryClient}>
<ReefKnot
rpc={backendRPC}
chains={supportedChains}
walletDataList={walletsDataList}
>
{isWalletConnectionAllowed && <AutoConnect autoConnect />}
<ReefKnotProvider config={reefKnotConfig}>
<ReefKnotWalletsModal
config={walletsModalConfig}
darkThemeEnabled={themeName === 'dark'}
/>
<LidoSDKProvider>
<SupportL1Chains>
<SDKLegacyProvider>{children}</SDKLegacyProvider>
</SupportL1Chains>
</LidoSDKProvider>
<ConnectWalletModal />
</ReefKnot>
</ReefKnotProvider>
</QueryClientProvider>
</WagmiProvider>
);
Expand Down
3 changes: 2 additions & 1 deletion package.json
Original file line number Diff line number Diff line change
Expand Up @@ -45,6 +45,7 @@
"@lidofinance/next-pages": "^0.45.1",
"@lidofinance/rpc": "^0.45.1",
"@lidofinance/satanizer": "^0.45.1",
"@reef-knot/types": "^3.0.0",
"@tanstack/react-query": "^5.51.21",
"bignumber.js": "9.1.0",
"copy-to-clipboard": "^3.3.1",
Expand All @@ -69,7 +70,7 @@
"react-hook-form": "^7.45.2",
"react-is": "^18.2.0",
"react-transition-group": "^4.4.2",
"reef-knot": "5.7.5",
"reef-knot": "6.0.3",
"styled-components": "^5.3.5",
"swr": "^1.3.0",
"tiny-async-pool": "^1.2.0",
Expand Down
15 changes: 2 additions & 13 deletions utils/getErrorMessage.ts
Original file line number Diff line number Diff line change
Expand Up @@ -84,23 +84,12 @@ export const extractCodeFromError = (
normalizedMessage.includes('rejected the request') ||
normalizedMessage.includes('reject this request') ||
normalizedMessage.includes('rejected methods') ||
normalizedMessage.includes('transaction declined')
normalizedMessage.includes('transaction declined') ||
normalizedMessage.includes('signed declined')
)
return 'ACTION_REJECTED';
}

// Ledger live errors
if (
'data' in error &&
typeof error.data === 'object' &&
Array.isArray(error.data) &&
typeof error.data['0'] === 'object' &&
typeof error.data['0'].message === 'string' &&
error.data['0'].message.toLowerCase().includes('rejected')
) {
return 'ACTION_REJECTED';
}

if ('name' in error && typeof error.name == 'string') {
const error_name = error.name.toLowerCase();
if (error_name === 'EthAppPleaseEnableContractData'.toLowerCase())
Expand Down
Loading

0 comments on commit 5156cd6

Please sign in to comment.