@getpara/evm-wallet-connectors 2.0.0-alpha.7 → 2.0.0-alpha.71
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +20 -0
- package/dist/connectors/walletConnect.d.ts +63 -0
- package/dist/connectors/walletConnect.js +366 -0
- package/dist/index.d.ts +4 -2
- package/dist/index.js +5 -1
- package/dist/providers/EvmExternalWalletContext.d.ts +7 -35
- package/dist/providers/EvmExternalWalletContext.js +280 -86
- package/dist/providers/ParaEvmContext.d.ts +2 -1
- package/dist/providers/ParaEvmContext.js +49 -7
- package/dist/providers/createParaWagmiConfig.d.ts +10 -0
- package/dist/providers/createParaWagmiConfig.js +65 -0
- package/dist/providers/externalHooks.d.ts +7 -0
- package/dist/providers/externalHooks.js +7 -0
- package/dist/stores/wagmiConfigStore.d.ts +14 -0
- package/dist/stores/wagmiConfigStore.js +16 -0
- package/dist/types/Wallet.d.ts +5 -1
- package/dist/types/utils.d.ts +1 -1
- package/dist/utils/getWalletConnectConnector.js +1 -1
- package/dist/utils/getWalletConnectUri.d.ts +1 -1
- package/dist/utils/getWalletConnectUri.js +20 -14
- package/dist/utils/isEIP6963Connector.js +1 -1
- package/dist/utils/resolveWalletList.d.ts +3 -0
- package/dist/utils/resolveWalletList.js +16 -0
- package/dist/wallets/connectors/backpack/backpack.d.ts +3 -0
- package/dist/wallets/connectors/backpack/backpack.js +31 -0
- package/dist/wallets/connectors/backpack/backpackIcon.d.ts +1 -0
- package/dist/wallets/connectors/backpack/backpackIcon.js +6 -0
- package/dist/wallets/connectors/coinbase/coinbase.js +1 -0
- package/dist/wallets/connectors/farcaster/farcaster.d.ts +2 -0
- package/dist/wallets/connectors/farcaster/farcaster.js +22 -0
- package/dist/wallets/connectors/farcaster/farcasterIcon.d.ts +1 -0
- package/dist/wallets/connectors/farcaster/farcasterIcon.js +6 -0
- package/dist/wallets/connectors/haha/haha.d.ts +3 -0
- package/dist/wallets/connectors/haha/haha.js +31 -0
- package/dist/wallets/connectors/haha/hahaIcon.d.ts +1 -0
- package/dist/wallets/connectors/haha/hahaIcon.js +6 -0
- package/dist/wallets/connectors/index.d.ts +7 -1
- package/dist/wallets/connectors/index.js +18 -1
- package/dist/wallets/connectors/metaMask/metaMask.js +8 -4
- package/dist/wallets/connectors/metaMask/metaMaskIcon.d.ts +1 -1
- package/dist/wallets/connectors/metaMask/metaMaskIcon.js +1 -1
- package/dist/wallets/connectors/okx/okx.d.ts +3 -0
- package/dist/wallets/connectors/okx/okx.js +32 -0
- package/dist/wallets/connectors/okx/okxIcon.d.ts +1 -0
- package/dist/wallets/connectors/okx/okxIcon.js +6 -0
- package/dist/wallets/connectors/phantom/phantom.d.ts +3 -0
- package/dist/wallets/connectors/phantom/phantom.js +31 -0
- package/dist/wallets/connectors/phantom/phantomIcon.d.ts +1 -0
- package/dist/wallets/connectors/phantom/phantomIcon.js +6 -0
- package/dist/wallets/connectors/rabby/rabby.js +1 -0
- package/dist/wallets/connectors/rainbow/rainbow.js +8 -1
- package/dist/wallets/connectors/safe/safe.js +1 -0
- package/dist/wallets/connectors/valora/valora.d.ts +3 -0
- package/dist/wallets/connectors/valora/valora.js +29 -0
- package/dist/wallets/connectors/valora/valoraIcon.d.ts +1 -0
- package/dist/wallets/connectors/valora/valoraIcon.js +6 -0
- package/dist/wallets/connectors/walletConnect/walletConnect.js +1 -0
- package/dist/wallets/connectors/zerion/zerion.js +5 -1
- package/dist/wallets/connectorsForWallets.d.ts +4 -1
- package/dist/wallets/connectorsForWallets.js +14 -3
- package/package.json +34 -26
|
@@ -1,17 +1,21 @@
|
|
|
1
1
|
"use client";
|
|
2
2
|
import {
|
|
3
|
+
__async,
|
|
3
4
|
__objRest,
|
|
4
5
|
__spreadProps,
|
|
5
6
|
__spreadValues
|
|
6
7
|
} from "../chunk-MMUBH76A.js";
|
|
7
8
|
import { jsx } from "react/jsx-runtime";
|
|
8
|
-
import { useMemo } from "react";
|
|
9
|
-
import { createConfig, WagmiProvider } from "wagmi";
|
|
9
|
+
import { useEffect, useMemo, useRef, useState } from "react";
|
|
10
|
+
import { createConfig as createWagmiConfig, WagmiProvider } from "wagmi";
|
|
10
11
|
import { connectorsForWallets } from "../wallets/connectorsForWallets.js";
|
|
11
12
|
import { http } from "viem";
|
|
12
13
|
import { computeWalletConnectMetaData } from "../utils/computeWalletConnectMetaData.js";
|
|
13
14
|
import { EvmExternalWalletProvider } from "./EvmExternalWalletContext.js";
|
|
14
15
|
import { paraConnector } from "@getpara/wagmi-v2-connector";
|
|
16
|
+
import { setWagmiConfig, getWagmiConfig } from "../stores/wagmiConfigStore.js";
|
|
17
|
+
import { resolveWalletList } from "../utils/resolveWalletList.js";
|
|
18
|
+
import { farcasterWallet } from "../wallets/connectors/index.js";
|
|
15
19
|
const createDefaultTransports = (chains) => {
|
|
16
20
|
const transportsObject = chains.reduce((acc, chain) => {
|
|
17
21
|
const key = chain.id;
|
|
@@ -33,7 +37,7 @@ function ParaEvmProvider({
|
|
|
33
37
|
appDescription,
|
|
34
38
|
appIcon,
|
|
35
39
|
appUrl,
|
|
36
|
-
wallets,
|
|
40
|
+
wallets: propsWallets,
|
|
37
41
|
chains,
|
|
38
42
|
transports,
|
|
39
43
|
paraConnectorOptions
|
|
@@ -48,6 +52,10 @@ function ParaEvmProvider({
|
|
|
48
52
|
"transports",
|
|
49
53
|
"paraConnectorOptions"
|
|
50
54
|
]);
|
|
55
|
+
const propsWalletList = useMemo(() => {
|
|
56
|
+
return resolveWalletList(propsWallets != null ? propsWallets : []);
|
|
57
|
+
}, [propsWallets]);
|
|
58
|
+
const prevWallets = useRef(propsWalletList);
|
|
51
59
|
const paraConnectorInstance = useMemo(() => {
|
|
52
60
|
return paraConnector({
|
|
53
61
|
para,
|
|
@@ -57,9 +65,16 @@ function ParaEvmProvider({
|
|
|
57
65
|
options: paraConnectorOptions != null ? paraConnectorOptions : {}
|
|
58
66
|
});
|
|
59
67
|
}, [para]);
|
|
60
|
-
const
|
|
68
|
+
const createConfig = (walletList, createFarcasterConnector) => {
|
|
69
|
+
const existing = getWagmiConfig();
|
|
70
|
+
if (existing && prevWallets.current === walletList) {
|
|
71
|
+
return existing;
|
|
72
|
+
}
|
|
73
|
+
prevWallets.current = walletList;
|
|
61
74
|
const wcMetadata = computeWalletConnectMetaData({ appName, appDescription, appUrl, appIcon });
|
|
62
|
-
const baseConnectors = connectorsForWallets(
|
|
75
|
+
const baseConnectors = connectorsForWallets(walletList, {
|
|
76
|
+
para,
|
|
77
|
+
createFarcasterConnector,
|
|
63
78
|
projectId,
|
|
64
79
|
appName,
|
|
65
80
|
appDescription,
|
|
@@ -68,12 +83,39 @@ function ParaEvmProvider({
|
|
|
68
83
|
walletConnectParameters: { metadata: wcMetadata }
|
|
69
84
|
});
|
|
70
85
|
const allConnectors = [...baseConnectors, paraConnectorInstance];
|
|
71
|
-
|
|
86
|
+
const createdConfig = createWagmiConfig(__spreadProps(__spreadValues({
|
|
87
|
+
ssr: true
|
|
88
|
+
}, wagmiConfigParams), {
|
|
72
89
|
chains,
|
|
73
90
|
transports: transports || createDefaultTransports(chains),
|
|
74
91
|
connectors: allConnectors
|
|
75
92
|
}));
|
|
76
|
-
|
|
93
|
+
setWagmiConfig(createdConfig);
|
|
94
|
+
return createdConfig;
|
|
95
|
+
};
|
|
96
|
+
const [config, setConfig] = useState(null);
|
|
97
|
+
useEffect(() => {
|
|
98
|
+
if (!para.isReady) {
|
|
99
|
+
return;
|
|
100
|
+
}
|
|
101
|
+
const initializeConfig = () => __async(this, null, function* () {
|
|
102
|
+
var _a2;
|
|
103
|
+
if (para.isFarcasterMiniApp) {
|
|
104
|
+
let createFarcasterConnector = null;
|
|
105
|
+
try {
|
|
106
|
+
createFarcasterConnector = (_a2 = (yield import("@farcaster/miniapp-wagmi-connector")).farcasterMiniApp) != null ? _a2 : void 0;
|
|
107
|
+
} catch (e) {
|
|
108
|
+
}
|
|
109
|
+
setConfig(createConfig([...propsWalletList, farcasterWallet], createFarcasterConnector));
|
|
110
|
+
} else {
|
|
111
|
+
setConfig(createConfig([...propsWalletList]));
|
|
112
|
+
}
|
|
113
|
+
});
|
|
114
|
+
initializeConfig();
|
|
115
|
+
}, [para.isFarcasterMiniApp, para.isReady, propsWalletList]);
|
|
116
|
+
if (!config) {
|
|
117
|
+
return null;
|
|
118
|
+
}
|
|
77
119
|
return /* @__PURE__ */ jsx(WagmiProvider, __spreadProps(__spreadValues({ config }, wagmiProviderProps), { children: /* @__PURE__ */ jsx(EvmExternalWalletProvider, __spreadProps(__spreadValues({}, internalConfig), { children })) }));
|
|
78
120
|
}
|
|
79
121
|
export {
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import { Chain, Transport } from 'viem';
|
|
2
|
+
import type { ParaEvmProviderConfig } from './ParaEvmContext.js';
|
|
3
|
+
import ParaWeb from '@getpara/web-sdk';
|
|
4
|
+
/**
|
|
5
|
+
* Creates a Wagmi configuration for the Para EVM provider.
|
|
6
|
+
* @param para - The ParaWeb instance to use.
|
|
7
|
+
* @param cfg - The configuration options for the Para EVM provider.
|
|
8
|
+
* @returns The created Wagmi configuration.
|
|
9
|
+
*/
|
|
10
|
+
export declare function createParaWagmiConfig<const chains extends readonly [Chain, ...Chain[]], transports extends Record<chains[number]['id'], Transport>>(para: ParaWeb, cfg: ParaEvmProviderConfig<chains, transports>): import("wagmi").Config<chains, transports, readonly import("wagmi").CreateConnectorFn[]>;
|
|
@@ -0,0 +1,65 @@
|
|
|
1
|
+
"use client";
|
|
2
|
+
import {
|
|
3
|
+
__objRest,
|
|
4
|
+
__spreadProps,
|
|
5
|
+
__spreadValues
|
|
6
|
+
} from "../chunk-MMUBH76A.js";
|
|
7
|
+
import { createConfig } from "wagmi";
|
|
8
|
+
import { connectorsForWallets } from "../wallets/connectorsForWallets.js";
|
|
9
|
+
import { computeWalletConnectMetaData } from "../utils/computeWalletConnectMetaData.js";
|
|
10
|
+
import { paraConnector } from "@getpara/wagmi-v2-connector";
|
|
11
|
+
import { setWagmiConfig } from "../stores/wagmiConfigStore.js";
|
|
12
|
+
import { resolveWalletList } from "../utils/resolveWalletList.js";
|
|
13
|
+
function createParaWagmiConfig(para, cfg) {
|
|
14
|
+
const _a = cfg, {
|
|
15
|
+
projectId,
|
|
16
|
+
appName,
|
|
17
|
+
appDescription,
|
|
18
|
+
appIcon,
|
|
19
|
+
appUrl,
|
|
20
|
+
wallets,
|
|
21
|
+
chains,
|
|
22
|
+
transports,
|
|
23
|
+
paraConnectorOptions
|
|
24
|
+
} = _a, wagmiParams = __objRest(_a, [
|
|
25
|
+
"projectId",
|
|
26
|
+
"appName",
|
|
27
|
+
"appDescription",
|
|
28
|
+
"appIcon",
|
|
29
|
+
"appUrl",
|
|
30
|
+
"wallets",
|
|
31
|
+
"chains",
|
|
32
|
+
"transports",
|
|
33
|
+
"paraConnectorOptions"
|
|
34
|
+
]);
|
|
35
|
+
const wcMetadata = computeWalletConnectMetaData({ appName, appDescription, appUrl, appIcon });
|
|
36
|
+
const walletFactories = resolveWalletList(wallets);
|
|
37
|
+
const baseConnectors = connectorsForWallets(walletFactories, {
|
|
38
|
+
para,
|
|
39
|
+
projectId,
|
|
40
|
+
appName,
|
|
41
|
+
appDescription,
|
|
42
|
+
appUrl,
|
|
43
|
+
appIcon,
|
|
44
|
+
walletConnectParameters: { metadata: wcMetadata }
|
|
45
|
+
});
|
|
46
|
+
const paraConn = paraConnector({
|
|
47
|
+
para,
|
|
48
|
+
chains: [...chains],
|
|
49
|
+
disableModal: true,
|
|
50
|
+
appName,
|
|
51
|
+
options: paraConnectorOptions != null ? paraConnectorOptions : {}
|
|
52
|
+
});
|
|
53
|
+
const created = createConfig(__spreadProps(__spreadValues({
|
|
54
|
+
ssr: true
|
|
55
|
+
}, wagmiParams), {
|
|
56
|
+
chains,
|
|
57
|
+
transports,
|
|
58
|
+
connectors: [...baseConnectors, paraConn]
|
|
59
|
+
}));
|
|
60
|
+
setWagmiConfig(created);
|
|
61
|
+
return created;
|
|
62
|
+
}
|
|
63
|
+
export {
|
|
64
|
+
createParaWagmiConfig
|
|
65
|
+
};
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import type { Config } from 'wagmi';
|
|
2
|
+
/**
|
|
3
|
+
* Sets the Wagmi configuration in the global store.
|
|
4
|
+
*
|
|
5
|
+
* @param config - The Wagmi configuration object to be stored
|
|
6
|
+
* @returns {void}
|
|
7
|
+
*/
|
|
8
|
+
export declare const setWagmiConfig: (config: Config) => void;
|
|
9
|
+
/**
|
|
10
|
+
* Retrieves the current Wagmi configuration from the global store.
|
|
11
|
+
*
|
|
12
|
+
* @returns {Config | null} - The current Wagmi configuration or null if not set
|
|
13
|
+
*/
|
|
14
|
+
export declare const getWagmiConfig: () => Config;
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
"use client";
|
|
2
|
+
import "../chunk-MMUBH76A.js";
|
|
3
|
+
import { createStore } from "zustand/vanilla";
|
|
4
|
+
const wagmiConfigStore = createStore(() => ({
|
|
5
|
+
config: null
|
|
6
|
+
}));
|
|
7
|
+
const setWagmiConfig = (config) => {
|
|
8
|
+
wagmiConfigStore.setState({ config });
|
|
9
|
+
};
|
|
10
|
+
const getWagmiConfig = () => {
|
|
11
|
+
return wagmiConfigStore.getState().config;
|
|
12
|
+
};
|
|
13
|
+
export {
|
|
14
|
+
getWagmiConfig,
|
|
15
|
+
setWagmiConfig
|
|
16
|
+
};
|
package/dist/types/Wallet.d.ts
CHANGED
|
@@ -1,14 +1,18 @@
|
|
|
1
1
|
import { Connector, CreateConnectorFn } from 'wagmi';
|
|
2
|
-
import { WalletConnectParameters } from 'wagmi/connectors';
|
|
3
2
|
import { CoinbaseWalletOptions } from '../wallets/connectors/coinbase/coinbase.js';
|
|
4
3
|
import { WalletConnectWalletOptions } from '../wallets/connectors/walletConnect/walletConnect.js';
|
|
5
4
|
import { type WalletMetadata } from '@getpara/react-common';
|
|
5
|
+
import ParaWeb from '@getpara/web-sdk';
|
|
6
|
+
import { WalletConnectParameters } from '../connectors/walletConnect.js';
|
|
6
7
|
export type Wallet = {
|
|
7
8
|
createConnector?: (walletDetails: WalletDetailsParams) => CreateConnectorFn;
|
|
8
9
|
createMobileConnector?: (walletDetails: WalletDetailsParams) => CreateConnectorFn;
|
|
9
10
|
getUri?: (uri: string) => string;
|
|
11
|
+
deeplinkUri?: string;
|
|
10
12
|
} & WalletMetadata;
|
|
11
13
|
export interface DefaultWalletOptions {
|
|
14
|
+
para?: ParaWeb;
|
|
15
|
+
createFarcasterConnector?: () => any;
|
|
12
16
|
projectId: string;
|
|
13
17
|
walletConnectParameters?: ParaWalletConnectParameters;
|
|
14
18
|
}
|
package/dist/types/utils.d.ts
CHANGED
|
@@ -9,7 +9,7 @@ export type Mutable<type extends object> = {
|
|
|
9
9
|
};
|
|
10
10
|
/** Strict version of built-in Omit type */
|
|
11
11
|
export type Omit<type, keys extends keyof type> = Pick<type, Exclude<keyof type, keys>>;
|
|
12
|
-
export type WalletProviderFlags = 'isApexWallet' | 'isAvalanche' | 'isBackpack' | 'isBifrost' | 'isBitKeep' | 'isBitski' | 'isBlockWallet' | 'isBraveWallet' | 'isCoinbaseWallet' | 'isDawn' | 'isEnkrypt' | 'isExodus' | 'isFrame' | 'isFrontier' | 'isGamestop' | 'isHyperPay' | 'isImToken' | 'isKuCoinWallet' | 'isMathWallet' | 'isMetaMask' | 'isNestWallet' | 'isOkxWallet' | 'isOKExWallet' | 'isOneInchAndroidWallet' | 'isOneInchIOSWallet' | 'isOpera' | 'isPhantom' | 'isPortal' | 'isRabby' | 'isRainbow' | 'isSafe' | 'isStatus' | 'isTally' | 'isTokenPocket' | 'isTokenary' | 'isTrust' | 'isTrustWallet' | 'isXDEFI' | 'isZerion' | 'isTalisman' | 'isZeal' | 'isCoin98' | 'isMEWwallet' | 'isSafeheron' | 'isSafePal' | '__seif';
|
|
12
|
+
export type WalletProviderFlags = 'isApexWallet' | 'isAvalanche' | 'isBackpack' | 'isBifrost' | 'isBitKeep' | 'isBitski' | 'isBlockWallet' | 'isBraveWallet' | 'isCoinbaseWallet' | 'isDawn' | 'isEnkrypt' | 'isExodus' | 'isFarcaster' | 'isFrame' | 'isFrontier' | 'isGamestop' | 'isHyperPay' | 'isImToken' | 'isKuCoinWallet' | 'isMathWallet' | 'isMetaMask' | 'isNestWallet' | 'isOkxWallet' | 'isOKExWallet' | 'isOneInchAndroidWallet' | 'isOneInchIOSWallet' | 'isOpera' | 'isPhantom' | 'isPortal' | 'isRabby' | 'isRainbow' | 'isSafe' | 'isStatus' | 'isTally' | 'isTokenPocket' | 'isTokenary' | 'isTrust' | 'isTrustWallet' | 'isXDEFI' | 'isZerion' | 'isTalisman' | 'isZeal' | 'isCoin98' | 'isMEWwallet' | 'isSafeheron' | 'isSafePal' | '__seif';
|
|
13
13
|
export type WalletProvider = Evaluate<EIP1193Provider & {
|
|
14
14
|
[key in WalletProviderFlags]?: true | undefined;
|
|
15
15
|
} & {
|
|
@@ -4,7 +4,7 @@ import {
|
|
|
4
4
|
__spreadValues
|
|
5
5
|
} from "../chunk-MMUBH76A.js";
|
|
6
6
|
import { createConnector } from "wagmi";
|
|
7
|
-
import { walletConnect } from "
|
|
7
|
+
import { walletConnect } from "../connectors/walletConnect.js";
|
|
8
8
|
const walletConnectInstances = /* @__PURE__ */ new Map();
|
|
9
9
|
const getOrCreateWalletConnectInstance = ({
|
|
10
10
|
projectId,
|
|
@@ -1,2 +1,2 @@
|
|
|
1
1
|
import { Connector } from 'wagmi';
|
|
2
|
-
export declare const
|
|
2
|
+
export declare const emitWalletConnectUri: (connector: Connector, uriConverter?: (uri: string) => string) => Promise<void>;
|
|
@@ -2,21 +2,27 @@
|
|
|
2
2
|
import {
|
|
3
3
|
__async
|
|
4
4
|
} from "../chunk-MMUBH76A.js";
|
|
5
|
-
const
|
|
6
|
-
|
|
7
|
-
if (
|
|
8
|
-
return
|
|
5
|
+
const emitWalletConnectUri = (connector, uriConverter) => __async(void 0, null, function* () {
|
|
6
|
+
var _a, _b;
|
|
7
|
+
if (typeof window === "undefined") {
|
|
8
|
+
return;
|
|
9
9
|
}
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
);
|
|
10
|
+
const provider = yield (_b = (_a = connector.getProvider) == null ? void 0 : _a.call(connector)) != null ? _b : void 0;
|
|
11
|
+
if (connector.type === "coinbaseWallet" && (provider == null ? void 0 : provider.qrUrl)) {
|
|
12
|
+
window.dispatchEvent(new CustomEvent("PARA_WALLETCONNECT_URI_READY", { detail: provider.qrUrl }));
|
|
13
|
+
}
|
|
14
|
+
if (!provider || typeof provider.once !== "function" && typeof provider.on !== "function") {
|
|
15
|
+
throw new Error("display_uri event not supported for this connector");
|
|
16
|
+
}
|
|
17
|
+
const listen = typeof provider.once === "function" ? provider.once.bind(provider) : provider.on.bind(provider);
|
|
18
|
+
const cancel = setTimeout(() => console.error("display_uri event not emitted"), 1e4);
|
|
19
|
+
listen("display_uri", (uri) => {
|
|
20
|
+
clearTimeout(cancel);
|
|
21
|
+
window.dispatchEvent(
|
|
22
|
+
new CustomEvent("PARA_WALLETCONNECT_URI_READY", { detail: uriConverter ? uriConverter(uri) : uri })
|
|
23
|
+
);
|
|
24
|
+
});
|
|
19
25
|
});
|
|
20
26
|
export {
|
|
21
|
-
|
|
27
|
+
emitWalletConnectUri
|
|
22
28
|
};
|
|
@@ -2,7 +2,7 @@
|
|
|
2
2
|
import "../chunk-MMUBH76A.js";
|
|
3
3
|
const isEIP6963Connector = (wallet) => {
|
|
4
4
|
var _a;
|
|
5
|
-
return !!(!wallet.isRainbowKitConnector && ((_a = wallet.icon) == null ? void 0 : _a.startsWith("data:image")) && wallet.uid && wallet.name);
|
|
5
|
+
return !!(!wallet.isRainbowKitConnector && ((_a = wallet.icon) == null ? void 0 : _a.trim().startsWith("data:image")) && wallet.uid && wallet.name);
|
|
6
6
|
};
|
|
7
7
|
export {
|
|
8
8
|
isEIP6963Connector
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
"use client";
|
|
2
|
+
import "../chunk-MMUBH76A.js";
|
|
3
|
+
import { allWallets } from "../wallets/connectors/index.js";
|
|
4
|
+
function resolveWalletList(wallets) {
|
|
5
|
+
if (!wallets || !wallets.length) return [];
|
|
6
|
+
if (typeof wallets[0] === "function") return wallets;
|
|
7
|
+
const ids = wallets;
|
|
8
|
+
const resolved = allWallets.filter((createWalletFn) => {
|
|
9
|
+
const meta = createWalletFn({ projectId: "", appName: "" });
|
|
10
|
+
return ids.includes(meta.id.toUpperCase());
|
|
11
|
+
});
|
|
12
|
+
return resolved;
|
|
13
|
+
}
|
|
14
|
+
export {
|
|
15
|
+
resolveWalletList
|
|
16
|
+
};
|
|
@@ -0,0 +1,31 @@
|
|
|
1
|
+
"use client";
|
|
2
|
+
import "../../../chunk-MMUBH76A.js";
|
|
3
|
+
import { getInjectedConnector, hasInjectedProvider } from "../../../utils/getInjectedConnector.js";
|
|
4
|
+
import { icon } from "./backpackIcon.js";
|
|
5
|
+
import { getWalletConnectConnector } from "../../../utils/getWalletConnectConnector.js";
|
|
6
|
+
const backpackWallet = ({ projectId, walletConnectParameters }) => {
|
|
7
|
+
const isBackpackInjected = hasInjectedProvider({ namespace: "backpack.ethereum" });
|
|
8
|
+
const shouldUseWalletConnect = !isBackpackInjected;
|
|
9
|
+
const getUri = (uri) => {
|
|
10
|
+
return uri;
|
|
11
|
+
};
|
|
12
|
+
return {
|
|
13
|
+
id: "backpack",
|
|
14
|
+
internalId: "BACKPACK",
|
|
15
|
+
name: "Backpack",
|
|
16
|
+
rdns: "app.backpack",
|
|
17
|
+
iconUrl: icon,
|
|
18
|
+
installed: isBackpackInjected,
|
|
19
|
+
isExtension: true,
|
|
20
|
+
isMobile: true,
|
|
21
|
+
getUri,
|
|
22
|
+
downloadUrl: "https://backpack.app/download",
|
|
23
|
+
createConnector: shouldUseWalletConnect ? getWalletConnectConnector({
|
|
24
|
+
projectId,
|
|
25
|
+
walletConnectParameters
|
|
26
|
+
}) : getInjectedConnector({ namespace: "backpack.ethereum" })
|
|
27
|
+
};
|
|
28
|
+
};
|
|
29
|
+
export {
|
|
30
|
+
backpackWallet
|
|
31
|
+
};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export declare const icon = "";
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
"use client";
|
|
2
|
+
import "../../../chunk-MMUBH76A.js";
|
|
3
|
+
const icon = "";
|
|
4
|
+
export {
|
|
5
|
+
icon
|
|
6
|
+
};
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
"use client";
|
|
2
|
+
import {
|
|
3
|
+
__spreadValues
|
|
4
|
+
} from "../../../chunk-MMUBH76A.js";
|
|
5
|
+
import { createConnector } from "wagmi";
|
|
6
|
+
import { icon } from "./farcasterIcon.js";
|
|
7
|
+
const farcasterWallet = ({ para, createFarcasterConnector }) => {
|
|
8
|
+
return {
|
|
9
|
+
id: "farcaster",
|
|
10
|
+
internalId: "FARCASTER",
|
|
11
|
+
name: "Farcaster",
|
|
12
|
+
rdns: "xyz.farcaster.MiniAppWallet",
|
|
13
|
+
iconUrl: icon,
|
|
14
|
+
installed: (para == null ? void 0 : para.isReady) && (para == null ? void 0 : para.isFarcasterMiniApp),
|
|
15
|
+
isExtension: true,
|
|
16
|
+
downloadUrl: "https://farcaster.xyz/",
|
|
17
|
+
createConnector: (walletDetails) => createConnector((config) => __spreadValues(__spreadValues({}, createFarcasterConnector()(config)), walletDetails))
|
|
18
|
+
};
|
|
19
|
+
};
|
|
20
|
+
export {
|
|
21
|
+
farcasterWallet
|
|
22
|
+
};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export declare const icon = "";
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
"use client";
|
|
2
|
+
import "../../../chunk-MMUBH76A.js";
|
|
3
|
+
const icon = "";
|
|
4
|
+
export {
|
|
5
|
+
icon
|
|
6
|
+
};
|
|
@@ -0,0 +1,31 @@
|
|
|
1
|
+
"use client";
|
|
2
|
+
import "../../../chunk-MMUBH76A.js";
|
|
3
|
+
import { getInjectedConnector, hasInjectedProvider } from "../../../utils/getInjectedConnector.js";
|
|
4
|
+
import { icon } from "./hahaIcon.js";
|
|
5
|
+
import { getWalletConnectConnector } from "../../../utils/getWalletConnectConnector.js";
|
|
6
|
+
const hahaWallet = ({ projectId, walletConnectParameters }) => {
|
|
7
|
+
const isHahaInjected = hasInjectedProvider({ namespace: "haha" });
|
|
8
|
+
const shouldUseWalletConnect = !isHahaInjected;
|
|
9
|
+
const getUri = (uri) => {
|
|
10
|
+
return uri;
|
|
11
|
+
};
|
|
12
|
+
return {
|
|
13
|
+
id: "haha",
|
|
14
|
+
internalId: "HAHA",
|
|
15
|
+
name: "HaHa",
|
|
16
|
+
rdns: "haha.me",
|
|
17
|
+
iconUrl: icon,
|
|
18
|
+
installed: isHahaInjected,
|
|
19
|
+
isExtension: true,
|
|
20
|
+
isMobile: true,
|
|
21
|
+
getUri,
|
|
22
|
+
downloadUrl: "https://www.haha.me/",
|
|
23
|
+
createConnector: shouldUseWalletConnect ? getWalletConnectConnector({
|
|
24
|
+
projectId,
|
|
25
|
+
walletConnectParameters
|
|
26
|
+
}) : getInjectedConnector({ namespace: "haha" })
|
|
27
|
+
};
|
|
28
|
+
};
|
|
29
|
+
export {
|
|
30
|
+
hahaWallet
|
|
31
|
+
};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export declare const icon = "";
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
"use client";
|
|
2
|
+
import "../../../chunk-MMUBH76A.js";
|
|
3
|
+
const icon = "";
|
|
4
|
+
export {
|
|
5
|
+
icon
|
|
6
|
+
};
|
|
@@ -1,3 +1,4 @@
|
|
|
1
|
+
import { farcasterWallet } from './farcaster/farcaster.js';
|
|
1
2
|
import { metaMaskWallet } from './metaMask/metaMask.js';
|
|
2
3
|
import { rainbowWallet } from './rainbow/rainbow.js';
|
|
3
4
|
import { walletConnectWallet } from './walletConnect/walletConnect.js';
|
|
@@ -5,5 +6,10 @@ import { coinbaseWallet } from './coinbase/coinbase.js';
|
|
|
5
6
|
import { zerionWallet } from './zerion/zerion.js';
|
|
6
7
|
import { rabbyWallet } from './rabby/rabby.js';
|
|
7
8
|
import { safeWallet } from './safe/safe.js';
|
|
8
|
-
|
|
9
|
+
import { okxWallet } from './okx/okx.js';
|
|
10
|
+
import { backpackWallet } from './backpack/backpack.js';
|
|
11
|
+
import { hahaWallet } from './haha/haha.js';
|
|
12
|
+
import { phantomWallet } from './phantom/phantom.js';
|
|
13
|
+
import { valoraWallet } from './valora/valora.js';
|
|
14
|
+
export { farcasterWallet, metaMaskWallet, rainbowWallet, walletConnectWallet, coinbaseWallet, zerionWallet, rabbyWallet, safeWallet, okxWallet, backpackWallet, hahaWallet, phantomWallet, valoraWallet, };
|
|
9
15
|
export declare const allWallets: ((({ appName, appIcon }: import("./coinbase/coinbase.js").CoinbaseWalletOptions) => import("../../types/Wallet.js").Wallet) | (({ projectId, options }: import("./walletConnect/walletConnect.js").WalletConnectWalletOptions) => import("../../types/Wallet.js").Wallet) | (({ projectId, walletConnectParameters }: import("./metaMask/metaMask.js").MetaMaskWalletOptions) => import("../../types/Wallet.js").Wallet))[];
|
|
@@ -1,5 +1,6 @@
|
|
|
1
1
|
"use client";
|
|
2
2
|
import "../../chunk-MMUBH76A.js";
|
|
3
|
+
import { farcasterWallet } from "./farcaster/farcaster.js";
|
|
3
4
|
import { metaMaskWallet } from "./metaMask/metaMask.js";
|
|
4
5
|
import { rainbowWallet } from "./rainbow/rainbow.js";
|
|
5
6
|
import { walletConnectWallet } from "./walletConnect/walletConnect.js";
|
|
@@ -7,6 +8,11 @@ import { coinbaseWallet } from "./coinbase/coinbase.js";
|
|
|
7
8
|
import { zerionWallet } from "./zerion/zerion.js";
|
|
8
9
|
import { rabbyWallet } from "./rabby/rabby.js";
|
|
9
10
|
import { safeWallet } from "./safe/safe.js";
|
|
11
|
+
import { okxWallet } from "./okx/okx.js";
|
|
12
|
+
import { backpackWallet } from "./backpack/backpack.js";
|
|
13
|
+
import { hahaWallet } from "./haha/haha.js";
|
|
14
|
+
import { phantomWallet } from "./phantom/phantom.js";
|
|
15
|
+
import { valoraWallet } from "./valora/valora.js";
|
|
10
16
|
const allWallets = [
|
|
11
17
|
metaMaskWallet,
|
|
12
18
|
rainbowWallet,
|
|
@@ -14,15 +20,26 @@ const allWallets = [
|
|
|
14
20
|
coinbaseWallet,
|
|
15
21
|
zerionWallet,
|
|
16
22
|
rabbyWallet,
|
|
17
|
-
safeWallet
|
|
23
|
+
safeWallet,
|
|
24
|
+
okxWallet,
|
|
25
|
+
backpackWallet,
|
|
26
|
+
hahaWallet,
|
|
27
|
+
phantomWallet,
|
|
28
|
+
valoraWallet
|
|
18
29
|
];
|
|
19
30
|
export {
|
|
20
31
|
allWallets,
|
|
32
|
+
backpackWallet,
|
|
21
33
|
coinbaseWallet,
|
|
34
|
+
farcasterWallet,
|
|
35
|
+
hahaWallet,
|
|
22
36
|
metaMaskWallet,
|
|
37
|
+
okxWallet,
|
|
38
|
+
phantomWallet,
|
|
23
39
|
rabbyWallet,
|
|
24
40
|
rainbowWallet,
|
|
25
41
|
safeWallet,
|
|
42
|
+
valoraWallet,
|
|
26
43
|
walletConnectWallet,
|
|
27
44
|
zerionWallet
|
|
28
45
|
};
|
|
@@ -55,14 +55,17 @@ const metaMaskWallet = ({ projectId, walletConnectParameters }) => {
|
|
|
55
55
|
if (providerMapTarget) {
|
|
56
56
|
metaMaskTarget = providerMapTarget;
|
|
57
57
|
}
|
|
58
|
+
const deeplinkUri = "metamask://";
|
|
59
|
+
const baseUri = isAndroid() ? `${deeplinkUri}wc` : isIOS() ? !isTelegram() ? (
|
|
60
|
+
// currently broken in MetaMask v6.5.0 https://github.com/MetaMask/metamask-mobile/issues/6457
|
|
61
|
+
`${deeplinkUri}wc`
|
|
62
|
+
) : "https://metamask.app.link/wc" : "https://metamask.app.link/wc";
|
|
58
63
|
const getUri = (uri) => {
|
|
59
|
-
return
|
|
60
|
-
// currently broken in MetaMask v6.5.0 https://github.com/MetaMask/metamask-mobile/issues/6457
|
|
61
|
-
`metamask://wc?uri=${encodeURIComponent(uri)}`
|
|
62
|
-
) : `https://metamask.app.link/wc?uri=${encodeURIComponent(uri)}` : `https://metamask.app.link/wc?uri=${encodeURIComponent(uri)}`;
|
|
64
|
+
return `${baseUri}?uri=${encodeURIComponent(uri)}`;
|
|
63
65
|
};
|
|
64
66
|
return {
|
|
65
67
|
id: "metaMask",
|
|
68
|
+
internalId: "METAMASK",
|
|
66
69
|
name: "MetaMask",
|
|
67
70
|
rdns: "io.metamask",
|
|
68
71
|
iconUrl: icon,
|
|
@@ -71,6 +74,7 @@ const metaMaskWallet = ({ projectId, walletConnectParameters }) => {
|
|
|
71
74
|
isMobile: true,
|
|
72
75
|
downloadUrl: "https://metamask.io/download/",
|
|
73
76
|
getUri,
|
|
77
|
+
deeplinkUri,
|
|
74
78
|
createConnector: isMetaMaskInjected ? getInjectedConnector({
|
|
75
79
|
target: metaMaskTarget
|
|
76
80
|
}) : getWalletConnectConnector({
|
|
@@ -1 +1 @@
|
|
|
1
|
-
export declare const icon = "data:image/svg+xml;base64,
|
|
1
|
+
export declare const icon = "";
|