@matchain/matchid-sdk-react 0.1.37-alpha.2 → 0.1.37-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.
Files changed (60) hide show
  1. package/dist/assets/icon/index.d.mts +123 -0
  2. package/dist/assets/icon/index.d.ts +123 -0
  3. package/dist/assets/icon/index.js +1055 -0
  4. package/dist/assets/icon/index.js.map +1 -0
  5. package/dist/assets/icon/index.mjs +82 -0
  6. package/dist/assets/icon/index.mjs.map +1 -0
  7. package/dist/chunk-HYQ3T6WW.mjs +79 -0
  8. package/dist/chunk-HYQ3T6WW.mjs.map +1 -0
  9. package/dist/chunk-J5LGTIGS.mjs +10 -0
  10. package/dist/chunk-J5LGTIGS.mjs.map +1 -0
  11. package/dist/chunk-J6EA7OSJ.mjs +992 -0
  12. package/dist/chunk-J6EA7OSJ.mjs.map +1 -0
  13. package/dist/chunk-MZB76VOE.mjs +93 -0
  14. package/dist/chunk-MZB76VOE.mjs.map +1 -0
  15. package/dist/chunk-YCRZLAOS.mjs +3709 -0
  16. package/dist/chunk-YCRZLAOS.mjs.map +1 -0
  17. package/dist/components/index.d.mts +4 -0
  18. package/dist/components/index.d.ts +4 -0
  19. package/dist/components/index.js +3352 -0
  20. package/dist/components/index.js.map +1 -0
  21. package/dist/components/index.mjs +39 -0
  22. package/dist/components/index.mjs.map +1 -0
  23. package/dist/config/chains/index.d.mts +2 -0
  24. package/dist/config/chains/index.d.ts +2 -0
  25. package/dist/config/chains/index.js +94 -0
  26. package/dist/config/chains/index.js.map +1 -0
  27. package/dist/config/chains/index.mjs +10 -0
  28. package/dist/config/chains/index.mjs.map +1 -0
  29. package/dist/hooks/api/index.d.mts +5 -0
  30. package/dist/hooks/api/index.d.ts +5 -0
  31. package/dist/hooks/api/index.js +1010 -0
  32. package/dist/hooks/api/index.js.map +1 -0
  33. package/dist/hooks/api/index.mjs +14 -0
  34. package/dist/hooks/api/index.mjs.map +1 -0
  35. package/dist/hooks/index.d.mts +4 -0
  36. package/dist/hooks/index.d.ts +4 -0
  37. package/dist/hooks/index.js +1055 -0
  38. package/dist/hooks/index.js.map +1 -0
  39. package/dist/hooks/index.mjs +17 -0
  40. package/dist/hooks/index.mjs.map +1 -0
  41. package/dist/index-BFn-HCRJ.d.ts +64 -0
  42. package/dist/index-BTTka3Uo.d.mts +75 -0
  43. package/dist/index-BdeWio3u.d.mts +64 -0
  44. package/dist/index-CfipOX1C.d.ts +83 -0
  45. package/dist/index-DUCRzr-P.d.ts +75 -0
  46. package/dist/index-DXRGMAbv.d.mts +83 -0
  47. package/dist/index-DXRGMAbv.d.ts +83 -0
  48. package/dist/index-Dq1vYJ0E.d.mts +83 -0
  49. package/dist/index.css +7 -0
  50. package/dist/index.d.mts +12 -436
  51. package/dist/index.d.ts +12 -436
  52. package/dist/index.js +1185 -297
  53. package/dist/index.js.map +1 -1
  54. package/dist/index.mjs +13 -3682
  55. package/dist/index.mjs.map +1 -1
  56. package/dist/types.d-Cqt8ifXa.d.mts +176 -0
  57. package/dist/types.d-Cqt8ifXa.d.ts +176 -0
  58. package/example/src/config/index.ts +6 -1
  59. package/example/src/pages/User.tsx +12 -3
  60. package/package.json +23 -2
