@ksangkuk10/wallet-controller 1.7.14

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.
Files changed (124) hide show
  1. package/README.md +7 -0
  2. package/_commonjs/controller.js +704 -0
  3. package/_commonjs/env.js +9 -0
  4. package/_commonjs/exception/isError.js +15 -0
  5. package/_commonjs/exception/mapExtensionTxError.js +46 -0
  6. package/_commonjs/exception/mapWalletConnectError.js +69 -0
  7. package/_commonjs/getChainOptions.js +57 -0
  8. package/_commonjs/index.js +22 -0
  9. package/_commonjs/modules/connect-modal/index.js +80 -0
  10. package/_commonjs/modules/connect-modal/style.js +161 -0
  11. package/_commonjs/modules/extension-router/ExtensionRouter.js +241 -0
  12. package/_commonjs/modules/extension-router/index.js +19 -0
  13. package/_commonjs/modules/extension-router/modal.js +80 -0
  14. package/_commonjs/modules/extension-router/modal.style.js +161 -0
  15. package/_commonjs/modules/extension-router/multiChannel.js +18 -0
  16. package/_commonjs/modules/extension-router/session.js +37 -0
  17. package/_commonjs/modules/extension-router/types.js +16 -0
  18. package/_commonjs/modules/legacy-extension/LegacyExtensionConnector.js +143 -0
  19. package/_commonjs/modules/legacy-extension/createFixedExtension.js +236 -0
  20. package/_commonjs/modules/legacy-extension/index.js +19 -0
  21. package/_commonjs/modules/readonly-wallet/connect.js +24 -0
  22. package/_commonjs/modules/readonly-wallet/index.js +20 -0
  23. package/_commonjs/modules/readonly-wallet/modal.js +123 -0
  24. package/_commonjs/modules/readonly-wallet/modal.style.js +204 -0
  25. package/_commonjs/modules/readonly-wallet/storage.js +40 -0
  26. package/_commonjs/modules/readonly-wallet/types.js +3 -0
  27. package/_commonjs/modules/walletconnect/connect.js +421 -0
  28. package/_commonjs/modules/walletconnect/errors.js +51 -0
  29. package/_commonjs/modules/walletconnect/impl/socket-transport/index.js +204 -0
  30. package/_commonjs/modules/walletconnect/impl/socket-transport/network.js +30 -0
  31. package/_commonjs/modules/walletconnect/index.js +22 -0
  32. package/_commonjs/modules/walletconnect/modal.js +147 -0
  33. package/_commonjs/modules/walletconnect/modal.style.js +138 -0
  34. package/_commonjs/modules/walletconnect/types.js +13 -0
  35. package/_commonjs/operators/getExtensions.js +55 -0
  36. package/_commonjs/operators/toConnectedWallet.js +24 -0
  37. package/_commonjs/operators/toLcdClient.js +15 -0
  38. package/_commonjs/utils/browser-check.js +47 -0
  39. package/_commonjs/utils/checkExtensionReady.js +28 -0
  40. package/_commonjs/utils/sortConnections.js +13 -0
  41. package/_commonjs/verifyBytes.js +19 -0
  42. package/controller.d.ts +220 -0
  43. package/controller.js +697 -0
  44. package/env.d.ts +2 -0
  45. package/env.js +5 -0
  46. package/exception/isError.d.ts +3 -0
  47. package/exception/isError.js +11 -0
  48. package/exception/mapExtensionTxError.d.ts +5 -0
  49. package/exception/mapExtensionTxError.js +41 -0
  50. package/exception/mapWalletConnectError.d.ts +6 -0
  51. package/exception/mapWalletConnectError.js +63 -0
  52. package/getChainOptions.d.ts +3 -0
  53. package/getChainOptions.js +53 -0
  54. package/index.d.ts +6 -0
  55. package/index.js +6 -0
  56. package/modules/connect-modal/index.d.ts +2 -0
  57. package/modules/connect-modal/index.js +76 -0
  58. package/modules/connect-modal/style.d.ts +1 -0
  59. package/modules/connect-modal/style.js +158 -0
  60. package/modules/extension-router/ExtensionRouter.d.ts +43 -0
  61. package/modules/extension-router/ExtensionRouter.js +237 -0
  62. package/modules/extension-router/index.d.ts +2 -0
  63. package/modules/extension-router/index.js +3 -0
  64. package/modules/extension-router/modal.d.ts +2 -0
  65. package/modules/extension-router/modal.js +76 -0
  66. package/modules/extension-router/modal.style.d.ts +1 -0
  67. package/modules/extension-router/modal.style.js +158 -0
  68. package/modules/extension-router/multiChannel.d.ts +13 -0
  69. package/modules/extension-router/multiChannel.js +14 -0
  70. package/modules/extension-router/session.d.ts +8 -0
  71. package/modules/extension-router/session.js +31 -0
  72. package/modules/extension-router/types.d.ts +35 -0
  73. package/modules/extension-router/types.js +13 -0
  74. package/modules/legacy-extension/LegacyExtensionConnector.d.ts +30 -0
  75. package/modules/legacy-extension/LegacyExtensionConnector.js +139 -0
  76. package/modules/legacy-extension/createFixedExtension.d.ts +46 -0
  77. package/modules/legacy-extension/createFixedExtension.js +232 -0
  78. package/modules/legacy-extension/index.d.ts +2 -0
  79. package/modules/legacy-extension/index.js +3 -0
  80. package/modules/readonly-wallet/connect.d.ts +8 -0
  81. package/modules/readonly-wallet/connect.js +19 -0
  82. package/modules/readonly-wallet/index.d.ts +3 -0
  83. package/modules/readonly-wallet/index.js +4 -0
  84. package/modules/readonly-wallet/modal.d.ts +7 -0
  85. package/modules/readonly-wallet/modal.js +119 -0
  86. package/modules/readonly-wallet/modal.style.d.ts +1 -0
  87. package/modules/readonly-wallet/modal.style.js +201 -0
  88. package/modules/readonly-wallet/storage.d.ts +4 -0
  89. package/modules/readonly-wallet/storage.js +34 -0
  90. package/modules/readonly-wallet/types.d.ts +5 -0
  91. package/modules/readonly-wallet/types.js +2 -0
  92. package/modules/walletconnect/connect.d.ts +42 -0
  93. package/modules/walletconnect/connect.js +390 -0
  94. package/modules/walletconnect/errors.d.ts +22 -0
  95. package/modules/walletconnect/errors.js +41 -0
  96. package/modules/walletconnect/impl/socket-transport/index.d.ts +39 -0
  97. package/modules/walletconnect/impl/socket-transport/index.js +199 -0
  98. package/modules/walletconnect/impl/socket-transport/network.d.ts +8 -0
  99. package/modules/walletconnect/impl/socket-transport/network.js +28 -0
  100. package/modules/walletconnect/index.d.ts +5 -0
  101. package/modules/walletconnect/index.js +6 -0
  102. package/modules/walletconnect/modal.d.ts +12 -0
  103. package/modules/walletconnect/modal.js +143 -0
  104. package/modules/walletconnect/modal.style.d.ts +1 -0
  105. package/modules/walletconnect/modal.style.js +135 -0
  106. package/modules/walletconnect/types.d.ts +24 -0
  107. package/modules/walletconnect/types.js +10 -0
  108. package/operators/getExtensions.d.ts +9 -0
  109. package/operators/getExtensions.js +51 -0
  110. package/operators/toConnectedWallet.d.ts +4 -0
  111. package/operators/toConnectedWallet.js +20 -0
  112. package/operators/toLcdClient.d.ts +4 -0
  113. package/operators/toLcdClient.js +11 -0
  114. package/package.json +550 -0
  115. package/utils/browser-check.d.ts +3 -0
  116. package/utils/browser-check.js +38 -0
  117. package/utils/checkExtensionReady.d.ts +6 -0
  118. package/utils/checkExtensionReady.js +24 -0
  119. package/utils/sortConnections.d.ts +2 -0
  120. package/utils/sortConnections.js +9 -0
  121. package/verifyBytes.d.ts +4 -0
  122. package/verifyBytes.js +15 -0
  123. package/~/.npm/_cacache/content-v2/sha512/ad/b5/8c87dfae7c208906a88f1997b323933e7efb4e481bcfdc559cb13199d077e1b40abcb161561a293ca59cd98aae224cd0877555e6e7a2e11021bc55ebedf4 +0 -0
  124. package/~/.npm/_cacache/index-v5/6a/39/c03f62d7353a7cc1411e180ec37c393f9fedcfd081fa567f67bf32e6fb68 +2 -0
