@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,6 +1,6 @@
|
|
|
1
1
|
"use client";
|
|
2
2
|
import "../../../chunk-MMUBH76A.js";
|
|
3
|
-
const icon = "data:image/svg+xml;base64,
|
|
3
|
+
const icon = "";
|
|
4
4
|
export {
|
|
5
5
|
icon
|
|
6
6
|
};
|
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
"use client";
|
|
2
|
+
import "../../../chunk-MMUBH76A.js";
|
|
3
|
+
import { isAndroid } from "@getpara/web-sdk";
|
|
4
|
+
import { getInjectedConnector, hasInjectedProvider } from "../../../utils/getInjectedConnector.js";
|
|
5
|
+
import { getWalletConnectConnector } from "../../../utils/getWalletConnectConnector.js";
|
|
6
|
+
import { icon } from "./okxIcon.js";
|
|
7
|
+
const okxWallet = ({ projectId, walletConnectParameters }) => {
|
|
8
|
+
const isOKXInjected = hasInjectedProvider({ namespace: "okxwallet" });
|
|
9
|
+
const shouldUseWalletConnect = !isOKXInjected;
|
|
10
|
+
const getUri = (uri) => {
|
|
11
|
+
return isAndroid() ? uri : `okex://main/wc?uri=${encodeURIComponent(uri)}`;
|
|
12
|
+
};
|
|
13
|
+
return {
|
|
14
|
+
id: "okx",
|
|
15
|
+
internalId: "OKX",
|
|
16
|
+
name: "OKX Wallet",
|
|
17
|
+
rdns: "com.okex.wallet",
|
|
18
|
+
iconUrl: icon,
|
|
19
|
+
installed: isOKXInjected,
|
|
20
|
+
isExtension: true,
|
|
21
|
+
isMobile: true,
|
|
22
|
+
getUri,
|
|
23
|
+
downloadUrl: "https://okx.com/download",
|
|
24
|
+
createConnector: shouldUseWalletConnect ? getWalletConnectConnector({
|
|
25
|
+
projectId,
|
|
26
|
+
walletConnectParameters
|
|
27
|
+
}) : getInjectedConnector({ namespace: "okxwallet" })
|
|
28
|
+
};
|
|
29
|
+
};
|
|
30
|
+
export {
|
|
31
|
+
okxWallet
|
|
32
|
+
};
|
|
@@ -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 "./phantomIcon.js";
|
|
5
|
+
import { getWalletConnectConnector } from "../../../utils/getWalletConnectConnector.js";
|
|
6
|
+
const phantomWallet = ({ projectId, walletConnectParameters }) => {
|
|
7
|
+
const isPhantomInjected = hasInjectedProvider({ namespace: "phantom.ethereum" });
|
|
8
|
+
const shouldUseWalletConnect = !isPhantomInjected;
|
|
9
|
+
const getUri = (uri) => {
|
|
10
|
+
return uri;
|
|
11
|
+
};
|
|
12
|
+
return {
|
|
13
|
+
id: "phantom",
|
|
14
|
+
internalId: "PHANTOM",
|
|
15
|
+
name: "Phantom",
|
|
16
|
+
rdns: "app.phantom",
|
|
17
|
+
iconUrl: icon,
|
|
18
|
+
installed: isPhantomInjected,
|
|
19
|
+
isExtension: true,
|
|
20
|
+
isMobile: true,
|
|
21
|
+
getUri,
|
|
22
|
+
downloadUrl: "https://phantom.app/download",
|
|
23
|
+
createConnector: shouldUseWalletConnect ? getWalletConnectConnector({
|
|
24
|
+
projectId,
|
|
25
|
+
walletConnectParameters
|
|
26
|
+
}) : getInjectedConnector({ namespace: "phantom.ethereum" })
|
|
27
|
+
};
|
|
28
|
+
};
|
|
29
|
+
export {
|
|
30
|
+
phantomWallet
|
|
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
|
+
};
|
|
@@ -6,11 +6,17 @@ import { getWalletConnectConnector } from "../../../utils/getWalletConnectConnec
|
|
|
6
6
|
import { icon } from "./rainbowIcon.js";
|
|
7
7
|
const rainbowWallet = ({ projectId, walletConnectParameters }) => {
|
|
8
8
|
const isRainbowInjected = hasInjectedProvider({ flag: "isRainbow" });
|
|
9
|
+
const deeplinkUri = "rainbow://";
|
|
10
|
+
const baseUri = isAndroid() ? `${deeplinkUri}wc` : isIOS() ? !isTelegram() ? (
|
|
11
|
+
// currently broken in MetaMask v6.5.0 https://github.com/MetaMask/metamask-mobile/issues/6457
|
|
12
|
+
`${deeplinkUri}wc`
|
|
13
|
+
) : "https://rnbwapp.com/wc" : "https://rnbwapp.com/wc";
|
|
9
14
|
const getUri = (uri) => {
|
|
10
|
-
return
|
|
15
|
+
return `${baseUri}?uri=${encodeURIComponent(uri)}`;
|
|
11
16
|
};
|
|
12
17
|
return {
|
|
13
18
|
id: "rainbow",
|
|
19
|
+
internalId: "RAINBOW",
|
|
14
20
|
name: "Rainbow",
|
|
15
21
|
rdns: "me.rainbow",
|
|
16
22
|
iconUrl: icon,
|
|
@@ -19,6 +25,7 @@ const rainbowWallet = ({ projectId, walletConnectParameters }) => {
|
|
|
19
25
|
isMobile: true,
|
|
20
26
|
downloadUrl: "https://rainbow.me/",
|
|
21
27
|
getUri,
|
|
28
|
+
deeplinkUri,
|
|
22
29
|
createConnector: isRainbowInjected ? getInjectedConnector({ flag: "isRainbow" }) : getWalletConnectConnector({
|
|
23
30
|
projectId,
|
|
24
31
|
walletConnectParameters
|
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
"use client";
|
|
2
|
+
import "../../../chunk-MMUBH76A.js";
|
|
3
|
+
import { getWalletConnectConnector } from "../../../utils/getWalletConnectConnector.js";
|
|
4
|
+
import { icon } from "./valoraIcon.js";
|
|
5
|
+
import { isMobile } from "@getpara/web-sdk";
|
|
6
|
+
const valoraWallet = ({ projectId, walletConnectParameters }) => {
|
|
7
|
+
const getUri = (uri) => {
|
|
8
|
+
return !isMobile() ? uri : `celo://wallet/wc?uri=${encodeURIComponent(uri)}`;
|
|
9
|
+
};
|
|
10
|
+
return {
|
|
11
|
+
id: "valora",
|
|
12
|
+
internalId: "VALORA",
|
|
13
|
+
name: "Valora",
|
|
14
|
+
rdns: "co.clabs.valora",
|
|
15
|
+
iconUrl: icon,
|
|
16
|
+
installed: false,
|
|
17
|
+
isExtension: false,
|
|
18
|
+
isMobile: true,
|
|
19
|
+
downloadUrl: "https://valora.xyz",
|
|
20
|
+
getUri,
|
|
21
|
+
createConnector: getWalletConnectConnector({
|
|
22
|
+
projectId,
|
|
23
|
+
walletConnectParameters
|
|
24
|
+
})
|
|
25
|
+
};
|
|
26
|
+
};
|
|
27
|
+
export {
|
|
28
|
+
valoraWallet
|
|
29
|
+
};
|
|
@@ -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
|
+
};
|
|
@@ -9,11 +9,14 @@ const zerionWallet = ({ projectId, walletConnectParameters }) => {
|
|
|
9
9
|
namespace: "zerionWallet",
|
|
10
10
|
flag: "isZerion"
|
|
11
11
|
});
|
|
12
|
+
const deeplinkUri = "zerion://";
|
|
13
|
+
const baseUri = isTelegram() && isIOS() ? "https://app.zerion.io/wc" : `${deeplinkUri}wc`;
|
|
12
14
|
const getUri = (uri) => {
|
|
13
|
-
return
|
|
15
|
+
return `${baseUri}?uri=${encodeURIComponent(uri)}`;
|
|
14
16
|
};
|
|
15
17
|
return {
|
|
16
18
|
id: "zerion",
|
|
19
|
+
internalId: "ZERION",
|
|
17
20
|
name: "Zerion",
|
|
18
21
|
rdns: "io.zerion.wallet",
|
|
19
22
|
iconUrl: icon,
|
|
@@ -21,6 +24,7 @@ const zerionWallet = ({ projectId, walletConnectParameters }) => {
|
|
|
21
24
|
isExtension: true,
|
|
22
25
|
isMobile: true,
|
|
23
26
|
getUri,
|
|
27
|
+
deeplinkUri,
|
|
24
28
|
downloadUrl: "https://zerion.io/download",
|
|
25
29
|
createConnector: isZerionInjected ? getInjectedConnector({
|
|
26
30
|
namespace: "zerionWallet",
|
|
@@ -1,10 +1,13 @@
|
|
|
1
1
|
import type { CreateConnectorFn } from 'wagmi';
|
|
2
2
|
import type { WalletList } from '../types/Wallet.js';
|
|
3
3
|
import type { ParaWalletConnectParameters, Wallet } from '../types/Wallet.js';
|
|
4
|
+
import ParaWeb from '@getpara/web-sdk';
|
|
4
5
|
export interface WalletListItem extends Wallet {
|
|
5
6
|
index: number;
|
|
6
7
|
}
|
|
7
8
|
export interface ConnectorsForWalletsParameters {
|
|
9
|
+
para: ParaWeb;
|
|
10
|
+
createFarcasterConnector?: () => any;
|
|
8
11
|
projectId: string;
|
|
9
12
|
appName: string;
|
|
10
13
|
appDescription?: string;
|
|
@@ -12,4 +15,4 @@ export interface ConnectorsForWalletsParameters {
|
|
|
12
15
|
appIcon?: string;
|
|
13
16
|
walletConnectParameters?: ParaWalletConnectParameters;
|
|
14
17
|
}
|
|
15
|
-
export declare const connectorsForWallets: (walletList: WalletList, { projectId, walletConnectParameters, appName, appDescription, appUrl, appIcon }: ConnectorsForWalletsParameters) => CreateConnectorFn[];
|
|
18
|
+
export declare const connectorsForWallets: (walletList: WalletList, { para, projectId, walletConnectParameters, appName, appDescription, appUrl, appIcon, createFarcasterConnector, }: ConnectorsForWalletsParameters) => CreateConnectorFn[];
|
|
@@ -7,7 +7,16 @@ import {
|
|
|
7
7
|
import { uniqueBy } from "../utils/uniqueBy.js";
|
|
8
8
|
import { computeWalletConnectMetaData } from "../utils/computeWalletConnectMetaData.js";
|
|
9
9
|
import { omitUndefinedValues } from "../utils/omitUndefinedValues.js";
|
|
10
|
-
const connectorsForWallets = (walletList, {
|
|
10
|
+
const connectorsForWallets = (walletList, {
|
|
11
|
+
para,
|
|
12
|
+
projectId,
|
|
13
|
+
walletConnectParameters,
|
|
14
|
+
appName,
|
|
15
|
+
appDescription,
|
|
16
|
+
appUrl,
|
|
17
|
+
appIcon,
|
|
18
|
+
createFarcasterConnector
|
|
19
|
+
}) => {
|
|
11
20
|
if (!walletList.length) {
|
|
12
21
|
return [];
|
|
13
22
|
}
|
|
@@ -23,6 +32,7 @@ const connectorsForWallets = (walletList, { projectId, walletConnectParameters,
|
|
|
23
32
|
walletList.forEach((createWallet) => {
|
|
24
33
|
index++;
|
|
25
34
|
const wallet = createWallet({
|
|
35
|
+
para,
|
|
26
36
|
projectId,
|
|
27
37
|
appName,
|
|
28
38
|
appIcon,
|
|
@@ -34,7 +44,8 @@ const connectorsForWallets = (walletList, { projectId, walletConnectParameters,
|
|
|
34
44
|
// `walletConnectWallet` wallet will have `walletConnectParameters` property
|
|
35
45
|
walletConnectParameters: __spreadValues({
|
|
36
46
|
metadata: walletConnectMetaData
|
|
37
|
-
}, walletConnectParameters)
|
|
47
|
+
}, walletConnectParameters),
|
|
48
|
+
createFarcasterConnector
|
|
38
49
|
});
|
|
39
50
|
const walletListItem = __spreadProps(__spreadValues({}, wallet), {
|
|
40
51
|
index
|
|
@@ -51,7 +62,7 @@ const connectorsForWallets = (walletList, { projectId, walletConnectParameters,
|
|
|
51
62
|
}), additionalParaParams ? additionalParaParams : {}))
|
|
52
63
|
};
|
|
53
64
|
};
|
|
54
|
-
const isWalletConnectConnector = walletMeta.
|
|
65
|
+
const isWalletConnectConnector = walletMeta.internalId === "WALLETCONNECT";
|
|
55
66
|
if (isWalletConnectConnector && createConnector) {
|
|
56
67
|
connectors.push(
|
|
57
68
|
createConnector(
|
package/package.json
CHANGED
|
@@ -1,43 +1,51 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@getpara/evm-wallet-connectors",
|
|
3
|
-
"version": "2.0.0-alpha.
|
|
4
|
-
"type": "module",
|
|
5
|
-
"main": "dist/index.js",
|
|
6
|
-
"types": "dist/index.d.ts",
|
|
7
|
-
"exports": {
|
|
8
|
-
".": "./dist/index.js",
|
|
9
|
-
"./connectors": "./dist/wallets/connectors/index.js"
|
|
10
|
-
},
|
|
3
|
+
"version": "2.0.0-alpha.71",
|
|
11
4
|
"dependencies": {
|
|
12
5
|
"@coinbase/wallet-sdk": "4.3.0",
|
|
13
|
-
"@getpara/wagmi-v2-connector": "2.0.0-alpha.
|
|
14
|
-
"@getpara/web-sdk": "2.0.0-alpha.
|
|
15
|
-
"
|
|
16
|
-
"wagmi": "^2.14.16",
|
|
6
|
+
"@getpara/wagmi-v2-connector": "2.0.0-alpha.71",
|
|
7
|
+
"@getpara/web-sdk": "2.0.0-alpha.71",
|
|
8
|
+
"@walletconnect/ethereum-provider": "^2.22.4",
|
|
17
9
|
"zustand": "^4.5.2",
|
|
18
10
|
"zustand-sync-tabs": "^0.2.2"
|
|
19
11
|
},
|
|
20
|
-
"scripts": {
|
|
21
|
-
"build": "rm -rf dist && yarn typegen && node ./scripts/build.mjs",
|
|
22
|
-
"typegen": "tsc --emitDeclarationOnly",
|
|
23
|
-
"test": "vitest run --coverage"
|
|
24
|
-
},
|
|
25
12
|
"devDependencies": {
|
|
26
|
-
"@getpara/react-common": "2.0.0-alpha.
|
|
27
|
-
"@tanstack/react-query": "
|
|
13
|
+
"@getpara/react-common": "2.0.0-alpha.71",
|
|
14
|
+
"@tanstack/react-query": "^5.74.0",
|
|
28
15
|
"@types/react": "^18.0.31",
|
|
29
16
|
"@types/react-dom": "^18.2.7",
|
|
30
|
-
"typescript": "^5.
|
|
31
|
-
"viem": "2.
|
|
32
|
-
"wagmi": "2.
|
|
17
|
+
"typescript": "^5.8.3",
|
|
18
|
+
"viem": "^2.38.5",
|
|
19
|
+
"wagmi": "^2.14.16"
|
|
33
20
|
},
|
|
34
|
-
"
|
|
35
|
-
"
|
|
36
|
-
"
|
|
21
|
+
"exports": {
|
|
22
|
+
".": "./dist/index.js",
|
|
23
|
+
"./connectors": "./dist/wallets/connectors/index.js"
|
|
37
24
|
},
|
|
38
25
|
"files": [
|
|
39
26
|
"dist",
|
|
40
27
|
"package.json"
|
|
41
28
|
],
|
|
42
|
-
"gitHead": "
|
|
29
|
+
"gitHead": "30e5bad6a141f1b56959432f11aaf1536b84dece",
|
|
30
|
+
"main": "dist/index.js",
|
|
31
|
+
"peerDependencies": {
|
|
32
|
+
"@farcaster/miniapp-wagmi-connector": "^1.0.0",
|
|
33
|
+
"@tanstack/react-query": ">=5.0.0",
|
|
34
|
+
"react": ">=18",
|
|
35
|
+
"react-dom": ">=18",
|
|
36
|
+
"viem": "2.x",
|
|
37
|
+
"wagmi": "^2.9.0"
|
|
38
|
+
},
|
|
39
|
+
"peerDependenciesMeta": {
|
|
40
|
+
"@farcaster/miniapp-wagmi-connector": {
|
|
41
|
+
"optional": true
|
|
42
|
+
}
|
|
43
|
+
},
|
|
44
|
+
"scripts": {
|
|
45
|
+
"build": "rm -rf dist && yarn typegen && node ./scripts/build.mjs",
|
|
46
|
+
"test": "vitest run --coverage",
|
|
47
|
+
"typegen": "tsc --emitDeclarationOnly"
|
|
48
|
+
},
|
|
49
|
+
"type": "module",
|
|
50
|
+
"types": "dist/index.d.ts"
|
|
43
51
|
}
|