@xyo-network/react-wallet 2.71.0 → 2.71.2

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 (133) hide show
  1. package/dist/browser/components/WalletAccountSelect/WalletInfo.d.cts +1 -0
  2. package/dist/browser/components/WalletAccountSelect/WalletInfo.d.cts.map +1 -1
  3. package/dist/browser/components/WalletAccountSelect/WalletInfo.d.mts +1 -0
  4. package/dist/browser/components/WalletAccountSelect/WalletInfo.d.mts.map +1 -1
  5. package/dist/browser/components/WalletAccountSelect/WalletInfo.d.ts +1 -0
  6. package/dist/browser/components/WalletAccountSelect/WalletInfo.d.ts.map +1 -1
  7. package/dist/browser/components/WalletAccountSelect/stories/WalletProviderDecorator.d.cts +3 -0
  8. package/dist/browser/components/WalletAccountSelect/stories/WalletProviderDecorator.d.cts.map +1 -0
  9. package/dist/browser/components/WalletAccountSelect/stories/WalletProviderDecorator.d.mts +3 -0
  10. package/dist/browser/components/WalletAccountSelect/stories/WalletProviderDecorator.d.mts.map +1 -0
  11. package/dist/browser/components/WalletAccountSelect/stories/WalletProviderDecorator.d.ts +3 -0
  12. package/dist/browser/components/WalletAccountSelect/stories/WalletProviderDecorator.d.ts.map +1 -0
  13. package/dist/browser/components/WalletAccountSelect/stories/index.d.cts +2 -0
  14. package/dist/browser/components/WalletAccountSelect/stories/index.d.cts.map +1 -0
  15. package/dist/browser/components/WalletAccountSelect/stories/index.d.mts +2 -0
  16. package/dist/browser/components/WalletAccountSelect/stories/index.d.mts.map +1 -0
  17. package/dist/browser/components/WalletAccountSelect/stories/index.d.ts +2 -0
  18. package/dist/browser/components/WalletAccountSelect/stories/index.d.ts.map +1 -0
  19. package/dist/browser/contexts/Wallet/Provider.d.cts +1 -0
  20. package/dist/browser/contexts/Wallet/Provider.d.cts.map +1 -1
  21. package/dist/browser/contexts/Wallet/Provider.d.mts +1 -0
  22. package/dist/browser/contexts/Wallet/Provider.d.mts.map +1 -1
  23. package/dist/browser/contexts/Wallet/Provider.d.ts +1 -0
  24. package/dist/browser/contexts/Wallet/Provider.d.ts.map +1 -1
  25. package/dist/browser/contexts/Wallet/State.d.cts +2 -0
  26. package/dist/browser/contexts/Wallet/State.d.cts.map +1 -1
  27. package/dist/browser/contexts/Wallet/State.d.mts +2 -0
  28. package/dist/browser/contexts/Wallet/State.d.mts.map +1 -1
  29. package/dist/browser/contexts/Wallet/State.d.ts +2 -0
  30. package/dist/browser/contexts/Wallet/State.d.ts.map +1 -1
  31. package/dist/browser/contexts/Wallet/index.d.cts +0 -1
  32. package/dist/browser/contexts/Wallet/index.d.cts.map +1 -1
  33. package/dist/browser/contexts/Wallet/index.d.mts +0 -1
  34. package/dist/browser/contexts/Wallet/index.d.mts.map +1 -1
  35. package/dist/browser/contexts/Wallet/index.d.ts +0 -1
  36. package/dist/browser/contexts/Wallet/index.d.ts.map +1 -1
  37. package/dist/browser/contexts/Wallet/use.d.cts +1 -0
  38. package/dist/browser/contexts/Wallet/use.d.cts.map +1 -1
  39. package/dist/browser/contexts/Wallet/use.d.mts +1 -0
  40. package/dist/browser/contexts/Wallet/use.d.mts.map +1 -1
  41. package/dist/browser/contexts/Wallet/use.d.ts +1 -0
  42. package/dist/browser/contexts/Wallet/use.d.ts.map +1 -1
  43. package/dist/browser/index.cjs +18 -53
  44. package/dist/browser/index.cjs.map +1 -1
  45. package/dist/browser/index.js +18 -53
  46. package/dist/browser/index.js.map +1 -1
  47. package/dist/node/components/WalletAccountSelect/WalletInfo.d.cts +1 -0
  48. package/dist/node/components/WalletAccountSelect/WalletInfo.d.cts.map +1 -1
  49. package/dist/node/components/WalletAccountSelect/WalletInfo.d.mts +1 -0
  50. package/dist/node/components/WalletAccountSelect/WalletInfo.d.mts.map +1 -1
  51. package/dist/node/components/WalletAccountSelect/WalletInfo.d.ts +1 -0
  52. package/dist/node/components/WalletAccountSelect/WalletInfo.d.ts.map +1 -1
  53. package/dist/node/components/WalletAccountSelect/stories/WalletProviderDecorator.d.cts +3 -0
  54. package/dist/node/components/WalletAccountSelect/stories/WalletProviderDecorator.d.cts.map +1 -0
  55. package/dist/node/components/WalletAccountSelect/stories/WalletProviderDecorator.d.mts +3 -0
  56. package/dist/node/components/WalletAccountSelect/stories/WalletProviderDecorator.d.mts.map +1 -0
  57. package/dist/node/components/WalletAccountSelect/stories/WalletProviderDecorator.d.ts +3 -0
  58. package/dist/node/components/WalletAccountSelect/stories/WalletProviderDecorator.d.ts.map +1 -0
  59. package/dist/node/components/WalletAccountSelect/stories/index.d.cts +2 -0
  60. package/dist/node/components/WalletAccountSelect/stories/index.d.cts.map +1 -0
  61. package/dist/node/components/WalletAccountSelect/stories/index.d.mts +2 -0
  62. package/dist/node/components/WalletAccountSelect/stories/index.d.mts.map +1 -0
  63. package/dist/node/components/WalletAccountSelect/stories/index.d.ts +2 -0
  64. package/dist/node/components/WalletAccountSelect/stories/index.d.ts.map +1 -0
  65. package/dist/node/contexts/Wallet/Provider.d.cts +1 -0
  66. package/dist/node/contexts/Wallet/Provider.d.cts.map +1 -1
  67. package/dist/node/contexts/Wallet/Provider.d.mts +1 -0
  68. package/dist/node/contexts/Wallet/Provider.d.mts.map +1 -1
  69. package/dist/node/contexts/Wallet/Provider.d.ts +1 -0
  70. package/dist/node/contexts/Wallet/Provider.d.ts.map +1 -1
  71. package/dist/node/contexts/Wallet/State.d.cts +2 -0
  72. package/dist/node/contexts/Wallet/State.d.cts.map +1 -1
  73. package/dist/node/contexts/Wallet/State.d.mts +2 -0
  74. package/dist/node/contexts/Wallet/State.d.mts.map +1 -1
  75. package/dist/node/contexts/Wallet/State.d.ts +2 -0
  76. package/dist/node/contexts/Wallet/State.d.ts.map +1 -1
  77. package/dist/node/contexts/Wallet/index.d.cts +0 -1
  78. package/dist/node/contexts/Wallet/index.d.cts.map +1 -1
  79. package/dist/node/contexts/Wallet/index.d.mts +0 -1
  80. package/dist/node/contexts/Wallet/index.d.mts.map +1 -1
  81. package/dist/node/contexts/Wallet/index.d.ts +0 -1
  82. package/dist/node/contexts/Wallet/index.d.ts.map +1 -1
  83. package/dist/node/contexts/Wallet/use.d.cts +1 -0
  84. package/dist/node/contexts/Wallet/use.d.cts.map +1 -1
  85. package/dist/node/contexts/Wallet/use.d.mts +1 -0
  86. package/dist/node/contexts/Wallet/use.d.mts.map +1 -1
  87. package/dist/node/contexts/Wallet/use.d.ts +1 -0
  88. package/dist/node/contexts/Wallet/use.d.ts.map +1 -1
  89. package/dist/node/index.cjs +18 -56
  90. package/dist/node/index.cjs.map +1 -1
  91. package/dist/node/index.js +18 -53
  92. package/dist/node/index.js.map +1 -1
  93. package/package.json +8 -8
  94. package/src/components/WalletAccountSelect/Select.tsx +5 -5
  95. package/src/components/WalletAccountSelect/WalletAccountSelect.stories.tsx +5 -8
  96. package/src/components/WalletAccountSelect/WalletAccountSelectBar.stories.tsx +9 -19
  97. package/src/components/WalletAccountSelect/WalletAccountSelectWithProvider.stories.tsx +3 -9
  98. package/src/components/WalletAccountSelect/WalletInfo.tsx +1 -0
  99. package/src/components/WalletAccountSelect/stories/WalletProviderDecorator.tsx +15 -0
  100. package/src/components/WalletAccountSelect/stories/index.ts +1 -0
  101. package/src/contexts/Wallet/Provider.tsx +6 -25
  102. package/src/contexts/Wallet/State.ts +2 -0
  103. package/src/contexts/Wallet/index.ts +0 -1
  104. package/src/contexts/Wallet/use.ts +3 -2
  105. package/src/hooks/useAccount.ts +5 -5
  106. package/src/hooks/useWallet.ts +2 -2
  107. package/src/hooks/useWallets.ts +2 -2
  108. package/dist/browser/contexts/Wallet/lib/WalletPath.d.cts +0 -13
  109. package/dist/browser/contexts/Wallet/lib/WalletPath.d.cts.map +0 -1
  110. package/dist/browser/contexts/Wallet/lib/WalletPath.d.mts +0 -13
  111. package/dist/browser/contexts/Wallet/lib/WalletPath.d.mts.map +0 -1
  112. package/dist/browser/contexts/Wallet/lib/WalletPath.d.ts +0 -13
  113. package/dist/browser/contexts/Wallet/lib/WalletPath.d.ts.map +0 -1
  114. package/dist/browser/contexts/Wallet/lib/index.d.cts +0 -2
  115. package/dist/browser/contexts/Wallet/lib/index.d.cts.map +0 -1
  116. package/dist/browser/contexts/Wallet/lib/index.d.mts +0 -2
  117. package/dist/browser/contexts/Wallet/lib/index.d.mts.map +0 -1
  118. package/dist/browser/contexts/Wallet/lib/index.d.ts +0 -2
  119. package/dist/browser/contexts/Wallet/lib/index.d.ts.map +0 -1
  120. package/dist/node/contexts/Wallet/lib/WalletPath.d.cts +0 -13
  121. package/dist/node/contexts/Wallet/lib/WalletPath.d.cts.map +0 -1
  122. package/dist/node/contexts/Wallet/lib/WalletPath.d.mts +0 -13
  123. package/dist/node/contexts/Wallet/lib/WalletPath.d.mts.map +0 -1
  124. package/dist/node/contexts/Wallet/lib/WalletPath.d.ts +0 -13
  125. package/dist/node/contexts/Wallet/lib/WalletPath.d.ts.map +0 -1
  126. package/dist/node/contexts/Wallet/lib/index.d.cts +0 -2
  127. package/dist/node/contexts/Wallet/lib/index.d.cts.map +0 -1
  128. package/dist/node/contexts/Wallet/lib/index.d.mts +0 -2
  129. package/dist/node/contexts/Wallet/lib/index.d.mts.map +0 -1
  130. package/dist/node/contexts/Wallet/lib/index.d.ts +0 -2
  131. package/dist/node/contexts/Wallet/lib/index.d.ts.map +0 -1
  132. package/src/contexts/Wallet/lib/WalletPath.ts +0 -17
  133. package/src/contexts/Wallet/lib/index.ts +0 -1
@@ -255,29 +255,12 @@ var useSeedPhrase = () => useContextEx(SeedPhraseContext, "SeedPhrase", true);
255
255
  import { createContextEx as createContextEx2 } from "@xyo-network/react-shared";
256
256
  var WalletContext = createContextEx2();
257
257
 
258
- // src/contexts/Wallet/lib/WalletPath.ts
259
- var Bip44 = {
260
- base: "m",
261
- coin_type: {
262
- /* https://github.com/satoshilabs/slips/blob/master/slip-0044.md */
263
- bitcoin: "0'",
264
- bitcoinTestnet: "1'",
265
- ether: "60'",
266
- etherClassic: "61'"
267
- },
268
- purpose: "44'"
269
- };
270
- var WalletRootPath = `${Bip44.base}/${Bip44.purpose}/${Bip44.coin_type.ether}`;
271
- var ethereumAccountPath = (index, hardened = true) => {
272
- return `${WalletRootPath}/${index}${hardened ? "'" : ""}/0`;
273
- };
274
-
275
258
  // src/contexts/Wallet/Provider.tsx
276
259
  import { usePromise } from "@xylabs/react-promise";
277
260
  import { useEffect as useEffect3, useState as useState5 } from "react";
278
261
  import { jsx as jsx6 } from "react/jsx-runtime";
