@getpara/evm-wallet-connectors 1.8.0 → 2.0.0-alpha.3
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/index.d.ts +4 -1
- package/dist/index.js +952 -6
- package/dist/index.js.br +0 -0
- package/dist/index.js.gz +0 -0
- package/dist/providers/EvmExternalWalletContext.d.ts +19 -26
- package/dist/providers/ParaEvmContext.d.ts +10 -11
- package/dist/types/Wallet.d.ts +1 -1
- package/dist/types/utils.d.ts +1 -1
- package/dist/utils/getWalletConnectConnector.d.ts +1 -1
- package/dist/wallets/connectors/index.d.ts +2 -2
- package/package.json +9 -10
- package/dist/chunk-MMUBH76A.js +0 -59
- package/dist/global.d.js +0 -1
- package/dist/package.json +0 -3
- package/dist/providers/EvmExternalWalletContext.js +0 -345
- package/dist/providers/ParaEvmContext.js +0 -115
- package/dist/stores/useStore.js +0 -22
- package/dist/types/Wallet.js +0 -1
- package/dist/types/utils.js +0 -1
- package/dist/utils/computeWalletConnectMetaData.js +0 -18
- package/dist/utils/getInjectedConnector.js +0 -69
- package/dist/utils/getWalletConnectConnector.js +0 -63
- package/dist/utils/getWalletConnectUri.js +0 -22
- package/dist/utils/isEIP6963Connector.js +0 -9
- package/dist/utils/omitUndefinedValues.js +0 -11
- package/dist/utils/uniqueBy.js +0 -14
- package/dist/wallets/connectors/coinbase/coinbase.js +0 -35
- package/dist/wallets/connectors/coinbase/coinbaseIcon.js +0 -6
- package/dist/wallets/connectors/index.js +0 -18
- package/dist/wallets/connectors/metaMask/metaMask.js +0 -84
- package/dist/wallets/connectors/metaMask/metaMaskIcon.js +0 -6
- package/dist/wallets/connectors/rabby/rabby.js +0 -25
- package/dist/wallets/connectors/rabby/rabbyIcon.js +0 -6
- package/dist/wallets/connectors/rainbow/rainbow.js +0 -30
- package/dist/wallets/connectors/rainbow/rainbowIcon.js +0 -6
- package/dist/wallets/connectors/safe/safe.d.ts +0 -2
- package/dist/wallets/connectors/safe/safe.js +0 -26
- package/dist/wallets/connectors/safe/safeIcon.d.ts +0 -1
- package/dist/wallets/connectors/safe/safeIcon.js +0 -6
- package/dist/wallets/connectors/walletConnect/walletConnect.js +0 -22
- package/dist/wallets/connectors/walletConnect/walletConnectIcon.js +0 -6
- package/dist/wallets/connectors/zerion/zerion.js +0 -36
- package/dist/wallets/connectors/zerion/zerionIcon.js +0 -6
- package/dist/wallets/connectorsForWallets.js +0 -73
- package/dist/window.d.js +0 -1
|
@@ -1,115 +0,0 @@
|
|
|
1
|
-
"use client";
|
|
2
|
-
import {
|
|
3
|
-
__async,
|
|
4
|
-
__objRest,
|
|
5
|
-
__spreadProps,
|
|
6
|
-
__spreadValues
|
|
7
|
-
} from "../chunk-MMUBH76A.js";
|
|
8
|
-
import { jsx } from "react/jsx-runtime";
|
|
9
|
-
import { useCallback, useEffect, useMemo } from "react";
|
|
10
|
-
import { createConfig, WagmiProvider } from "wagmi";
|
|
11
|
-
import { connectorsForWallets } from "../wallets/connectorsForWallets.js";
|
|
12
|
-
import { http } from "viem";
|
|
13
|
-
import { computeWalletConnectMetaData } from "../utils/computeWalletConnectMetaData.js";
|
|
14
|
-
import { EvmExternalWalletContext, EvmExternalWalletProvider } from "./EvmExternalWalletContext.js";
|
|
15
|
-
import { useClient, useExternalWalletProviderStore } from "@getpara/react-sdk";
|
|
16
|
-
import { connect } from "wagmi/actions";
|
|
17
|
-
import { paraConnector } from "@getpara/wagmi-v2-integration";
|
|
18
|
-
const createDefaultTransports = (chains) => {
|
|
19
|
-
const transportsObject = chains.reduce((acc, chain) => {
|
|
20
|
-
const key = chain.id;
|
|
21
|
-
acc[key] = http();
|
|
22
|
-
return acc;
|
|
23
|
-
}, {});
|
|
24
|
-
return transportsObject;
|
|
25
|
-
};
|
|
26
|
-
function ParaEvmProvider(_a) {
|
|
27
|
-
var _b = _a, { children, config: _config } = _b, wagmiProviderProps = __objRest(_b, ["children", "config"]);
|
|
28
|
-
var _a2;
|
|
29
|
-
const updateExternalWalletProviderState = useExternalWalletProviderStore((state) => state.updateState);
|
|
30
|
-
const EvmProvider = useExternalWalletProviderStore((state) => state.EvmProvider);
|
|
31
|
-
const evmContext = useExternalWalletProviderStore((state) => state.evmContext);
|
|
32
|
-
const para = (_a2 = _config.para) != null ? _a2 : useClient();
|
|
33
|
-
const _b2 = _config, {
|
|
34
|
-
projectId,
|
|
35
|
-
appName,
|
|
36
|
-
appDescription,
|
|
37
|
-
appIcon,
|
|
38
|
-
appUrl,
|
|
39
|
-
wallets,
|
|
40
|
-
chains,
|
|
41
|
-
transports,
|
|
42
|
-
paraDisableModal,
|
|
43
|
-
paraOptions
|
|
44
|
-
} = _b2, wagmiConfigParams = __objRest(_b2, [
|
|
45
|
-
"projectId",
|
|
46
|
-
"appName",
|
|
47
|
-
"appDescription",
|
|
48
|
-
"appIcon",
|
|
49
|
-
"appUrl",
|
|
50
|
-
"wallets",
|
|
51
|
-
"chains",
|
|
52
|
-
"transports",
|
|
53
|
-
"paraDisableModal",
|
|
54
|
-
"paraOptions"
|
|
55
|
-
]);
|
|
56
|
-
const wcMetadata = computeWalletConnectMetaData({ appName, appDescription, appUrl, appIcon });
|
|
57
|
-
const paraConnectorInstance = para ? paraConnector({
|
|
58
|
-
para,
|
|
59
|
-
chains: [...chains],
|
|
60
|
-
disableModal: paraDisableModal != null ? paraDisableModal : true,
|
|
61
|
-
appName,
|
|
62
|
-
options: paraOptions != null ? paraOptions : {}
|
|
63
|
-
}) : void 0;
|
|
64
|
-
const allConnectors = useMemo(() => {
|
|
65
|
-
const baseConnectors = connectorsForWallets(wallets, {
|
|
66
|
-
projectId,
|
|
67
|
-
appName,
|
|
68
|
-
appDescription,
|
|
69
|
-
appUrl,
|
|
70
|
-
appIcon,
|
|
71
|
-
walletConnectParameters: { metadata: wcMetadata }
|
|
72
|
-
});
|
|
73
|
-
return paraConnectorInstance ? [...baseConnectors, paraConnectorInstance] : baseConnectors;
|
|
74
|
-
}, [wallets, projectId, appName, appDescription, appUrl, appIcon, wcMetadata, paraConnectorInstance]);
|
|
75
|
-
const config = useMemo(
|
|
76
|
-
() => createConfig(__spreadProps(__spreadValues({}, wagmiConfigParams), {
|
|
77
|
-
chains,
|
|
78
|
-
transports: transports || createDefaultTransports(chains),
|
|
79
|
-
connectors: allConnectors
|
|
80
|
-
})),
|
|
81
|
-
[wagmiConfigParams, chains, transports, allConnectors]
|
|
82
|
-
);
|
|
83
|
-
const connectParaEvmWallet = useCallback(() => __async(this, null, function* () {
|
|
84
|
-
if (!paraConnectorInstance) {
|
|
85
|
-
return { error: "No para connector instance" };
|
|
86
|
-
}
|
|
87
|
-
try {
|
|
88
|
-
const result = yield connect(config, { connector: paraConnectorInstance });
|
|
89
|
-
return { result };
|
|
90
|
-
} catch (err) {
|
|
91
|
-
const error = err instanceof Error ? err.message : "Unknown error";
|
|
92
|
-
return { error };
|
|
93
|
-
}
|
|
94
|
-
}), [paraConnectorInstance, config, connect]);
|
|
95
|
-
useEffect(() => {
|
|
96
|
-
if (!evmContext || !EvmProvider) {
|
|
97
|
-
updateExternalWalletProviderState({
|
|
98
|
-
EvmProvider: EvmExternalWalletProvider,
|
|
99
|
-
evmContext: EvmExternalWalletContext
|
|
100
|
-
});
|
|
101
|
-
}
|
|
102
|
-
}, []);
|
|
103
|
-
useEffect(() => {
|
|
104
|
-
updateExternalWalletProviderState({
|
|
105
|
-
connectParaEvmWallet: paraConnectorInstance ? connectParaEvmWallet : void 0
|
|
106
|
-
});
|
|
107
|
-
}, [paraConnectorInstance]);
|
|
108
|
-
if (!evmContext || !EvmProvider) {
|
|
109
|
-
return null;
|
|
110
|
-
}
|
|
111
|
-
return /* @__PURE__ */ jsx(WagmiProvider, __spreadProps(__spreadValues({ config }, wagmiProviderProps), { children }));
|
|
112
|
-
}
|
|
113
|
-
export {
|
|
114
|
-
ParaEvmProvider
|
|
115
|
-
};
|
package/dist/stores/useStore.js
DELETED
|
@@ -1,22 +0,0 @@
|
|
|
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
|
-
};
|
package/dist/types/Wallet.js
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
"use client";
|
package/dist/types/utils.js
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
"use client";
|
|
@@ -1,18 +0,0 @@
|
|
|
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
|
-
};
|
|
@@ -1,69 +0,0 @@
|
|
|
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
|
-
};
|
|
@@ -1,63 +0,0 @@
|
|
|
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
|
-
throw new Error(
|
|
52
|
-
"No projectId found. Every dApp must now provide a WalletConnect Cloud projectId to enable WalletConnect v2. Sign up for your free key at https://cloud.walletconnect.com/sign-in"
|
|
53
|
-
);
|
|
54
|
-
}
|
|
55
|
-
return (walletDetails) => createWalletConnectConnector({
|
|
56
|
-
projectId,
|
|
57
|
-
walletDetails,
|
|
58
|
-
walletConnectParameters
|
|
59
|
-
});
|
|
60
|
-
}
|
|
61
|
-
export {
|
|
62
|
-
getWalletConnectConnector
|
|
63
|
-
};
|
|
@@ -1,22 +0,0 @@
|
|
|
1
|
-
"use client";
|
|
2
|
-
import {
|
|
3
|
-
__async
|
|
4
|
-
} from "../chunk-MMUBH76A.js";
|
|
5
|
-
const getWalletConnectUri = (connector, uriConverter) => __async(void 0, null, function* () {
|
|
6
|
-
const provider = yield connector.getProvider();
|
|
7
|
-
if (connector.type === "coinbaseWallet") {
|
|
8
|
-
return provider.qrUrl;
|
|
9
|
-
}
|
|
10
|
-
return new Promise(
|
|
11
|
-
(resolve) => (
|
|
12
|
-
// Wagmi v2 doesn't have a return type for provider yet
|
|
13
|
-
// @ts-expect-error
|
|
14
|
-
provider.once("display_uri", (uri) => {
|
|
15
|
-
resolve(uriConverter ? uriConverter(uri) : uri);
|
|
16
|
-
})
|
|
17
|
-
)
|
|
18
|
-
);
|
|
19
|
-
});
|
|
20
|
-
export {
|
|
21
|
-
getWalletConnectUri
|
|
22
|
-
};
|
|
@@ -1,9 +0,0 @@
|
|
|
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
|
-
};
|
package/dist/utils/uniqueBy.js
DELETED
|
@@ -1,14 +0,0 @@
|
|
|
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
|
-
};
|
|
@@ -1,35 +0,0 @@
|
|
|
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
|
-
name: "Coinbase Wallet",
|
|
15
|
-
rdns: "com.coinbase.wallet",
|
|
16
|
-
iconUrl: icon,
|
|
17
|
-
// Note that we never resolve `installed` to `false` because the
|
|
18
|
-
// Coinbase Wallet SDK falls back to other connection methods if
|
|
19
|
-
// the injected connector isn't available
|
|
20
|
-
installed: isCoinbaseInjected,
|
|
21
|
-
isExtension: true,
|
|
22
|
-
isMobile: true,
|
|
23
|
-
downloadUrl: "https://www.coinbase.com/wallet/downloads",
|
|
24
|
-
getUri,
|
|
25
|
-
createConnector: (walletDetails) => createConnector((config) => __spreadValues(__spreadValues({}, coinbaseWagmiWallet({
|
|
26
|
-
version: "4",
|
|
27
|
-
appName,
|
|
28
|
-
appLogoUrl: appIcon,
|
|
29
|
-
preference: "eoaOnly"
|
|
30
|
-
})(config)), walletDetails))
|
|
31
|
-
};
|
|
32
|
-
};
|
|
33
|
-
export {
|
|
34
|
-
coinbaseWallet
|
|
35
|
-
};
|
|
@@ -1,6 +0,0 @@
|
|
|
1
|
-
"use client";
|
|
2
|
-
import "../../../chunk-MMUBH76A.js";
|
|
3
|
-
const icon = "";
|
|
4
|
-
export {
|
|
5
|
-
icon
|
|
6
|
-
};
|
|
@@ -1,18 +0,0 @@
|
|
|
1
|
-
"use client";
|
|
2
|
-
import "../../chunk-MMUBH76A.js";
|
|
3
|
-
import { metaMaskWallet } from "./metaMask/metaMask.js";
|
|
4
|
-
import { rainbowWallet } from "./rainbow/rainbow.js";
|
|
5
|
-
import { walletConnectWallet } from "./walletConnect/walletConnect.js";
|
|
6
|
-
import { coinbaseWallet } from "./coinbase/coinbase.js";
|
|
7
|
-
import { zerionWallet } from "./zerion/zerion.js";
|
|
8
|
-
import { rabbyWallet } from "./rabby/rabby.js";
|
|
9
|
-
import { safeWallet } from "./safe/safe.js";
|
|
10
|
-
export {
|
|
11
|
-
coinbaseWallet,
|
|
12
|
-
metaMaskWallet,
|
|
13
|
-
rabbyWallet,
|
|
14
|
-
rainbowWallet,
|
|
15
|
-
safeWallet,
|
|
16
|
-
walletConnectWallet,
|
|
17
|
-
zerionWallet
|
|
18
|
-
};
|
|
@@ -1,84 +0,0 @@
|
|
|
1
|
-
"use client";
|
|
2
|
-
import "../../../chunk-MMUBH76A.js";
|
|
3
|
-
import { isAndroid, isIOS, isTelegram } from "@getpara/react-sdk";
|
|
4
|
-
import { getInjectedConnector, getInjectedProvider } from "../../../utils/getInjectedConnector.js";
|
|
5
|
-
import { getWalletConnectConnector } from "../../../utils/getWalletConnectConnector.js";
|
|
6
|
-
import { icon } from "./metaMaskIcon.js";
|
|
7
|
-
function isMetaMask(ethereum) {
|
|
8
|
-
if (!(ethereum == null ? void 0 : ethereum.isMetaMask)) return false;
|
|
9
|
-
if (ethereum.isBraveWallet && !ethereum._events && !ethereum._state) return false;
|
|
10
|
-
if (ethereum.isApexWallet) return false;
|
|
11
|
-
if (ethereum.isAvalanche) return false;
|
|
12
|
-
if (ethereum.isBackpack) return false;
|
|
13
|
-
if (ethereum.isBifrost) return false;
|
|
14
|
-
if (ethereum.isBitKeep) return false;
|
|
15
|
-
if (ethereum.isBitski) return false;
|
|
16
|
-
if (ethereum.isBlockWallet) return false;
|
|
17
|
-
if (ethereum.isCoinbaseWallet) return false;
|
|
18
|
-
if (ethereum.isDawn) return false;
|
|
19
|
-
if (ethereum.isEnkrypt) return false;
|
|
20
|
-
if (ethereum.isExodus) return false;
|
|
21
|
-
if (ethereum.isFrame) return false;
|
|
22
|
-
if (ethereum.isFrontier) return false;
|
|
23
|
-
if (ethereum.isGamestop) return false;
|
|
24
|
-
if (ethereum.isHyperPay) return false;
|
|
25
|
-
if (ethereum.isImToken) return false;
|
|
26
|
-
if (ethereum.isKuCoinWallet) return false;
|
|
27
|
-
if (ethereum.isMathWallet) return false;
|
|
28
|
-
if (ethereum.isNestWallet) return false;
|
|
29
|
-
if (ethereum.isOkxWallet || ethereum.isOKExWallet) return false;
|
|
30
|
-
if (ethereum.isOneInchIOSWallet || ethereum.isOneInchAndroidWallet) return false;
|
|
31
|
-
if (ethereum.isOpera) return false;
|
|
32
|
-
if (ethereum.isPhantom) return false;
|
|
33
|
-
if (ethereum.isPortal) return false;
|
|
34
|
-
if (ethereum.isRabby) return false;
|
|
35
|
-
if (ethereum.isSafe) return false;
|
|
36
|
-
if (ethereum.isRainbow) return false;
|
|
37
|
-
if (ethereum.isStatus) return false;
|
|
38
|
-
if (ethereum.isTalisman) return false;
|
|
39
|
-
if (ethereum.isTally) return false;
|
|
40
|
-
if (ethereum.isTokenPocket) return false;
|
|
41
|
-
if (ethereum.isTokenary) return false;
|
|
42
|
-
if (ethereum.isTrust || ethereum.isTrustWallet) return false;
|
|
43
|
-
if (ethereum.isXDEFI) return false;
|
|
44
|
-
if (ethereum.isZeal) return false;
|
|
45
|
-
if (ethereum.isZerion) return false;
|
|
46
|
-
if (ethereum.__seif) return false;
|
|
47
|
-
return true;
|
|
48
|
-
}
|
|
49
|
-
const metaMaskWallet = ({ projectId, walletConnectParameters }) => {
|
|
50
|
-
var _a, _b, _c, _d;
|
|
51
|
-
let metaMaskTarget = typeof window !== "undefined" ? (_c = (_b = (_a = window.ethereum) == null ? void 0 : _a.providers) == null ? void 0 : _b.find(isMetaMask)) != null ? _c : window.ethereum : void 0;
|
|
52
|
-
const metaMaskInjectedProvider = metaMaskTarget ? metaMaskTarget : getInjectedProvider({ flag: "isMetaMask" });
|
|
53
|
-
const isMetaMaskInjected = !!metaMaskInjectedProvider && metaMaskInjectedProvider.isMetaMask;
|
|
54
|
-
const providerMapTarget = (_d = metaMaskTarget == null ? void 0 : metaMaskTarget.providerMap) == null ? void 0 : _d.get("MetaMask");
|
|
55
|
-
if (providerMapTarget) {
|
|
56
|
-
metaMaskTarget = providerMapTarget;
|
|
57
|
-
}
|
|
58
|
-
const getUri = (uri) => {
|
|
59
|
-
return isAndroid() ? `metamask://wc?uri=${encodeURIComponent(uri)}` : isIOS() ? !isTelegram() ? (
|
|
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)}`;
|
|
63
|
-
};
|
|
64
|
-
return {
|
|
65
|
-
id: "metaMask",
|
|
66
|
-
name: "MetaMask",
|
|
67
|
-
rdns: "io.metamask",
|
|
68
|
-
iconUrl: icon,
|
|
69
|
-
installed: isMetaMaskInjected,
|
|
70
|
-
isExtension: true,
|
|
71
|
-
isMobile: true,
|
|
72
|
-
downloadUrl: "https://metamask.io/download/",
|
|
73
|
-
getUri,
|
|
74
|
-
createConnector: isMetaMaskInjected ? getInjectedConnector({
|
|
75
|
-
target: metaMaskTarget
|
|
76
|
-
}) : getWalletConnectConnector({
|
|
77
|
-
projectId,
|
|
78
|
-
walletConnectParameters
|
|
79
|
-
})
|
|
80
|
-
};
|
|
81
|
-
};
|
|
82
|
-
export {
|
|
83
|
-
metaMaskWallet
|
|
84
|
-
};
|
|
@@ -1,6 +0,0 @@
|
|
|
1
|
-
"use client";
|
|
2
|
-
import "../../../chunk-MMUBH76A.js";
|
|
3
|
-
const icon = "";
|
|
4
|
-
export {
|
|
5
|
-
icon
|
|
6
|
-
};
|
|
@@ -1,25 +0,0 @@
|
|
|
1
|
-
"use client";
|
|
2
|
-
import "../../../chunk-MMUBH76A.js";
|
|
3
|
-
import { getInjectedConnector, hasInjectedProvider } from "../../../utils/getInjectedConnector.js";
|
|
4
|
-
import { getWalletConnectConnector } from "../../../utils/getWalletConnectConnector.js";
|
|
5
|
-
import { icon } from "./rabbyIcon.js";
|
|
6
|
-
const rabbyWallet = ({ projectId, walletConnectParameters }) => {
|
|
7
|
-
const isRabbyInjected = hasInjectedProvider({ flag: "isRabby" });
|
|
8
|
-
return {
|
|
9
|
-
id: "rabby",
|
|
10
|
-
name: "Rabby Wallet",
|
|
11
|
-
rdns: "io.rabby",
|
|
12
|
-
iconUrl: icon,
|
|
13
|
-
installed: isRabbyInjected,
|
|
14
|
-
isExtension: true,
|
|
15
|
-
isMobile: false,
|
|
16
|
-
downloadUrl: "https://rabby.io",
|
|
17
|
-
createConnector: isRabbyInjected ? getInjectedConnector({ flag: "isRabby" }) : getWalletConnectConnector({
|
|
18
|
-
projectId,
|
|
19
|
-
walletConnectParameters
|
|
20
|
-
})
|
|
21
|
-
};
|
|
22
|
-
};
|
|
23
|
-
export {
|
|
24
|
-
rabbyWallet
|
|
25
|
-
};
|
|
@@ -1,6 +0,0 @@
|
|
|
1
|
-
"use client";
|
|
2
|
-
import "../../../chunk-MMUBH76A.js";
|
|
3
|
-
const icon = "";
|
|
4
|
-
export {
|
|
5
|
-
icon
|
|
6
|
-
};
|
|
@@ -1,30 +0,0 @@
|
|
|
1
|
-
"use client";
|
|
2
|
-
import "../../../chunk-MMUBH76A.js";
|
|
3
|
-
import { isAndroid, isIOS, isTelegram } from "@getpara/react-sdk";
|
|
4
|
-
import { getInjectedConnector, hasInjectedProvider } from "../../../utils/getInjectedConnector.js";
|
|
5
|
-
import { getWalletConnectConnector } from "../../../utils/getWalletConnectConnector.js";
|
|
6
|
-
import { icon } from "./rainbowIcon.js";
|
|
7
|
-
const rainbowWallet = ({ projectId, walletConnectParameters }) => {
|
|
8
|
-
const isRainbowInjected = hasInjectedProvider({ flag: "isRainbow" });
|
|
9
|
-
const getUri = (uri) => {
|
|
10
|
-
return isAndroid() ? `rainbow://wc?uri=${encodeURIComponent(uri)}` : isIOS() ? !isTelegram() ? `rainbow://wc?uri=${encodeURIComponent(uri)}` : `https://rnbwapp.com/wc?uri=${encodeURIComponent(uri)}` : `https://rnbwapp.com/wc?uri=${encodeURIComponent(uri)}`;
|
|
11
|
-
};
|
|
12
|
-
return {
|
|
13
|
-
id: "rainbow",
|
|
14
|
-
name: "Rainbow",
|
|
15
|
-
rdns: "me.rainbow",
|
|
16
|
-
iconUrl: icon,
|
|
17
|
-
installed: isRainbowInjected,
|
|
18
|
-
isExtension: true,
|
|
19
|
-
isMobile: true,
|
|
20
|
-
downloadUrl: "https://rainbow.me/",
|
|
21
|
-
getUri,
|
|
22
|
-
createConnector: isRainbowInjected ? getInjectedConnector({ flag: "isRainbow" }) : getWalletConnectConnector({
|
|
23
|
-
projectId,
|
|
24
|
-
walletConnectParameters
|
|
25
|
-
})
|
|
26
|
-
};
|
|
27
|
-
};
|
|
28
|
-
export {
|
|
29
|
-
rainbowWallet
|
|
30
|
-
};
|
|
@@ -1,6 +0,0 @@
|
|
|
1
|
-
"use client";
|
|
2
|
-
import "../../../chunk-MMUBH76A.js";
|
|
3
|
-
const icon = "";
|
|
4
|
-
export {
|
|
5
|
-
icon
|
|
6
|
-
};
|
|
@@ -1,26 +0,0 @@
|
|
|
1
|
-
"use client";
|
|
2
|
-
import {
|
|
3
|
-
__spreadValues
|
|
4
|
-
} from "../../../chunk-MMUBH76A.js";
|
|
5
|
-
import { createConnector } from "wagmi";
|
|
6
|
-
import { safe } from "wagmi/connectors";
|
|
7
|
-
import { icon } from "./safeIcon.js";
|
|
8
|
-
const safeWallet = () => ({
|
|
9
|
-
id: "safe",
|
|
10
|
-
name: "Safe",
|
|
11
|
-
rdns: "io.safe",
|
|
12
|
-
iconUrl: icon,
|
|
13
|
-
installed: (
|
|
14
|
-
// Only allowed in iframe context
|
|
15
|
-
!(typeof window === "undefined") && (window == null ? void 0 : window.parent) !== window
|
|
16
|
-
),
|
|
17
|
-
isExtension: false,
|
|
18
|
-
isMobile: false,
|
|
19
|
-
downloadUrl: "https://safe.global",
|
|
20
|
-
createConnector: (walletDetails) => {
|
|
21
|
-
return createConnector((config) => __spreadValues(__spreadValues({}, safe()(config)), walletDetails));
|
|
22
|
-
}
|
|
23
|
-
});
|
|
24
|
-
export {
|
|
25
|
-
safeWallet
|
|
26
|
-
};
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
export declare const icon = "";
|
|
@@ -1,6 +0,0 @@
|
|
|
1
|
-
"use client";
|
|
2
|
-
import "../../../chunk-MMUBH76A.js";
|
|
3
|
-
const icon = "";
|
|
4
|
-
export {
|
|
5
|
-
icon
|
|
6
|
-
};
|