@@ -0,0 +1,237 @@
1
+ import { WebExtensionStatus, } from '@ksangkuk10/web-extension-interface';
2
+ import { BehaviorSubject } from 'rxjs';
3
+ import { LegacyExtensionConnector } from '../legacy-extension';
4
+ import { selectModal } from './modal';
5
+ import { getXplaExtensions } from './multiChannel';
6
+ import { clearSession, getStoredSession, storeSession } from './session';
7
+ import { ExtensionRouterConnectorType, ExtensionRouterStatus, } from './types';
8
+ export class ExtensionRouter {
9
+ constructor(options) {
10
+ this.options = options;
11
+ this._connector = null;
12
+ // ---------------------------------------------
13
+ // states
14
+ // ---------------------------------------------
15
+ this.states = () => {
16
+ return this._states.asObservable();
17
+ };
18
+ this.getLastStates = () => {
19
+ return this._states.getValue();
20
+ };
21
+ // ---------------------------------------------
22
+ // behaviors
23
+ // ---------------------------------------------
24
+ this.connect = async (identifier) => {
25
+ var _a;
26
+ const extensionInfos = getXplaExtensions();
27
+ if (extensionInfos.length === 0) {
28
+ throw new Error(`[ExtensionRouter] Can't find connectors`);
29
+ }
30
+ let extensionInfo;
31
+ if (identifier) {
32
+ extensionInfo = extensionInfos.find((item) => item.identifier === identifier);
33
+ }
34
+ else if (extensionInfos.length === 1) {
35
+ extensionInfo = extensionInfos[0];
36
+ }
37
+ else {
38
+ const select = (_a = this.options.selectExtension) !== null && _a !== void 0 ? _a : selectModal;
39
+ const selectedExtensionInfo = await select(extensionInfos);
40
+ if (selectedExtensionInfo) {
41
+ extensionInfo = selectedExtensionInfo;
42
+ }
43
+ }
44
+ if (extensionInfo) {
45
+ this.createConnector(extensionInfo);
46
+ }
47
+ };
48
+ this.disconnect = () => {
49
+ var _a;
50
+ clearSession();
51
+ this._states.next({
52
+ type: ExtensionRouterStatus.WALLET_NOT_CONNECTED,
53
+ network: this.options.defaultNetwork,
54
+ });
55
+ (_a = this._connector) === null || _a === void 0 ? void 0 : _a.close();
56
+ this._connector = null;
57
+ };
58
+ this.requestApproval = () => {
59
+ if (!this._connector) {
60
+ throw new Error('[ExtensionRouter] No connector');
61
+ }
62
+ this._connector.requestApproval();
63
+ };
64
+ this.refetchStates = () => {
65
+ if (!this._connector) {
66
+ throw new Error('[ExtensionRouter] No connector');
67
+ }
68
+ this._connector.refetchStates();
69
+ };
70
+ this.post = (tx, xplaAddress) => {
71
+ if (!this._connector) {
72
+ throw new Error('[ExtensionRouter] No connector');
73
+ }
74
+ const latestStates = this.getLastStates();
75
+ if (latestStates.type !== ExtensionRouterStatus.WALLET_CONNECTED) {
76
+ throw new Error(`[ExtensionRouter] Wallet is not connected`);
77
+ }
78
+ return this._connector.post(xplaAddress !== null && xplaAddress !== void 0 ? xplaAddress : latestStates.wallet.xplaAddress, tx);
79
+ };
80
+ this.sign = (tx, xplaAddress) => {
81
+ if (!this._connector) {
82
+ throw new Error('[ExtensionRouter] No connector');
83
+ }
84
+ const latestStates = this.getLastStates();
85
+ if (latestStates.type !== ExtensionRouterStatus.WALLET_CONNECTED) {
86
+ throw new Error(`[ExtensionRouter] Wallet is not connected`);
87
+ }
88
+ return this._connector.sign(xplaAddress !== null && xplaAddress !== void 0 ? xplaAddress : latestStates.wallet.xplaAddress, tx);
89
+ };
90
+ this.signBytes = (bytes, xplaAddress) => {
91
+ if (!this._connector) {
92
+ throw new Error('[ExtensionRouter] No connector');
93
+ }
94
+ const latestStates = this.getLastStates();
95
+ if (latestStates.type !== ExtensionRouterStatus.WALLET_CONNECTED) {
96
+ throw new Error(`[ExtensionRouter] Wallet is not connected`);
97
+ }
98
+ return this._connector.signBytes(xplaAddress !== null && xplaAddress !== void 0 ? xplaAddress : latestStates.wallet.xplaAddress, bytes);
99
+ };
100
+ this.hasCW20Tokens = (chainID, ...tokenAddrs) => {
101
+ if (!this._connector) {
102
+ throw new Error('[ExtensionRouter] No connector');
103
+ }
104
+ else if (this._connector instanceof LegacyExtensionConnector) {
105
+ throw new Error('[ExtensionRouter] Legacy extension does not support hasCW20Tokens() ');
106
+ }
107
+ return this._connector.hasCW20Tokens(chainID, ...tokenAddrs);
108
+ };
109
+ this.addCW20Tokens = (chainID, ...tokenAddrs) => {
110
+ if (!this._connector) {
111
+ throw new Error('[ExtensionRouter] No connector');
112
+ }
113
+ else if (this._connector instanceof LegacyExtensionConnector) {
114
+ throw new Error('[ExtensionRouter] Legacy extension does not support addCW20Tokens() ');
115
+ }
116
+ return this._connector.addCW20Tokens(chainID, ...tokenAddrs);
117
+ };
118
+ this.hasNetwork = (network) => {
119
+ if (!this._connector) {
120
+ throw new Error('[ExtensionRouter] No connector');
121
+ }
122
+ else if (this._connector instanceof LegacyExtensionConnector) {
123
+ throw new Error('[ExtensionRouter] Legacy extension does not support hasNetwork() ');
124
+ }
125
+ return this._connector.hasNetwork(network);
126
+ };
127
+ this.addNetwork = (network) => {
128
+ if (!this._connector) {
129
+ throw new Error('[ExtensionRouter] No connector');
130
+ }
131
+ else if (this._connector instanceof LegacyExtensionConnector) {
132
+ throw new Error('[ExtensionRouter] Legacy extension does not support addNetwork() ');
133
+ }
134
+ return this._connector.addNetwork(network);
135
+ };
136
+ // ---------------------------------------------
137
+ // internal
138
+ // ---------------------------------------------
139
+ this.createConnector = (extensionInfo) => {
140
+ var _a;
141
+ (_a = this._connector) === null || _a === void 0 ? void 0 : _a.close();
142
+ const connectorPromise = extensionInfo.connector
143
+ ? Promise.resolve(extensionInfo.connector())
144
+ : Promise.resolve(new LegacyExtensionConnector(extensionInfo.identifier));
145
+ connectorPromise.then((connector) => {
146
+ var _a;
147
+ connector.open((_a = this.options.hostWindow) !== null && _a !== void 0 ? _a : window, {
148
+ next: (nextStates) => {
149
+ var _a;
150
+ if (nextStates.type === WebExtensionStatus.INITIALIZING) {
151
+ this._states.next({
152
+ type: ExtensionRouterStatus.INITIALIZING,
153
+ network: this.options.defaultNetwork,
154
+ });
155
+ }
156
+ else if (nextStates.type === WebExtensionStatus.NO_AVAILABLE) {
157
+ this._states.next({
158
+ type: ExtensionRouterStatus.NO_AVAILABLE,
159
+ network: this.options.defaultNetwork,
160
+ isConnectorExists: true,
161
+ isApproved: nextStates.isApproved,
162
+ });
163
+ }
164
+ else if (nextStates.wallets.length === 0) {
165
+ this._states.next({
166
+ type: ExtensionRouterStatus.WALLET_NOT_CONNECTED,
167
+ network: nextStates.network,
168
+ });
169
+ }
170
+ else {
171
+ this._states.next({
172
+ type: ExtensionRouterStatus.WALLET_CONNECTED,
173
+ network: nextStates.network,
174
+ wallet: nextStates.focusedWalletAddress
175
+ ? (_a = nextStates.wallets.find((itemWallet) => itemWallet.xplaAddress ===
176
+ nextStates.focusedWalletAddress)) !== null && _a !== void 0 ? _a : nextStates.wallets[0]
177
+ : nextStates.wallets[0],
178
+ connectorType: connector instanceof LegacyExtensionConnector
179
+ ? ExtensionRouterConnectorType.LEGACY
180
+ : ExtensionRouterConnectorType.WEB_EXTENSION,
181
+ supportFeatures: new Set(connector.supportFeatures()),
182
+ extensionInfo,
183
+ });
184
+ }
185
+ },
186
+ error: (error) => {
187
+ console.error(error);
188
+ },
189
+ complete: () => { },
190
+ });
191
+ this._connector = connector;
192
+ storeSession({
193
+ identifier: extensionInfo.identifier,
194
+ });
195
+ });
196
+ };
197
+ this._states = new BehaviorSubject({
198
+ type: ExtensionRouterStatus.INITIALIZING,
199
+ network: options.defaultNetwork,
200
+ });
201
+ this._extensionInfos = getXplaExtensions();
202
+ if (this._extensionInfos.length === 0) {
203
+ this._states.next({
204
+ type: ExtensionRouterStatus.NO_AVAILABLE,
205
+ network: options.defaultNetwork,
206
+ isConnectorExists: false,
207
+ });
208
+ return;
209
+ }
210
+ // ---------------------------------------------
211
+ // initialize session
212
+ // ---------------------------------------------
213
+ const session = getStoredSession();
214
+ if (session) {
215
+ const extensionInfo = this._extensionInfos.find((item) => item.identifier === session.identifier);
216
+ if (extensionInfo) {
217
+ this.createConnector(extensionInfo);
218
+ return;
219
+ }
220
+ else {
221
+ console.warn(`Can't find an extension for the session "${session.identifier}"`);
222
+ clearSession();
223
+ this._states.next({
224
+ type: ExtensionRouterStatus.WALLET_NOT_CONNECTED,
225
+ network: options.defaultNetwork,
226
+ });
227
+ }
228
+ }
229
+ else {
230
+ this._states.next({
231
+ type: ExtensionRouterStatus.WALLET_NOT_CONNECTED,
232
+ network: options.defaultNetwork,
233
+ });
234
+ }
235
+ }
236
+ }
237
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ExtensionRouter.js","sourceRoot":"","sources":["../../../../../src/@ksangkuk10/wallet-controller/modules/extension-router/ExtensionRouter.ts"],"names":[],"mappings":"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","sourcesContent":["import { NetworkInfo } from '@ksangkuk10/wallet-types';\nimport {\n  XplaWebExtensionConnector,\n  WebExtensionNetworkInfo,\n  WebExtensionPostPayload,\n  WebExtensionSignBytesPayload,\n  WebExtensionSignPayload,\n  WebExtensionStates,\n  WebExtensionStatus,\n  WebExtensionTxResult,\n} from '@ksangkuk10/web-extension-interface';\nimport { CreateTxOptions, SignMode } from '@xpla/xpla.js';\nimport { BehaviorSubject, Subscribable } from 'rxjs';\nimport { LegacyExtensionConnector } from '../legacy-extension';\nimport { selectModal } from './modal';\nimport { ExtensionInfo, getXplaExtensions } from './multiChannel';\nimport { clearSession, getStoredSession, storeSession } from './session';\nimport {\n  ExtensionRouterConnectorType,\n  ExtensionRouterStates,\n  ExtensionRouterStatus,\n} from './types';\n\nexport interface ExtensionRouterOptions {\n  defaultNetwork: NetworkInfo;\n  selectExtension?: (\n    extensionInfos: ExtensionInfo[],\n  ) => Promise<ExtensionInfo | null>;\n\n  hostWindow?: Window;\n\n  // ---------------------------------------------\n  // development features\n  // ---------------------------------------------\n  dangerously__chromeExtensionCompatibleBrowserCheck: (\n    userAgent: string,\n  ) => boolean;\n}\n\nexport class ExtensionRouter {\n  private readonly _states: BehaviorSubject<ExtensionRouterStates>;\n  private readonly _extensionInfos: ExtensionInfo[];\n\n  private _connector: XplaWebExtensionConnector | null = null;\n\n  constructor(private readonly options: ExtensionRouterOptions) {\n    this._states = new BehaviorSubject<ExtensionRouterStates>({\n      type: ExtensionRouterStatus.INITIALIZING,\n      network: options.defaultNetwork,\n    });\n\n    this._extensionInfos = getXplaExtensions();\n\n    if (this._extensionInfos.length === 0) {\n      this._states.next({\n        type: ExtensionRouterStatus.NO_AVAILABLE,\n        network: options.defaultNetwork,\n        isConnectorExists: false,\n      });\n\n      return;\n    }\n\n    // ---------------------------------------------\n    // initialize session\n    // ---------------------------------------------\n    const session = getStoredSession();\n\n    if (session) {\n      const extensionInfo = this._extensionInfos.find(\n        (item) => item.identifier === session.identifier,\n      );\n\n      if (extensionInfo) {\n        this.createConnector(extensionInfo);\n        return;\n      } else {\n        console.warn(\n          `Can't find an extension for the session \"${session.identifier}\"`,\n        );\n        clearSession();\n\n        this._states.next({\n          type: ExtensionRouterStatus.WALLET_NOT_CONNECTED,\n          network: options.defaultNetwork,\n        });\n      }\n    } else {\n      this._states.next({\n        type: ExtensionRouterStatus.WALLET_NOT_CONNECTED,\n        network: options.defaultNetwork,\n      });\n    }\n  }\n\n  // ---------------------------------------------\n  // states\n  // ---------------------------------------------\n  states = () => {\n    return this._states.asObservable();\n  };\n\n  getLastStates = () => {\n    return this._states.getValue();\n  };\n\n  // ---------------------------------------------\n  // behaviors\n  // ---------------------------------------------\n  connect = async (identifier?: string) => {\n    const extensionInfos = getXplaExtensions();\n\n    if (extensionInfos.length === 0) {\n      throw new Error(`[ExtensionRouter] Can't find connectors`);\n    }\n\n    let extensionInfo: ExtensionInfo | undefined;\n\n    if (identifier) {\n      extensionInfo = extensionInfos.find(\n        (item) => item.identifier === identifier,\n      );\n    } else if (extensionInfos.length === 1) {\n      extensionInfo = extensionInfos[0];\n    } else {\n      const select = this.options.selectExtension ?? selectModal;\n      const selectedExtensionInfo = await select(extensionInfos);\n\n      if (selectedExtensionInfo) {\n        extensionInfo = selectedExtensionInfo;\n      }\n    }\n\n    if (extensionInfo) {\n      this.createConnector(extensionInfo);\n    }\n  };\n\n  disconnect = () => {\n    clearSession();\n\n    this._states.next({\n      type: ExtensionRouterStatus.WALLET_NOT_CONNECTED,\n      network: this.options.defaultNetwork,\n    });\n\n    this._connector?.close();\n    this._connector = null;\n  };\n\n  requestApproval = () => {\n    if (!this._connector) {\n      throw new Error('[ExtensionRouter] No connector');\n    }\n\n    this._connector.requestApproval();\n  };\n\n  refetchStates = () => {\n    if (!this._connector) {\n      throw new Error('[ExtensionRouter] No connector');\n    }\n\n    this._connector.refetchStates();\n  };\n\n  post = (\n    tx: CreateTxOptions,\n    xplaAddress?: string,\n  ): Subscribable<WebExtensionTxResult<WebExtensionPostPayload>> => {\n    if (!this._connector) {\n      throw new Error('[ExtensionRouter] No connector');\n    }\n\n    const latestStates = this.getLastStates();\n\n    if (latestStates.type !== ExtensionRouterStatus.WALLET_CONNECTED) {\n      throw new Error(`[ExtensionRouter] Wallet is not connected`);\n    }\n\n    return this._connector.post(\n      xplaAddress ?? latestStates.wallet.xplaAddress,\n      tx,\n    );\n  };\n\n  sign = (\n    tx: CreateTxOptions & {\n      sequence?: number;\n      accountNumber?: number;\n      signMode?: SignMode;\n    },\n    xplaAddress?: string,\n  ): Subscribable<WebExtensionTxResult<WebExtensionSignPayload>> => {\n    if (!this._connector) {\n      throw new Error('[ExtensionRouter] No connector');\n    }\n\n    const latestStates = this.getLastStates();\n\n    if (latestStates.type !== ExtensionRouterStatus.WALLET_CONNECTED) {\n      throw new Error(`[ExtensionRouter] Wallet is not connected`);\n    }\n\n    return this._connector.sign(\n      xplaAddress ?? latestStates.wallet.xplaAddress,\n      tx,\n    );\n  };\n\n  signBytes = (\n    bytes: Buffer,\n    xplaAddress?: string,\n  ): Subscribable<WebExtensionTxResult<WebExtensionSignBytesPayload>> => {\n    if (!this._connector) {\n      throw new Error('[ExtensionRouter] No connector');\n    }\n\n    const latestStates = this.getLastStates();\n\n    if (latestStates.type !== ExtensionRouterStatus.WALLET_CONNECTED) {\n      throw new Error(`[ExtensionRouter] Wallet is not connected`);\n    }\n\n    return this._connector.signBytes(\n      xplaAddress ?? latestStates.wallet.xplaAddress,\n      bytes,\n    );\n  };\n\n  hasCW20Tokens = (\n    chainID: string,\n    ...tokenAddrs: string[]\n  ): Promise<{ [tokenAddr: string]: boolean }> => {\n    if (!this._connector) {\n      throw new Error('[ExtensionRouter] No connector');\n    } else if (this._connector instanceof LegacyExtensionConnector) {\n      throw new Error(\n        '[ExtensionRouter] Legacy extension does not support hasCW20Tokens() ',\n      );\n    }\n\n    return this._connector.hasCW20Tokens(chainID, ...tokenAddrs);\n  };\n\n  addCW20Tokens = (\n    chainID: string,\n    ...tokenAddrs: string[]\n  ): Promise<{ [tokenAddr: string]: boolean }> => {\n    if (!this._connector) {\n      throw new Error('[ExtensionRouter] No connector');\n    } else if (this._connector instanceof LegacyExtensionConnector) {\n      throw new Error(\n        '[ExtensionRouter] Legacy extension does not support addCW20Tokens() ',\n      );\n    }\n\n    return this._connector.addCW20Tokens(chainID, ...tokenAddrs);\n  };\n\n  hasNetwork = (\n    network: Omit<WebExtensionNetworkInfo, 'name'>,\n  ): Promise<boolean> => {\n    if (!this._connector) {\n      throw new Error('[ExtensionRouter] No connector');\n    } else if (this._connector instanceof LegacyExtensionConnector) {\n      throw new Error(\n        '[ExtensionRouter] Legacy extension does not support hasNetwork() ',\n      );\n    }\n\n    return this._connector.hasNetwork(network);\n  };\n\n  addNetwork = (network: WebExtensionNetworkInfo): Promise<boolean> => {\n    if (!this._connector) {\n      throw new Error('[ExtensionRouter] No connector');\n    } else if (this._connector instanceof LegacyExtensionConnector) {\n      throw new Error(\n        '[ExtensionRouter] Legacy extension does not support addNetwork() ',\n      );\n    }\n\n    return this._connector.addNetwork(network);\n  };\n\n  // ---------------------------------------------\n  // internal\n  // ---------------------------------------------\n  private createConnector = (extensionInfo: ExtensionInfo) => {\n    this._connector?.close();\n\n    const connectorPromise: Promise<XplaWebExtensionConnector> =\n      extensionInfo.connector\n        ? Promise.resolve(extensionInfo.connector())\n        : Promise.resolve(\n            new LegacyExtensionConnector(extensionInfo.identifier),\n          );\n\n    connectorPromise.then((connector) => {\n      connector.open(this.options.hostWindow ?? window, {\n        next: (nextStates: WebExtensionStates) => {\n          if (nextStates.type === WebExtensionStatus.INITIALIZING) {\n            this._states.next({\n              type: ExtensionRouterStatus.INITIALIZING,\n              network: this.options.defaultNetwork,\n            });\n          } else if (nextStates.type === WebExtensionStatus.NO_AVAILABLE) {\n            this._states.next({\n              type: ExtensionRouterStatus.NO_AVAILABLE,\n              network: this.options.defaultNetwork,\n              isConnectorExists: true,\n              isApproved: nextStates.isApproved,\n            });\n          } else if (nextStates.wallets.length === 0) {\n            this._states.next({\n              type: ExtensionRouterStatus.WALLET_NOT_CONNECTED,\n              network: nextStates.network,\n            });\n          } else {\n            this._states.next({\n              type: ExtensionRouterStatus.WALLET_CONNECTED,\n              network: nextStates.network,\n              wallet: nextStates.focusedWalletAddress\n                ? nextStates.wallets.find(\n                    (itemWallet) =>\n                      itemWallet.xplaAddress ===\n                      nextStates.focusedWalletAddress,\n                  ) ?? nextStates.wallets[0]\n                : nextStates.wallets[0],\n              connectorType:\n                connector instanceof LegacyExtensionConnector\n                  ? ExtensionRouterConnectorType.LEGACY\n                  : ExtensionRouterConnectorType.WEB_EXTENSION,\n              supportFeatures: new Set(connector.supportFeatures()),\n              extensionInfo,\n            });\n          }\n        },\n        error: (error) => {\n          console.error(error);\n        },\n        complete: () => {},\n      });\n\n      this._connector = connector;\n\n      storeSession({\n        identifier: extensionInfo.identifier,\n      });\n    });\n  };\n}\n"]}
@@ -0,0 +1,2 @@
1
+ export * from './ExtensionRouter';
2
+ export * from './types';
@@ -0,0 +1,3 @@
1
+ export * from './ExtensionRouter';
2
+ export * from './types';
3
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9zcmMvQGtzYW5na3VrMTAvd2FsbGV0LWNvbnRyb2xsZXIvbW9kdWxlcy9leHRlbnNpb24tcm91dGVyL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMsbUJBQW1CLENBQUM7QUFDbEMsY0FBYyxTQUFTLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL0V4dGVuc2lvblJvdXRlcic7XG5leHBvcnQgKiBmcm9tICcuL3R5cGVzJztcbiJdfQ==
@@ -0,0 +1,2 @@
1
+ import { ExtensionInfo } from './multiChannel';
2
+ export declare function selectModal(extensionInfos: ExtensionInfo[]): Promise<ExtensionInfo | null>;
@@ -0,0 +1,76 @@
1
+ import { modalStyle } from './modal.style';
2
+ export function selectModal(extensionInfos) {
3
+ return new Promise((resolve) => {
4
+ var _a, _b;
5
+ const modalContainer = document.createElement('div');
6
+ const styleContainer = document.createElement('style');
7
+ function onComplete(extensionInfo) {
8
+ var _a, _b;
9
+ resolve(extensionInfo);
10
+ (_a = modalContainer.parentElement) === null || _a === void 0 ? void 0 : _a.removeChild(modalContainer);
11
+ (_b = styleContainer.parentElement) === null || _b === void 0 ? void 0 : _b.removeChild(styleContainer);
12
+ }
13
+ const element = createModalElement({
14
+ extensionInfos,
15
+ onComplete,
16
+ });
17
+ styleContainer.textContent = modalStyle;
18
+ modalContainer.appendChild(element);
19
+ (_a = document.querySelector('head')) === null || _a === void 0 ? void 0 : _a.appendChild(styleContainer);
20
+ (_b = document.querySelector('body')) === null || _b === void 0 ? void 0 : _b.appendChild(modalContainer);
21
+ });
22
+ }
23
+ function createModalElement({ extensionInfos, onComplete, }) {
24
+ // ---------------------------------------------
25
+ // container
26
+ // ---------------------------------------------
27
+ const container = document.createElement('div');
28
+ container.setAttribute('class', 'wallet-select-modal');
29
+ // ---------------------------------------------
30
+ // container > div.wallet-select-modal--dim
31
+ // ---------------------------------------------
32
+ const dim = document.createElement('div');
33
+ dim.setAttribute('class', 'wallet-select-modal--dim');
34
+ container.appendChild(dim);
35
+ // ---------------------------------------------
36
+ // content > div.wallet-select-modal--content
37
+ // ---------------------------------------------
38
+ const content = document.createElement('section');
39
+ content.setAttribute('class', 'wallet-select-modal--content');
40
+ container.appendChild(content);
41
+ // h1
42
+ const title = document.createElement('h1');
43
+ title.textContent = 'Select a Wallet';
44
+ content.appendChild(title);
45
+ // ul
46
+ const list = document.createElement('ul');
47
+ content.appendChild(list);
48
+ for (const extensionInfo of extensionInfos) {
49
+ const item = document.createElement('li');
50
+ const button = document.createElement('button');
51
+ button.addEventListener('click', () => onComplete(extensionInfo));
52
+ item.appendChild(button);
53
+ const icon = document.createElement('span');
54
+ icon.setAttribute('class', 'wallet-select-modal--icon');
55
+ button.appendChild(icon);
56
+ const iconImg = document.createElement('img');
57
+ iconImg.setAttribute('src', extensionInfo.icon);
58
+ iconImg.setAttribute('alt', `${extensionInfo.name} [${extensionInfo.identifier}]`);
59
+ icon.appendChild(iconImg);
60
+ const description = document.createElement('span');
61
+ description.setAttribute('class', 'wallet-select-modal--description');
62
+ description.textContent = extensionInfo.name;
63
+ button.appendChild(description);
64
+ const arrow = document.createElementNS('http://www.w3.org/2000/svg', 'svg');
65
+ arrow.setAttribute('viewBox', '0 0 24 24');
66
+ button.appendChild(arrow);
67
+ const path = document.createElementNS('http://www.w3.org/2000/svg', 'path');
68
+ path.setAttribute('d', 'M10 6L8.59 7.41 13.17 12l-4.58 4.59L10 18l6-6z');
69
+ arrow.appendChild(path);
70
+ list.appendChild(item);
71
+ }
72
+ // events
73
+ dim.addEventListener('click', () => onComplete(null));
74
+ return container;
75
+ }
76
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"modal.js","sourceRoot":"","sources":["../../../../../src/@ksangkuk10/wallet-controller/modules/extension-router/modal.ts"],"names":[],"mappings":"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","sourcesContent":["import { ExtensionInfo } from './multiChannel';\nimport { modalStyle } from './modal.style';\n\nexport function selectModal(\n  extensionInfos: ExtensionInfo[],\n): Promise<ExtensionInfo | null> {\n  return new Promise<ExtensionInfo | null>((resolve) => {\n    const modalContainer = document.createElement('div');\n    const styleContainer = document.createElement('style');\n\n    function onComplete(extensionInfo: ExtensionInfo | null) {\n      resolve(extensionInfo);\n      modalContainer.parentElement?.removeChild(modalContainer);\n      styleContainer.parentElement?.removeChild(styleContainer);\n    }\n\n    const element = createModalElement({\n      extensionInfos,\n      onComplete,\n    });\n\n    styleContainer.textContent = modalStyle;\n    modalContainer.appendChild(element);\n\n    document.querySelector('head')?.appendChild(styleContainer);\n    document.querySelector('body')?.appendChild(modalContainer);\n  });\n}\n\nfunction createModalElement({\n  extensionInfos,\n  onComplete,\n}: {\n  extensionInfos: ExtensionInfo[];\n  onComplete: (extensionInfo: ExtensionInfo | null) => void;\n}): HTMLElement {\n  // ---------------------------------------------\n  // container\n  // ---------------------------------------------\n  const container = document.createElement('div');\n  container.setAttribute('class', 'wallet-select-modal');\n\n  // ---------------------------------------------\n  // container > div.wallet-select-modal--dim\n  // ---------------------------------------------\n  const dim = document.createElement('div');\n  dim.setAttribute('class', 'wallet-select-modal--dim');\n\n  container.appendChild(dim);\n\n  // ---------------------------------------------\n  // content > div.wallet-select-modal--content\n  // ---------------------------------------------\n  const content = document.createElement('section');\n  content.setAttribute('class', 'wallet-select-modal--content');\n\n  container.appendChild(content);\n\n  // h1\n  const title = document.createElement('h1');\n  title.textContent = 'Select a Wallet';\n  content.appendChild(title);\n\n  // ul\n  const list = document.createElement('ul');\n  content.appendChild(list);\n\n  for (const extensionInfo of extensionInfos) {\n    const item = document.createElement('li');\n\n    const button = document.createElement('button');\n    button.addEventListener('click', () => onComplete(extensionInfo));\n\n    item.appendChild(button);\n\n    const icon = document.createElement('span');\n    icon.setAttribute('class', 'wallet-select-modal--icon');\n\n    button.appendChild(icon);\n\n    const iconImg = document.createElement('img');\n    iconImg.setAttribute('src', extensionInfo.icon);\n    iconImg.setAttribute(\n      'alt',\n      `${extensionInfo.name} [${extensionInfo.identifier}]`,\n    );\n\n    icon.appendChild(iconImg);\n\n    const description = document.createElement('span');\n    description.setAttribute('class', 'wallet-select-modal--description');\n    description.textContent = extensionInfo.name;\n\n    button.appendChild(description);\n\n    const arrow = document.createElementNS('http://www.w3.org/2000/svg', 'svg');\n    arrow.setAttribute('viewBox', '0 0 24 24');\n\n    button.appendChild(arrow);\n\n    const path = document.createElementNS('http://www.w3.org/2000/svg', 'path');\n    path.setAttribute('d', 'M10 6L8.59 7.41 13.17 12l-4.58 4.59L10 18l6-6z');\n\n    arrow.appendChild(path);\n\n    list.appendChild(item);\n  }\n\n  // events\n  dim.addEventListener('click', () => onComplete(null));\n\n  return container;\n}\n"]}
@@ -0,0 +1 @@
1
+ export declare const modalStyle = "\n@keyframes wallet-select-modal--dim-enter {\n 0% {\n opacity: 0;\n }\n \n 100% {\n opacity: 1;\n }\n}\n\n@keyframes wallet-select-modal--content-enter {\n 0% {\n opacity: 0;\n transform: scale(0.4);\n }\n \n 100% {\n opacity: 1;\n transform: scale(1);\n }\n}\n\n.wallet-select-modal {\n position: fixed;\n z-index: 100000;\n \n color: #212121;\n \n left: 0;\n top: 0;\n width: 100vw;\n height: 100vh;\n \n font-family: sans-serif;\n \n display: grid;\n place-content: center;\n}\n\n.wallet-select-modal > .wallet-select-modal--dim {\n position: fixed;\n z-index: -1;\n \n left: 0;\n top: 0;\n width: 100vw;\n height: 100vh;\n background-color: rgba(0, 0, 0, 0.3);\n \n animation: wallet-select-modal--dim-enter 0.2s ease-in-out;\n}\n\n.wallet-select-modal > .wallet-select-modal--content {\n box-sizing: border-box;\n \n border-radius: 8px;\n \n background-color: #ffffff;\n box-shadow: 0 4px 18px 3px rgba(0, 0, 0, 0.43);\n \n animation: wallet-select-modal--content-enter 0.2s ease-in-out;\n \n width: 100vw;\n max-width: 480px;\n padding: 40px;\n}\n\n.wallet-select-modal > .wallet-select-modal--content h1 {\n font-size: 20px;\n font-weight: bold;\n \n margin: 0 0 32px 0;\n \n text-align: center;\n}\n\n.wallet-select-modal > .wallet-select-modal--content ul {\n padding: 0;\n margin: 0;\n list-style: none;\n \n display: flex;\n flex-direction: column;\n}\n\n.wallet-select-modal > .wallet-select-modal--content ul li {\n border-top: 1px solid #cfd8ea;\n}\n\n.wallet-select-modal > .wallet-select-modal--content ul li:last-child {\n border-bottom: 1px solid #cfd8ea;\n}\n\n.wallet-select-modal > .wallet-select-modal--content ul button {\n width: 100%;\n height: 66px;\n \n border: none;\n background-color: transparent;\n outline: none;\n cursor: pointer;\n \n display: flex;\n gap: 10px;\n align-items: center;\n}\n\n.wallet-select-modal > .wallet-select-modal--content ul button:hover {\n background-color: hsl(220, 39%, 86%, 0.25);\n}\n\n.wallet-select-modal > .wallet-select-modal--content ul button .wallet-select-modal--icon {\n display: inline-grid;\n width: 50px;\n height: 50px;\n \n place-content: center;\n}\n\n.wallet-select-modal > .wallet-select-modal--content ul button .wallet-select-modal--icon img {\n width: 30px;\n height: 30px;\n}\n\n.wallet-select-modal > .wallet-select-modal--content ul button .wallet-select-modal--description {\n flex: 1;\n text-align: left;\n \n font-size: 16px;\n font-weight: 600;\n color: #212121;\n}\n\n.wallet-select-modal > .wallet-select-modal--content ul button svg {\n width: 18px;\n height: 18px;\n \n fill: #cfd8ea;\n}\n\n.wallet-select-modal > .wallet-select-modal--content ul button:hover svg {\n fill: #2043b5;\n}\n\n@media (max-width: 450px) {\n .wallet-select-modal {\n place-content: flex-end;\n }\n \n .wallet-select-modal > .wallet-select-modal--content {\n border-bottom-left-radius: 0;\n border-bottom-right-radius: 0;\n }\n}\n";
@@ -0,0 +1,158 @@
1
+ // language=css
2
+ export const modalStyle = `
3
+ @keyframes wallet-select-modal--dim-enter {
4
+ 0% {
5
+ opacity: 0;
6
+ }
7
+
8
+ 100% {
9
+ opacity: 1;
10
+ }
11
+ }
12
+
13
+ @keyframes wallet-select-modal--content-enter {
14
+ 0% {
15
+ opacity: 0;
16
+ transform: scale(0.4);
17
+ }
18
+
19
+ 100% {
20
+ opacity: 1;
21
+ transform: scale(1);
22
+ }
23
+ }
24
+
25
+ .wallet-select-modal {
26
+ position: fixed;
27
+ z-index: 100000;
28
+
29
+ color: #212121;
30
+
31
+ left: 0;
32
+ top: 0;
33
+ width: 100vw;
34
+ height: 100vh;
35
+
36
+ font-family: sans-serif;
37
+
38
+ display: grid;
39
+ place-content: center;
40
+ }
41
+
42
+ .wallet-select-modal > .wallet-select-modal--dim {
43
+ position: fixed;
44
+ z-index: -1;
45
+
46
+ left: 0;
47
+ top: 0;
48
+ width: 100vw;
49
+ height: 100vh;
50
+ background-color: rgba(0, 0, 0, 0.3);
51
+
52
+ animation: wallet-select-modal--dim-enter 0.2s ease-in-out;
53
+ }
54
+
55
+ .wallet-select-modal > .wallet-select-modal--content {
56
+ box-sizing: border-box;
57
+
58
+ border-radius: 8px;
59
+
60
+ background-color: #ffffff;
61
+ box-shadow: 0 4px 18px 3px rgba(0, 0, 0, 0.43);
62
+
63
+ animation: wallet-select-modal--content-enter 0.2s ease-in-out;
64
+
65
+ width: 100vw;
66
+ max-width: 480px;
67
+ padding: 40px;
68
+ }
69
+
70
+ .wallet-select-modal > .wallet-select-modal--content h1 {
71
+ font-size: 20px;
72
+ font-weight: bold;
73
+
74
+ margin: 0 0 32px 0;
75
+
76
+ text-align: center;
77
+ }
78
+
79
+ .wallet-select-modal > .wallet-select-modal--content ul {
80
+ padding: 0;
81
+ margin: 0;
82
+ list-style: none;
83
+
84
+ display: flex;
85
+ flex-direction: column;
86
+ }
87
+
88
+ .wallet-select-modal > .wallet-select-modal--content ul li {
89
+ border-top: 1px solid #cfd8ea;
90
+ }
91
+
92
+ .wallet-select-modal > .wallet-select-modal--content ul li:last-child {
93
+ border-bottom: 1px solid #cfd8ea;
94
+ }
95
+
96
+ .wallet-select-modal > .wallet-select-modal--content ul button {
97
+ width: 100%;
98
+ height: 66px;
99
+
100
+ border: none;
101
+ background-color: transparent;
102
+ outline: none;
103
+ cursor: pointer;
104
+
105
+ display: flex;
106
+ gap: 10px;
107
+ align-items: center;
108
+ }
109
+
110
+ .wallet-select-modal > .wallet-select-modal--content ul button:hover {
111
+ background-color: hsl(220, 39%, 86%, 0.25);
112
+ }
113
+
114
+ .wallet-select-modal > .wallet-select-modal--content ul button .wallet-select-modal--icon {
115
+ display: inline-grid;
116
+ width: 50px;
117
+ height: 50px;
118
+
119
+ place-content: center;
120
+ }
121
+
122
+ .wallet-select-modal > .wallet-select-modal--content ul button .wallet-select-modal--icon img {
123
+ width: 30px;
124
+ height: 30px;
125
+ }
126
+
127
+ .wallet-select-modal > .wallet-select-modal--content ul button .wallet-select-modal--description {
128
+ flex: 1;
129
+ text-align: left;
130
+
131
+ font-size: 16px;
132
+ font-weight: 600;
133
+ color: #212121;
134
+ }
135
+
136
+ .wallet-select-modal > .wallet-select-modal--content ul button svg {
137
+ width: 18px;
138
+ height: 18px;
139
+
140
+ fill: #cfd8ea;
141
+ }
142
+
143
+ .wallet-select-modal > .wallet-select-modal--content ul button:hover svg {
144
+ fill: #2043b5;
145
+ }
146
+
147
+ @media (max-width: 450px) {
148
+ .wallet-select-modal {
149
+ place-content: flex-end;
150
+ }
151
+
152
+ .wallet-select-modal > .wallet-select-modal--content {
153
+ border-bottom-left-radius: 0;
154
+ border-bottom-right-radius: 0;
155
+ }
156
+ }
157
+ `;
158
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibW9kYWwuc3R5bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9zcmMvQGtzYW5na3VrMTAvd2FsbGV0LWNvbnRyb2xsZXIvbW9kdWxlcy9leHRlbnNpb24tcm91dGVyL21vZGFsLnN0eWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGVBQWU7QUFDZixNQUFNLENBQUMsTUFBTSxVQUFVLEdBQUc7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0NBMkp6QixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLy8gbGFuZ3VhZ2U9Y3NzXG5leHBvcnQgY29uc3QgbW9kYWxTdHlsZSA9IGBcbkBrZXlmcmFtZXMgd2FsbGV0LXNlbGVjdC1tb2RhbC0tZGltLWVudGVyIHtcbiAgMCUge1xuICAgIG9wYWNpdHk6IDA7XG4gIH1cbiAgXG4gIDEwMCUge1xuICAgIG9wYWNpdHk6IDE7XG4gIH1cbn1cblxuQGtleWZyYW1lcyB3YWxsZXQtc2VsZWN0LW1vZGFsLS1jb250ZW50LWVudGVyIHtcbiAgMCUge1xuICAgIG9wYWNpdHk6IDA7XG4gICAgdHJhbnNmb3JtOiBzY2FsZSgwLjQpO1xuICB9XG4gIFxuICAxMDAlIHtcbiAgICBvcGFjaXR5OiAxO1xuICAgIHRyYW5zZm9ybTogc2NhbGUoMSk7XG4gIH1cbn1cblxuLndhbGxldC1zZWxlY3QtbW9kYWwge1xuICBwb3NpdGlvbjogZml4ZWQ7XG4gIHotaW5kZXg6IDEwMDAwMDtcbiAgXG4gIGNvbG9yOiAjMjEyMTIxO1xuICBcbiAgbGVmdDogMDtcbiAgdG9wOiAwO1xuICB3aWR0aDogMTAwdnc7XG4gIGhlaWdodDogMTAwdmg7XG4gIFxuICBmb250LWZhbWlseTogc2Fucy1zZXJpZjtcbiAgXG4gIGRpc3BsYXk6IGdyaWQ7XG4gIHBsYWNlLWNvbnRlbnQ6IGNlbnRlcjtcbn1cblxuLndhbGxldC1zZWxlY3QtbW9kYWwgPiAud2FsbGV0LXNlbGVjdC1tb2RhbC0tZGltIHtcbiAgcG9zaXRpb246IGZpeGVkO1xuICB6LWluZGV4OiAtMTtcbiAgXG4gIGxlZnQ6IDA7XG4gIHRvcDogMDtcbiAgd2lkdGg6IDEwMHZ3O1xuICBoZWlnaHQ6IDEwMHZoO1xuICBiYWNrZ3JvdW5kLWNvbG9yOiByZ2JhKDAsIDAsIDAsIDAuMyk7XG4gIFxuICBhbmltYXRpb246IHdhbGxldC1zZWxlY3QtbW9kYWwtLWRpbS1lbnRlciAwLjJzIGVhc2UtaW4tb3V0O1xufVxuXG4ud2FsbGV0LXNlbGVjdC1tb2RhbCA+IC53YWxsZXQtc2VsZWN0LW1vZGFsLS1jb250ZW50IHtcbiAgYm94LXNpemluZzogYm9yZGVyLWJveDtcbiAgXG4gIGJvcmRlci1yYWRpdXM6IDhweDtcbiAgXG4gIGJhY2tncm91bmQtY29sb3I6ICNmZmZmZmY7XG4gIGJveC1zaGFkb3c6IDAgNHB4IDE4cHggM3B4IHJnYmEoMCwgMCwgMCwgMC40Myk7XG4gIFxuICBhbmltYXRpb246IHdhbGxldC1zZWxlY3QtbW9kYWwtLWNvbnRlbnQtZW50ZXIgMC4ycyBlYXNlLWluLW91dDtcbiAgXG4gIHdpZHRoOiAxMDB2dztcbiAgbWF4LXdpZHRoOiA0ODBweDtcbiAgcGFkZGluZzogNDBweDtcbn1cblxuLndhbGxldC1zZWxlY3QtbW9kYWwgPiAud2FsbGV0LXNlbGVjdC1tb2RhbC0tY29udGVudCBoMSB7XG4gIGZvbnQtc2l6ZTogMjBweDtcbiAgZm9udC13ZWlnaHQ6IGJvbGQ7XG4gIFxuICBtYXJnaW46IDAgMCAzMnB4IDA7XG4gIFxuICB0ZXh0LWFsaWduOiBjZW50ZXI7XG59XG5cbi53YWxsZXQtc2VsZWN0LW1vZGFsID4gLndhbGxldC1zZWxlY3QtbW9kYWwtLWNvbnRlbnQgdWwge1xuICBwYWRkaW5nOiAwO1xuICBtYXJnaW46IDA7XG4gIGxpc3Qtc3R5bGU6IG5vbmU7XG4gIFxuICBkaXNwbGF5OiBmbGV4O1xuICBmbGV4LWRpcmVjdGlvbjogY29sdW1uO1xufVxuXG4ud2FsbGV0LXNlbGVjdC1tb2RhbCA+IC53YWxsZXQtc2VsZWN0LW1vZGFsLS1jb250ZW50IHVsIGxpIHtcbiAgYm9yZGVyLXRvcDogMXB4IHNvbGlkICNjZmQ4ZWE7XG59XG5cbi53YWxsZXQtc2VsZWN0LW1vZGFsID4gLndhbGxldC1zZWxlY3QtbW9kYWwtLWNvbnRlbnQgdWwgbGk6bGFzdC1jaGlsZCB7XG4gIGJvcmRlci1ib3R0b206IDFweCBzb2xpZCAjY2ZkOGVhO1xufVxuXG4ud2FsbGV0LXNlbGVjdC1tb2RhbCA+IC53YWxsZXQtc2VsZWN0LW1vZGFsLS1jb250ZW50IHVsIGJ1dHRvbiB7XG4gIHdpZHRoOiAxMDAlO1xuICBoZWlnaHQ6IDY2cHg7XG4gIFxuICBib3JkZXI6IG5vbmU7XG4gIGJhY2tncm91bmQtY29sb3I6IHRyYW5zcGFyZW50O1xuICBvdXRsaW5lOiBub25lO1xuICBjdXJzb3I6IHBvaW50ZXI7XG4gIFxuICBkaXNwbGF5OiBmbGV4O1xuICBnYXA6IDEwcHg7XG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG59XG5cbi53YWxsZXQtc2VsZWN0LW1vZGFsID4gLndhbGxldC1zZWxlY3QtbW9kYWwtLWNvbnRlbnQgdWwgYnV0dG9uOmhvdmVyIHtcbiAgYmFja2dyb3VuZC1jb2xvcjogaHNsKDIyMCwgMzklLCA4NiUsIDAuMjUpO1xufVxuXG4ud2FsbGV0LXNlbGVjdC1tb2RhbCA+IC53YWxsZXQtc2VsZWN0LW1vZGFsLS1jb250ZW50IHVsIGJ1dHRvbiAud2FsbGV0LXNlbGVjdC1tb2RhbC0taWNvbiB7XG4gIGRpc3BsYXk6IGlubGluZS1ncmlkO1xuICB3aWR0aDogNTBweDtcbiAgaGVpZ2h0OiA1MHB4O1xuICBcbiAgcGxhY2UtY29udGVudDogY2VudGVyO1xufVxuXG4ud2FsbGV0LXNlbGVjdC1tb2RhbCA+IC53YWxsZXQtc2VsZWN0LW1vZGFsLS1jb250ZW50IHVsIGJ1dHRvbiAud2FsbGV0LXNlbGVjdC1tb2RhbC0taWNvbiBpbWcge1xuICB3aWR0aDogMzBweDtcbiAgaGVpZ2h0OiAzMHB4O1xufVxuXG4ud2FsbGV0LXNlbGVjdC1tb2RhbCA+IC53YWxsZXQtc2VsZWN0LW1vZGFsLS1jb250ZW50IHVsIGJ1dHRvbiAud2FsbGV0LXNlbGVjdC1tb2RhbC0tZGVzY3JpcHRpb24ge1xuICBmbGV4OiAxO1xuICB0ZXh0LWFsaWduOiBsZWZ0O1xuICBcbiAgZm9udC1zaXplOiAxNnB4O1xuICBmb250LXdlaWdodDogNjAwO1xuICBjb2xvcjogIzIxMjEyMTtcbn1cblxuLndhbGxldC1zZWxlY3QtbW9kYWwgPiAud2FsbGV0LXNlbGVjdC1tb2RhbC0tY29udGVudCB1bCBidXR0b24gc3ZnIHtcbiAgd2lkdGg6IDE4cHg7XG4gIGhlaWdodDogMThweDtcbiAgXG4gIGZpbGw6ICNjZmQ4ZWE7XG59XG5cbi53YWxsZXQtc2VsZWN0LW1vZGFsID4gLndhbGxldC1zZWxlY3QtbW9kYWwtLWNvbnRlbnQgdWwgYnV0dG9uOmhvdmVyIHN2ZyB7XG4gIGZpbGw6ICMyMDQzYjU7XG59XG5cbkBtZWRpYSAobWF4LXdpZHRoOiA0NTBweCkge1xuICAud2FsbGV0LXNlbGVjdC1tb2RhbCB7XG4gICAgcGxhY2UtY29udGVudDogZmxleC1lbmQ7XG4gIH1cbiAgXG4gIC53YWxsZXQtc2VsZWN0LW1vZGFsID4gLndhbGxldC1zZWxlY3QtbW9kYWwtLWNvbnRlbnQge1xuICAgIGJvcmRlci1ib3R0b20tbGVmdC1yYWRpdXM6IDA7XG4gICAgYm9yZGVyLWJvdHRvbS1yaWdodC1yYWRpdXM6IDA7XG4gIH1cbn1cbmA7XG4iXX0=
@@ -0,0 +1,13 @@
1
+ import { XplaWebExtensionConnector } from '@ksangkuk10/web-extension-interface';
2
+ export interface ExtensionInfo {
3
+ name: string;
4
+ identifier: string;
5
+ icon: string;
6
+ connector?: () => XplaWebExtensionConnector | Promise<XplaWebExtensionConnector>;
7
+ }
8
+ declare global {
9
+ interface Window {
10
+ xplaWallets: ExtensionInfo[] | undefined;
11
+ }
12
+ }
13
+ export declare function getXplaExtensions(): ExtensionInfo[];
@@ -0,0 +1,14 @@
1
+ export function getXplaExtensions() {
2
+ return Array.isArray(window.xplaWallets)
3
+ ? window.xplaWallets
4
+ : window.isXplaExtensionAvailable
5
+ ? [
6
+ {
7
+ name: 'Xpla Valut Wallet',
8
+ identifier: 'xplavault',
9
+ icon: 'https://assets.xpla.io/icon/extension/icon.png',
10
+ },
11
+ ]
12
+ : [];
13
+ }
14
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibXVsdGlDaGFubmVsLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vc3JjL0Brc2FuZ2t1azEwL3dhbGxldC1jb250cm9sbGVyL21vZHVsZXMvZXh0ZW5zaW9uLXJvdXRlci9tdWx0aUNoYW5uZWwudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBaUJBLE1BQU0sVUFBVSxpQkFBaUI7SUFDL0IsT0FBTyxLQUFLLENBQUMsT0FBTyxDQUFDLE1BQU0sQ0FBQyxXQUFXLENBQUM7UUFDdEMsQ0FBQyxDQUFDLE1BQU0sQ0FBQyxXQUFXO1FBQ3BCLENBQUMsQ0FBQyxNQUFNLENBQUMsd0JBQXdCO1lBQ2pDLENBQUMsQ0FBQztnQkFDRTtvQkFDRSxJQUFJLEVBQUUsbUJBQW1CO29CQUN6QixVQUFVLEVBQUUsV0FBVztvQkFDdkIsSUFBSSxFQUFFLGdEQUFnRDtpQkFDdkQ7YUFDRjtZQUNILENBQUMsQ0FBQyxFQUFFLENBQUM7QUFDVCxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgWHBsYVdlYkV4dGVuc2lvbkNvbm5lY3RvciB9IGZyb20gJ0Brc2FuZ2t1azEwL3dlYi1leHRlbnNpb24taW50ZXJmYWNlJztcblxuZXhwb3J0IGludGVyZmFjZSBFeHRlbnNpb25JbmZvIHtcbiAgbmFtZTogc3RyaW5nO1xuICBpZGVudGlmaWVyOiBzdHJpbmc7XG4gIGljb246IHN0cmluZztcbiAgY29ubmVjdG9yPzogKCkgPT5cbiAgICB8IFhwbGFXZWJFeHRlbnNpb25Db25uZWN0b3JcbiAgICB8IFByb21pc2U8WHBsYVdlYkV4dGVuc2lvbkNvbm5lY3Rvcj47XG59XG5cbmRlY2xhcmUgZ2xvYmFsIHtcbiAgaW50ZXJmYWNlIFdpbmRvdyB7XG4gICAgeHBsYVdhbGxldHM6IEV4dGVuc2lvbkluZm9bXSB8IHVuZGVmaW5lZDtcbiAgfVxufVxuXG5leHBvcnQgZnVuY3Rpb24gZ2V0WHBsYUV4dGVuc2lvbnMoKTogRXh0ZW5zaW9uSW5mb1tdIHtcbiAgcmV0dXJuIEFycmF5LmlzQXJyYXkod2luZG93LnhwbGFXYWxsZXRzKVxuICAgID8gd2luZG93LnhwbGFXYWxsZXRzXG4gICAgOiB3aW5kb3cuaXNYcGxhRXh0ZW5zaW9uQXZhaWxhYmxlXG4gICAgPyBbXG4gICAgICAgIHtcbiAgICAgICAgICBuYW1lOiAnWHBsYSBWYWx1dCBXYWxsZXQnLFxuICAgICAgICAgIGlkZW50aWZpZXI6ICd4cGxhdmF1bHQnLFxuICAgICAgICAgIGljb246ICdodHRwczovL2Fzc2V0cy54cGxhLmlvL2ljb24vZXh0ZW5zaW9uL2ljb24ucG5nJyxcbiAgICAgICAgfSxcbiAgICAgIF1cbiAgICA6IFtdO1xufVxuIl19
@@ -0,0 +1,8 @@
1
+ export declare const storage: Storage | undefined;
2
+ interface Session {
3
+ identifier: string;
4
+ }
5
+ export declare function getStoredSession(): Session | undefined;
6
+ export declare function storeSession(session: Session): void;
7
+ export declare function clearSession(): void;
8
+ export {};
@@ -0,0 +1,31 @@
1
+ export const storage = typeof window === 'undefined' ? undefined : localStorage;
2
+ const SESSION_KEY = '__xpla_extension_router_session__';
3
+ export function getStoredSession() {
4
+ const data = storage === null || storage === void 0 ? void 0 : storage.getItem(SESSION_KEY);
5
+ if (!data) {
6
+ return undefined;
7
+ }
8
+ try {
9
+ const object = JSON.parse(data);
10
+ if ('identifier' in object) {
11
+ return {
12
+ identifier: object['identifier'],
13
+ };
14
+ }
15
+ else {
16
+ storage === null || storage === void 0 ? void 0 : storage.removeItem(SESSION_KEY);
17
+ return undefined;
18
+ }
19
+ }
20
+ catch (_a) {
21
+ storage === null || storage === void 0 ? void 0 : storage.removeItem(SESSION_KEY);
22
+ return undefined;
23
+ }
24
+ }
25
+ export function storeSession(session) {
26
+ storage === null || storage === void 0 ? void 0 : storage.setItem(SESSION_KEY, JSON.stringify(session));
27
+ }
28
+ export function clearSession() {
29
+ storage === null || storage === void 0 ? void 0 : storage.removeItem(SESSION_KEY);
30
+ }
31
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2Vzc2lvbi5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3NyYy9Aa3NhbmdrdWsxMC93YWxsZXQtY29udHJvbGxlci9tb2R1bGVzL2V4dGVuc2lvbi1yb3V0ZXIvc2Vzc2lvbi50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxNQUFNLENBQUMsTUFBTSxPQUFPLEdBQUcsT0FBTyxNQUFNLEtBQUssV0FBVyxDQUFDLENBQUMsQ0FBQyxTQUFTLENBQUMsQ0FBQyxDQUFDLFlBQVksQ0FBQztBQU1oRixNQUFNLFdBQVcsR0FBRyxtQ0FBbUMsQ0FBQztBQUV4RCxNQUFNLFVBQVUsZ0JBQWdCO0lBQzlCLE1BQU0sSUFBSSxHQUFHLE9BQU8sYUFBUCxPQUFPLHVCQUFQLE9BQU8sQ0FBRSxPQUFPLENBQUMsV0FBVyxDQUFDLENBQUM7SUFFM0MsSUFBSSxDQUFDLElBQUksRUFBRTtRQUNULE9BQU8sU0FBUyxDQUFDO0tBQ2xCO0lBRUQsSUFBSTtRQUNGLE1BQU0sTUFBTSxHQUFHLElBQUksQ0FBQyxLQUFLLENBQUMsSUFBSSxDQUFDLENBQUM7UUFFaEMsSUFBSSxZQUFZLElBQUksTUFBTSxFQUFFO1lBQzFCLE9BQU87Z0JBQ0wsVUFBVSxFQUFFLE1BQU0sQ0FBQyxZQUFZLENBQUM7YUFDakMsQ0FBQztTQUNIO2FBQU07WUFDTCxPQUFPLGFBQVAsT0FBTyx1QkFBUCxPQUFPLENBQUUsVUFBVSxDQUFDLFdBQVcsQ0FBQyxDQUFDO1lBQ2pDLE9BQU8sU0FBUyxDQUFDO1NBQ2xCO0tBQ0Y7SUFBQyxXQUFNO1FBQ04sT0FBTyxhQUFQLE9BQU8sdUJBQVAsT0FBTyxDQUFFLFVBQVUsQ0FBQyxXQUFXLENBQUMsQ0FBQztRQUNqQyxPQUFPLFNBQVMsQ0FBQztLQUNsQjtBQUNILENBQUM7QUFFRCxNQUFNLFVBQVUsWUFBWSxDQUFDLE9BQWdCO0lBQzNDLE9BQU8sYUFBUCxPQUFPLHVCQUFQLE9BQU8sQ0FBRSxPQUFPLENBQUMsV0FBVyxFQUFFLElBQUksQ0FBQyxTQUFTLENBQUMsT0FBTyxDQUFDLENBQUMsQ0FBQztBQUN6RCxDQUFDO0FBRUQsTUFBTSxVQUFVLFlBQVk7SUFDMUIsT0FBTyxhQUFQLE9BQU8sdUJBQVAsT0FBTyxDQUFFLFVBQVUsQ0FBQyxXQUFXLENBQUMsQ0FBQztBQUNuQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGNvbnN0IHN0b3JhZ2UgPSB0eXBlb2Ygd2luZG93ID09PSAndW5kZWZpbmVkJyA/IHVuZGVmaW5lZCA6IGxvY2FsU3RvcmFnZTtcblxuaW50ZXJmYWNlIFNlc3Npb24ge1xuICBpZGVudGlmaWVyOiBzdHJpbmc7XG59XG5cbmNvbnN0IFNFU1NJT05fS0VZID0gJ19feHBsYV9leHRlbnNpb25fcm91dGVyX3Nlc3Npb25fXyc7XG5cbmV4cG9ydCBmdW5jdGlvbiBnZXRTdG9yZWRTZXNzaW9uKCk6IFNlc3Npb24gfCB1bmRlZmluZWQge1xuICBjb25zdCBkYXRhID0gc3RvcmFnZT8uZ2V0SXRlbShTRVNTSU9OX0tFWSk7XG5cbiAgaWYgKCFkYXRhKSB7XG4gICAgcmV0dXJuIHVuZGVmaW5lZDtcbiAgfVxuXG4gIHRyeSB7XG4gICAgY29uc3Qgb2JqZWN0ID0gSlNPTi5wYXJzZShkYXRhKTtcblxuICAgIGlmICgnaWRlbnRpZmllcicgaW4gb2JqZWN0KSB7XG4gICAgICByZXR1cm4ge1xuICAgICAgICBpZGVudGlmaWVyOiBvYmplY3RbJ2lkZW50aWZpZXInXSxcbiAgICAgIH07XG4gICAgfSBlbHNlIHtcbiAgICAgIHN0b3JhZ2U/LnJlbW92ZUl0ZW0oU0VTU0lPTl9LRVkpO1xuICAgICAgcmV0dXJuIHVuZGVmaW5lZDtcbiAgICB9XG4gIH0gY2F0Y2gge1xuICAgIHN0b3JhZ2U/LnJlbW92ZUl0ZW0oU0VTU0lPTl9LRVkpO1xuICAgIHJldHVybiB1bmRlZmluZWQ7XG4gIH1cbn1cblxuZXhwb3J0IGZ1bmN0aW9uIHN0b3JlU2Vzc2lvbihzZXNzaW9uOiBTZXNzaW9uKSB7XG4gIHN0b3JhZ2U/LnNldEl0ZW0oU0VTU0lPTl9LRVksIEpTT04uc3RyaW5naWZ5KHNlc3Npb24pKTtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGNsZWFyU2Vzc2lvbigpIHtcbiAgc3RvcmFnZT8ucmVtb3ZlSXRlbShTRVNTSU9OX0tFWSk7XG59XG4iXX0=