279
262
  var WalletProvider = ({
280
- basePath = WalletRootPath,
263
+ basePath,
281
264
  children,
282
265
  defaultActiveAccountIndex = 0,
283
266
  rootWallet = null,
@@ -289,24 +272,7 @@ var WalletProvider = ({
289
272
  setActiveAccountIndex(defaultActiveAccountIndex);
290
273
  }
291
274
  }, [defaultActiveAccountIndex]);
292
- const [coinTypeWallet = null] = usePromise(async () => {
293
- if (rootWallet) {
294
- if ((rootWallet == null ? void 0 : rootWallet.path) !== basePath) {
295
- try {
296
- const result = await (rootWallet == null ? void 0 : rootWallet.derivePath(basePath));
297
- return result;
298
- } catch (e) {
299
- console.error("Error setting proper wallet base path", e);
300
- }
301
- }
302
- } else {
303
- return rootWallet;
304
- }
305
- }, [basePath, rootWallet]);
306
- const [activeAccount = null] = usePromise(
307
- async () => await (coinTypeWallet == null ? void 0 : coinTypeWallet.derivePath(activeAccountIndex.toString())),
308
- [coinTypeWallet, activeAccountIndex]
309
- );
275
+ const [activeAccount = null] = usePromise(async () => await (rootWallet == null ? void 0 : rootWallet.derivePath(activeAccountIndex.toString())), [activeAccountIndex, rootWallet]);
310
276
  return /* @__PURE__ */ jsx6(
311
277
  WalletContext.Provider,
312
278
  {
@@ -314,7 +280,9 @@ var WalletProvider = ({
314
280
  activeAccount,
315
281
  activeAccountIndex,
316
282
  basePath,
317
- coinTypeWallet,
283
+ /* eslint-disable deprecation/deprecation */
284
+ /** @deprecated - Set path for coinTypeWallet outside of provider and pass as rootWallet */
285
+ coinTypeWallet: null,
318
286
  provided: true,
319
287
  rootWallet,
320
288
  setActiveAccountIndex
@@ -343,8 +311,8 @@ var useRootWallet = (required = true) => {
343
311
  return [rootWallet, void 0];
344
312
  };
345
313
  var useIndexedWalletFromContext = (index, required = true) => {
346
- const [coinTypeWallet] = useCoinTypeWallet(required);
347
- const [wallet] = usePromise2(async () => await (coinTypeWallet == null ? void 0 : coinTypeWallet.derivePath(index.toString())) ?? coinTypeWallet, [coinTypeWallet, index]);
314
+ const { rootWallet } = useWalletContext(required);
315
+ const [wallet] = usePromise2(async () => await (rootWallet == null ? void 0 : rootWallet.derivePath(index.toString())) ?? rootWallet, [rootWallet, index]);
348
316
  return [wallet, void 0];
349
317
  };
350
318
  var useSelectedWalletAccount = (required = true) => {
@@ -593,7 +561,7 @@ var useAccount = ({ wallet, account, index, required = false } = {}) => {
593
561
  setValidationError(new Error("useAccount can not have both a index and an account in the parameters"));
594
562
  }
595
563
  const [error, setError] = useState8();
596
- const [coinTypeWallet] = useCoinTypeWallet(!wallet && required);
564
+ const [rootWallet] = useRootWallet(!wallet && required);
597
565
  const { activeAccountIndex } = useWalletContext(false);
598
566
  const [activeAccount] = usePromise3(async () => {
599
567
  var _a, _b;
@@ -601,8 +569,8 @@ var useAccount = ({ wallet, account, index, required = false } = {}) => {
601
569
  if (!validationError) {
602
570
  if (wallet) {
603
571
  return await ((_a = wallet == null ? void 0 : wallet.derivePath) == null ? void 0 : _a.call(wallet, `${index ?? 0}'\0`));
604
- } else if (coinTypeWallet) {
605
- return await ((_b = coinTypeWallet == null ? void 0 : coinTypeWallet.derivePath) == null ? void 0 : _b.call(coinTypeWallet, `${index ?? activeAccountIndex ?? 0}'\0`));
572
+ } else if (rootWallet) {
573
+ return await ((_b = rootWallet == null ? void 0 : rootWallet.derivePath) == null ? void 0 : _b.call(rootWallet, `${index ?? activeAccountIndex ?? 0}'\0`));
606
574
  }
607
575
  }
608
576
  } catch (ex) {
@@ -610,7 +578,7 @@ var useAccount = ({ wallet, account, index, required = false } = {}) => {
610
578
  console.error(error2.message);
611
579
  setError(error2);
612
580
  }
613
- }, [index, wallet, coinTypeWallet, activeAccountIndex, validationError]);
581
+ }, [index, wallet, rootWallet, activeAccountIndex, validationError]);
614
582
  if (validationError && !error) {
615
583
  console.error(validationError.message);
616
584
  setError(validationError);
@@ -626,7 +594,7 @@ import { usePromise as usePromise4 } from "@xylabs/react-promise";
626
594
  import { HDWallet } from "@xyo-network/account";
627
595
  import { useState as useState9 } from "react";
628
596
  var useWallet = ({ mnemonic, wallet, path, required = false, seed } = {}) => {
629
- const walletContextProvided = useWalletProvided();
597
+ const walletContextProvided = useWalletContext(false);
630
598
  const [error, setError] = useState9();
631
599
  const [contextAccount] = useSelectedWalletAccount(!wallet && required);
632
600
  const [activeAccount] = usePromise4(async () => {
@@ -653,7 +621,7 @@ var useWallet = ({ mnemonic, wallet, path, required = false, seed } = {}) => {
653
621
  // src/hooks/useWallets.ts
654
622
  import { usePromise as usePromise5 } from "@xylabs/react-promise";
655
623
  var useWallets = ({ wallet, paths }) => {
656
- const walletContextProvided = useWalletProvided();
624
+ const walletContextProvided = useWalletContext(false);
657
625
  const [foundWallet] = useWallet({ wallet });
658
626
  const [wallets, error] = usePromise5(
659
627
  async () => foundWallet ? await Promise.all(paths.map((path) => foundWallet.derivePath(path))) : void 0,
@@ -725,16 +693,16 @@ var WalletAccountSelect = ({
725
693
  variant = "outlined",
726
694
  ...props
727
695
  }) => {
728
- const { activeAccountIndex = 0, setActiveAccountIndex, coinTypeWallet } = useWalletContext();
729
- const disabled = !coinTypeWallet || activeAccountIndex === void 0;
730
- return /* @__PURE__ */ jsx17(Fragment5, { children: coinTypeWallet ? /* @__PURE__ */ jsx17(
696
+ const { activeAccountIndex = 0, setActiveAccountIndex, rootWallet } = useWalletContext();
697
+ const disabled = !rootWallet || activeAccountIndex === void 0;
698
+ return /* @__PURE__ */ jsx17(Fragment5, { children: rootWallet ? /* @__PURE__ */ jsx17(
731
699
  SelectEx,
732
700
  {
733
701
  margin: "dense",
734
702
  disabled,
735
703
  renderValue: (selectedAccountIndex) => {
736
704
  const Item = () => {
737
- const [selectedAccount] = useWallet({ path: selectedAccountIndex.toString(), wallet: coinTypeWallet });
705
+ const [selectedAccount] = useWallet({ path: selectedAccountIndex.toString(), wallet: rootWallet });
738
706
  const customName = selectedAccount ? addressNames[selectedAccount.address] : void 0;
739
707
  const favorite = !!selectedAccount && selectedAccount.address in addressNames;
740
708
  return /* @__PURE__ */ jsx17(MenuItem, { value: selectedAccountIndex, sx: { minHeight: 0, paddingBottom: 0, paddingTop: 0 }, children: /* @__PURE__ */ jsx17(
@@ -761,7 +729,7 @@ var WalletAccountSelect = ({
761
729
  ...props,
762
730
  children: arrayRange(maxAccounts).map((index) => {
763
731
  const Item = () => {
764
- const [account] = useWallet({ path: index.toString(), wallet: coinTypeWallet });
732
+ const [account] = useWallet({ path: index.toString(), wallet: rootWallet });
765
733
  const customName = account ? addressNames[account.address] : void 0;
766
734
  const favorite = !!account && account.address in addressNames;
767
735
  return /* @__PURE__ */ jsx17(MenuItem, { value: index, sx: { minHeight: 0, paddingBottom: 0, paddingTop: 0 }, children: /* @__PURE__ */ jsx17(
@@ -814,7 +782,6 @@ var WalletAccountSelectBar = ({
814
782
  ) });
815
783
  };
816
784
  export {
817
- Bip44,
818
785
  DefaultSeedPhrase,
819
786
  DialogActionButtons,
820
787
  InvalidPhraseTypography,
@@ -835,9 +802,7 @@ export {
835
802
  WalletAccountSelectBar,
836
803
  WalletContext,
837
804
  WalletProvider,
838
- WalletRootPath,
839
805
  colorParser,
840
- ethereumAccountPath,
841
806
  useAccount,
842
807
  useCoinTypeWallet,
843
808
  useIndexedWalletFromContext,
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/components/MaxAccounts/MaxAccountsTableRow.tsx","../../src/components/MaxAccounts/OutOfBoundsSnackBar.tsx","../../src/components/SeedPhrase/_shared/SeedPhraseIconButton.tsx","../../src/components/SeedPhrase/DefaultSeedPhrase.tsx","../../src/components/SeedPhrase/dialog/components/DialogActionButtons.tsx","../../src/contexts/SeedPhrase/Context.ts","../../src/contexts/SeedPhrase/Provider.tsx","../../src/contexts/SeedPhrase/use.tsx","../../src/contexts/Wallet/Context.ts","../../src/contexts/Wallet/lib/WalletPath.ts","../../src/contexts/Wallet/Provider.tsx","../../src/contexts/Wallet/use.ts","../../src/components/SeedPhrase/dialog/components/fields/NewPhraseTextField.tsx","../../src/components/SeedPhrase/dialog/components/fields/validation-messages/colorParser.ts","../../src/components/SeedPhrase/dialog/components/fields/validation-messages/InvalidPhrase.tsx","../../src/components/SeedPhrase/dialog/components/fields/validation-messages/PhraseHeaderBox.tsx","../../src/components/SeedPhrase/dialog/components/fields/PhraseDialogActions.tsx","../../src/components/SeedPhrase/dialog/components/fields/SavedPhraseTextField.tsx","../../src/components/SeedPhrase/dialog/components/OverwriteWarning.tsx","../../src/components/SeedPhrase/dialog/SeedPhraseDialog.tsx","../../src/components/SeedPhrase/settings/SeedPhraseTableRow.tsx","../../src/components/WalletAccountDetails/WalletAccountDetails.tsx","../../src/hooks/useAccount.ts","../../src/hooks/useWallet.ts","../../src/hooks/useWallets.ts","../../src/hooks/useWrapperAccount.ts","../../src/components/WalletAccountSelect/Select.tsx","../../src/components/WalletAccountSelect/SelectBar.tsx"],"sourcesContent":["import { ButtonGroup, TableCell, TableRow, TableRowProps, Typography } from '@mui/material'\nimport { ButtonEx } from '@xylabs/react-button'\nimport { useState } from 'react'\n\nimport { OutOfBoundsSnackBar } from './OutOfBoundsSnackBar'\n\nexport interface MaxAccountsTableRow extends TableRowProps {\n activeAccountIndex?: number\n changeMaxAccounts?: (maxAccounts: number) => void\n maxAccounts?: number\n}\n\nexport const MaxAccountsTableRow: React.FC<MaxAccountsTableRow> = ({ activeAccountIndex, changeMaxAccounts, maxAccounts }) => {\n const [desiredMaximumAccounts, setDesiredMaximumAccounts] = useState<number | undefined>()\n const [showSnackBar, setShowSnackBar] = useState(false)\n\n const handleChangeMaxAccounts = (change: 'increase' | 'decrease') => {\n if (maxAccounts !== undefined && activeAccountIndex !== undefined) {\n switch (change) {\n case 'decrease': {\n const desiredMaximumAccounts = maxAccounts - 1\n const validMaximumAccounts = desiredMaximumAccounts > 0\n const maxAccountsWithinRange = activeAccountIndex + 1 <= desiredMaximumAccounts\n if (validMaximumAccounts && maxAccountsWithinRange) {\n changeMaxAccounts?.(desiredMaximumAccounts)\n }\n if (!maxAccountsWithinRange) setShowSnackBar(true)\n setDesiredMaximumAccounts(desiredMaximumAccounts)\n return\n }\n case 'increase': {\n changeMaxAccounts?.(maxAccounts + 1)\n return\n }\n default: {\n console.error(change, 'is not a recognized value')\n }\n }\n } else {\n throw new Error('Max Accounts is unset and needs a default')\n }\n }\n\n return (\n <TableRow>\n <TableCell>Maximum Accounts</TableCell>\n <TableCell align=\"center\">\n <Typography variant={'caption'}>{maxAccounts}</Typography>\n </TableCell>\n <TableCell align=\"center\">\n <ButtonGroup>\n <ButtonEx onClick={() => handleChangeMaxAccounts('decrease')} variant={'contained'} size={'small'}>\n -\n </ButtonEx>\n <ButtonEx onClick={() => handleChangeMaxAccounts('increase')} variant={'contained'} size={'small'}>\n +\n </ButtonEx>\n </ButtonGroup>\n <OutOfBoundsSnackBar\n desiredMaximumAccounts={desiredMaximumAccounts}\n activeAccountIndex={activeAccountIndex}\n setShowSnackBar={setShowSnackBar}\n showSnackBar={showSnackBar}\n />\n </TableCell>\n </TableRow>\n )\n}\n","import { Alert, AlertTitle, Snackbar, SnackbarProps } from '@mui/material'\nimport { Dispatch, SetStateAction } from 'react'\n\nexport interface OutOfBoundsSnackBarProps extends SnackbarProps {\n activeAccountIndex?: number\n desiredMaximumAccounts?: number\n setShowSnackBar?: Dispatch<SetStateAction<boolean>>\n showSnackBar?: boolean\n}\n\nexport const OutOfBoundsSnackBar: React.FC<OutOfBoundsSnackBarProps> = ({\n activeAccountIndex,\n desiredMaximumAccounts,\n setShowSnackBar,\n showSnackBar,\n}) => {\n return (\n <Snackbar\n anchorOrigin={{ horizontal: 'center', vertical: 'top' }}\n autoHideDuration={5000}\n onClose={() => setShowSnackBar?.(false)}\n open={showSnackBar}\n >\n <Alert severity={'error'} onClose={() => setShowSnackBar?.(false)}>\n <AlertTitle>Maximum Accounts Error</AlertTitle>\n Your currently selected account number ({activeAccountIndex === undefined ? '' : activeAccountIndex + 1}) cannot be greater than the desired\n Maximum Accounts ({desiredMaximumAccounts}).\n </Alert>\n </Snackbar>\n )\n}\n","import { HelpOutline as HelpOutlineIcon } from '@mui/icons-material'\nimport {\n Button,\n Dialog,\n DialogActions,\n DialogContent,\n DialogTitle,\n IconButton,\n IconButtonProps,\n Link,\n List,\n ListItem,\n Typography,\n} from '@mui/material'\nimport { useState } from 'react'\n\nexport const SeedPhraseIconButton: React.FC<IconButtonProps> = (props) => {\n const [open, setOpen] = useState(false)\n const onClose = () => setOpen(false)\n return (\n <>\n <IconButton onClick={() => setOpen(true)} {...props}>\n <HelpOutlineIcon fontSize=\"small\" />\n </IconButton>\n <Dialog open={open}>\n <DialogTitle>Understanding your Seed Phrase</DialogTitle>\n <DialogContent>\n <Typography>\n Your Seed Phrase should adhere to the{' '}\n <Link target={'_blank'} href=\"https://github.com/bitcoin/bips/blob/master/bip-0039.mediawiki\">\n bip39 specification\n </Link>{' '}\n and is used to generate accounts which identify your data on the XYO Network.\n </Typography>\n <List>\n <ListItem>Do not share this phrase with anyone.</ListItem>\n <ListItem>Do not save it to a public computer.</ListItem>\n <ListItem>Do not use a existing phrase from another wallet (i.e. Metamask).</ListItem>\n <ListItem>Do not use before copying it down somewhere safe.</ListItem>\n </List>\n </DialogContent>\n <DialogActions>\n <Button onClick={onClose} variant=\"outlined\">\n OK\n </Button>\n </DialogActions>\n </Dialog>\n </>\n )\n}\n","import { Alert, AlertTitle, Snackbar } from '@mui/material'\nimport { generateMnemonic } from '@scure/bip39'\n// eslint-disable-next-line import/no-internal-modules\nimport { wordlist } from '@scure/bip39/wordlists/english'\nimport { WithChildren } from '@xylabs/react-shared'\nimport { useEffect, useState } from 'react'\n\nexport interface DefaultSeedPhraseProps extends WithChildren {\n changeSeedPhrase?: (seedPhrase: string) => void\n hideDefaultSeedPhraseMessage?: boolean\n seedPhrase?: string\n}\n\nexport const DefaultSeedPhrase: React.FC<DefaultSeedPhraseProps> = ({ changeSeedPhrase, children, hideDefaultSeedPhraseMessage, seedPhrase }) => {\n const [showSnackBar, setShowSnackBar] = useState(false)\n\n useEffect(() => {\n if (!seedPhrase) {\n const mnemonic = generateMnemonic(wordlist, 256)\n changeSeedPhrase?.(mnemonic)\n setShowSnackBar(true)\n }\n }, [changeSeedPhrase, seedPhrase])\n\n return (\n <>\n {hideDefaultSeedPhraseMessage ? null : (\n <Snackbar\n open={showSnackBar}\n autoHideDuration={5000}\n onClose={() => setShowSnackBar(false)}\n anchorOrigin={{ horizontal: 'center', vertical: 'top' }}\n >\n <Alert severity={'success'}>\n <AlertTitle>Default Seed Phrase Generated</AlertTitle>\n Go to application settings to save it.\n </Alert>\n </Snackbar>\n )}\n {children}\n </>\n )\n}\n","import { Button, DialogActions, DialogActionsProps, DialogProps } from '@mui/material'\nimport { MouseEvent } from 'react'\n\nimport { useSeedPhrase } from '../../../../contexts'\n\ninterface DialogActionButtonsProps extends DialogActionsProps {\n onClose?: DialogProps['onClose']\n}\n\nexport const DialogActionButtons: React.FC<DialogActionButtonsProps> = ({ onClose, ...props }) => {\n const { handleSave, setPhrase } = useSeedPhrase()\n\n const wrappedOnClose = (e: MouseEvent<HTMLElement>) => {\n // clear local copy of phrase when modal closes\n setPhrase?.('')\n onClose?.(e, 'escapeKeyDown')\n }\n\n return (\n <DialogActions {...props}>\n <Button variant=\"outlined\" onClick={wrappedOnClose}>\n Cancel\n </Button>\n <Button variant=\"outlined\" onClick={handleSave}>\n Save\n </Button>\n </DialogActions>\n )\n}\n","import { createContextEx } from '@xyo-network/react-shared'\n\nimport { SeedPhraseContextState } from './State'\n\nexport const SeedPhraseContext = createContextEx<SeedPhraseContextState>()\n","import { generateMnemonic, validateMnemonic } from '@scure/bip39'\n// eslint-disable-next-line import/no-internal-modules\nimport { wordlist } from '@scure/bip39/wordlists/english'\nimport { WithChildren } from '@xylabs/react-shared'\nimport { useCallback, useEffect, useMemo, useState } from 'react'\n\nimport { SeedPhraseContext } from './Context'\n\nexport interface SeedPhraseProviderProps extends WithChildren {\n defaultPhrase?: string\n handleChangeSeedPhrase?: (phrase: string) => void\n open?: boolean\n saveCallback?: () => void\n seedPhrase?: string\n}\n\nconst validate = (passedPhrase?: string) => {\n if (!passedPhrase) {\n return null\n }\n return validateMnemonic(passedPhrase, wordlist)\n}\n\nexport const SeedPhraseProvider: React.FC<SeedPhraseProviderProps> = ({\n children,\n defaultPhrase,\n handleChangeSeedPhrase,\n saveCallback,\n seedPhrase,\n open,\n}) => {\n const [phrase, setPhrase] = useState<string | undefined>()\n const [overwriteWarning, setOverwriteWarning] = useState(false)\n\n useEffect(() => {\n setPhrase(defaultPhrase)\n }, [defaultPhrase])\n\n useEffect(() => {\n if (seedPhrase || open) {\n setPhrase?.(seedPhrase ?? '')\n }\n }, [seedPhrase, open, setPhrase])\n\n const handleGenerate = useCallback(() => {\n const mnemonic = generateMnemonic(wordlist, 256)\n setPhrase?.(mnemonic)\n setOverwriteWarning?.(false)\n }, [])\n\n const handleCancelOverwrite = useCallback(() => {\n setOverwriteWarning?.(false)\n }, [])\n\n const handleClear = useCallback(() => {\n setPhrase?.('')\n setOverwriteWarning?.(false)\n }, [])\n\n const handleSave = useCallback(() => {\n if (!overwriteWarning && seedPhrase && seedPhrase !== phrase) {\n setOverwriteWarning?.(true)\n } else {\n handleChangeSeedPhrase?.(phrase ?? '')\n saveCallback?.()\n }\n }, [handleChangeSeedPhrase, overwriteWarning, phrase, saveCallback, seedPhrase])\n\n useEffect(() => {\n if (!open) {\n handleCancelOverwrite()\n }\n }, [handleCancelOverwrite, open])\n\n const validSeedPhrase = useMemo(() => validate?.(seedPhrase), [seedPhrase])\n const validPhrase = useMemo(() => validate?.(phrase), [phrase])\n\n return (\n <SeedPhraseContext.Provider\n value={{\n handleCancelOverwrite,\n handleChangeSeedPhrase,\n handleClear,\n handleGenerate,\n handleSave,\n overwriteWarning,\n phrase,\n provided: true,\n seedPhrase,\n setOverwriteWarning,\n setPhrase,\n validPhrase,\n validSeedPhrase,\n validate,\n }}\n >\n {children}\n </SeedPhraseContext.Provider>\n )\n}\n","import { useContextEx } from '@xyo-network/react-shared'\n\nimport { SeedPhraseContext } from './Context'\n\nexport const useSeedPhrase = () => useContextEx(SeedPhraseContext, 'SeedPhrase', true)\n","import { createContextEx } from '@xyo-network/react-shared'\n\nimport { WalletContextState } from './State'\n\nexport const WalletContext = createContextEx<WalletContextState>()\n","export const Bip44 = {\n base: 'm',\n coin_type: {\n /* https://github.com/satoshilabs/slips/blob/master/slip-0044.md */\n bitcoin: \"0'\",\n bitcoinTestnet: \"1'\",\n ether: \"60'\",\n etherClassic: \"61'\",\n },\n purpose: \"44'\",\n}\n\nexport const WalletRootPath = `${Bip44.base}/${Bip44.purpose}/${Bip44.coin_type.ether}`\n\nexport const ethereumAccountPath = (index: number, hardened = true) => {\n return `${WalletRootPath}/${index}${hardened ? \"'\" : ''}/0`\n}\n","import { usePromise } from '@xylabs/react-promise'\nimport { WithChildren } from '@xylabs/react-shared'\nimport { WalletInstance } from '@xyo-network/wallet-model'\nimport { useEffect, useState } from 'react'\n\nimport { WalletContext } from './Context'\nimport { WalletRootPath } from './lib'\n\nexport interface WalletProviderProps {\n basePath?: string\n defaultActiveAccountIndex?: number\n rootWallet?: WalletInstance | null\n}\n\nexport const WalletProvider: React.FC<WithChildren<WalletProviderProps>> = ({\n basePath = WalletRootPath,\n children,\n defaultActiveAccountIndex = 0,\n rootWallet = null,\n ...props\n}) => {\n const [activeAccountIndex, setActiveAccountIndex] = useState(defaultActiveAccountIndex)\n\n useEffect(() => {\n if (defaultActiveAccountIndex !== undefined) {\n setActiveAccountIndex(defaultActiveAccountIndex)\n }\n }, [defaultActiveAccountIndex])\n\n const [coinTypeWallet = null] = usePromise(async () => {\n // ensure the wallet has the proper base\n if (rootWallet) {\n if (rootWallet?.path !== basePath) {\n try {\n const result = await rootWallet?.derivePath(basePath)\n return result\n } catch (e) {\n console.error('Error setting proper wallet base path', e)\n }\n }\n } else {\n return rootWallet\n }\n }, [basePath, rootWallet])\n\n //console.log(`coinTypeWallet: ${coinTypeWallet}`)\n\n const [activeAccount = null] = usePromise(\n async () => await coinTypeWallet?.derivePath(activeAccountIndex.toString()),\n [coinTypeWallet, activeAccountIndex],\n )\n\n return (\n <WalletContext.Provider\n value={{\n activeAccount,\n activeAccountIndex,\n basePath,\n coinTypeWallet,\n provided: true,\n rootWallet,\n setActiveAccountIndex,\n }}\n {...props}\n >\n {children}\n </WalletContext.Provider>\n )\n}\n","import { usePromise } from '@xylabs/react-promise'\nimport { useContextEx, useProvided } from '@xyo-network/react-shared'\nimport { WalletInstance } from '@xyo-network/wallet-model'\n\nimport { WalletContext } from './Context'\n\nexport const useWalletContext = (required = true) => {\n return useContextEx(WalletContext, 'Wallet', required)\n}\n\nexport const useWalletProvided = () => {\n return useProvided(WalletContext)\n}\n\nexport const useCoinTypeWallet = (required = true): [WalletInstance | null | undefined, Error | undefined] => {\n const { coinTypeWallet } = useWalletContext(required)\n return [coinTypeWallet, undefined]\n}\n\nexport const useRootWallet = (required = true): [WalletInstance | null | undefined, Error | undefined] => {\n const { rootWallet } = useWalletContext(required)\n return [rootWallet, undefined]\n}\n\nexport const useIndexedWalletFromContext = (index: number, required = true): [WalletInstance | null | undefined, Error | undefined] => {\n const [coinTypeWallet] = useCoinTypeWallet(required)\n const [wallet] = usePromise(async () => (await coinTypeWallet?.derivePath(index.toString())) ?? coinTypeWallet, [coinTypeWallet, index])\n return [wallet, undefined]\n}\n\nexport const useSelectedWalletAccount = (required = true): [WalletInstance | null | undefined, Error | undefined] => {\n const { activeAccountIndex } = useWalletContext(required)\n //we pass in 0 as default since we can not call the hook optionally,\n //we resolve this false result by checking whether activeAccountIndex is defined before returning it\n const [account] = useIndexedWalletFromContext(activeAccountIndex ?? 0, required)\n return activeAccountIndex === undefined && account === null ? [null, undefined] : [account, undefined]\n}\n","import { FormControl, StandardTextFieldProps, TextField } from '@mui/material'\nimport { ReactNode } from 'react'\n\nimport { useSeedPhrase } from '../../../../../contexts'\nimport { colorParser, InvalidPhraseTypography } from './validation-messages'\n\nexport interface NewPhraseTextFieldProps extends StandardTextFieldProps {\n children?: ReactNode\n disableColor?: boolean\n}\n\nexport const NewPhraseTextField: React.FC<NewPhraseTextFieldProps> = ({ children, disableColor, ...props }) => {\n const { phrase, setPhrase, validPhrase } = useSeedPhrase()\n return (\n <>\n <FormControl fullWidth size=\"small\" sx={{ display: 'flex', flexDirection: 'column', rowGap: 1 }}>\n {children}\n <TextField\n focused\n color={disableColor ? undefined : colorParser(validPhrase)}\n error={validPhrase === false}\n helperText={validPhrase === false ? <InvalidPhraseTypography /> : null}\n fullWidth\n maxRows={Number.POSITIVE_INFINITY}\n multiline\n onChange={(e) => setPhrase?.(e.target.value)}\n value={phrase}\n {...props}\n />\n </FormControl>\n </>\n )\n}\n","export const colorParser = (conditional?: boolean | null) => {\n switch (conditional) {\n case true: {\n return 'success'\n }\n case false: {\n return 'error'\n }\n default: {\n return\n }\n }\n}\n","import { Link, Typography, TypographyProps } from '@mui/material'\n\nexport const InvalidPhraseTypography: React.FC<TypographyProps> = (props) => (\n <Typography variant={'caption'} color={'error'} {...props}>\n Invalid seed phrase. See -{' '}\n <Link target={'_blank'} href=\"https://github.com/bitcoin/bips/blob/master/bip-0039.mediawiki\">\n bip39 Proposal\n </Link>\n </Typography>\n)\n","import { CheckCircleOutline as CheckCircleOutlineIcon, HighlightOff as HighlightOffIcon } from '@mui/icons-material'\nimport { FlexBoxProps, FlexRow } from '@xylabs/react-flexbox'\nimport { WithChildren } from '@xylabs/react-shared'\nimport { useMemo } from 'react'\n\ninterface PhraseHeaderBox extends FlexBoxProps, WithChildren {\n conditional?: boolean | null\n}\n\nexport const PhraseHeaderBox: React.FC<PhraseHeaderBox> = ({ children, conditional, ...props }) => {\n const state = useMemo(() => {\n switch (conditional) {\n case true: {\n return 'success'\n }\n case false: {\n return 'error'\n }\n default: {\n return null\n }\n }\n }, [conditional])\n\n const Icon = useMemo(() => {\n switch (state) {\n case 'success': {\n return <CheckCircleOutlineIcon fontSize=\"small\" color=\"success\" />\n }\n case 'error': {\n return <HighlightOffIcon fontSize=\"small\" color=\"error\" />\n }\n default: {\n return null\n }\n }\n }, [state])\n\n return (\n <FlexRow justifyContent={'start'} columnGap={1} {...props}>\n {Icon}\n {children}\n </FlexRow>\n )\n}\n","import { Button, DialogActions } from '@mui/material'\n\nimport { useSeedPhrase } from '../../../../../contexts'\n\nexport const PhraseDialogActions = () => {\n const { handleClear, handleGenerate, overwriteWarning } = useSeedPhrase()\n return (\n <DialogActions sx={{ justifyContent: 'center' }}>\n <Button disabled={overwriteWarning} variant=\"outlined\" onClick={handleGenerate}>\n Generate\n </Button>\n <Button variant=\"outlined\" onClick={handleClear}>\n Clear\n </Button>\n </DialogActions>\n )\n}\n","import { Chip, FormControl, FormLabel, StandardTextFieldProps, TextField } from '@mui/material'\nimport { useState } from 'react'\n\nimport { useSeedPhrase } from '../../../../../contexts'\nimport { InvalidPhraseTypography, PhraseHeaderBox } from './validation-messages'\n\nexport const SavedPhraseTextField: React.FC<StandardTextFieldProps> = (props) => {\n const { validSeedPhrase, seedPhrase } = useSeedPhrase()\n\n const [visible, setVisible] = useState(false)\n\n return (\n <FormControl fullWidth size=\"small\" sx={{ display: 'flex', flexDirection: 'column', rowGap: 1 }}>\n <Chip label={visible ? 'Hide Saved Seed Phrase' : 'Reveal Saved Seed Phrase'} onClick={() => setVisible(!visible)} />\n {visible ?\n <>\n <FormLabel>\n <PhraseHeaderBox conditional={validSeedPhrase}>Saved Seed Phrase</PhraseHeaderBox>\n </FormLabel>\n <TextField\n defaultValue={seedPhrase}\n disabled\n error={validSeedPhrase === false}\n helperText={validSeedPhrase === false ? <InvalidPhraseTypography /> : null}\n fullWidth\n maxRows={Number.POSITIVE_INFINITY}\n multiline\n {...props}\n />\n </>\n : null}\n </FormControl>\n )\n}\n","import { Alert, Button } from '@mui/material'\nimport { FlexRow } from '@xylabs/react-flexbox'\n\nimport { useSeedPhrase } from '../../../../contexts'\n\nexport const OverwriteWarning = () => {\n const { handleCancelOverwrite, handleSave } = useSeedPhrase()\n return (\n <Alert\n variant=\"outlined\"\n severity=\"warning\"\n action={\n <FlexRow sx={{ columnGap: 1 }}>\n <Button variant=\"outlined\" color=\"inherit\" size=\"small\" onClick={handleSave}>\n Overwrite\n </Button>\n <Button variant=\"outlined\" color=\"inherit\" size=\"small\" onClick={handleCancelOverwrite}>\n Cancel\n </Button>\n </FlexRow>\n }\n >\n Are you sure you want to overwrite existing seed phrase? This action cannot be undone.\n </Alert>\n )\n}\n","import { Dialog, DialogContent, DialogProps, DialogTitle, FormLabel } from '@mui/material'\n\nimport { SeedPhraseProvider, useSeedPhrase } from '../../../contexts'\nimport { SeedPhraseIconButton } from '../_shared'\nimport { DialogActionButtons, NewPhraseTextField, OverwriteWarning, PhraseDialogActions, PhraseHeaderBox, SavedPhraseTextField } from './components'\n\nexport interface SeedPhraseDialogProps extends DialogProps {\n changeSeedPhrase?: (value: string) => void\n seedPhrase?: string\n}\n\nexport const SeedPhraseDialog: React.FC<SeedPhraseDialogProps> = ({ changeSeedPhrase, seedPhrase, ...props }) => {\n return (\n <SeedPhraseProvider\n seedPhrase={seedPhrase}\n handleChangeSeedPhrase={changeSeedPhrase}\n open={props.open}\n saveCallback={() => props.onClose?.({}, 'escapeKeyDown')}\n >\n <SeedPhraseDialogInner {...props} />\n </SeedPhraseProvider>\n )\n}\n\nexport const SeedPhraseDialogInner: React.FC<SeedPhraseDialogProps> = (props) => {\n const { overwriteWarning, seedPhrase, validPhrase } = useSeedPhrase()\n\n return (\n <Dialog aria-labelledby=\"alert-dialog-title\" aria-describedby=\"alert-dialog-description\" fullWidth maxWidth={'sm'} {...props}>\n <DialogTitle id=\"alert-dialog-title\">\n Update Your Seed Phrase <SeedPhraseIconButton />\n </DialogTitle>\n <DialogContent sx={{ display: 'flex', flexDirection: 'column', rowGap: 2 }}>\n <NewPhraseTextField>\n <FormLabel>\n <PhraseHeaderBox conditional={validPhrase}>New Seed Phrase</PhraseHeaderBox>\n </FormLabel>\n </NewPhraseTextField>\n <PhraseDialogActions />\n {seedPhrase ?\n <SavedPhraseTextField />\n : null}\n {overwriteWarning ?\n <OverwriteWarning />\n : null}\n </DialogContent>\n <DialogActionButtons onClose={props.onClose} />\n </Dialog>\n )\n}\n","import { Cancel as CancelIcon, RadioButtonChecked as RadioButtonCheckedIcon } from '@mui/icons-material'\nimport { Button, ButtonGroup, TableCell, TableRow, TableRowProps } from '@mui/material'\nimport { useState } from 'react'\n\nimport { SeedPhraseIconButton } from '../_shared'\nimport { SeedPhraseDialog } from '../dialog'\n\nexport interface SeedPhraseTableRowProps extends TableRowProps {\n changeSeedPhrase?: (seedPhrase: string) => void\n seedPhrase?: string\n}\n\nexport const SeedPhraseTableRow: React.FC<SeedPhraseTableRowProps> = ({ changeSeedPhrase, seedPhrase, ...props }) => {\n const [open, setOpen] = useState(false)\n\n const handleOpen = () => {\n setOpen(true)\n }\n return (\n <TableRow {...props}>\n <TableCell>\n Seed Phrase <SeedPhraseIconButton />\n </TableCell>\n <TableCell align=\"center\">\n {seedPhrase ?\n <RadioButtonCheckedIcon color=\"success\" />\n : <CancelIcon color=\"error\" />}\n </TableCell>\n <TableCell>\n <SeedPhraseDialog changeSeedPhrase={changeSeedPhrase} open={open} onClose={() => setOpen(false)} seedPhrase={seedPhrase} />\n <ButtonGroup fullWidth>\n <Button variant=\"contained\" size=\"small\" onClick={handleOpen}>\n Update\n </Button>\n </ButtonGroup>\n </TableCell>\n </TableRow>\n )\n}\n","import { EthAddress } from '@xylabs/eth-address'\nimport { EthAccountButton } from '@xylabs/react-crypto'\nimport { FlexBoxProps, FlexCol, FlexRow } from '@xylabs/react-flexbox'\nimport { NumberStatus } from '@xylabs/react-number-status'\nimport { useNetwork } from '@xyo-network/react-network'\nimport { WalletInstance } from '@xyo-network/wallet-model'\n\nimport { useAccount } from '../../hooks'\n\nexport interface WalletAccountDetailsProps extends FlexBoxProps {\n account?: WalletInstance\n exploreUrl?: string\n}\n\nexport const WalletAccountDetails: React.FC<WalletAccountDetailsProps> = ({ exploreUrl = 'https://explore.xyo.network', account, ...props }) => {\n const [accountToUse] = useAccount({ account })\n const { network } = useNetwork()\n const exploreAddressUrl = `${exploreUrl}/recent?account=${accountToUse?.address}&network=${network?.name ?? 'main'}`\n\n return (\n <FlexCol {...props}>\n <EthAccountButton address={EthAddress.fromString(accountToUse?.address)} />\n <FlexRow gap={1}>\n <NumberStatus rounded title=\"Tokens\" value={0} to={`${exploreAddressUrl}&schema=network.xyo.account.tokens`} target=\"_blank\" />\n <NumberStatus rounded title=\"NFTs\" value={0} to={`${exploreAddressUrl}&schema=network.xyo.account.nfts`} target=\"_blank\" />\n <NumberStatus rounded title=\"Signatures\" value={0} to={`${exploreAddressUrl}&schema=network.xyo.account.signatures`} target=\"_blank\" />\n <NumberStatus rounded title=\"Signins\" value={0} to={`${exploreAddressUrl}&schema=network.xyo.account.signins`} target=\"_blank\" />\n </FlexRow>\n </FlexCol>\n )\n}\n","import { usePromise } from '@xylabs/react-promise'\nimport { AccountInstance } from '@xyo-network/account-model'\nimport { WalletInstance } from '@xyo-network/wallet-model'\nimport { useState } from 'react'\n\nimport { useCoinTypeWallet, useWalletContext, useWalletProvided } from '../contexts'\n\nexport interface AccountHookParams {\n account?: AccountInstance\n index?: number\n required?: boolean\n wallet?: WalletInstance\n}\n\nexport const useAccount = ({ wallet, account, index, required = false }: AccountHookParams = {}): [\n AccountInstance | null | undefined,\n Error | undefined,\n] => {\n const walletContextProvided = useWalletProvided()\n const [validationError, setValidationError] = useState<Error>()\n if (wallet && account && !validationError) {\n setValidationError(new Error('useAccount can not have both a wallet and an account in the parameters'))\n }\n\n if (index && account && !validationError) {\n setValidationError(new Error('useAccount can not have both a index and an account in the parameters'))\n }\n\n const [error, setError] = useState<Error>()\n const [coinTypeWallet] = useCoinTypeWallet(!wallet && required)\n const { activeAccountIndex } = useWalletContext(false)\n const [activeAccount] = usePromise(async () => {\n try {\n if (!validationError) {\n if (wallet) {\n return await wallet?.derivePath?.(`${index ?? 0}'\\0`)\n } else if (coinTypeWallet) {\n return await coinTypeWallet?.derivePath?.(`${index ?? activeAccountIndex ?? 0}'\\0`)\n }\n }\n } catch (ex) {\n const error = ex as Error\n console.error(error.message)\n setError(error)\n }\n }, [index, wallet, coinTypeWallet, activeAccountIndex, validationError])\n if (validationError && !error) {\n console.error(validationError.message)\n setError(validationError)\n }\n\n return [\n error ? undefined\n : account ?? activeAccount ?? walletContextProvided ? null\n : undefined,\n error,\n ]\n}\n","import { usePromise } from '@xylabs/react-promise'\nimport { HDWallet } from '@xyo-network/account'\nimport { WalletInstance } from '@xyo-network/wallet-model'\nimport { useState } from 'react'\n\nimport { useSelectedWalletAccount, useWalletProvided } from '../contexts'\n\nexport interface WalletHookParams {\n mnemonic?: string\n path?: string\n required?: boolean\n seed?: Uint8Array | string\n wallet?: WalletInstance | null\n}\n\nexport const useWallet = ({ mnemonic, wallet, path, required = false, seed }: WalletHookParams = {}): [\n WalletInstance | null | undefined,\n Error | undefined,\n] => {\n const walletContextProvided = useWalletProvided()\n const [error, setError] = useState<Error>()\n const [contextAccount] = useSelectedWalletAccount(!wallet && required)\n const [activeAccount] = usePromise(async () => {\n try {\n const newAccount = await (() => {\n if (wallet) {\n return wallet\n } else if (mnemonic) {\n return HDWallet.fromPhrase(mnemonic)\n } else if (seed) {\n return HDWallet.fromSeed(seed)\n }\n return contextAccount\n })()\n\n return path ? newAccount?.derivePath?.(path) : newAccount ?? wallet\n } catch (ex) {\n setError(ex as Error)\n }\n }, [mnemonic, contextAccount, seed, path, wallet])\n return [activeAccount ?? (walletContextProvided ? null : activeAccount), error]\n}\n","import { usePromise } from '@xylabs/react-promise'\nimport { WalletInstance } from '@xyo-network/wallet-model'\n\nimport { useWalletProvided } from '../contexts'\nimport { useWallet } from './useWallet'\n\nexport interface WalletsHookParams {\n paths: string[]\n wallet?: WalletInstance | null\n}\n\nexport const useWallets = ({ wallet, paths }: WalletsHookParams): [WalletInstance[] | null | undefined, Error | undefined] => {\n const walletContextProvided = useWalletProvided()\n const [foundWallet] = useWallet({ wallet })\n const [wallets, error] = usePromise(\n async () => (foundWallet ? await Promise.all(paths.map((path) => foundWallet.derivePath(path))) : undefined),\n [foundWallet, paths],\n )\n return [wallets ?? (walletContextProvided ? null : wallets), error]\n}\n","import { State as PromiseState, usePromise } from '@xylabs/react-promise'\nimport { HDWallet } from '@xyo-network/account'\nimport { AccountInstance } from '@xyo-network/account-model'\nimport { WalletInstance } from '@xyo-network/wallet-model'\nimport { Mutex } from 'async-mutex'\n\nlet globalWrapperWallet: WalletInstance | undefined\nconst globalWrapperWalletMutex = new Mutex()\n\nexport const useWrapperAccount = (\n account?: AccountInstance | null,\n): [AccountInstance | null | undefined, Error | undefined, PromiseState | undefined] => {\n return usePromise(async () => {\n return await globalWrapperWalletMutex.runExclusive(async () => {\n //if we are expecting to receive a wallet or did receive on, return the override account\n if (account !== undefined) {\n return account\n }\n\n if (globalWrapperWallet) {\n return globalWrapperWallet\n }\n\n try {\n globalWrapperWallet = await HDWallet.random()\n console.log(`Global Wrapper Wallet Creation Success: ${globalWrapperWallet.address}`)\n } catch (ex) {\n const error = ex as Error\n console.error(`Global Wrapper Wallet Creation Failed: ${error.message}`)\n }\n return globalWrapperWallet\n })\n }, [account])\n}\n","import { CircularProgress, MenuItem, SelectProps } from '@mui/material'\nimport { SelectEx } from '@xylabs/react-select'\nimport { AddressRenderRowBox, AddressRenderRowBoxProps } from '@xyo-network/react-address-render'\n\nimport { useWalletContext } from '../../contexts'\nimport { useWallet } from '../../hooks'\n\ntype SharedAddressRenderRowBoxProps = Pick<AddressRenderRowBoxProps, 'iconOnly' | 'iconSize' | 'icons' | 'showFavorite'>\n\nexport type WalletAccountSelectProps = SharedAddressRenderRowBoxProps &\n Omit<SelectProps<number>, 'variant'> &\n Partial<SelectProps<number>> & {\n addressNames?: Record<string, string | undefined>\n maxAccounts?: number\n }\n\nconst arrayRange = (length: number, start = 0) => {\n return [...Array.from({ length }).keys()].map((x) => x + start)\n}\n\nexport const WalletAccountSelect: React.FC<WalletAccountSelectProps> = ({\n addressNames = {},\n iconOnly,\n iconSize = 24,\n icons,\n maxAccounts = 1,\n showFavorite = false,\n size,\n variant = 'outlined',\n ...props\n}) => {\n const { activeAccountIndex = 0, setActiveAccountIndex, coinTypeWallet } = useWalletContext()\n const disabled = !coinTypeWallet || activeAccountIndex === undefined\n\n return (\n <>\n {coinTypeWallet ?\n <SelectEx\n margin=\"dense\"\n disabled={disabled}\n renderValue={(selectedAccountIndex) => {\n const Item: React.FC = () => {\n const [selectedAccount] = useWallet({ path: selectedAccountIndex.toString(), wallet: coinTypeWallet })\n const customName = selectedAccount ? addressNames[selectedAccount.address] : undefined\n const favorite = !!selectedAccount && selectedAccount.address in addressNames\n return (\n <MenuItem value={selectedAccountIndex} sx={{ minHeight: 0, paddingBottom: 0, paddingTop: 0 }}>\n <AddressRenderRowBox\n disableSharedRef={true}\n flexGrow={1}\n address={selectedAccount?.address}\n iconOnly={iconOnly}\n iconSize={iconSize}\n icons={icons}\n name={customName}\n favorite={favorite}\n showFavorite={showFavorite}\n />\n </MenuItem>\n )\n }\n return <Item />\n }}\n value={activeAccountIndex}\n onChange={(event) => setActiveAccountIndex?.(Number.parseInt(`${event.target.value}`))}\n size={size}\n variant={variant}\n {...props}\n >\n {arrayRange(maxAccounts).map((index) => {\n const Item: React.FC = () => {\n const [account] = useWallet({ path: index.toString(), wallet: coinTypeWallet })\n const customName = account ? addressNames[account.address] : undefined\n const favorite = !!account && account.address in addressNames\n return (\n <MenuItem key={account?.address} value={index} sx={{ minHeight: 0, paddingBottom: 0, paddingTop: 0 }}>\n <AddressRenderRowBox\n disableSharedRef={true}\n flexGrow={1}\n address={account?.address}\n favorite={favorite}\n iconOnly={iconOnly}\n iconSize={iconSize}\n icons={icons}\n name={customName}\n showFavorite={showFavorite}\n />\n </MenuItem>\n )\n }\n\n return <Item key={index} />\n })}\n </SelectEx>\n : <CircularProgress size={24} />}\n </>\n )\n}\n","import { FlexBoxProps, FlexCol } from '@xylabs/react-flexbox'\n\nimport { WalletAccountSelect } from './Select'\n\nexport interface WalletAccountSelectBarProps extends FlexBoxProps {\n addressNames?: Record<string, string | undefined>\n iconOnly?: boolean\n iconSize?: number\n icons?: boolean\n maxAccounts?: number\n showFavorite?: boolean\n size?: 'small' | 'medium'\n}\n\nexport const WalletAccountSelectBar: React.FC<WalletAccountSelectBarProps> = ({\n addressNames = {},\n iconOnly,\n iconSize,\n icons,\n maxAccounts = 1,\n showFavorite = false,\n size = 'small',\n ...props\n}) => {\n return (\n <FlexCol alignItems=\"stretch\" {...props}>\n <WalletAccountSelect\n addressNames={addressNames}\n fullWidth\n showFavorite={showFavorite}\n iconSize={iconSize}\n iconOnly={iconOnly}\n icons={icons}\n maxAccounts={maxAccounts}\n size={size ?? 'small'}\n variant=\"outlined\"\n />\n </FlexCol>\n )\n}\n"],"mappings":";AAAA,SAAS,aAAa,WAAW,UAAyB,kBAAkB;AAC5E,SAAS,gBAAgB;AACzB,SAAS,gBAAgB;;;ACFzB,SAAS,OAAO,YAAY,gBAA+B;AAuBrD,SACE,KADF;AAbC,IAAM,sBAA0D,CAAC;AAAA,EACtE;AAAA,EACA;AAAA,EACA;AAAA,EACA;AACF,MAAM;AACJ,SACE;AAAA,IAAC;AAAA;AAAA,MACC,cAAc,EAAE,YAAY,UAAU,UAAU,MAAM;AAAA,MACtD,kBAAkB;AAAA,MAClB,SAAS,MAAM,mDAAkB;AAAA,MACjC,MAAM;AAAA,MAEN,+BAAC,SAAM,UAAU,SAAS,SAAS,MAAM,mDAAkB,QACzD;AAAA,4BAAC,cAAW,oCAAsB;AAAA,QAAa;AAAA,QACN,uBAAuB,SAAY,KAAK,qBAAqB;AAAA,QAAE;AAAA,QACrF;AAAA,QAAuB;AAAA,SAC5C;AAAA;AAAA,EACF;AAEJ;;;ADeM,gBAAAA,MAKE,QAAAC,aALF;AAjCC,IAAM,sBAAqD,CAAC,EAAE,oBAAoB,mBAAmB,YAAY,MAAM;AAC5H,QAAM,CAAC,wBAAwB,yBAAyB,IAAI,SAA6B;AACzF,QAAM,CAAC,cAAc,eAAe,IAAI,SAAS,KAAK;AAEtD,QAAM,0BAA0B,CAAC,WAAoC;AACnE,QAAI,gBAAgB,UAAa,uBAAuB,QAAW;AACjE,cAAQ,QAAQ;AAAA,QACd,KAAK,YAAY;AACf,gBAAMC,0BAAyB,cAAc;AAC7C,gBAAM,uBAAuBA,0BAAyB;AACtD,gBAAM,yBAAyB,qBAAqB,KAAKA;AACzD,cAAI,wBAAwB,wBAAwB;AAClD,mEAAoBA;AAAA,UACtB;AACA,cAAI,CAAC;AAAwB,4BAAgB,IAAI;AACjD,oCAA0BA,uBAAsB;AAChD;AAAA,QACF;AAAA,QACA,KAAK,YAAY;AACf,iEAAoB,cAAc;AAClC;AAAA,QACF;AAAA,QACA,SAAS;AACP,kBAAQ,MAAM,QAAQ,2BAA2B;AAAA,QACnD;AAAA,MACF;AAAA,IACF,OAAO;AACL,YAAM,IAAI,MAAM,2CAA2C;AAAA,IAC7D;AAAA,EACF;AAEA,SACE,gBAAAD,MAAC,YACC;AAAA,oBAAAD,KAAC,aAAU,8BAAgB;AAAA,IAC3B,gBAAAA,KAAC,aAAU,OAAM,UACf,0BAAAA,KAAC,cAAW,SAAS,WAAY,uBAAY,GAC/C;AAAA,IACA,gBAAAC,MAAC,aAAU,OAAM,UACf;AAAA,sBAAAA,MAAC,eACC;AAAA,wBAAAD,KAAC,YAAS,SAAS,MAAM,wBAAwB,UAAU,GAAG,SAAS,aAAa,MAAM,SAAS,eAEnG;AAAA,QACA,gBAAAA,KAAC,YAAS,SAAS,MAAM,wBAAwB,UAAU,GAAG,SAAS,aAAa,MAAM,SAAS,eAEnG;AAAA,SACF;AAAA,MACA,gBAAAA;AAAA,QAAC;AAAA;AAAA,UACC;AAAA,UACA;AAAA,UACA;AAAA,UACA;AAAA;AAAA,MACF;AAAA,OACF;AAAA,KACF;AAEJ;;;AEnEA,SAAS,eAAe,uBAAuB;AAC/C;AAAA,EACE;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EAEA;AAAA,EACA;AAAA,EACA;AAAA,EACA,cAAAG;AAAA,OACK;AACP,SAAS,YAAAC,iBAAgB;AAMrB,mBAEI,OAAAC,MAKE,QAAAC,aAPN;AAJG,IAAM,uBAAkD,CAAC,UAAU;AACxE,QAAM,CAAC,MAAM,OAAO,IAAIF,UAAS,KAAK;AACtC,QAAM,UAAU,MAAM,QAAQ,KAAK;AACnC,SACE,gBAAAE,MAAA,YACE;AAAA,oBAAAD,KAAC,cAAW,SAAS,MAAM,QAAQ,IAAI,GAAI,GAAG,OAC5C,0BAAAA,KAAC,mBAAgB,UAAS,SAAQ,GACpC;AAAA,IACA,gBAAAC,MAAC,UAAO,MACN;AAAA,sBAAAD,KAAC,eAAY,4CAA8B;AAAA,MAC3C,gBAAAC,MAAC,iBACC;AAAA,wBAAAA,MAACH,aAAA,EAAW;AAAA;AAAA,UAC4B;AAAA,UACtC,gBAAAE,KAAC,QAAK,QAAQ,UAAU,MAAK,kEAAiE,iCAE9F;AAAA,UAAQ;AAAA,UAAI;AAAA,WAEd;AAAA,QACA,gBAAAC,MAAC,QACC;AAAA,0BAAAD,KAAC,YAAS,mDAAqC;AAAA,UAC/C,gBAAAA,KAAC,YAAS,kDAAoC;AAAA,UAC9C,gBAAAA,KAAC,YAAS,+EAAiE;AAAA,UAC3E,gBAAAA,KAAC,YAAS,+DAAiD;AAAA,WAC7D;AAAA,SACF;AAAA,MACA,gBAAAA,KAAC,iBACC,0BAAAA,KAAC,UAAO,SAAS,SAAS,SAAQ,YAAW,gBAE7C,GACF;AAAA,OACF;AAAA,KACF;AAEJ;;;ACjDA,SAAS,SAAAE,QAAO,cAAAC,aAAY,YAAAC,iBAAgB;AAC5C,SAAS,wBAAwB;AAEjC,SAAS,gBAAgB;AAEzB,SAAS,WAAW,YAAAC,iBAAgB;AAoBhC,qBAAAC,WASQ,OAAAC,MADF,QAAAC,aARN;AAZG,IAAM,oBAAsD,CAAC,EAAE,kBAAkB,UAAU,8BAA8B,WAAW,MAAM;AAC/I,QAAM,CAAC,cAAc,eAAe,IAAIH,UAAS,KAAK;AAEtD,YAAU,MAAM;AACd,QAAI,CAAC,YAAY;AACf,YAAM,WAAW,iBAAiB,UAAU,GAAG;AAC/C,2DAAmB;AACnB,sBAAgB,IAAI;AAAA,IACtB;AAAA,EACF,GAAG,CAAC,kBAAkB,UAAU,CAAC;AAEjC,SACE,gBAAAG,MAAAF,WAAA,EACG;AAAA,mCAA+B,OAC9B,gBAAAC;AAAA,MAACH;AAAA,MAAA;AAAA,QACC,MAAM;AAAA,QACN,kBAAkB;AAAA,QAClB,SAAS,MAAM,gBAAgB,KAAK;AAAA,QACpC,cAAc,EAAE,YAAY,UAAU,UAAU,MAAM;AAAA,QAEtD,0BAAAI,MAACN,QAAA,EAAM,UAAU,WACf;AAAA,0BAAAK,KAACJ,aAAA,EAAW,2CAA6B;AAAA,UAAa;AAAA,WAExD;AAAA;AAAA,IACF;AAAA,IAED;AAAA,KACH;AAEJ;;;AC1CA,SAAS,UAAAM,SAAQ,iBAAAC,sBAAsD;;;ACAvE,SAAS,uBAAuB;AAIzB,IAAM,oBAAoB,gBAAwC;;;ACJzE,SAAS,oBAAAC,mBAAkB,wBAAwB;AAEnD,SAAS,YAAAC,iBAAgB;AAEzB,SAAS,aAAa,aAAAC,YAAW,SAAS,YAAAC,iBAAgB;AA0EtD,gBAAAC,YAAA;AA9DJ,IAAM,WAAW,CAAC,iBAA0B;AAC1C,MAAI,CAAC,cAAc;AACjB,WAAO;AAAA,EACT;AACA,SAAO,iBAAiB,cAAcC,SAAQ;AAChD;AAEO,IAAM,qBAAwD,CAAC;AAAA,EACpE;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AACF,MAAM;AACJ,QAAM,CAAC,QAAQ,SAAS,IAAIC,UAA6B;AACzD,QAAM,CAAC,kBAAkB,mBAAmB,IAAIA,UAAS,KAAK;AAE9D,EAAAC,WAAU,MAAM;AACd,cAAU,aAAa;AAAA,EACzB,GAAG,CAAC,aAAa,CAAC;AAElB,EAAAA,WAAU,MAAM;AACd,QAAI,cAAc,MAAM;AACtB,6CAAY,cAAc;AAAA,IAC5B;AAAA,EACF,GAAG,CAAC,YAAY,MAAM,SAAS,CAAC;AAEhC,QAAM,iBAAiB,YAAY,MAAM;AACvC,UAAM,WAAWC,kBAAiBH,WAAU,GAAG;AAC/C,2CAAY;AACZ,+DAAsB;AAAA,EACxB,GAAG,CAAC,CAAC;AAEL,QAAM,wBAAwB,YAAY,MAAM;AAC9C,+DAAsB;AAAA,EACxB,GAAG,CAAC,CAAC;AAEL,QAAM,cAAc,YAAY,MAAM;AACpC,2CAAY;AACZ,+DAAsB;AAAA,EACxB,GAAG,CAAC,CAAC;AAEL,QAAM,aAAa,YAAY,MAAM;AACnC,QAAI,CAAC,oBAAoB,cAAc,eAAe,QAAQ;AAC5D,iEAAsB;AAAA,IACxB,OAAO;AACL,uEAAyB,UAAU;AACnC;AAAA,IACF;AAAA,EACF,GAAG,CAAC,wBAAwB,kBAAkB,QAAQ,cAAc,UAAU,CAAC;AAE/E,EAAAE,WAAU,MAAM;AACd,QAAI,CAAC,MAAM;AACT,4BAAsB;AAAA,IACxB;AAAA,EACF,GAAG,CAAC,uBAAuB,IAAI,CAAC;AAEhC,QAAM,kBAAkB,QAAQ,MAAM,qCAAW,aAAa,CAAC,UAAU,CAAC;AAC1E,QAAM,cAAc,QAAQ,MAAM,qCAAW,SAAS,CAAC,MAAM,CAAC;AAE9D,SACE,gBAAAH;AAAA,IAAC,kBAAkB;AAAA,IAAlB;AAAA,MACC,OAAO;AAAA,QACL;AAAA,QACA;AAAA,QACA;AAAA,QACA;AAAA,QACA;AAAA,QACA;AAAA,QACA;AAAA,QACA,UAAU;AAAA,QACV;AAAA,QACA;AAAA,QACA;AAAA,QACA;AAAA,QACA;AAAA,QACA;AAAA,MACF;AAAA,MAEC;AAAA;AAAA,EACH;AAEJ;;;ACnGA,SAAS,oBAAoB;AAItB,IAAM,gBAAgB,MAAM,aAAa,mBAAmB,cAAc,IAAI;;;ACJrF,SAAS,mBAAAK,wBAAuB;AAIzB,IAAM,gBAAgBA,iBAAoC;;;ACJ1D,IAAM,QAAQ;AAAA,EACnB,MAAM;AAAA,EACN,WAAW;AAAA;AAAA,IAET,SAAS;AAAA,IACT,gBAAgB;AAAA,IAChB,OAAO;AAAA,IACP,cAAc;AAAA,EAChB;AAAA,EACA,SAAS;AACX;AAEO,IAAM,iBAAiB,GAAG,MAAM,IAAI,IAAI,MAAM,OAAO,IAAI,MAAM,UAAU,KAAK;AAE9E,IAAM,sBAAsB,CAAC,OAAe,WAAW,SAAS;AACrE,SAAO,GAAG,cAAc,IAAI,KAAK,GAAG,WAAW,MAAM,EAAE;AACzD;;;AChBA,SAAS,kBAAkB;AAG3B,SAAS,aAAAC,YAAW,YAAAC,iBAAgB;AAkDhC,gBAAAC,YAAA;AAvCG,IAAM,iBAA8D,CAAC;AAAA,EAC1E,WAAW;AAAA,EACX;AAAA,EACA,4BAA4B;AAAA,EAC5B,aAAa;AAAA,EACb,GAAG;AACL,MAAM;AACJ,QAAM,CAAC,oBAAoB,qBAAqB,IAAIC,UAAS,yBAAyB;AAEtF,EAAAC,WAAU,MAAM;AACd,QAAI,8BAA8B,QAAW;AAC3C,4BAAsB,yBAAyB;AAAA,IACjD;AAAA,EACF,GAAG,CAAC,yBAAyB,CAAC;AAE9B,QAAM,CAAC,iBAAiB,IAAI,IAAI,WAAW,YAAY;AAErD,QAAI,YAAY;AACd,WAAI,yCAAY,UAAS,UAAU;AACjC,YAAI;AACF,gBAAM,SAAS,OAAM,yCAAY,WAAW;AAC5C,iBAAO;AAAA,QACT,SAAS,GAAG;AACV,kBAAQ,MAAM,yCAAyC,CAAC;AAAA,QAC1D;AAAA,MACF;AAAA,IACF,OAAO;AACL,aAAO;AAAA,IACT;AAAA,EACF,GAAG,CAAC,UAAU,UAAU,CAAC;AAIzB,QAAM,CAAC,gBAAgB,IAAI,IAAI;AAAA,IAC7B,YAAY,OAAM,iDAAgB,WAAW,mBAAmB,SAAS;AAAA,IACzE,CAAC,gBAAgB,kBAAkB;AAAA,EACrC;AAEA,SACE,gBAAAF;AAAA,IAAC,cAAc;AAAA,IAAd;AAAA,MACC,OAAO;AAAA,QACL;AAAA,QACA;AAAA,QACA;AAAA,QACA;AAAA,QACA,UAAU;AAAA,QACV;AAAA,QACA;AAAA,MACF;AAAA,MACC,GAAG;AAAA,MAEH;AAAA;AAAA,EACH;AAEJ;;;ACpEA,SAAS,cAAAG,mBAAkB;AAC3B,SAAS,gBAAAC,eAAc,mBAAmB;AAKnC,IAAM,mBAAmB,CAAC,WAAW,SAAS;AACnD,SAAOC,cAAa,eAAe,UAAU,QAAQ;AACvD;AAEO,IAAM,oBAAoB,MAAM;AACrC,SAAO,YAAY,aAAa;AAClC;AAEO,IAAM,oBAAoB,CAAC,WAAW,SAAiE;AAC5G,QAAM,EAAE,eAAe,IAAI,iBAAiB,QAAQ;AACpD,SAAO,CAAC,gBAAgB,MAAS;AACnC;AAEO,IAAM,gBAAgB,CAAC,WAAW,SAAiE;AACxG,QAAM,EAAE,WAAW,IAAI,iBAAiB,QAAQ;AAChD,SAAO,CAAC,YAAY,MAAS;AAC/B;AAEO,IAAM,8BAA8B,CAAC,OAAe,WAAW,SAAiE;AACrI,QAAM,CAAC,cAAc,IAAI,kBAAkB,QAAQ;AACnD,QAAM,CAAC,MAAM,IAAIC,YAAW,YAAa,OAAM,iDAAgB,WAAW,MAAM,SAAS,OAAO,gBAAgB,CAAC,gBAAgB,KAAK,CAAC;AACvI,SAAO,CAAC,QAAQ,MAAS;AAC3B;AAEO,IAAM,2BAA2B,CAAC,WAAW,SAAiE;AACnH,QAAM,EAAE,mBAAmB,IAAI,iBAAiB,QAAQ;AAGxD,QAAM,CAAC,OAAO,IAAI,4BAA4B,sBAAsB,GAAG,QAAQ;AAC/E,SAAO,uBAAuB,UAAa,YAAY,OAAO,CAAC,MAAM,MAAS,IAAI,CAAC,SAAS,MAAS;AACvG;;;APjBI,SACE,OAAAC,MADF,QAAAC,aAAA;AAVG,IAAM,sBAA0D,CAAC,EAAE,SAAS,GAAG,MAAM,MAAM;AAChG,QAAM,EAAE,YAAY,UAAU,IAAI,cAAc;AAEhD,QAAM,iBAAiB,CAAC,MAA+B;AAErD,2CAAY;AACZ,uCAAU,GAAG;AAAA,EACf;AAEA,SACE,gBAAAA,MAACC,gBAAA,EAAe,GAAG,OACjB;AAAA,oBAAAF,KAACG,SAAA,EAAO,SAAQ,YAAW,SAAS,gBAAgB,oBAEpD;AAAA,IACA,gBAAAH,KAACG,SAAA,EAAO,SAAQ,YAAW,SAAS,YAAY,kBAEhD;AAAA,KACF;AAEJ;;;AQ5BA,SAAS,aAAqC,iBAAiB;;;ACAxD,IAAM,cAAc,CAAC,gBAAiC;AAC3D,UAAQ,aAAa;AAAA,IACnB,KAAK,MAAM;AACT,aAAO;AAAA,IACT;AAAA,IACA,KAAK,OAAO;AACV,aAAO;AAAA,IACT;AAAA,IACA,SAAS;AACP;AAAA,IACF;AAAA,EACF;AACF;;;ACZA,SAAS,QAAAC,OAAM,cAAAC,mBAAmC;AAGhD,SAEE,OAAAC,MAFF,QAAAC,aAAA;AADK,IAAM,0BAAqD,CAAC,UACjE,gBAAAA,MAACF,aAAA,EAAW,SAAS,WAAW,OAAO,SAAU,GAAG,OAAO;AAAA;AAAA,EAC9B;AAAA,EAC3B,gBAAAC,KAACF,OAAA,EAAK,QAAQ,UAAU,MAAK,kEAAiE,4BAE9F;AAAA,GACF;;;ACRF,SAAS,sBAAsB,wBAAwB,gBAAgB,wBAAwB;AAC/F,SAAuB,eAAe;AAEtC,SAAS,WAAAI,gBAAe;AAwBT,gBAAAC,MAYX,QAAAC,aAZW;AAlBR,IAAM,kBAA6C,CAAC,EAAE,UAAU,aAAa,GAAG,MAAM,MAAM;AACjG,QAAM,QAAQF,SAAQ,MAAM;AAC1B,YAAQ,aAAa;AAAA,MACnB,KAAK,MAAM;AACT,eAAO;AAAA,MACT;AAAA,MACA,KAAK,OAAO;AACV,eAAO;AAAA,MACT;AAAA,MACA,SAAS;AACP,eAAO;AAAA,MACT;AAAA,IACF;AAAA,EACF,GAAG,CAAC,WAAW,CAAC;AAEhB,QAAM,OAAOA,SAAQ,MAAM;AACzB,YAAQ,OAAO;AAAA,MACb,KAAK,WAAW;AACd,eAAO,gBAAAC,KAAC,0BAAuB,UAAS,SAAQ,OAAM,WAAU;AAAA,MAClE;AAAA,MACA,KAAK,SAAS;AACZ,eAAO,gBAAAA,KAAC,oBAAiB,UAAS,SAAQ,OAAM,SAAQ;AAAA,MAC1D;AAAA,MACA,SAAS;AACP,eAAO;AAAA,MACT;AAAA,IACF;AAAA,EACF,GAAG,CAAC,KAAK,CAAC;AAEV,SACE,gBAAAC,MAAC,WAAQ,gBAAgB,SAAS,WAAW,GAAI,GAAG,OACjD;AAAA;AAAA,IACA;AAAA,KACH;AAEJ;;;AH9BI,qBAAAC,WAO0C,OAAAC,OANxC,QAAAC,aADF;AAHG,IAAM,qBAAwD,CAAC,EAAE,UAAU,cAAc,GAAG,MAAM,MAAM;AAC7G,QAAM,EAAE,QAAQ,WAAW,YAAY,IAAI,cAAc;AACzD,SACE,gBAAAD,MAAAD,WAAA,EACE,0BAAAE,MAAC,eAAY,WAAS,MAAC,MAAK,SAAQ,IAAI,EAAE,SAAS,QAAQ,eAAe,UAAU,QAAQ,EAAE,GAC3F;AAAA;AAAA,IACD,gBAAAD;AAAA,MAAC;AAAA;AAAA,QACC,SAAO;AAAA,QACP,OAAO,eAAe,SAAY,YAAY,WAAW;AAAA,QACzD,OAAO,gBAAgB;AAAA,QACvB,YAAY,gBAAgB,QAAQ,gBAAAA,MAAC,2BAAwB,IAAK;AAAA,QAClE,WAAS;AAAA,QACT,SAAS,OAAO;AAAA,QAChB,WAAS;AAAA,QACT,UAAU,CAAC,MAAM,uCAAY,EAAE,OAAO;AAAA,QACtC,OAAO;AAAA,QACN,GAAG;AAAA;AAAA,IACN;AAAA,KACF,GACF;AAEJ;;;AIhCA,SAAS,UAAAE,SAAQ,iBAAAC,sBAAqB;AAOlC,SACE,OAAAC,OADF,QAAAC,aAAA;AAHG,IAAM,sBAAsB,MAAM;AACvC,QAAM,EAAE,aAAa,gBAAgB,iBAAiB,IAAI,cAAc;AACxE,SACE,gBAAAA,MAACC,gBAAA,EAAc,IAAI,EAAE,gBAAgB,SAAS,GAC5C;AAAA,oBAAAF,MAACG,SAAA,EAAO,UAAU,kBAAkB,SAAQ,YAAW,SAAS,gBAAgB,sBAEhF;AAAA,IACA,gBAAAH,MAACG,SAAA,EAAO,SAAQ,YAAW,SAAS,aAAa,mBAEjD;AAAA,KACF;AAEJ;;;AChBA,SAAS,MAAM,eAAAC,cAAa,WAAmC,aAAAC,kBAAiB;AAChF,SAAS,YAAAC,iBAAgB;AAYnB,SAEE,YAAAC,WAFF,OAAAC,OAEE,QAAAC,cAFF;AAPC,IAAM,uBAAyD,CAAC,UAAU;AAC/E,QAAM,EAAE,iBAAiB,WAAW,IAAI,cAAc;AAEtD,QAAM,CAAC,SAAS,UAAU,IAAIC,UAAS,KAAK;AAE5C,SACE,gBAAAD,OAACE,cAAA,EAAY,WAAS,MAAC,MAAK,SAAQ,IAAI,EAAE,SAAS,QAAQ,eAAe,UAAU,QAAQ,EAAE,GAC5F;AAAA,oBAAAH,MAAC,QAAK,OAAO,UAAU,2BAA2B,4BAA4B,SAAS,MAAM,WAAW,CAAC,OAAO,GAAG;AAAA,IAClH,UACC,gBAAAC,OAAAF,WAAA,EACE;AAAA,sBAAAC,MAAC,aACC,0BAAAA,MAAC,mBAAgB,aAAa,iBAAiB,+BAAiB,GAClE;AAAA,MACA,gBAAAA;AAAA,QAACI;AAAA,QAAA;AAAA,UACC,cAAc;AAAA,UACd,UAAQ;AAAA,UACR,OAAO,oBAAoB;AAAA,UAC3B,YAAY,oBAAoB,QAAQ,gBAAAJ,MAAC,2BAAwB,IAAK;AAAA,UACtE,WAAS;AAAA,UACT,SAAS,OAAO;AAAA,UAChB,WAAS;AAAA,UACR,GAAG;AAAA;AAAA,MACN;AAAA,OACF,IACA;AAAA,KACJ;AAEJ;;;ACjCA,SAAS,SAAAK,QAAO,UAAAC,eAAc;AAC9B,SAAS,WAAAC,gBAAe;AAWhB,SACE,OAAAC,OADF,QAAAC,cAAA;AAPD,IAAM,mBAAmB,MAAM;AACpC,QAAM,EAAE,uBAAuB,WAAW,IAAI,cAAc;AAC5D,SACE,gBAAAD;AAAA,IAACE;AAAA,IAAA;AAAA,MACC,SAAQ;AAAA,MACR,UAAS;AAAA,MACT,QACE,gBAAAD,OAACE,UAAA,EAAQ,IAAI,EAAE,WAAW,EAAE,GAC1B;AAAA,wBAAAH,MAACI,SAAA,EAAO,SAAQ,YAAW,OAAM,WAAU,MAAK,SAAQ,SAAS,YAAY,uBAE7E;AAAA,QACA,gBAAAJ,MAACI,SAAA,EAAO,SAAQ,YAAW,OAAM,WAAU,MAAK,SAAQ,SAAS,uBAAuB,oBAExF;AAAA,SACF;AAAA,MAEH;AAAA;AAAA,EAED;AAEJ;;;ACzBA,SAAS,UAAAC,SAAQ,iBAAAC,gBAA4B,eAAAC,cAAa,aAAAC,kBAAiB;AAmBrE,gBAAAC,OAUA,QAAAC,cAVA;AARC,IAAM,mBAAoD,CAAC,EAAE,kBAAkB,YAAY,GAAG,MAAM,MAAM;AAC/G,SACE,gBAAAD;AAAA,IAAC;AAAA;AAAA,MACC;AAAA,MACA,wBAAwB;AAAA,MACxB,MAAM,MAAM;AAAA,MACZ,cAAc,MAAG;AAjBvB;AAiB0B,2BAAM,YAAN,+BAAgB,CAAC,GAAG;AAAA;AAAA,MAExC,0BAAAA,MAAC,yBAAuB,GAAG,OAAO;AAAA;AAAA,EACpC;AAEJ;AAEO,IAAM,wBAAyD,CAAC,UAAU;AAC/E,QAAM,EAAE,kBAAkB,YAAY,YAAY,IAAI,cAAc;AAEpE,SACE,gBAAAC,OAACC,SAAA,EAAO,mBAAgB,sBAAqB,oBAAiB,4BAA2B,WAAS,MAAC,UAAU,MAAO,GAAG,OACrH;AAAA,oBAAAD,OAACE,cAAA,EAAY,IAAG,sBAAqB;AAAA;AAAA,MACX,gBAAAH,MAAC,wBAAqB;AAAA,OAChD;AAAA,IACA,gBAAAC,OAACG,gBAAA,EAAc,IAAI,EAAE,SAAS,QAAQ,eAAe,UAAU,QAAQ,EAAE,GACvE;AAAA,sBAAAJ,MAAC,sBACC,0BAAAA,MAACK,YAAA,EACC,0BAAAL,MAAC,mBAAgB,aAAa,aAAa,6BAAe,GAC5D,GACF;AAAA,MACA,gBAAAA,MAAC,uBAAoB;AAAA,MACpB,aACC,gBAAAA,MAAC,wBAAqB,IACtB;AAAA,MACD,mBACC,gBAAAA,MAAC,oBAAiB,IAClB;AAAA,OACJ;AAAA,IACA,gBAAAA,MAAC,uBAAoB,SAAS,MAAM,SAAS;AAAA,KAC/C;AAEJ;;;ACjDA,SAAS,UAAU,YAAY,sBAAsB,8BAA8B;AACnF,SAAS,UAAAM,SAAQ,eAAAC,cAAa,aAAAC,YAAW,YAAAC,iBAA+B;AACxE,SAAS,YAAAC,iBAAgB;AAkBnB,SACc,OAAAC,OADd,QAAAC,cAAA;AARC,IAAM,qBAAwD,CAAC,EAAE,kBAAkB,YAAY,GAAG,MAAM,MAAM;AACnH,QAAM,CAAC,MAAM,OAAO,IAAIC,UAAS,KAAK;AAEtC,QAAM,aAAa,MAAM;AACvB,YAAQ,IAAI;AAAA,EACd;AACA,SACE,gBAAAD,OAACE,WAAA,EAAU,GAAG,OACZ;AAAA,oBAAAF,OAACG,YAAA,EAAU;AAAA;AAAA,MACG,gBAAAJ,MAAC,wBAAqB;AAAA,OACpC;AAAA,IACA,gBAAAA,MAACI,YAAA,EAAU,OAAM,UACd,uBACC,gBAAAJ,MAAC,0BAAuB,OAAM,WAAU,IACxC,gBAAAA,MAAC,cAAW,OAAM,SAAQ,GAC9B;AAAA,IACA,gBAAAC,OAACG,YAAA,EACC;AAAA,sBAAAJ,MAAC,oBAAiB,kBAAoC,MAAY,SAAS,MAAM,QAAQ,KAAK,GAAG,YAAwB;AAAA,MACzH,gBAAAA,MAACK,cAAA,EAAY,WAAS,MACpB,0BAAAL,MAACM,SAAA,EAAO,SAAQ,aAAY,MAAK,SAAQ,SAAS,YAAY,oBAE9D,GACF;AAAA,OACF;AAAA,KACF;AAEJ;;;ACtCA,SAAS,kBAAkB;AAC3B,SAAS,wBAAwB;AACjC,SAAuB,SAAS,WAAAC,gBAAe;AAC/C,SAAS,oBAAoB;AAC7B,SAAS,kBAAkB;;;ACJ3B,SAAS,cAAAC,mBAAkB;AAG3B,SAAS,YAAAC,iBAAgB;AAWlB,IAAM,aAAa,CAAC,EAAE,QAAQ,SAAS,OAAO,WAAW,MAAM,IAAuB,CAAC,MAGzF;AACH,QAAM,wBAAwB,kBAAkB;AAChD,QAAM,CAAC,iBAAiB,kBAAkB,IAAIC,UAAgB;AAC9D,MAAI,UAAU,WAAW,CAAC,iBAAiB;AACzC,uBAAmB,IAAI,MAAM,wEAAwE,CAAC;AAAA,EACxG;AAEA,MAAI,SAAS,WAAW,CAAC,iBAAiB;AACxC,uBAAmB,IAAI,MAAM,uEAAuE,CAAC;AAAA,EACvG;AAEA,QAAM,CAAC,OAAO,QAAQ,IAAIA,UAAgB;AAC1C,QAAM,CAAC,cAAc,IAAI,kBAAkB,CAAC,UAAU,QAAQ;AAC9D,QAAM,EAAE,mBAAmB,IAAI,iBAAiB,KAAK;AACrD,QAAM,CAAC,aAAa,IAAIC,YAAW,YAAY;AA/BjD;AAgCI,QAAI;AACF,UAAI,CAAC,iBAAiB;AACpB,YAAI,QAAQ;AACV,iBAAO,QAAM,sCAAQ,eAAR,gCAAqB,GAAG,SAAS,CAAC;AAAA,QACjD,WAAW,gBAAgB;AACzB,iBAAO,QAAM,sDAAgB,eAAhB,wCAA6B,GAAG,SAAS,sBAAsB,CAAC;AAAA,QAC/E;AAAA,MACF;AAAA,IACF,SAAS,IAAI;AACX,YAAMC,SAAQ;AACd,cAAQ,MAAMA,OAAM,OAAO;AAC3B,eAASA,MAAK;AAAA,IAChB;AAAA,EACF,GAAG,CAAC,OAAO,QAAQ,gBAAgB,oBAAoB,eAAe,CAAC;AACvE,MAAI,mBAAmB,CAAC,OAAO;AAC7B,YAAQ,MAAM,gBAAgB,OAAO;AACrC,aAAS,eAAe;AAAA,EAC1B;AAEA,SAAO;AAAA,IACL,QAAQ,SACN,WAAW,iBAAiB,wBAAwB,OACpD;AAAA,IACF;AAAA,EACF;AACF;;;ACzDA,SAAS,cAAAC,mBAAkB;AAC3B,SAAS,gBAAgB;AAEzB,SAAS,YAAAC,iBAAgB;AAYlB,IAAM,YAAY,CAAC,EAAE,UAAU,QAAQ,MAAM,WAAW,OAAO,KAAK,IAAsB,CAAC,MAG7F;AACH,QAAM,wBAAwB,kBAAkB;AAChD,QAAM,CAAC,OAAO,QAAQ,IAAIC,UAAgB;AAC1C,QAAM,CAAC,cAAc,IAAI,yBAAyB,CAAC,UAAU,QAAQ;AACrE,QAAM,CAAC,aAAa,IAAIC,YAAW,YAAY;AAtBjD;AAuBI,QAAI;AACF,YAAM,aAAa,OAAO,MAAM;AAC9B,YAAI,QAAQ;AACV,iBAAO;AAAA,QACT,WAAW,UAAU;AACnB,iBAAO,SAAS,WAAW,QAAQ;AAAA,QACrC,WAAW,MAAM;AACf,iBAAO,SAAS,SAAS,IAAI;AAAA,QAC/B;AACA,eAAO;AAAA,MACT,GAAG;AAEH,aAAO,QAAO,8CAAY,eAAZ,oCAAyB,QAAQ,cAAc;AAAA,IAC/D,SAAS,IAAI;AACX,eAAS,EAAW;AAAA,IACtB;AAAA,EACF,GAAG,CAAC,UAAU,gBAAgB,MAAM,MAAM,MAAM,CAAC;AACjD,SAAO,CAAC,kBAAkB,wBAAwB,OAAO,gBAAgB,KAAK;AAChF;;;ACzCA,SAAS,cAAAC,mBAAkB;AAWpB,IAAM,aAAa,CAAC,EAAE,QAAQ,MAAM,MAAmF;AAC5H,QAAM,wBAAwB,kBAAkB;AAChD,QAAM,CAAC,WAAW,IAAI,UAAU,EAAE,OAAO,CAAC;AAC1C,QAAM,CAAC,SAAS,KAAK,IAAIC;AAAA,IACvB,YAAa,cAAc,MAAM,QAAQ,IAAI,MAAM,IAAI,CAAC,SAAS,YAAY,WAAW,IAAI,CAAC,CAAC,IAAI;AAAA,IAClG,CAAC,aAAa,KAAK;AAAA,EACrB;AACA,SAAO,CAAC,YAAY,wBAAwB,OAAO,UAAU,KAAK;AACpE;;;ACnBA,SAAgC,cAAAC,mBAAkB;AAClD,SAAS,YAAAC,iBAAgB;AAGzB,SAAS,aAAa;AAEtB,IAAI;AACJ,IAAM,2BAA2B,IAAI,MAAM;AAEpC,IAAM,oBAAoB,CAC/B,YACsF;AACtF,SAAOD,YAAW,YAAY;AAC5B,WAAO,MAAM,yBAAyB,aAAa,YAAY;AAE7D,UAAI,YAAY,QAAW;AACzB,eAAO;AAAA,MACT;AAEA,UAAI,qBAAqB;AACvB,eAAO;AAAA,MACT;AAEA,UAAI;AACF,8BAAsB,MAAMC,UAAS,OAAO;AAC5C,gBAAQ,IAAI,2CAA2C,oBAAoB,OAAO,EAAE;AAAA,MACtF,SAAS,IAAI;AACX,cAAM,QAAQ;AACd,gBAAQ,MAAM,0CAA0C,MAAM,OAAO,EAAE;AAAA,MACzE;AACA,aAAO;AAAA,IACT,CAAC;AAAA,EACH,GAAG,CAAC,OAAO,CAAC;AACd;;;AJZM,gBAAAC,OACA,QAAAC,cADA;AAPC,IAAM,uBAA4D,CAAC,EAAE,aAAa,+BAA+B,SAAS,GAAG,MAAM,MAAM;AAC9I,QAAM,CAAC,YAAY,IAAI,WAAW,EAAE,QAAQ,CAAC;AAC7C,QAAM,EAAE,QAAQ,IAAI,WAAW;AAC/B,QAAM,oBAAoB,GAAG,UAAU,mBAAmB,6CAAc,OAAO,aAAY,mCAAS,SAAQ,MAAM;AAElH,SACE,gBAAAA,OAAC,WAAS,GAAG,OACX;AAAA,oBAAAD,MAAC,oBAAiB,SAAS,WAAW,WAAW,6CAAc,OAAO,GAAG;AAAA,IACzE,gBAAAC,OAACC,UAAA,EAAQ,KAAK,GACZ;AAAA,sBAAAF,MAAC,gBAAa,SAAO,MAAC,OAAM,UAAS,OAAO,GAAG,IAAI,GAAG,iBAAiB,sCAAsC,QAAO,UAAS;AAAA,MAC7H,gBAAAA,MAAC,gBAAa,SAAO,MAAC,OAAM,QAAO,OAAO,GAAG,IAAI,GAAG,iBAAiB,oCAAoC,QAAO,UAAS;AAAA,MACzH,gBAAAA,MAAC,gBAAa,SAAO,MAAC,OAAM,cAAa,OAAO,GAAG,IAAI,GAAG,iBAAiB,0CAA0C,QAAO,UAAS;AAAA,MACrI,gBAAAA,MAAC,gBAAa,SAAO,MAAC,OAAM,WAAU,OAAO,GAAG,IAAI,GAAG,iBAAiB,uCAAuC,QAAO,UAAS;AAAA,OACjI;AAAA,KACF;AAEJ;;;AK9BA,SAAS,kBAAkB,gBAA6B;AACxD,SAAS,gBAAgB;AACzB,SAAS,2BAAqD;AAiC1D,qBAAAG,WAYc,OAAAC,aAZd;AAnBJ,IAAM,aAAa,CAAC,QAAgB,QAAQ,MAAM;AAChD,SAAO,CAAC,GAAG,MAAM,KAAK,EAAE,OAAO,CAAC,EAAE,KAAK,CAAC,EAAE,IAAI,CAAC,MAAM,IAAI,KAAK;AAChE;AAEO,IAAM,sBAA0D,CAAC;AAAA,EACtE,eAAe,CAAC;AAAA,EAChB;AAAA,EACA,WAAW;AAAA,EACX;AAAA,EACA,cAAc;AAAA,EACd,eAAe;AAAA,EACf;AAAA,EACA,UAAU;AAAA,EACV,GAAG;AACL,MAAM;AACJ,QAAM,EAAE,qBAAqB,GAAG,uBAAuB,eAAe,IAAI,iBAAiB;AAC3F,QAAM,WAAW,CAAC,kBAAkB,uBAAuB;AAE3D,SACE,gBAAAA,MAAAD,WAAA,EACG,2BACC,gBAAAC;AAAA,IAAC;AAAA;AAAA,MACC,QAAO;AAAA,MACP;AAAA,MACA,aAAa,CAAC,yBAAyB;AACrC,cAAM,OAAiB,MAAM;AAC3B,gBAAM,CAAC,eAAe,IAAI,UAAU,EAAE,MAAM,qBAAqB,SAAS,GAAG,QAAQ,eAAe,CAAC;AACrG,gBAAM,aAAa,kBAAkB,aAAa,gBAAgB,OAAO,IAAI;AAC7E,gBAAM,WAAW,CAAC,CAAC,mBAAmB,gBAAgB,WAAW;AACjE,iBACE,gBAAAA,MAAC,YAAS,OAAO,sBAAsB,IAAI,EAAE,WAAW,GAAG,eAAe,GAAG,YAAY,EAAE,GACzF,0BAAAA;AAAA,YAAC;AAAA;AAAA,cACC,kBAAkB;AAAA,cAClB,UAAU;AAAA,cACV,SAAS,mDAAiB;AAAA,cAC1B;AAAA,cACA;AAAA,cACA;AAAA,cACA,MAAM;AAAA,cACN;AAAA,cACA;AAAA;AAAA,UACF,GACF;AAAA,QAEJ;AACA,eAAO,gBAAAA,MAAC,QAAK;AAAA,MACf;AAAA,MACA,OAAO;AAAA,MACP,UAAU,CAAC,UAAU,+DAAwB,OAAO,SAAS,GAAG,MAAM,OAAO,KAAK,EAAE;AAAA,MACpF;AAAA,MACA;AAAA,MACC,GAAG;AAAA,MAEH,qBAAW,WAAW,EAAE,IAAI,CAAC,UAAU;AACtC,cAAM,OAAiB,MAAM;AAC3B,gBAAM,CAAC,OAAO,IAAI,UAAU,EAAE,MAAM,MAAM,SAAS,GAAG,QAAQ,eAAe,CAAC;AAC9E,gBAAM,aAAa,UAAU,aAAa,QAAQ,OAAO,IAAI;AAC7D,gBAAM,WAAW,CAAC,CAAC,WAAW,QAAQ,WAAW;AACjD,iBACE,gBAAAA,MAAC,YAAgC,OAAO,OAAO,IAAI,EAAE,WAAW,GAAG,eAAe,GAAG,YAAY,EAAE,GACjG,0BAAAA;AAAA,YAAC;AAAA;AAAA,cACC,kBAAkB;AAAA,cAClB,UAAU;AAAA,cACV,SAAS,mCAAS;AAAA,cAClB;AAAA,cACA;AAAA,cACA;AAAA,cACA;AAAA,cACA,MAAM;AAAA,cACN;AAAA;AAAA,UACF,KAXa,mCAAS,OAYxB;AAAA,QAEJ;AAEA,eAAO,gBAAAA,MAAC,UAAU,KAAO;AAAA,MAC3B,CAAC;AAAA;AAAA,EACH,IACA,gBAAAA,MAAC,oBAAiB,MAAM,IAAI,GAChC;AAEJ;;;ACjGA,SAAuB,WAAAC,gBAAe;AA0BhC,gBAAAC,aAAA;AAZC,IAAM,yBAAgE,CAAC;AAAA,EAC5E,eAAe,CAAC;AAAA,EAChB;AAAA,EACA;AAAA,EACA;AAAA,EACA,cAAc;AAAA,EACd,eAAe;AAAA,EACf,OAAO;AAAA,EACP,GAAG;AACL,MAAM;AACJ,SACE,gBAAAA,MAACC,UAAA,EAAQ,YAAW,WAAW,GAAG,OAChC,0BAAAD;AAAA,IAAC;AAAA;AAAA,MACC;AAAA,MACA,WAAS;AAAA,MACT;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA,MAAM,QAAQ;AAAA,MACd,SAAQ;AAAA;AAAA,EACV,GACF;AAEJ;","names":["jsx","jsxs","desiredMaximumAccounts","Typography","useState","jsx","jsxs","Alert","AlertTitle","Snackbar","useState","Fragment","jsx","jsxs","Button","DialogActions","generateMnemonic","wordlist","useEffect","useState","jsx","wordlist","useState","useEffect","generateMnemonic","createContextEx","useEffect","useState","jsx","useState","useEffect","usePromise","useContextEx","useContextEx","usePromise","jsx","jsxs","DialogActions","Button","Link","Typography","jsx","jsxs","useMemo","jsx","jsxs","Fragment","jsx","jsxs","Button","DialogActions","jsx","jsxs","DialogActions","Button","FormControl","TextField","useState","Fragment","jsx","jsxs","useState","FormControl","TextField","Alert","Button","FlexRow","jsx","jsxs","Alert","FlexRow","Button","Dialog","DialogContent","DialogTitle","FormLabel","jsx","jsxs","Dialog","DialogTitle","DialogContent","FormLabel","Button","ButtonGroup","TableCell","TableRow","useState","jsx","jsxs","useState","TableRow","TableCell","ButtonGroup","Button","FlexRow","usePromise","useState","useState","usePromise","error","usePromise","useState","useState","usePromise","usePromise","usePromise","usePromise","HDWallet","jsx","jsxs","FlexRow","Fragment","jsx","FlexCol","jsx","FlexCol"]}
1
+ {"version":3,"sources":["../../src/components/MaxAccounts/MaxAccountsTableRow.tsx","../../src/components/MaxAccounts/OutOfBoundsSnackBar.tsx","../../src/components/SeedPhrase/_shared/SeedPhraseIconButton.tsx","../../src/components/SeedPhrase/DefaultSeedPhrase.tsx","../../src/components/SeedPhrase/dialog/components/DialogActionButtons.tsx","../../src/contexts/SeedPhrase/Context.ts","../../src/contexts/SeedPhrase/Provider.tsx","../../src/contexts/SeedPhrase/use.tsx","../../src/contexts/Wallet/Context.ts","../../src/contexts/Wallet/Provider.tsx","../../src/contexts/Wallet/use.ts","../../src/components/SeedPhrase/dialog/components/fields/NewPhraseTextField.tsx","../../src/components/SeedPhrase/dialog/components/fields/validation-messages/colorParser.ts","../../src/components/SeedPhrase/dialog/components/fields/validation-messages/InvalidPhrase.tsx","../../src/components/SeedPhrase/dialog/components/fields/validation-messages/PhraseHeaderBox.tsx","../../src/components/SeedPhrase/dialog/components/fields/PhraseDialogActions.tsx","../../src/components/SeedPhrase/dialog/components/fields/SavedPhraseTextField.tsx","../../src/components/SeedPhrase/dialog/components/OverwriteWarning.tsx","../../src/components/SeedPhrase/dialog/SeedPhraseDialog.tsx","../../src/components/SeedPhrase/settings/SeedPhraseTableRow.tsx","../../src/components/WalletAccountDetails/WalletAccountDetails.tsx","../../src/hooks/useAccount.ts","../../src/hooks/useWallet.ts","../../src/hooks/useWallets.ts","../../src/hooks/useWrapperAccount.ts","../../src/components/WalletAccountSelect/Select.tsx","../../src/components/WalletAccountSelect/SelectBar.tsx"],"sourcesContent":["import { ButtonGroup, TableCell, TableRow, TableRowProps, Typography } from '@mui/material'\nimport { ButtonEx } from '@xylabs/react-button'\nimport { useState } from 'react'\n\nimport { OutOfBoundsSnackBar } from './OutOfBoundsSnackBar'\n\nexport interface MaxAccountsTableRow extends TableRowProps {\n activeAccountIndex?: number\n changeMaxAccounts?: (maxAccounts: number) => void\n maxAccounts?: number\n}\n\nexport const MaxAccountsTableRow: React.FC<MaxAccountsTableRow> = ({ activeAccountIndex, changeMaxAccounts, maxAccounts }) => {\n const [desiredMaximumAccounts, setDesiredMaximumAccounts] = useState<number | undefined>()\n const [showSnackBar, setShowSnackBar] = useState(false)\n\n const handleChangeMaxAccounts = (change: 'increase' | 'decrease') => {\n if (maxAccounts !== undefined && activeAccountIndex !== undefined) {\n switch (change) {\n case 'decrease': {\n const desiredMaximumAccounts = maxAccounts - 1\n const validMaximumAccounts = desiredMaximumAccounts > 0\n const maxAccountsWithinRange = activeAccountIndex + 1 <= desiredMaximumAccounts\n if (validMaximumAccounts && maxAccountsWithinRange) {\n changeMaxAccounts?.(desiredMaximumAccounts)\n }\n if (!maxAccountsWithinRange) setShowSnackBar(true)\n setDesiredMaximumAccounts(desiredMaximumAccounts)\n return\n }\n case 'increase': {\n changeMaxAccounts?.(maxAccounts + 1)\n return\n }\n default: {\n console.error(change, 'is not a recognized value')\n }\n }\n } else {\n throw new Error('Max Accounts is unset and needs a default')\n }\n }\n\n return (\n <TableRow>\n <TableCell>Maximum Accounts</TableCell>\n <TableCell align=\"center\">\n <Typography variant={'caption'}>{maxAccounts}</Typography>\n </TableCell>\n <TableCell align=\"center\">\n <ButtonGroup>\n <ButtonEx onClick={() => handleChangeMaxAccounts('decrease')} variant={'contained'} size={'small'}>\n -\n </ButtonEx>\n <ButtonEx onClick={() => handleChangeMaxAccounts('increase')} variant={'contained'} size={'small'}>\n +\n </ButtonEx>\n </ButtonGroup>\n <OutOfBoundsSnackBar\n desiredMaximumAccounts={desiredMaximumAccounts}\n activeAccountIndex={activeAccountIndex}\n setShowSnackBar={setShowSnackBar}\n showSnackBar={showSnackBar}\n />\n </TableCell>\n </TableRow>\n )\n}\n","import { Alert, AlertTitle, Snackbar, SnackbarProps } from '@mui/material'\nimport { Dispatch, SetStateAction } from 'react'\n\nexport interface OutOfBoundsSnackBarProps extends SnackbarProps {\n activeAccountIndex?: number\n desiredMaximumAccounts?: number\n setShowSnackBar?: Dispatch<SetStateAction<boolean>>\n showSnackBar?: boolean\n}\n\nexport const OutOfBoundsSnackBar: React.FC<OutOfBoundsSnackBarProps> = ({\n activeAccountIndex,\n desiredMaximumAccounts,\n setShowSnackBar,\n showSnackBar,\n}) => {\n return (\n <Snackbar\n anchorOrigin={{ horizontal: 'center', vertical: 'top' }}\n autoHideDuration={5000}\n onClose={() => setShowSnackBar?.(false)}\n open={showSnackBar}\n >\n <Alert severity={'error'} onClose={() => setShowSnackBar?.(false)}>\n <AlertTitle>Maximum Accounts Error</AlertTitle>\n Your currently selected account number ({activeAccountIndex === undefined ? '' : activeAccountIndex + 1}) cannot be greater than the desired\n Maximum Accounts ({desiredMaximumAccounts}).\n </Alert>\n </Snackbar>\n )\n}\n","import { HelpOutline as HelpOutlineIcon } from '@mui/icons-material'\nimport {\n Button,\n Dialog,\n DialogActions,\n DialogContent,\n DialogTitle,\n IconButton,\n IconButtonProps,\n Link,\n List,\n ListItem,\n Typography,\n} from '@mui/material'\nimport { useState } from 'react'\n\nexport const SeedPhraseIconButton: React.FC<IconButtonProps> = (props) => {\n const [open, setOpen] = useState(false)\n const onClose = () => setOpen(false)\n return (\n <>\n <IconButton onClick={() => setOpen(true)} {...props}>\n <HelpOutlineIcon fontSize=\"small\" />\n </IconButton>\n <Dialog open={open}>\n <DialogTitle>Understanding your Seed Phrase</DialogTitle>\n <DialogContent>\n <Typography>\n Your Seed Phrase should adhere to the{' '}\n <Link target={'_blank'} href=\"https://github.com/bitcoin/bips/blob/master/bip-0039.mediawiki\">\n bip39 specification\n </Link>{' '}\n and is used to generate accounts which identify your data on the XYO Network.\n </Typography>\n <List>\n <ListItem>Do not share this phrase with anyone.</ListItem>\n <ListItem>Do not save it to a public computer.</ListItem>\n <ListItem>Do not use a existing phrase from another wallet (i.e. Metamask).</ListItem>\n <ListItem>Do not use before copying it down somewhere safe.</ListItem>\n </List>\n </DialogContent>\n <DialogActions>\n <Button onClick={onClose} variant=\"outlined\">\n OK\n </Button>\n </DialogActions>\n </Dialog>\n </>\n )\n}\n","import { Alert, AlertTitle, Snackbar } from '@mui/material'\nimport { generateMnemonic } from '@scure/bip39'\n// eslint-disable-next-line import/no-internal-modules\nimport { wordlist } from '@scure/bip39/wordlists/english'\nimport { WithChildren } from '@xylabs/react-shared'\nimport { useEffect, useState } from 'react'\n\nexport interface DefaultSeedPhraseProps extends WithChildren {\n changeSeedPhrase?: (seedPhrase: string) => void\n hideDefaultSeedPhraseMessage?: boolean\n seedPhrase?: string\n}\n\nexport const DefaultSeedPhrase: React.FC<DefaultSeedPhraseProps> = ({ changeSeedPhrase, children, hideDefaultSeedPhraseMessage, seedPhrase }) => {\n const [showSnackBar, setShowSnackBar] = useState(false)\n\n useEffect(() => {\n if (!seedPhrase) {\n const mnemonic = generateMnemonic(wordlist, 256)\n changeSeedPhrase?.(mnemonic)\n setShowSnackBar(true)\n }\n }, [changeSeedPhrase, seedPhrase])\n\n return (\n <>\n {hideDefaultSeedPhraseMessage ? null : (\n <Snackbar\n open={showSnackBar}\n autoHideDuration={5000}\n onClose={() => setShowSnackBar(false)}\n anchorOrigin={{ horizontal: 'center', vertical: 'top' }}\n >\n <Alert severity={'success'}>\n <AlertTitle>Default Seed Phrase Generated</AlertTitle>\n Go to application settings to save it.\n </Alert>\n </Snackbar>\n )}\n {children}\n </>\n )\n}\n","import { Button, DialogActions, DialogActionsProps, DialogProps } from '@mui/material'\nimport { MouseEvent } from 'react'\n\nimport { useSeedPhrase } from '../../../../contexts'\n\ninterface DialogActionButtonsProps extends DialogActionsProps {\n onClose?: DialogProps['onClose']\n}\n\nexport const DialogActionButtons: React.FC<DialogActionButtonsProps> = ({ onClose, ...props }) => {\n const { handleSave, setPhrase } = useSeedPhrase()\n\n const wrappedOnClose = (e: MouseEvent<HTMLElement>) => {\n // clear local copy of phrase when modal closes\n setPhrase?.('')\n onClose?.(e, 'escapeKeyDown')\n }\n\n return (\n <DialogActions {...props}>\n <Button variant=\"outlined\" onClick={wrappedOnClose}>\n Cancel\n </Button>\n <Button variant=\"outlined\" onClick={handleSave}>\n Save\n </Button>\n </DialogActions>\n )\n}\n","import { createContextEx } from '@xyo-network/react-shared'\n\nimport { SeedPhraseContextState } from './State'\n\nexport const SeedPhraseContext = createContextEx<SeedPhraseContextState>()\n","import { generateMnemonic, validateMnemonic } from '@scure/bip39'\n// eslint-disable-next-line import/no-internal-modules\nimport { wordlist } from '@scure/bip39/wordlists/english'\nimport { WithChildren } from '@xylabs/react-shared'\nimport { useCallback, useEffect, useMemo, useState } from 'react'\n\nimport { SeedPhraseContext } from './Context'\n\nexport interface SeedPhraseProviderProps extends WithChildren {\n defaultPhrase?: string\n handleChangeSeedPhrase?: (phrase: string) => void\n open?: boolean\n saveCallback?: () => void\n seedPhrase?: string\n}\n\nconst validate = (passedPhrase?: string) => {\n if (!passedPhrase) {\n return null\n }\n return validateMnemonic(passedPhrase, wordlist)\n}\n\nexport const SeedPhraseProvider: React.FC<SeedPhraseProviderProps> = ({\n children,\n defaultPhrase,\n handleChangeSeedPhrase,\n saveCallback,\n seedPhrase,\n open,\n}) => {\n const [phrase, setPhrase] = useState<string | undefined>()\n const [overwriteWarning, setOverwriteWarning] = useState(false)\n\n useEffect(() => {\n setPhrase(defaultPhrase)\n }, [defaultPhrase])\n\n useEffect(() => {\n if (seedPhrase || open) {\n setPhrase?.(seedPhrase ?? '')\n }\n }, [seedPhrase, open, setPhrase])\n\n const handleGenerate = useCallback(() => {\n const mnemonic = generateMnemonic(wordlist, 256)\n setPhrase?.(mnemonic)\n setOverwriteWarning?.(false)\n }, [])\n\n const handleCancelOverwrite = useCallback(() => {\n setOverwriteWarning?.(false)\n }, [])\n\n const handleClear = useCallback(() => {\n setPhrase?.('')\n setOverwriteWarning?.(false)\n }, [])\n\n const handleSave = useCallback(() => {\n if (!overwriteWarning && seedPhrase && seedPhrase !== phrase) {\n setOverwriteWarning?.(true)\n } else {\n handleChangeSeedPhrase?.(phrase ?? '')\n saveCallback?.()\n }\n }, [handleChangeSeedPhrase, overwriteWarning, phrase, saveCallback, seedPhrase])\n\n useEffect(() => {\n if (!open) {\n handleCancelOverwrite()\n }\n }, [handleCancelOverwrite, open])\n\n const validSeedPhrase = useMemo(() => validate?.(seedPhrase), [seedPhrase])\n const validPhrase = useMemo(() => validate?.(phrase), [phrase])\n\n return (\n <SeedPhraseContext.Provider\n value={{\n handleCancelOverwrite,\n handleChangeSeedPhrase,\n handleClear,\n handleGenerate,\n handleSave,\n overwriteWarning,\n phrase,\n provided: true,\n seedPhrase,\n setOverwriteWarning,\n setPhrase,\n validPhrase,\n validSeedPhrase,\n validate,\n }}\n >\n {children}\n </SeedPhraseContext.Provider>\n )\n}\n","import { useContextEx } from '@xyo-network/react-shared'\n\nimport { SeedPhraseContext } from './Context'\n\nexport const useSeedPhrase = () => useContextEx(SeedPhraseContext, 'SeedPhrase', true)\n","import { createContextEx } from '@xyo-network/react-shared'\n\nimport { WalletContextState } from './State'\n\nexport const WalletContext = createContextEx<WalletContextState>()\n","import { usePromise } from '@xylabs/react-promise'\nimport { WithChildren } from '@xylabs/react-shared'\nimport { WalletInstance } from '@xyo-network/wallet-model'\nimport { useEffect, useState } from 'react'\n\nimport { WalletContext } from './Context'\n\nexport interface WalletProviderProps {\n /** @deprecated - BasePath is no longer supported. Set base path outside of WalletProvider */\n basePath?: string\n defaultActiveAccountIndex?: number\n rootWallet?: WalletInstance | null\n}\n\nexport const WalletProvider: React.FC<WithChildren<WalletProviderProps>> = ({\n basePath,\n children,\n defaultActiveAccountIndex = 0,\n rootWallet = null,\n ...props\n}) => {\n const [activeAccountIndex, setActiveAccountIndex] = useState(defaultActiveAccountIndex)\n\n useEffect(() => {\n if (defaultActiveAccountIndex !== undefined) {\n setActiveAccountIndex(defaultActiveAccountIndex)\n }\n }, [defaultActiveAccountIndex])\n\n const [activeAccount = null] = usePromise(async () => await rootWallet?.derivePath(activeAccountIndex.toString()), [activeAccountIndex, rootWallet])\n\n return (\n <WalletContext.Provider\n value={{\n activeAccount,\n activeAccountIndex,\n basePath,\n /* eslint-disable deprecation/deprecation */\n /** @deprecated - Set path for coinTypeWallet outside of provider and pass as rootWallet */\n coinTypeWallet: null,\n provided: true,\n rootWallet,\n setActiveAccountIndex,\n }}\n {...props}\n >\n {children}\n </WalletContext.Provider>\n )\n}\n","import { usePromise } from '@xylabs/react-promise'\nimport { useContextEx, useProvided } from '@xyo-network/react-shared'\nimport { WalletInstance } from '@xyo-network/wallet-model'\n\nimport { WalletContext } from './Context'\n\nexport const useWalletContext = (required = true) => {\n return useContextEx(WalletContext, 'Wallet', required)\n}\n\nexport const useWalletProvided = () => {\n return useProvided(WalletContext)\n}\n\n/** @deprecated - useWalletContext instead */\nexport const useCoinTypeWallet = (required = true): [WalletInstance | null | undefined, Error | undefined] => {\n const { coinTypeWallet } = useWalletContext(required)\n return [coinTypeWallet, undefined]\n}\n\nexport const useRootWallet = (required = true): [WalletInstance | null | undefined, Error | undefined] => {\n const { rootWallet } = useWalletContext(required)\n return [rootWallet, undefined]\n}\n\nexport const useIndexedWalletFromContext = (index: number, required = true): [WalletInstance | null | undefined, Error | undefined] => {\n const { rootWallet } = useWalletContext(required)\n const [wallet] = usePromise(async () => (await rootWallet?.derivePath(index.toString())) ?? rootWallet, [rootWallet, index])\n return [wallet, undefined]\n}\n\nexport const useSelectedWalletAccount = (required = true): [WalletInstance | null | undefined, Error | undefined] => {\n const { activeAccountIndex } = useWalletContext(required)\n //we pass in 0 as default since we can not call the hook optionally,\n //we resolve this false result by checking whether activeAccountIndex is defined before returning it\n const [account] = useIndexedWalletFromContext(activeAccountIndex ?? 0, required)\n return activeAccountIndex === undefined && account === null ? [null, undefined] : [account, undefined]\n}\n","import { FormControl, StandardTextFieldProps, TextField } from '@mui/material'\nimport { ReactNode } from 'react'\n\nimport { useSeedPhrase } from '../../../../../contexts'\nimport { colorParser, InvalidPhraseTypography } from './validation-messages'\n\nexport interface NewPhraseTextFieldProps extends StandardTextFieldProps {\n children?: ReactNode\n disableColor?: boolean\n}\n\nexport const NewPhraseTextField: React.FC<NewPhraseTextFieldProps> = ({ children, disableColor, ...props }) => {\n const { phrase, setPhrase, validPhrase } = useSeedPhrase()\n return (\n <>\n <FormControl fullWidth size=\"small\" sx={{ display: 'flex', flexDirection: 'column', rowGap: 1 }}>\n {children}\n <TextField\n focused\n color={disableColor ? undefined : colorParser(validPhrase)}\n error={validPhrase === false}\n helperText={validPhrase === false ? <InvalidPhraseTypography /> : null}\n fullWidth\n maxRows={Number.POSITIVE_INFINITY}\n multiline\n onChange={(e) => setPhrase?.(e.target.value)}\n value={phrase}\n {...props}\n />\n </FormControl>\n </>\n )\n}\n","export const colorParser = (conditional?: boolean | null) => {\n switch (conditional) {\n case true: {\n return 'success'\n }\n case false: {\n return 'error'\n }\n default: {\n return\n }\n }\n}\n","import { Link, Typography, TypographyProps } from '@mui/material'\n\nexport const InvalidPhraseTypography: React.FC<TypographyProps> = (props) => (\n <Typography variant={'caption'} color={'error'} {...props}>\n Invalid seed phrase. See -{' '}\n <Link target={'_blank'} href=\"https://github.com/bitcoin/bips/blob/master/bip-0039.mediawiki\">\n bip39 Proposal\n </Link>\n </Typography>\n)\n","import { CheckCircleOutline as CheckCircleOutlineIcon, HighlightOff as HighlightOffIcon } from '@mui/icons-material'\nimport { FlexBoxProps, FlexRow } from '@xylabs/react-flexbox'\nimport { WithChildren } from '@xylabs/react-shared'\nimport { useMemo } from 'react'\n\ninterface PhraseHeaderBox extends FlexBoxProps, WithChildren {\n conditional?: boolean | null\n}\n\nexport const PhraseHeaderBox: React.FC<PhraseHeaderBox> = ({ children, conditional, ...props }) => {\n const state = useMemo(() => {\n switch (conditional) {\n case true: {\n return 'success'\n }\n case false: {\n return 'error'\n }\n default: {\n return null\n }\n }\n }, [conditional])\n\n const Icon = useMemo(() => {\n switch (state) {\n case 'success': {\n return <CheckCircleOutlineIcon fontSize=\"small\" color=\"success\" />\n }\n case 'error': {\n return <HighlightOffIcon fontSize=\"small\" color=\"error\" />\n }\n default: {\n return null\n }\n }\n }, [state])\n\n return (\n <FlexRow justifyContent={'start'} columnGap={1} {...props}>\n {Icon}\n {children}\n </FlexRow>\n )\n}\n","import { Button, DialogActions } from '@mui/material'\n\nimport { useSeedPhrase } from '../../../../../contexts'\n\nexport const PhraseDialogActions = () => {\n const { handleClear, handleGenerate, overwriteWarning } = useSeedPhrase()\n return (\n <DialogActions sx={{ justifyContent: 'center' }}>\n <Button disabled={overwriteWarning} variant=\"outlined\" onClick={handleGenerate}>\n Generate\n </Button>\n <Button variant=\"outlined\" onClick={handleClear}>\n Clear\n </Button>\n </DialogActions>\n )\n}\n","import { Chip, FormControl, FormLabel, StandardTextFieldProps, TextField } from '@mui/material'\nimport { useState } from 'react'\n\nimport { useSeedPhrase } from '../../../../../contexts'\nimport { InvalidPhraseTypography, PhraseHeaderBox } from './validation-messages'\n\nexport const SavedPhraseTextField: React.FC<StandardTextFieldProps> = (props) => {\n const { validSeedPhrase, seedPhrase } = useSeedPhrase()\n\n const [visible, setVisible] = useState(false)\n\n return (\n <FormControl fullWidth size=\"small\" sx={{ display: 'flex', flexDirection: 'column', rowGap: 1 }}>\n <Chip label={visible ? 'Hide Saved Seed Phrase' : 'Reveal Saved Seed Phrase'} onClick={() => setVisible(!visible)} />\n {visible ?\n <>\n <FormLabel>\n <PhraseHeaderBox conditional={validSeedPhrase}>Saved Seed Phrase</PhraseHeaderBox>\n </FormLabel>\n <TextField\n defaultValue={seedPhrase}\n disabled\n error={validSeedPhrase === false}\n helperText={validSeedPhrase === false ? <InvalidPhraseTypography /> : null}\n fullWidth\n maxRows={Number.POSITIVE_INFINITY}\n multiline\n {...props}\n />\n </>\n : null}\n </FormControl>\n )\n}\n","import { Alert, Button } from '@mui/material'\nimport { FlexRow } from '@xylabs/react-flexbox'\n\nimport { useSeedPhrase } from '../../../../contexts'\n\nexport const OverwriteWarning = () => {\n const { handleCancelOverwrite, handleSave } = useSeedPhrase()\n return (\n <Alert\n variant=\"outlined\"\n severity=\"warning\"\n action={\n <FlexRow sx={{ columnGap: 1 }}>\n <Button variant=\"outlined\" color=\"inherit\" size=\"small\" onClick={handleSave}>\n Overwrite\n </Button>\n <Button variant=\"outlined\" color=\"inherit\" size=\"small\" onClick={handleCancelOverwrite}>\n Cancel\n </Button>\n </FlexRow>\n }\n >\n Are you sure you want to overwrite existing seed phrase? This action cannot be undone.\n </Alert>\n )\n}\n","import { Dialog, DialogContent, DialogProps, DialogTitle, FormLabel } from '@mui/material'\n\nimport { SeedPhraseProvider, useSeedPhrase } from '../../../contexts'\nimport { SeedPhraseIconButton } from '../_shared'\nimport { DialogActionButtons, NewPhraseTextField, OverwriteWarning, PhraseDialogActions, PhraseHeaderBox, SavedPhraseTextField } from './components'\n\nexport interface SeedPhraseDialogProps extends DialogProps {\n changeSeedPhrase?: (value: string) => void\n seedPhrase?: string\n}\n\nexport const SeedPhraseDialog: React.FC<SeedPhraseDialogProps> = ({ changeSeedPhrase, seedPhrase, ...props }) => {\n return (\n <SeedPhraseProvider\n seedPhrase={seedPhrase}\n handleChangeSeedPhrase={changeSeedPhrase}\n open={props.open}\n saveCallback={() => props.onClose?.({}, 'escapeKeyDown')}\n >\n <SeedPhraseDialogInner {...props} />\n </SeedPhraseProvider>\n )\n}\n\nexport const SeedPhraseDialogInner: React.FC<SeedPhraseDialogProps> = (props) => {\n const { overwriteWarning, seedPhrase, validPhrase } = useSeedPhrase()\n\n return (\n <Dialog aria-labelledby=\"alert-dialog-title\" aria-describedby=\"alert-dialog-description\" fullWidth maxWidth={'sm'} {...props}>\n <DialogTitle id=\"alert-dialog-title\">\n Update Your Seed Phrase <SeedPhraseIconButton />\n </DialogTitle>\n <DialogContent sx={{ display: 'flex', flexDirection: 'column', rowGap: 2 }}>\n <NewPhraseTextField>\n <FormLabel>\n <PhraseHeaderBox conditional={validPhrase}>New Seed Phrase</PhraseHeaderBox>\n </FormLabel>\n </NewPhraseTextField>\n <PhraseDialogActions />\n {seedPhrase ?\n <SavedPhraseTextField />\n : null}\n {overwriteWarning ?\n <OverwriteWarning />\n : null}\n </DialogContent>\n <DialogActionButtons onClose={props.onClose} />\n </Dialog>\n )\n}\n","import { Cancel as CancelIcon, RadioButtonChecked as RadioButtonCheckedIcon } from '@mui/icons-material'\nimport { Button, ButtonGroup, TableCell, TableRow, TableRowProps } from '@mui/material'\nimport { useState } from 'react'\n\nimport { SeedPhraseIconButton } from '../_shared'\nimport { SeedPhraseDialog } from '../dialog'\n\nexport interface SeedPhraseTableRowProps extends TableRowProps {\n changeSeedPhrase?: (seedPhrase: string) => void\n seedPhrase?: string\n}\n\nexport const SeedPhraseTableRow: React.FC<SeedPhraseTableRowProps> = ({ changeSeedPhrase, seedPhrase, ...props }) => {\n const [open, setOpen] = useState(false)\n\n const handleOpen = () => {\n setOpen(true)\n }\n return (\n <TableRow {...props}>\n <TableCell>\n Seed Phrase <SeedPhraseIconButton />\n </TableCell>\n <TableCell align=\"center\">\n {seedPhrase ?\n <RadioButtonCheckedIcon color=\"success\" />\n : <CancelIcon color=\"error\" />}\n </TableCell>\n <TableCell>\n <SeedPhraseDialog changeSeedPhrase={changeSeedPhrase} open={open} onClose={() => setOpen(false)} seedPhrase={seedPhrase} />\n <ButtonGroup fullWidth>\n <Button variant=\"contained\" size=\"small\" onClick={handleOpen}>\n Update\n </Button>\n </ButtonGroup>\n </TableCell>\n </TableRow>\n )\n}\n","import { EthAddress } from '@xylabs/eth-address'\nimport { EthAccountButton } from '@xylabs/react-crypto'\nimport { FlexBoxProps, FlexCol, FlexRow } from '@xylabs/react-flexbox'\nimport { NumberStatus } from '@xylabs/react-number-status'\nimport { useNetwork } from '@xyo-network/react-network'\nimport { WalletInstance } from '@xyo-network/wallet-model'\n\nimport { useAccount } from '../../hooks'\n\nexport interface WalletAccountDetailsProps extends FlexBoxProps {\n account?: WalletInstance\n exploreUrl?: string\n}\n\nexport const WalletAccountDetails: React.FC<WalletAccountDetailsProps> = ({ exploreUrl = 'https://explore.xyo.network', account, ...props }) => {\n const [accountToUse] = useAccount({ account })\n const { network } = useNetwork()\n const exploreAddressUrl = `${exploreUrl}/recent?account=${accountToUse?.address}&network=${network?.name ?? 'main'}`\n\n return (\n <FlexCol {...props}>\n <EthAccountButton address={EthAddress.fromString(accountToUse?.address)} />\n <FlexRow gap={1}>\n <NumberStatus rounded title=\"Tokens\" value={0} to={`${exploreAddressUrl}&schema=network.xyo.account.tokens`} target=\"_blank\" />\n <NumberStatus rounded title=\"NFTs\" value={0} to={`${exploreAddressUrl}&schema=network.xyo.account.nfts`} target=\"_blank\" />\n <NumberStatus rounded title=\"Signatures\" value={0} to={`${exploreAddressUrl}&schema=network.xyo.account.signatures`} target=\"_blank\" />\n <NumberStatus rounded title=\"Signins\" value={0} to={`${exploreAddressUrl}&schema=network.xyo.account.signins`} target=\"_blank\" />\n </FlexRow>\n </FlexCol>\n )\n}\n","import { usePromise } from '@xylabs/react-promise'\nimport { AccountInstance } from '@xyo-network/account-model'\nimport { WalletInstance } from '@xyo-network/wallet-model'\nimport { useState } from 'react'\n\nimport { useRootWallet, useWalletContext, useWalletProvided } from '../contexts'\n\nexport interface AccountHookParams {\n account?: AccountInstance\n index?: number\n required?: boolean\n wallet?: WalletInstance\n}\n\nexport const useAccount = ({ wallet, account, index, required = false }: AccountHookParams = {}): [\n AccountInstance | null | undefined,\n Error | undefined,\n] => {\n const walletContextProvided = useWalletProvided()\n const [validationError, setValidationError] = useState<Error>()\n if (wallet && account && !validationError) {\n setValidationError(new Error('useAccount can not have both a wallet and an account in the parameters'))\n }\n\n if (index && account && !validationError) {\n setValidationError(new Error('useAccount can not have both a index and an account in the parameters'))\n }\n\n const [error, setError] = useState<Error>()\n const [rootWallet] = useRootWallet(!wallet && required)\n const { activeAccountIndex } = useWalletContext(false)\n const [activeAccount] = usePromise(async () => {\n try {\n if (!validationError) {\n if (wallet) {\n return await wallet?.derivePath?.(`${index ?? 0}'\\0`)\n } else if (rootWallet) {\n return await rootWallet?.derivePath?.(`${index ?? activeAccountIndex ?? 0}'\\0`)\n }\n }\n } catch (ex) {\n const error = ex as Error\n console.error(error.message)\n setError(error)\n }\n }, [index, wallet, rootWallet, activeAccountIndex, validationError])\n if (validationError && !error) {\n console.error(validationError.message)\n setError(validationError)\n }\n\n return [\n error ? undefined\n : account ?? activeAccount ?? walletContextProvided ? null\n : undefined,\n error,\n ]\n}\n","import { usePromise } from '@xylabs/react-promise'\nimport { HDWallet } from '@xyo-network/account'\nimport { WalletInstance } from '@xyo-network/wallet-model'\nimport { useState } from 'react'\n\nimport { useSelectedWalletAccount, useWalletContext } from '../contexts'\n\nexport interface WalletHookParams {\n mnemonic?: string\n path?: string\n required?: boolean\n seed?: Uint8Array | string\n wallet?: WalletInstance | null\n}\n\nexport const useWallet = ({ mnemonic, wallet, path, required = false, seed }: WalletHookParams = {}): [\n WalletInstance | null | undefined,\n Error | undefined,\n] => {\n const walletContextProvided = useWalletContext(false)\n const [error, setError] = useState<Error>()\n const [contextAccount] = useSelectedWalletAccount(!wallet && required)\n const [activeAccount] = usePromise(async () => {\n try {\n const newAccount = await (() => {\n if (wallet) {\n return wallet\n } else if (mnemonic) {\n return HDWallet.fromPhrase(mnemonic)\n } else if (seed) {\n return HDWallet.fromSeed(seed)\n }\n return contextAccount\n })()\n\n return path ? newAccount?.derivePath?.(path) : newAccount ?? wallet\n } catch (ex) {\n setError(ex as Error)\n }\n }, [mnemonic, contextAccount, seed, path, wallet])\n return [activeAccount ?? (walletContextProvided ? null : activeAccount), error]\n}\n","import { usePromise } from '@xylabs/react-promise'\nimport { WalletInstance } from '@xyo-network/wallet-model'\n\nimport { useWalletContext } from '../contexts'\nimport { useWallet } from './useWallet'\n\nexport interface WalletsHookParams {\n paths: string[]\n wallet?: WalletInstance | null\n}\n\nexport const useWallets = ({ wallet, paths }: WalletsHookParams): [WalletInstance[] | null | undefined, Error | undefined] => {\n const walletContextProvided = useWalletContext(false)\n const [foundWallet] = useWallet({ wallet })\n const [wallets, error] = usePromise(\n async () => (foundWallet ? await Promise.all(paths.map((path) => foundWallet.derivePath(path))) : undefined),\n [foundWallet, paths],\n )\n return [wallets ?? (walletContextProvided ? null : wallets), error]\n}\n","import { State as PromiseState, usePromise } from '@xylabs/react-promise'\nimport { HDWallet } from '@xyo-network/account'\nimport { AccountInstance } from '@xyo-network/account-model'\nimport { WalletInstance } from '@xyo-network/wallet-model'\nimport { Mutex } from 'async-mutex'\n\nlet globalWrapperWallet: WalletInstance | undefined\nconst globalWrapperWalletMutex = new Mutex()\n\nexport const useWrapperAccount = (\n account?: AccountInstance | null,\n): [AccountInstance | null | undefined, Error | undefined, PromiseState | undefined] => {\n return usePromise(async () => {\n return await globalWrapperWalletMutex.runExclusive(async () => {\n //if we are expecting to receive a wallet or did receive on, return the override account\n if (account !== undefined) {\n return account\n }\n\n if (globalWrapperWallet) {\n return globalWrapperWallet\n }\n\n try {\n globalWrapperWallet = await HDWallet.random()\n console.log(`Global Wrapper Wallet Creation Success: ${globalWrapperWallet.address}`)\n } catch (ex) {\n const error = ex as Error\n console.error(`Global Wrapper Wallet Creation Failed: ${error.message}`)\n }\n return globalWrapperWallet\n })\n }, [account])\n}\n","import { CircularProgress, MenuItem, SelectProps } from '@mui/material'\nimport { SelectEx } from '@xylabs/react-select'\nimport { AddressRenderRowBox, AddressRenderRowBoxProps } from '@xyo-network/react-address-render'\n\nimport { useWalletContext } from '../../contexts'\nimport { useWallet } from '../../hooks'\n\ntype SharedAddressRenderRowBoxProps = Pick<AddressRenderRowBoxProps, 'iconOnly' | 'iconSize' | 'icons' | 'showFavorite'>\n\nexport type WalletAccountSelectProps = SharedAddressRenderRowBoxProps &\n Omit<SelectProps<number>, 'variant'> &\n Partial<SelectProps<number>> & {\n addressNames?: Record<string, string | undefined>\n maxAccounts?: number\n }\n\nconst arrayRange = (length: number, start = 0) => {\n return [...Array.from({ length }).keys()].map((x) => x + start)\n}\n\nexport const WalletAccountSelect: React.FC<WalletAccountSelectProps> = ({\n addressNames = {},\n iconOnly,\n iconSize = 24,\n icons,\n maxAccounts = 1,\n showFavorite = false,\n size,\n variant = 'outlined',\n ...props\n}) => {\n const { activeAccountIndex = 0, setActiveAccountIndex, rootWallet } = useWalletContext()\n const disabled = !rootWallet || activeAccountIndex === undefined\n\n return (\n <>\n {rootWallet ?\n <SelectEx\n margin=\"dense\"\n disabled={disabled}\n renderValue={(selectedAccountIndex) => {\n const Item: React.FC = () => {\n const [selectedAccount] = useWallet({ path: selectedAccountIndex.toString(), wallet: rootWallet })\n const customName = selectedAccount ? addressNames[selectedAccount.address] : undefined\n const favorite = !!selectedAccount && selectedAccount.address in addressNames\n return (\n <MenuItem value={selectedAccountIndex} sx={{ minHeight: 0, paddingBottom: 0, paddingTop: 0 }}>\n <AddressRenderRowBox\n disableSharedRef={true}\n flexGrow={1}\n address={selectedAccount?.address}\n iconOnly={iconOnly}\n iconSize={iconSize}\n icons={icons}\n name={customName}\n favorite={favorite}\n showFavorite={showFavorite}\n />\n </MenuItem>\n )\n }\n return <Item />\n }}\n value={activeAccountIndex}\n onChange={(event) => setActiveAccountIndex?.(Number.parseInt(`${event.target.value}`))}\n size={size}\n variant={variant}\n {...props}\n >\n {arrayRange(maxAccounts).map((index) => {\n const Item: React.FC = () => {\n const [account] = useWallet({ path: index.toString(), wallet: rootWallet })\n const customName = account ? addressNames[account.address] : undefined\n const favorite = !!account && account.address in addressNames\n return (\n <MenuItem key={account?.address} value={index} sx={{ minHeight: 0, paddingBottom: 0, paddingTop: 0 }}>\n <AddressRenderRowBox\n disableSharedRef={true}\n flexGrow={1}\n address={account?.address}\n favorite={favorite}\n iconOnly={iconOnly}\n iconSize={iconSize}\n icons={icons}\n name={customName}\n showFavorite={showFavorite}\n />\n </MenuItem>\n )\n }\n\n return <Item key={index} />\n })}\n </SelectEx>\n : <CircularProgress size={24} />}\n </>\n )\n}\n","import { FlexBoxProps, FlexCol } from '@xylabs/react-flexbox'\n\nimport { WalletAccountSelect } from './Select'\n\nexport interface WalletAccountSelectBarProps extends FlexBoxProps {\n addressNames?: Record<string, string | undefined>\n iconOnly?: boolean\n iconSize?: number\n icons?: boolean\n maxAccounts?: number\n showFavorite?: boolean\n size?: 'small' | 'medium'\n}\n\nexport const WalletAccountSelectBar: React.FC<WalletAccountSelectBarProps> = ({\n addressNames = {},\n iconOnly,\n iconSize,\n icons,\n maxAccounts = 1,\n showFavorite = false,\n size = 'small',\n ...props\n}) => {\n return (\n <FlexCol alignItems=\"stretch\" {...props}>\n <WalletAccountSelect\n addressNames={addressNames}\n fullWidth\n showFavorite={showFavorite}\n iconSize={iconSize}\n iconOnly={iconOnly}\n icons={icons}\n maxAccounts={maxAccounts}\n size={size ?? 'small'}\n variant=\"outlined\"\n />\n </FlexCol>\n )\n}\n"],"mappings":"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","names":["jsx","jsxs","desiredMaximumAccounts","Typography","useState","jsx","jsxs","Alert","AlertTitle","Snackbar","useState","Fragment","jsx","jsxs","Button","DialogActions","generateMnemonic","wordlist","useEffect","useState","jsx","wordlist","useState","useEffect","generateMnemonic","createContextEx","useEffect","useState","jsx","useState","useEffect","usePromise","useContextEx","useContextEx","usePromise","jsx","jsxs","DialogActions","Button","Link","Typography","jsx","jsxs","useMemo","jsx","jsxs","Fragment","jsx","jsxs","Button","DialogActions","jsx","jsxs","DialogActions","Button","FormControl","TextField","useState","Fragment","jsx","jsxs","useState","FormControl","TextField","Alert","Button","FlexRow","jsx","jsxs","Alert","FlexRow","Button","Dialog","DialogContent","DialogTitle","FormLabel","jsx","jsxs","Dialog","DialogTitle","DialogContent","FormLabel","Button","ButtonGroup","TableCell","TableRow","useState","jsx","jsxs","useState","TableRow","TableCell","ButtonGroup","Button","FlexRow","usePromise","useState","useState","usePromise","error","usePromise","useState","useState","usePromise","usePromise","usePromise","usePromise","HDWallet","jsx","jsxs","FlexRow","Fragment","jsx","FlexCol","jsx","FlexCol"]}
package/package.json CHANGED
@@ -21,12 +21,12 @@
21
21
  "@xylabs/react-quick-tip-button": "^3.1.6",
22
22
  "@xylabs/react-select": "^3.1.6",
23
23
  "@xylabs/react-shared": "^3.1.6",
24
- "@xyo-network/account": "^2.93.4",
25
- "@xyo-network/account-model": "^2.93.4",
26
- "@xyo-network/react-address-render": "~2.71.0",
27
- "@xyo-network/react-network": "~2.71.0",
28
- "@xyo-network/react-shared": "~2.71.0",
29
- "@xyo-network/wallet-model": "^2.93.4",
24
+ "@xyo-network/account": "^2.93.8",
25
+ "@xyo-network/account-model": "^2.93.8",
26
+ "@xyo-network/react-address-render": "~2.71.2",
27
+ "@xyo-network/react-network": "~2.71.2",
28
+ "@xyo-network/react-shared": "~2.71.2",
29
+ "@xyo-network/wallet-model": "^2.93.8",
30
30
  "async-mutex": "^0.5.0"
31
31
  },
32
32
  "peerDependencies": {
@@ -41,7 +41,7 @@
41
41
  "@storybook/react": "^7.6.17",
42
42
  "@xylabs/ts-scripts-yarn3": "^3.5.2",
43
43
  "@xylabs/tsconfig-react": "^3.5.2",
44
- "@xyo-network/react-storybook": "~2.71.0",
44
+ "@xyo-network/react-storybook": "~2.71.2",
45
45
  "react-router-dom": "^6.22.3",
46
46
  "typescript": "^5.4.3"
47
47
  },
@@ -95,6 +95,6 @@
95
95
  },
96
96
  "sideEffects": false,
97
97
  "types": "dist/browser/index.d.ts",
98
- "version": "2.71.0",
98
+ "version": "2.71.2",
99
99
  "type": "module"
100
100
  }
@@ -29,18 +29,18 @@ export const WalletAccountSelect: React.FC<WalletAccountSelectProps> = ({
29
29
  variant = 'outlined',
30
30
  ...props
31
31
  }) => {
32
- const { activeAccountIndex = 0, setActiveAccountIndex, coinTypeWallet } = useWalletContext()
33
- const disabled = !coinTypeWallet || activeAccountIndex === undefined
32
+ const { activeAccountIndex = 0, setActiveAccountIndex, rootWallet } = useWalletContext()
33
+ const disabled = !rootWallet || activeAccountIndex === undefined
34
34
 
35
35
  return (
36
36
  <>
37
- {coinTypeWallet ?
37
+ {rootWallet ?
38
38
  <SelectEx
39
39
  margin="dense"
40
40
  disabled={disabled}
41
41
  renderValue={(selectedAccountIndex) => {
42
42
  const Item: React.FC = () => {
43
- const [selectedAccount] = useWallet({ path: selectedAccountIndex.toString(), wallet: coinTypeWallet })
43
+ const [selectedAccount] = useWallet({ path: selectedAccountIndex.toString(), wallet: rootWallet })
44
44
  const customName = selectedAccount ? addressNames[selectedAccount.address] : undefined
45
45
  const favorite = !!selectedAccount && selectedAccount.address in addressNames
46
46
  return (
@@ -69,7 +69,7 @@ export const WalletAccountSelect: React.FC<WalletAccountSelectProps> = ({
69
69
  >
70
70
  {arrayRange(maxAccounts).map((index) => {
71
71
  const Item: React.FC = () => {
72
- const [account] = useWallet({ path: index.toString(), wallet: coinTypeWallet })
72
+ const [account] = useWallet({ path: index.toString(), wallet: rootWallet })
73
73
  const customName = account ? addressNames[account.address] : undefined
74
74
  const favorite = !!account && account.address in addressNames
75
75
  return (
@@ -1,15 +1,14 @@
1
1
  import { Stack } from '@mui/material'
2
2
  import { Meta, StoryFn } from '@storybook/react'
3
- import { DefaultSeedPhrase } from '@xyo-network/react-storybook'
4
3
 
5
- import { WalletProvider } from '../../contexts'
6
- import { useWallet } from '../../hooks'
7
4
  import { WalletAccountSelect } from './Select'
8
- import { AccountInfo, CoinTypeWalletInfo, RootWalletInfo, SelectedWalletInfo, WalletInfo } from './WalletInfo'
5
+ import { AccountInfo, RootWalletInfo, SelectedWalletInfo, WalletInfo } from './WalletInfo'
6
+ import { WalletProviderDecorator } from './stories'
9
7
 
10
8
  const StorybookEntry = {
11
9
  argTypes: {},
12
10
  component: WalletAccountSelect,
11
+ decorators: [WalletProviderDecorator],
13
12
  parameters: {
14
13
  docs: {
15
14
  page: null,
@@ -23,18 +22,16 @@ const Template: StoryFn<typeof WalletAccountSelect> = (args) => {
23
22
  }
24
23
 
25
24
  const WithWalletTemplate: StoryFn<typeof WalletAccountSelect> = (args) => {
26
- const [wallet] = useWallet({ mnemonic: DefaultSeedPhrase })
27
25
  return (
28
- <WalletProvider rootWallet={wallet}>
26
+ <>
29
27
  <WalletAccountSelect {...args} />
30
28
  <Stack direction="row" position="absolute" right={0} top={0} bgcolor="black" height={16}>
31
29
  <RootWalletInfo />
32
- <CoinTypeWalletInfo />
33
30
  <SelectedWalletInfo />
34
31
  <WalletInfo />
35
32
  <AccountInfo />
36
33
  </Stack>
37
- </WalletProvider>
34
+ </>
38
35
  )
39
36
  }
40
37