@matchain/matchid-sdk-react 0.1.53-alpha.19 → 0.1.53-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.
@@ -4372,34 +4372,8 @@ function UsernameModal({
4372
4372
  }
4373
4373
 
4374
4374
  // src/components/EVMModal/index.tsx
4375
+ var import_react31 = require("react");
4375
4376
  var import_react_intl14 = require("react-intl");
4376
- var import_styles = require("@rainbow-me/rainbowkit/styles.css");
4377
- var import_jsx_runtime87 = require("react/jsx-runtime");
4378
- function WalletContent({
4379
- onSuccess,
4380
- type
4381
- }) {
4382
- return /* @__PURE__ */ (0, import_jsx_runtime87.jsx)(import_jsx_runtime87.Fragment, {});
4383
- }
4384
- function EVMConnectModal({
4385
- type = "login",
4386
- onSuccess,
4387
- ...props
4388
- }) {
4389
- const intl = (0, import_react_intl14.useIntl)();
4390
- return /* @__PURE__ */ (0, import_jsx_runtime87.jsx)(ModalWithHeader, { ...props, title: props.title || intl.formatMessage({
4391
- id: type == "bind" ? "bindWith" : "loginWith"
4392
- }, {
4393
- name: "EVM"
4394
- }), children: /* @__PURE__ */ (0, import_jsx_runtime87.jsx)(WalletContent, { onSuccess, type }) });
4395
- }
4396
- function EVMModal(props) {
4397
- return props.isOpen && /* @__PURE__ */ (0, import_jsx_runtime87.jsx)(EVMConnectModal, { ...props });
4398
- }
4399
-
4400
- // src/components/TRONModal/index.tsx
4401
- var import_react31 = __toESM(require("react"));
4402
- var import_react_intl15 = require("react-intl");
4403
4377
 
4404
4378
  // src/components/WalletModalContent/index.tsx
4405
4379
  var import_react29 = require("react");
@@ -4412,7 +4386,7 @@ var walletConnectImage = "
4412
4386
  var walletSigningImage = "";
4413
4387
 
4414
4388
  // src/components/WalletModalContent/index.tsx
4415
- var import_jsx_runtime88 = require("react/jsx-runtime");
4389
+ var import_jsx_runtime87 = require("react/jsx-runtime");
4416
4390
  function WalletModalContent({
4417
4391
  status,
4418
4392
  error,
@@ -4482,12 +4456,93 @@ function WalletModalContent({
4482
4456
  statusImage: walletConnectImage
4483
4457
  };
4484
4458
  }, [visible, connected, status, error, address]);
4485
- return /* @__PURE__ */ (0, import_jsx_runtime88.jsx)("div", { className: "matchid-wallet-container", children: /* @__PURE__ */ (0, import_jsx_runtime88.jsxs)("div", { className: `matchid-wallet-box`, children: [
4486
- /* @__PURE__ */ (0, import_jsx_runtime88.jsxs)("div", { className: `matchid-wallet-content`, children: [
4487
- /* @__PURE__ */ (0, import_jsx_runtime88.jsx)("img", { src: pageData.statusImage }),
4488
- /* @__PURE__ */ (0, import_jsx_runtime88.jsx)("div", { className: pageData.isError ? "matchid-error" : "", children: pageData.text })
4459
+ return /* @__PURE__ */ (0, import_jsx_runtime87.jsx)("div", { className: "matchid-wallet-container", children: /* @__PURE__ */ (0, import_jsx_runtime87.jsxs)("div", { className: `matchid-wallet-box`, children: [
4460
+ /* @__PURE__ */ (0, import_jsx_runtime87.jsxs)("div", { className: `matchid-wallet-content`, children: [
4461
+ /* @__PURE__ */ (0, import_jsx_runtime87.jsx)("img", { src: pageData.statusImage }),
4462
+ /* @__PURE__ */ (0, import_jsx_runtime87.jsx)("div", { className: pageData.isError ? "matchid-error" : "", children: pageData.text })
4463
+ ] }),
4464
+ /* @__PURE__ */ (0, import_jsx_runtime87.jsx)(
4465
+ Button,
4466
+ {
4467
+ block: true,
4468
+ size: "lg",
4469
+ onClick: pageData.btnClick,
4470
+ loading: pageData.btnLoading,
4471
+ disabled: pageData.btnDisabled,
4472
+ children: pageData.btnText
4473
+ }
4474
+ )
4475
+ ] }) });
4476
+ }
4477
+ function WalletModalContentV2(props) {
4478
+ const [submitting, setSubmitting] = (0, import_react29.useState)(false);
4479
+ const pageData = (0, import_react29.useMemo)(() => {
4480
+ const { status } = props;
4481
+ if (status == "success") {
4482
+ return {
4483
+ btnText: "Disconnect Wallet",
4484
+ btnClick: async () => {
4485
+ setSubmitting(true);
4486
+ await props.onDisconnect?.();
4487
+ setSubmitting(false);
4488
+ },
4489
+ text: "Wallet connection successful!",
4490
+ statusImage: walletConnectedImage,
4491
+ btnLoading: submitting
4492
+ };
4493
+ }
4494
+ if (status == "error") {
4495
+ return {
4496
+ text: props.error || "Unknown Error",
4497
+ btnText: "Reconnect Wallet",
4498
+ btnClick: async () => {
4499
+ setSubmitting(true);
4500
+ await props.onError?.();
4501
+ setSubmitting(false);
4502
+ },
4503
+ statusImage: walletErrorImage,
4504
+ isError: true,
4505
+ btnLoading: submitting
4506
+ };
4507
+ }
4508
+ if (status == "nonce") {
4509
+ return {
4510
+ btnLoading: true,
4511
+ text: "Connecting",
4512
+ statusImage: walletConnectingImage
4513
+ };
4514
+ }
4515
+ if (status == "signer") {
4516
+ return {
4517
+ btnLoading: true,
4518
+ text: "Signing",
4519
+ statusImage: walletSigningImage
4520
+ };
4521
+ }
4522
+ if (status == "connecting") {
4523
+ return {
4524
+ btnLoading: true,
4525
+ text: "Connecting",
4526
+ statusImage: walletConnectingImage
4527
+ };
4528
+ }
4529
+ return {
4530
+ btnText: "Connect Wallet",
4531
+ btnClick: async () => {
4532
+ setSubmitting(true);
4533
+ await props.onConnect?.();
4534
+ setSubmitting(false);
4535
+ },
4536
+ text: "Please Connect your wallet",
4537
+ statusImage: walletConnectImage
4538
+ };
4539
+ }, [props, submitting]);
4540
+ return /* @__PURE__ */ (0, import_jsx_runtime87.jsx)("div", { className: "matchid-wallet-container", children: /* @__PURE__ */ (0, import_jsx_runtime87.jsxs)("div", { className: `matchid-wallet-box`, children: [
4541
+ /* @__PURE__ */ (0, import_jsx_runtime87.jsxs)("div", { className: `matchid-wallet-content`, children: [
4542
+ /* @__PURE__ */ (0, import_jsx_runtime87.jsx)("img", { src: pageData.statusImage }),
4543
+ /* @__PURE__ */ (0, import_jsx_runtime87.jsx)("div", { className: props.status == "error" ? "matchid-error" : "", children: pageData.text })
4489
4544
  ] }),
4490
- /* @__PURE__ */ (0, import_jsx_runtime88.jsx)(
4545
+ /* @__PURE__ */ (0, import_jsx_runtime87.jsx)(
4491
4546
  Button,
4492
4547
  {
4493
4548
  block: true,
@@ -4501,6 +4556,459 @@ function WalletModalContent({
4501
4556
  ] }) });
4502
4557
  }
4503
4558
 
4559
+ // src/components/EVMModal/index.tsx
4560
+ var import_rainbowkit2 = require("@rainbow-me/rainbowkit");
4561
+ var import_wagmi3 = require("wagmi");
4562
+
4563
+ // src/hooks/useWalletBox.ts
4564
+ var import_react30 = require("react");
4565
+ function useWalletBox({
4566
+ onInit
4567
+ }) {
4568
+ const [status, setStateStatus] = (0, import_react30.useState)("start");
4569
+ const [error, setError] = (0, import_react30.useState)("");
4570
+ const statusRef = (0, import_react30.useRef)(status);
4571
+ const [nonce, setNonce] = (0, import_react30.useState)();
4572
+ const setStatus = (status2) => {
4573
+ statusRef.current = status2;
4574
+ setStateStatus(status2);
4575
+ };
4576
+ const init = () => {
4577
+ setError("");
4578
+ setNonce(null);
4579
+ };
4580
+ (0, import_react30.useEffect)(() => {
4581
+ init();
4582
+ onInit({
4583
+ setStatus
4584
+ });
4585
+ return () => {
4586
+ setStatus("start");
4587
+ setNonce(null);
4588
+ setError("");
4589
+ };
4590
+ }, []);
4591
+ return {
4592
+ status,
4593
+ statusRef,
4594
+ setStatus,
4595
+ error,
4596
+ setError,
4597
+ nonce,
4598
+ setNonce,
4599
+ init
4600
+ };
4601
+ }
4602
+
4603
+ // src/hooks/useEthersSigner.ts
4604
+ var React8 = __toESM(require("react"));
4605
+ var import_wagmi2 = require("wagmi");
4606
+ var import_ethers = require("ethers");
4607
+
4608
+ // node_modules/@wagmi/core/dist/esm/version.js
4609
+ var version = "2.16.3";
4610
+
4611
+ // node_modules/@wagmi/core/dist/esm/utils/getVersion.js
4612
+ var getVersion2 = () => `@wagmi/core@${version}`;
4613
+
4614
+ // node_modules/@wagmi/core/dist/esm/errors/base.js
4615
+ var __classPrivateFieldGet = function(receiver, state, kind, f) {
4616
+ if (kind === "a" && !f) throw new TypeError("Private accessor was defined without a getter");
4617
+ if (typeof state === "function" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError("Cannot read private member from an object whose class did not declare it");
4618
+ return kind === "m" ? f : kind === "a" ? f.call(receiver) : f ? f.value : state.get(receiver);
4619
+ };
4620
+ var _BaseError_instances;
4621
+ var _BaseError_walk;
4622
+ var BaseError = class _BaseError extends Error {
4623
+ get docsBaseUrl() {
4624
+ return "https://wagmi.sh/core";
4625
+ }
4626
+ get version() {
4627
+ return getVersion2();
4628
+ }
4629
+ constructor(shortMessage, options = {}) {
4630
+ super();
4631
+ _BaseError_instances.add(this);
4632
+ Object.defineProperty(this, "details", {
4633
+ enumerable: true,
4634
+ configurable: true,
4635
+ writable: true,
4636
+ value: void 0
4637
+ });
4638
+ Object.defineProperty(this, "docsPath", {
4639
+ enumerable: true,
4640
+ configurable: true,
4641
+ writable: true,
4642
+ value: void 0
4643
+ });
4644
+ Object.defineProperty(this, "metaMessages", {
4645
+ enumerable: true,
4646
+ configurable: true,
4647
+ writable: true,
4648
+ value: void 0
4649
+ });
4650
+ Object.defineProperty(this, "shortMessage", {
4651
+ enumerable: true,
4652
+ configurable: true,
4653
+ writable: true,
4654
+ value: void 0
4655
+ });
4656
+ Object.defineProperty(this, "name", {
4657
+ enumerable: true,
4658
+ configurable: true,
4659
+ writable: true,
4660
+ value: "WagmiCoreError"
4661
+ });
4662
+ const details = options.cause instanceof _BaseError ? options.cause.details : options.cause?.message ? options.cause.message : options.details;
4663
+ const docsPath = options.cause instanceof _BaseError ? options.cause.docsPath || options.docsPath : options.docsPath;
4664
+ this.message = [
4665
+ shortMessage || "An error occurred.",
4666
+ "",
4667
+ ...options.metaMessages ? [...options.metaMessages, ""] : [],
4668
+ ...docsPath ? [
4669
+ `Docs: ${this.docsBaseUrl}${docsPath}.html${options.docsSlug ? `#${options.docsSlug}` : ""}`
4670
+ ] : [],
4671
+ ...details ? [`Details: ${details}`] : [],
4672
+ `Version: ${this.version}`
4673
+ ].join("\n");
4674
+ if (options.cause)
4675
+ this.cause = options.cause;
4676
+ this.details = details;
4677
+ this.docsPath = docsPath;
4678
+ this.metaMessages = options.metaMessages;
4679
+ this.shortMessage = shortMessage;
4680
+ }
4681
+ walk(fn) {
4682
+ return __classPrivateFieldGet(this, _BaseError_instances, "m", _BaseError_walk).call(this, this, fn);
4683
+ }
4684
+ };
4685
+ _BaseError_instances = /* @__PURE__ */ new WeakSet(), _BaseError_walk = function _BaseError_walk2(err, fn) {
4686
+ if (fn?.(err))
4687
+ return err;
4688
+ if (err.cause)
4689
+ return __classPrivateFieldGet(this, _BaseError_instances, "m", _BaseError_walk2).call(this, err.cause, fn);
4690
+ return err;
4691
+ };
4692
+
4693
+ // node_modules/@wagmi/core/dist/esm/errors/config.js
4694
+ var ConnectorNotConnectedError = class extends BaseError {
4695
+ constructor() {
4696
+ super("Connector not connected.");
4697
+ Object.defineProperty(this, "name", {
4698
+ enumerable: true,
4699
+ configurable: true,
4700
+ writable: true,
4701
+ value: "ConnectorNotConnectedError"
4702
+ });
4703
+ }
4704
+ };
4705
+ var ConnectorAccountNotFoundError = class extends BaseError {
4706
+ constructor({ address, connector }) {
4707
+ super(`Account "${address}" not found for connector "${connector.name}".`);
4708
+ Object.defineProperty(this, "name", {
4709
+ enumerable: true,
4710
+ configurable: true,
4711
+ writable: true,
4712
+ value: "ConnectorAccountNotFoundError"
4713
+ });
4714
+ }
4715
+ };
4716
+ var ConnectorChainMismatchError = class extends BaseError {
4717
+ constructor({ connectionChainId, connectorChainId }) {
4718
+ super(`The current chain of the connector (id: ${connectorChainId}) does not match the connection's chain (id: ${connectionChainId}).`, {
4719
+ metaMessages: [
4720
+ `Current Chain ID: ${connectorChainId}`,
4721
+ `Expected Chain ID: ${connectionChainId}`
4722
+ ]
4723
+ });
4724
+ Object.defineProperty(this, "name", {
4725
+ enumerable: true,
4726
+ configurable: true,
4727
+ writable: true,
4728
+ value: "ConnectorChainMismatchError"
4729
+ });
4730
+ }
4731
+ };
4732
+ var ConnectorUnavailableReconnectingError = class extends BaseError {
4733
+ constructor({ connector }) {
4734
+ super(`Connector "${connector.name}" unavailable while reconnecting.`, {
4735
+ details: [
4736
+ "During the reconnection step, the only connector methods guaranteed to be available are: `id`, `name`, `type`, `uid`.",
4737
+ "All other methods are not guaranteed to be available until reconnection completes and connectors are fully restored.",
4738
+ "This error commonly occurs for connectors that asynchronously inject after reconnection has already started."
4739
+ ].join(" ")
4740
+ });
4741
+ Object.defineProperty(this, "name", {
4742
+ enumerable: true,
4743
+ configurable: true,
4744
+ writable: true,
4745
+ value: "ConnectorUnavailableReconnectingError"
4746
+ });
4747
+ }
4748
+ };
4749
+
4750
+ // node_modules/@wagmi/core/dist/esm/actions/getConnectorClient.js
4751
+ var import_viem13 = require("viem");
4752
+ var import_utils9 = require("viem/utils");
4753
+ async function getConnectorClient(config, parameters = {}) {
4754
+ let connection;
4755
+ if (parameters.connector) {
4756
+ const { connector: connector2 } = parameters;
4757
+ if (config.state.status === "reconnecting" && !connector2.getAccounts && !connector2.getChainId)
4758
+ throw new ConnectorUnavailableReconnectingError({ connector: connector2 });
4759
+ const [accounts, chainId2] = await Promise.all([
4760
+ connector2.getAccounts(),
4761
+ connector2.getChainId()
4762
+ ]);
4763
+ connection = {
4764
+ accounts,
4765
+ chainId: chainId2,
4766
+ connector: connector2
4767
+ };
4768
+ } else
4769
+ connection = config.state.connections.get(config.state.current);
4770
+ if (!connection)
4771
+ throw new ConnectorNotConnectedError();
4772
+ const chainId = parameters.chainId ?? connection.chainId;
4773
+ const connectorChainId = await connection.connector.getChainId();
4774
+ if (connectorChainId !== connection.chainId)
4775
+ throw new ConnectorChainMismatchError({
4776
+ connectionChainId: connection.chainId,
4777
+ connectorChainId
4778
+ });
4779
+ const connector = connection.connector;
4780
+ if (connector.getClient)
4781
+ return connector.getClient({ chainId });
4782
+ const account = (0, import_utils9.parseAccount)(parameters.account ?? connection.accounts[0]);
4783
+ account.address = (0, import_utils9.getAddress)(account.address);
4784
+ if (parameters.account && !connection.accounts.some((x) => x.toLowerCase() === account.address.toLowerCase()))
4785
+ throw new ConnectorAccountNotFoundError({
4786
+ address: account.address,
4787
+ connector
4788
+ });
4789
+ const chain = config.chains.find((chain2) => chain2.id === chainId);
4790
+ const provider = await connection.connector.getProvider({ chainId });
4791
+ return (0, import_viem13.createClient)({
4792
+ account,
4793
+ chain,
4794
+ name: "Connector Client",
4795
+ transport: (opts) => (0, import_viem13.custom)(provider)({ ...opts, retryCount: 0 })
4796
+ });
4797
+ }
4798
+
4799
+ // node_modules/@wagmi/core/dist/esm/exports/index.js
4800
+ var import_viem14 = require("viem");
4801
+
4802
+ // src/hooks/useEthersSigner.ts
4803
+ function clientToSigner(client) {
4804
+ const { account, chain, transport } = client;
4805
+ const network = {
4806
+ chainId: chain.id,
4807
+ name: chain.name,
4808
+ ensAddress: chain.contracts?.ensRegistry?.address
4809
+ };
4810
+ const provider = new import_ethers.providers.Web3Provider(transport, network);
4811
+ const signer = provider.getSigner(account.address);
4812
+ return signer;
4813
+ }
4814
+ async function getEthersSigner(config, { chainId } = {}) {
4815
+ const client = await getConnectorClient(config, { chainId });
4816
+ return clientToSigner(client);
4817
+ }
4818
+
4819
+ // src/components/EVMModal/index.tsx
4820
+ var import_siwe = require("siwe");
4821
+ var import_styles = require("@rainbow-me/rainbowkit/styles.css");
4822
+ var import_jsx_runtime88 = require("react/jsx-runtime");
4823
+ function WalletContent({
4824
+ onSuccess,
4825
+ type
4826
+ }) {
4827
+ const config = (0, import_wagmi3.useConfig)();
4828
+ const { openConnectModal, connectModalOpen } = (0, import_rainbowkit2.useConnectModal)();
4829
+ const { address, connector, isConnected } = (0, import_wagmi3.useAccount)();
4830
+ const { disconnectAsync } = (0, import_wagmi3.useDisconnect)({ config });
4831
+ const chainId = (0, import_wagmi3.useChainId)();
4832
+ const { events, login } = useMatch();
4833
+ const [inited, setInited] = (0, import_react31.useState)(false);
4834
+ const { status, setStatus, error, setError, statusRef, nonce, setNonce, init } = useWalletBox({
4835
+ onInit: async ({ setStatus: setStatus2 }) => {
4836
+ setStatus2("start");
4837
+ }
4838
+ });
4839
+ (0, import_react31.useEffect)(() => {
4840
+ matchlog_default.log(`status=${status}`, `connectModalOpen=${connectModalOpen}`, `address=${address}`, `isConnected=${isConnected}`);
4841
+ }, [status, connectModalOpen, isConnected, address]);
4842
+ (0, import_react31.useEffect)(() => {
4843
+ if (connectModalOpen) {
4844
+ setStatus("connecting");
4845
+ return;
4846
+ }
4847
+ if (!connectModalOpen && address) {
4848
+ toLoginInWallet(address);
4849
+ return;
4850
+ }
4851
+ if (!connectModalOpen && !address) {
4852
+ setStatus("start");
4853
+ }
4854
+ }, [connectModalOpen, address]);
4855
+ (0, import_react31.useEffect)(() => {
4856
+ if (openConnectModal && !isConnected && !inited) {
4857
+ openConnectModal && openConnectModal();
4858
+ setInited(true);
4859
+ }
4860
+ }, [openConnectModal, inited]);
4861
+ const toLoginInWallet = async (address2) => {
4862
+ if (statusRef.current != "start" && statusRef.current != "connecting") return;
4863
+ try {
4864
+ if (!address2) {
4865
+ throw new Error("Wallet address is empty");
4866
+ }
4867
+ setStatus("nonce");
4868
+ const res = type == "bind" ? await getWalletInitApi({
4869
+ address: address2,
4870
+ type: "EVM"
4871
+ }) : await getWalletNonceApi({ address: address2, type: "EVM" });
4872
+ if (!isSuccess(res)) {
4873
+ throw new Error(res.message);
4874
+ }
4875
+ setNonce(res.data.nonce);
4876
+ } catch (error2) {
4877
+ console.error("toLoginInWallet", error2);
4878
+ setStatus("error");
4879
+ setError(error2.message);
4880
+ }
4881
+ };
4882
+ const signature = (0, import_react31.useCallback)(async () => {
4883
+ if (!nonce || status != "nonce") {
4884
+ return;
4885
+ }
4886
+ try {
4887
+ const signer = await getEthersSigner(config);
4888
+ if (!signer) return;
4889
+ matchlog_default.log("signature", nonce, status);
4890
+ if (!address) {
4891
+ throw new Error("Wallet address is empty");
4892
+ }
4893
+ setStatus("signer");
4894
+ const params = {
4895
+ domain: window.location.host,
4896
+ address,
4897
+ statement: "By signing, you are proving you own this wallet and logging in. This does not initiate a transaction or cost any fees.",
4898
+ uri: window.location.origin,
4899
+ nonce,
4900
+ version: "1",
4901
+ chainId
4902
+ };
4903
+ const message = new import_siwe.SiweMessage({ ...params });
4904
+ const signature2 = await signer.signMessage(message.prepareMessage());
4905
+ const obj = {
4906
+ type: "EVM",
4907
+ address,
4908
+ signature: signature2,
4909
+ message: `${message.prepareMessage()}`,
4910
+ connector_type: connector?.type || "",
4911
+ wallet_client_type: connector?.name || ""
4912
+ };
4913
+ const res = type == "bind" ? await toBindWalletApi(obj) : await loginByWalletApi(obj);
4914
+ if (!isSuccess(res)) {
4915
+ throw new Error(res.message);
4916
+ }
4917
+ matchlog_default.log(res);
4918
+ setStatus("success");
4919
+ if (type == "bind") {
4920
+ events.onBind && events.onBind({
4921
+ type: "evm"
4922
+ });
4923
+ eventManager_default.emit("onBind", {
4924
+ type: "evm"
4925
+ });
4926
+ } else {
4927
+ await login({
4928
+ token: `${res.data.token_type} ${res.data.access_token}`
4929
+ });
4930
+ }
4931
+ onSuccess && onSuccess();
4932
+ } catch (error2) {
4933
+ console.error("signature", error2);
4934
+ setStatus("error");
4935
+ setError(error2.reason || error2.message);
4936
+ }
4937
+ }, [nonce, status, address]);
4938
+ (0, import_react31.useEffect)(() => {
4939
+ if (signature) {
4940
+ signature();
4941
+ }
4942
+ }, [signature]);
4943
+ const onError = async () => {
4944
+ if (isConnected) {
4945
+ try {
4946
+ await disconnectAsync();
4947
+ } catch (error2) {
4948
+ console.error("disconnectAsync", error2);
4949
+ }
4950
+ }
4951
+ setError("");
4952
+ setNonce(void 0);
4953
+ setStatus("start");
4954
+ openConnectModal?.();
4955
+ };
4956
+ const onConnect = async () => {
4957
+ if (isConnected) {
4958
+ try {
4959
+ await disconnectAsync();
4960
+ } catch (error2) {
4961
+ console.error("disconnectAsync", error2);
4962
+ }
4963
+ }
4964
+ setError("");
4965
+ setNonce(void 0);
4966
+ openConnectModal?.();
4967
+ };
4968
+ const onDisconnect = async () => {
4969
+ if (isConnected) {
4970
+ try {
4971
+ await disconnectAsync();
4972
+ } catch (error2) {
4973
+ console.error("disconnectAsync", error2);
4974
+ }
4975
+ }
4976
+ setError("");
4977
+ setNonce(void 0);
4978
+ setStatus("start");
4979
+ };
4980
+ return /* @__PURE__ */ (0, import_jsx_runtime88.jsx)(
4981
+ WalletModalContentV2,
4982
+ {
4983
+ status,
4984
+ onSuccess: async () => onSuccess?.(),
4985
+ error,
4986
+ onError,
4987
+ onConnect,
4988
+ onDisconnect
4989
+ }
4990
+ );
4991
+ }
4992
+ function EVMConnectModal({
4993
+ type = "login",
4994
+ onSuccess,
4995
+ ...props
4996
+ }) {
4997
+ const intl = (0, import_react_intl14.useIntl)();
4998
+ return /* @__PURE__ */ (0, import_jsx_runtime88.jsx)(ModalWithHeader, { ...props, title: props.title || intl.formatMessage({
4999
+ id: type == "bind" ? "bindWith" : "loginWith"
5000
+ }, {
5001
+ name: "EVM"
5002
+ }), children: /* @__PURE__ */ (0, import_jsx_runtime88.jsx)(WalletContent, { onSuccess, type }) });
5003
+ }
5004
+ function EVMModal(props) {
5005
+ return props.isOpen && /* @__PURE__ */ (0, import_jsx_runtime88.jsx)(EVMConnectModal, { ...props });
5006
+ }
5007
+
5008
+ // src/components/TRONModal/index.tsx
5009
+ var import_react33 = __toESM(require("react"));
5010
+ var import_react_intl15 = require("react-intl");
5011
+
4504
5012
  // src/lib/tron/TronLinkAdapter.ts
4505
5013
  var TronLinkAdapter = class {
4506
5014
  constructor() {
@@ -4532,7 +5040,7 @@ var TronLinkAdapter = class {
4532
5040
  };
4533
5041
 
4534
5042
  // src/hooks/useTRONWallet.ts
4535
- var import_react30 = require("react");
5043
+ var import_react32 = require("react");
4536
5044
 
4537
5045
  // src/lib/tron/BitgetAdapter.ts
4538
5046
  var BitgetAdapter = class {
@@ -4577,9 +5085,9 @@ var OKXAdapter = class {
4577
5085
  // src/hooks/useTRONWallet.ts
4578
5086
  var useTRONWallet = () => {
4579
5087
  const wallets = [new TronLinkAdapter(), new BitgetAdapter(), new OKXAdapter()];
4580
- const [installedWallets, setInstalledWallets] = (0, import_react30.useState)([]);
4581
- const [address, setAddress] = (0, import_react30.useState)(null);
4582
- (0, import_react30.useEffect)(() => {
5088
+ const [installedWallets, setInstalledWallets] = (0, import_react32.useState)([]);
5089
+ const [address, setAddress] = (0, import_react32.useState)(null);
5090
+ (0, import_react32.useEffect)(() => {
4583
5091
  const getInstalled = async () => {
4584
5092
  const installed = await Promise.all(wallets.map((wallet2) => wallet2.isInstalled().then((isInstalled) => ({
4585
5093
  wallet: wallet2,
@@ -4589,11 +5097,11 @@ var useTRONWallet = () => {
4589
5097
  };
4590
5098
  getInstalled();
4591
5099
  }, []);
4592
- const [wallet, chooseWallet] = (0, import_react30.useState)(null);
5100
+ const [wallet, chooseWallet] = (0, import_react32.useState)(null);
4593
5101
  const onConnect = async () => {
4594
5102
  setAddress(await wallet.connect());
4595
5103
  };
4596
- (0, import_react30.useEffect)(() => {
5104
+ (0, import_react32.useEffect)(() => {
4597
5105
  if (!wallet) {
4598
5106
  setAddress(null);
4599
5107
  }
@@ -4624,10 +5132,10 @@ function TRONConnectModal({
4624
5132
  okx: /* @__PURE__ */ (0, import_jsx_runtime89.jsx)(OKXIcon, { size: isDownMd ? 36 : 40 })
4625
5133
  };
4626
5134
  const { events, login } = useMatch();
4627
- const [status, setStatus] = (0, import_react31.useState)("");
4628
- const statusRef = import_react31.default.useRef(status);
4629
- const [error, setError] = (0, import_react31.useState)("");
4630
- const connected = (0, import_react31.useMemo)(() => {
5135
+ const [status, setStatus] = (0, import_react33.useState)("");
5136
+ const statusRef = import_react33.default.useRef(status);
5137
+ const [error, setError] = (0, import_react33.useState)("");
5138
+ const connected = (0, import_react33.useMemo)(() => {
4631
5139
  return !!address;
4632
5140
  }, [address]);
4633
5141
  const disconnect = async () => {
@@ -4695,7 +5203,7 @@ function TRONConnectModal({
4695
5203
  statusRef.current = "";
4696
5204
  }
4697
5205
  };
4698
- (0, import_react31.useEffect)(() => {
5206
+ (0, import_react33.useEffect)(() => {
4699
5207
  if (wallet) {
4700
5208
  console.log("onConnect");
4701
5209
  onConnect();
@@ -4703,12 +5211,12 @@ function TRONConnectModal({
4703
5211
  setStatus("");
4704
5212
  }
4705
5213
  }, [wallet]);
4706
- (0, import_react31.useEffect)(() => {
5214
+ (0, import_react33.useEffect)(() => {
4707
5215
  if (address) {
4708
5216
  toLoginInWallet();
4709
5217
  }
4710
5218
  }, [address]);
4711
- (0, import_react31.useEffect)(() => {
5219
+ (0, import_react33.useEffect)(() => {
4712
5220
  if (!props.isOpen) {
4713
5221
  disconnect();
4714
5222
  }
@@ -4766,7 +5274,7 @@ function TRONModal(props) {
4766
5274
  }
4767
5275
 
4768
5276
  // src/components/TONModal/index.tsx
4769
- var import_react32 = __toESM(require("react"));
5277
+ var import_react34 = __toESM(require("react"));
4770
5278
  var import_react_intl16 = require("react-intl");
4771
5279
  var import_ui_react = require("@tonconnect/ui-react");
4772
5280
  var import_jsx_runtime90 = require("react/jsx-runtime");
@@ -4775,15 +5283,15 @@ function WalletContent2({
4775
5283
  type
4776
5284
  }) {
4777
5285
  const { events, login } = useMatch();
4778
- const [connected, setConnected] = (0, import_react32.useState)(false);
5286
+ const [connected, setConnected] = (0, import_react34.useState)(false);
4779
5287
  const wallet = (0, import_ui_react.useTonWallet)();
4780
5288
  const userFriendlyAddress = (0, import_ui_react.useTonAddress)();
4781
5289
  const [tonConnectUI] = (0, import_ui_react.useTonConnectUI)();
4782
5290
  const { state, open, close } = (0, import_ui_react.useTonConnectModal)();
4783
- const [status, setStatus] = (0, import_react32.useState)("");
4784
- const statusRef = import_react32.default.useRef(status);
4785
- const [error, setError] = (0, import_react32.useState)("");
4786
- (0, import_react32.useEffect)(() => {
5291
+ const [status, setStatus] = (0, import_react34.useState)("");
5292
+ const statusRef = import_react34.default.useRef(status);
5293
+ const [error, setError] = (0, import_react34.useState)("");
5294
+ (0, import_react34.useEffect)(() => {
4787
5295
  const init = async () => {
4788
5296
  if (tonConnectUI.connected) {
4789
5297
  await tonConnectUI.disconnect();
@@ -4856,7 +5364,7 @@ function WalletContent2({
4856
5364
  }
4857
5365
  });
4858
5366
  }, []);
4859
- (0, import_react32.useEffect)(() => {
5367
+ (0, import_react34.useEffect)(() => {
4860
5368
  if (wallet) {
4861
5369
  setConnected(true);
4862
5370
  console.log("Wallet connected:", wallet);
@@ -4867,7 +5375,7 @@ function WalletContent2({
4867
5375
  setStatus("");
4868
5376
  }
4869
5377
  }, [wallet]);
4870
- (0, import_react32.useEffect)(() => {
5378
+ (0, import_react34.useEffect)(() => {
4871
5379
  console.log({
4872
5380
  state,
4873
5381
  wallet
@@ -4947,7 +5455,7 @@ function TONModal(props) {
4947
5455
  }
4948
5456
 
4949
5457
  // src/components/BTCModal/index.tsx
4950
- var import_react34 = __toESM(require("react"));
5458
+ var import_react36 = __toESM(require("react"));
4951
5459
  var import_react_intl17 = require("react-intl");
4952
5460
 
4953
5461
  // src/lib/btc/UnisatAdapter.ts
@@ -5096,7 +5604,7 @@ var LeatherAdapter = class {
5096
5604
  };
5097
5605
 
5098
5606
  // src/hooks/useBTCWallet.ts
5099
- var import_react33 = require("react");
5607
+ var import_react35 = require("react");
5100
5608
 
5101
5609
  // src/lib/btc/PhantomAdapter.ts
5102
5610
  var PhantomAdapter = class {
@@ -5134,9 +5642,9 @@ var PhantomAdapter = class {
5134
5642
  // src/hooks/useBTCWallet.ts
5135
5643
  var useBTCWallet = () => {
5136
5644
  const wallets = [new UnisatAdapter(), new XverseAdapter(), new LeatherAdapter(), new PhantomAdapter()];
5137
- const [installedWallets, setInstalledWallets] = (0, import_react33.useState)([]);
5138
- const [address, setAddress] = (0, import_react33.useState)(null);
5139
- (0, import_react33.useEffect)(() => {
5645
+ const [installedWallets, setInstalledWallets] = (0, import_react35.useState)([]);
5646
+ const [address, setAddress] = (0, import_react35.useState)(null);
5647
+ (0, import_react35.useEffect)(() => {
5140
5648
  const getInstalled = async () => {
5141
5649
  const installed = await Promise.all(wallets.map((wallet2) => wallet2.isInstalled().then((isInstalled) => ({
5142
5650
  wallet: wallet2,
@@ -5146,11 +5654,11 @@ var useBTCWallet = () => {
5146
5654
  };
5147
5655
  getInstalled();
5148
5656
  }, []);
5149
- const [wallet, chooseWallet] = (0, import_react33.useState)(null);
5657
+ const [wallet, chooseWallet] = (0, import_react35.useState)(null);
5150
5658
  const onConnect = async () => {
5151
5659
  setAddress(await wallet.connect());
5152
5660
  };
5153
- (0, import_react33.useEffect)(() => {
5661
+ (0, import_react35.useEffect)(() => {
5154
5662
  if (!wallet) {
5155
5663
  setAddress(null);
5156
5664
  }
@@ -5182,10 +5690,10 @@ function BTCConnectModal({
5182
5690
  phantom: /* @__PURE__ */ (0, import_jsx_runtime91.jsx)(PhantomIcon, { size: isDownMd ? 36 : 40 })
5183
5691
  };
5184
5692
  const { events, login } = useMatch();
5185
- const [status, setStatus] = (0, import_react34.useState)("");
5186
- const statusRef = import_react34.default.useRef(status);
5187
- const [error, setError] = (0, import_react34.useState)("");
5188
- const connected = (0, import_react34.useMemo)(() => {
5693
+ const [status, setStatus] = (0, import_react36.useState)("");
5694
+ const statusRef = import_react36.default.useRef(status);
5695
+ const [error, setError] = (0, import_react36.useState)("");
5696
+ const connected = (0, import_react36.useMemo)(() => {
5189
5697
  return !!address;
5190
5698
  }, [address]);
5191
5699
  const disconnect = async () => {
@@ -5249,7 +5757,7 @@ function BTCConnectModal({
5249
5757
  statusRef.current = "";
5250
5758
  }
5251
5759
  };
5252
- (0, import_react34.useEffect)(() => {
5760
+ (0, import_react36.useEffect)(() => {
5253
5761
  if (wallet) {
5254
5762
  console.log("onConnect");
5255
5763
  try {
@@ -5262,12 +5770,12 @@ function BTCConnectModal({
5262
5770
  setStatus("");
5263
5771
  }
5264
5772
  }, [wallet]);
5265
- (0, import_react34.useEffect)(() => {
5773
+ (0, import_react36.useEffect)(() => {
5266
5774
  if (address) {
5267
5775
  toLoginInWallet();
5268
5776
  }
5269
5777
  }, [address]);
5270
- (0, import_react34.useEffect)(() => {
5778
+ (0, import_react36.useEffect)(() => {
5271
5779
  if (!props.isOpen) {
5272
5780
  disconnect();
5273
5781
  }
@@ -5332,7 +5840,7 @@ function BTCModal(props) {
5332
5840
  }
5333
5841
 
5334
5842
  // src/components/WalletModal/index.tsx
5335
- var import_react35 = require("react");
5843
+ var import_react37 = require("react");
5336
5844
  var import_react_intl18 = require("react-intl");
5337
5845
  var import_jsx_runtime92 = require("react/jsx-runtime");
5338
5846
  function WalletConnectModal({
@@ -5344,7 +5852,7 @@ function WalletConnectModal({
5344
5852
  const { walletMap } = useWalletConfig();
5345
5853
  const { bind, login } = useUserInfo();
5346
5854
  const config = useAppConfig();
5347
- const methods = (0, import_react35.useMemo)(() => {
5855
+ const methods = (0, import_react37.useMemo)(() => {
5348
5856
  if (_methods) return _methods;
5349
5857
  if (!config.platform) {
5350
5858
  return [];
@@ -5376,11 +5884,11 @@ function WalletModal(props) {
5376
5884
  }
5377
5885
 
5378
5886
  // src/components/AlphaAvatar/index.tsx
5379
- var import_react36 = require("react");
5887
+ var import_react38 = require("react");
5380
5888
  var import_jsx_runtime93 = require("react/jsx-runtime");
5381
5889
  function AlphaAvatar2({ name, size = 40, className = "" }) {
5382
- const [avatar, setAvatar] = (0, import_react36.useState)(void 0);
5383
- (0, import_react36.useEffect)(() => {
5890
+ const [avatar, setAvatar] = (0, import_react38.useState)(void 0);
5891
+ (0, import_react38.useEffect)(() => {
5384
5892
  if (name) {
5385
5893
  const char = name[0].toUpperCase();
5386
5894
  setAvatar(char);
@@ -5477,8 +5985,8 @@ function WalletAsset({
5477
5985
  }
5478
5986
 
5479
5987
  // src/components/TokenSend/index.tsx
5480
- var import_react37 = require("react");
5481
- var import_viem13 = require("viem");
5988
+ var import_react39 = require("react");
5989
+ var import_viem15 = require("viem");
5482
5990
  var import_react_intl19 = require("react-intl");
5483
5991
  var import_jsx_runtime95 = require("react/jsx-runtime");
5484
5992
  function Input2({
@@ -5515,33 +6023,33 @@ function TokenSend({
5515
6023
  const intl = (0, import_react_intl19.useIntl)();
5516
6024
  const { createWalletClient: createWalletClient2 } = useWallet();
5517
6025
  const isNative = token.address.toLowerCase() == NATIVE_TOKEN_ADDRESS;
5518
- const chain = (0, import_react37.useMemo)(() => {
6026
+ const chain = (0, import_react39.useMemo)(() => {
5519
6027
  return chainList?.find((m) => m.id.toString() === token.chain_id);
5520
6028
  }, [chainList, token.chain_id]);
5521
- const walletClient = (0, import_react37.useMemo)(() => {
6029
+ const walletClient = (0, import_react39.useMemo)(() => {
5522
6030
  return createWalletClient2({
5523
6031
  // @ts-ignore
5524
- chain: (0, import_viem13.defineChain)(chain),
5525
- transport: (0, import_viem13.http)()
6032
+ chain: (0, import_viem15.defineChain)(chain),
6033
+ transport: (0, import_viem15.http)()
5526
6034
  });
5527
6035
  }, [chain]);
5528
- const [amount, setAmount] = (0, import_react37.useState)("");
5529
- const [address, setAddress] = (0, import_react37.useState)("");
5530
- const [loading, setLoading] = (0, import_react37.useState)(false);
5531
- const [sending, setSending] = (0, import_react37.useState)(false);
5532
- const [txError, setTxError] = (0, import_react37.useState)("");
5533
- const transaction = (0, import_react37.useMemo)(() => {
6036
+ const [amount, setAmount] = (0, import_react39.useState)("");
6037
+ const [address, setAddress] = (0, import_react39.useState)("");
6038
+ const [loading, setLoading] = (0, import_react39.useState)(false);
6039
+ const [sending, setSending] = (0, import_react39.useState)(false);
6040
+ const [txError, setTxError] = (0, import_react39.useState)("");
6041
+ const transaction = (0, import_react39.useMemo)(() => {
5534
6042
  const reg = /^0x[a-fA-F0-9]{40}$/;
5535
6043
  if (!amount || !address || !reg.test(address)) {
5536
6044
  return;
5537
6045
  }
5538
- const viemChain = (0, import_viem13.defineChain)(chain);
6046
+ const viemChain = (0, import_viem15.defineChain)(chain);
5539
6047
  const to = isNative ? address : token.address;
5540
- const value = isNative ? (0, import_viem13.parseUnits)(amount, parseInt(token?.decimals || "18")) : BigInt(0);
5541
- const data = isNative ? "0x" : (0, import_viem13.encodeFunctionData)({
5542
- abi: import_viem13.erc20Abi,
6048
+ const value = isNative ? (0, import_viem15.parseUnits)(amount, parseInt(token?.decimals || "18")) : BigInt(0);
6049
+ const data = isNative ? "0x" : (0, import_viem15.encodeFunctionData)({
6050
+ abi: import_viem15.erc20Abi,
5543
6051
  functionName: "transfer",
5544
- args: [address, (0, import_viem13.parseUnits)(amount, parseInt(token?.decimals || "18"))]
6052
+ args: [address, (0, import_viem15.parseUnits)(amount, parseInt(token?.decimals || "18"))]
5545
6053
  });
5546
6054
  return {
5547
6055
  to,
@@ -5561,7 +6069,7 @@ function TokenSend({
5561
6069
  setLoading(false);
5562
6070
  }
5563
6071
  };
5564
- const error = (0, import_react37.useMemo)(() => {
6072
+ const error = (0, import_react39.useMemo)(() => {
5565
6073
  setTxError("");
5566
6074
  let amountError = "";
5567
6075
  let addressError = "";
@@ -5604,7 +6112,7 @@ function TokenSend({
5604
6112
  setAmount(value);
5605
6113
  }
5606
6114
  };
5607
- const canSend = (0, import_react37.useMemo)(() => {
6115
+ const canSend = (0, import_react39.useMemo)(() => {
5608
6116
  return !error.amount && !error.address && amount && address;
5609
6117
  }, [error]);
5610
6118
  const onNext = async () => {
@@ -5614,7 +6122,7 @@ function TokenSend({
5614
6122
  }
5615
6123
  onClose();
5616
6124
  };
5617
- (0, import_react37.useEffect)(() => {
6125
+ (0, import_react39.useEffect)(() => {
5618
6126
  const receiveMessage = (event) => {
5619
6127
  if (event.data) {
5620
6128
  if (event.data.source == "match-wallet") {
@@ -5746,7 +6254,7 @@ function TokenDetail({
5746
6254
  }
5747
6255
 
5748
6256
  // src/components/TokenSendList/index.tsx
5749
- var import_react38 = require("react");
6257
+ var import_react40 = require("react");
5750
6258
  var import_react_intl21 = require("react-intl");
5751
6259
  var import_jsx_runtime97 = require("react/jsx-runtime");
5752
6260
  function TokenSendList({ close }) {
@@ -5756,7 +6264,7 @@ function TokenSendList({ close }) {
5756
6264
  list: walletAssets.mergedAssets
5757
6265
  });
5758
6266
  const { list } = useMatchChain();
5759
- const [checked, setChecked] = (0, import_react38.useState)();
6267
+ const [checked, setChecked] = (0, import_react40.useState)();
5760
6268
  const modal = useModal();
5761
6269
  const onNext = () => {
5762
6270
  checked && modal.show((props) => {
@@ -5813,9 +6321,9 @@ function TokenSendList({ close }) {
5813
6321
 
5814
6322
  // src/components/TransactionList/index.tsx
5815
6323
  var import_react_infinite_scroll_component = __toESM(require("react-infinite-scroll-component"));
5816
- var import_react39 = require("react");
5817
- var import_viem14 = require("viem");
5818
- var import_viem15 = require("viem");
6324
+ var import_react41 = require("react");
6325
+ var import_viem16 = require("viem");
6326
+ var import_viem17 = require("viem");
5819
6327
  var import_react_intl22 = require("react-intl");
5820
6328
  var import_jsx_runtime98 = require("react/jsx-runtime");
5821
6329
  var Item = ({ data }) => {
@@ -5823,8 +6331,8 @@ var Item = ({ data }) => {
5823
6331
  const isOut = data.from.toLowerCase() == address.toLowerCase();
5824
6332
  const { chain, chainId, explorerLink, formatUnits: chainFormatUnits } = useMatchChain();
5825
6333
  const { contracts } = useContractStore_default();
5826
- const [shouldRefetch, setShouldRefetch] = (0, import_react39.useState)(true);
5827
- const transferType = (0, import_react39.useMemo)(() => {
6334
+ const [shouldRefetch, setShouldRefetch] = (0, import_react41.useState)(true);
6335
+ const transferType = (0, import_react41.useMemo)(() => {
5828
6336
  const methodId = data.input.substring(2, 10);
5829
6337
  if (methodId == "095ea7b3") {
5830
6338
  return "erc20_approve";
@@ -5834,38 +6342,38 @@ var Item = ({ data }) => {
5834
6342
  }
5835
6343
  return "unknown";
5836
6344
  }, [data.input]);
5837
- const to = (0, import_react39.useMemo)(() => {
6345
+ const to = (0, import_react41.useMemo)(() => {
5838
6346
  if (!isOut) {
5839
6347
  return data.from;
5840
6348
  }
5841
6349
  if (transferType == "erc20_transfer") {
5842
- const decodeData = (0, import_viem14.decodeFunctionData)({
5843
- abi: import_viem15.erc20Abi,
6350
+ const decodeData = (0, import_viem16.decodeFunctionData)({
6351
+ abi: import_viem17.erc20Abi,
5844
6352
  data: data.input
5845
6353
  });
5846
6354
  return decodeData.args[0];
5847
6355
  }
5848
6356
  return data.to;
5849
6357
  }, [data.input, transferType, data.to, isOut]);
5850
- const amount = (0, import_react39.useMemo)(() => {
6358
+ const amount = (0, import_react41.useMemo)(() => {
5851
6359
  if (transferType == "erc20_transfer") {
5852
- const decodeData = (0, import_viem14.decodeFunctionData)({
5853
- abi: import_viem15.erc20Abi,
6360
+ const decodeData = (0, import_viem16.decodeFunctionData)({
6361
+ abi: import_viem17.erc20Abi,
5854
6362
  data: data.input
5855
6363
  });
5856
6364
  const value = decodeData.args[1];
5857
- return (0, import_viem14.formatUnits)(value, contracts[`${chainId}-${data.to.toLowerCase()}`]?.decimals || 18);
6365
+ return (0, import_viem16.formatUnits)(value, contracts[`${chainId}-${data.to.toLowerCase()}`]?.decimals || 18);
5858
6366
  }
5859
6367
  return chainFormatUnits(BigInt(data.value));
5860
6368
  }, [data.input, transferType, data.value, contracts, chainId, data.to]);
5861
6369
  const hashQuery = useHash({
5862
6370
  hash: data.hash,
5863
6371
  //@ts-ignore
5864
- chain: (0, import_viem14.defineChain)(chain),
6372
+ chain: (0, import_viem16.defineChain)(chain),
5865
6373
  refetchInterval: shouldRefetch ? 3e3 : false,
5866
6374
  enabled: shouldRefetch && data.source == "local"
5867
6375
  });
5868
- const status = (0, import_react39.useMemo)(() => {
6376
+ const status = (0, import_react41.useMemo)(() => {
5869
6377
  if (data.source == "matchain") {
5870
6378
  switch (data.extra.status) {
5871
6379
  case "ok":
@@ -5892,12 +6400,12 @@ var Item = ({ data }) => {
5892
6400
  }
5893
6401
  return "loading";
5894
6402
  }, [data.extra?.status, data.source, hashQuery.data]);
5895
- (0, import_react39.useEffect)(() => {
6403
+ (0, import_react41.useEffect)(() => {
5896
6404
  if (data.hash) {
5897
6405
  setShouldRefetch(status == "loading");
5898
6406
  }
5899
6407
  }, [status, data.hash]);
5900
- const symbol = (0, import_react39.useMemo)(() => {
6408
+ const symbol = (0, import_react41.useMemo)(() => {
5901
6409
  if (transferType == "erc20_transfer") {
5902
6410
  const contract = contracts[`${chainId}-${data.to.toLowerCase()}`];
5903
6411
  return contract?.symbol || contract?.name || "unknown";
@@ -5973,10 +6481,10 @@ __export(contact_exports, {
5973
6481
  });
5974
6482
  var import_react_query13 = require("@tanstack/react-query");
5975
6483
  var import_last = __toESM(require("lodash/last"));
5976
- var import_react40 = require("react");
6484
+ var import_react42 = require("react");
5977
6485
  function useContactList(page_size = 10, type = "Friend") {
5978
6486
  const { token } = useLocalStore_default();
5979
- const limitIdRef = (0, import_react40.useRef)(0);
6487
+ const limitIdRef = (0, import_react42.useRef)(0);
5980
6488
  const queryClient2 = (0, import_react_query13.useQueryClient)();
5981
6489
  const contactQuery = (0, import_react_query13.useInfiniteQuery)({
5982
6490
  queryKey: ["matchid-contacts-list", type, token],
@@ -5998,7 +6506,7 @@ function useContactList(page_size = 10, type = "Friend") {
5998
6506
  return allPages.length >= lastPageNum ? void 0 : allPages.length + 1;
5999
6507
  }
6000
6508
  });
6001
- (0, import_react40.useEffect)(() => {
6509
+ (0, import_react42.useEffect)(() => {
6002
6510
  if (!contactQuery.data?.pages || contactQuery.data?.pages.length == 0) {
6003
6511
  limitIdRef.current = 0;
6004
6512
  } else {
@@ -6012,10 +6520,10 @@ function useContactList(page_size = 10, type = "Friend") {
6012
6520
  limitIdRef.current = lastItem?.limit_id || 0;
6013
6521
  }
6014
6522
  }, [contactQuery.data?.pages]);
6015
- (0, import_react40.useEffect)(() => {
6523
+ (0, import_react42.useEffect)(() => {
6016
6524
  console.log("contactQuery.data", contactQuery.data);
6017
6525
  }, [contactQuery.data]);
6018
- const data = (0, import_react40.useMemo)(() => {
6526
+ const data = (0, import_react42.useMemo)(() => {
6019
6527
  return (contactQuery.data?.pages ?? []).reduce(
6020
6528
  (a, b) => {
6021
6529
  return a.concat(b?.items ?? []);
@@ -6085,7 +6593,7 @@ var delContact = async (friend_id) => {
6085
6593
 
6086
6594
  // src/components/ContactList/index.tsx
6087
6595
  var import_react_virtuoso = require("react-virtuoso");
6088
- var import_react41 = require("react");
6596
+ var import_react43 = require("react");
6089
6597
  var import_react_intl23 = require("react-intl");
6090
6598
  var import_jsx_runtime99 = require("react/jsx-runtime");
6091
6599
  function ContactCard({
@@ -6106,7 +6614,7 @@ function ContactCard({
6106
6614
  ] });
6107
6615
  }
6108
6616
  function RequestAction({ data, onSuccess }) {
6109
- const [loading, setLoading] = (0, import_react41.useState)(false);
6617
+ const [loading, setLoading] = (0, import_react43.useState)(false);
6110
6618
  const toast = useToast();
6111
6619
  const intl = (0, import_react_intl23.useIntl)();
6112
6620
  const onApprove = async () => {
@@ -6130,7 +6638,7 @@ function FriendsAction({
6130
6638
  data,
6131
6639
  onSuccess
6132
6640
  }) {
6133
- const [loading, setLoading] = (0, import_react41.useState)(false);
6641
+ const [loading, setLoading] = (0, import_react43.useState)(false);
6134
6642
  const toast = useToast();
6135
6643
  const intl = (0, import_react_intl23.useIntl)();
6136
6644
  const onRemove = async () => {
@@ -6156,9 +6664,9 @@ function ContactList({
6156
6664
  type = "Friend"
6157
6665
  }) {
6158
6666
  const { loading, totalCount, data, onLoadMore } = contact_exports.useContactList(limit, type);
6159
- const [hiddenList, setHiddenList] = (0, import_react41.useState)([]);
6667
+ const [hiddenList, setHiddenList] = (0, import_react43.useState)([]);
6160
6668
  const { address } = useWallet();
6161
- (0, import_react41.useEffect)(() => {
6669
+ (0, import_react43.useEffect)(() => {
6162
6670
  setHiddenList([]);
6163
6671
  }, [type]);
6164
6672
  return /* @__PURE__ */ (0, import_jsx_runtime99.jsx)(