@@ -0,0 +1,1010 @@
1
+ "use strict";
2
+ var __create = Object.create;
3
+ var __defProp = Object.defineProperty;
4
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
5
+ var __getOwnPropNames = Object.getOwnPropertyNames;
6
+ var __getProtoOf = Object.getPrototypeOf;
7
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
8
+ var __export = (target, all) => {
9
+ for (var name in all)
10
+ __defProp(target, name, { get: all[name], enumerable: true });
11
+ };
12
+ var __copyProps = (to, from, except, desc) => {
13
+ if (from && typeof from === "object" || typeof from === "function") {
14
+ for (let key of __getOwnPropNames(from))
15
+ if (!__hasOwnProp.call(to, key) && key !== except)
16
+ __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
17
+ }
18
+ return to;
19
+ };
20
+ var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
21
+ // If the importer is in node compatibility mode or this is not an ESM
22
+ // file that has been converted to a CommonJS file using a Babel-
23
+ // compatible transform (i.e. "__esModule" has not been set), then set
24
+ // "default" to the CommonJS "module.exports" for node compatibility.
25
+ isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
26
+ mod
27
+ ));
28
+ var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
29
+
30
+ // src/hooks/api/index.ts
31
+ var api_exports = {};
32
+ __export(api_exports, {
33
+ bind: () => bind_exports,
34
+ poh: () => poh_exports,
35
+ user: () => user_exports
36
+ });
37
+ module.exports = __toCommonJS(api_exports);
38
+
39
+ // src/hooks/api/bind.ts
40
+ var bind_exports = {};
41
+ __export(bind_exports, {
42
+ bindCexApi: () => bindCexApi,
43
+ unBindApi: () => unBindApi,
44
+ unBindWalletApi: () => unBindWalletApi,
45
+ useBindInfo: () => useBindInfo,
46
+ useBindList: () => useBindList
47
+ });
48
+ var import_react_query2 = require("@tanstack/react-query");
49
+
50
+ // src/store/useLocalStore.ts
51
+ var import_zustand = require("zustand");
52
+ var import_middleware = require("zustand/middleware");
53
+ var persistedState = (0, import_middleware.persist)(
54
+ (set) => ({
55
+ appid: "",
56
+ token: "",
57
+ did: "",
58
+ mid: "",
59
+ overview: null,
60
+ theme: "light",
61
+ setOverview: (overview) => set({
62
+ overview,
63
+ address: overview.address,
64
+ did: overview.did,
65
+ mid: overview.mid
66
+ }),
67
+ endpoints: {
68
+ back: "https://api.matchid.ai/",
69
+ auth: "https://auth.matchid.ai/"
70
+ },
71
+ setDid: (did) => set({ did }),
72
+ setToken: (token) => set({ token }),
73
+ setAppid: (appid) => set({ appid }),
74
+ setMid: (mid) => set({ mid }),
75
+ logout: () => set({ token: "", did: "", mid: "", address: "", overview: null }),
76
+ setTheme: (theme) => set({ theme }),
77
+ setEndpoints: (endpoints) => set({ endpoints }),
78
+ address: "",
79
+ setAddress: (address) => set({ address }),
80
+ locale: "en",
81
+ setLocale: (locale) => set({ locale })
82
+ }),
83
+ { name: "match-local" }
84
+ );
85
+ var useLocalStore = (0, import_zustand.create)((0, import_middleware.devtools)(persistedState));
86
+ var localStore = useLocalStore;
87
+ var useLocalStore_default = useLocalStore;
88
+
89
+ // src/hooks/useUserInfo.tsx
90
+ var import_react24 = require("react");
91
+
92
+ // src/api/request.ts
93
+ var import_axios = __toESM(require("axios"));
94
+
95
+ // src/config/env/index.ts
96
+ var env_default = {
97
+ endpoints: {
98
+ back: "https://api.matchid.ai/",
99
+ auth: "https://auth.matchid.ai/"
100
+ }
101
+ };
102
+
103
+ // src/store/index.ts
104
+ var getEndpoints = () => {
105
+ try {
106
+ const store = localStore.getState();
107
+ const env = store?.endpoints;
108
+ if (env) {
109
+ return env;
110
+ } else {
111
+ return env_default.endpoints;
112
+ }
113
+ } catch (e) {
114
+ return env_default.endpoints;
115
+ }
116
+ };
117
+ var getAppid = () => {
118
+ try {
119
+ const store = localStore.getState();
120
+ const appid = store?.appid;
121
+ if (appid) {
122
+ return appid;
123
+ } else {
124
+ return "";
125
+ }
126
+ } catch (e) {
127
+ return "";
128
+ }
129
+ };
130
+ var getLocale = () => {
131
+ try {
132
+ const store = localStore.getState();
133
+ const locale = store?.locale;
134
+ if (locale) {
135
+ return locale;
136
+ } else {
137
+ return "en";
138
+ }
139
+ } catch (e) {
140
+ return "en";
141
+ }
142
+ };
143
+ var getToken = () => {
144
+ try {
145
+ const store = localStore.getState();
146
+ const token = store?.token;
147
+ if (token) {
148
+ return token;
149
+ } else {
150
+ return "";
151
+ }
152
+ } catch (e) {
153
+ return "";
154
+ }
155
+ };
156
+
157
+ // src/utils/matchlog.ts
158
+ var matchDevExists = () => localStorage.getItem("matchid-sdk-react-debug") !== null;
159
+ var handler = {
160
+ get(target, prop) {
161
+ if (matchDevExists() && typeof target[prop] === "function") {
162
+ return target[prop].bind(console);
163
+ }
164
+ return () => {
165
+ };
166
+ }
167
+ };
168
+ var matchlog = new Proxy(console, handler);
169
+ var matchlog_default = matchlog;
170
+
171
+ // src/api/request.ts
172
+ var SUCCESS_CODE = 0;
173
+ var isSuccess = (res) => {
174
+ return res.code === SUCCESS_CODE;
175
+ };
176
+ var instance = import_axios.default.create({
177
+ timeout: 6e4,
178
+ validateStatus(status) {
179
+ return status >= 200 && status <= 500;
180
+ }
181
+ });
182
+ var request = async (config) => {
183
+ try {
184
+ const endpoints = getEndpoints();
185
+ const token = getToken();
186
+ instance.defaults.baseURL = `${endpoints.back}`;
187
+ instance.defaults.headers.common["Appid"] = getAppid();
188
+ if (token) {
189
+ instance.defaults.headers.common["Authorization"] = token;
190
+ }
191
+ instance.defaults.headers.common["Accept-Language"] = getLocale();
192
+ const { data } = await instance.request(config);
193
+ matchlog_default.log("api", data);
194
+ if (data.code == 401001) {
195
+ localStore.getState().logout();
196
+ throw new Error("Your session has expired, please log in again");
197
+ }
198
+ return data;
199
+ } catch (err) {
200
+ console.error("qwe-err", err);
201
+ const message = "Request Error";
202
+ console.error(message);
203
+ return {
204
+ code: -1,
205
+ data: null,
206
+ message,
207
+ success: false,
208
+ fail: true,
209
+ result: null
210
+ };
211
+ }
212
+ };
213
+ var request_default = request;
214
+
215
+ // src/api/index.ts
216
+ var getEmailCodeApi = (email) => {
217
+ return request_default({
218
+ url: `/api/v1/email/code`,
219
+ method: "POST",
220
+ data: { email }
221
+ });
222
+ };
223
+ var verifyEmailCodeApi = ({ email, verification_key, verification_code }) => {
224
+ return request_default({
225
+ url: `/api/v1/user/email/login`,
226
+ method: "POST",
227
+ data: { email, verification_key, verification_code }
228
+ });
229
+ };
230
+ var getOverviewInfoApi = () => {
231
+ return request_default({
232
+ url: `/api/v1/user/overview`,
233
+ method: "GET"
234
+ });
235
+ };
236
+ var toLogoutApi = () => {
237
+ return request_default({
238
+ url: `/api/v1/user/logout`,
239
+ method: "POST"
240
+ });
241
+ };
242
+ var getBindListApi = () => {
243
+ return request_default({
244
+ url: `/api/v1/bind/list`,
245
+ method: "GET"
246
+ });
247
+ };
248
+ var getPohListApi = () => {
249
+ return request_default({
250
+ url: `/api/v1/poh/list`,
251
+ method: "GET"
252
+ });
253
+ };
254
+ var getBindInfoApi = () => {
255
+ return request_default({
256
+ url: `/api/v1/bind`,
257
+ method: "GET"
258
+ });
259
+ };
260
+ var bindCexApi = ({ cex, api_key, api_secret }) => {
261
+ return request_default({
262
+ url: `/api/v1/cex/subscribe`,
263
+ method: "POST",
264
+ data: { cex, api_key, api_secret }
265
+ });
266
+ };
267
+ var unBindApi = ({ type }) => {
268
+ return request_default({
269
+ url: `/api/v1/unbind`,
270
+ method: "POST",
271
+ data: { type }
272
+ });
273
+ };
274
+ var unBindWalletApi = ({ address }) => {
275
+ return request_default({
276
+ url: `/api/v1/wallet/unbind`,
277
+ method: "POST",
278
+ data: { address }
279
+ });
280
+ };
281
+ var verifyPohApi = ({
282
+ taskId,
283
+ schemaId,
284
+ publicFields,
285
+ allocatorAddress,
286
+ publicFieldsHash,
287
+ allocatorSignature,
288
+ uHash,
289
+ validatorAddress,
290
+ validatorSignature
291
+ }) => {
292
+ return request_default({
293
+ url: `/api/v1/poh/zkpass`,
294
+ method: "POST",
295
+ data: {
296
+ taskId,
297
+ schemaId,
298
+ publicFields,
299
+ allocatorAddress,
300
+ publicFieldsHash,
301
+ allocatorSignature,
302
+ uHash,
303
+ validatorAddress,
304
+ validatorSignature
305
+ }
306
+ });
307
+ };
308
+ var chooseIdentityApi = ({ identity }) => {
309
+ return request_default({
310
+ url: `/api/v1/user/choose/identity`,
311
+ method: "POST",
312
+ data: { identity }
313
+ });
314
+ };
315
+ var mintPassportNftApi = () => {
316
+ return request_default({
317
+ url: `/api/v1/mint/passport/nft`,
318
+ method: "POST"
319
+ });
320
+ };
321
+ var getAuthInfoApi = () => {
322
+ return request_default({
323
+ url: `/api/v1/user/auth`,
324
+ method: "GET"
325
+ });
326
+ };
327
+
328
+ // src/MatchContext.tsx
329
+ var import_react23 = require("react");
330
+
331
+ // src/assets/icon/ArrowLeftIcon.tsx
332
+ var import_jsx_runtime = require("react/jsx-runtime");
333
+
334
+ // src/assets/icon/BackIcon.tsx
335
+ var import_jsx_runtime2 = require("react/jsx-runtime");
336
+
337
+ // src/assets/icon/CloseIcon.tsx
338
+ var import_jsx_runtime3 = require("react/jsx-runtime");
339
+
340
+ // src/assets/icon/XIcon.tsx
341
+ var import_jsx_runtime4 = require("react/jsx-runtime");
342
+
343
+ // src/assets/icon/GoogleIcon.tsx
344
+ var import_jsx_runtime5 = require("react/jsx-runtime");
345
+
346
+ // src/assets/icon/WalletIcon.tsx
347
+ var import_jsx_runtime6 = require("react/jsx-runtime");
348
+
349
+ // src/assets/icon/TelegramIcon.tsx
350
+ var import_jsx_runtime7 = require("react/jsx-runtime");
351
+
352
+ // src/assets/icon/EmailIcon.tsx
353
+ var import_jsx_runtime8 = require("react/jsx-runtime");
354
+
355
+ // src/assets/icon/ArrowRightIcon.tsx
356
+ var import_jsx_runtime9 = require("react/jsx-runtime");
357
+
358
+ // src/assets/icon/CloseRoundIcon.tsx
359
+ var import_jsx_runtime10 = require("react/jsx-runtime");
360
+
361
+ // src/assets/icon/LoadingIcon.tsx
362
+ var import_jsx_runtime11 = require("react/jsx-runtime");
363
+
364
+ // src/assets/icon/EmailLineIcon.tsx
365
+ var import_jsx_runtime12 = require("react/jsx-runtime");
366
+
367
+ // src/assets/icon/UnLoginIcon.tsx
368
+ var import_jsx_runtime13 = require("react/jsx-runtime");
369
+
370
+ // src/assets/icon/LoginIcon.tsx
371
+ var import_jsx_runtime14 = require("react/jsx-runtime");
372
+
373
+ // src/assets/icon/CheckRoundIcon.tsx
374
+ var import_jsx_runtime15 = require("react/jsx-runtime");
375
+
376
+ // src/assets/icon/PasswordRoundIcon.tsx
377
+ var import_jsx_runtime16 = require("react/jsx-runtime");
378
+
379
+ // src/assets/icon/CloseEyeIcon.tsx
380
+ var import_jsx_runtime17 = require("react/jsx-runtime");
381
+
382
+ // src/assets/icon/OpenEyeIcon.tsx
383
+ var import_jsx_runtime18 = require("react/jsx-runtime");
384
+
385
+ // src/assets/icon/DeleteRoundIcon.tsx
386
+ var import_jsx_runtime19 = require("react/jsx-runtime");
387
+
388
+ // src/assets/icon/FacebookIcon.tsx
389
+ var import_jsx_runtime20 = require("react/jsx-runtime");
390
+
391
+ // src/assets/icon/GithubIcon.tsx
392
+ var import_jsx_runtime21 = require("react/jsx-runtime");
393
+
394
+ // src/assets/icon/DiscordIcon.tsx
395
+ var import_jsx_runtime22 = require("react/jsx-runtime");
396
+
397
+ // src/assets/icon/CheckIcon.tsx
398
+ var import_jsx_runtime23 = require("react/jsx-runtime");
399
+
400
+ // src/assets/icon/CopyIcon.tsx
401
+ var import_jsx_runtime24 = require("react/jsx-runtime");
402
+
403
+ // src/assets/icon/LinkedinIcon.tsx
404
+ var import_jsx_runtime25 = require("react/jsx-runtime");
405
+
406
+ // src/assets/icon/YoutubeIcon.tsx
407
+ var import_jsx_runtime26 = require("react/jsx-runtime");
408
+
409
+ // src/assets/icon/BTCDarkIcon.tsx
410
+ var import_jsx_runtime27 = require("react/jsx-runtime");
411
+
412
+ // src/assets/icon/BTCLightIcon.tsx
413
+ var import_jsx_runtime28 = require("react/jsx-runtime");
414
+
415
+ // src/assets/icon/EVMDarkIcon.tsx
416
+ var import_jsx_runtime29 = require("react/jsx-runtime");
417
+
418
+ // src/assets/icon/EVMLightIcon.tsx
419
+ var import_jsx_runtime30 = require("react/jsx-runtime");
420
+
421
+ // src/assets/icon/SOLDarkIcon.tsx
422
+ var import_jsx_runtime31 = require("react/jsx-runtime");
423
+
424
+ // src/assets/icon/SOLLightIcon.tsx
425
+ var import_jsx_runtime32 = require("react/jsx-runtime");
426
+
427
+ // src/assets/icon/TRXDarkIcon.tsx
428
+ var import_jsx_runtime33 = require("react/jsx-runtime");
429
+
430
+ // src/assets/icon/TRXLightIcon.tsx
431
+ var import_jsx_runtime34 = require("react/jsx-runtime");
432
+
433
+ // src/assets/icon/ArrowDownIcon.tsx
434
+ var import_jsx_runtime35 = require("react/jsx-runtime");
435
+
436
+ // src/assets/icon/LeatherIcon.tsx
437
+ var import_jsx_runtime36 = require("react/jsx-runtime");
438
+
439
+ // src/assets/icon/UnisatIcon.tsx
440
+ var import_jsx_runtime37 = require("react/jsx-runtime");
441
+
442
+ // src/assets/icon/XverseIcon.tsx
443
+ var import_jsx_runtime38 = require("react/jsx-runtime");
444
+
445
+ // src/hooks/useLayout.tsx
446
+ var import_react = require("react");
447
+
448
+ // src/components/Modal/index.tsx
449
+ var import_jsx_runtime39 = require("react/jsx-runtime");
450
+
451
+ // src/components/PasswordModal/index.tsx
452
+ var import_react5 = require("react");
453
+
454
+ // src/components/Input/index.tsx
455
+ var import_react2 = require("react");
456
+ var import_jsx_runtime40 = require("react/jsx-runtime");
457
+
458
+ // src/components/Field/index.tsx
459
+ var import_jsx_runtime41 = require("react/jsx-runtime");
460
+
461
+ // src/components/Button/index.tsx
462
+ var import_jsx_runtime42 = require("react/jsx-runtime");
463
+
464
+ // src/hooks/useMatchEvents.ts
465
+ var import_react3 = require("react");
466
+
467
+ // src/hooks/eventManager.ts
468
+ var EventManager = class {
469
+ constructor() {
470
+ this.listeners = {};
471
+ }
472
+ on(event, callback) {
473
+ if (!this.listeners[event]) {
474
+ this.listeners[event] = /* @__PURE__ */ new Set();
475
+ }
476
+ this.listeners[event].add(callback);
477
+ }
478
+ off(event, callback) {
479
+ if (this.listeners[event]) {
480
+ this.listeners[event].delete(callback);
481
+ if (this.listeners[event].size === 0) {
482
+ delete this.listeners[event];
483
+ }
484
+ }
485
+ }
486
+ emit(event, ...args) {
487
+ if (this.listeners[event]) {
488
+ this.listeners[event].forEach((callback) => callback(...args));
489
+ }
490
+ }
491
+ };
492
+ var eventManager = new EventManager();
493
+ var eventManager_default = eventManager;
494
+
495
+ // src/utils/index.ts
496
+ var getVersion = () => {
497
+ return "0.0.1";
498
+ };
499
+ function encodeBase64(input) {
500
+ return btoa(unescape(encodeURIComponent(input)));
501
+ }
502
+ function getAppClientId() {
503
+ return "react-sdk-" + getVersion();
504
+ }
505
+
506
+ // src/store/useStore.ts
507
+ var import_zustand2 = require("zustand");
508
+ var useStore = (0, import_zustand2.create)((set) => ({
509
+ walletIframeInited: false,
510
+ setWalletIframeInited: (inited) => set({ walletIframeInited: inited }),
511
+ recoveryModal: {
512
+ open: false,
513
+ success: async () => {
514
+ },
515
+ close: async () => {
516
+ }
517
+ },
518
+ setRecoveryModal: (params) => set({ recoveryModal: params }),
519
+ closeRecoveryModal: () => set({ recoveryModal: { open: false } })
520
+ }));
521
+
522
+ // src/hooks/useWallet.tsx
523
+ var import_accounts = require("viem/accounts");
524
+ var AppClientId = "react-sdk-" + getVersion();
525
+
526
+ // src/hooks/useCopyClipboard.ts
527
+ var import_copy_to_clipboard = __toESM(require("copy-to-clipboard"));
528
+ var import_react4 = require("react");
529
+
530
+ // src/components/PasswordModal/index.tsx
531
+ var import_react_intl = require("react-intl");
532
+ var import_jsx_runtime43 = require("react/jsx-runtime");
533
+
534
+ // src/components/RecoveryModal/index.tsx
535
+ var import_react6 = require("react");
536
+ var import_react_intl2 = require("react-intl");
537
+ var import_jsx_runtime44 = require("react/jsx-runtime");
538
+
539
+ // src/store/useModalStore.ts
540
+ var import_zustand3 = require("zustand");
541
+ var useSOLModalStore = (0, import_zustand3.create)((set) => ({
542
+ isOpen: false,
543
+ type: "",
544
+ open: (type) => set({ isOpen: true, type }),
545
+ close: () => set({ isOpen: false })
546
+ }));
547
+ var useTronModalStore = (0, import_zustand3.create)((set) => ({
548
+ isOpen: false,
549
+ type: "",
550
+ open: (type) => set({ isOpen: true, type }),
551
+ close: () => set({ isOpen: false })
552
+ }));
553
+ var useBTCModalStore = (0, import_zustand3.create)((set) => ({
554
+ isOpen: false,
555
+ type: "",
556
+ open: (type) => set({ isOpen: true, type }),
557
+ close: () => set({ isOpen: false })
558
+ }));
559
+ var useCEXBindModalStore = (0, import_zustand3.create)((set) => ({
560
+ type: "",
561
+ isOpen: false,
562
+ open: (type) => set({ isOpen: true, type }),
563
+ close: () => set({ isOpen: false })
564
+ }));
565
+
566
+ // src/components/EmailModal/index.tsx
567
+ var import_react9 = require("react");
568
+
569
+ // src/components/EmailModal/StepEmail.tsx
570
+ var import_react7 = require("react");
571
+ var import_react_intl3 = require("react-intl");
572
+ var import_jsx_runtime45 = require("react/jsx-runtime");
573
+
574
+ // src/components/EmailModal/StepVerify.tsx
575
+ var import_react8 = require("react");
576
+ var import_react_intl4 = require("react-intl");
577
+ var import_jsx_runtime46 = require("react/jsx-runtime");
578
+
579
+ // src/components/EmailModal/index.tsx
580
+ var import_react_intl5 = require("react-intl");
581
+ var import_jsx_runtime47 = require("react/jsx-runtime");
582
+
583
+ // src/components/Popover/index.tsx
584
+ var import_react10 = require("react");
585
+ var import_jsx_runtime48 = require("react/jsx-runtime");
586
+
587
+ // src/components/LoginBox/index.tsx
588
+ var import_react11 = require("react");
589
+ var import_react_intl6 = require("react-intl");
590
+ var import_jsx_runtime49 = require("react/jsx-runtime");
591
+
592
+ // src/components/LoginButton/index.tsx
593
+ var import_react13 = require("react");
594
+
595
+ // src/components/LoginPanel/index.tsx
596
+ var import_react_intl7 = require("react-intl");
597
+ var import_jsx_runtime50 = require("react/jsx-runtime");
598
+
599
+ // src/components/LoginModal/index.tsx
600
+ var import_jsx_runtime51 = require("react/jsx-runtime");
601
+
602
+ // src/components/UserPopover/index.tsx
603
+ var import_react12 = require("react");
604
+
605
+ // src/assets/icon/ProfileIcon.tsx
606
+ var import_jsx_runtime52 = require("react/jsx-runtime");
607
+
608
+ // src/components/UserPopover/index.tsx
609
+ var import_react_intl8 = require("react-intl");
610
+ var import_jsx_runtime53 = require("react/jsx-runtime");
611
+
612
+ // src/components/LoginButton/index.tsx
613
+ var import_react_intl9 = require("react-intl");
614
+ var import_jsx_runtime54 = require("react/jsx-runtime");
615
+
616
+ // src/components/UsernameModal/index.tsx
617
+ var import_react14 = require("react");
618
+
619
+ // src/assets/icon/InfoRoundIcon.tsx
620
+ var import_jsx_runtime55 = require("react/jsx-runtime");
621
+
622
+ // src/components/UsernameModal/index.tsx
623
+ var import_react_intl10 = require("react-intl");
624
+ var import_jsx_runtime56 = require("react/jsx-runtime");
625
+
626
+ // src/components/SOLModal/index.tsx
627
+ var import_react16 = __toESM(require("react"));
628
+ var import_web3 = require("@solana/web3.js");
629
+ var import_wallet_adapter_react = require("@solana/wallet-adapter-react");
630
+ var import_wallet_adapter_react_ui = require("@solana/wallet-adapter-react-ui");
631
+
632
+ // node_modules/@solana/wallet-adapter-base/lib/esm/types.js
633
+ var WalletAdapterNetwork;
634
+ (function(WalletAdapterNetwork2) {
635
+ WalletAdapterNetwork2["Mainnet"] = "mainnet-beta";
636
+ WalletAdapterNetwork2["Testnet"] = "testnet";
637
+ WalletAdapterNetwork2["Devnet"] = "devnet";
638
+ })(WalletAdapterNetwork || (WalletAdapterNetwork = {}));
639
+
640
+ // src/components/SOLModal/index.tsx
641
+ var import_wallet_adapter_wallets = require("@solana/wallet-adapter-wallets");
642
+ var import_styles = require("@solana/wallet-adapter-react-ui/styles.css");
643
+ var import_react_intl11 = require("react-intl");
644
+
645
+ // src/components/WalletModalContent/index.tsx
646
+ var import_react15 = require("react");
647
+ var import_jsx_runtime57 = require("react/jsx-runtime");
648
+
649
+ // src/components/SOLModal/index.tsx
650
+ var import_jsx_runtime58 = require("react/jsx-runtime");
651
+ var wallets = [
652
+ new import_wallet_adapter_wallets.PhantomWalletAdapter(),
653
+ new import_wallet_adapter_wallets.SolflareWalletAdapter(),
654
+ new import_wallet_adapter_wallets.WalletConnectWalletAdapter({
655
+ network: WalletAdapterNetwork.Mainnet,
656
+ options: {
657
+ relayUrl: "wss://relay.walletconnect.com"
658
+ }
659
+ }),
660
+ new import_wallet_adapter_wallets.AlphaWalletAdapter(),
661
+ new import_wallet_adapter_wallets.AvanaWalletAdapter(),
662
+ new import_wallet_adapter_wallets.BitgetWalletAdapter(),
663
+ new import_wallet_adapter_wallets.BitpieWalletAdapter(),
664
+ new import_wallet_adapter_wallets.CloverWalletAdapter(),
665
+ new import_wallet_adapter_wallets.Coin98WalletAdapter(),
666
+ new import_wallet_adapter_wallets.CoinbaseWalletAdapter(),
667
+ new import_wallet_adapter_wallets.CoinhubWalletAdapter(),
668
+ new import_wallet_adapter_wallets.FractalWalletAdapter(),
669
+ new import_wallet_adapter_wallets.HuobiWalletAdapter(),
670
+ new import_wallet_adapter_wallets.HyperPayWalletAdapter(),
671
+ new import_wallet_adapter_wallets.KeystoneWalletAdapter(),
672
+ new import_wallet_adapter_wallets.KrystalWalletAdapter(),
673
+ new import_wallet_adapter_wallets.LedgerWalletAdapter(),
674
+ new import_wallet_adapter_wallets.MathWalletAdapter(),
675
+ new import_wallet_adapter_wallets.NekoWalletAdapter(),
676
+ new import_wallet_adapter_wallets.NightlyWalletAdapter(),
677
+ new import_wallet_adapter_wallets.NufiWalletAdapter(),
678
+ new import_wallet_adapter_wallets.OntoWalletAdapter(),
679
+ new import_wallet_adapter_wallets.ParticleAdapter(),
680
+ new import_wallet_adapter_wallets.SafePalWalletAdapter(),
681
+ new import_wallet_adapter_wallets.SaifuWalletAdapter(),
682
+ new import_wallet_adapter_wallets.SalmonWalletAdapter(),
683
+ new import_wallet_adapter_wallets.SkyWalletAdapter(),
684
+ new import_wallet_adapter_wallets.SolongWalletAdapter(),
685
+ new import_wallet_adapter_wallets.SpotWalletAdapter(),
686
+ new import_wallet_adapter_wallets.TokenaryWalletAdapter(),
687
+ new import_wallet_adapter_wallets.TokenPocketWalletAdapter(),
688
+ new import_wallet_adapter_wallets.TorusWalletAdapter(),
689
+ new import_wallet_adapter_wallets.TrustWalletAdapter(),
690
+ new import_wallet_adapter_wallets.XDEFIWalletAdapter()
691
+ ];
692
+
693
+ // src/components/TronModal/index.tsx
694
+ var import_react17 = __toESM(require("react"));
695
+ var import_react_intl12 = require("react-intl");
696
+ var import_jsx_runtime59 = require("react/jsx-runtime");
697
+
698
+ // src/components/BTCModal/index.tsx
699
+ var import_react19 = __toESM(require("react"));
700
+ var import_react_intl13 = require("react-intl");
701
+
702
+ // src/lib/btc/XverseAdapter.ts
703
+ var import_sats_connect = require("sats-connect");
704
+
705
+ // src/hooks/useBTCWallet.ts
706
+ var import_react18 = require("react");
707
+
708
+ // src/components/BTCModal/index.tsx
709
+ var import_jsx_runtime60 = require("react/jsx-runtime");
710
+
711
+ // src/components/CEXBindModal/index.tsx
712
+ var import_react20 = require("react");
713
+ var import_react_intl14 = require("react-intl");
714
+ var import_jsx_runtime61 = require("react/jsx-runtime");
715
+
716
+ // src/context/BusinessProvider.tsx
717
+ var import_jsx_runtime62 = require("react/jsx-runtime");
718
+
719
+ // src/context/index.tsx
720
+ var import_jsx_runtime63 = (
721
+ // <MpcWalletProvider>
722
+ require("react/jsx-runtime")
723
+ );
724
+
725
+ // src/hooks/useWalletInit.ts
726
+ var import_react21 = require("react");
727
+ var AppClientId2 = getAppClientId();
728
+
729
+ // src/hooks/useInit.tsx
730
+ var import_react22 = require("react");
731
+
732
+ // src/MatchContext.tsx
733
+ var import_react_query = require("@tanstack/react-query");
734
+ var import_react_intl15 = require("react-intl");
735
+ var import_jsx_runtime64 = require("react/jsx-runtime");
736
+ var queryClient = new import_react_query.QueryClient();
737
+ var MatchContext = (0, import_react23.createContext)(void 0);
738
+ var useMatch = () => {
739
+ const context = (0, import_react23.useContext)(MatchContext);
740
+ if (context === void 0) {
741
+ throw new Error("useMatch must be used within a MatchProvider");
742
+ }
743
+ return context;
744
+ };
745
+
746
+ // src/hooks/useUserInfo.tsx
747
+ function useUserInfo() {
748
+ const {
749
+ appid,
750
+ token,
751
+ mid,
752
+ did,
753
+ logout: logoutStore,
754
+ setOverview,
755
+ overview,
756
+ address,
757
+ endpoints
758
+ } = useLocalStore_default();
759
+ const { events, login } = useMatch();
760
+ const { open: SOLOpen } = useSOLModalStore();
761
+ const { open: TronOpen } = useTronModalStore();
762
+ const { open: BTCOpen } = useBTCModalStore();
763
+ const { open: CEXBindOpen } = useCEXBindModalStore();
764
+ const isLogin = (0, import_react24.useMemo)(() => !!token, [token]);
765
+ const logout = async () => {
766
+ try {
767
+ await toLogoutApi();
768
+ } catch (err) {
769
+ console.error("logout", err);
770
+ }
771
+ logoutStore();
772
+ events && events.onLogout && events.onLogout();
773
+ eventManager_default.emit("onLogout");
774
+ };
775
+ const loginByMethod = async (method) => {
776
+ const link = `${endpoints.back}api/v1/auth/${method == "youtube" ? "google" : method}?appid=${appid}&provider=${method == "youtube" ? "google" : method}&redirect=${encodeURIComponent(endpoints.auth + "login/" + method)}&authorization=${(/* @__PURE__ */ new Date()).getTime()}${method == "youtube" ? "&auth_type=youtube" : ""}`;
777
+ matchlog_default.log("link", link);
778
+ return window.open(
779
+ link,
780
+ // Replace with the actual authorization URL
781
+ "authWindow",
782
+ "width=800,height=600"
783
+ );
784
+ };
785
+ const loginByTwitter = () => {
786
+ return loginByMethod("twitter");
787
+ };
788
+ const loginByGoogle = () => {
789
+ return loginByMethod("google");
790
+ };
791
+ const loginByWallet = async () => {
792
+ return window.open(`${endpoints.auth}login/wallet?appid=${appid}`);
793
+ };
794
+ const loginByTelegram = async () => {
795
+ return window.open(
796
+ `${endpoints.auth}login/telegram?appid=${appid}`,
797
+ // Replace with the actual authorization URL
798
+ "authWindow",
799
+ "width=800,height=600"
800
+ );
801
+ };
802
+ const loginMethod = async (method) => {
803
+ switch (method) {
804
+ case "evm":
805
+ return window.open(`${endpoints.auth}login/wallet?appid=${appid}`);
806
+ case "sol":
807
+ return SOLOpen("login");
808
+ case "tron":
809
+ return TronOpen("login");
810
+ case "btc":
811
+ return BTCOpen("login");
812
+ case "telegram":
813
+ return await loginByTelegram();
814
+ case "youtube":
815
+ case "twitter":
816
+ case "google":
817
+ case "discord":
818
+ case "github":
819
+ case "linkedin":
820
+ case "facebook":
821
+ return await loginByMethod(method);
822
+ default:
823
+ throw new Error("unsupported method");
824
+ }
825
+ };
826
+ const getLoginEmailCode = async (email) => {
827
+ const res = await getEmailCodeApi(email);
828
+ if (res && res.data && isSuccess(res)) {
829
+ window.sessionStorage.setItem("loginkey", res.data.key);
830
+ return res.data.key;
831
+ }
832
+ return "";
833
+ };
834
+ const loginByEmail = async ({
835
+ email,
836
+ code
837
+ }) => {
838
+ try {
839
+ const obj = {
840
+ email,
841
+ verification_key: window.sessionStorage.getItem("loginkey"),
842
+ verification_code: code
843
+ };
844
+ const res = await verifyEmailCodeApi(obj);
845
+ if (res && res.data && isSuccess(res)) {
846
+ await login({
847
+ mid: res.data.mid,
848
+ token: `${res.data.token_type} ${res.data.access_token}`
849
+ });
850
+ return true;
851
+ } else {
852
+ throw new Error(res.message);
853
+ }
854
+ } catch (error) {
855
+ console.error("loginByEmail", error);
856
+ throw error;
857
+ }
858
+ return false;
859
+ };
860
+ const refreshOverview = async () => {
861
+ const res = await getOverviewInfoApi();
862
+ if (res.data) {
863
+ setOverview(res.data);
864
+ }
865
+ };
866
+ const bindWallet = async () => {
867
+ if (!token) {
868
+ throw new Error("You must login first");
869
+ }
870
+ return window.open(`${endpoints.auth}bind/wallet?appid=${appid}&st=` + encodeURIComponent(encodeBase64(token)));
871
+ };
872
+ const bindTelegram = async () => {
873
+ if (!token) {
874
+ throw new Error("You must login first");
875
+ }
876
+ const authWindow = window.open(
877
+ `${endpoints.auth}bind/telegram?appid=${appid}&st=` + encodeURIComponent(encodeBase64(token)),
878
+ // Replace with the actual authorization URL
879
+ "authWindow",
880
+ "width=800,height=600"
881
+ );
882
+ };
883
+ const auth = async () => {
884
+ const res = await getAuthInfoApi();
885
+ if (isSuccess(res)) {
886
+ return res.data;
887
+ }
888
+ throw new Error(res.message);
889
+ };
890
+ const bind = async (method) => {
891
+ if (!token) {
892
+ throw new Error("You must login first");
893
+ }
894
+ switch (method) {
895
+ case "evm":
896
+ return window.open(`${endpoints.auth}bind/wallet?appid=${appid}&st=` + encodeURIComponent(encodeBase64(token)));
897
+ case "sol":
898
+ return SOLOpen("bind");
899
+ case "tron":
900
+ return TronOpen("bind");
901
+ case "btc":
902
+ return BTCOpen("bind");
903
+ case "telegram":
904
+ return await bindTelegram();
905
+ case "twitter":
906
+ case "google":
907
+ case "discord":
908
+ case "github":
909
+ case "linkedin":
910
+ case "facebook":
911
+ case "youtube":
912
+ const link = `${endpoints.back}api/v1/auth/${method == "youtube" ? "google" : method}?appid=${appid}&provider=${method == "youtube" ? "google" : method}&redirect=${encodeURIComponent(endpoints.auth + "bind/" + method)}&authorization=${token.includes("Bearer ") ? token.split(" ")[1] : token}${method == "youtube" ? "&auth_type=youtube" : ""}`;
913
+ matchlog_default.log("link", link);
914
+ return window.open(
915
+ link,
916
+ "authWindow",
917
+ "width=800,height=600"
918
+ );
919
+ default:
920
+ throw new Error("unsupported method");
921
+ }
922
+ };
923
+ const bindCex = (type) => {
924
+ return CEXBindOpen(type);
925
+ };
926
+ return {
927
+ loginByMethod,
928
+ loginByTelegram,
929
+ loginByTwitter,
930
+ loginByGoogle,
931
+ loginByWallet,
932
+ loginByEmail,
933
+ bindWallet,
934
+ bindTelegram,
935
+ token,
936
+ mid,
937
+ did,
938
+ address,
939
+ isLogin,
940
+ logout,
941
+ getLoginEmailCode,
942
+ refreshOverview,
943
+ overview,
944
+ bindCex,
945
+ username: overview?.username || "",
946
+ auth,
947
+ login: loginMethod,
948
+ bind
949
+ };
950
+ }
951
+
952
+ // src/hooks/api/bind.ts
953
+ function useBindList(options) {
954
+ const { isLogin } = useUserInfo();
955
+ return (0, import_react_query2.useQuery)({
956
+ queryKey: ["bindList"],
957
+ enabled: isLogin,
958
+ queryFn: async () => {
959
+ let res = await getBindListApi();
960
+ return res.data;
961
+ },
962
+ ...options
963
+ });
964
+ }
965
+ function useBindInfo(options) {
966
+ const { isLogin } = useUserInfo();
967
+ return (0, import_react_query2.useQuery)({
968
+ queryKey: ["bindInfo"],
969
+ enabled: isLogin,
970
+ queryFn: async () => {
971
+ let res = await getBindInfoApi();
972
+ return res.data;
973
+ },
974
+ ...options
975
+ });
976
+ }
977
+
978
+ // src/hooks/api/poh.ts
979
+ var poh_exports = {};
980
+ __export(poh_exports, {
981
+ usePohList: () => usePohList,
982
+ verifyPohApi: () => verifyPohApi
983
+ });
984
+ var import_react_query3 = require("@tanstack/react-query");
985
+ function usePohList(options) {
986
+ const { isLogin } = useUserInfo();
987
+ return (0, import_react_query3.useQuery)({
988
+ queryKey: ["pohList"],
989
+ enabled: isLogin,
990
+ queryFn: async () => {
991
+ let res = await getPohListApi();
992
+ return res.data;
993
+ },
994
+ ...options
995
+ });
996
+ }
997
+
998
+ // src/hooks/api/user.ts
999
+ var user_exports = {};
1000
+ __export(user_exports, {
1001
+ chooseIdentityApi: () => chooseIdentityApi,
1002
+ mintPassportNftApi: () => mintPassportNftApi
1003
+ });
1004
+ // Annotate the CommonJS export names for ESM import in node:
1005
+ 0 && (module.exports = {
1006
+ bind,
1007
+ poh,
1008
+ user
1009
+ });
1010
+ //# sourceMappingURL=index.js.map