@matchain/matchid-sdk-react 0.1.48-alpha.2 → 0.1.48-alpha.20

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 (73) hide show
  1. package/dist/assets/icon/index.d.mts +12 -2
  2. package/dist/assets/icon/index.d.ts +12 -2
  3. package/dist/assets/icon/index.js +93 -2
  4. package/dist/assets/icon/index.js.map +1 -1
  5. package/dist/assets/icon/index.mjs +9 -1
  6. package/dist/{chunk-6HRRPZPM.mjs → chunk-3UVHHJP6.mjs} +2 -2
  7. package/dist/chunk-5JHHHLG4.mjs +136 -0
  8. package/dist/chunk-5JHHHLG4.mjs.map +1 -0
  9. package/dist/{chunk-A5D3NKTK.mjs → chunk-LHNKZISB.mjs} +91 -4
  10. package/dist/chunk-LHNKZISB.mjs.map +1 -0
  11. package/dist/{chunk-D6IUBR7S.mjs → chunk-WHZ3HI4R.mjs} +2197 -553
  12. package/dist/chunk-WHZ3HI4R.mjs.map +1 -0
  13. package/dist/{chunk-LNSJ3ZXG.mjs → chunk-WXPVHKGJ.mjs} +73 -42
  14. package/dist/chunk-WXPVHKGJ.mjs.map +1 -0
  15. package/dist/components/index.d.mts +4 -3
  16. package/dist/components/index.d.ts +4 -3
  17. package/dist/components/index.js +2283 -525
  18. package/dist/components/index.js.map +1 -1
  19. package/dist/components/index.mjs +14 -3
  20. package/dist/hooks/api/index.d.mts +2 -2
  21. package/dist/hooks/api/index.d.ts +2 -2
  22. package/dist/hooks/api/index.js +375 -193
  23. package/dist/hooks/api/index.js.map +1 -1
  24. package/dist/hooks/api/index.mjs +5 -4
  25. package/dist/hooks/index.d.mts +4 -2
  26. package/dist/hooks/index.d.ts +4 -2
  27. package/dist/hooks/index.js +1904 -227
  28. package/dist/hooks/index.js.map +1 -1
  29. package/dist/hooks/index.mjs +12 -3
  30. package/dist/index-BMfaixEx.d.mts +66 -0
  31. package/dist/{index-DamklTOJ.d.mts → index-BMsj8hJv.d.ts} +4 -3
  32. package/dist/{index-CKiK4KHj.d.ts → index-BcEreCxd.d.ts} +1 -1
  33. package/dist/index-Bpmrd7mh.d.ts +66 -0
  34. package/dist/{index-CGs_yTFg.d.ts → index-Bvc8cjpN.d.ts} +34 -4
  35. package/dist/{index-C2-M-aBb.d.ts → index-C9F6f2iz.d.mts} +4 -3
  36. package/dist/{index-M7ZB3yR5.d.mts → index-C9qYyRgt.d.mts} +34 -4
  37. package/dist/index-CFKZWJVt.d.ts +3306 -0
  38. package/dist/{index-Bb7IkjUW.d.mts → index-Cou96DpL.d.mts} +1 -1
  39. package/dist/{index-BIgM4fy0.d.mts → index-Cy3K-Yao.d.ts} +31 -8
  40. package/dist/{index-BwD1ij0H.d.ts → index-D4ju2J_e.d.mts} +31 -8
  41. package/dist/index-Dhtyz0pT.d.mts +3306 -0
  42. package/dist/index.css +587 -6
  43. package/dist/index.d.mts +9 -8
  44. package/dist/index.d.ts +9 -8
  45. package/dist/index.js +2855 -1015
  46. package/dist/index.js.map +1 -1
  47. package/dist/index.mjs +11 -10
  48. package/dist/types/index.d.mts +2 -1
  49. package/dist/types/index.d.ts +2 -1
  50. package/dist/{types-DQq17lf4.d.mts → types-DzVVzMYU.d.mts} +74 -36
  51. package/dist/{types-DQq17lf4.d.ts → types-DzVVzMYU.d.ts} +74 -36
  52. package/dist/ui/index.d.mts +4 -3
  53. package/dist/ui/index.d.ts +4 -3
  54. package/dist/ui/index.js +140 -95
  55. package/dist/ui/index.js.map +1 -1
  56. package/dist/ui/index.mjs +2 -2
  57. package/dist/utils/index.d.mts +26 -0
  58. package/dist/utils/index.d.ts +26 -0
  59. package/dist/utils/index.js +181 -0
  60. package/dist/utils/index.js.map +1 -0
  61. package/dist/utils/index.mjs +30 -0
  62. package/dist/utils/index.mjs.map +1 -0
  63. package/example/src/pages/Wallet/components/MatchWallet.tsx +24 -10
  64. package/example/src/pages/Wallet/index.tsx +2 -1
  65. package/package.json +7 -1
  66. package/dist/chunk-A5D3NKTK.mjs.map +0 -1
  67. package/dist/chunk-D6IUBR7S.mjs.map +0 -1
  68. package/dist/chunk-LNSJ3ZXG.mjs.map +0 -1
  69. package/dist/index-BHVMQGZj.d.mts +0 -173
  70. package/dist/index-BVatQlwF.d.mts +0 -59
  71. package/dist/index-DgAnNnit.d.ts +0 -173
  72. package/dist/index-RfA22r-Z.d.ts +0 -59
  73. /package/dist/{chunk-6HRRPZPM.mjs.map → chunk-3UVHHJP6.mjs.map} +0 -0
