@getpara/evm-wallet-connectors 2.0.0-dev.0 → 2.0.0-dev.2
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/dist/chunk-MMUBH76A.js +59 -0
- package/dist/global.d.js +1 -0
- package/dist/index.d.ts +4 -2
- package/dist/index.js +8 -874
- package/dist/package.json +3 -0
- package/dist/providers/EvmExternalWalletContext.d.ts +6 -32
- package/dist/providers/EvmExternalWalletContext.js +457 -0
- package/dist/providers/ParaEvmContext.d.ts +2 -1
- package/dist/providers/ParaEvmContext.js +123 -0
- 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/useStore.js +22 -0
- package/dist/stores/wagmiConfigStore.d.ts +14 -0
- package/dist/stores/wagmiConfigStore.js +16 -0
- package/dist/types/Wallet.d.ts +3 -0
- package/dist/types/Wallet.js +1 -0
- package/dist/types/utils.d.ts +1 -1
- package/dist/types/utils.js +1 -0
- package/dist/utils/computeWalletConnectMetaData.js +18 -0
- package/dist/utils/getInjectedConnector.d.ts +4 -0
- package/dist/utils/getInjectedConnector.js +69 -0
- package/dist/utils/getWalletConnectConnector.js +61 -0
- package/dist/utils/getWalletConnectUri.js +25 -0
- package/dist/utils/isEIP6963Connector.js +9 -0
- package/dist/utils/omitUndefinedValues.js +11 -0
- package/dist/utils/resolveWalletList.d.ts +3 -0
- package/dist/utils/resolveWalletList.js +16 -0
- package/dist/utils/uniqueBy.js +14 -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 +36 -0
- package/dist/wallets/connectors/coinbase/coinbaseIcon.js +6 -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 +8 -1
- package/dist/wallets/connectors/index.js +45 -0
- package/dist/wallets/connectors/metaMask/metaMask.js +85 -0
- package/dist/wallets/connectors/metaMask/metaMaskIcon.d.ts +1 -1
- package/dist/wallets/connectors/metaMask/metaMaskIcon.js +6 -0
- 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 +26 -0
- package/dist/wallets/connectors/rabby/rabbyIcon.js +6 -0
- package/dist/wallets/connectors/rainbow/rainbow.js +31 -0
- package/dist/wallets/connectors/rainbow/rainbowIcon.js +6 -0
- package/dist/wallets/connectors/safe/safe.d.ts +2 -0
- package/dist/wallets/connectors/safe/safe.js +27 -0
- package/dist/wallets/connectors/safe/safeIcon.d.ts +1 -0
- package/dist/wallets/connectors/safe/safeIcon.js +6 -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 +23 -0
- package/dist/wallets/connectors/walletConnect/walletConnectIcon.js +6 -0
- package/dist/wallets/connectors/zerion/zerion.js +37 -0
- package/dist/wallets/connectors/zerion/zerionIcon.js +6 -0
- package/dist/wallets/connectorsForWallets.d.ts +4 -1
- package/dist/wallets/connectorsForWallets.js +84 -0
- package/dist/window.d.js +1 -0
- package/package.json +33 -23
- package/dist/index.js.br +0 -0
- package/dist/index.js.gz +0 -0
|
@@ -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,22 @@
|
|
|
1
|
+
"use client";
|
|
2
|
+
import {
|
|
3
|
+
__spreadValues
|
|
4
|
+
} from "../chunk-MMUBH76A.js";
|
|
5
|
+
import { create } from "zustand";
|
|
6
|
+
import { syncTabs } from "zustand-sync-tabs";
|
|
7
|
+
const useExternalWalletStore = create(
|
|
8
|
+
syncTabs(
|
|
9
|
+
(set) => ({
|
|
10
|
+
isConnecting: false,
|
|
11
|
+
updateState: (state) => {
|
|
12
|
+
set(__spreadValues({}, state));
|
|
13
|
+
}
|
|
14
|
+
}),
|
|
15
|
+
{
|
|
16
|
+
name: "para-evm-external-wallet-state"
|
|
17
|
+
}
|
|
18
|
+
)
|
|
19
|
+
);
|
|
20
|
+
export {
|
|
21
|
+
useExternalWalletStore
|
|
22
|
+
};
|
|
@@ -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
|
@@ -3,12 +3,15 @@ import { WalletConnectParameters } from 'wagmi/connectors';
|
|
|
3
3
|
import { CoinbaseWalletOptions } from '../wallets/connectors/coinbase/coinbase.js';
|
|
4
4
|
import { WalletConnectWalletOptions } from '../wallets/connectors/walletConnect/walletConnect.js';
|
|
5
5
|
import { type WalletMetadata } from '@getpara/react-common';
|
|
6
|
+
import ParaWeb from '@getpara/web-sdk';
|
|
6
7
|
export type Wallet = {
|
|
7
8
|
createConnector?: (walletDetails: WalletDetailsParams) => CreateConnectorFn;
|
|
8
9
|
createMobileConnector?: (walletDetails: WalletDetailsParams) => CreateConnectorFn;
|
|
9
10
|
getUri?: (uri: string) => string;
|
|
10
11
|
} & WalletMetadata;
|
|
11
12
|
export interface DefaultWalletOptions {
|
|
13
|
+
para?: ParaWeb;
|
|
14
|
+
createFarcasterConnector?: () => any;
|
|
12
15
|
projectId: string;
|
|
13
16
|
walletConnectParameters?: ParaWalletConnectParameters;
|
|
14
17
|
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
"use client";
|
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' | '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
|
} & {
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
"use client";
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
"use client";
|
|
2
|
+
import "../chunk-MMUBH76A.js";
|
|
3
|
+
const computeWalletConnectMetaData = ({
|
|
4
|
+
appName,
|
|
5
|
+
appDescription,
|
|
6
|
+
appUrl,
|
|
7
|
+
appIcon
|
|
8
|
+
}) => {
|
|
9
|
+
return {
|
|
10
|
+
name: appName,
|
|
11
|
+
description: appDescription != null ? appDescription : appName,
|
|
12
|
+
url: appUrl != null ? appUrl : typeof window !== "undefined" ? window.location.href : "",
|
|
13
|
+
icons: [...appIcon ? [appIcon] : []]
|
|
14
|
+
};
|
|
15
|
+
};
|
|
16
|
+
export {
|
|
17
|
+
computeWalletConnectMetaData
|
|
18
|
+
};
|
|
@@ -4,6 +4,10 @@ export declare function hasInjectedProvider({ flag, namespace }: {
|
|
|
4
4
|
flag?: WalletProviderFlags;
|
|
5
5
|
namespace?: string;
|
|
6
6
|
}): boolean;
|
|
7
|
+
export declare function getInjectedProvider({ flag, namespace }: {
|
|
8
|
+
flag?: WalletProviderFlags;
|
|
9
|
+
namespace?: string;
|
|
10
|
+
}): any;
|
|
7
11
|
export declare function getInjectedConnector({ flag, namespace, target, }: {
|
|
8
12
|
flag?: WalletProviderFlags;
|
|
9
13
|
namespace?: string;
|
|
@@ -0,0 +1,69 @@
|
|
|
1
|
+
"use client";
|
|
2
|
+
import {
|
|
3
|
+
__spreadValues
|
|
4
|
+
} from "../chunk-MMUBH76A.js";
|
|
5
|
+
import { createConnector } from "wagmi";
|
|
6
|
+
import { injected } from "wagmi/connectors";
|
|
7
|
+
function getExplicitInjectedProvider(flag) {
|
|
8
|
+
const _window = typeof window !== "undefined" ? window : void 0;
|
|
9
|
+
if (typeof _window === "undefined" || typeof _window.ethereum === "undefined") return;
|
|
10
|
+
const providers = _window.ethereum.providers;
|
|
11
|
+
return providers ? providers.find((provider) => provider[flag]) : _window.ethereum[flag] ? _window.ethereum : void 0;
|
|
12
|
+
}
|
|
13
|
+
function getWindowProviderNamespace(namespace) {
|
|
14
|
+
const providerSearch = (provider, namespace2) => {
|
|
15
|
+
const [property, ...path] = namespace2.split(".");
|
|
16
|
+
const _provider = provider[property];
|
|
17
|
+
if (_provider) {
|
|
18
|
+
if (path.length === 0) return _provider;
|
|
19
|
+
return providerSearch(_provider, path.join("."));
|
|
20
|
+
}
|
|
21
|
+
};
|
|
22
|
+
if (typeof window !== "undefined") return providerSearch(window, namespace);
|
|
23
|
+
}
|
|
24
|
+
function hasInjectedProvider({ flag, namespace }) {
|
|
25
|
+
if (namespace && typeof getWindowProviderNamespace(namespace) !== "undefined") return true;
|
|
26
|
+
if (flag && typeof getExplicitInjectedProvider(flag) !== "undefined") return true;
|
|
27
|
+
return false;
|
|
28
|
+
}
|
|
29
|
+
function getInjectedProvider({ flag, namespace }) {
|
|
30
|
+
var _a;
|
|
31
|
+
const _window = typeof window !== "undefined" ? window : void 0;
|
|
32
|
+
if (typeof _window === "undefined") return;
|
|
33
|
+
if (namespace) {
|
|
34
|
+
const windowProvider = getWindowProviderNamespace(namespace);
|
|
35
|
+
if (windowProvider) return windowProvider;
|
|
36
|
+
}
|
|
37
|
+
const providers = (_a = _window.ethereum) == null ? void 0 : _a.providers;
|
|
38
|
+
if (flag) {
|
|
39
|
+
const provider = getExplicitInjectedProvider(flag);
|
|
40
|
+
if (provider) return provider;
|
|
41
|
+
}
|
|
42
|
+
if (typeof providers !== "undefined" && providers.length > 0) return providers[0];
|
|
43
|
+
return _window.ethereum;
|
|
44
|
+
}
|
|
45
|
+
function createInjectedConnector(provider) {
|
|
46
|
+
return (walletDetails) => {
|
|
47
|
+
const injectedConfig = provider ? {
|
|
48
|
+
target: () => ({
|
|
49
|
+
id: walletDetails.paraDetails.id,
|
|
50
|
+
name: walletDetails.paraDetails.name,
|
|
51
|
+
provider
|
|
52
|
+
})
|
|
53
|
+
} : {};
|
|
54
|
+
return createConnector((config) => __spreadValues(__spreadValues({}, injected(injectedConfig)(config)), walletDetails));
|
|
55
|
+
};
|
|
56
|
+
}
|
|
57
|
+
function getInjectedConnector({
|
|
58
|
+
flag,
|
|
59
|
+
namespace,
|
|
60
|
+
target
|
|
61
|
+
}) {
|
|
62
|
+
const provider = target ? target : getInjectedProvider({ flag, namespace });
|
|
63
|
+
return createInjectedConnector(provider);
|
|
64
|
+
}
|
|
65
|
+
export {
|
|
66
|
+
getInjectedConnector,
|
|
67
|
+
getInjectedProvider,
|
|
68
|
+
hasInjectedProvider
|
|
69
|
+
};
|
|
@@ -0,0 +1,61 @@
|
|
|
1
|
+
"use client";
|
|
2
|
+
import {
|
|
3
|
+
__spreadProps,
|
|
4
|
+
__spreadValues
|
|
5
|
+
} from "../chunk-MMUBH76A.js";
|
|
6
|
+
import { createConnector } from "wagmi";
|
|
7
|
+
import { walletConnect } from "wagmi/connectors";
|
|
8
|
+
const walletConnectInstances = /* @__PURE__ */ new Map();
|
|
9
|
+
const getOrCreateWalletConnectInstance = ({
|
|
10
|
+
projectId,
|
|
11
|
+
walletConnectParameters,
|
|
12
|
+
paraDetailsShowQrModal
|
|
13
|
+
}) => {
|
|
14
|
+
let config = __spreadProps(__spreadValues({}, walletConnectParameters ? walletConnectParameters : {}), {
|
|
15
|
+
projectId,
|
|
16
|
+
showQrModal: false
|
|
17
|
+
// Required. Otherwise WalletConnect modal (Web3Modal) will popup during time of connection for a wallet
|
|
18
|
+
});
|
|
19
|
+
if (paraDetailsShowQrModal) {
|
|
20
|
+
config = __spreadProps(__spreadValues({}, config), { showQrModal: true });
|
|
21
|
+
}
|
|
22
|
+
const serializedConfig = JSON.stringify(config);
|
|
23
|
+
const sharedWalletConnector = walletConnectInstances.get(serializedConfig);
|
|
24
|
+
if (sharedWalletConnector) {
|
|
25
|
+
return sharedWalletConnector;
|
|
26
|
+
}
|
|
27
|
+
const newWalletConnectInstance = walletConnect(config);
|
|
28
|
+
walletConnectInstances.set(serializedConfig, newWalletConnectInstance);
|
|
29
|
+
return newWalletConnectInstance;
|
|
30
|
+
};
|
|
31
|
+
function createWalletConnectConnector({
|
|
32
|
+
projectId,
|
|
33
|
+
walletDetails,
|
|
34
|
+
walletConnectParameters
|
|
35
|
+
}) {
|
|
36
|
+
return createConnector((config) => __spreadProps(__spreadValues(__spreadValues({}, getOrCreateWalletConnectInstance({
|
|
37
|
+
projectId,
|
|
38
|
+
walletConnectParameters,
|
|
39
|
+
// Used in `connectorsForWallets` to add another
|
|
40
|
+
// walletConnect wallet into Para with modal popup option
|
|
41
|
+
paraDetailsShowQrModal: walletDetails.paraDetails.showQrModal
|
|
42
|
+
})(config)), walletDetails), {
|
|
43
|
+
id: walletDetails.paraDetails.id
|
|
44
|
+
}));
|
|
45
|
+
}
|
|
46
|
+
function getWalletConnectConnector({
|
|
47
|
+
projectId,
|
|
48
|
+
walletConnectParameters
|
|
49
|
+
}) {
|
|
50
|
+
if (!projectId || projectId === "") {
|
|
51
|
+
return;
|
|
52
|
+
}
|
|
53
|
+
return (walletDetails) => createWalletConnectConnector({
|
|
54
|
+
projectId,
|
|
55
|
+
walletDetails,
|
|
56
|
+
walletConnectParameters
|
|
57
|
+
});
|
|
58
|
+
}
|
|
59
|
+
export {
|
|
60
|
+
getWalletConnectConnector
|
|
61
|
+
};
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
"use client";
|
|
2
|
+
import {
|
|
3
|
+
__async
|
|
4
|
+
} from "../chunk-MMUBH76A.js";
|
|
5
|
+
const getWalletConnectUri = (connector, uriConverter) => __async(void 0, null, function* () {
|
|
6
|
+
var _a, _b;
|
|
7
|
+
const provider = yield (_b = (_a = connector.getProvider) == null ? void 0 : _a.call(connector)) != null ? _b : void 0;
|
|
8
|
+
if (connector.type === "coinbaseWallet" && (provider == null ? void 0 : provider.qrUrl)) {
|
|
9
|
+
return provider.qrUrl;
|
|
10
|
+
}
|
|
11
|
+
if (!provider || typeof provider.once !== "function" && typeof provider.on !== "function") {
|
|
12
|
+
throw new Error("display_uri event not supported for this connector");
|
|
13
|
+
}
|
|
14
|
+
const listen = typeof provider.once === "function" ? provider.once.bind(provider) : provider.on.bind(provider);
|
|
15
|
+
return new Promise((resolve, reject) => {
|
|
16
|
+
const cancel = setTimeout(() => reject(new Error("display_uri event not emitted")), 1e4);
|
|
17
|
+
listen("display_uri", (uri) => {
|
|
18
|
+
clearTimeout(cancel);
|
|
19
|
+
resolve(uriConverter ? uriConverter(uri) : uri);
|
|
20
|
+
});
|
|
21
|
+
});
|
|
22
|
+
});
|
|
23
|
+
export {
|
|
24
|
+
getWalletConnectUri
|
|
25
|
+
};
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
"use client";
|
|
2
|
+
import "../chunk-MMUBH76A.js";
|
|
3
|
+
const isEIP6963Connector = (wallet) => {
|
|
4
|
+
var _a;
|
|
5
|
+
return !!(!wallet.isRainbowKitConnector && ((_a = wallet.icon) == null ? void 0 : _a.startsWith("data:image")) && wallet.uid && wallet.name);
|
|
6
|
+
};
|
|
7
|
+
export {
|
|
8
|
+
isEIP6963Connector
|
|
9
|
+
};
|
|
@@ -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,14 @@
|
|
|
1
|
+
"use client";
|
|
2
|
+
import "../chunk-MMUBH76A.js";
|
|
3
|
+
function uniqueBy(items, key) {
|
|
4
|
+
const filtered = [];
|
|
5
|
+
for (const item of items) {
|
|
6
|
+
if (!filtered.some((x) => x[key] === item[key])) {
|
|
7
|
+
filtered.push(item);
|
|
8
|
+
}
|
|
9
|
+
}
|
|
10
|
+
return filtered;
|
|
11
|
+
}
|
|
12
|
+
export {
|
|
13
|
+
uniqueBy
|
|
14
|
+
};
|
|
@@ -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.mobile",
|
|
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,36 @@
|
|
|
1
|
+
"use client";
|
|
2
|
+
import {
|
|
3
|
+
__spreadValues
|
|
4
|
+
} from "../../../chunk-MMUBH76A.js";
|
|
5
|
+
import { createConnector } from "wagmi";
|
|
6
|
+
import { coinbaseWallet as coinbaseWagmiWallet } from "wagmi/connectors";
|
|
7
|
+
import { icon } from "./coinbaseIcon.js";
|
|
8
|
+
import { hasInjectedProvider } from "../../../utils/getInjectedConnector.js";
|
|
9
|
+
const coinbaseWallet = ({ appName, appIcon }) => {
|
|
10
|
+
const isCoinbaseInjected = hasInjectedProvider({ flag: "isCoinbaseWallet" });
|
|
11
|
+
const getUri = (uri) => uri;
|
|
12
|
+
return {
|
|
13
|
+
id: "coinbase",
|
|
14
|
+
internalId: "COINBASE",
|
|
15
|
+
name: "Coinbase Wallet",
|
|
16
|
+
rdns: "com.coinbase.wallet",
|
|
17
|
+
iconUrl: icon,
|
|
18
|
+
// Note that we never resolve `installed` to `false` because the
|
|
19
|
+
// Coinbase Wallet SDK falls back to other connection methods if
|
|
20
|
+
// the injected connector isn't available
|
|
21
|
+
installed: isCoinbaseInjected,
|
|
22
|
+
isExtension: true,
|
|
23
|
+
isMobile: true,
|
|
24
|
+
downloadUrl: "https://www.coinbase.com/wallet/downloads",
|
|
25
|
+
getUri,
|
|
26
|
+
createConnector: (walletDetails) => createConnector((config) => __spreadValues(__spreadValues({}, coinbaseWagmiWallet({
|
|
27
|
+
version: "4",
|
|
28
|
+
appName,
|
|
29
|
+
appLogoUrl: appIcon,
|
|
30
|
+
preference: "eoaOnly"
|
|
31
|
+
})(config)), walletDetails))
|
|
32
|
+
};
|
|
33
|
+
};
|
|
34
|
+
export {
|
|
35
|
+
coinbaseWallet
|
|
36
|
+
};
|
|
@@ -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://warpcast.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,8 +1,15 @@
|
|
|
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';
|
|
4
5
|
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';
|
|
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, };
|
|
8
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))[];
|