-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathWalletProvider.js
More file actions
110 lines (110 loc) · 15 KB
/
WalletProvider.js
File metadata and controls
110 lines (110 loc) · 15 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
import { WalletContext, WalletStatus, } from '@nestwallet/use-wallet';
import { WalletController, } from '@nestwallet/wallet-controller';
import React, { useEffect, useMemo, useState } from 'react';
const EMPTY_ARRAY = [];
const EMPTY_SUPPORT_FEATURES = new Set();
export function WalletProvider({ children, defaultNetwork, walletConnectChainIds, connectorOpts, pushServerOpts, createReadonlyWalletSession, selectExtension, waitingChromeExtensionInstallCheck, dangerously__chromeExtensionCompatibleBrowserCheck, plugins, }) {
const [controller] = useState(() => new WalletController({
defaultNetwork,
walletConnectChainIds,
connectorOpts,
pushServerOpts,
createReadonlyWalletSession,
selectExtension,
waitingChromeExtensionInstallCheck,
dangerously__chromeExtensionCompatibleBrowserCheck,
plugins,
}));
const [availableConnectTypes, setAvailableConnectTypes] = useState(() => []);
const [availableInstallTypes, setAvailableInstallTypes] = useState(() => []);
const [availableConnections, setAvailableConnections] = useState(() => []);
const [availableInstallations, setAvailableInstallations] = useState(() => []);
const [states, setStates] = useState({
status: WalletStatus.INITIALIZING,
network: defaultNetwork,
});
useEffect(() => {
const availableConnectTypesSubscription = controller
.availableConnectTypes()
.subscribe({
next: (value) => {
setAvailableConnectTypes(value);
},
});
const availableInstallTypesSubscription = controller
.availableInstallTypes()
.subscribe({
next: (value) => {
setAvailableInstallTypes(value);
},
});
const availableConnectionsSubscription = controller
.availableConnections()
.subscribe({
next: (value) => {
setAvailableConnections(value);
},
});
const availableInstallationsSubscription = controller
.availableInstallations()
.subscribe({
next: (value) => {
setAvailableInstallations(value);
},
});
const statesSubscription = controller.states().subscribe({
next: (value) => {
setStates(value);
},
});
return () => {
availableConnectTypesSubscription.unsubscribe();
availableInstallTypesSubscription.unsubscribe();
availableConnectionsSubscription.unsubscribe();
availableInstallationsSubscription.unsubscribe();
statesSubscription.unsubscribe();
};
}, [controller]);
const state = useMemo(() => {
return {
availableConnectTypes,
availableInstallTypes,
availableConnections,
availableInstallations,
status: states.status,
network: states.network,
wallets: states.status === WalletStatus.WALLET_CONNECTED
? states.wallets
: EMPTY_ARRAY,
install: controller.install,
connect: controller.connect,
connectReadonly: controller.connectReadonly,
disconnect: controller.disconnect,
connection: states.status === WalletStatus.WALLET_CONNECTED
? states.connection
: undefined,
supportFeatures: states.status === WalletStatus.WALLET_CONNECTED
? states.supportFeatures
: EMPTY_SUPPORT_FEATURES,
post: controller.post,
sign: controller.sign,
signBytes: controller.signBytes,
hasCW20Tokens: controller.hasCW20Tokens,
addCW20Tokens: controller.addCW20Tokens,
hasNetwork: controller.hasNetwork,
addNetwork: controller.addNetwork,
refetchStates: controller.refetchStates,
recheckStatus: controller.refetchStates,
isChromeExtensionCompatibleBrowser: controller.isChromeExtensionCompatibleBrowser,
};
}, [
availableConnectTypes,
availableInstallTypes,
availableConnections,
availableInstallations,
controller,
states,
]);
return (React.createElement(WalletContext.Provider, { value: state }, children));
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"WalletProvider.js","sourceRoot":"","sources":["../../../src/@terra-money/wallet-provider/WalletProvider.tsx"],"names":[],"mappings":"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","sourcesContent":["import { TerraWebExtensionFeatures } from '@terra-money/web-extension-interface';\nimport {\n  Connection,\n  ConnectType,\n  Installation,\n  Wallet,\n  WalletContext,\n  WalletInfo,\n  WalletStates,\n  WalletStatus,\n} from '@terra-money/use-wallet';\nimport {\n  WalletController,\n  WalletControllerOptions,\n} from '@terra-money/wallet-controller';\nimport React, { ReactNode, useEffect, useMemo, useState } from 'react';\n\nexport interface WalletProviderProps extends WalletControllerOptions {\n  children: ReactNode;\n}\n\nconst EMPTY_ARRAY: WalletInfo[] = [];\nconst EMPTY_SUPPORT_FEATURES = new Set<TerraWebExtensionFeatures>();\n\nexport function WalletProvider({\n  children,\n  defaultNetwork,\n  walletConnectChainIds,\n  connectorOpts,\n  pushServerOpts,\n  createReadonlyWalletSession,\n  selectExtension,\n  waitingChromeExtensionInstallCheck,\n  dangerously__chromeExtensionCompatibleBrowserCheck,\n  plugins,\n}: WalletProviderProps) {\n  const [controller] = useState<WalletController>(\n    () =>\n      new WalletController({\n        defaultNetwork,\n        walletConnectChainIds,\n        connectorOpts,\n        pushServerOpts,\n        createReadonlyWalletSession,\n        selectExtension,\n        waitingChromeExtensionInstallCheck,\n        dangerously__chromeExtensionCompatibleBrowserCheck,\n        plugins,\n      }),\n  );\n\n  const [availableConnectTypes, setAvailableConnectTypes] = useState<\n    ConnectType[]\n  >(() => []);\n\n  const [availableInstallTypes, setAvailableInstallTypes] = useState<\n    ConnectType[]\n  >(() => []);\n\n  const [availableConnections, setAvailableConnections] = useState<\n    Connection[]\n  >(() => []);\n\n  const [availableInstallations, setAvailableInstallations] = useState<\n    Installation[]\n  >(() => []);\n\n  const [states, setStates] = useState<WalletStates>({\n    status: WalletStatus.INITIALIZING,\n    network: defaultNetwork,\n  });\n\n  useEffect(() => {\n    const availableConnectTypesSubscription = controller\n      .availableConnectTypes()\n      .subscribe({\n        next: (value) => {\n          setAvailableConnectTypes(value);\n        },\n      });\n\n    const availableInstallTypesSubscription = controller\n      .availableInstallTypes()\n      .subscribe({\n        next: (value) => {\n          setAvailableInstallTypes(value);\n        },\n      });\n\n    const availableConnectionsSubscription = controller\n      .availableConnections()\n      .subscribe({\n        next: (value) => {\n          setAvailableConnections(value);\n        },\n      });\n\n    const availableInstallationsSubscription = controller\n      .availableInstallations()\n      .subscribe({\n        next: (value) => {\n          setAvailableInstallations(value);\n        },\n      });\n\n    const statesSubscription = controller.states().subscribe({\n      next: (value) => {\n        setStates(value);\n      },\n    });\n\n    return () => {\n      availableConnectTypesSubscription.unsubscribe();\n      availableInstallTypesSubscription.unsubscribe();\n      availableConnectionsSubscription.unsubscribe();\n      availableInstallationsSubscription.unsubscribe();\n      statesSubscription.unsubscribe();\n    };\n  }, [controller]);\n\n  const state = useMemo<Wallet>(() => {\n    return {\n      availableConnectTypes,\n      availableInstallTypes,\n      availableConnections,\n      availableInstallations,\n      status: states.status,\n      network: states.network,\n      wallets:\n        states.status === WalletStatus.WALLET_CONNECTED\n          ? states.wallets\n          : EMPTY_ARRAY,\n      install: controller.install,\n      connect: controller.connect,\n      connectReadonly: controller.connectReadonly,\n      disconnect: controller.disconnect,\n      connection:\n        states.status === WalletStatus.WALLET_CONNECTED\n          ? states.connection\n          : undefined,\n      supportFeatures:\n        states.status === WalletStatus.WALLET_CONNECTED\n          ? states.supportFeatures\n          : EMPTY_SUPPORT_FEATURES,\n      post: controller.post,\n      sign: controller.sign,\n      signBytes: controller.signBytes,\n      hasCW20Tokens: controller.hasCW20Tokens,\n      addCW20Tokens: controller.addCW20Tokens,\n      hasNetwork: controller.hasNetwork,\n      addNetwork: controller.addNetwork,\n      refetchStates: controller.refetchStates,\n      recheckStatus: controller.refetchStates,\n      isChromeExtensionCompatibleBrowser:\n        controller.isChromeExtensionCompatibleBrowser,\n    };\n  }, [\n    availableConnectTypes,\n    availableInstallTypes,\n    availableConnections,\n    availableInstallations,\n    controller,\n    states,\n  ]);\n\n  return (\n    <WalletContext.Provider value={state}>{children}</WalletContext.Provider>\n  );\n}\n"]}