@@ -1,4 +1,5 @@
1
1
  import {
2
+ AlphaAvatar,
2
3
  Button,
3
4
  Field,
4
5
  HashPanel_default,
@@ -11,11 +12,24 @@ import {
11
12
  Radio,
12
13
  matchlog_default,
13
14
  useDownMd,
15
+ useHash,
14
16
  useLayout_exports
15
- } from "./chunk-LNSJ3ZXG.mjs";
17
+ } from "./chunk-WXPVHKGJ.mjs";
18
+ import {
19
+ NumberFormatter,
20
+ encodeBase64,
21
+ formatAddress,
22
+ formatDate,
23
+ getAppClientId,
24
+ getVersion,
25
+ isValidEmail,
26
+ isValidUsername,
27
+ truncateAddress
28
+ } from "./chunk-5JHHHLG4.mjs";
16
29
  import {
17
30
  ArrowDownIcon,
18
31
  ArrowRightIcon,
32
+ ArrowSendIcon,
19
33
  BTCDarkIcon,
20
34
  BTCLightIcon,
21
35
  BitgetIcon,
@@ -32,8 +46,11 @@ import {
32
46
  FacebookIcon,
33
47
  GithubIcon,
34
48
  GoogleIcon,
49
+ InfoLineIcon,
50
+ InfoRoundIcon,
35
51
  LeatherIcon,
36
52
  LinkedinIcon,
53
+ LoadingIcon_default,
37
54
  LoginIcon_default,
38
55
  OKXIcon,
39
56
  SOLDarkIcon,
@@ -43,6 +60,7 @@ import {
43
60
  TelegramIcon,
44
61
  TonLightIcon,
45
62
  TonLightIcon2,
63
+ TransferIcon,
46
64
  TronLinkIcon,
47
65
  UnLoginIcon_default,
48
66
  UnisatIcon,
@@ -50,7 +68,7 @@ import {
50
68
  XIcon,
51
69
  XverseIcon,
52
70
  YoutubeIcon
53
- } from "./chunk-A5D3NKTK.mjs";
71
+ } from "./chunk-LHNKZISB.mjs";
54
72
  import {
55
73
  __export
56
74
  } from "./chunk-J5LGTIGS.mjs";
@@ -74,42 +92,20 @@ __export(components_exports, {
74
92
  SOLModal: () => SOLModal,
75
93
  TONModal: () => TONModal,
76
94
  TRONModal: () => TRONModal,
95
+ TokenDetail: () => TokenDetail,
96
+ TokenSend: () => TokenSend,
97
+ TokenSendList: () => TokenSendList,
98
+ TransactionList: () => TransactionList,
77
99
  UsernameModal: () => UsernameModal,
100
+ WalletAsset: () => WalletAsset,
78
101
  WalletModal: () => WalletModal
79
102
  });
80
103
 
81
104
  // src/components/EmailModal/index.tsx
82
- import { useEffect as useEffect13, useState as useState12 } from "react";
105
+ import { useEffect as useEffect14, useState as useState13 } from "react";
83
106
 
84
107
  // src/components/EmailModal/StepEmail.tsx
85
108
  import { useEffect, useMemo, useState } from "react";
86
-
87
- // src/utils/index.ts
88
- var getVersion = () => {
89
- return "0.0.2";
90
- };
91
- function encodeBase64(input) {
92
- return btoa(unescape(encodeURIComponent(input)));
93
- }
94
- var isValidEmail = (email) => {
95
- return /^[^\s@]+@[^\s@]+\.[^\s@]+$/.test(email);
96
- };
97
- var isValidUsername = (username) => {
98
- return /^[a-zA-Z0-9_-]+$/.test(username);
99
- };
100
- function truncateAddress(address2) {
101
- if (address2.length <= 6) {
102
- return address2;
103
- }
104
- const start = address2.slice(0, 4);
105
- const end = address2.slice(-2);
106
- return `${start}...${end}`;
107
- }
108
- function getAppClientId() {
109
- return "react-sdk-" + getVersion();
110
- }
111
-
112
- // src/components/EmailModal/StepEmail.tsx
113
109
  import { FormattedMessage, useIntl } from "react-intl";
114
110
  import { jsx, jsxs } from "react/jsx-runtime";
115
111
  function StepEmail(props) {
@@ -370,11 +366,11 @@ var unBindApi = ({ type }) => {
370
366
  data: { type }
371
367
  });
372
368
  };
373
- var unBindWalletApi = ({ address: address2 }) => {
369
+ var unBindWalletApi = ({ address }) => {
374
370
  return request_default({
375
371
  url: `/api/v1/wallet/unbind`,
376
372
  method: "POST",
377
- data: { address: address2 }
373
+ data: { address }
378
374
  });
379
375
  };
380
376
  var verifyPohApi = ({
@@ -432,7 +428,7 @@ var getWalletNonceApi = (data) => {
432
428
  };
433
429
  var loginByWalletApi = ({
434
430
  type,
435
- address: address2,
431
+ address,
436
432
  signature,
437
433
  message,
438
434
  connector_type,
@@ -441,7 +437,7 @@ var loginByWalletApi = ({
441
437
  return request_default({
442
438
  url: `/api/v1/login/wallet`,
443
439
  method: "POST",
444
- data: { type, address: address2, signature, message, connector_type, wallet_client_type }
440
+ data: { type, address, signature, message, connector_type, wallet_client_type }
445
441
  });
446
442
  };
447
443
  var getWalletInitApi = (data) => {
@@ -453,7 +449,7 @@ var getWalletInitApi = (data) => {
453
449
  };
454
450
  var toBindWalletApi = ({
455
451
  type,
456
- address: address2,
452
+ address,
457
453
  signature,
458
454
  message,
459
455
  connector_type,
@@ -462,7 +458,7 @@ var toBindWalletApi = ({
462
458
  return request_default({
463
459
  url: `/api/v1/wallet/bind`,
464
460
  method: "POST",
465
- data: { type, address: address2, signature, message, connector_type, wallet_client_type }
461
+ data: { type, address, signature, message, connector_type, wallet_client_type }
466
462
  });
467
463
  };
468
464
  var getAppConfigApi = () => {
@@ -525,6 +521,13 @@ var getWalletChainListApi = () => {
525
521
  method: "POST"
526
522
  });
527
523
  };
524
+ var getWalletNftListApi = (data) => {
525
+ return request_default({
526
+ url: `/api/v1/wallet/nfts`,
527
+ method: "POST",
528
+ data
529
+ });
530
+ };
528
531
 
529
532
  // src/store/useLocalStore.ts
530
533
  var persistedState = persist(
@@ -558,11 +561,11 @@ var persistedState = persist(
558
561
  setToken: (token) => set({ token }),
559
562
  setAppid: (appid) => set({ appid }),
560
563
  setMid: (mid) => set({ mid }),
561
- logout: () => set({ token: "", did: "", mid: "", address: "", overview: null }),
564
+ logout: () => set({ token: "", did: "", mid: "", address: "", overview: null, assets: [] }),
562
565
  setTheme: (theme) => set({ theme }),
563
566
  setEndpoints: (endpoints) => set({ endpoints }),
564
567
  address: "",
565
- setAddress: (address2) => set({ address: address2 }),
568
+ setAddress: (address) => set({ address }),
566
569
  locale: "en",
567
570
  setLocale: (locale) => set({ locale }),
568
571
  wallet: {
@@ -570,7 +573,9 @@ var persistedState = persist(
570
573
  },
571
574
  setWallet: (wallet) => set({ wallet }),
572
575
  chainId: 698,
573
- setChainId: (chainId) => set({ chainId })
576
+ setChainId: (chainId) => set({ chainId }),
577
+ assets: [],
578
+ setAssets: (assets) => set({ assets })
574
579
  }),
575
580
  { name: "match-local" }
576
581
  );
@@ -592,9 +597,13 @@ __export(hooks_exports, {
592
597
  useMatchChain: () => useMatchChain,
593
598
  useMatchEvents: () => useMatchEvents,
594
599
  useMatchWallet: () => useMatchWallet,
600
+ useMatchWalletAssetList: () => useMatchWalletAssetList,
601
+ useMatchWalletAssets: () => useMatchWalletAssets,
602
+ useMatchWalletRecords: () => useMatchWalletRecords,
595
603
  useModal: () => useModal,
596
604
  useReceipt: () => useReceipt,
597
605
  useToast: () => useToast,
606
+ useTransaction: () => useTransaction,
598
607
  useUserInfo: () => useUserInfo,
599
608
  useWallet: () => useWallet
600
609
  });
@@ -667,108 +676,113 @@ import { createWalletClient } from "viem";
667
676
  import { useEffect as useEffect3, useMemo as useMemo2 } from "react";
668
677
  import { encodeDeployData } from "viem";
669
678
 
670
- // src/store/useModalStore.ts
671
- import { create as create3 } from "zustand";
679
+ // src/context/ModalContext.tsx
680
+ import { useState as useState2, useCallback, createContext, useContext } from "react";
681
+ import { createPortal } from "react-dom";
682
+ import { jsx as jsx2, jsxs as jsxs2 } from "react/jsx-runtime";
683
+ var ModalContext = createContext(null);
684
+ function ModalProvider({ children }) {
685
+ const [modalState, setModalState] = useState2({
686
+ modals: [],
687
+ highestZIndex: 100
688
+ });
689
+ const getNextIndex = useCallback(() => {
690
+ return Math.max(...modalState.modals.map((modal) => modal.index), 0) + 1 || 100;
691
+ }, [modalState]);
692
+ const closeModal = useCallback((index) => {
693
+ setModalState((prevState) => ({
694
+ modals: prevState.modals.filter((modal) => modal.index !== index),
695
+ highestZIndex: prevState.highestZIndex
696
+ }));
697
+ }, []);
698
+ const show = useCallback((content, index) => {
699
+ setModalState((prevState) => {
700
+ const modalIndex = index !== void 0 ? index : getNextIndex();
701
+ const newZIndex = prevState.highestZIndex + 1;
702
+ return {
703
+ modals: [...prevState.modals, {
704
+ visible: true,
705
+ index: modalIndex,
706
+ zIndex: newZIndex,
707
+ content: content({ close: () => closeModal(modalIndex), zIndex: newZIndex })
708
+ }],
709
+ highestZIndex: newZIndex
710
+ };
711
+ });
712
+ }, [getNextIndex, closeModal]);
713
+ const open = useCallback((props) => {
714
+ setModalState((prevState) => {
715
+ const modalIndex = props.index !== void 0 ? props.index : getNextIndex();
716
+ const newZIndex = prevState.highestZIndex + 1;
717
+ return {
718
+ modals: [...prevState.modals, {
719
+ visible: true,
720
+ index: modalIndex,
721
+ zIndex: newZIndex,
722
+ content: /* @__PURE__ */ jsx2(ModalDrawer, { showClose: true, isOpen: true, onClose: () => closeModal(modalIndex), title: props.title, zIndex: newZIndex, onBack: props.onBack, children: /* @__PURE__ */ jsx2(props.content, { close: () => closeModal(modalIndex), zIndex: newZIndex }) })
723
+ }],
724
+ highestZIndex: newZIndex
725
+ };
726
+ });
727
+ }, [getNextIndex, closeModal]);
728
+ const modalElements = modalState.modals.sort((a, b) => b.zIndex - a.zIndex).map(
729
+ (modal) => modal.visible ? createPortal(
730
+ modal.content,
731
+ document.body
732
+ ) : null
733
+ );
734
+ return /* @__PURE__ */ jsxs2(ModalContext.Provider, { value: { show, open }, children: [
735
+ children,
736
+ modalElements
737
+ ] });
738
+ }
739
+ function useModal() {
740
+ const context = useContext(ModalContext);
741
+ if (!context) {
742
+ throw new Error("useModal must be used within a ModalProvider");
743
+ }
744
+ return context;
745
+ }
672
746
 
673
- // src/hooks/useConfig.tsx
674
- import { jsx as jsx2 } from "react/jsx-runtime";
675
- var DEFAULT_WALLET_METHODS = ["evm", "sol", "btc", "tron", "ton"];
676
- var WALLET_METHODS = ["evm", "sol", "btc", "tron", "ton"];
677
- function useWalletConfig() {
678
- const isDownMd = useDownMd();
679
- const walletMap = {
680
- evm: {
681
- icon: /* @__PURE__ */ jsx2(EVMDarkIcon, { size: isDownMd ? 36 : 40 }),
682
- activeIcon: /* @__PURE__ */ jsx2(EVMLightIcon, { size: isDownMd ? 36 : 40 }),
683
- name: "EVM",
684
- method: "evm"
685
- },
686
- sol: {
687
- icon: /* @__PURE__ */ jsx2(SOLDarkIcon, { size: isDownMd ? 36 : 40 }),
688
- activeIcon: /* @__PURE__ */ jsx2(SOLLightIcon, { size: isDownMd ? 36 : 40 }),
689
- name: "SOL",
690
- method: "sol"
691
- },
692
- btc: {
693
- icon: /* @__PURE__ */ jsx2(BTCDarkIcon, { size: isDownMd ? 36 : 40 }),
694
- activeIcon: /* @__PURE__ */ jsx2(BTCLightIcon, { size: isDownMd ? 36 : 40 }),
695
- name: "BTC",
696
- method: "btc"
697
- },
698
- tron: {
699
- icon: /* @__PURE__ */ jsx2(TRXDarkIcon, { size: isDownMd ? 36 : 40 }),
700
- activeIcon: /* @__PURE__ */ jsx2(TRXLightIcon, { size: isDownMd ? 36 : 40 }),
701
- name: "TRON",
702
- method: "tron"
747
+ // src/store/useTransactionStore.ts
748
+ import { create as create3 } from "zustand";
749
+ import { devtools as devtools2, persist as persist2 } from "zustand/middleware";
750
+ var persistedState2 = persist2(
751
+ (set, get) => ({
752
+ transactions: {},
753
+ getTransactions: (chainId, address) => get().transactions[`${chainId}-${address}`] || [],
754
+ addTransaction: (data) => {
755
+ set((state) => {
756
+ const updatedTransactions = {
757
+ ...state.transactions,
758
+ [`${data.chainId}-${data.address}`]: [data.info, ...state.transactions[`${data.chainId}-${data.address}`] || []]
759
+ };
760
+ return { transactions: updatedTransactions };
761
+ });
703
762
  },
704
- ton: {
705
- icon: /* @__PURE__ */ jsx2(TonLightIcon, { size: isDownMd ? 36 : 40 }),
706
- activeIcon: /* @__PURE__ */ jsx2(TonLightIcon2, { size: isDownMd ? 36 : 40 }),
707
- name: "TON",
708
- method: "ton"
763
+ removeTransaction: (data) => {
764
+ set((state) => {
765
+ const updatedTransactions = {
766
+ ...state.transactions,
767
+ [`${data.chainId}-${data.address}`]: (state.transactions[`${data.chainId}-${data.address}`] || []).filter((tx) => tx.hash !== data.hash)
768
+ };
769
+ return { transactions: updatedTransactions };
770
+ });
709
771
  }
710
- };
711
- return {
712
- walletMap
713
- };
714
- }
715
-
716
- // src/store/useModalStore.ts
717
- var useSOLModalStore = create3((set) => ({
718
- isOpen: false,
719
- type: "",
720
- open: (type) => set({ isOpen: true, type }),
721
- close: () => set({ isOpen: false })
722
- }));
723
- var useTRONModalStore = create3((set) => ({
724
- isOpen: false,
725
- type: "",
726
- open: (type) => set({ isOpen: true, type }),
727
- close: () => set({ isOpen: false })
728
- }));
729
- var useTONModalStore = create3((set) => ({
730
- isOpen: false,
731
- type: "",
732
- open: (type) => set({ isOpen: true, type }),
733
- close: () => set({ isOpen: false })
734
- }));
735
- var useBTCModalStore = create3((set) => ({
736
- isOpen: false,
737
- type: "",
738
- open: (type) => set({ isOpen: true, type }),
739
- close: () => set({ isOpen: false })
740
- }));
741
- var useCEXBindModalStore = create3((set) => ({
742
- type: "",
743
- isOpen: false,
744
- open: (type) => set({ isOpen: true, type }),
745
- close: () => set({ isOpen: false })
746
- }));
747
- var useHashPanelStore = create3((set) => ({
748
- isOpen: false,
749
- hash: null,
750
- chain: null,
751
- open: (params) => set({
752
- isOpen: true,
753
- hash: params?.hash || null,
754
- chain: params?.chain || null
755
772
  }),
756
- close: () => set({ isOpen: false })
757
- }));
758
- var useWalletModalStore = create3((set) => ({
759
- isOpen: false,
760
- type: "",
761
- methods: [],
762
- open: (type, methods = DEFAULT_WALLET_METHODS) => set({ isOpen: true, type, methods }),
763
- close: () => set({ isOpen: false })
764
- }));
773
+ { name: "match-transactions-local" }
774
+ );
775
+ var useTransactionStore = create3(devtools2(persistedState2));
776
+ var useTransactionStore_default = useTransactionStore;
765
777
 
766
778
  // src/hooks/useWallet.tsx
779
+ import { jsx as jsx3 } from "react/jsx-runtime";
767
780
  var AppClientId = "react-sdk-" + getVersion();
768
781
  function useWallet() {
769
- const { address: address2, wallet: walletConfig } = useLocalStore_default();
782
+ const { address, wallet: walletConfig } = useLocalStore_default();
770
783
  const { walletReady } = useStore_default();
771
- const { open: openHashPanel } = useHashPanelStore();
784
+ const modal = useModal();
785
+ const { addTransaction } = useTransactionStore_default();
772
786
  const isRecovered = async () => {
773
787
  const res = await window.matchProvider.waitUntilWalletMessage({
774
788
  method: "isRecovered"
@@ -814,39 +828,44 @@ function useWallet() {
814
828
  }
815
829
  };
816
830
  const evmAccount = useMemo2(() => {
817
- return address2 ? toAccount({
818
- address: address2,
819
- async signMessage({ message }) {
820
- return await signMessage2({
821
- message,
822
- chainType: "ethereum" /* Ethereum */
823
- });
824
- },
825
- async signTransaction(transaction, options) {
826
- const { account, chain, ...restTransaction } = transaction;
827
- console.log("qwe-sign-transaction", restTransaction, options);
828
- return await signTransaction({
829
- transaction: {
830
- ...restTransaction
831
- },
832
- chainType: "ethereum" /* Ethereum */,
833
- chain: {
834
- id: chain?.id || restTransaction.chainId,
835
- name: chain?.name,
836
- nativeCurrency: {
837
- name: chain?.nativeCurrency?.name || "ETH",
838
- symbol: chain?.nativeCurrency?.symbol || "ETH",
839
- decimals: chain?.nativeCurrency?.decimals || 18
831
+ try {
832
+ return address ? toAccount({
833
+ address,
834
+ async signMessage({ message }) {
835
+ return await signMessage2({
836
+ message,
837
+ chainType: "ethereum" /* Ethereum */
838
+ });
839
+ },
840
+ async signTransaction(transaction, options) {
841
+ const { account, chain, ...restTransaction } = transaction;
842
+ console.log("qwe-sign-transaction", restTransaction, options);
843
+ return await signTransaction({
844
+ transaction: {
845
+ ...restTransaction
840
846
  },
841
- rpcUrls: chain?.rpcUrls
842
- }
843
- });
844
- },
845
- async signTypedData(typedData) {
846
- return "0x";
847
- }
848
- }) : void 0;
849
- }, [address2]);
847
+ chainType: "ethereum" /* Ethereum */,
848
+ chain: {
849
+ id: chain?.id || restTransaction.chainId,
850
+ name: chain?.name,
851
+ nativeCurrency: {
852
+ name: chain?.nativeCurrency?.name || "ETH",
853
+ symbol: chain?.nativeCurrency?.symbol || "ETH",
854
+ decimals: chain?.nativeCurrency?.decimals || 18
855
+ },
856
+ rpcUrls: chain?.rpcUrls
857
+ }
858
+ });
859
+ },
860
+ async signTypedData(typedData) {
861
+ return "0x";
862
+ }
863
+ }) : void 0;
864
+ } catch (error) {
865
+ console.error(`qwe-evm-account-error ${address}`, error);
866
+ return void 0;
867
+ }
868
+ }, [address]);
850
869
  useEffect3(() => {
851
870
  matchlog_default.log("qwe-evmAccount", evmAccount);
852
871
  }, [evmAccount]);
@@ -912,13 +931,25 @@ function useWallet() {
912
931
  prepareTransactionRequest
913
932
  }
914
933
  });
915
- openHashPanel();
916
934
  const txHash = await obj.sendRawTransaction({
917
935
  serializedTransaction
918
936
  });
919
- openHashPanel({
937
+ addTransaction({
938
+ chainId,
920
939
  hash: txHash,
921
- chain: _chain
940
+ info: {
941
+ from: evmAccount.address,
942
+ to: restTransaction.to,
943
+ value: (restTransaction.value || 0).toString(),
944
+ input: restTransaction.data,
945
+ timestamp: Math.floor(Date.now() / 1e3).toString(),
946
+ hash: txHash,
947
+ source: "local"
948
+ },
949
+ address: evmAccount.address
950
+ });
951
+ modal.show((props) => {
952
+ return /* @__PURE__ */ jsx3(HashPanel_default, { isOpen: true, onClose: props.close, zIndex: props.zIndex, hash: txHash, chain: _chain });
922
953
  });
923
954
  clearInterval(window.matchProvider.transactionMessageIntervalMap[transactionId].interval);
924
955
  delete window.matchProvider.transactionMessageIntervalMap[transactionId];
@@ -939,7 +970,7 @@ function useWallet() {
939
970
  });
940
971
  };
941
972
  const writeContract = async (parameters2) => {
942
- const { abi, address: address3, args, dataSuffix, functionName, ...request3 } = parameters2;
973
+ const { abi, address: address2, args, dataSuffix, functionName, ...request3 } = parameters2;
943
974
  const data = encodeFunctionData({
944
975
  abi,
945
976
  args,
@@ -947,7 +978,7 @@ function useWallet() {
947
978
  });
948
979
  return await sendTransaction({
949
980
  data: `${data}${dataSuffix ? dataSuffix.replace("0x", "") : ""}`,
950
- to: address3,
981
+ to: address2,
951
982
  ...request3
952
983
  });
953
984
  };
@@ -961,7 +992,7 @@ function useWallet() {
961
992
  return {
962
993
  walletReady,
963
994
  evmAccount,
964
- address: address2,
995
+ address,
965
996
  signMessage: signMessage2,
966
997
  signTransaction,
967
998
  isRecovered,
@@ -971,10 +1002,10 @@ function useWallet() {
971
1002
 
972
1003
  // src/hooks/useCopyClipboard.ts
973
1004
  import copy from "copy-to-clipboard";
974
- import { useCallback, useEffect as useEffect4, useState as useState3 } from "react";
1005
+ import { useCallback as useCallback2, useEffect as useEffect4, useState as useState4 } from "react";
975
1006
  function useCopyClipboard(timeout = 500) {
976
- const [isCopied, setIsCopied] = useState3(false);
977
- const staticCopy = useCallback((text) => {
1007
+ const [isCopied, setIsCopied] = useState4(false);
1008
+ const staticCopy = useCallback2((text) => {
978
1009
  const didCopy = copy(text);
979
1010
  setIsCopied(didCopy);
980
1011
  }, []);
@@ -992,48 +1023,6 @@ function useCopyClipboard(timeout = 500) {
992
1023
  return [isCopied, staticCopy];
993
1024
  }
994
1025
 
995
- // src/context/ModalContext.tsx
996
- import { useState as useState4, useCallback as useCallback2, createContext, useContext } from "react";
997
- import { createPortal } from "react-dom";
998
- import { jsx as jsx3, jsxs as jsxs2 } from "react/jsx-runtime";
999
- var ModalContext = createContext(null);
1000
- function ModalProvider({ children }) {
1001
- const [showModalState, setShowModalState] = useState4({
1002
- visible: false,
1003
- content: null
1004
- });
1005
- const closeShowModal = useCallback2(() => {
1006
- setShowModalState({ visible: false, content: null });
1007
- }, []);
1008
- const show = useCallback2((content) => {
1009
- setShowModalState({
1010
- visible: true,
1011
- content: content({ close: closeShowModal })
1012
- });
1013
- }, [closeShowModal]);
1014
- const open = useCallback2((props) => {
1015
- setShowModalState({
1016
- visible: true,
1017
- content: /* @__PURE__ */ jsx3(ModalDrawer, { showClose: true, isOpen: true, onClose: closeShowModal, title: props.title, children: /* @__PURE__ */ jsx3(props.content, { close: closeShowModal }) })
1018
- });
1019
- }, [closeShowModal]);
1020
- const ShowModalComponent = showModalState.visible ? createPortal(
1021
- showModalState.content,
1022
- document.body
1023
- ) : null;
1024
- return /* @__PURE__ */ jsxs2(ModalContext.Provider, { value: { show, open }, children: [
1025
- children,
1026
- ShowModalComponent
1027
- ] });
1028
- }
1029
- function useModal() {
1030
- const context = useContext(ModalContext);
1031
- if (!context) {
1032
- throw new Error("useModal must be used within a ModalProvider");
1033
- }
1034
- return context;
1035
- }
1036
-
1037
1026
  // src/context/ToastContext.tsx
1038
1027
  import { useState as useState5, useCallback as useCallback3, createContext as createContext2, useContext as useContext2 } from "react";
1039
1028
  import { createPortal as createPortal2 } from "react-dom";
@@ -1087,20 +1076,23 @@ function useToast() {
1087
1076
  // src/hooks/api/wallet.ts
1088
1077
  var wallet_exports = {};
1089
1078
  __export(wallet_exports, {
1079
+ USER_IMPORT_TOKEN_LIST_KEY: () => USER_IMPORT_TOKEN_LIST_KEY,
1090
1080
  getUserWalletTransactionsApi: () => getUserWalletTransactionsApi,
1091
1081
  getWalletAssetListApi: () => getWalletAssetListApi,
1092
1082
  getWalletListApi: () => getWalletListApi,
1093
1083
  useAssetListQuery: () => useAssetListQuery,
1094
1084
  useChainListQuery: () => useChainListQuery,
1095
1085
  useImportTokenListQuery: () => useImportTokenListQuery,
1086
+ useWalletAssetListQuery: () => useWalletAssetListQuery,
1096
1087
  useWalletChainListQuery: () => useWalletChainListQuery,
1088
+ useWalletNftListQuery: () => useWalletNftListQuery,
1097
1089
  userImportTokenApi: () => userImportTokenApi
1098
1090
  });
1099
1091
  import { useQuery } from "@tanstack/react-query";
1100
1092
  function useChainListQuery(options) {
1101
1093
  const { isLogin, token } = useUserInfo();
1102
1094
  return useQuery({
1103
- queryKey: ["match-chain-list", token],
1095
+ queryKey: ["match-user-chain-list", token],
1104
1096
  queryFn: async () => {
1105
1097
  const res = await getUserChainListApi();
1106
1098
  if (!isSuccess(res)) {
@@ -1118,7 +1110,7 @@ function useAssetListQuery({
1118
1110
  }) {
1119
1111
  const { isLogin, token } = useUserInfo();
1120
1112
  return useQuery({
1121
- queryKey: ["match-wallet-asset-list", token, chainId],
1113
+ queryKey: ["match-user-asset-list", token, chainId],
1122
1114
  queryFn: async () => {
1123
1115
  const res = await getUserWalletAssetApi({ chain_id: chainId.toString() });
1124
1116
  if (!isSuccess(res)) {
@@ -1130,13 +1122,14 @@ function useAssetListQuery({
1130
1122
  ...options
1131
1123
  });
1132
1124
  }
1125
+ var USER_IMPORT_TOKEN_LIST_KEY = "match-user-import-token-list";
1133
1126
  function useImportTokenListQuery({
1134
1127
  chainId,
1135
1128
  ...options
1136
1129
  }) {
1137
1130
  const { isLogin, token } = useUserInfo();
1138
1131
  return useQuery({
1139
- queryKey: ["match-wallet-import-token-list", token, chainId],
1132
+ queryKey: [USER_IMPORT_TOKEN_LIST_KEY, token, chainId],
1140
1133
  queryFn: async () => {
1141
1134
  const res = await getUserImportTokenListApi({ chain_id: chainId.toString() });
1142
1135
  if (!isSuccess(res)) {
@@ -1163,9 +1156,54 @@ function useWalletChainListQuery(options) {
1163
1156
  ...options
1164
1157
  });
1165
1158
  }
1159
+ function useWalletNftListQuery({
1160
+ chainId,
1161
+ address,
1162
+ ...options
1163
+ }) {
1164
+ const { isLogin, token } = useUserInfo();
1165
+ return useQuery({
1166
+ queryKey: ["match-wallet-nft-list", token, chainId, address],
1167
+ queryFn: async () => {
1168
+ const res = await getWalletNftListApi({
1169
+ chain_id: chainId.toString(),
1170
+ address
1171
+ });
1172
+ if (!isSuccess(res)) {
1173
+ return [];
1174
+ }
1175
+ return res.data;
1176
+ },
1177
+ enabled: isLogin,
1178
+ ...options
1179
+ });
1180
+ }
1181
+ function useWalletAssetListQuery({
1182
+ chainId,
1183
+ address,
1184
+ ...options
1185
+ }) {
1186
+ const { isLogin, token } = useUserInfo();
1187
+ return useQuery({
1188
+ queryKey: ["match-wallet-asset-list", token, chainId, address],
1189
+ queryFn: async () => {
1190
+ const res = await getWalletAssetListApi({
1191
+ chain_id: chainId,
1192
+ address
1193
+ });
1194
+ if (!isSuccess(res)) {
1195
+ return null;
1196
+ }
1197
+ return res.data;
1198
+ },
1199
+ enabled: isLogin,
1200
+ ...options
1201
+ });
1202
+ }
1166
1203
 
1167
1204
  // src/hooks/useMatchChain.tsx
1168
1205
  import { useMemo as useMemo3, useState as useState6 } from "react";
1206
+ import { createPublicClient as createPublicClient2, formatUnits, http as http2, parseUnits } from "viem";
1169
1207
  import { jsx as jsx5, jsxs as jsxs4 } from "react/jsx-runtime";
1170
1208
  function useMatchChain() {
1171
1209
  const chainListQuery = useChainListQuery();
@@ -1225,71 +1263,663 @@ function useMatchChain() {
1225
1263
  content: ChangeNetwork
1226
1264
  });
1227
1265
  };
1266
+ const publicClient = useMemo3(() => {
1267
+ if (!chain) {
1268
+ return null;
1269
+ }
1270
+ return createPublicClient2({
1271
+ chain,
1272
+ transport: http2()
1273
+ });
1274
+ }, [chain]);
1228
1275
  return {
1229
1276
  list: chainListQuery.data,
1230
1277
  chainId,
1231
1278
  setChainId,
1232
1279
  chain,
1233
1280
  explorerLink,
1234
- showChangeNetwork
1281
+ showChangeNetwork,
1282
+ publicClient,
1283
+ formatUnits: (value) => {
1284
+ return formatUnits(value, chain?.nativeCurrency.decimals || 18);
1285
+ },
1286
+ parseUnits: (value) => {
1287
+ return parseUnits(value, chain?.nativeCurrency.decimals || 18);
1288
+ }
1235
1289
  };
1236
1290
  }
1237
1291
 
1238
1292
  // src/hooks/useMatchWallet.tsx
1239
1293
  import { QRCode } from "react-qrcode";
1240
- import { useEffect as useEffect6, useState as useState7 } from "react";
1294
+ import { useEffect as useEffect6, useMemo as useMemo4, useRef, useState as useState7 } from "react";
1295
+ import { useQuery as useQuery2, useQueryClient } from "@tanstack/react-query";
1296
+
1297
+ // src/config/index.tsx
1298
+ var EMAIL_INTERVAL = 60;
1299
+ var EMAIL_CODE_LENGTH = 6;
1300
+ var NATIVE_TOKEN_ADDRESS = "0xeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeee";
1301
+
1302
+ // src/hooks/useMatchWallet.tsx
1303
+ import { erc20Abi, formatUnits as formatUnits2 } from "viem";
1304
+
1305
+ // src/store/useContractStore.ts
1306
+ import { create as create4 } from "zustand";
1307
+ import { devtools as devtools3, persist as persist3 } from "zustand/middleware";
1308
+ var persistedState3 = persist3(
1309
+ (set, get) => ({
1310
+ contracts: {},
1311
+ getContract: (chainId, contractAddress) => {
1312
+ const key = `${chainId}-${contractAddress}`;
1313
+ return get().contracts[key];
1314
+ },
1315
+ setContractName: (chainId, contractAddress, name) => {
1316
+ const key = `${chainId}-${contractAddress}`;
1317
+ set((state) => {
1318
+ const updatedContracts = {
1319
+ ...state.contracts,
1320
+ [key]: { ...state.contracts[key], name }
1321
+ };
1322
+ return { contracts: updatedContracts };
1323
+ });
1324
+ },
1325
+ setContractSymbol: (chainId, contractAddress, symbol) => {
1326
+ const key = `${chainId}-${contractAddress}`;
1327
+ set((state) => {
1328
+ const updatedContracts = {
1329
+ ...state.contracts,
1330
+ [key]: { ...state.contracts[key], symbol }
1331
+ };
1332
+ return { contracts: updatedContracts };
1333
+ });
1334
+ },
1335
+ setContractDecimals: (chainId, contractAddress, decimals) => {
1336
+ const key = `${chainId}-${contractAddress}`;
1337
+ set((state) => {
1338
+ const updatedContracts = {
1339
+ ...state.contracts,
1340
+ [key]: { ...state.contracts[key], decimals }
1341
+ };
1342
+ return { contracts: updatedContracts };
1343
+ });
1344
+ },
1345
+ setContracts: (data) => {
1346
+ set((state) => {
1347
+ const newContracts = { ...state.contracts };
1348
+ data.forEach(({ chainId, contractAddress, info }) => {
1349
+ const key = `${chainId}-${contractAddress}`;
1350
+ newContracts[key] = { ...newContracts[key], ...info };
1351
+ });
1352
+ return { contracts: newContracts };
1353
+ });
1354
+ }
1355
+ }),
1356
+ { name: "match-contract-local" }
1357
+ );
1358
+ var useContractStore = create4(devtools3(persistedState3));
1359
+ var useContractStore_default = useContractStore;
1360
+
1361
+ // src/hooks/useMatchWallet.tsx
1362
+ import { FormattedMessage as FormattedMessage2, useIntl as useIntl2 } from "react-intl";
1241
1363
  import { jsx as jsx6, jsxs as jsxs5 } from "react/jsx-runtime";
1242
- function useMatchWallet() {
1243
- const modal = useModal();
1244
- const { address: address2 } = useWallet();
1364
+ var ReceiveModal = () => {
1245
1365
  const chain = useMatchChain();
1366
+ const { address } = useWallet();
1246
1367
  const [copied, setCopied] = useCopyClipboard();
1247
1368
  const toast = useToast();
1369
+ const intl = useIntl2();
1248
1370
  const onCopy = () => {
1249
- setCopied(address2);
1250
- toast.success("Copied!");
1371
+ setCopied(address);
1372
+ toast.success(intl.formatMessage({
1373
+ id: "copied"
1374
+ }));
1375
+ };
1376
+ const chainLink = chain.explorerLink("address/" + address);
1377
+ return /* @__PURE__ */ jsxs5("div", { className: `matchid-receive-modal`, children: [
1378
+ /* @__PURE__ */ jsxs5("div", { className: "matchid-receive-container", children: [
1379
+ /* @__PURE__ */ jsx6("div", { className: `matchid-receive-text`, children: /* @__PURE__ */ jsx6(FormattedMessage2, { id: "receiveQrcode" }) }),
1380
+ /* @__PURE__ */ jsx6("div", { className: `matchid-qr-container`, children: /* @__PURE__ */ jsx6(
1381
+ QRCode,
1382
+ {
1383
+ margin: "0",
1384
+ className: `matchid-qr-code`,
1385
+ value: address
1386
+ }
1387
+ ) }),
1388
+ /* @__PURE__ */ jsx6(
1389
+ "a",
1390
+ {
1391
+ href: chainLink,
1392
+ target: "_blank",
1393
+ className: `matchid-receive-link`,
1394
+ children: address
1395
+ }
1396
+ )
1397
+ ] }),
1398
+ /* @__PURE__ */ jsx6(Button, { size: "lg", onClick: onCopy, block: true, highlight: true, disabled: copied, children: /* @__PURE__ */ jsx6(
1399
+ FormattedMessage2,
1400
+ {
1401
+ id: "copyAddress"
1402
+ }
1403
+ ) })
1404
+ ] });
1405
+ };
1406
+ var ImportTokenModal = ({ close }) => {
1407
+ const { token } = useUserInfo();
1408
+ const [address, setAddress] = useState7("");
1409
+ const [symbol, setSymbol] = useState7("");
1410
+ const [decimals, setDecimals] = useState7("");
1411
+ const [error, setError] = useState7({});
1412
+ const { publicClient, chainId } = useMatchChain();
1413
+ const getContractInfo = async () => {
1414
+ if (!publicClient) return;
1415
+ const erc20Abi3 = [
1416
+ {
1417
+ name: "decimals",
1418
+ type: "function",
1419
+ stateMutability: "view",
1420
+ inputs: [],
1421
+ outputs: [{ name: "decimals", type: "uint8" }]
1422
+ },
1423
+ {
1424
+ name: "symbol",
1425
+ type: "function",
1426
+ stateMutability: "view",
1427
+ inputs: [],
1428
+ outputs: [{ name: "symbol", type: "string" }]
1429
+ }
1430
+ ];
1431
+ const calls = [
1432
+ {
1433
+ address,
1434
+ abi: erc20Abi3,
1435
+ functionName: "symbol",
1436
+ args: []
1437
+ },
1438
+ {
1439
+ address,
1440
+ abi: erc20Abi3,
1441
+ functionName: "decimals",
1442
+ args: []
1443
+ }
1444
+ ];
1445
+ try {
1446
+ const results = await publicClient.multicall({ contracts: calls });
1447
+ console.log("results", results);
1448
+ if (!symbol && results[0]?.status == "success") {
1449
+ setSymbol(results[0]?.result);
1450
+ }
1451
+ if (!decimals && results[1]?.status == "success") {
1452
+ setDecimals((results[1]?.result).toString());
1453
+ }
1454
+ } catch (error2) {
1455
+ setError({
1456
+ address: error2.message
1457
+ });
1458
+ }
1459
+ };
1460
+ const intl = useIntl2();
1461
+ useEffect6(() => {
1462
+ if (address.length === 42) {
1463
+ const reg = /^0x[0-9a-fA-F]{40}$/;
1464
+ if (!reg.test(address)) {
1465
+ setError({
1466
+ ...error,
1467
+ address: intl.formatMessage({
1468
+ id: "tokenAddressError"
1469
+ })
1470
+ });
1471
+ } else {
1472
+ setError({
1473
+ ...error,
1474
+ address: ""
1475
+ });
1476
+ publicClient && getContractInfo();
1477
+ }
1478
+ }
1479
+ }, [address, publicClient]);
1480
+ const [loading, setLoading] = useState7(false);
1481
+ const toast = useToast();
1482
+ const queryClient2 = useQueryClient();
1483
+ const onImport = async () => {
1484
+ setLoading(true);
1485
+ try {
1486
+ const res = await userImportTokenApi({
1487
+ chain_id: chainId?.toString() || "",
1488
+ symbol,
1489
+ address,
1490
+ decimals
1491
+ });
1492
+ if (isSuccess(res)) {
1493
+ toast.success(intl.formatMessage({
1494
+ id: "importSuccess"
1495
+ }));
1496
+ queryClient2.invalidateQueries({
1497
+ queryKey: [USER_IMPORT_TOKEN_LIST_KEY, token, chainId]
1498
+ });
1499
+ close();
1500
+ } else {
1501
+ toast.error(res.message);
1502
+ }
1503
+ } catch (error2) {
1504
+ toast.error(error2.message);
1505
+ } finally {
1506
+ setLoading(false);
1507
+ }
1251
1508
  };
1509
+ const canImport = useMemo4(() => {
1510
+ if (!address) {
1511
+ return false;
1512
+ }
1513
+ if (!symbol) {
1514
+ return false;
1515
+ }
1516
+ if (decimals.length === 0) {
1517
+ return false;
1518
+ }
1519
+ const reg = /^0x[0-9a-fA-F]{40}$/;
1520
+ if (!reg.test(address)) {
1521
+ return false;
1522
+ }
1523
+ return true;
1524
+ }, [error, address, symbol, decimals]);
1525
+ return /* @__PURE__ */ jsxs5("div", { className: `matchid-import-token`, children: [
1526
+ /* @__PURE__ */ jsxs5("div", { className: "matchid-import-token-form", children: [
1527
+ /* @__PURE__ */ jsx6(Field, { label: intl.formatMessage({
1528
+ id: "tokenSmartContract"
1529
+ }), error: error.address, children: /* @__PURE__ */ jsx6(
1530
+ Input,
1531
+ {
1532
+ placeholder: intl.formatMessage({
1533
+ id: "tokenSmartContractPlaceholder"
1534
+ }),
1535
+ value: address,
1536
+ onChange: (e) => setAddress(e.target.value),
1537
+ maxLength: 42
1538
+ }
1539
+ ) }),
1540
+ /* @__PURE__ */ jsx6(Field, { label: intl.formatMessage({
1541
+ id: "tokenSymbol"
1542
+ }), error: error.symbol, children: /* @__PURE__ */ jsx6(
1543
+ Input,
1544
+ {
1545
+ placeholder: intl.formatMessage({
1546
+ id: "tokenSymbolPlaceholder"
1547
+ }),
1548
+ value: symbol,
1549
+ onChange: (e) => setSymbol(e.target.value),
1550
+ maxLength: 16
1551
+ }
1552
+ ) }),
1553
+ /* @__PURE__ */ jsx6(Field, { label: intl.formatMessage({
1554
+ id: "tokenDecimals"
1555
+ }), error: error.decimals, children: /* @__PURE__ */ jsx6(
1556
+ Input,
1557
+ {
1558
+ placeholder: intl.formatMessage({
1559
+ id: "tokenDecimalsPlaceholder"
1560
+ }),
1561
+ type: "number",
1562
+ value: decimals,
1563
+ onChange: (e) => setDecimals(e.target.value)
1564
+ }
1565
+ ) })
1566
+ ] }),
1567
+ /* @__PURE__ */ jsx6(
1568
+ Button,
1569
+ {
1570
+ size: "lg",
1571
+ onClick: onImport,
1572
+ block: true,
1573
+ loading,
1574
+ disabled: !canImport,
1575
+ highlight: true,
1576
+ children: /* @__PURE__ */ jsx6(FormattedMessage2, { id: "import" })
1577
+ }
1578
+ )
1579
+ ] });
1580
+ };
1581
+ function useMatchWallet() {
1582
+ const modal = useModal();
1583
+ const intl = useIntl2();
1252
1584
  const showReceiveModal = () => {
1253
- const chainLink = chain.explorerLink("address/" + address2);
1254
- const ReceiveModal = () => {
1255
- return /* @__PURE__ */ jsxs5("div", { className: `matchid-receive-modal`, children: [
1256
- /* @__PURE__ */ jsxs5("div", { className: "matchid-receive-container", children: [
1257
- /* @__PURE__ */ jsx6("div", { className: `matchid-receive-text`, children: "Receive by scanning the QR code" }),
1258
- /* @__PURE__ */ jsx6("div", { className: `matchid-qr-container`, children: /* @__PURE__ */ jsx6(
1259
- QRCode,
1260
- {
1261
- margin: "0",
1262
- className: `matchid-qr-code`,
1263
- value: address2
1264
- }
1265
- ) }),
1266
- /* @__PURE__ */ jsx6(
1267
- "a",
1268
- {
1269
- href: chainLink,
1270
- target: "_blank",
1271
- className: `matchid-receive-link`,
1272
- children: address2
1273
- }
1274
- )
1275
- ] }),
1276
- /* @__PURE__ */ jsx6(Button, { size: "lg", onClick: onCopy, block: true, highlight: true, disabled: copied, children: "Copy Address" })
1277
- ] });
1278
- };
1279
1585
  modal.open({
1280
- title: "Receive",
1586
+ title: intl.formatMessage({
1587
+ id: "receive"
1588
+ }),
1281
1589
  content: ReceiveModal
1282
1590
  });
1283
1591
  };
1592
+ const showImportTokenModal = () => {
1593
+ modal.open({
1594
+ title: intl.formatMessage({
1595
+ id: "Customized Token"
1596
+ }),
1597
+ content: ImportTokenModal
1598
+ });
1599
+ };
1600
+ const showSendListModal = () => {
1601
+ modal.open({
1602
+ title: intl.formatMessage({
1603
+ id: "send"
1604
+ }),
1605
+ content: TokenSendList
1606
+ });
1607
+ };
1608
+ return {
1609
+ showReceiveModal,
1610
+ showImportTokenModal,
1611
+ showSendListModal
1612
+ };
1613
+ }
1614
+ function useMatchWalletRecords() {
1615
+ const [hasMore, setHasMore] = useState7(true);
1616
+ const [items, setItems] = useState7([]);
1617
+ const { chainId, publicClient } = useMatchChain();
1618
+ const { address } = useWallet();
1619
+ const hasMoreRef = useRef(hasMore);
1620
+ const nextPageParamsRef = useRef(void 0);
1621
+ const { getContract, setContracts } = useContractStore_default();
1622
+ const fetchMoreData = async () => {
1623
+ const chainIdStr = chainId ? chainId.toString() : "";
1624
+ if (!hasMoreRef.current || !chainIdStr) {
1625
+ return;
1626
+ }
1627
+ const res = await getUserWalletTransactionsApi({
1628
+ chain_id: chainIdStr,
1629
+ ...nextPageParamsRef.current
1630
+ });
1631
+ if (isSuccess(res)) {
1632
+ if (res.data && res.data.transactions && res.data.transactions.length > 0) {
1633
+ const contractList = res.data.transactions.filter((item) => item.input.toLowerCase().substring(0, 10) == "0xa9059cbb").map((item) => item.to);
1634
+ const contractUnique = Array.from(new Set(contractList)).filter((item) => {
1635
+ const contract = getContract(chainId || 0, item);
1636
+ if (!contract) {
1637
+ return true;
1638
+ }
1639
+ if (!contract.symbol && !contract.name) {
1640
+ return true;
1641
+ }
1642
+ if (!contract.decimals) {
1643
+ return true;
1644
+ }
1645
+ return false;
1646
+ });
1647
+ const calls = [];
1648
+ for (const contract of contractUnique) {
1649
+ calls.push({
1650
+ address: contract,
1651
+ abi: erc20Abi,
1652
+ functionName: "symbol",
1653
+ args: []
1654
+ });
1655
+ calls.push({
1656
+ address: contract,
1657
+ abi: erc20Abi,
1658
+ functionName: "decimals",
1659
+ args: []
1660
+ });
1661
+ }
1662
+ const results = await publicClient?.multicall({ contracts: calls });
1663
+ if (results) {
1664
+ console.log("contract results", calls, results);
1665
+ const contractMap = [];
1666
+ for (let i = 0; i < contractUnique.length; i++) {
1667
+ const info = {};
1668
+ if (results[i * 2].status == "success") {
1669
+ info.symbol = results[i * 2].result;
1670
+ }
1671
+ if (results[i * 2 + 1].status == "success") {
1672
+ info.decimals = results[i * 2 + 1].result;
1673
+ }
1674
+ contractMap.push({
1675
+ chainId: chainId || 0,
1676
+ contractAddress: contractUnique[i],
1677
+ info
1678
+ });
1679
+ }
1680
+ setContracts(contractMap);
1681
+ }
1682
+ setItems(items.concat(res.data.transactions || []));
1683
+ }
1684
+ hasMoreRef.current = res.data && res.data.transactions && res.data.transactions.length >= 50;
1685
+ setHasMore(hasMoreRef.current);
1686
+ nextPageParamsRef.current = res.data.next_page_params;
1687
+ }
1688
+ };
1689
+ const onInit = async () => {
1690
+ nextPageParamsRef.current = void 0;
1691
+ setItems([]);
1692
+ setHasMore(true);
1693
+ hasMoreRef.current = true;
1694
+ fetchMoreData();
1695
+ };
1696
+ useEffect6(() => {
1697
+ if (chainId && address) {
1698
+ onInit();
1699
+ }
1700
+ }, [chainId, address]);
1701
+ const { getTransactions, removeTransaction } = useTransactionStore_default();
1702
+ const localTransaction = useMemo4(() => {
1703
+ return getTransactions(chainId || 0, address) || [];
1704
+ }, [getTransactions, chainId]);
1705
+ useEffect6(() => {
1706
+ const removeList = localTransaction.filter((n) => items.findIndex((m) => m.hash == n.hash) >= 0);
1707
+ removeList.forEach((item) => {
1708
+ removeTransaction({
1709
+ chainId: chainId || 0,
1710
+ hash: item.hash,
1711
+ address
1712
+ });
1713
+ });
1714
+ }, [localTransaction, items]);
1715
+ return {
1716
+ items: [
1717
+ ...getTransactions(chainId || 0, address) || [],
1718
+ ...items
1719
+ ].sort((a, b) => {
1720
+ const btimestamp = typeof b.timestamp === "string" ? parseInt(b.timestamp) : b.timestamp;
1721
+ const atimestamp = typeof a.timestamp === "string" ? parseInt(a.timestamp) : a.timestamp;
1722
+ return btimestamp - atimestamp;
1723
+ }),
1724
+ fetchMoreData,
1725
+ hasMore
1726
+ };
1727
+ }
1728
+ function useMatchWalletAssets({
1729
+ importTokenOptions,
1730
+ assetListOptions
1731
+ } = {}) {
1732
+ const { chainId, chain } = useMatchChain();
1733
+ const importTokenQuery = useImportTokenListQuery({
1734
+ chainId: chainId || 0,
1735
+ ...importTokenOptions
1736
+ });
1737
+ const assetListQuery = useAssetListQuery({
1738
+ chainId: chainId || 0,
1739
+ ...assetListOptions
1740
+ });
1741
+ const mergedAssets = useMemo4(() => {
1742
+ if (!assetListQuery.data && !importTokenQuery.data) return [];
1743
+ const assetList = (assetListQuery.data || []).map((asset) => ({
1744
+ ...asset,
1745
+ isAuto: true
1746
+ }));
1747
+ const importTokens = (importTokenQuery.data || []).map((token) => ({
1748
+ ...token,
1749
+ isCustom: true
1750
+ }));
1751
+ const assetMap = /* @__PURE__ */ new Map();
1752
+ assetList.forEach((asset) => {
1753
+ const key = `${asset.chain_id}-${asset.address.toLowerCase()}`;
1754
+ assetMap.set(key, asset);
1755
+ });
1756
+ importTokens.forEach((token) => {
1757
+ const key = `${token.chain_id}-${token.address.toLowerCase()}`;
1758
+ if (assetMap.has(key)) {
1759
+ const existing = assetMap.get(key);
1760
+ assetMap.set(key, {
1761
+ ...existing,
1762
+ symbol: token.symbol,
1763
+ decimals: token.decimals,
1764
+ isCustom: true,
1765
+ isAuto: existing.isAuto ?? false
1766
+ });
1767
+ } else {
1768
+ assetMap.set(key, token);
1769
+ }
1770
+ });
1771
+ const list = Array.from(assetMap.values()).sort((a, b) => {
1772
+ return (b.isAuto ? 1 : 0) - (a.isAuto ? 1 : 0);
1773
+ });
1774
+ const nativeToken = list.find((asset) => asset.address.toLowerCase() === NATIVE_TOKEN_ADDRESS.toLowerCase());
1775
+ if (!nativeToken) {
1776
+ list.unshift({
1777
+ chain_id: chain?.id.toString() || "",
1778
+ address: NATIVE_TOKEN_ADDRESS,
1779
+ decimals: 18,
1780
+ symbol: chain?.nativeCurrency.symbol,
1781
+ name: chain?.nativeCurrency.name,
1782
+ balance: 0,
1783
+ icon: chain?.nativeCurrency.icon
1784
+ });
1785
+ }
1786
+ return list;
1787
+ }, [assetListQuery.data, importTokenQuery.data]);
1788
+ return {
1789
+ importTokenQuery,
1790
+ assetListQuery,
1791
+ mergedAssets
1792
+ };
1793
+ }
1794
+ var MULTICALL_LIMIT = 100;
1795
+ function useMatchWalletAssetList({
1796
+ list
1797
+ }) {
1798
+ const { publicClient, chain } = useMatchChain();
1799
+ const { address } = useWallet();
1800
+ const { assets, setAssets } = useLocalStore_default();
1801
+ const nativeToken = list.find((asset) => asset.address.toLowerCase() === NATIVE_TOKEN_ADDRESS.toLowerCase()) || {
1802
+ chain_id: chain?.id || "",
1803
+ address: NATIVE_TOKEN_ADDRESS,
1804
+ decimals: 18,
1805
+ symbol: chain?.nativeCurrency.symbol,
1806
+ name: chain?.nativeCurrency.name,
1807
+ balance: 0
1808
+ };
1809
+ const nativeBalanceQuery = useQuery2({
1810
+ queryKey: ["nativeBalance", nativeToken?.chain_id],
1811
+ queryFn: async () => {
1812
+ if (!nativeToken || !publicClient) return null;
1813
+ try {
1814
+ return await publicClient.getBalance({
1815
+ address
1816
+ });
1817
+ } catch (error) {
1818
+ console.error("Native Token Balance Error:", error);
1819
+ return null;
1820
+ }
1821
+ },
1822
+ enabled: !!nativeToken && !!publicClient,
1823
+ refetchInterval: 15e3,
1824
+ // Refresh every 15 seconds
1825
+ retry: 3
1826
+ // Retry up to 3 times if failed
1827
+ });
1828
+ const erc20Tokens = useMemo4(() => list.filter((asset) => asset.address !== NATIVE_TOKEN_ADDRESS), [list]);
1829
+ const erc20Abi3 = [
1830
+ {
1831
+ "constant": true,
1832
+ "inputs": [
1833
+ {
1834
+ "name": "_owner",
1835
+ "type": "address"
1836
+ }
1837
+ ],
1838
+ "name": "balanceOf",
1839
+ "outputs": [
1840
+ {
1841
+ "name": "balance",
1842
+ "type": "uint256"
1843
+ }
1844
+ ],
1845
+ "payable": false,
1846
+ "stateMutability": "view",
1847
+ "type": "function"
1848
+ }
1849
+ ];
1850
+ const erc20BalanceQuery = useQuery2({
1851
+ queryKey: ["erc20Balances", erc20Tokens.map((token) => token.address)],
1852
+ queryFn: async () => {
1853
+ if (!erc20Tokens.length || !publicClient) return [];
1854
+ const calls = erc20Tokens.map((token) => ({
1855
+ address: token.address,
1856
+ abi: erc20Abi3,
1857
+ functionName: "balanceOf",
1858
+ args: [address]
1859
+ }));
1860
+ let balances = [];
1861
+ for (let i = 0; i < calls.length; i += MULTICALL_LIMIT) {
1862
+ const batchCalls = calls.slice(i, i + MULTICALL_LIMIT);
1863
+ try {
1864
+ const results = await publicClient.multicall({ contracts: batchCalls });
1865
+ balances.push(...results);
1866
+ } catch (error) {
1867
+ console.error("MultiCall Error:", error);
1868
+ }
1869
+ }
1870
+ return balances;
1871
+ },
1872
+ enabled: erc20Tokens.length > 0 && !!publicClient,
1873
+ refetchInterval: 15e3,
1874
+ // Refresh every 15 seconds
1875
+ retry: 3
1876
+ });
1877
+ const enrichedAssets = useMemo4(() => {
1878
+ if (!list) return [];
1879
+ const erc20Balances = erc20BalanceQuery.data || [];
1880
+ return list.map((asset) => {
1881
+ let balanceValue = "0";
1882
+ let balance = 0;
1883
+ const decimals = typeof asset.decimals === "string" ? parseInt(asset.decimals) : asset.decimals;
1884
+ if (asset.address === NATIVE_TOKEN_ADDRESS) {
1885
+ balanceValue = nativeBalanceQuery.data?.toString() || "0";
1886
+ balance = nativeBalanceQuery.data ? Number(formatUnits2(nativeBalanceQuery.data, decimals)) : 0;
1887
+ } else {
1888
+ const index = erc20Tokens.findIndex((t) => t.address === asset.address);
1889
+ if (index !== -1 && erc20Balances[index] && erc20Balances[index].status === "success") {
1890
+ balance = Number(formatUnits2(erc20Balances[index].result, decimals));
1891
+ balanceValue = erc20Balances[index].result?.toString() || "0";
1892
+ }
1893
+ }
1894
+ const value = asset.isAuto ? balance * (asset.price || 0) : 0;
1895
+ return { ...asset, balance, value, balanceValue };
1896
+ });
1897
+ }, [list, nativeBalanceQuery.data, erc20BalanceQuery.data]);
1898
+ useEffect6(() => {
1899
+ const list2 = enrichedAssets.sort((a, b) => {
1900
+ if (a.address === NATIVE_TOKEN_ADDRESS) return -1;
1901
+ if (b.address === NATIVE_TOKEN_ADDRESS) return 1;
1902
+ if (a.isAuto && b.isAuto) return b.value - a.value;
1903
+ if (a.isAuto) return -1;
1904
+ if (b.isAuto) return 1;
1905
+ if (a.isCustom && !a.isAuto && a.balance > 0) return -1;
1906
+ if (b.isCustom && !b.isAuto && b.balance > 0) return 1;
1907
+ return 0;
1908
+ });
1909
+ setAssets(list2);
1910
+ }, [enrichedAssets]);
1284
1911
  return {
1285
- showReceiveModal
1912
+ list: assets,
1913
+ isLoading: nativeBalanceQuery.isLoading || erc20BalanceQuery.isLoading,
1914
+ nativeBalance: nativeBalanceQuery.data,
1915
+ erc20Balances: erc20BalanceQuery.data
1286
1916
  };
1287
1917
  }
1288
1918
 
1289
1919
  // src/hooks/useReceipt.tsx
1290
1920
  import { useState as useState8, useCallback as useCallback4, useEffect as useEffect7 } from "react";
1291
- import { useQuery as useQuery2 } from "@tanstack/react-query";
1292
- import { createPublicClient, defineChain, http } from "viem";
1921
+ import { useQuery as useQuery3 } from "@tanstack/react-query";
1922
+ import { createPublicClient as createPublicClient3, defineChain, http as http3 } from "viem";
1293
1923
  var CACHE_TTL = 86400 * 30 * 1e3;
1294
1924
  var MAX_CACHE_SIZE = 500;
1295
1925
  var STORAGE_KEY = "match_receipt_logs";
@@ -1397,7 +2027,7 @@ function useReceipt({
1397
2027
  const cache = useReceiptCache();
1398
2028
  const chain = list?.find((item) => item.id === chainId);
1399
2029
  const [shouldRefetch, setShouldRefetch] = useState8(true);
1400
- const query = useQuery2({
2030
+ const query = useQuery3({
1401
2031
  queryKey: ["match-tx-receipt", hash, chain],
1402
2032
  queryFn: async () => {
1403
2033
  if (!chain || !hash) return false;
@@ -1406,12 +2036,11 @@ function useReceipt({
1406
2036
  return cache.get(cacheKey);
1407
2037
  }
1408
2038
  try {
1409
- const publicClient = createPublicClient({
1410
- //@ts-ignore
2039
+ const publicClient = createPublicClient3({
1411
2040
  chain: defineChain(chain),
1412
- transport: http()
2041
+ transport: http3()
1413
2042
  });
1414
- const receipt = await publicClient.getTransaction({ hash });
2043
+ const receipt = await publicClient.getTransactionReceipt({ hash });
1415
2044
  if (!receipt) {
1416
2045
  return false;
1417
2046
  }
@@ -1431,28 +2060,257 @@ function useReceipt({
1431
2060
  return query;
1432
2061
  }
1433
2062
 
2063
+ // src/hooks/useTransaction.tsx
2064
+ import { useState as useState9, useCallback as useCallback5, useEffect as useEffect8 } from "react";
2065
+ import { useQuery as useQuery4 } from "@tanstack/react-query";
2066
+ import { createPublicClient as createPublicClient4, defineChain as defineChain2, http as http4 } from "viem";
2067
+ var CACHE_TTL2 = 86400 * 30 * 1e3;
2068
+ var MAX_CACHE_SIZE2 = 500;
2069
+ var STORAGE_KEY2 = "match_transaction_logs";
2070
+ function useTransactionCache() {
2071
+ const [cache, setCache] = useState9(/* @__PURE__ */ new Map());
2072
+ const isLocalStorageAvailable = (() => {
2073
+ try {
2074
+ const testKey = "__test__";
2075
+ localStorage.setItem(testKey, "1");
2076
+ localStorage.removeItem(testKey);
2077
+ return true;
2078
+ } catch (e) {
2079
+ return false;
2080
+ }
2081
+ })();
2082
+ useEffect8(() => {
2083
+ if (isLocalStorageAvailable) {
2084
+ try {
2085
+ const storedData = localStorage.getItem(STORAGE_KEY2);
2086
+ if (storedData) {
2087
+ try {
2088
+ const parsed = JSON.parse(storedData);
2089
+ const now = Date.now();
2090
+ const validEntries = Object.entries(parsed).filter(([_, entry]) => typeof entry === "object" && entry !== null && "timestamp" in entry && now - entry.timestamp <= CACHE_TTL2).map(([key, entry]) => [key, entry]);
2091
+ setCache(new Map(validEntries));
2092
+ } catch (e) {
2093
+ console.error("Failed to parse cache from localStorage:", e);
2094
+ }
2095
+ }
2096
+ } catch (e) {
2097
+ console.error("Failed to load cache from localStorage:", e);
2098
+ }
2099
+ }
2100
+ }, []);
2101
+ const updateLocalStorage = useCallback5((updatedCache) => {
2102
+ if (isLocalStorageAvailable) {
2103
+ try {
2104
+ const storedData = localStorage.getItem(STORAGE_KEY2);
2105
+ let parsed = {};
2106
+ if (storedData) {
2107
+ parsed = JSON.parse(storedData);
2108
+ }
2109
+ updatedCache.forEach((entry, key) => {
2110
+ parsed[key] = entry;
2111
+ });
2112
+ localStorage.setItem(STORAGE_KEY2, JSON.stringify(parsed));
2113
+ } catch (e) {
2114
+ console.error("Failed to update localStorage:", e);
2115
+ }
2116
+ }
2117
+ }, []);
2118
+ const set = useCallback5((key, value) => {
2119
+ const now = Date.now();
2120
+ const newCache = new Map(cache);
2121
+ newCache.forEach((entry, k) => {
2122
+ if (now - entry.timestamp > CACHE_TTL2) {
2123
+ newCache.delete(k);
2124
+ }
2125
+ });
2126
+ if (newCache.size >= MAX_CACHE_SIZE2) {
2127
+ const firstKey = newCache.keys().next().value;
2128
+ if (firstKey !== void 0) {
2129
+ newCache.delete(firstKey);
2130
+ }
2131
+ }
2132
+ newCache.set(key, { value, timestamp: now });
2133
+ setCache(newCache);
2134
+ updateLocalStorage(newCache);
2135
+ }, [cache, updateLocalStorage]);
2136
+ const get = useCallback5((key) => {
2137
+ const entry = cache.get(key);
2138
+ if (entry) {
2139
+ if (Date.now() - entry.timestamp > CACHE_TTL2) {
2140
+ const newCache = new Map(cache);
2141
+ newCache.delete(key);
2142
+ setCache(newCache);
2143
+ updateLocalStorage(newCache);
2144
+ return void 0;
2145
+ }
2146
+ return entry.value;
2147
+ }
2148
+ return void 0;
2149
+ }, [cache, updateLocalStorage]);
2150
+ const del = useCallback5((key) => {
2151
+ if (cache.has(key)) {
2152
+ const newCache = new Map(cache);
2153
+ newCache.delete(key);
2154
+ setCache(newCache);
2155
+ updateLocalStorage(newCache);
2156
+ }
2157
+ }, [cache, updateLocalStorage]);
2158
+ const clear = useCallback5(() => {
2159
+ setCache(/* @__PURE__ */ new Map());
2160
+ if (isLocalStorageAvailable) {
2161
+ localStorage.removeItem(STORAGE_KEY2);
2162
+ }
2163
+ }, [isLocalStorageAvailable]);
2164
+ return { set, get, del, clear };
2165
+ }
2166
+ function useTransaction({
2167
+ chainId,
2168
+ hash
2169
+ }) {
2170
+ const { list } = useMatchChain();
2171
+ const cache = useTransactionCache();
2172
+ const chain = list?.find((item) => item.id === chainId);
2173
+ const [shouldRefetch, setShouldRefetch] = useState9(true);
2174
+ const query = useQuery4({
2175
+ queryKey: ["match-tx-transaction", hash, chain],
2176
+ queryFn: async () => {
2177
+ if (!chain || !hash) return false;
2178
+ const cacheKey = `${chain.id}-${hash}`;
2179
+ if (cache.get(cacheKey)) {
2180
+ return cache.get(cacheKey);
2181
+ }
2182
+ try {
2183
+ const publicClient = createPublicClient4({
2184
+ chain: defineChain2(chain),
2185
+ transport: http4()
2186
+ });
2187
+ const transaction = await publicClient.getTransaction({ hash });
2188
+ if (!transaction) {
2189
+ return false;
2190
+ }
2191
+ cache.set(cacheKey, transaction);
2192
+ return transaction;
2193
+ } catch (e) {
2194
+ return false;
2195
+ }
2196
+ },
2197
+ refetchInterval: shouldRefetch ? 1e4 : false
2198
+ });
2199
+ useEffect8(() => {
2200
+ if (query.data) {
2201
+ setShouldRefetch(false);
2202
+ }
2203
+ }, [query.data]);
2204
+ return query;
2205
+ }
2206
+
2207
+ // src/store/useModalStore.ts
2208
+ import { create as create5 } from "zustand";
2209
+
2210
+ // src/hooks/useConfig.tsx
2211
+ import { jsx as jsx7 } from "react/jsx-runtime";
2212
+ var DEFAULT_WALLET_METHODS = ["evm", "sol", "btc", "tron", "ton"];
2213
+ var WALLET_METHODS = ["evm", "sol", "btc", "tron", "ton"];
2214
+ function useWalletConfig() {
2215
+ const isDownMd = useDownMd();
2216
+ const walletMap = {
2217
+ evm: {
2218
+ icon: /* @__PURE__ */ jsx7(EVMDarkIcon, { size: isDownMd ? 36 : 40 }),
2219
+ activeIcon: /* @__PURE__ */ jsx7(EVMLightIcon, { size: isDownMd ? 36 : 40 }),
2220
+ name: "EVM",
2221
+ method: "evm"
2222
+ },
2223
+ sol: {
2224
+ icon: /* @__PURE__ */ jsx7(SOLDarkIcon, { size: isDownMd ? 36 : 40 }),
2225
+ activeIcon: /* @__PURE__ */ jsx7(SOLLightIcon, { size: isDownMd ? 36 : 40 }),
2226
+ name: "SOL",
2227
+ method: "sol"
2228
+ },
2229
+ btc: {
2230
+ icon: /* @__PURE__ */ jsx7(BTCDarkIcon, { size: isDownMd ? 36 : 40 }),
2231
+ activeIcon: /* @__PURE__ */ jsx7(BTCLightIcon, { size: isDownMd ? 36 : 40 }),
2232
+ name: "BTC",
2233
+ method: "btc"
2234
+ },
2235
+ tron: {
2236
+ icon: /* @__PURE__ */ jsx7(TRXDarkIcon, { size: isDownMd ? 36 : 40 }),
2237
+ activeIcon: /* @__PURE__ */ jsx7(TRXLightIcon, { size: isDownMd ? 36 : 40 }),
2238
+ name: "TRON",
2239
+ method: "tron"
2240
+ },
2241
+ ton: {
2242
+ icon: /* @__PURE__ */ jsx7(TonLightIcon, { size: isDownMd ? 36 : 40 }),
2243
+ activeIcon: /* @__PURE__ */ jsx7(TonLightIcon2, { size: isDownMd ? 36 : 40 }),
2244
+ name: "TON",
2245
+ method: "ton"
2246
+ }
2247
+ };
2248
+ return {
2249
+ walletMap
2250
+ };
2251
+ }
2252
+
2253
+ // src/store/useModalStore.ts
2254
+ var useSOLModalStore = create5((set) => ({
2255
+ isOpen: false,
2256
+ type: "",
2257
+ open: (type) => set({ isOpen: true, type }),
2258
+ close: () => set({ isOpen: false })
2259
+ }));
2260
+ var useTRONModalStore = create5((set) => ({
2261
+ isOpen: false,
2262
+ type: "",
2263
+ open: (type) => set({ isOpen: true, type }),
2264
+ close: () => set({ isOpen: false })
2265
+ }));
2266
+ var useTONModalStore = create5((set) => ({
2267
+ isOpen: false,
2268
+ type: "",
2269
+ open: (type) => set({ isOpen: true, type }),
2270
+ close: () => set({ isOpen: false })
2271
+ }));
2272
+ var useBTCModalStore = create5((set) => ({
2273
+ isOpen: false,
2274
+ type: "",
2275
+ open: (type) => set({ isOpen: true, type }),
2276
+ close: () => set({ isOpen: false })
2277
+ }));
2278
+ var useCEXBindModalStore = create5((set) => ({
2279
+ type: "",
2280
+ isOpen: false,
2281
+ open: (type) => set({ isOpen: true, type }),
2282
+ close: () => set({ isOpen: false })
2283
+ }));
2284
+ var useWalletModalStore = create5((set) => ({
2285
+ isOpen: false,
2286
+ type: "",
2287
+ methods: [],
2288
+ open: (type, methods = DEFAULT_WALLET_METHODS) => set({ isOpen: true, type, methods }),
2289
+ close: () => set({ isOpen: false })
2290
+ }));
2291
+
1434
2292
  // src/components/CEXBindModal/index.tsx
1435
- import { useEffect as useEffect8, useMemo as useMemo5, useState as useState9 } from "react";
1436
- import { FormattedMessage as FormattedMessage2, useIntl as useIntl2 } from "react-intl";
1437
- import { jsx as jsx7, jsxs as jsxs6 } from "react/jsx-runtime";
2293
+ import { useEffect as useEffect9, useMemo as useMemo5, useState as useState10 } from "react";
2294
+ import { FormattedMessage as FormattedMessage3, useIntl as useIntl3 } from "react-intl";
2295
+ import { jsx as jsx8, jsxs as jsxs6 } from "react/jsx-runtime";
1438
2296
  function CEXBindModal({
1439
2297
  onClose,
1440
2298
  type,
1441
2299
  isOpen = false,
1442
2300
  ...props
1443
2301
  }) {
1444
- const intl = useIntl2();
2302
+ const intl = useIntl3();
1445
2303
  const { events } = useMatch();
1446
- const [APIPassphrase, setAPIPassphrase] = useState9("");
2304
+ const [APIPassphrase, setAPIPassphrase] = useState10("");
1447
2305
  const { refreshOverview } = useUserInfo();
1448
- const [loading, setLoading] = useState9(false);
1449
- const [key, setKey] = useState9("");
1450
- const [secret, setSecret] = useState9("");
1451
- const [error, setError] = useState9("");
2306
+ const [loading, setLoading] = useState10(false);
2307
+ const [key, setKey] = useState10("");
2308
+ const [secret, setSecret] = useState10("");
2309
+ const [error, setError] = useState10("");
1452
2310
  const needPassphrase = useMemo5(() => {
1453
2311
  return ["bitget", "okx"].includes(type.toLowerCase());
1454
2312
  }, [type]);
1455
- useEffect8(() => {
2313
+ useEffect9(() => {
1456
2314
  if (isOpen) {
1457
2315
  setSecret("");
1458
2316
  setKey("");
@@ -1489,20 +2347,20 @@ function CEXBindModal({
1489
2347
  setLoading(false);
1490
2348
  }
1491
2349
  };
1492
- return /* @__PURE__ */ jsx7(ModalWithHeader, { showClose: true, isOpen, onClose, title: intl.formatMessage({
2350
+ return /* @__PURE__ */ jsx8(ModalWithHeader, { showClose: true, isOpen, onClose, title: intl.formatMessage({
1493
2351
  id: "CEXBindTitle"
1494
2352
  }, {
1495
2353
  type
1496
2354
  }), ...props, children: /* @__PURE__ */ jsxs6("div", { className: "matchid-cex-modal", children: [
1497
2355
  /* @__PURE__ */ jsxs6("div", { children: [
1498
- /* @__PURE__ */ jsx7("p", { children: /* @__PURE__ */ jsx7(FormattedMessage2, { id: "CEXBindAttention" }) }),
1499
- /* @__PURE__ */ jsx7("p", { children: /* @__PURE__ */ jsx7(FormattedMessage2, { id: "CEXBindTips1" }) }),
1500
- /* @__PURE__ */ jsx7("p", { children: /* @__PURE__ */ jsx7(FormattedMessage2, { id: "CEXBindTips2" }) }),
1501
- /* @__PURE__ */ jsx7("p", { children: /* @__PURE__ */ jsx7(FormattedMessage2, { id: "CEXBindTips3" }) })
2356
+ /* @__PURE__ */ jsx8("p", { children: /* @__PURE__ */ jsx8(FormattedMessage3, { id: "CEXBindAttention" }) }),
2357
+ /* @__PURE__ */ jsx8("p", { children: /* @__PURE__ */ jsx8(FormattedMessage3, { id: "CEXBindTips1" }) }),
2358
+ /* @__PURE__ */ jsx8("p", { children: /* @__PURE__ */ jsx8(FormattedMessage3, { id: "CEXBindTips2" }) }),
2359
+ /* @__PURE__ */ jsx8("p", { children: /* @__PURE__ */ jsx8(FormattedMessage3, { id: "CEXBindTips3" }) })
1502
2360
  ] }),
1503
- /* @__PURE__ */ jsx7(Field, { label: intl.formatMessage({
2361
+ /* @__PURE__ */ jsx8(Field, { label: intl.formatMessage({
1504
2362
  id: "CEXBindApiKey"
1505
- }), children: /* @__PURE__ */ jsx7(
2363
+ }), children: /* @__PURE__ */ jsx8(
1506
2364
  Input,
1507
2365
  {
1508
2366
  value: key,
@@ -1510,9 +2368,9 @@ function CEXBindModal({
1510
2368
  placeholder: "**** **** ****"
1511
2369
  }
1512
2370
  ) }),
1513
- /* @__PURE__ */ jsx7(Field, { label: intl.formatMessage({
2371
+ /* @__PURE__ */ jsx8(Field, { label: intl.formatMessage({
1514
2372
  id: "CEXBindApiSecretKey"
1515
- }), error: !needPassphrase && error, children: /* @__PURE__ */ jsx7(
2373
+ }), error: !needPassphrase && error, children: /* @__PURE__ */ jsx8(
1516
2374
  Input,
1517
2375
  {
1518
2376
  value: secret,
@@ -1520,9 +2378,9 @@ function CEXBindModal({
1520
2378
  placeholder: "**** **** ****"
1521
2379
  }
1522
2380
  ) }),
1523
- needPassphrase && /* @__PURE__ */ jsx7(Field, { error, label: intl.formatMessage({
2381
+ needPassphrase && /* @__PURE__ */ jsx8(Field, { error, label: intl.formatMessage({
1524
2382
  id: "CEXBindApiPassphrase"
1525
- }), children: /* @__PURE__ */ jsx7(
2383
+ }), children: /* @__PURE__ */ jsx8(
1526
2384
  Input,
1527
2385
  {
1528
2386
  value: APIPassphrase,
@@ -1530,7 +2388,7 @@ function CEXBindModal({
1530
2388
  placeholder: "**** **** ****"
1531
2389
  }
1532
2390
  ) }),
1533
- /* @__PURE__ */ jsx7(
2391
+ /* @__PURE__ */ jsx8(
1534
2392
  Button,
1535
2393
  {
1536
2394
  onClick: SubmitApi,
@@ -1538,14 +2396,14 @@ function CEXBindModal({
1538
2396
  block: true,
1539
2397
  loading,
1540
2398
  disabled: !key || !secret,
1541
- children: /* @__PURE__ */ jsx7(FormattedMessage2, { id: "continue" })
2399
+ children: /* @__PURE__ */ jsx8(FormattedMessage3, { id: "continue" })
1542
2400
  }
1543
2401
  )
1544
2402
  ] }) });
1545
2403
  }
1546
2404
 
1547
2405
  // src/context/BusinessProvider.tsx
1548
- import { Fragment, jsx as jsx8, jsxs as jsxs7 } from "react/jsx-runtime";
2406
+ import { Fragment, jsx as jsx9, jsxs as jsxs7 } from "react/jsx-runtime";
1549
2407
  function BusinessProvider({ children }) {
1550
2408
  const { overview, token } = useUserInfo();
1551
2409
  const { type: SOLType, isOpen: SOLIsOpen, close: SOLClose } = useSOLModalStore();
@@ -1554,13 +2412,12 @@ function BusinessProvider({ children }) {
1554
2412
  const { type: BTCType, isOpen: BTCIsOpen, close: BTCClose } = useBTCModalStore();
1555
2413
  const { type: CEXType, isOpen: CEXIsOpen, close: CEXClose } = useCEXBindModalStore();
1556
2414
  const WalletModalStore = useWalletModalStore();
1557
- const { close: HashPanelClose, ...hashPanelProps } = useHashPanelStore();
1558
2415
  const walletModalClose = (func) => {
1559
2416
  WalletModalStore.close();
1560
2417
  func();
1561
2418
  };
1562
2419
  return /* @__PURE__ */ jsxs7(Fragment, { children: [
1563
- /* @__PURE__ */ jsx8(
2420
+ /* @__PURE__ */ jsx9(
1564
2421
  SOLModal,
1565
2422
  {
1566
2423
  isOpen: SOLIsOpen && (SOLType == "login" && !overview && !token || SOLType == "bind" && !!token && !!overview),
@@ -1570,7 +2427,7 @@ function BusinessProvider({ children }) {
1570
2427
  zIndex: 199
1571
2428
  }
1572
2429
  ),
1573
- /* @__PURE__ */ jsx8(
2430
+ /* @__PURE__ */ jsx9(
1574
2431
  TRONModal,
1575
2432
  {
1576
2433
  isOpen: TRONIsOpen && (TRONType == "login" && !overview && !token || TRONType == "bind" && !!token && !!overview),
@@ -1580,7 +2437,7 @@ function BusinessProvider({ children }) {
1580
2437
  zIndex: 199
1581
2438
  }
1582
2439
  ),
1583
- /* @__PURE__ */ jsx8(
2440
+ /* @__PURE__ */ jsx9(
1584
2441
  TONModal,
1585
2442
  {
1586
2443
  isOpen: TONIsOpen && (TONType == "login" && !overview && !token || TONType == "bind" && !!token && !!overview),
@@ -1590,7 +2447,7 @@ function BusinessProvider({ children }) {
1590
2447
  zIndex: 199
1591
2448
  }
1592
2449
  ),
1593
- /* @__PURE__ */ jsx8(
2450
+ /* @__PURE__ */ jsx9(
1594
2451
  BTCModal,
1595
2452
  {
1596
2453
  isOpen: BTCIsOpen && (BTCType == "login" && !overview && !token || BTCType == "bind" && !!token && !!overview),
@@ -1600,7 +2457,7 @@ function BusinessProvider({ children }) {
1600
2457
  zIndex: 199
1601
2458
  }
1602
2459
  ),
1603
- /* @__PURE__ */ jsx8(
2460
+ /* @__PURE__ */ jsx9(
1604
2461
  CEXBindModal,
1605
2462
  {
1606
2463
  isOpen: CEXIsOpen && (!!token && !!overview),
@@ -1609,8 +2466,7 @@ function BusinessProvider({ children }) {
1609
2466
  zIndex: 199
1610
2467
  }
1611
2468
  ),
1612
- /* @__PURE__ */ jsx8(HashPanel_default, { onClose: HashPanelClose, ...hashPanelProps }),
1613
- /* @__PURE__ */ jsx8(
2469
+ /* @__PURE__ */ jsx9(
1614
2470
  WalletModal,
1615
2471
  {
1616
2472
  isOpen: WalletModalStore.isOpen && (WalletModalStore.type == "login" && !overview && !token || WalletModalStore.type == "bind" && !!token && !!overview),
@@ -1625,14 +2481,14 @@ function BusinessProvider({ children }) {
1625
2481
  }
1626
2482
 
1627
2483
  // src/context/index.tsx
1628
- import { jsx as jsx9 } from "react/jsx-runtime";
2484
+ import { jsx as jsx10 } from "react/jsx-runtime";
1629
2485
  var Providers = ({ children }) => {
1630
- return /* @__PURE__ */ jsx9(ToastProvider, { children: /* @__PURE__ */ jsx9(ModalProvider, { children: /* @__PURE__ */ jsx9(BusinessProvider, { children }) }) });
2486
+ return /* @__PURE__ */ jsx10(ToastProvider, { children: /* @__PURE__ */ jsx10(ModalProvider, { children: /* @__PURE__ */ jsx10(BusinessProvider, { children }) }) });
1631
2487
  };
1632
2488
  var context_default = Providers;
1633
2489
 
1634
2490
  // src/hooks/useWalletInit.ts
1635
- import { useEffect as useEffect9, useRef } from "react";
2491
+ import { useEffect as useEffect10, useRef as useRef2 } from "react";
1636
2492
 
1637
2493
  // src/utils/wallet.ts
1638
2494
  var sendMessage = ({ method, data, resolve, reject, timeout }) => {
@@ -1665,11 +2521,11 @@ function useWalletInit({
1665
2521
  }) {
1666
2522
  const { endpoints, token, overview, setWallet, wallet, appid, locale, refreshOverview } = useLocalStore_default();
1667
2523
  const { setWalletReady, walletReady } = useStore_default();
1668
- const iframeReadyRef = useRef(walletReady);
1669
- useEffect9(() => {
2524
+ const iframeReadyRef = useRef2(walletReady);
2525
+ useEffect10(() => {
1670
2526
  setWallet(config);
1671
2527
  }, [config]);
1672
- useEffect9(() => {
2528
+ useEffect10(() => {
1673
2529
  matchlog_default.log("sdk.mpc.status", walletReady, iframeReadyRef.current);
1674
2530
  iframeReadyRef.current = walletReady;
1675
2531
  if (iframeReadyRef.current) {
@@ -1686,7 +2542,7 @@ function useWalletInit({
1686
2542
  onReady();
1687
2543
  }
1688
2544
  }, [walletReady]);
1689
- useEffect9(() => {
2545
+ useEffect10(() => {
1690
2546
  if (!endpoints.auth || !appid || !token || !config) {
1691
2547
  const existingIframe = getWalletIframe();
1692
2548
  if (existingIframe) {
@@ -1786,7 +2642,7 @@ function useWalletInit({
1786
2642
  }
1787
2643
  }
1788
2644
  }, [endpoints.auth, appid, token, config]);
1789
- useEffect9(() => {
2645
+ useEffect10(() => {
1790
2646
  const messageHandle = async (e) => {
1791
2647
  if (e.origin !== endpoints.auth.substring(0, endpoints.auth.length - 1)) {
1792
2648
  return;
@@ -1867,7 +2723,7 @@ function useWalletInit({
1867
2723
  }
1868
2724
 
1869
2725
  // src/hooks/useInit.tsx
1870
- import { useEffect as useEffect10, useRef as useRef2 } from "react";
2726
+ import { useEffect as useEffect11, useRef as useRef3 } from "react";
1871
2727
  function useInit({
1872
2728
  theme,
1873
2729
  appid,
@@ -1887,23 +2743,23 @@ function useInit({
1887
2743
  locale: realLocale
1888
2744
  } = useLocalStore_default();
1889
2745
  const walletModalStore = useWalletModalStore();
1890
- const overviewLoadingRef = useRef2(false);
2746
+ const overviewLoadingRef = useRef3(false);
1891
2747
  const searchParams = new URLSearchParams(window.location.search);
1892
2748
  const matchToken = searchParams.get("matchToken");
1893
2749
  const realEndpoints = endpoints || env_default.endpoints;
1894
- useEffect10(() => {
2750
+ useEffect11(() => {
1895
2751
  setTheme(theme);
1896
2752
  }, [theme]);
1897
- useEffect10(() => {
2753
+ useEffect11(() => {
1898
2754
  setAppid(appid);
1899
2755
  }, [appid]);
1900
- useEffect10(() => {
2756
+ useEffect11(() => {
1901
2757
  setEndpoints(realEndpoints);
1902
2758
  }, [realEndpoints]);
1903
- useEffect10(() => {
2759
+ useEffect11(() => {
1904
2760
  setLocale(locale || "en");
1905
2761
  }, [locale]);
1906
- useEffect10(() => {
2762
+ useEffect11(() => {
1907
2763
  if (matchToken) {
1908
2764
  const tokenData = JSON.parse(atob(matchToken));
1909
2765
  if (tokenData && tokenData.mid && tokenData.token) {
@@ -1914,7 +2770,7 @@ function useInit({
1914
2770
  }
1915
2771
  }
1916
2772
  }, [matchToken]);
1917
- useEffect10(() => {
2773
+ useEffect11(() => {
1918
2774
  const onLoginMessage = (event) => {
1919
2775
  const res = event.data;
1920
2776
  if (res.event === "login" && res.data && (res.data.token || res.data.token_type && res.data.access_token)) {
@@ -1951,7 +2807,7 @@ function useInit({
1951
2807
  overviewLoadingRef.current = false;
1952
2808
  }
1953
2809
  };
1954
- useEffect10(() => {
2810
+ useEffect11(() => {
1955
2811
  if (token) {
1956
2812
  loadOverview();
1957
2813
  }
@@ -2034,7 +2890,30 @@ var en_default = {
2034
2890
  CEXBindApiSecretKey: "API Secret Key",
2035
2891
  CEXBindApiPassphrase: "API Passphrase",
2036
2892
  cancel: "Cancel",
2037
- walletLoading: "Wallet service is loading"
2893
+ walletLoading: "Wallet service is loading",
2894
+ tokenDetails: "Token Details",
2895
+ tokenAmountMin: "Amount must be greater than 0.",
2896
+ tokenAmountMax: "Insufficient balance.",
2897
+ tokenAddressError: "Invalid address.",
2898
+ amount: "Amount",
2899
+ amountPlaceholder: "Enter the Amount.",
2900
+ balance: "Balance",
2901
+ receiveTitle: "Received wallet address",
2902
+ receivePlaceholder: "Enter the Received wallet address.",
2903
+ next: "Next",
2904
+ copied: "Copied",
2905
+ receiveQrcode: "Receive by scanning the QR code",
2906
+ copyAddress: "Copy Address",
2907
+ importSuccess: "Imported successfully",
2908
+ tokenSmartContract: "Token Smart Contract",
2909
+ tokenSmartContractPlaceholder: "Enter the Token Smart Contract.",
2910
+ tokenSymbol: "Token Symbol",
2911
+ tokenSymbolPlaceholder: "Enter the Token Symbol.",
2912
+ tokenDecimals: "Decimals",
2913
+ tokenDecimalsPlaceholder: "Enter the Decimals.",
2914
+ import: "Import",
2915
+ receive: "Receive",
2916
+ customizedToken: "Customized Token"
2038
2917
  };
2039
2918
 
2040
2919
  // src/i18n/zh.json
@@ -2086,7 +2965,30 @@ var zh_default = {
2086
2965
  CEXBindApiSecretKey: "API \u79D8\u94A5",
2087
2966
  CEXBindApiPassphrase: "API \u5BC6\u7801\u77ED\u8BED",
2088
2967
  cancel: "\u53D6\u6D88",
2089
- walletLoading: "\u94B1\u5305\u670D\u52A1\u6B63\u5728\u52A0\u8F7D"
2968
+ walletLoading: "\u94B1\u5305\u670D\u52A1\u6B63\u5728\u52A0\u8F7D",
2969
+ tokenDetails: "\u4EE3\u5E01\u8BE6\u60C5",
2970
+ tokenAmountMin: "\u91D1\u989D\u5FC5\u987B\u5927\u4E8E 0\u3002",
2971
+ tokenAmountMax: "\u4F59\u989D\u4E0D\u8DB3\u3002",
2972
+ tokenAddressError: "\u65E0\u6548\u7684\u5730\u5740\u3002",
2973
+ amount: "\u91D1\u989D",
2974
+ amountPlaceholder: "\u8BF7\u8F93\u5165\u91D1\u989D\u3002",
2975
+ balance: "\u4F59\u989D",
2976
+ receiveTitle: "\u63A5\u6536\u94B1\u5305\u5730\u5740",
2977
+ receivePlaceholder: "\u8BF7\u8F93\u5165\u63A5\u6536\u94B1\u5305\u5730\u5740\u3002",
2978
+ next: "\u4E0B\u4E00\u6B65",
2979
+ copied: "\u5DF2\u590D\u5236",
2980
+ receiveQrcode: "\u626B\u63CF QR \u7801\u63A5\u6536",
2981
+ copyAddress: "\u590D\u5236\u5730\u5740",
2982
+ importSuccess: "\u5BFC\u5165\u6210\u529F",
2983
+ tokenSmartContract: "\u4EE3\u5E01\u667A\u80FD\u5408\u7EA6",
2984
+ tokenSmartContractPlaceholder: "\u8BF7\u8F93\u5165\u4EE3\u5E01\u667A\u80FD\u5408\u7EA6\u3002",
2985
+ tokenSymbol: "\u4EE3\u5E01\u7B26\u53F7",
2986
+ tokenSymbolPlaceholder: "\u8BF7\u8F93\u5165\u4EE3\u5E01\u7B26\u53F7\u3002",
2987
+ tokenDecimals: "\u5C0F\u6570\u4F4D\u6570",
2988
+ tokenDecimalsPlaceholder: "\u8BF7\u8F93\u5165\u5C0F\u6570\u4F4D\u6570\u3002",
2989
+ import: "\u5BFC\u5165",
2990
+ receive: "\u63A5\u6536",
2991
+ customizedToken: "\u81EA\u5B9A\u4E49\u4EE3\u5E01"
2090
2992
  };
2091
2993
 
2092
2994
  // src/i18n/tw.json
@@ -2138,7 +3040,30 @@ var tw_default = {
2138
3040
  CEXBindApiSecretKey: "API \u5BC6\u9470",
2139
3041
  CEXBindApiPassphrase: "API \u5BC6\u78BC\u77ED\u8A9E",
2140
3042
  cancel: "\u53D6\u6D88",
2141
- walletLoading: "\u9322\u5305\u670D\u52D9\u6B63\u5728\u52A0\u8F09"
3043
+ walletLoading: "\u9322\u5305\u670D\u52D9\u6B63\u5728\u52A0\u8F09",
3044
+ tokenDetails: "\u4EE3\u5E63\u8A73\u60C5",
3045
+ tokenAmountMin: "\u91D1\u984D\u5FC5\u9808\u5927\u65BC 0\u3002",
3046
+ tokenAmountMax: "\u9918\u984D\u4E0D\u8DB3\u3002",
3047
+ tokenAddressError: "\u7121\u6548\u7684\u5730\u5740\u3002",
3048
+ amount: "\u91D1\u984D",
3049
+ amountPlaceholder: "\u8ACB\u8F38\u5165\u91D1\u984D\u3002",
3050
+ balance: "\u9918\u984D",
3051
+ receiveTitle: "\u63A5\u6536\u9322\u5305\u5730\u5740",
3052
+ receivePlaceholder: "\u8ACB\u8F38\u5165\u63A5\u6536\u9322\u5305\u5730\u5740\u3002",
3053
+ next: "\u4E0B\u4E00\u6B65",
3054
+ copied: "\u5DF2\u8907\u88FD",
3055
+ receiveQrcode: "\u6383\u63CF QR \u78BC\u63A5\u6536",
3056
+ copyAddress: "\u8907\u88FD\u5730\u5740",
3057
+ importSuccess: "\u5C0E\u5165\u6210\u529F",
3058
+ tokenSmartContract: "\u4EE3\u5E63\u667A\u80FD\u5408\u7D04",
3059
+ tokenSmartContractPlaceholder: "\u8ACB\u8F38\u5165\u4EE3\u5E63\u667A\u80FD\u5408\u7D04\u3002",
3060
+ tokenSymbol: "\u4EE3\u5E63\u7B26\u865F",
3061
+ tokenSymbolPlaceholder: "\u8ACB\u8F38\u5165\u4EE3\u5E63\u7B26\u865F\u3002",
3062
+ tokenDecimals: "\u5C0F\u6578\u4F4D\u6578",
3063
+ tokenDecimalsPlaceholder: "\u8ACB\u8F38\u5165\u5C0F\u6578\u4F4D\u6578\u3002",
3064
+ import: "\u5C0E\u5165",
3065
+ receive: "\u63A5\u6536",
3066
+ customizedToken: "\u81EA\u5B9A\u7FA9\u4EE3\u5E63"
2142
3067
  };
2143
3068
 
2144
3069
  // src/i18n/fr.json
@@ -2190,7 +3115,30 @@ var fr_default = {
2190
3115
  CEXBindApiSecretKey: "Cl\xE9 Secr\xE8te API",
2191
3116
  CEXBindApiPassphrase: "Phrase secr\xE8te API",
2192
3117
  cancel: "Annuler",
2193
- walletLoading: "Le service de portefeuille est en cours de chargement"
3118
+ walletLoading: "Le service de portefeuille est en cours de chargement",
3119
+ tokenDetails: "D\xE9tails du Token",
3120
+ tokenAmountMin: "Le montant doit \xEAtre sup\xE9rieur \xE0 0.",
3121
+ tokenAmountMax: "Solde insuffisant.",
3122
+ tokenAddressError: "Adresse invalide.",
3123
+ amount: "Montant",
3124
+ amountPlaceholder: "Entrez le montant.",
3125
+ balance: "Solde",
3126
+ receiveTitle: "Adresse du portefeuille re\xE7u",
3127
+ receivePlaceholder: "Entrez l'adresse du portefeuille re\xE7u.",
3128
+ next: "Suivant",
3129
+ copied: "Copi\xE9",
3130
+ receiveQrcode: "Recevoir en scannant le code QR",
3131
+ copyAddress: "Copier l'adresse",
3132
+ importSuccess: "Import\xE9 avec succ\xE8s",
3133
+ tokenSmartContract: "Contrat intelligent du Token",
3134
+ tokenSmartContractPlaceholder: "Entrez le contrat intelligent du Token.",
3135
+ tokenSymbol: "Symbole du Token",
3136
+ tokenSymbolPlaceholder: "Entrez le symbole du Token.",
3137
+ tokenDecimals: "D\xE9cimales",
3138
+ tokenDecimalsPlaceholder: "Entrez les d\xE9cimales.",
3139
+ import: "Importer",
3140
+ receive: "Recevoir",
3141
+ customizedToken: "Token personnalis\xE9"
2194
3142
  };
2195
3143
 
2196
3144
  // src/i18n/ja.json
@@ -2242,7 +3190,30 @@ var ja_default = {
2242
3190
  CEXBindApiSecretKey: "API \u30B7\u30FC\u30AF\u30EC\u30C3\u30C8\u30AD\u30FC",
2243
3191
  CEXBindApiPassphrase: "API \u30D1\u30B9\u30D5\u30EC\u30FC\u30BA",
2244
3192
  cancel: "\u30AD\u30E3\u30F3\u30BB\u30EB",
2245
- walletLoading: "\u30A6\u30A9\u30EC\u30C3\u30C8\u30B5\u30FC\u30D3\u30B9\u3092\u8AAD\u307F\u8FBC\u3093\u3067\u3044\u307E\u3059"
3193
+ walletLoading: "\u30A6\u30A9\u30EC\u30C3\u30C8\u30B5\u30FC\u30D3\u30B9\u3092\u8AAD\u307F\u8FBC\u3093\u3067\u3044\u307E\u3059",
3194
+ tokenDetails: "\u30C8\u30FC\u30AF\u30F3\u306E\u8A73\u7D30",
3195
+ tokenAmountMin: "\u91D1\u984D\u306F0\u3088\u308A\u5927\u304D\u304F\u306A\u3051\u308C\u3070\u306A\u308A\u307E\u305B\u3093\u3002",
3196
+ tokenAmountMax: "\u6B8B\u9AD8\u304C\u4E0D\u8DB3\u3057\u3066\u3044\u307E\u3059\u3002",
3197
+ tokenAddressError: "\u7121\u52B9\u306A\u30A2\u30C9\u30EC\u30B9\u3067\u3059\u3002",
3198
+ amount: "\u91D1\u984D",
3199
+ amountPlaceholder: "\u91D1\u984D\u3092\u5165\u529B\u3057\u3066\u304F\u3060\u3055\u3044\u3002",
3200
+ balance: "\u6B8B\u9AD8",
3201
+ receiveTitle: "\u53D7\u53D6\u30A6\u30A9\u30EC\u30C3\u30C8\u30A2\u30C9\u30EC\u30B9",
3202
+ receivePlaceholder: "\u53D7\u53D6\u30A6\u30A9\u30EC\u30C3\u30C8\u30A2\u30C9\u30EC\u30B9\u3092\u5165\u529B\u3057\u3066\u304F\u3060\u3055\u3044\u3002",
3203
+ next: "\u6B21\u3078",
3204
+ copied: "\u30B3\u30D4\u30FC\u3057\u307E\u3057\u305F",
3205
+ receiveQrcode: "QR\u30B3\u30FC\u30C9\u3092\u30B9\u30AD\u30E3\u30F3\u3057\u3066\u53D7\u3051\u53D6\u308B",
3206
+ copyAddress: "\u30A2\u30C9\u30EC\u30B9\u3092\u30B3\u30D4\u30FC",
3207
+ importSuccess: "\u30A4\u30F3\u30DD\u30FC\u30C8\u306B\u6210\u529F\u3057\u307E\u3057\u305F",
3208
+ tokenSmartContract: "\u30C8\u30FC\u30AF\u30F3\u306E\u30B9\u30DE\u30FC\u30C8\u30B3\u30F3\u30C8\u30E9\u30AF\u30C8",
3209
+ tokenSmartContractPlaceholder: "\u30C8\u30FC\u30AF\u30F3\u306E\u30B9\u30DE\u30FC\u30C8\u30B3\u30F3\u30C8\u30E9\u30AF\u30C8\u3092\u5165\u529B\u3057\u3066\u304F\u3060\u3055\u3044\u3002",
3210
+ tokenSymbol: "\u30C8\u30FC\u30AF\u30F3\u30B7\u30F3\u30DC\u30EB",
3211
+ tokenSymbolPlaceholder: "\u30C8\u30FC\u30AF\u30F3\u30B7\u30F3\u30DC\u30EB\u3092\u5165\u529B\u3057\u3066\u304F\u3060\u3055\u3044\u3002",
3212
+ tokenDecimals: "\u5C0F\u6570\u70B9",
3213
+ tokenDecimalsPlaceholder: "\u5C0F\u6570\u70B9\u3092\u5165\u529B\u3057\u3066\u304F\u3060\u3055\u3044\u3002",
3214
+ import: "\u30A4\u30F3\u30DD\u30FC\u30C8",
3215
+ receive: "\u53D7\u3051\u53D6\u308B",
3216
+ customizedToken: "\u30AB\u30B9\u30BF\u30DE\u30A4\u30BA\u30C8\u30FC\u30AF\u30F3"
2246
3217
  };
2247
3218
 
2248
3219
  // src/i18n/ko.json
@@ -2294,7 +3265,30 @@ var ko_default = {
2294
3265
  CEXBindApiSecretKey: "API \uBE44\uBC00 \uD0A4",
2295
3266
  CEXBindApiPassphrase: "API \uC554\uD638 \uAD6C\uBB38",
2296
3267
  cancel: "\uCDE8\uC18C",
2297
- walletLoading: "\uC9C0\uAC11 \uC11C\uBE44\uC2A4\uB97C \uBD88\uB7EC\uC624\uB294 \uC911"
3268
+ walletLoading: "\uC9C0\uAC11 \uC11C\uBE44\uC2A4\uB97C \uBD88\uB7EC\uC624\uB294 \uC911",
3269
+ tokenDetails: "\uD1A0\uD070 \uC0C1\uC138\uC815\uBCF4",
3270
+ tokenAmountMin: "\uAE08\uC561\uC740 0\uBCF4\uB2E4 \uCEE4\uC57C \uD569\uB2C8\uB2E4.",
3271
+ tokenAmountMax: "\uC794\uC561\uC774 \uBD80\uC871\uD569\uB2C8\uB2E4.",
3272
+ tokenAddressError: "\uC720\uD6A8\uD558\uC9C0 \uC54A\uC740 \uC8FC\uC18C\uC785\uB2C8\uB2E4.",
3273
+ amount: "\uAE08\uC561",
3274
+ amountPlaceholder: "\uAE08\uC561\uC744 \uC785\uB825\uD558\uC138\uC694.",
3275
+ balance: "\uC794\uC561",
3276
+ receiveTitle: "\uC218\uC2E0 \uC9C0\uAC11 \uC8FC\uC18C",
3277
+ receivePlaceholder: "\uC218\uC2E0 \uC9C0\uAC11 \uC8FC\uC18C\uB97C \uC785\uB825\uD558\uC138\uC694.",
3278
+ next: "\uB2E4\uC74C",
3279
+ copied: "\uBCF5\uC0AC\uB428",
3280
+ receiveQrcode: "QR \uCF54\uB4DC\uB97C \uC2A4\uCE94\uD558\uC5EC \uBC1B\uAE30",
3281
+ copyAddress: "\uC8FC\uC18C \uBCF5\uC0AC",
3282
+ importSuccess: "\uC131\uACF5\uC801\uC73C\uB85C \uAC00\uC838\uC654\uC2B5\uB2C8\uB2E4.",
3283
+ tokenSmartContract: "\uD1A0\uD070 \uC2A4\uB9C8\uD2B8 \uCEE8\uD2B8\uB799\uD2B8",
3284
+ tokenSmartContractPlaceholder: "\uD1A0\uD070 \uC2A4\uB9C8\uD2B8 \uCEE8\uD2B8\uB799\uD2B8\uB97C \uC785\uB825\uD558\uC138\uC694.",
3285
+ tokenSymbol: "\uD1A0\uD070 \uC2EC\uBCFC",
3286
+ tokenSymbolPlaceholder: "\uD1A0\uD070 \uC2EC\uBCFC\uC744 \uC785\uB825\uD558\uC138\uC694.",
3287
+ tokenDecimals: "\uC18C\uC218\uC810 \uC790\uB9AC\uC218",
3288
+ tokenDecimalsPlaceholder: "\uC18C\uC218\uC810 \uC790\uB9AC\uC218\uB97C \uC785\uB825\uD558\uC138\uC694.",
3289
+ import: "\uAC00\uC838\uC624\uAE30",
3290
+ receive: "\uBC1B\uAE30",
3291
+ customizedToken: "\uB9DE\uCDA4\uD615 \uD1A0\uD070"
2298
3292
  };
2299
3293
 
2300
3294
  // src/i18n/vi.json
@@ -2346,7 +3340,30 @@ var vi_default = {
2346
3340
  CEXBindApiSecretKey: "Kh\xF3a b\xED m\u1EADt API",
2347
3341
  CEXBindApiPassphrase: "C\u1EE5m m\u1EADt kh\u1EA9u API",
2348
3342
  cancel: "H\u1EE7y",
2349
- walletLoading: "D\u1ECBch v\u1EE5 v\xED \u0111ang t\u1EA3i"
3343
+ walletLoading: "D\u1ECBch v\u1EE5 v\xED \u0111ang t\u1EA3i",
3344
+ tokenDetails: "Chi ti\u1EBFt Token",
3345
+ tokenAmountMin: "S\u1ED1 ti\u1EC1n ph\u1EA3i l\u1EDBn h\u01A1n 0.",
3346
+ tokenAmountMax: "S\u1ED1 d\u01B0 kh\xF4ng \u0111\u1EE7.",
3347
+ tokenAddressError: "\u0110\u1ECBa ch\u1EC9 kh\xF4ng h\u1EE3p l\u1EC7.",
3348
+ amount: "S\u1ED1 l\u01B0\u1EE3ng",
3349
+ amountPlaceholder: "Nh\u1EADp s\u1ED1 l\u01B0\u1EE3ng.",
3350
+ balance: "S\u1ED1 d\u01B0",
3351
+ receiveTitle: "\u0110\u1ECBa ch\u1EC9 v\xED nh\u1EADn",
3352
+ receivePlaceholder: "Nh\u1EADp \u0111\u1ECBa ch\u1EC9 v\xED nh\u1EADn.",
3353
+ next: "Ti\u1EBFp theo",
3354
+ copied: "\u0110\xE3 sao ch\xE9p",
3355
+ receiveQrcode: "Nh\u1EADn b\u1EB1ng c\xE1ch qu\xE9t m\xE3 QR",
3356
+ copyAddress: "Sao ch\xE9p \u0111\u1ECBa ch\u1EC9",
3357
+ importSuccess: "Nh\u1EADp th\xE0nh c\xF4ng",
3358
+ tokenSmartContract: "H\u1EE3p \u0111\u1ED3ng th\xF4ng minh Token",
3359
+ tokenSmartContractPlaceholder: "Nh\u1EADp h\u1EE3p \u0111\u1ED3ng th\xF4ng minh Token.",
3360
+ tokenSymbol: "K\xFD hi\u1EC7u Token",
3361
+ tokenSymbolPlaceholder: "Nh\u1EADp k\xFD hi\u1EC7u Token.",
3362
+ tokenDecimals: "S\u1ED1 th\u1EADp ph\xE2n",
3363
+ tokenDecimalsPlaceholder: "Nh\u1EADp s\u1ED1 th\u1EADp ph\xE2n.",
3364
+ import: "Nh\u1EADp",
3365
+ receive: "Nh\u1EADn",
3366
+ customizedToken: "Token t\xF9y ch\u1EC9nh"
2350
3367
  };
2351
3368
 
2352
3369
  // src/i18n/es.json
@@ -2398,7 +3415,30 @@ var es_default = {
2398
3415
  CEXBindApiSecretKey: "Clave Secreta API",
2399
3416
  CEXBindApiPassphrase: "Frase de contrase\xF1a API",
2400
3417
  cancel: "Cancelar",
2401
- walletLoading: "El servicio de cartera se est\xE1 cargando"
3418
+ walletLoading: "El servicio de cartera se est\xE1 cargando",
3419
+ tokenDetails: "Detalles del Token",
3420
+ tokenAmountMin: "La cantidad debe ser mayor que 0.",
3421
+ tokenAmountMax: "Saldo insuficiente.",
3422
+ tokenAddressError: "Direcci\xF3n no v\xE1lida.",
3423
+ amount: "Cantidad",
3424
+ amountPlaceholder: "Ingrese la cantidad.",
3425
+ balance: "Saldo",
3426
+ receiveTitle: "Direcci\xF3n de billetera recibida",
3427
+ receivePlaceholder: "Ingrese la direcci\xF3n de la billetera recibida.",
3428
+ next: "Siguiente",
3429
+ copied: "Copiado",
3430
+ receiveQrcode: "Recibir escaneando el c\xF3digo QR",
3431
+ copyAddress: "Copiar direcci\xF3n",
3432
+ importSuccess: "Importado con \xE9xito",
3433
+ tokenSmartContract: "Contrato inteligente del Token",
3434
+ tokenSmartContractPlaceholder: "Ingrese el contrato inteligente del Token.",
3435
+ tokenSymbol: "S\xEDmbolo del Token",
3436
+ tokenSymbolPlaceholder: "Ingrese el s\xEDmbolo del Token.",
3437
+ tokenDecimals: "Decimales",
3438
+ tokenDecimalsPlaceholder: "Ingrese los decimales.",
3439
+ import: "Importar",
3440
+ receive: "Recibir",
3441
+ customizedToken: "Token personalizado"
2402
3442
  };
2403
3443
 
2404
3444
  // src/i18n/pt.json
@@ -2450,7 +3490,30 @@ var pt_default = {
2450
3490
  CEXBindApiSecretKey: "Chave Secreta API",
2451
3491
  CEXBindApiPassphrase: "Senha de API",
2452
3492
  cancel: "Cancelar",
2453
- walletLoading: "O servi\xE7o de carteira est\xE1 carregando"
3493
+ walletLoading: "O servi\xE7o de carteira est\xE1 carregando",
3494
+ tokenDetails: "Detalhes do Token",
3495
+ tokenAmountMin: "O valor deve ser maior que 0.",
3496
+ tokenAmountMax: "Saldo insuficiente.",
3497
+ tokenAddressError: "Endere\xE7o inv\xE1lido.",
3498
+ amount: "Quantidade",
3499
+ amountPlaceholder: "Digite a quantidade.",
3500
+ balance: "Saldo",
3501
+ receiveTitle: "Endere\xE7o da carteira recebida",
3502
+ receivePlaceholder: "Digite o endere\xE7o da carteira recebida.",
3503
+ next: "Pr\xF3ximo",
3504
+ copied: "Copiado",
3505
+ receiveQrcode: "Receber escaneando o c\xF3digo QR",
3506
+ copyAddress: "Copiar endere\xE7o",
3507
+ importSuccess: "Importado com sucesso",
3508
+ tokenSmartContract: "Contrato inteligente do Token",
3509
+ tokenSmartContractPlaceholder: "Digite o contrato inteligente do Token.",
3510
+ tokenSymbol: "S\xEDmbolo do Token",
3511
+ tokenSymbolPlaceholder: "Digite o s\xEDmbolo do Token.",
3512
+ tokenDecimals: "Decimais",
3513
+ tokenDecimalsPlaceholder: "Digite os decimais.",
3514
+ import: "Importar",
3515
+ receive: "Receber",
3516
+ customizedToken: "Token personalizado"
2454
3517
  };
2455
3518
 
2456
3519
  // src/i18n/index.ts
@@ -2467,7 +3530,7 @@ var messages = {
2467
3530
  };
2468
3531
 
2469
3532
  // src/MatchContext.tsx
2470
- import { jsx as jsx10 } from "react/jsx-runtime";
3533
+ import { jsx as jsx11 } from "react/jsx-runtime";
2471
3534
  var queryClient = new QueryClient();
2472
3535
  var MatchContext = createContext3(void 0);
2473
3536
  var MatchProvider = ({
@@ -2489,7 +3552,7 @@ var MatchProvider = ({
2489
3552
  useWalletInit({
2490
3553
  config: wallet
2491
3554
  });
2492
- return /* @__PURE__ */ jsx10(IntlProvider, { locale: realLocale, messages: messages[realLocale], children: /* @__PURE__ */ jsx10(QueryClientProvider, { client: queryClient, children: /* @__PURE__ */ jsx10(
3555
+ return /* @__PURE__ */ jsx11(IntlProvider, { locale: realLocale, messages: messages[realLocale], children: /* @__PURE__ */ jsx11(QueryClientProvider, { client: queryClient, children: /* @__PURE__ */ jsx11(
2493
3556
  MatchContext.Provider,
2494
3557
  {
2495
3558
  value: {
@@ -2500,7 +3563,7 @@ var MatchProvider = ({
2500
3563
  theme,
2501
3564
  locale: realLocale
2502
3565
  },
2503
- children: /* @__PURE__ */ jsx10(context_default, { children })
3566
+ children: /* @__PURE__ */ jsx11(context_default, { children })
2504
3567
  }
2505
3568
  ) }) });
2506
3569
  };
@@ -2522,7 +3585,7 @@ function useUserInfo() {
2522
3585
  logout: logoutStore,
2523
3586
  setOverview,
2524
3587
  overview,
2525
- address: address2,
3588
+ address,
2526
3589
  endpoints,
2527
3590
  locale,
2528
3591
  refreshOverview
@@ -2750,7 +3813,7 @@ function useUserInfo() {
2750
3813
  token,
2751
3814
  mid,
2752
3815
  did,
2753
- address: address2,
3816
+ address,
2754
3817
  isLogin,
2755
3818
  logout,
2756
3819
  getLoginEmailCode,
@@ -2766,29 +3829,23 @@ function useUserInfo() {
2766
3829
  }
2767
3830
 
2768
3831
  // src/components/EmailModal/StepVerify.tsx
2769
- import { useEffect as useEffect12, useMemo as useMemo7, useRef as useRef3, useState as useState11 } from "react";
2770
-
2771
- // src/config/index.tsx
2772
- var EMAIL_INTERVAL = 60;
2773
- var EMAIL_CODE_LENGTH = 6;
2774
-
2775
- // src/components/EmailModal/StepVerify.tsx
2776
- import { FormattedMessage as FormattedMessage3, useIntl as useIntl3 } from "react-intl";
2777
- import { jsx as jsx11, jsxs as jsxs8 } from "react/jsx-runtime";
3832
+ import { useEffect as useEffect13, useMemo as useMemo7, useRef as useRef4, useState as useState12 } from "react";
3833
+ import { FormattedMessage as FormattedMessage4, useIntl as useIntl4 } from "react-intl";
3834
+ import { jsx as jsx12, jsxs as jsxs8 } from "react/jsx-runtime";
2778
3835
  function StepVerify(props) {
2779
- const intl = useIntl3();
3836
+ const intl = useIntl4();
2780
3837
  const { getLoginEmailCode, loginByEmail } = useUserInfo();
2781
- const [error, setError] = useState11("");
2782
- const [code, setCode] = useState11("");
2783
- const [sending, setSending] = useState11(false);
2784
- const [submitting, setSubmitting] = useState11(false);
2785
- const sendTimeRef = useRef3(0);
2786
- const [sendBtnText, setSendBtnText] = useState11(intl.formatMessage({
3838
+ const [error, setError] = useState12("");
3839
+ const [code, setCode] = useState12("");
3840
+ const [sending, setSending] = useState12(false);
3841
+ const [submitting, setSubmitting] = useState12(false);
3842
+ const sendTimeRef = useRef4(0);
3843
+ const [sendBtnText, setSendBtnText] = useState12(intl.formatMessage({
2787
3844
  id: "send"
2788
3845
  }));
2789
3846
  const intervalTime = EMAIL_INTERVAL;
2790
3847
  const codeLength = EMAIL_CODE_LENGTH;
2791
- const intervalRef = useRef3(null);
3848
+ const intervalRef = useRef4(null);
2792
3849
  const isDownMd = useDownMd();
2793
3850
  const onSend = async () => {
2794
3851
  if (sendTimeRef.current > 0) {
@@ -2819,7 +3876,7 @@ function StepVerify(props) {
2819
3876
  setSending(false);
2820
3877
  }
2821
3878
  };
2822
- useEffect12(() => {
3879
+ useEffect13(() => {
2823
3880
  onSend();
2824
3881
  return () => {
2825
3882
  if (intervalRef.current) {
@@ -2853,15 +3910,15 @@ function StepVerify(props) {
2853
3910
  };
2854
3911
  return /* @__PURE__ */ jsxs8("div", { className: "matchid-email-verify-box", children: [
2855
3912
  /* @__PURE__ */ jsxs8("div", { className: "matchid-email-verify-header", children: [
2856
- /* @__PURE__ */ jsx11("div", { className: "matchid-email-verify-header-icon", children: /* @__PURE__ */ jsx11(EmailLineIcon, { size: isDownMd ? 19 : 24 }) }),
3913
+ /* @__PURE__ */ jsx12("div", { className: "matchid-email-verify-header-icon", children: /* @__PURE__ */ jsx12(EmailLineIcon, { size: isDownMd ? 19 : 24 }) }),
2857
3914
  /* @__PURE__ */ jsxs8("div", { className: "matchid-email-verify-header-content", children: [
2858
- /* @__PURE__ */ jsx11("div", { className: "matchid-email-verify-header-value", children: props.email }),
2859
- /* @__PURE__ */ jsx11("div", { className: "matchid-email-verify-header-tips", children: /* @__PURE__ */ jsx11(FormattedMessage3, { id: "sendEmailTips" }) })
3915
+ /* @__PURE__ */ jsx12("div", { className: "matchid-email-verify-header-value", children: props.email }),
3916
+ /* @__PURE__ */ jsx12("div", { className: "matchid-email-verify-header-tips", children: /* @__PURE__ */ jsx12(FormattedMessage4, { id: "sendEmailTips" }) })
2860
3917
  ] })
2861
3918
  ] }),
2862
- /* @__PURE__ */ jsx11(Field, { label: intl.formatMessage({
3919
+ /* @__PURE__ */ jsx12(Field, { label: intl.formatMessage({
2863
3920
  id: "verificationCode"
2864
- }), error, children: /* @__PURE__ */ jsx11(
3921
+ }), error, children: /* @__PURE__ */ jsx12(
2865
3922
  Input,
2866
3923
  {
2867
3924
  placeholder: intl.formatMessage({
@@ -2871,7 +3928,7 @@ function StepVerify(props) {
2871
3928
  maxLength: codeLength,
2872
3929
  onChange: (e) => setCode(e.target.value),
2873
3930
  value: code,
2874
- after: /* @__PURE__ */ jsx11(
3931
+ after: /* @__PURE__ */ jsx12(
2875
3932
  Button,
2876
3933
  {
2877
3934
  highlight: true,
@@ -2890,13 +3947,13 @@ function StepVerify(props) {
2890
3947
  )
2891
3948
  }
2892
3949
  ) }),
2893
- /* @__PURE__ */ jsx11(Button, { disabled: !canContinue, highlight: true, block: true, size: "lg", onClick: onContinue, children: /* @__PURE__ */ jsx11(FormattedMessage3, { id: "continue" }) })
3950
+ /* @__PURE__ */ jsx12(Button, { disabled: !canContinue, highlight: true, block: true, size: "lg", onClick: onContinue, children: /* @__PURE__ */ jsx12(FormattedMessage4, { id: "continue" }) })
2894
3951
  ] });
2895
3952
  }
2896
3953
 
2897
3954
  // src/components/EmailModal/index.tsx
2898
- import { useIntl as useIntl4 } from "react-intl";
2899
- import { jsx as jsx12 } from "react/jsx-runtime";
3955
+ import { useIntl as useIntl5 } from "react-intl";
3956
+ import { jsx as jsx13 } from "react/jsx-runtime";
2900
3957
  function EmailModal({
2901
3958
  isOpen = false,
2902
3959
  width = 480,
@@ -2904,16 +3961,16 @@ function EmailModal({
2904
3961
  onBack,
2905
3962
  onLogin
2906
3963
  }) {
2907
- const [step, setStep] = useState12("input");
2908
- const [emailVal, setEmailVal] = useState12("");
2909
- const intl = useIntl4();
2910
- useEffect13(() => {
3964
+ const [step, setStep] = useState13("input");
3965
+ const [emailVal, setEmailVal] = useState13("");
3966
+ const intl = useIntl5();
3967
+ useEffect14(() => {
2911
3968
  if (!isOpen) {
2912
3969
  setStep("input");
2913
3970
  setEmailVal("");
2914
3971
  }
2915
3972
  }, [isOpen]);
2916
- return /* @__PURE__ */ jsx12(
3973
+ return /* @__PURE__ */ jsx13(
2917
3974
  ModalWithHeader,
2918
3975
  {
2919
3976
  isOpen,
@@ -2923,22 +3980,22 @@ function EmailModal({
2923
3980
  id: "email"
2924
3981
  }),
2925
3982
  onBack: step == "verify" ? () => setStep("input") : onBack,
2926
- children: step === "input" ? /* @__PURE__ */ jsx12(StepEmail, { email: emailVal, onContinue: (email) => {
3983
+ children: step === "input" ? /* @__PURE__ */ jsx13(StepEmail, { email: emailVal, onContinue: (email) => {
2927
3984
  setEmailVal(email);
2928
3985
  setStep("verify");
2929
- } }) : /* @__PURE__ */ jsx12(StepVerify, { email: emailVal, onSuccess: onLogin })
3986
+ } }) : /* @__PURE__ */ jsx13(StepVerify, { email: emailVal, onSuccess: onLogin })
2930
3987
  }
2931
3988
  );
2932
3989
  }
2933
3990
 
2934
3991
  // src/components/LoginBox/index.tsx
2935
- import { useMemo as useMemo8, useState as useState13 } from "react";
2936
- import { FormattedMessage as FormattedMessage4, useIntl as useIntl5 } from "react-intl";
3992
+ import { useMemo as useMemo8, useState as useState14 } from "react";
3993
+ import { FormattedMessage as FormattedMessage5, useIntl as useIntl6 } from "react-intl";
2937
3994
 
2938
3995
  // src/hooks/useAppConfig.ts
2939
- import { useQuery as useQuery3 } from "@tanstack/react-query";
3996
+ import { useQuery as useQuery5 } from "@tanstack/react-query";
2940
3997
  function useAppConfig() {
2941
- const query = useQuery3({
3998
+ const query = useQuery5({
2942
3999
  queryKey: ["appConfig"],
2943
4000
  queryFn: async () => {
2944
4001
  const res = await getAppConfigApi();
@@ -2956,7 +4013,7 @@ function useAppConfig() {
2956
4013
  }
2957
4014
 
2958
4015
  // src/components/LoginBox/index.tsx
2959
- import { Fragment as Fragment2, jsx as jsx13, jsxs as jsxs9 } from "react/jsx-runtime";
4016
+ import { Fragment as Fragment2, jsx as jsx14, jsxs as jsxs9 } from "react/jsx-runtime";
2960
4017
  var RecommendItem = ({
2961
4018
  icon,
2962
4019
  name,
@@ -2968,17 +4025,17 @@ var RecommendItem = ({
2968
4025
  return /* @__PURE__ */ jsxs9("div", { className: "matchid-login-recommend-method", children: [
2969
4026
  /* @__PURE__ */ jsxs9("div", { className: "matchid-login-recommend-method-item", onClick, children: [
2970
4027
  /* @__PURE__ */ jsxs9("div", { className: "matchid-login-recommend-method-content", children: [
2971
- /* @__PURE__ */ jsx13("div", { className: "matchid-login-recommend-method-icon", children: icon }),
2972
- /* @__PURE__ */ jsx13("span", { className: "matchid-login-recommend-method-name", children: name })
4028
+ /* @__PURE__ */ jsx14("div", { className: "matchid-login-recommend-method-icon", children: icon }),
4029
+ /* @__PURE__ */ jsx14("span", { className: "matchid-login-recommend-method-name", children: name })
2973
4030
  ] }),
2974
- footer ? footer : children ? /* @__PURE__ */ jsx13(
4031
+ footer ? footer : children ? /* @__PURE__ */ jsx14(
2975
4032
  ArrowDownIcon,
2976
4033
  {
2977
4034
  className: `matchid-login-recommend-method-arrow ${showChildren ? "matchid-login-recommend-method-arrow-active" : ""}`,
2978
4035
  size: 20,
2979
4036
  color: "var(--matchid-arrow-color)"
2980
4037
  }
2981
- ) : /* @__PURE__ */ jsx13(
4038
+ ) : /* @__PURE__ */ jsx14(
2982
4039
  ArrowRightIcon,
2983
4040
  {
2984
4041
  className: "matchid-login-recommend-method-arrow",
@@ -2987,7 +4044,7 @@ var RecommendItem = ({
2987
4044
  }
2988
4045
  )
2989
4046
  ] }),
2990
- children && /* @__PURE__ */ jsx13(
4047
+ children && /* @__PURE__ */ jsx14(
2991
4048
  "div",
2992
4049
  {
2993
4050
  className: `matchid-login-recommend-method-popover ${showChildren ? "matchid-login-recommend-method-popover-active" : ""}`,
@@ -3045,62 +4102,62 @@ function LoginBox({
3045
4102
  walletMethods: walletMethodList
3046
4103
  };
3047
4104
  }, [config.platform, recommendMethods, methods, walletMethods]);
3048
- const [emailOpen, setEmailOpen] = useState13(false);
4105
+ const [emailOpen, setEmailOpen] = useState14(false);
3049
4106
  const { login } = useUserInfo();
3050
- const [showWallet, setShowWallet] = useState13(false);
3051
- const intl = useIntl5();
4107
+ const [showWallet, setShowWallet] = useState14(false);
4108
+ const intl = useIntl6();
3052
4109
  const isDownMd = useDownMd();
3053
4110
  const methodMap = {
3054
4111
  wallet: {
3055
- icon: /* @__PURE__ */ jsx13(WalletIcon, { size: isDownMd ? 36 : 40 }),
4112
+ icon: /* @__PURE__ */ jsx14(WalletIcon, { size: isDownMd ? 36 : 40 }),
3056
4113
  name: intl.formatMessage({ id: "wallet" }),
3057
4114
  onClick: () => setShowWallet(!showWallet),
3058
4115
  type: "wallet"
3059
4116
  },
3060
4117
  email: {
3061
- icon: /* @__PURE__ */ jsx13(EmailIcon, { size: isDownMd ? 36 : 40 }),
4118
+ icon: /* @__PURE__ */ jsx14(EmailIcon, { size: isDownMd ? 36 : 40 }),
3062
4119
  name: intl.formatMessage({ id: "email" }),
3063
4120
  onClick: () => {
3064
4121
  setEmailOpen(true);
3065
4122
  }
3066
4123
  },
3067
4124
  google: {
3068
- icon: /* @__PURE__ */ jsx13(GoogleIcon, { size: isDownMd ? 36 : 40 }),
4125
+ icon: /* @__PURE__ */ jsx14(GoogleIcon, { size: isDownMd ? 36 : 40 }),
3069
4126
  name: "Google",
3070
4127
  onClick: () => login("google")
3071
4128
  },
3072
4129
  twitter: {
3073
- icon: /* @__PURE__ */ jsx13(XIcon, { size: isDownMd ? 36 : 40 }),
4130
+ icon: /* @__PURE__ */ jsx14(XIcon, { size: isDownMd ? 36 : 40 }),
3074
4131
  name: "X",
3075
4132
  onClick: () => login("twitter")
3076
4133
  },
3077
4134
  telegram: {
3078
- icon: /* @__PURE__ */ jsx13(TelegramIcon, { size: isDownMd ? 36 : 40 }),
4135
+ icon: /* @__PURE__ */ jsx14(TelegramIcon, { size: isDownMd ? 36 : 40 }),
3079
4136
  name: "Telegram",
3080
4137
  onClick: () => login("telegram")
3081
4138
  },
3082
4139
  github: {
3083
- icon: /* @__PURE__ */ jsx13(GithubIcon, { size: isDownMd ? 36 : 40 }),
4140
+ icon: /* @__PURE__ */ jsx14(GithubIcon, { size: isDownMd ? 36 : 40 }),
3084
4141
  name: "Github",
3085
4142
  onClick: () => login("github")
3086
4143
  },
3087
4144
  discord: {
3088
- icon: /* @__PURE__ */ jsx13(DiscordIcon, { size: isDownMd ? 36 : 40 }),
4145
+ icon: /* @__PURE__ */ jsx14(DiscordIcon, { size: isDownMd ? 36 : 40 }),
3089
4146
  name: "Discord",
3090
4147
  onClick: () => login("discord")
3091
4148
  },
3092
4149
  linkedin: {
3093
- icon: /* @__PURE__ */ jsx13(LinkedinIcon, { size: isDownMd ? 36 : 40 }),
4150
+ icon: /* @__PURE__ */ jsx14(LinkedinIcon, { size: isDownMd ? 36 : 40 }),
3094
4151
  name: "LinkedIn",
3095
4152
  onClick: () => login("linkedin")
3096
4153
  },
3097
4154
  facebook: {
3098
- icon: /* @__PURE__ */ jsx13(FacebookIcon, { size: isDownMd ? 36 : 40 }),
4155
+ icon: /* @__PURE__ */ jsx14(FacebookIcon, { size: isDownMd ? 36 : 40 }),
3099
4156
  name: "Facebook",
3100
4157
  onClick: () => login("facebook")
3101
4158
  },
3102
4159
  youtube: {
3103
- icon: /* @__PURE__ */ jsx13(YoutubeIcon, { size: isDownMd ? 36 : 40 }),
4160
+ icon: /* @__PURE__ */ jsx14(YoutubeIcon, { size: isDownMd ? 36 : 40 }),
3104
4161
  name: "Youtube",
3105
4162
  onClick: () => login("youtube")
3106
4163
  }
@@ -3108,8 +4165,8 @@ function LoginBox({
3108
4165
  const { walletMap } = useWalletConfig();
3109
4166
  return /* @__PURE__ */ jsxs9(Fragment2, { children: [
3110
4167
  (!inModal || !emailOpen) && /* @__PURE__ */ jsxs9("div", { className: "matchid-login-box", children: [
3111
- /* @__PURE__ */ jsx13("div", { className: "matchid-login-recommend-list", children: methodConfig.recommendMethods.map((m) => {
3112
- return /* @__PURE__ */ jsx13(
4168
+ /* @__PURE__ */ jsx14("div", { className: "matchid-login-recommend-list", children: methodConfig.recommendMethods.map((m) => {
4169
+ return /* @__PURE__ */ jsx14(
3113
4170
  RecommendItem,
3114
4171
  {
3115
4172
  icon: methodMap[m]?.icon,
@@ -3117,8 +4174,8 @@ function LoginBox({
3117
4174
  onClick: methodMap[m]?.onClick,
3118
4175
  showChildren: m == "wallet" && showWallet,
3119
4176
  children: m == "wallet" && /* @__PURE__ */ jsxs9(Fragment2, { children: [
3120
- /* @__PURE__ */ jsx13("div", { className: "matchid-login-recommend-wallet-divider" }),
3121
- /* @__PURE__ */ jsx13("div", { className: "matchid-login-recommend-wallet-list", children: methodConfig.walletMethods.map((n) => {
4177
+ /* @__PURE__ */ jsx14("div", { className: "matchid-login-recommend-wallet-divider" }),
4178
+ /* @__PURE__ */ jsx14("div", { className: "matchid-login-recommend-wallet-list", children: methodConfig.walletMethods.map((n) => {
3122
4179
  const m2 = walletMap[n];
3123
4180
  return /* @__PURE__ */ jsxs9(
3124
4181
  "div",
@@ -3129,15 +4186,15 @@ function LoginBox({
3129
4186
  },
3130
4187
  children: [
3131
4188
  /* @__PURE__ */ jsxs9("div", { className: "matchid-login-recommend-wallet-item-content", children: [
3132
- /* @__PURE__ */ jsx13("div", { className: "matchid-login-recommend-wallet-item-icon", children: m2.icon }),
3133
- /* @__PURE__ */ jsx13(
4189
+ /* @__PURE__ */ jsx14("div", { className: "matchid-login-recommend-wallet-item-icon", children: m2.icon }),
4190
+ /* @__PURE__ */ jsx14(
3134
4191
  "div",
3135
4192
  {
3136
4193
  className: "matchid-login-recommend-wallet-item-hover-icon",
3137
4194
  children: m2.activeIcon
3138
4195
  }
3139
4196
  ),
3140
- /* @__PURE__ */ jsx13(
4197
+ /* @__PURE__ */ jsx14(
3141
4198
  "span",
3142
4199
  {
3143
4200
  className: "matchid-login-recommend-wallet-item-name",
@@ -3145,7 +4202,7 @@ function LoginBox({
3145
4202
  }
3146
4203
  )
3147
4204
  ] }),
3148
- /* @__PURE__ */ jsx13(
4205
+ /* @__PURE__ */ jsx14(
3149
4206
  ArrowRightIcon,
3150
4207
  {
3151
4208
  className: "matchid-login-recommend-wallet-item-arrow",
@@ -3164,9 +4221,9 @@ function LoginBox({
3164
4221
  );
3165
4222
  }) }),
3166
4223
  methodConfig.methods.length > 0 && /* @__PURE__ */ jsxs9("div", { className: "matchid-login-other", children: [
3167
- /* @__PURE__ */ jsx13("div", { className: "matchid-login-other-text", children: /* @__PURE__ */ jsx13(FormattedMessage4, { id: "otherLoginMethods" }) }),
3168
- /* @__PURE__ */ jsx13("div", { className: "matchid-login-method-box", children: methodConfig.methods.map((m) => {
3169
- return /* @__PURE__ */ jsx13(
4224
+ /* @__PURE__ */ jsx14("div", { className: "matchid-login-other-text", children: /* @__PURE__ */ jsx14(FormattedMessage5, { id: "otherLoginMethods" }) }),
4225
+ /* @__PURE__ */ jsx14("div", { className: "matchid-login-method-box", children: methodConfig.methods.map((m) => {
4226
+ return /* @__PURE__ */ jsx14(
3170
4227
  "div",
3171
4228
  {
3172
4229
  className: "matchid-login-method-item",
@@ -3179,7 +4236,7 @@ function LoginBox({
3179
4236
  }) })
3180
4237
  ] })
3181
4238
  ] }),
3182
- /* @__PURE__ */ jsx13(
4239
+ /* @__PURE__ */ jsx14(
3183
4240
  EmailModal,
3184
4241
  {
3185
4242
  isOpen: emailOpen,
@@ -3195,11 +4252,11 @@ function LoginBox({
3195
4252
  }
3196
4253
 
3197
4254
  // src/components/LoginButton/index.tsx
3198
- import { useState as useState15 } from "react";
4255
+ import { useState as useState16 } from "react";
3199
4256
 
3200
4257
  // src/components/LoginPanel/index.tsx
3201
- import { FormattedMessage as FormattedMessage5 } from "react-intl";
3202
- import { jsx as jsx14, jsxs as jsxs10 } from "react/jsx-runtime";
4258
+ import { FormattedMessage as FormattedMessage6 } from "react-intl";
4259
+ import { jsx as jsx15, jsxs as jsxs10 } from "react/jsx-runtime";
3203
4260
  function LoginPanel({
3204
4261
  header,
3205
4262
  onClose,
@@ -3209,42 +4266,42 @@ function LoginPanel({
3209
4266
  return /* @__PURE__ */ jsxs10("div", { className: "matchid-login-panel", children: [
3210
4267
  header ? header : /* @__PURE__ */ jsxs10("div", { className: "matchid-login-panel-header", children: [
3211
4268
  /* @__PURE__ */ jsxs10("div", { className: "matchid-login-panel-header-content", children: [
3212
- /* @__PURE__ */ jsx14("div", { className: "matchid-login-panel-header-title", children: /* @__PURE__ */ jsx14(FormattedMessage5, { id: "loginTitle" }) }),
3213
- /* @__PURE__ */ jsx14("div", { className: "matchid-login-panel-header-subtilte", children: /* @__PURE__ */ jsx14(FormattedMessage5, { id: "loginTips" }) })
4269
+ /* @__PURE__ */ jsx15("div", { className: "matchid-login-panel-header-title", children: /* @__PURE__ */ jsx15(FormattedMessage6, { id: "loginTitle" }) }),
4270
+ /* @__PURE__ */ jsx15("div", { className: "matchid-login-panel-header-subtilte", children: /* @__PURE__ */ jsx15(FormattedMessage6, { id: "loginTips" }) })
3214
4271
  ] }),
3215
- onClose && /* @__PURE__ */ jsx14("div", { className: "matchid-login-panel-header-close", onClick: onClose, children: /* @__PURE__ */ jsx14(CloseRoundIcon, { size: isDownMd ? 24 : 30 }) })
4272
+ onClose && /* @__PURE__ */ jsx15("div", { className: "matchid-login-panel-header-close", onClick: onClose, children: /* @__PURE__ */ jsx15(CloseRoundIcon, { size: isDownMd ? 24 : 30 }) })
3216
4273
  ] }),
3217
- /* @__PURE__ */ jsx14("div", { className: "matchid-login-panel-divide" }),
3218
- /* @__PURE__ */ jsx14("div", { className: "matchid-login-panel-box", children: /* @__PURE__ */ jsx14(LoginBox, { ...props }) })
4274
+ /* @__PURE__ */ jsx15("div", { className: "matchid-login-panel-divide" }),
4275
+ /* @__PURE__ */ jsx15("div", { className: "matchid-login-panel-box", children: /* @__PURE__ */ jsx15(LoginBox, { ...props }) })
3219
4276
  ] });
3220
4277
  }
3221
4278
 
3222
4279
  // src/components/LoginModal/index.tsx
3223
- import { jsx as jsx15 } from "react/jsx-runtime";
4280
+ import { jsx as jsx16 } from "react/jsx-runtime";
3224
4281
  function LoginModal({
3225
4282
  isOpen = false,
3226
4283
  width = 480,
3227
4284
  ...props
3228
4285
  }) {
3229
4286
  const { isLogin } = useUserInfo();
3230
- return /* @__PURE__ */ jsx15(
4287
+ return /* @__PURE__ */ jsx16(
3231
4288
  Modal,
3232
4289
  {
3233
4290
  isOpen: isOpen && !isLogin,
3234
4291
  width,
3235
- children: /* @__PURE__ */ jsx15(LoginPanel, { ...props, inModal: true })
4292
+ children: /* @__PURE__ */ jsx16(LoginPanel, { ...props, inModal: true })
3236
4293
  }
3237
4294
  );
3238
4295
  }
3239
4296
 
3240
4297
  // src/components/UserPopover/index.tsx
3241
- import { useState as useState14 } from "react";
4298
+ import { useState as useState15 } from "react";
3242
4299
 
3243
4300
  // src/assets/icon/ProfileIcon.tsx
3244
- import { jsx as jsx16, jsxs as jsxs11 } from "react/jsx-runtime";
4301
+ import { jsx as jsx17, jsxs as jsxs11 } from "react/jsx-runtime";
3245
4302
  function ProfileIcon({ size = 24, color = "black", ...props }) {
3246
4303
  return /* @__PURE__ */ jsxs11("svg", { width: size, height: size, viewBox: "0 0 24 24", fill: "none", xmlns: "http://www.w3.org/2000/svg", children: [
3247
- /* @__PURE__ */ jsx16(
4304
+ /* @__PURE__ */ jsx17(
3248
4305
  "path",
3249
4306
  {
3250
4307
  fillRule: "evenodd",
@@ -3253,7 +4310,7 @@ function ProfileIcon({ size = 24, color = "black", ...props }) {
3253
4310
  fill: color
3254
4311
  }
3255
4312
  ),
3256
- /* @__PURE__ */ jsx16(
4313
+ /* @__PURE__ */ jsx17(
3257
4314
  "path",
3258
4315
  {
3259
4316
  fillRule: "evenodd",
@@ -3266,11 +4323,11 @@ function ProfileIcon({ size = 24, color = "black", ...props }) {
3266
4323
  }
3267
4324
 
3268
4325
  // src/components/UserPopover/index.tsx
3269
- import { FormattedMessage as FormattedMessage6, useIntl as useIntl6 } from "react-intl";
3270
- import { jsx as jsx17, jsxs as jsxs12 } from "react/jsx-runtime";
4326
+ import { FormattedMessage as FormattedMessage7, useIntl as useIntl7 } from "react-intl";
4327
+ import { jsx as jsx18, jsxs as jsxs12 } from "react/jsx-runtime";
3271
4328
  function UserContent() {
3272
- const { logout, address: address2, username } = useUserInfo();
3273
- const [logouting, setLogouting] = useState14(false);
4329
+ const { logout, address, username } = useUserInfo();
4330
+ const [logouting, setLogouting] = useState15(false);
3274
4331
  const onLogout = async () => {
3275
4332
  if (logouting) return;
3276
4333
  try {
@@ -3291,31 +4348,31 @@ function UserContent() {
3291
4348
  return /* @__PURE__ */ jsxs12("div", { className: "matchid-user-popover-item", onClick, children: [
3292
4349
  /* @__PURE__ */ jsxs12("div", { className: `matchid-user-popover-item-content`, children: [
3293
4350
  icon,
3294
- /* @__PURE__ */ jsx17("div", { className: "matchid-user-popover-item-text", children })
4351
+ /* @__PURE__ */ jsx18("div", { className: "matchid-user-popover-item-text", children })
3295
4352
  ] }),
3296
4353
  rightIcon
3297
4354
  ] });
3298
4355
  };
3299
4356
  const UserDivider = () => {
3300
- return /* @__PURE__ */ jsx17("div", { className: `matchid-user-popover-divider` });
4357
+ return /* @__PURE__ */ jsx18("div", { className: `matchid-user-popover-divider` });
3301
4358
  };
3302
- const [usernameOpen, setUsernameOpen] = useState14(false);
4359
+ const [usernameOpen, setUsernameOpen] = useState15(false);
3303
4360
  const [copied, setCopied] = useCopyClipboard();
3304
- const intl = useIntl6();
4361
+ const intl = useIntl7();
3305
4362
  return /* @__PURE__ */ jsxs12("div", { className: "matchid-user-popover-content", children: [
3306
4363
  /* @__PURE__ */ jsxs12("div", { className: "matchid-user-popover-list", children: [
3307
- /* @__PURE__ */ jsx17(UserItem, { onClick: () => {
3308
- setCopied(address2);
3309
- }, icon: copied ? /* @__PURE__ */ jsx17(CheckIcon, { size: 20, color: "#0ecb81" }) : /* @__PURE__ */ jsx17(CopyIcon, { size: 20, color: "var(--icon-color)" }), rightIcon: /* @__PURE__ */ jsx17(CheckIcon, { size: 20, color: "var(--icon-color)" }), children: truncateAddress(address2) }),
3310
- /* @__PURE__ */ jsx17(UserDivider, {}),
3311
- /* @__PURE__ */ jsx17(UserItem, { onClick: () => {
4364
+ /* @__PURE__ */ jsx18(UserItem, { onClick: () => {
4365
+ setCopied(address);
4366
+ }, icon: copied ? /* @__PURE__ */ jsx18(CheckIcon, { size: 20, color: "#0ecb81" }) : /* @__PURE__ */ jsx18(CopyIcon, { size: 20, color: "var(--icon-color)" }), rightIcon: /* @__PURE__ */ jsx18(CheckIcon, { size: 20, color: "var(--icon-color)" }), children: truncateAddress(address) }),
4367
+ /* @__PURE__ */ jsx18(UserDivider, {}),
4368
+ /* @__PURE__ */ jsx18(UserItem, { onClick: () => {
3312
4369
  setUsernameOpen(true);
3313
- }, icon: /* @__PURE__ */ jsx17(ProfileIcon, { size: 20, color: "var(--icon-color)" }), rightIcon: /* @__PURE__ */ jsx17(ArrowRightIcon, { size: 20, color: "var(--icon-color)" }), children: username || intl.formatMessage({
4370
+ }, icon: /* @__PURE__ */ jsx18(ProfileIcon, { size: 20, color: "var(--icon-color)" }), rightIcon: /* @__PURE__ */ jsx18(ArrowRightIcon, { size: 20, color: "var(--icon-color)" }), children: username || intl.formatMessage({
3314
4371
  id: "setUsername"
3315
4372
  }) })
3316
4373
  ] }),
3317
- /* @__PURE__ */ jsx17(Button, { onClick: onLogout, loading: logouting, children: /* @__PURE__ */ jsx17(FormattedMessage6, { id: "disconnect" }) }),
3318
- /* @__PURE__ */ jsx17(UsernameModal, { isOpen: usernameOpen, onClose: () => {
4374
+ /* @__PURE__ */ jsx18(Button, { onClick: onLogout, loading: logouting, children: /* @__PURE__ */ jsx18(FormattedMessage7, { id: "disconnect" }) }),
4375
+ /* @__PURE__ */ jsx18(UsernameModal, { isOpen: usernameOpen, onClose: () => {
3319
4376
  setUsernameOpen(false);
3320
4377
  }, onSuccess: () => {
3321
4378
  setUsernameOpen(false);
@@ -3326,12 +4383,12 @@ function UserPopover({
3326
4383
  children,
3327
4384
  ...props
3328
4385
  }) {
3329
- return /* @__PURE__ */ jsx17(Popover, { ...props, content: /* @__PURE__ */ jsx17(UserContent, {}), children });
4386
+ return /* @__PURE__ */ jsx18(Popover, { ...props, content: /* @__PURE__ */ jsx18(UserContent, {}), children });
3330
4387
  }
3331
4388
 
3332
4389
  // src/components/LoginButton/index.tsx
3333
- import { FormattedMessage as FormattedMessage7, useIntl as useIntl7 } from "react-intl";
3334
- import { Fragment as Fragment3, jsx as jsx18, jsxs as jsxs13 } from "react/jsx-runtime";
4390
+ import { FormattedMessage as FormattedMessage8, useIntl as useIntl8 } from "react-intl";
4391
+ import { Fragment as Fragment3, jsx as jsx19, jsxs as jsxs13 } from "react/jsx-runtime";
3335
4392
  function LoginButton({
3336
4393
  loginRender,
3337
4394
  methods,
@@ -3343,12 +4400,12 @@ function LoginButton({
3343
4400
  walletMethods,
3344
4401
  ...props
3345
4402
  }) {
3346
- const intl = useIntl7();
4403
+ const intl = useIntl8();
3347
4404
  const { isLogin, username } = useUserInfo();
3348
- const [loginOpen, setLoginOpen] = useState15(false);
4405
+ const [loginOpen, setLoginOpen] = useState16(false);
3349
4406
  if (!isLogin) {
3350
4407
  return /* @__PURE__ */ jsxs13(Fragment3, { children: [
3351
- /* @__PURE__ */ jsx18(
4408
+ /* @__PURE__ */ jsx19(
3352
4409
  LoginModal,
3353
4410
  {
3354
4411
  methods,
@@ -3359,53 +4416,30 @@ function LoginButton({
3359
4416
  }
3360
4417
  ),
3361
4418
  /* @__PURE__ */ jsxs13(Button, { className: "matchid-unlogin-btn", ...props, highlight: true, onClick: () => setLoginOpen(true), children: [
3362
- /* @__PURE__ */ jsx18(UnLoginIcon_default, {}),
3363
- /* @__PURE__ */ jsx18("span", { children: /* @__PURE__ */ jsx18(FormattedMessage7, { id: "login" }) })
4419
+ /* @__PURE__ */ jsx19(UnLoginIcon_default, {}),
4420
+ /* @__PURE__ */ jsx19("span", { children: /* @__PURE__ */ jsx19(FormattedMessage8, { id: "login" }) })
3364
4421
  ] })
3365
4422
  ] });
3366
4423
  }
3367
- return loginRender ? /* @__PURE__ */ jsx18(Fragment3, { children: loginRender }) : /* @__PURE__ */ jsx18(UserPopover, { position: popoverPosition, type: popoverType, gap: popoverGap, children: /* @__PURE__ */ jsxs13(Button, { onClick: onLoginClick, className: "matchid-login-btn", ...props, children: [
3368
- /* @__PURE__ */ jsx18(LoginIcon_default, {}),
3369
- /* @__PURE__ */ jsx18("span", { children: username ? truncateAddress(username) : "MatchID " + intl.formatMessage({
4424
+ return loginRender ? /* @__PURE__ */ jsx19(Fragment3, { children: loginRender }) : /* @__PURE__ */ jsx19(UserPopover, { position: popoverPosition, type: popoverType, gap: popoverGap, children: /* @__PURE__ */ jsxs13(Button, { onClick: onLoginClick, className: "matchid-login-btn", ...props, children: [
4425
+ /* @__PURE__ */ jsx19(LoginIcon_default, {}),
4426
+ /* @__PURE__ */ jsx19("span", { children: username ? truncateAddress(username) : "MatchID " + intl.formatMessage({
3370
4427
  id: "user"
3371
4428
  }) })
3372
4429
  ] }) });
3373
4430
  }
3374
4431
 
3375
4432
  // src/components/UsernameModal/index.tsx
3376
- import { useEffect as useEffect14, useMemo as useMemo9, useState as useState16 } from "react";
3377
-
3378
- // src/assets/icon/InfoRoundIcon.tsx
3379
- import { jsx as jsx19, jsxs as jsxs14 } from "react/jsx-runtime";
3380
- function InfoRoundIcon({
3381
- size,
3382
- color = "#6E6E6E",
3383
- ...props
3384
- }) {
3385
- return /* @__PURE__ */ jsxs14("svg", { width: size, height: size, viewBox: "0 0 16 16", fill: "none", xmlns: "http://www.w3.org/2000/svg", ...props, children: [
3386
- /* @__PURE__ */ jsx19("g", { clipPath: "url(#clip0_418_7746)", children: /* @__PURE__ */ jsx19(
3387
- "path",
3388
- {
3389
- fillRule: "evenodd",
3390
- clipRule: "evenodd",
3391
- d: "M7.99984 0.666504C3.94975 0.666504 0.666504 3.94975 0.666504 7.99984C0.666504 12.0499 3.94975 15.3332 7.99984 15.3332C12.0499 15.3332 15.3332 12.0499 15.3332 7.99984C15.3332 3.94975 12.0499 0.666504 7.99984 0.666504ZM1.99984 7.99984C1.99984 4.68613 4.68613 1.99984 7.99984 1.99984C11.3135 1.99984 13.9998 4.68613 13.9998 7.99984C13.9998 11.3135 11.3135 13.9998 7.99984 13.9998C4.68613 13.9998 1.99984 11.3135 1.99984 7.99984ZM8.6665 7.33317C8.6665 6.96498 8.36803 6.6665 7.99984 6.6665C7.63165 6.6665 7.33317 6.96498 7.33317 7.33317V11.3332C7.33317 11.7014 7.63165 11.9998 7.99984 11.9998C8.36803 11.9998 8.6665 11.7014 8.6665 11.3332V7.33317ZM7.99984 5.33317C8.36803 5.33317 8.6665 5.03469 8.6665 4.6665C8.6665 4.29831 8.36803 3.99984 7.99984 3.99984C7.63165 3.99984 7.33317 4.29831 7.33317 4.6665C7.33317 5.03469 7.63165 5.33317 7.99984 5.33317Z",
3392
- fill: color
3393
- }
3394
- ) }),
3395
- /* @__PURE__ */ jsx19("defs", { children: /* @__PURE__ */ jsx19("clipPath", { id: "clip0_418_7746", children: /* @__PURE__ */ jsx19("rect", { width: "16", height: "16", fill: "white" }) }) })
3396
- ] });
3397
- }
3398
-
3399
- // src/components/UsernameModal/index.tsx
3400
- import { FormattedMessage as FormattedMessage8, useIntl as useIntl8 } from "react-intl";
3401
- import { jsx as jsx20, jsxs as jsxs15 } from "react/jsx-runtime";
4433
+ import { useEffect as useEffect15, useMemo as useMemo9, useState as useState17 } from "react";
4434
+ import { FormattedMessage as FormattedMessage9, useIntl as useIntl9 } from "react-intl";
4435
+ import { jsx as jsx20, jsxs as jsxs14 } from "react/jsx-runtime";
3402
4436
  var ValidItem = ({
3403
4437
  success = false,
3404
4438
  text
3405
4439
  }) => {
3406
4440
  const isDownMd = useDownMd();
3407
- return /* @__PURE__ */ jsxs15("div", { className: `matchid-valid-status-item matchid-valid-status-${success ? "success" : "error"}`, children: [
3408
- success ? /* @__PURE__ */ jsx20(CheckRoundIcon, { size: isDownMd ? 12 : 16 }) : /* @__PURE__ */ jsx20(InfoRoundIcon, { size: isDownMd ? 12 : 16 }),
4441
+ return /* @__PURE__ */ jsxs14("div", { className: `matchid-valid-status-item matchid-valid-status-${success ? "success" : "error"}`, children: [
4442
+ success ? /* @__PURE__ */ jsx20(CheckRoundIcon, { size: isDownMd ? 12 : 16 }) : /* @__PURE__ */ jsx20(InfoLineIcon, { size: isDownMd ? 12 : 16 }),
3409
4443
  /* @__PURE__ */ jsx20("span", { children: text })
3410
4444
  ] });
3411
4445
  };
@@ -3417,10 +4451,10 @@ function UsernameModal({
3417
4451
  }) {
3418
4452
  const { username, refreshOverview } = useUserInfo();
3419
4453
  const { isLogin } = useUserInfo();
3420
- const [val, setVal] = useState16(username);
3421
- const [error, setError] = useState16("");
4454
+ const [val, setVal] = useState17(username);
4455
+ const [error, setError] = useState17("");
3422
4456
  const isDownMd = useDownMd();
3423
- useEffect14(() => {
4457
+ useEffect15(() => {
3424
4458
  if (isOpen) {
3425
4459
  setVal(username);
3426
4460
  setError("");
@@ -3433,7 +4467,7 @@ function UsernameModal({
3433
4467
  return val.length >= 2 && val.length <= 32;
3434
4468
  }, [val]);
3435
4469
  const isSafe = isValid && isLength;
3436
- const [isSubmitting, setIsSubmitting] = useState16(false);
4470
+ const [isSubmitting, setIsSubmitting] = useState17(false);
3437
4471
  const onSubmit = async () => {
3438
4472
  if (isSubmitting) return;
3439
4473
  try {
@@ -3453,10 +4487,10 @@ function UsernameModal({
3453
4487
  setIsSubmitting(false);
3454
4488
  }
3455
4489
  };
3456
- const intl = useIntl8();
4490
+ const intl = useIntl9();
3457
4491
  return /* @__PURE__ */ jsx20(ModalWithHeader, { isOpen: isOpen && isLogin, ...props, title: title || intl.formatMessage({
3458
4492
  id: username ? "editUsernameTitle" : "setUsernameTitle"
3459
- }), children: /* @__PURE__ */ jsxs15("div", { className: "matchid-username-box", children: [
4493
+ }), children: /* @__PURE__ */ jsxs14("div", { className: "matchid-username-box", children: [
3460
4494
  /* @__PURE__ */ jsx20(Field, { label: intl.formatMessage({
3461
4495
  id: "username"
3462
4496
  }), error, children: /* @__PURE__ */ jsx20(
@@ -3472,7 +4506,7 @@ function UsernameModal({
3472
4506
  value: val
3473
4507
  }
3474
4508
  ) }),
3475
- /* @__PURE__ */ jsxs15("div", { className: "matchid-valid", children: [
4509
+ /* @__PURE__ */ jsxs14("div", { className: "matchid-valid", children: [
3476
4510
  /* @__PURE__ */ jsx20(
3477
4511
  ValidItem,
3478
4512
  {
@@ -3488,15 +4522,15 @@ function UsernameModal({
3488
4522
  ] }),
3489
4523
  /* @__PURE__ */ jsx20(Button, { disabled: !isSafe, loading: isSubmitting, style: {
3490
4524
  marginTop: isDownMd ? "36px" : "64px"
3491
- }, onClick: onSubmit, size: "lg", block: true, highlight: true, children: /* @__PURE__ */ jsx20(FormattedMessage8, { id: "confirm" }) }),
4525
+ }, onClick: onSubmit, size: "lg", block: true, highlight: true, children: /* @__PURE__ */ jsx20(FormattedMessage9, { id: "confirm" }) }),
3492
4526
  /* @__PURE__ */ jsx20(Button, { style: {
3493
4527
  marginTop: isDownMd ? "12px" : "24px"
3494
- }, onClick: props.onClose, size: "lg", block: true, children: /* @__PURE__ */ jsx20(FormattedMessage8, { id: "cancel" }) })
4528
+ }, onClick: props.onClose, size: "lg", block: true, children: /* @__PURE__ */ jsx20(FormattedMessage9, { id: "cancel" }) })
3495
4529
  ] }) });
3496
4530
  }
3497
4531
 
3498
4532
  // src/components/SOLModal/index.tsx
3499
- import React7, { useEffect as useEffect15, useState as useState17 } from "react";
4533
+ import React7, { useEffect as useEffect16, useState as useState18 } from "react";
3500
4534
  import { clusterApiUrl } from "@solana/web3.js";
3501
4535
  import { useWallet as useWallet2, WalletProvider, ConnectionProvider } from "@solana/wallet-adapter-react";
3502
4536
  import { WalletModalProvider, useWalletModal } from "@solana/wallet-adapter-react-ui";
@@ -3547,7 +4581,7 @@ import {
3547
4581
  XDEFIWalletAdapter
3548
4582
  } from "@solana/wallet-adapter-wallets";
3549
4583
  import "@solana/wallet-adapter-react-ui/styles.css";
3550
- import { useIntl as useIntl9 } from "react-intl";
4584
+ import { useIntl as useIntl10 } from "react-intl";
3551
4585
 
3552
4586
  // src/components/WalletModalContent/index.tsx
3553
4587
  import { useMemo as useMemo10 } from "react";
@@ -3560,7 +4594,7 @@ var walletConnectImage = "
3560
4594
  var walletSigningImage = "";
3561
4595
 
3562
4596
  // src/components/WalletModalContent/index.tsx
3563
- import { jsx as jsx21, jsxs as jsxs16 } from "react/jsx-runtime";
4597
+ import { jsx as jsx21, jsxs as jsxs15 } from "react/jsx-runtime";
3564
4598
  function WalletModalContent({
3565
4599
  status,
3566
4600
  error,
@@ -3568,7 +4602,7 @@ function WalletModalContent({
3568
4602
  setError,
3569
4603
  setVisible,
3570
4604
  visible,
3571
- address: address2,
4605
+ address,
3572
4606
  connected
3573
4607
  }) {
3574
4608
  const pageData = useMemo10(() => {
@@ -3629,9 +4663,9 @@ function WalletModalContent({
3629
4663
  text: "Please Connect your wallet",
3630
4664
  statusImage: walletConnectImage
3631
4665
  };
3632
- }, [visible, connected, status, error, address2]);
3633
- return /* @__PURE__ */ jsx21("div", { className: "matchid-wallet-container", children: /* @__PURE__ */ jsxs16("div", { className: `matchid-wallet-box`, children: [
3634
- /* @__PURE__ */ jsxs16("div", { className: `matchid-wallet-content`, children: [
4666
+ }, [visible, connected, status, error, address]);
4667
+ return /* @__PURE__ */ jsx21("div", { className: "matchid-wallet-container", children: /* @__PURE__ */ jsxs15("div", { className: `matchid-wallet-box`, children: [
4668
+ /* @__PURE__ */ jsxs15("div", { className: `matchid-wallet-content`, children: [
3635
4669
  /* @__PURE__ */ jsx21("img", { src: pageData.statusImage }),
3636
4670
  /* @__PURE__ */ jsx21("div", { className: pageData.isError ? "text-[#F7585E]" : "", children: pageData.text })
3637
4671
  ] }),
@@ -3658,17 +4692,17 @@ function WalletContent({
3658
4692
  const { setVisible, visible } = useWalletModal();
3659
4693
  const wallet = useWallet2();
3660
4694
  const { events, login } = useMatch();
3661
- const [status, setStatus] = useState17("");
4695
+ const [status, setStatus] = useState18("");
3662
4696
  const statusRef = React7.useRef(status);
3663
- const [error, setError] = useState17("");
3664
- useEffect15(() => {
4697
+ const [error, setError] = useState18("");
4698
+ useEffect16(() => {
3665
4699
  const init = async () => {
3666
4700
  await wallet.disconnect();
3667
4701
  setVisible(true);
3668
4702
  };
3669
4703
  init();
3670
4704
  }, []);
3671
- useEffect15(() => {
4705
+ useEffect16(() => {
3672
4706
  if (wallet.connected) {
3673
4707
  console.log("wallet.connected", wallet.connected);
3674
4708
  toLoginInWallet();
@@ -3676,14 +4710,14 @@ function WalletContent({
3676
4710
  }, [wallet.connected]);
3677
4711
  const toLoginInWallet = async () => {
3678
4712
  if (statusRef.current) return;
3679
- const address2 = wallet.publicKey?.toBase58() || "";
4713
+ const address = wallet.publicKey?.toBase58() || "";
3680
4714
  try {
3681
4715
  setStatus("nonce");
3682
4716
  statusRef.current = "nonce";
3683
4717
  const res = type == "bind" ? await getWalletInitApi({
3684
- address: address2,
4718
+ address,
3685
4719
  type: "SOL"
3686
- }) : await getWalletNonceApi({ address: address2, type: "SOL" });
4720
+ }) : await getWalletNonceApi({ address, type: "SOL" });
3687
4721
  if (!isSuccess(res)) {
3688
4722
  throw new Error(res.message);
3689
4723
  }
@@ -3696,7 +4730,7 @@ function WalletContent({
3696
4730
  const signedMessage = await wallet.signMessage(encodedMessage);
3697
4731
  let obj = {
3698
4732
  type: "SOL",
3699
- address: address2,
4733
+ address,
3700
4734
  signature: Buffer.from(signedMessage).toString("base64"),
3701
4735
  message,
3702
4736
  connector_type: "SOL",
@@ -3792,7 +4826,7 @@ function SOLConnectModal({
3792
4826
  onSuccess,
3793
4827
  ...props
3794
4828
  }) {
3795
- const intl = useIntl9();
4829
+ const intl = useIntl10();
3796
4830
  return /* @__PURE__ */ jsx22(ModalWithHeader, { ...props, title: props.title || intl.formatMessage({
3797
4831
  id: type == "bind" ? "bindWith" : "loginWith"
3798
4832
  }, {
@@ -3804,8 +4838,8 @@ function SOLModal(props) {
3804
4838
  }
3805
4839
 
3806
4840
  // src/components/TRONModal/index.tsx
3807
- import React8, { useEffect as useEffect17, useMemo as useMemo11, useState as useState19 } from "react";
3808
- import { useIntl as useIntl10 } from "react-intl";
4841
+ import React8, { useEffect as useEffect18, useMemo as useMemo11, useState as useState20 } from "react";
4842
+ import { useIntl as useIntl11 } from "react-intl";
3809
4843
 
3810
4844
  // src/lib/tron/TronLinkAdapter.ts
3811
4845
  var TronLinkAdapter = class {
@@ -3838,7 +4872,7 @@ var TronLinkAdapter = class {
3838
4872
  };
3839
4873
 
3840
4874
  // src/hooks/useTRONWallet.ts
3841
- import { useEffect as useEffect16, useState as useState18 } from "react";
4875
+ import { useEffect as useEffect17, useState as useState19 } from "react";
3842
4876
 
3843
4877
  // src/lib/tron/BitgetAdapter.ts
3844
4878
  var BitgetAdapter = class {
@@ -3883,9 +4917,9 @@ var OKXAdapter = class {
3883
4917
  // src/hooks/useTRONWallet.ts
3884
4918
  var useTRONWallet = () => {
3885
4919
  const wallets2 = [new TronLinkAdapter(), new BitgetAdapter(), new OKXAdapter()];
3886
- const [installedWallets, setInstalledWallets] = useState18([]);
3887
- const [address2, setAddress] = useState18(null);
3888
- useEffect16(() => {
4920
+ const [installedWallets, setInstalledWallets] = useState19([]);
4921
+ const [address, setAddress] = useState19(null);
4922
+ useEffect17(() => {
3889
4923
  const getInstalled = async () => {
3890
4924
  const installed = await Promise.all(wallets2.map((wallet2) => wallet2.isInstalled().then((isInstalled) => ({
3891
4925
  wallet: wallet2,
@@ -3895,11 +4929,11 @@ var useTRONWallet = () => {
3895
4929
  };
3896
4930
  getInstalled();
3897
4931
  }, []);
3898
- const [wallet, chooseWallet] = useState18(null);
4932
+ const [wallet, chooseWallet] = useState19(null);
3899
4933
  const onConnect = async () => {
3900
4934
  setAddress(await wallet.connect());
3901
4935
  };
3902
- useEffect16(() => {
4936
+ useEffect17(() => {
3903
4937
  if (!wallet) {
3904
4938
  setAddress(null);
3905
4939
  }
@@ -3909,33 +4943,33 @@ var useTRONWallet = () => {
3909
4943
  wallets: wallets2,
3910
4944
  chooseWallet,
3911
4945
  wallet,
3912
- address: address2,
4946
+ address,
3913
4947
  onConnect
3914
4948
  };
3915
4949
  };
3916
4950
 
3917
4951
  // src/components/TRONModal/index.tsx
3918
- import { jsx as jsx23, jsxs as jsxs17 } from "react/jsx-runtime";
4952
+ import { jsx as jsx23, jsxs as jsxs16 } from "react/jsx-runtime";
3919
4953
  function TRONConnectModal({
3920
4954
  type = "login",
3921
4955
  onSuccess,
3922
4956
  ...props
3923
4957
  }) {
3924
4958
  const isDownMd = useDownMd();
3925
- const intl = useIntl10();
3926
- const { wallets: wallets2, installedWallets, chooseWallet, wallet, address: address2, onConnect } = useTRONWallet();
4959
+ const intl = useIntl11();
4960
+ const { wallets: wallets2, installedWallets, chooseWallet, wallet, address, onConnect } = useTRONWallet();
3927
4961
  const iconMaps = {
3928
4962
  tronlink: /* @__PURE__ */ jsx23(TronLinkIcon, { size: isDownMd ? 36 : 40 }),
3929
4963
  bitget: /* @__PURE__ */ jsx23(BitgetIcon, { size: isDownMd ? 36 : 40 }),
3930
4964
  okx: /* @__PURE__ */ jsx23(OKXIcon, { size: isDownMd ? 36 : 40 })
3931
4965
  };
3932
4966
  const { events, login } = useMatch();
3933
- const [status, setStatus] = useState19("");
4967
+ const [status, setStatus] = useState20("");
3934
4968
  const statusRef = React8.useRef(status);
3935
- const [error, setError] = useState19("");
4969
+ const [error, setError] = useState20("");
3936
4970
  const connected = useMemo11(() => {
3937
- return !!address2;
3938
- }, [address2]);
4971
+ return !!address;
4972
+ }, [address]);
3939
4973
  const disconnect = async () => {
3940
4974
  setStatus("");
3941
4975
  chooseWallet(null);
@@ -3949,11 +4983,11 @@ function TRONConnectModal({
3949
4983
  setError("");
3950
4984
  };
3951
4985
  const toLoginInWallet = async () => {
3952
- if (statusRef.current || !address2 || !wallet) return;
4986
+ if (statusRef.current || !address || !wallet) return;
3953
4987
  try {
3954
4988
  setStatus("nonce");
3955
4989
  statusRef.current = "nonce";
3956
- const res = type == "bind" ? await getWalletInitApi({ address: address2, type: "TRON" }) : await getWalletNonceApi({ address: address2, type: "TRON" });
4990
+ const res = type == "bind" ? await getWalletInitApi({ address, type: "TRON" }) : await getWalletNonceApi({ address, type: "TRON" });
3957
4991
  if (!isSuccess(res)) {
3958
4992
  throw new Error(res.message);
3959
4993
  }
@@ -3965,7 +4999,7 @@ function TRONConnectModal({
3965
4999
  const signedMessage = await wallet.signMessage(message);
3966
5000
  let obj = {
3967
5001
  type: "TRON",
3968
- address: address2,
5002
+ address,
3969
5003
  signature: signedMessage,
3970
5004
  message,
3971
5005
  connector_type: "TRON",
@@ -4001,7 +5035,7 @@ function TRONConnectModal({
4001
5035
  statusRef.current = "";
4002
5036
  }
4003
5037
  };
4004
- useEffect17(() => {
5038
+ useEffect18(() => {
4005
5039
  if (wallet) {
4006
5040
  console.log("onConnect");
4007
5041
  onConnect();
@@ -4009,12 +5043,12 @@ function TRONConnectModal({
4009
5043
  setStatus("");
4010
5044
  }
4011
5045
  }, [wallet]);
4012
- useEffect17(() => {
4013
- if (address2) {
5046
+ useEffect18(() => {
5047
+ if (address) {
4014
5048
  toLoginInWallet();
4015
5049
  }
4016
- }, [address2]);
4017
- useEffect17(() => {
5050
+ }, [address]);
5051
+ useEffect18(() => {
4018
5052
  if (!props.isOpen) {
4019
5053
  disconnect();
4020
5054
  }
@@ -4030,13 +5064,13 @@ function TRONConnectModal({
4030
5064
  setError,
4031
5065
  status,
4032
5066
  disconnect,
4033
- address: address2 || "",
5067
+ address: address || "",
4034
5068
  connected,
4035
5069
  visible: true,
4036
5070
  setVisible: () => {
4037
5071
  }
4038
5072
  }
4039
- ) : /* @__PURE__ */ jsx23("div", { className: "matchid-login-box", children: /* @__PURE__ */ jsxs17("div", { className: "matchid-login-recommend-list", children: [
5073
+ ) : /* @__PURE__ */ jsx23("div", { className: "matchid-login-box", children: /* @__PURE__ */ jsxs16("div", { className: "matchid-login-recommend-list", children: [
4040
5074
  installedWallets.map((wallet2) => {
4041
5075
  return /* @__PURE__ */ jsx23(
4042
5076
  RecommendItem,
@@ -4072,8 +5106,8 @@ function TRONModal(props) {
4072
5106
  }
4073
5107
 
4074
5108
  // src/components/TONModal/index.tsx
4075
- import React9, { useEffect as useEffect18, useState as useState20 } from "react";
4076
- import { useIntl as useIntl11 } from "react-intl";
5109
+ import React9, { useEffect as useEffect19, useState as useState21 } from "react";
5110
+ import { useIntl as useIntl12 } from "react-intl";
4077
5111
  import {
4078
5112
  TonConnectUIProvider,
4079
5113
  useTonAddress,
@@ -4087,15 +5121,15 @@ function WalletContent2({
4087
5121
  type
4088
5122
  }) {
4089
5123
  const { events, login } = useMatch();
4090
- const [connected, setConnected] = useState20(false);
5124
+ const [connected, setConnected] = useState21(false);
4091
5125
  const wallet = useTonWallet();
4092
5126
  const userFriendlyAddress = useTonAddress();
4093
5127
  const [tonConnectUI] = useTonConnectUI();
4094
5128
  const { state, open, close } = useTonConnectModal();
4095
- const [status, setStatus] = useState20("");
5129
+ const [status, setStatus] = useState21("");
4096
5130
  const statusRef = React9.useRef(status);
4097
- const [error, setError] = useState20("");
4098
- useEffect18(() => {
5131
+ const [error, setError] = useState21("");
5132
+ useEffect19(() => {
4099
5133
  const init = async () => {
4100
5134
  if (wallet) {
4101
5135
  await tonConnectUI.disconnect();
@@ -4168,7 +5202,7 @@ function WalletContent2({
4168
5202
  }
4169
5203
  });
4170
5204
  }, []);
4171
- useEffect18(() => {
5205
+ useEffect19(() => {
4172
5206
  if (wallet) {
4173
5207
  setConnected(true);
4174
5208
  console.log("Wallet connected:", wallet);
@@ -4179,7 +5213,7 @@ function WalletContent2({
4179
5213
  setStatus("");
4180
5214
  }
4181
5215
  }, [wallet]);
4182
- useEffect18(() => {
5216
+ useEffect19(() => {
4183
5217
  console.log({
4184
5218
  state,
4185
5219
  wallet
@@ -4239,7 +5273,7 @@ function TONConnectModal({
4239
5273
  onSuccess,
4240
5274
  ...props
4241
5275
  }) {
4242
- const intl = useIntl11();
5276
+ const intl = useIntl12();
4243
5277
  const { endpoints, appid } = useLocalStore_default();
4244
5278
  const manifestUrl = `${endpoints.back}api/v1/wallet/ton?appid=${appid}&url=` + encodeURIComponent(window.location.origin);
4245
5279
  return /* @__PURE__ */ jsx24(ModalWithHeader, { ...props, title: props.title || intl.formatMessage({
@@ -4259,8 +5293,8 @@ function TONModal(props) {
4259
5293
  }
4260
5294
 
4261
5295
  // src/components/BTCModal/index.tsx
4262
- import React10, { useEffect as useEffect20, useMemo as useMemo12, useState as useState22 } from "react";
4263
- import { useIntl as useIntl12 } from "react-intl";
5296
+ import React10, { useEffect as useEffect21, useMemo as useMemo12, useState as useState23 } from "react";
5297
+ import { useIntl as useIntl13 } from "react-intl";
4264
5298
 
4265
5299
  // src/lib/btc/UnisatAdapter.ts
4266
5300
  var UnisatAdapter = class {
@@ -4351,7 +5385,7 @@ var XverseAdapter = class {
4351
5385
  matchlog_default.log("getAccounts ~ response:", response);
4352
5386
  if (response.status === "success") {
4353
5387
  const ordinalsAddressItem = response.result.find(
4354
- (address2) => address2.purpose === AddressPurpose.Ordinals
5388
+ (address) => address.purpose === AddressPurpose.Ordinals
4355
5389
  );
4356
5390
  this.address = ordinalsAddressItem?.address || "";
4357
5391
  return ordinalsAddressItem?.address || "";
@@ -4414,12 +5448,12 @@ var LeatherAdapter = class {
4414
5448
  };
4415
5449
 
4416
5450
  // src/hooks/useBTCWallet.ts
4417
- import { useEffect as useEffect19, useState as useState21 } from "react";
5451
+ import { useEffect as useEffect20, useState as useState22 } from "react";
4418
5452
  var useBTCWallet = () => {
4419
5453
  const wallets2 = [new UnisatAdapter(), new XverseAdapter(), new LeatherAdapter()];
4420
- const [installedWallets, setInstalledWallets] = useState21([]);
4421
- const [address2, setAddress] = useState21(null);
4422
- useEffect19(() => {
5454
+ const [installedWallets, setInstalledWallets] = useState22([]);
5455
+ const [address, setAddress] = useState22(null);
5456
+ useEffect20(() => {
4423
5457
  const getInstalled = async () => {
4424
5458
  const installed = await Promise.all(wallets2.map((wallet2) => wallet2.isInstalled().then((isInstalled) => ({
4425
5459
  wallet: wallet2,
@@ -4429,11 +5463,11 @@ var useBTCWallet = () => {
4429
5463
  };
4430
5464
  getInstalled();
4431
5465
  }, []);
4432
- const [wallet, chooseWallet] = useState21(null);
5466
+ const [wallet, chooseWallet] = useState22(null);
4433
5467
  const onConnect = async () => {
4434
5468
  setAddress(await wallet.connect());
4435
5469
  };
4436
- useEffect19(() => {
5470
+ useEffect20(() => {
4437
5471
  if (!wallet) {
4438
5472
  setAddress(null);
4439
5473
  }
@@ -4443,33 +5477,33 @@ var useBTCWallet = () => {
4443
5477
  wallets: wallets2,
4444
5478
  chooseWallet,
4445
5479
  wallet,
4446
- address: address2,
5480
+ address,
4447
5481
  onConnect
4448
5482
  };
4449
5483
  };
4450
5484
 
4451
5485
  // src/components/BTCModal/index.tsx
4452
- import { jsx as jsx25, jsxs as jsxs18 } from "react/jsx-runtime";
5486
+ import { jsx as jsx25, jsxs as jsxs17 } from "react/jsx-runtime";
4453
5487
  function BTCConnectModal({
4454
5488
  type = "login",
4455
5489
  onSuccess,
4456
5490
  ...props
4457
5491
  }) {
4458
5492
  const isDownMd = useDownMd();
4459
- const intl = useIntl12();
4460
- const { wallets: wallets2, installedWallets, chooseWallet, wallet, address: address2, onConnect } = useBTCWallet();
5493
+ const intl = useIntl13();
5494
+ const { wallets: wallets2, installedWallets, chooseWallet, wallet, address, onConnect } = useBTCWallet();
4461
5495
  const iconMaps = {
4462
5496
  leather: /* @__PURE__ */ jsx25(LeatherIcon, { size: isDownMd ? 36 : 40 }),
4463
5497
  unisat: /* @__PURE__ */ jsx25(UnisatIcon, { size: isDownMd ? 36 : 40 }),
4464
5498
  xverse: /* @__PURE__ */ jsx25(XverseIcon, { size: isDownMd ? 36 : 40 })
4465
5499
  };
4466
5500
  const { events, login } = useMatch();
4467
- const [status, setStatus] = useState22("");
5501
+ const [status, setStatus] = useState23("");
4468
5502
  const statusRef = React10.useRef(status);
4469
- const [error, setError] = useState22("");
5503
+ const [error, setError] = useState23("");
4470
5504
  const connected = useMemo12(() => {
4471
- return !!address2;
4472
- }, [address2]);
5505
+ return !!address;
5506
+ }, [address]);
4473
5507
  const disconnect = async () => {
4474
5508
  wallet && wallet.disconnet && wallet.disconnet();
4475
5509
  setStatus("");
@@ -4478,11 +5512,11 @@ function BTCConnectModal({
4478
5512
  setError("");
4479
5513
  };
4480
5514
  const toLoginInWallet = async () => {
4481
- if (statusRef.current || !address2 || !wallet) return;
5515
+ if (statusRef.current || !address || !wallet) return;
4482
5516
  try {
4483
5517
  setStatus("nonce");
4484
5518
  statusRef.current = "nonce";
4485
- const res = type == "bind" ? await getWalletInitApi({ address: address2, type: "BTC" }) : await getWalletNonceApi({ address: address2, type: "BTC" });
5519
+ const res = type == "bind" ? await getWalletInitApi({ address, type: "BTC" }) : await getWalletNonceApi({ address, type: "BTC" });
4486
5520
  if (!isSuccess(res)) {
4487
5521
  throw new Error(res.message);
4488
5522
  }
@@ -4494,7 +5528,7 @@ function BTCConnectModal({
4494
5528
  const signedMessage = await wallet.signMessage(message);
4495
5529
  let obj = {
4496
5530
  type: "BTC",
4497
- address: address2,
5531
+ address,
4498
5532
  signature: signedMessage,
4499
5533
  message,
4500
5534
  connector_type: "BTC",
@@ -4531,7 +5565,7 @@ function BTCConnectModal({
4531
5565
  statusRef.current = "";
4532
5566
  }
4533
5567
  };
4534
- useEffect20(() => {
5568
+ useEffect21(() => {
4535
5569
  if (wallet) {
4536
5570
  console.log("onConnect");
4537
5571
  try {
@@ -4544,12 +5578,12 @@ function BTCConnectModal({
4544
5578
  setStatus("");
4545
5579
  }
4546
5580
  }, [wallet]);
4547
- useEffect20(() => {
4548
- if (address2) {
5581
+ useEffect21(() => {
5582
+ if (address) {
4549
5583
  toLoginInWallet();
4550
5584
  }
4551
- }, [address2]);
4552
- useEffect20(() => {
5585
+ }, [address]);
5586
+ useEffect21(() => {
4553
5587
  if (!props.isOpen) {
4554
5588
  disconnect();
4555
5589
  }
@@ -4572,13 +5606,13 @@ function BTCConnectModal({
4572
5606
  setError,
4573
5607
  status,
4574
5608
  disconnect,
4575
- address: address2 || "",
5609
+ address: address || "",
4576
5610
  connected,
4577
5611
  visible: true,
4578
5612
  setVisible: () => {
4579
5613
  }
4580
5614
  }
4581
- ) : /* @__PURE__ */ jsx25("div", { className: "matchid-login-box", children: /* @__PURE__ */ jsxs18("div", { className: "matchid-login-recommend-list", children: [
5615
+ ) : /* @__PURE__ */ jsx25("div", { className: "matchid-login-box", children: /* @__PURE__ */ jsxs17("div", { className: "matchid-login-recommend-list", children: [
4582
5616
  installedWallets.map((wallet2) => {
4583
5617
  return /* @__PURE__ */ jsx25(
4584
5618
  RecommendItem,
@@ -4615,14 +5649,14 @@ function BTCModal(props) {
4615
5649
 
4616
5650
  // src/components/WalletModal/index.tsx
4617
5651
  import { useMemo as useMemo13 } from "react";
4618
- import { useIntl as useIntl13 } from "react-intl";
5652
+ import { useIntl as useIntl14 } from "react-intl";
4619
5653
  import { jsx as jsx26 } from "react/jsx-runtime";
4620
5654
  function WalletConnectModal({
4621
5655
  type,
4622
5656
  methods: _methods,
4623
5657
  ...props
4624
5658
  }) {
4625
- const intl = useIntl13();
5659
+ const intl = useIntl14();
4626
5660
  const { walletMap } = useWalletConfig();
4627
5661
  const { bind, login } = useUserInfo();
4628
5662
  const config = useAppConfig();
@@ -4657,6 +5691,607 @@ function WalletModal(props) {
4657
5691
  return props.isOpen && /* @__PURE__ */ jsx26(WalletConnectModal, { ...props });
4658
5692
  }
4659
5693
 
5694
+ // src/components/AlphaAvatar/index.tsx
5695
+ import { useEffect as useEffect22, useState as useState24 } from "react";
5696
+ import { jsx as jsx27 } from "react/jsx-runtime";
5697
+ function AlphaAvatar2({ name, size = 40, className = "" }) {
5698
+ const [avatar, setAvatar] = useState24(void 0);
5699
+ useEffect22(() => {
5700
+ if (name) {
5701
+ const char = name[0].toUpperCase();
5702
+ setAvatar(char);
5703
+ }
5704
+ }, [name]);
5705
+ return /* @__PURE__ */ jsx27("div", { className: `matchid-alpha-avatar ${className}`, style: {
5706
+ width: size,
5707
+ height: size,
5708
+ fontSize: Math.ceil(size / 2)
5709
+ }, children: avatar });
5710
+ }
5711
+
5712
+ // src/components/WalletAsset/index.tsx
5713
+ import { jsx as jsx28, jsxs as jsxs18 } from "react/jsx-runtime";
5714
+ function WalletAsset({
5715
+ onAssetClick,
5716
+ matchWalletAssetsOptions
5717
+ }) {
5718
+ const walletAssets = useMatchWalletAssets(matchWalletAssetsOptions);
5719
+ const matchWalletAssetList = useMatchWalletAssetList({
5720
+ list: walletAssets.mergedAssets
5721
+ });
5722
+ const { list } = useMatchChain();
5723
+ return /* @__PURE__ */ jsx28("div", { className: "matchid-wallet-asset-list", children: matchWalletAssetList.list.map((n, index) => {
5724
+ const clickFunc = onAssetClick && onAssetClick(n);
5725
+ const chain = list?.find((m) => m.id.toString() === n.chain_id);
5726
+ const getFooterColor = () => {
5727
+ if (!n.price_change_24h) {
5728
+ return "";
5729
+ }
5730
+ if (n.price_change_24h > 0) {
5731
+ return "matchid-wallet-asset-up";
5732
+ }
5733
+ if (n.price_change_24h < 0) {
5734
+ return "matchid-wallet-asset-down";
5735
+ }
5736
+ return "";
5737
+ };
5738
+ return /* @__PURE__ */ jsxs18("div", { className: `matchid-wallet-asset-item`, onClick: clickFunc, style: {
5739
+ cursor: clickFunc ? "pointer" : "default"
5740
+ }, children: [
5741
+ /* @__PURE__ */ jsxs18("div", { className: "matchid-wallet-asset-logo", title: n.symbol || n.name || "", children: [
5742
+ n.icon ? /* @__PURE__ */ jsx28("img", { src: n.icon, alt: n.symbol, className: `matchid-wallet-asset-icon` }) : /* @__PURE__ */ jsx28(
5743
+ AlphaAvatar2,
5744
+ {
5745
+ className: `matchid-wallet-asset-icon`,
5746
+ size: 40,
5747
+ name: n.symbol || n.name || ""
5748
+ }
5749
+ ),
5750
+ chain?.iconUrl && /* @__PURE__ */ jsx28("img", { src: chain.iconUrl, alt: chain.name, className: `matchid-wallet-asset-chain` })
5751
+ ] }),
5752
+ /* @__PURE__ */ jsxs18("div", { className: `matchid-wallet-asset-info`, children: [
5753
+ /* @__PURE__ */ jsx28("div", { className: `matchid-wallet-asset-name`, children: n.symbol }),
5754
+ "price" in n && /* @__PURE__ */ jsxs18("div", { className: `matchid-wallet-asset-content`, children: [
5755
+ /* @__PURE__ */ jsx28("div", { className: "matchid-wallet-asset-price", children: /* @__PURE__ */ jsx28(
5756
+ NumberFormatter,
5757
+ {
5758
+ value: n.price,
5759
+ prefix: "$ ",
5760
+ tFixNum: 2
5761
+ }
5762
+ ) }),
5763
+ /* @__PURE__ */ jsx28("div", { className: "matchid-wallet-asset-value", children: /* @__PURE__ */ jsx28(
5764
+ NumberFormatter,
5765
+ {
5766
+ value: n.value,
5767
+ prefix: "$ ",
5768
+ tFixNum: 2
5769
+ }
5770
+ ) })
5771
+ ] }),
5772
+ /* @__PURE__ */ jsxs18("div", { className: `matchid-wallet-asset-footer`, children: [
5773
+ /* @__PURE__ */ jsx28("div", { className: `matchid-wallet-asset-balance`, children: /* @__PURE__ */ jsx28(
5774
+ NumberFormatter,
5775
+ {
5776
+ value: n.balance,
5777
+ tFixNum: 3
5778
+ }
5779
+ ) }),
5780
+ "price_change_24h" in n && /* @__PURE__ */ jsx28("div", { className: `matchid-wallet-asset-change ${getFooterColor()}`, children: /* @__PURE__ */ jsx28(
5781
+ NumberFormatter,
5782
+ {
5783
+ prefix: `${(n?.price_change_24h || 0) < 0 ? "-" : "+"} `,
5784
+ value: Math.abs(n.price_change_24h || 0),
5785
+ suffix: "%",
5786
+ tFixNum: 3
5787
+ }
5788
+ ) })
5789
+ ] })
5790
+ ] })
5791
+ ] }, index);
5792
+ }) });
5793
+ }
5794
+
5795
+ // src/components/TokenSend/index.tsx
5796
+ import { useEffect as useEffect23, useMemo as useMemo14, useState as useState25 } from "react";
5797
+ import { defineChain as defineChain3, encodeFunctionData as encodeFunctionData2, http as http5, parseUnits as parseUnits2 } from "viem";
5798
+ import { FormattedMessage as FormattedMessage10, useIntl as useIntl15 } from "react-intl";
5799
+ import { jsx as jsx29, jsxs as jsxs19 } from "react/jsx-runtime";
5800
+ function Input2({
5801
+ onChange,
5802
+ placeholder,
5803
+ value,
5804
+ maxLength,
5805
+ type,
5806
+ error,
5807
+ size = "df"
5808
+ }) {
5809
+ return /* @__PURE__ */ jsxs19("div", { className: `matchid-token-input-box ${"matchid-token-input-" + size}`, children: [
5810
+ /* @__PURE__ */ jsx29(
5811
+ "input",
5812
+ {
5813
+ placeholder,
5814
+ onChange,
5815
+ maxLength,
5816
+ type,
5817
+ value,
5818
+ className: `matchid-token-input ${error ? "matchid-token-input-error" : ""}`
5819
+ }
5820
+ ),
5821
+ error && /* @__PURE__ */ jsx29("div", { className: "matchid-token-input-error-text", children: error })
5822
+ ] });
5823
+ }
5824
+ function TokenSend({
5825
+ onClose,
5826
+ zIndex,
5827
+ token,
5828
+ onBack
5829
+ }) {
5830
+ const { list: chainList } = useMatchChain();
5831
+ const intl = useIntl15();
5832
+ const { createWalletClient: createWalletClient2 } = useWallet();
5833
+ const isNative = token.address.toLowerCase() == NATIVE_TOKEN_ADDRESS;
5834
+ const chain = useMemo14(() => {
5835
+ return chainList?.find((m) => m.id.toString() === token.chain_id);
5836
+ }, [chainList, token.chain_id]);
5837
+ const walletClient = useMemo14(() => {
5838
+ return createWalletClient2({
5839
+ // @ts-ignore
5840
+ chain: defineChain3(chain),
5841
+ transport: http5()
5842
+ });
5843
+ }, [chain]);
5844
+ const [amount, setAmount] = useState25("");
5845
+ const [address, setAddress] = useState25("");
5846
+ const [loading, setLoading] = useState25(false);
5847
+ const [sending, setSending] = useState25(false);
5848
+ const [txError, setTxError] = useState25("");
5849
+ const transaction = useMemo14(() => {
5850
+ if (!amount || !address) {
5851
+ return;
5852
+ }
5853
+ const abi = [
5854
+ {
5855
+ "constant": false,
5856
+ "inputs": [
5857
+ {
5858
+ "name": "_to",
5859
+ "type": "address"
5860
+ },
5861
+ {
5862
+ "name": "_value",
5863
+ "type": "uint256"
5864
+ }
5865
+ ],
5866
+ "name": "transfer",
5867
+ "outputs": [
5868
+ {
5869
+ "name": "",
5870
+ "type": "bool"
5871
+ }
5872
+ ],
5873
+ "payable": false,
5874
+ "stateMutability": "nonpayable",
5875
+ "type": "function"
5876
+ }
5877
+ ];
5878
+ const viemChain = defineChain3(chain);
5879
+ const to = isNative ? address : token.address;
5880
+ const value = isNative ? parseUnits2(amount, parseInt(token?.decimals || "18")) : BigInt(0);
5881
+ const data = isNative ? "0x" : encodeFunctionData2({
5882
+ abi,
5883
+ functionName: "transfer",
5884
+ args: [address, parseUnits2(amount, parseInt(token?.decimals || "18"))]
5885
+ });
5886
+ return {
5887
+ to,
5888
+ value,
5889
+ data,
5890
+ chain: viemChain
5891
+ };
5892
+ }, [amount, address]);
5893
+ const onCal = async () => {
5894
+ try {
5895
+ setLoading(true);
5896
+ await walletClient?.prepareTransactionRequest(transaction);
5897
+ } catch (error2) {
5898
+ console.error(error2);
5899
+ setTxError(error2.details || error2.message);
5900
+ } finally {
5901
+ setLoading(false);
5902
+ }
5903
+ };
5904
+ const error = useMemo14(() => {
5905
+ setTxError("");
5906
+ let amountError = "";
5907
+ let addressError = "";
5908
+ if (amount) {
5909
+ if (parseFloat(amount) <= 0) {
5910
+ amountError = intl.formatMessage({
5911
+ id: "tokenAmountMin"
5912
+ });
5913
+ } else if ("balance" in token && parseFloat(amount) > (token.balance || 0)) {
5914
+ amountError = intl.formatMessage({
5915
+ id: "tokenAmountMax"
5916
+ });
5917
+ }
5918
+ }
5919
+ if (address) {
5920
+ if (address.length < 42) {
5921
+ addressError = intl.formatMessage({
5922
+ id: "tokenAddressError"
5923
+ });
5924
+ } else {
5925
+ const reg = /^0x[a-fA-F0-9]{40}$/;
5926
+ if (!reg.test(address)) {
5927
+ addressError = intl.formatMessage({
5928
+ id: "tokenAddressError"
5929
+ });
5930
+ }
5931
+ }
5932
+ }
5933
+ if (amount && address && !amountError && !addressError && walletClient) {
5934
+ onCal();
5935
+ }
5936
+ return {
5937
+ amount: amountError,
5938
+ address: addressError
5939
+ };
5940
+ }, [amount, token, chain, address, walletClient]);
5941
+ const onChangeAmount = (e) => {
5942
+ const value = e.target.value;
5943
+ if (value.match(/^\d*\.?\d*$/)) {
5944
+ setAmount(value);
5945
+ }
5946
+ };
5947
+ const canSend = useMemo14(() => {
5948
+ return !error.amount && !error.address && amount && address;
5949
+ }, [error]);
5950
+ const onNext = async () => {
5951
+ setSending(true);
5952
+ if (transaction) {
5953
+ await walletClient?.sendTransaction(transaction);
5954
+ }
5955
+ onClose();
5956
+ };
5957
+ useEffect23(() => {
5958
+ const receiveMessage = (event) => {
5959
+ if (event.data) {
5960
+ if (event.data.source == "match-wallet") {
5961
+ if (event.data.method == "sendTransaction" && event.data.messageId == "openIframe") {
5962
+ onBack();
5963
+ setSending(false);
5964
+ }
5965
+ }
5966
+ }
5967
+ };
5968
+ window.addEventListener("message", receiveMessage);
5969
+ return () => {
5970
+ window.removeEventListener("message", receiveMessage);
5971
+ };
5972
+ }, []);
5973
+ return /* @__PURE__ */ jsx29(ModalDrawer, { isOpen: true, onClose, zIndex, title: /* @__PURE__ */ jsx29(FormattedMessage10, { id: "send" }), onBack, children: /* @__PURE__ */ jsxs19("div", { className: `matchid-token-send-box`, children: [
5974
+ /* @__PURE__ */ jsxs19("div", { className: "matchid-token-send-content", children: [
5975
+ /* @__PURE__ */ jsxs19("div", { className: `matchid-token-amount-content`, children: [
5976
+ /* @__PURE__ */ jsxs19("div", { className: `matchid-token-amount-header`, children: [
5977
+ /* @__PURE__ */ jsx29("div", { className: `matchid-token-amount-title`, children: /* @__PURE__ */ jsx29(FormattedMessage10, { id: "amount" }) }),
5978
+ /* @__PURE__ */ jsxs19("div", { className: `matchid-token-amount-chain`, children: [
5979
+ token.icon ? /* @__PURE__ */ jsx29(
5980
+ "img",
5981
+ {
5982
+ src: token?.icon,
5983
+ alt: token?.symbol,
5984
+ className: `matchid-token-amount-chain-icon`
5985
+ }
5986
+ ) : /* @__PURE__ */ jsx29(AlphaAvatar, { name: token.symbol || token.name || "", size: 16 }),
5987
+ /* @__PURE__ */ jsx29("span", { children: token?.symbol })
5988
+ ] })
5989
+ ] }),
5990
+ /* @__PURE__ */ jsx29(
5991
+ Input2,
5992
+ {
5993
+ type: "text",
5994
+ onChange: onChangeAmount,
5995
+ placeholder: intl.formatMessage({
5996
+ id: "amountPlaceholder"
5997
+ }),
5998
+ value: amount,
5999
+ maxLength: 40,
6000
+ error: error.amount || txError
6001
+ }
6002
+ ),
6003
+ /* @__PURE__ */ jsxs19("div", { className: `matchid-token-amount-footer`, children: [
6004
+ /* @__PURE__ */ jsxs19("div", { className: `matchid-token-amount-title`, children: [
6005
+ /* @__PURE__ */ jsx29(FormattedMessage10, { id: "balance" }),
6006
+ ":"
6007
+ ] }),
6008
+ /* @__PURE__ */ jsx29("div", { className: `matchid-token-amount-value`, children: /* @__PURE__ */ jsx29(NumberFormatter, { value: token.balance, tFixNum: 10, suffix: " " + token.symbol }) })
6009
+ ] }),
6010
+ /* @__PURE__ */ jsx29(TransferIcon, { className: "matchid-token-amount-transfer" })
6011
+ ] }),
6012
+ /* @__PURE__ */ jsxs19("div", { className: `matchid-token-address-content`, children: [
6013
+ /* @__PURE__ */ jsx29("div", { className: `matchid-token-address-header`, children: /* @__PURE__ */ jsx29("div", { className: `matchid-token-address-title`, children: /* @__PURE__ */ jsx29(FormattedMessage10, { id: "receiveTitle" }) }) }),
6014
+ /* @__PURE__ */ jsx29(
6015
+ Input2,
6016
+ {
6017
+ type: "text",
6018
+ size: "sm",
6019
+ onChange: (e) => setAddress(e.target.value),
6020
+ placeholder: intl.formatMessage({
6021
+ id: "receivePlaceholder"
6022
+ }),
6023
+ value: address,
6024
+ maxLength: 42,
6025
+ error: error.address
6026
+ }
6027
+ )
6028
+ ] })
6029
+ ] }),
6030
+ /* @__PURE__ */ jsx29(
6031
+ Button,
6032
+ {
6033
+ size: "lg",
6034
+ block: true,
6035
+ highlight: true,
6036
+ disabled: !canSend || !!txError,
6037
+ onClick: onNext,
6038
+ loading: loading || sending,
6039
+ children: /* @__PURE__ */ jsx29(FormattedMessage10, { id: "next" })
6040
+ }
6041
+ )
6042
+ ] }) });
6043
+ }
6044
+
6045
+ // src/components/TokenDetail/index.tsx
6046
+ import { FormattedMessage as FormattedMessage11, useIntl as useIntl16 } from "react-intl";
6047
+ import { jsx as jsx30, jsxs as jsxs20 } from "react/jsx-runtime";
6048
+ function TokenDetail({
6049
+ onClose,
6050
+ token
6051
+ }) {
6052
+ const { list: chainList } = useMatchChain();
6053
+ const modal = useModal();
6054
+ const chain = chainList?.find((m) => m.id.toString() === token.chain_id);
6055
+ const onSend = () => {
6056
+ modal.show((props) => {
6057
+ return /* @__PURE__ */ jsx30(TokenSend, { onClose: () => {
6058
+ props.close();
6059
+ onClose();
6060
+ }, onBack: props.close, zIndex: props.zIndex, token });
6061
+ });
6062
+ };
6063
+ const intl = useIntl16();
6064
+ return /* @__PURE__ */ jsx30(ModalDrawer, { isOpen: true, title: intl.formatMessage({
6065
+ id: "tokenDetails"
6066
+ }), onClose, children: /* @__PURE__ */ jsxs20("div", { className: `matchid-token-detail`, children: [
6067
+ /* @__PURE__ */ jsxs20("div", { className: `matchid-token-main`, children: [
6068
+ /* @__PURE__ */ jsxs20("div", { className: `matchid-token-info`, children: [
6069
+ /* @__PURE__ */ jsxs20("div", { className: `matchid-token-logo`, children: [
6070
+ token.icon ? /* @__PURE__ */ jsx30("img", { src: token.icon, alt: token.symbol, className: `matchid-token-icon` }) : /* @__PURE__ */ jsx30(AlphaAvatar, { className: `matchid-token-icon`, size: 48, name: token.symbol || token.name || "" }),
6071
+ chain?.iconUrl && /* @__PURE__ */ jsx30("img", { src: chain.iconUrl, alt: chain.name, className: `matchid-token-chain` })
6072
+ ] }),
6073
+ /* @__PURE__ */ jsxs20("div", { className: `matchid-token-name`, children: [
6074
+ /* @__PURE__ */ jsx30(NumberFormatter, { value: token.balance, tFixNum: 10 }),
6075
+ " ",
6076
+ token.symbol
6077
+ ] })
6078
+ ] }),
6079
+ token.address.toLowerCase() != NATIVE_TOKEN_ADDRESS && /* @__PURE__ */ jsxs20("div", { className: `matchid-token-contract`, children: [
6080
+ /* @__PURE__ */ jsx30("div", { className: "matchid-token-contract-title", children: "Contract address" }),
6081
+ /* @__PURE__ */ jsx30("div", { className: "matchid-token-contract-address", children: token.address })
6082
+ ] })
6083
+ ] }),
6084
+ /* @__PURE__ */ jsx30(Button, { size: "lg", block: true, highlight: true, onClick: onSend, children: /* @__PURE__ */ jsx30(FormattedMessage11, { id: "send" }) })
6085
+ ] }) });
6086
+ }
6087
+
6088
+ // src/components/TokenSendList/index.tsx
6089
+ import { useState as useState26 } from "react";
6090
+ import { FormattedMessage as FormattedMessage12 } from "react-intl";
6091
+ import { jsx as jsx31, jsxs as jsxs21 } from "react/jsx-runtime";
6092
+ function TokenSendList({ close }) {
6093
+ const walletAssets = useMatchWalletAssets();
6094
+ const matchWalletAssetList = useMatchWalletAssetList({
6095
+ list: walletAssets.mergedAssets
6096
+ });
6097
+ const { list } = useMatchChain();
6098
+ const [checked, setChecked] = useState26();
6099
+ const modal = useModal();
6100
+ const onNext = () => {
6101
+ checked && modal.show((props) => {
6102
+ return /* @__PURE__ */ jsx31(TokenSend, { onClose: () => {
6103
+ props.close();
6104
+ close();
6105
+ }, onBack: props.close, zIndex: props.zIndex, token: checked });
6106
+ });
6107
+ };
6108
+ return /* @__PURE__ */ jsxs21("div", { className: "matchid-token-send-list-box", children: [
6109
+ /* @__PURE__ */ jsx31("div", { className: "matchid-token-send-list", children: matchWalletAssetList.list.map((n, index) => {
6110
+ const chain = list?.find((m) => m.id.toString() === n.chain_id);
6111
+ return /* @__PURE__ */ jsxs21(
6112
+ "div",
6113
+ {
6114
+ className: `matchid-token-send-item ${checked?.address == n.address ? "matchid-token-send-chekced" : ""}`,
6115
+ onClick: () => {
6116
+ setChecked(n);
6117
+ },
6118
+ children: [
6119
+ /* @__PURE__ */ jsx31(Radio, { checked: checked?.address == n.address }),
6120
+ /* @__PURE__ */ jsxs21("div", { className: "matchid-token-send-content", children: [
6121
+ /* @__PURE__ */ jsxs21("div", { className: "matchid-token-send-logo", children: [
6122
+ n.icon ? /* @__PURE__ */ jsx31("img", { src: n.icon, alt: n.symbol, className: `matchid-token-send-icon` }) : /* @__PURE__ */ jsx31(
6123
+ AlphaAvatar2,
6124
+ {
6125
+ className: `matchid-token-send-icon`,
6126
+ size: 40,
6127
+ name: n.symbol || n.name || ""
6128
+ }
6129
+ ),
6130
+ chain?.iconUrl && /* @__PURE__ */ jsx31(
6131
+ "img",
6132
+ {
6133
+ src: chain.iconUrl,
6134
+ alt: chain.name,
6135
+ className: `matchid-token-send-chain`
6136
+ }
6137
+ )
6138
+ ] }),
6139
+ /* @__PURE__ */ jsxs21("div", { className: `matchid-token-send-info`, children: [
6140
+ /* @__PURE__ */ jsx31("div", { className: `matchid-token-send-name`, children: n.symbol }),
6141
+ /* @__PURE__ */ jsx31("div", { className: `matchid-token-send-balance`, children: /* @__PURE__ */ jsx31(NumberFormatter, { value: n.balance, tFixNum: 3 }) })
6142
+ ] })
6143
+ ] })
6144
+ ]
6145
+ },
6146
+ index
6147
+ );
6148
+ }) }),
6149
+ /* @__PURE__ */ jsx31(Button, { size: "lg", highlight: true, block: true, disabled: !checked, onClick: onNext, children: /* @__PURE__ */ jsx31(FormattedMessage12, { id: "next" }) })
6150
+ ] });
6151
+ }
6152
+
6153
+ // src/components/TransactionList/index.tsx
6154
+ import InfiniteScroll from "react-infinite-scroll-component";
6155
+ import { useEffect as useEffect24, useMemo as useMemo15, useState as useState27 } from "react";
6156
+ import { decodeFunctionData, defineChain as defineChain4, formatUnits as formatUnits3 } from "viem";
6157
+ import { erc20Abi as erc20Abi2 } from "viem";
6158
+ import { jsx as jsx32, jsxs as jsxs22 } from "react/jsx-runtime";
6159
+ var Item = ({ data }) => {
6160
+ const { address } = useWallet();
6161
+ const isOut = data.from == address;
6162
+ const { chain, chainId, explorerLink, formatUnits: chainFormatUnits } = useMatchChain();
6163
+ const { getContract } = useContractStore_default();
6164
+ const [shouldRefetch, setShouldRefetch] = useState27(true);
6165
+ const transferType = useMemo15(() => {
6166
+ const methodId = data.input.substring(2, 10);
6167
+ if (methodId == "095ea7b3") {
6168
+ return "erc20_approve";
6169
+ }
6170
+ if (methodId == "a9059cbb") {
6171
+ return "erc20_transfer";
6172
+ }
6173
+ return "unknown";
6174
+ }, [data.input]);
6175
+ const to = useMemo15(() => {
6176
+ if (transferType == "erc20_transfer") {
6177
+ const decodeData = decodeFunctionData({
6178
+ abi: erc20Abi2,
6179
+ data: data.input
6180
+ });
6181
+ return decodeData.args[0];
6182
+ }
6183
+ return data.to;
6184
+ }, [data.input, transferType, data.to]);
6185
+ const amount = useMemo15(() => {
6186
+ if (transferType == "erc20_transfer") {
6187
+ const decodeData = decodeFunctionData({
6188
+ abi: erc20Abi2,
6189
+ data: data.input
6190
+ });
6191
+ const value = decodeData.args[1];
6192
+ return formatUnits3(value, getContract(chainId || 0, data.to)?.decimals || 18);
6193
+ }
6194
+ return chainFormatUnits(BigInt(data.value));
6195
+ }, [data.input, transferType, data.value, getContract, chainId, data.to]);
6196
+ useEffect24(() => {
6197
+ if (data.hash) {
6198
+ setShouldRefetch(true);
6199
+ }
6200
+ }, [data.hash]);
6201
+ const hashQuery = useHash({
6202
+ hash: data.hash,
6203
+ //@ts-ignore
6204
+ chain: defineChain4(chain),
6205
+ refetchInterval: shouldRefetch ? 3e3 : false,
6206
+ enabled: shouldRefetch
6207
+ });
6208
+ const status = useMemo15(() => {
6209
+ if (data.source == "matchain") {
6210
+ switch (data.extra.status) {
6211
+ case "ok":
6212
+ return "success";
6213
+ case "error":
6214
+ return "error";
6215
+ }
6216
+ } else if (data.source == "auto") {
6217
+ if (data.extra.receipt_status == 1) {
6218
+ return "success";
6219
+ } else {
6220
+ return "error";
6221
+ }
6222
+ } else {
6223
+ if (hashQuery.data == 1) {
6224
+ return "success";
6225
+ }
6226
+ if (hashQuery.data == -1) {
6227
+ return "error";
6228
+ }
6229
+ if (Date.now() / 1e3 - parseInt(data.timestamp) > 3600) {
6230
+ return "error";
6231
+ }
6232
+ }
6233
+ return "loading";
6234
+ }, [data.extra?.status, data.source, hashQuery.data]);
6235
+ useEffect24(() => {
6236
+ setShouldRefetch(status == "loading");
6237
+ }, [status]);
6238
+ const symbol = useMemo15(() => {
6239
+ if (transferType == "erc20_transfer") {
6240
+ return getContract(chainId || 0, data.to)?.symbol || getContract(chainId || 0, data.to)?.name || "unknown";
6241
+ }
6242
+ return chain?.nativeCurrency.symbol || chain?.nativeCurrency.name;
6243
+ }, [transferType, chain, getContract, chainId, data.to]);
6244
+ return /* @__PURE__ */ jsxs22(
6245
+ "a",
6246
+ {
6247
+ href: explorerLink(`tx/${data.hash}`),
6248
+ target: "_blank",
6249
+ className: `matchid-transaction-item`,
6250
+ children: [
6251
+ /* @__PURE__ */ jsxs22("div", { className: `matchid-transacton-item-container`, children: [
6252
+ /* @__PURE__ */ jsx32("div", { className: "matchid-transaction-item-icon", children: /* @__PURE__ */ jsx32(ArrowSendIcon, { className: !isOut ? "rotate-180" : "" }) }),
6253
+ /* @__PURE__ */ jsxs22("div", { className: `matchid-transaction-item-details`, children: [
6254
+ /* @__PURE__ */ jsx32("div", { className: `matchid-transaction-item-address`, children: formatAddress(to, 6, 4) }),
6255
+ /* @__PURE__ */ jsx32(
6256
+ "div",
6257
+ {
6258
+ className: `matchid-transaction-item-timestamp`,
6259
+ children: formatDate(data.timestamp, "MM/DD HH:mm:ss")
6260
+ }
6261
+ )
6262
+ ] })
6263
+ ] }),
6264
+ /* @__PURE__ */ jsxs22("div", { className: `matchid-transaction-item-amount ${"matchid-transaction-item-" + status}`, children: [
6265
+ /* @__PURE__ */ jsx32(NumberFormatter, { value: amount, tFixNum: 6, prefix: isOut ? "-" : "+", suffix: " " + symbol }),
6266
+ status == "loading" && /* @__PURE__ */ jsx32(LoadingIcon_default, { color: "#000000", size: 16, rotate: true }),
6267
+ status == "success" && /* @__PURE__ */ jsx32(CheckRoundIcon, { size: 16 }),
6268
+ status == "error" && /* @__PURE__ */ jsx32(InfoRoundIcon, { size: 16 })
6269
+ ] })
6270
+ ]
6271
+ }
6272
+ );
6273
+ };
6274
+ function TransactionList({
6275
+ scrollableTarget
6276
+ }) {
6277
+ const { fetchMoreData, hasMore, items } = useMatchWalletRecords();
6278
+ return /* @__PURE__ */ jsx32(
6279
+ InfiniteScroll,
6280
+ {
6281
+ scrollableTarget,
6282
+ dataLength: items.length,
6283
+ next: fetchMoreData,
6284
+ hasMore,
6285
+ loader: /* @__PURE__ */ jsxs22("div", { className: "matchid-list-nomore", children: [
6286
+ /* @__PURE__ */ jsx32(LoadingIcon_default, { rotate: true, size: 16, color: "black" }),
6287
+ "Loading..."
6288
+ ] }),
6289
+ endMessage: items.length > 0 ? /* @__PURE__ */ jsx32("div", { className: `matchid-list-nomore`, children: "There is no more Records here!" }) : /* @__PURE__ */ jsx32("div", { className: `matchid-list-nomore`, children: "No Records here!" }),
6290
+ children: items.length == 0 && !hasMore ? /* @__PURE__ */ jsx32("div", { className: "mt-[150px]" }) : /* @__PURE__ */ jsx32("div", { className: `matchid-transaction-list`, children: items.map((item, index) => /* @__PURE__ */ jsx32(Item, { data: item }, index)) })
6291
+ }
6292
+ );
6293
+ }
6294
+
4660
6295
  export {
4661
6296
  isSuccess,
4662
6297
  getBindListApi,
@@ -4670,9 +6305,9 @@ export {
4670
6305
  mintPassportNftApi,
4671
6306
  useUserInfo,
4672
6307
  useMatchEvents,
6308
+ useModal,
4673
6309
  useWallet,
4674
6310
  useCopyClipboard,
4675
- useModal,
4676
6311
  useToast,
4677
6312
  wallet_exports,
4678
6313
  useMatchChain,
@@ -4687,11 +6322,20 @@ export {
4687
6322
  TONModal,
4688
6323
  BTCModal,
4689
6324
  WalletModal,
6325
+ WalletAsset,
6326
+ TokenSend,
6327
+ TokenDetail,
6328
+ TokenSendList,
6329
+ TransactionList,
4690
6330
  components_exports,
4691
6331
  useMatchWallet,
6332
+ useMatchWalletRecords,
6333
+ useMatchWalletAssets,
6334
+ useMatchWalletAssetList,
4692
6335
  useReceipt,
6336
+ useTransaction,
4693
6337
  hooks_exports,
4694
6338
  MatchProvider,
4695
6339
  useMatch
4696
6340
  };
4697
- //# sourceMappingURL=chunk-D6IUBR7S.mjs.map
6341
+ //# sourceMappingURL=chunk-WHZ3HI4R.mjs.map