@wallet-ui/react 1.1.0-canary-20250323230043 → 1.1.0-canary-20250324005504

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.
@@ -5,8 +5,8 @@ var react$1 = require('@wallet-standard/react');
5
5
  var react$2 = require('@zag-js/react');
6
6
  var menu = require('@zag-js/menu');
7
7
  var dialog = require('@zag-js/dialog');
8
- var gill = require('gill');
9
8
  var core$1 = require('@wallet-ui/core');
9
+ var gill = require('gill');
10
10
  var react = require('@solana/react');
11
11
  var walletStandardFeatures = require('@solana/wallet-standard-features');
12
12
  var core = require('@wallet-standard/core');
@@ -249,12 +249,6 @@ function useBaseModal() {
249
249
  open: () => service.send({ type: "OPEN" })
250
250
  };
251
251
  }
252
- var WalletUiSolanaClientContext = React19.createContext({});
253
-
254
- // src/use-wallet-ui-solana-client.tsx
255
- function useWalletUiSolanaClient() {
256
- return React19.useContext(WalletUiSolanaClientContext);
257
- }
258
252
  var WalletUiClusterContext = React19.createContext({});
259
253
 
260
254
  // src/use-wallet-ui-cluster.tsx
@@ -360,6 +354,12 @@ function ellipsify(str = "", len = 4, delimiter = "..") {
360
354
  const limit = len * 2 + delimiter.length;
361
355
  return strLen >= limit ? str.substring(0, len) + delimiter + str.substring(strLen - len, strLen) : str;
362
356
  }
357
+ var WalletUiSolanaClientContext = React19.createContext({});
358
+
359
+ // src/use-wallet-ui-solana-client.tsx
360
+ function useWalletUiSolanaClient() {
361
+ return React19.useContext(WalletUiSolanaClientContext);
362
+ }
363
363
  function useWalletUiWallets() {
364
364
  const readonlyWallets = react$1.useWallets();
365
365
  return React19.useMemo(
@@ -475,15 +475,6 @@ function WalletUiAccountContextProvider({
475
475
  children
476
476
  );
477
477
  }
478
- function WalletUiClientContextProvider({ children, urlOrMoniker }) {
479
- return /* @__PURE__ */ React19__default.default.createElement(
480
- WalletUiSolanaClientContext.Provider,
481
- {
482
- value: React19.useMemo(() => gill.createSolanaClient({ urlOrMoniker }), [urlOrMoniker])
483
- },
484
- children
485
- );
486
- }
487
478
  function useLocalStorage(key, initialValue) {
488
479
  const [storedValue, setStoredValue] = React19.useState(() => {
489
480
  try {
@@ -579,6 +570,18 @@ function WalletUiContextProvider({ children, size = "md" }) {
579
570
  };
580
571
  return /* @__PURE__ */ React19__default.default.createElement(WalletUiContext.Provider, { value }, children);
581
572
  }
573
+ function WalletUiSolanaClientContextProvider({
574
+ children,
575
+ urlOrMoniker
576
+ }) {
577
+ return /* @__PURE__ */ React19__default.default.createElement(
578
+ WalletUiSolanaClientContext.Provider,
579
+ {
580
+ value: React19.useMemo(() => gill.createSolanaClient({ urlOrMoniker }), [urlOrMoniker])
581
+ },
582
+ children
583
+ );
584
+ }
582
585
 
583
586
  // src/wallet-ui.tsx
584
587
  function createWalletUiConfig(props) {
@@ -594,7 +597,7 @@ function WalletUi({
594
597
  clusters,
595
598
  storageKey: clusterStorageKey,
596
599
  render: ({ cluster }) => {
597
- return /* @__PURE__ */ React19__default.default.createElement(WalletUiClientContextProvider, { urlOrMoniker: cluster.urlOrMoniker }, /* @__PURE__ */ React19__default.default.createElement(WalletUiAccountContextProvider, { storageKey: selectedAccountStorageKey }, /* @__PURE__ */ React19__default.default.createElement(WalletUiContextProvider, { ...config }, children)));
600
+ return /* @__PURE__ */ React19__default.default.createElement(WalletUiSolanaClientContextProvider, { urlOrMoniker: cluster.urlOrMoniker }, /* @__PURE__ */ React19__default.default.createElement(WalletUiAccountContextProvider, { storageKey: selectedAccountStorageKey }, /* @__PURE__ */ React19__default.default.createElement(WalletUiContextProvider, { ...config }, children)));
598
601
  }
599
602
  }
600
603
  ));
@@ -766,8 +769,9 @@ exports.BaseDropdownItemType = BaseDropdownItemType;
766
769
  exports.BaseModal = BaseModal;
767
770
  exports.BaseSvg = BaseSvg;
768
771
  exports.WalletUi = WalletUi;
772
+ exports.WalletUiAccountContext = WalletUiAccountContext;
773
+ exports.WalletUiAccountContextProvider = WalletUiAccountContextProvider;
769
774
  exports.WalletUiButton = WalletUiButton;
770
- exports.WalletUiClientContextProvider = WalletUiClientContextProvider;
771
775
  exports.WalletUiClusterContext = WalletUiClusterContext;
772
776
  exports.WalletUiClusterContextProvider = WalletUiClusterContextProvider;
773
777
  exports.WalletUiClusterDropdown = WalletUiClusterDropdown;
@@ -783,6 +787,7 @@ exports.WalletUiListButton = WalletUiListButton;
783
787
  exports.WalletUiModal = WalletUiModal;
784
788
  exports.WalletUiModalTrigger = WalletUiModalTrigger;
785
789
  exports.WalletUiSolanaClientContext = WalletUiSolanaClientContext;
790
+ exports.WalletUiSolanaClientContextProvider = WalletUiSolanaClientContextProvider;
786
791
  exports.createWalletUiConfig = createWalletUiConfig;
787
792
  exports.ellipsify = ellipsify;
788
793
  exports.useBaseDropdown = useBaseDropdown;
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/base-button.tsx","../src/wallet-ui-context.tsx","../src/use-wallet-ui.tsx","../src/wallet-ui-account-context.tsx","../src/use-wallet-ui-account.tsx","../src/use-wallet-ui-wallet.tsx","../src/base-dropdown.tsx","../src/base-svg.tsx","../src/wallet-ui-icon-close.tsx","../src/base-modal.tsx","../src/use-base-dropdown.tsx","../src/use-base-modal.tsx","../src/wallet-ui-solana-client-context.tsx","../src/use-wallet-ui-solana-client.tsx","../src/wallet-ui-cluster-context.tsx","../src/use-wallet-ui-cluster.tsx","../src/wallet-ui-icon.tsx","../src/use-wallet-ui-dropdown.tsx","../src/use-wallet-ui-wallets.tsx","../src/wallet-ui-account-context-provider.tsx","../src/wallet-ui-client-context-provider.tsx","../src/use-local-storage.ts","../src/wallet-ui-cluster-context-provider.tsx","../src/wallet-ui-context-provider.tsx","../src/wallet-ui.tsx","../src/wallet-ui-button.tsx","../src/wallet-ui-cluster-dropdown.tsx","../src/wallet-ui-dropdown.tsx","../src/wallet-ui-icon-no-wallet.tsx","../src/wallet-ui-label.tsx","../src/wallet-ui-list-button.tsx","../src/wallet-ui-list.tsx","../src/wallet-ui-modal.tsx","../src/wallet-ui-modal-trigger.tsx"],"names":["React","createContext","useContext","connect","useConnect","useDisconnect","useEffect","BaseDropdownItemType","Portal","useMachine","menu","useId","normalizeProps","dialog","useMemo","useWallets","useState","getUiWalletAccountStorageKey","uiWalletAccountsAreSame","uiWalletAccountBelongsToUiWallet","createSolanaClient","useCallback","cluster","account","handleCopyText"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAaO,SAAS,UAAA,CAAW,EAAE,SAAA,EAAW,KAAO,EAAA,WAAA,EAAa,SAAS,YAAc,EAAA,IAAA,EAAM,GAAG,KAAA,EAA0B,EAAA;AAClH,EAAA,uBACKA,wBAAA,CAAA,aAAA,CAAA,QAAA,EAAA,EAAO,SAAW,EAAA,CAAA,sBAAA,EAAyB,IAAQ,IAAA,IAAI,CAAI,CAAA,EAAA,SAAA,IAAa,EAAE,CAAA,CAAA,EAAI,OAAmB,EAAA,GAAG,KAChG,EAAA,EAAA,WAAA,mBAAeA,wBAAA,CAAA,aAAA,CAAA,MAAA,EAAA,EAAK,SAAU,EAAA,oCAAA,EAAA,EAAsC,WAAY,CAAA,GAAU,IAC1F,EAAA,KAAA,EACA,YAAe,mBAAAA,wBAAA,CAAA,aAAA,CAAC,MAAK,EAAA,EAAA,SAAA,EAAU,qCAAuC,EAAA,EAAA,YAAa,IAAU,IAClG,CAAA;AAER;ACOO,IAAM,eAAkBA,GAAAA,wBAAAA,CAAM,aAA4C,CAAA,EAAkC;;;ACxB5G,SAAS,WAAc,GAAA;AAC1B,EAAOA,OAAAA,wBAAAA,CAAM,WAAW,eAAe,CAAA;AAC3C;ACQO,IAAM,sBAAA,GAAyBC,qBAAoC,CAAA,EAA0B,CAAA;;;ACV7F,SAAS,kBAAqB,GAAA;AACjC,EAAA,OAAOC,mBAAW,sBAAsB,CAAA;AAC5C;;;ACAO,SAAS,iBAAA,CAAkB,EAAE,MAAA,EAAgC,EAAA;AAChE,EAAA,MAAM,EAAE,OAAA,EAAS,cAAe,EAAA,GAAI,WAAY,EAAA;AAChD,EAAM,MAAA,EAAE,UAAW,EAAA,GAAI,kBAAmB,EAAA;AAC1C,EAAA,MAAM,CAAC,YAAA,EAAcC,QAAO,CAAA,GAAIC,mBAAW,MAAM,CAAA;AACjD,EAAA,MAAM,CAAC,eAAA,EAAiB,UAAU,CAAA,GAAIC,sBAAc,MAAM,CAAA;AAC1D,EAAAC,iBAAA,CAAU,MAAM;AAAA,GAAC,EAAG,CAAC,eAAe,CAAC,CAAA;AAErC,EAAO,OAAA;AAAA,IACH,SAAS,YAAY;AACjB,MAAM,MAAA,gBAAA,GAAmB,MAAMH,QAAQ,EAAA;AACvC,MAAQ,OAAA,CAAA,GAAA,CAAI,oBAAoB,gBAAgB,CAAA;AAChD,MAAI,IAAA,CAAC,iBAAiB,MAAQ,EAAA;AAC1B,QAAA,OAAA,CAAQ,IAAI,sBAAsB,CAAA;AAClC,QAAO,OAAA,gBAAA;AAAA;AAEX,MAAM,MAAA,KAAA,GAAQ,iBAAiB,CAAC,CAAA;AAChC,MAAQ,OAAA,CAAA,GAAA,CAAI,sCAAsC,KAAK,CAAA;AACvD,MAAA,UAAA,CAAW,KAAK,CAAA;AAChB,MAAA,cAAA,CAAe,KAAK,CAAA;AACpB,MAAO,OAAA,gBAAA;AAAA,KACX;AAAA,IACA,UAAA;AAAA,IACA,YAAA;AAAA,IACA;AAAA,GACJ;AACJ;;;ACxBY,IAAA,oBAAA,qBAAAI,qBAAL,KAAA;AACH,EAAAA,sBAAA,MAAO,CAAA,GAAA,MAAA;AACP,EAAAA,sBAAA,eAAgB,CAAA,GAAA,eAAA;AAChB,EAAAA,sBAAA,YAAa,CAAA,GAAA,YAAA;AACb,EAAAA,sBAAA,kBAAmB,CAAA,GAAA,kBAAA;AACnB,EAAAA,sBAAA,cAAe,CAAA,GAAA,cAAA;AALP,EAAAA,OAAAA,qBAAAA;AAAA,CAAA,EAAA,oBAAA,IAAA,EAAA;AA2BL,SAAS,aAAa,EAAE,WAAA,EAAa,QAAU,EAAA,aAAA,EAAe,OAA4B,EAAA;AAC7F,EAAA,MAAM,MAAM,QAAS,CAAA,GAAA;AACrB,EAAM,MAAA,OAAA,mBACFP,wBAAA,CAAA,aAAA;AAAA,IAAC,UAAA;AAAA,IAAA;AAAA,MACI,GAAG,IAAI,eAAgB,EAAA;AAAA,MACxB,SAAW,EAAA,CAAA,+BAAA,CAAA;AAAA,MACX,WAAU,EAAA,SAAA;AAAA,MACV,YAAA,EACI,aACI,mBAAAA,wBAAA,CAAA,aAAA,CAAC,MAAK,EAAA,EAAA,SAAA,EAAU,gBACZ,EAAA,kBAAAA,wBAAA,CAAA,aAAA,CAAC,MAAM,EAAA,EAAA,GAAG,IAAI,iBAAkB,EAAA,EAAG,SAAU,EAAA,WAAA,EAAA,kBACzCA,wBAAAA,CAAA,aAAC,CAAA,uBAAA,EAAA,EAAwB,IAAM,EAAA,EAAA,EAAI,CACvC,CACJ,CACA,GAAA,IAAA;AAAA,MAEP,GAAG;AAAA;AAAA,GACR;AAGJ,EAAA,uBACIA,wBAAAA,CAAA,aAAC,CAAA,KAAA,EAAA,EAAI,SAAU,EAAA,yBAAA,EAAA,EACV,OACD,kBAAAA,wBAAA,CAAA,aAAA,CAAC,KAAK,EAAA,EAAA,GAAG,IAAI,kBAAmB,EAAA,EAAG,SAAU,EAAA,mBAAA,EAAA,kBACzCA,wBAAAA,CAAA,aAAC,CAAA,KAAA,EAAA,EAAK,GAAG,GAAI,CAAA,eAAA,EAAmB,EAAA,SAAA,EAAU,8BAA+B,EAAA,WAAA,EAAU,SAC9E,EAAA,EAAA,KAAA,CAAM,IAAI,CAAQ,IAAA,KAAA;AACf,IAAA,uBACIA,wBAAA,CAAA,aAAA;AAAA,MAAC,gBAAA;AAAA,MAAA;AAAA,QACI,GAAG,GAAI,CAAA,YAAA,CAAa,EAAE,KAAO,EAAA,IAAA,CAAK,OAAO,CAAA;AAAA,QAC1C,KAAK,IAAK,CAAA,KAAA;AAAA,QACV,IAAA;AAAA,QACA,YAAY,MAAM;AACd,UAAA,IAAI,KAAK,QAAU,EAAA;AACf,YAAA;AAAA;AAEJ,UAAI,IAAA,IAAA,CAAK,cAAc,KAAO,EAAA;AAC1B,YAAA,QAAA,CAAS,KAAM,EAAA;AAAA;AACnB;AACJ;AAAA,KACJ;AAAA,GAEP,CACL,CACJ,CACJ,CAAA;AAER;AAEA,SAAS,gBAAiB,CAAA,EAAE,UAAY,EAAA,IAAA,EAAqC,EAAA;AACzE,EAAI,IAAA,CAAC,KAAK,MAAQ,EAAA;AACd,IAAA,uBAAOA,wBAAAA,CAAA,aAAC,CAAA,sBAAA,EAAA,EAAuB,YAAwB,IAAY,EAAA,CAAA;AAAA;AAEvE,EAAA,QAAQ,KAAK,IAAM;AAAA,IACf,KAAK,MAAA;AACD,MAAA,uBAAOA,wBAAAA,CAAA,aAAC,CAAA,sBAAA,EAAA,EAAuB,YAAwB,IAAY,EAAA,CAAA;AAAA,IACvE,KAAK,eAAA;AACD,MAAO,uBAAAA,yBAAA,aAAC,CAAA,6BAAA,EAAA,EAA8B,YAAwB,IAAY,EAAA,MAAA,EAAQ,KAAK,MAAQ,EAAA,CAAA;AAAA,IACnG,KAAK,YAAA;AACD,MAAA,uBAAOA,wBAAAA,CAAA,aAAC,CAAA,sBAAA,EAAA,EAAuB,YAAwB,IAAY,EAAA,CAAA;AAAA,IACvE,KAAK,kBAAA;AACD,MAAO,uBAAAA,yBAAA,aAAC,CAAA,gCAAA,EAAA,EAAiC,YAAwB,IAAY,EAAA,MAAA,EAAQ,KAAK,MAAQ,EAAA,CAAA;AAAA;AAE9G;AAEA,SAAS,6BAA8B,CAAA;AAAA,EACnC,UAAA;AAAA,EACA,IAAA;AAAA,EACA;AACJ,CAEG,EAAA;AACC,EAAA,MAAM,EAAE,OAAAG,EAAAA,QAAAA,KAAY,iBAAkB,CAAA,EAAE,QAAQ,CAAA;AAChD,EAAA,uBACIH,wBAAA,CAAA,aAAA;AAAA,IAAC,sBAAA;AAAA,IAAA;AAAA,MACG,UAAA;AAAA,MACA,IAAM,EAAA;AAAA,QACF,GAAG,IAAA;AAAA,QACH,SAAS,YAAY;AAEjB,UAAA,MAAMG,QAAQ,EAAA;AACd,UAAO,OAAA,MAAM,KAAK,OAAQ,EAAA;AAAA;AAC9B;AACJ;AAAA,GACJ;AAER;AAEA,SAAS,gCAAiC,CAAA;AAAA,EACtC,UAAA;AAAA,EACA,IAAA;AAAA,EACA;AACJ,CAEG,EAAA;AACC,EAAA,MAAM,EAAE,UAAW,EAAA,GAAI,iBAAkB,CAAA,EAAE,QAAQ,CAAA;AACnD,EAAA,uBACIH,wBAAA,CAAA,aAAA;AAAA,IAAC,sBAAA;AAAA,IAAA;AAAA,MACG,UAAA;AAAA,MACA,IAAM,EAAA;AAAA,QACF,GAAG,IAAA;AAAA,QACH,SAAS,YAAY;AAEjB,UAAA,MAAM,UAAW,EAAA;AACjB,UAAO,OAAA,MAAM,KAAK,OAAQ,EAAA;AAAA;AAC9B;AACJ;AAAA,GACJ;AAER;AAOA,SAAS,sBAAuB,CAAA,EAAE,UAAY,EAAA,IAAA,EAAqC,EAAA;AAC/E,EAAA,SAAS,OAAU,GAAA;AACf,IAAA,IAAI,KAAK,QAAU,EAAA;AACf,MAAA;AAAA;AAEJ,IAAA,KAAK,IAAK,CAAA,OAAA,EAAU,CAAA,IAAA,CAAK,MAAM;AAC3B,MAAW,UAAA,EAAA;AAAA,KACd,CAAA;AAAA;AAGL,EAAA,uBACIA,wBAAAA,CAAA,aAAC,CAAA,KAAA,EAAA,EAAI,WAAU,8BAA+B,EAAA,WAAA,EAAU,MAAO,EAAA,OAAA,EAAA,EAC1D,KAAK,WACF,mBAAAA,wBAAA,CAAA,aAAA,CAAC,UAAK,SAAU,EAAA,2CAAA,EAAA,EAA6C,IAAK,CAAA,WAAY,CAC9E,GAAA,IAAA,EACH,IAAK,CAAA,KAAA,EACL,KAAK,YACF,mBAAAA,wBAAA,CAAA,aAAA,CAAC,UAAK,SAAU,EAAA,4CAAA,EAAA,EAA8C,IAAK,CAAA,YAAa,IAChF,IACR,CAAA;AAER;AAEO,SAAS,wBAAwB,KAAuD,EAAA;AAC3F,EAAA,uBACIA,wBAAA,CAAA,aAAA;AAAA,IAAC,KAAA;AAAA,IAAA;AAAA,MACG,KAAM,EAAA,4BAAA;AAAA,MACN,KAAA,EAAO,MAAM,IAAQ,IAAA,EAAA;AAAA,MACrB,MAAA,EAAQ,MAAM,IAAQ,IAAA,EAAA;AAAA,MACtB,OAAQ,EAAA,WAAA;AAAA,MACR,IAAK,EAAA,MAAA;AAAA,MACL,MAAO,EAAA,cAAA;AAAA,MACP,WAAY,EAAA,GAAA;AAAA,MACZ,aAAc,EAAA,OAAA;AAAA,MACd,cAAe,EAAA,OAAA;AAAA,MACd,GAAG;AAAA,KAAA;AAAA,oBAEJA,wBAAAA,CAAA,aAAC,CAAA,MAAA,EAAA,EAAK,GAAE,cAAe,EAAA;AAAA,GAC3B;AAER;AClLO,SAAS,QAAQ,EAAE,KAAA,GAAQ,EAAI,EAAA,GAAG,OAAuB,EAAA;AAC5D,EAAA,MAAM,OAAO,KAAM,CAAA,IAAA,GAAO,KAAM,CAAA,KAAA,CAAM,IAAI,CAAI,GAAA,EAAA;AAC9C,EAAA,uBACIA,wBAAAA,CAAA,aAAC,CAAA,KAAA,EAAA,EAAI,KAAM,EAAA,4BAAA,EAA6B,KAAO,EAAA,IAAA,EAAM,MAAQ,EAAA,IAAA,EAAO,GAAG,KAAA,EAAA,EAClE,MAAM,QACX,CAAA;AAER;;;ACdO,SAAS,kBAAkB,EAAE,IAAA,GAAO,IAAM,EAAA,GAAG,OAAkD,EAAA;AAClG,EAAA,uBACIA,wBAAA,CAAA,aAAA;AAAA,IAAC,OAAA;AAAA,IAAA;AAAA,MACG,IAAA;AAAA,MACA,OAAO,EAAE,EAAA,EAAI,IAAI,EAAI,EAAA,EAAA,EAAI,IAAI,CAAE,EAAA;AAAA,MAC/B,IAAK,EAAA,MAAA;AAAA,MACL,MAAO,EAAA,cAAA;AAAA,MACP,WAAY,EAAA,GAAA;AAAA,MACZ,OAAQ,EAAA,WAAA;AAAA,MACP,GAAG;AAAA,KAAA;AAAA,oBAEJA,wBAAAA,CAAA,aAAC,CAAA,MAAA,EAAA,EAAK,GAAE,qIAAsI,EAAA;AAAA,GAClJ;AAER;;;ACAO,SAAS,SAAA,CAAU,EAAE,KAAA,EAAO,WAAa,EAAA,WAAA,GAAc,EAAC,EAAG,IAAO,GAAA,IAAA,EAAM,GAAG,KAAA,EAAyB,EAAA;AACvG,EAAA,MAAM,MAAM,KAAM,CAAA,GAAA;AAClB,EACI,uBAAAA,yBAAA,aAAAA,CAAAA,wBAAAA,CAAA,gBACK,WACG,mBAAAA,yBAAA,aAAC,CAAA,UAAA,EAAA,EAAW,OAAO,WAAa,EAAA,IAAA,EAAa,GAAG,WAAc,EAAA,GAAG,IAAI,eAAgB,EAAA,EAAG,CACxF,GAAA,IAAA,EACH,GAAI,CAAA,IAAA,oBACDA,wBAAA,CAAA,aAAA,CAACQ,sCACGR,wBAAAA,CAAA,cAAC,KAAK,EAAA,EAAA,GAAG,IAAI,gBAAiB,EAAA,EAAG,mBACjCA,wBAAAA,CAAA,cAAC,KAAK,EAAA,EAAA,GAAG,IAAI,kBAAmB,EAAA,EAAA,kBAC5BA,wBAAAA,CAAA,aAAC,CAAA,KAAA,EAAA,EAAK,GAAG,GAAI,CAAA,eAAA,IAAmB,SAAW,EAAA,IAAA,EAAA,kBACvCA,wBAAA,CAAA,aAAA,CAAC,gCACGA,wBAAAA,CAAA,cAAC,QAAQ,EAAA,EAAA,GAAG,IAAI,oBAAqB,EAAA,EAAA,kBACjCA,wBAAA,CAAA,aAAA,CAAC,iBAAkB,EAAA,EAAA,IAAA,EAAY,CACnC,CACJ,GACC,KAAM,CAAA,WAAA,mBAAcA,wBAAA,CAAA,aAAA,CAAC,OAAG,GAAG,GAAA,CAAI,mBAAoB,EAAA,EAAA,EAAI,KAAM,CAAA,WAAY,IAAO,IACjF,kBAAAA,yBAAA,aAAC,CAAA,MAAA,EAAA,IAAA,EAAM,MAAM,QAAS,CAC1B,CACJ,CACJ,CAER,CAAA;AAER;AC/BO,SAAS,eAAuC,GAAA;AACnD,EAAA,MAAM,UAAUS,kBAAgB,CAAAC,eAAA,CAAA,OAAA,EAAS,EAAE,EAAI,EAAAC,aAAA,IAAS,CAAA;AACxD,EAAM,MAAA,GAAA,GAAWD,eAAQ,CAAA,OAAA,CAAA,OAAA,EAASE,sBAAc,CAAA;AAEhD,EAAO,OAAA;AAAA,IACH,GAAA;AAAA,IACA,OAAO,MAAM,OAAA,CAAQ,KAAK,EAAE,IAAA,EAAM,SAAS,CAAA;AAAA,IAC3C,MAAM,MAAM,OAAA,CAAQ,KAAK,EAAE,IAAA,EAAM,QAAQ;AAAA,GAC7C;AACJ;ACTO,SAAS,YAAiC,GAAA;AAC7C,EAAM,MAAA,OAAA,GAAUH,mBAAkBI,iBAAS,CAAA,OAAA,EAAA,EAAE,IAAIF,aAAM,EAAA,EAAG,KAAO,EAAA,IAAA,EAAM,CAAA;AACvE,EAAM,MAAA,GAAA,GAAaE,iBAAQ,CAAA,OAAA,CAAA,OAAA,EAASD,sBAAc,CAAA;AAElD,EAAO,OAAA;AAAA,IACH,GAAA;AAAA,IACA,OAAO,MAAM,OAAA,CAAQ,KAAK,EAAE,IAAA,EAAM,SAAS,CAAA;AAAA,IAC3C,MAAM,MAAM,OAAA,CAAQ,KAAK,EAAE,IAAA,EAAM,QAAQ;AAAA,GAC7C;AACJ;ACba,IAAA,2BAAA,GAA8BX,qBAA4B,CAAA,EAAkB;;;ACJlF,SAAS,uBAA0B,GAAA;AACtC,EAAA,OAAOC,mBAAW,2BAA2B,CAAA;AACjD;ACUa,IAAA,sBAAA,GAAyBD,qBAA2C,CAAA,EAAiC;;;ACZ3G,SAAS,kBAAqB,GAAA;AACjC,EAAA,OAAOC,mBAAW,sBAAsB,CAAA;AAC5C;ACKO,SAAS,aAAa,EAAE,SAAA,EAAW,MAAM,MAAQ,EAAA,GAAG,OAA4B,EAAA;AACnF,EAAA,IAAI,CAAC,MAAQ,EAAA;AACT,IAAO,OAAA,IAAA;AAAA;AAGX,EAAA,uBACIF,wBAAA,CAAA,aAAA;AAAA,IAAC,KAAA;AAAA,IAAA;AAAA,MACG,KAAK,MAAO,CAAA,IAAA;AAAA,MACZ,KAAK,MAAO,CAAA,IAAA;AAAA,MACZ,WAAW,CAAuB,oBAAA,EAAA,IAAA,IAAQ,IAAI,CAAA,CAAA,EAAI,aAAa,EAAE,CAAA,CAAA;AAAA,MAChE,GAAG;AAAA;AAAA,GACR;AAER;;;ACdA,SAAS,uBAAwB,CAAA;AAAA,EAC7B,OAAA;AAAA,EACA,OAAAG,EAAAA,QAAAA;AAAA,EACA;AACJ,CAIuB,EAAA;AACnB,EAAA,OAAO,OAAQ,CAAA,MAAA,GACT,OAAQ,CAAA,GAAA,CAAI,CAAW,MAAA,MAAA;AAAA,IACnB,SAAS,YAAY;AAEjB,MAAM,MAAA,OAAA,GAAU,OAAO,QAAS,CAAA,MAAA,GAAS,IAAI,MAAO,CAAA,QAAA,CAAS,CAAC,CAAI,GAAA,MAAA;AAClE,MAAA,IAAI,CAAC,OAAS,EAAA;AACV,QAAA;AAAA;AAEJ,MAAAA,SAAQ,OAAO,CAAA;AACf,MAAA,MAAM,QAAQ,OAAQ,EAAA;AAAA,KAC1B;AAAA,IACA,OAAO,MAAO,CAAA,IAAA;AAAA,IACd,6BAAaH,wBAAAA,CAAA,aAAC,CAAA,YAAA,EAAA,EAAa,QAAgB,IAAY,EAAA,CAAA;AAAA,IACvD,IAAA,EAAA,eAAA;AAAA,IACA,OAAO,MAAO,CAAA,IAAA;AAAA,IACd;AAAA,IACF,CACF,GAAA;AAAA,IACI;AAAA,MACI,SAAS,YAAY;AACjB,QAAO,MAAA,CAAA,IAAA,CAAK,qCAAqC,QAAQ,CAAA;AACzD,QAAA,MAAM,QAAQ,OAAQ,EAAA;AAAA,OAC1B;AAAA,MACA,KAAO,EAAA,4CAAA;AAAA,MACP,IAAA,EAAA,cAAA;AAAA,MACA,KAAO,EAAA;AAAA;AACX,GACJ;AACV;AAEO,SAAS,oBAAoB,EAAE,IAAA,GAAO,IAAK,EAAA,GAA6B,EAK7E,EAAA;AACE,EAAA,MAAM,WAAW,eAAgB,EAAA;AAEjC,EAAM,MAAA,EAAE,OAAS,EAAA,OAAA,EAAAG,QAAS,EAAA,IAAA,EAAM,YAAY,SAAW,EAAA,MAAA,EAAQ,OAAQ,EAAA,GAAI,WAAY,EAAA;AAEvF,EAAM,MAAA,YAAA,GAAeW,gBAAQ,MAAM;AAC/B,IAAA,OAAO,wBAAwB,EAAE,OAAA,EAAAX,QAAS,EAAA,IAAA,EAAM,SAAS,CAAA;AAAA,GAC1D,EAAA,CAAC,OAAS,EAAA,IAAA,EAAMA,QAAO,CAAC,CAAA;AAE3B,EAAA,MAAM,cAAqC,GAAAW,eAAA;AAAA,IACvC,MAAM;AAAA,MACF;AAAA,QACI,SAAS,YAAY;AACjB,UAAK,IAAA,EAAA;AACL,UAAM,KAAA,MAAM,QAAQ,OAAQ,EAAA;AAAA,SAChC;AAAA,QACA,KAAO,EAAA,cAAA;AAAA,QACP,IAAA,EAAA,YAAA;AAAA,QACA,KAAO,EAAA;AAAA,OACX;AAAA,MACA;AAAA,QACI,SAAS,YAAY;AACjB,UAAW,UAAA,EAAA;AACX,UAAA,QAAA,CAAS,KAAM,EAAA;AACf,UAAA,MAAM,QAAQ,OAAQ,EAAA;AAAA,SAC1B;AAAA,QACA,KAAO,EAAA,YAAA;AAAA,QACP,IAAA,EAAA,kBAAA;AAAA,QACA,KAAO,EAAA;AAAA,OACX;AAAA,MACA,GAAG;AAAA,KACP;AAAA,IACA,CAACX,QAAS,EAAA,IAAA,EAAM,UAAY,EAAA,QAAA,EAAU,MAAM,OAAO;AAAA,GACvD;AACA,EAAM,MAAA,KAAA,GAAQW,gBAAQ,MAAM;AACxB,IAAA,OAAO,YAAY,cAAiB,GAAA,YAAA;AAAA,GACrC,EAAA,CAAC,SAAW,EAAA,cAAA,EAAgB,YAAY,CAAC,CAAA;AAE5C,EAAM,MAAA,WAAA,GAA+BA,gBAAQ,MAAM;AAC/C,IAAO,OAAA;AAAA,MACH,KAAA,EAAO,aAAc,OAAU,GAAA,SAAA,CAAU,QAAQ,OAAO,CAAA,GAAI,MAAQ,EAAA,IAAA,KAAS,WAAe,GAAA,eAAA;AAAA,MAC5F,WAAA,EAAa,4BAAYd,wBAAAA,CAAA,cAAC,YAAa,EAAA,EAAA,IAAA,EAAY,QAAgB,CAAK,GAAA;AAAA,KAC5E;AAAA,KACD,CAAC,OAAA,EAAS,SAAW,EAAA,IAAA,EAAM,MAAM,CAAC,CAAA;AAErC,EAAO,OAAA;AAAA,IACH,WAAA;AAAA,IACA,SAAA;AAAA,IACA,QAAA;AAAA,IACA;AAAA,GACJ;AACJ;AAEO,SAAS,UAAU,GAAM,GAAA,EAAA,EAAI,GAAM,GAAA,CAAA,EAAG,YAAY,IAAM,EAAA;AAC3D,EAAA,MAAM,SAAS,GAAI,CAAA,MAAA;AACnB,EAAM,MAAA,KAAA,GAAQ,GAAM,GAAA,CAAA,GAAI,SAAU,CAAA,MAAA;AAElC,EAAA,OAAO,MAAU,IAAA,KAAA,GAAQ,GAAI,CAAA,SAAA,CAAU,CAAG,EAAA,GAAG,CAAI,GAAA,SAAA,GAAY,GAAI,CAAA,SAAA,CAAU,MAAS,GAAA,GAAA,EAAK,MAAM,CAAI,GAAA,GAAA;AACvG;AC7GO,SAAS,kBAAqB,GAAA;AACjC,EAAA,MAAM,kBAAkBe,kBAAW,EAAA;AACnC,EAAOD,OAAAA,eAAAA;AAAA,IACH,MACI,gBACK,MAAO,CAAA,CAAA,MAAA,KAAU,OAAO,MAAO,CAAA,IAAA,CAAK,CAAK,CAAA,KAAA,CAAA,CAAE,UAAW,CAAA,SAAS,CAAC,CAAC,CAAA,CACjE,IAAK,CAAA,CAAC,CAAG,EAAA,CAAA,KAAM,EAAE,IAAK,CAAA,aAAA,CAAc,CAAE,CAAA,IAAI,CAAC,CAAA;AAAA,IACpD,CAAC,eAAe;AAAA,GACpB;AACJ;ACCA,IAAM,WAAc,GAAA,mCAAA;AAEpB,IAAI,gBAAmB,GAAA,KAAA;AAEvB,SAAS,qBAAA,CAAsB,SAA8B,UAAiD,EAAA;AAC1G,EAAA,IAAI,gBAAkB,EAAA;AAGlB,IAAA;AAAA;AAEJ,EAAM,MAAA,yBAAA,GAA4B,YAAa,CAAA,OAAA,CAAQ,UAAU,CAAA;AACjE,EAAA,IAAI,CAAC,yBAAA,IAA6B,OAAO,yBAAA,KAA8B,QAAU,EAAA;AAC7E,IAAA;AAAA;AAEJ,EAAA,MAAM,CAAC,eAAiB,EAAA,mBAAmB,CAAI,GAAA,yBAAA,CAA0B,MAAM,GAAG,CAAA;AAClF,EAAI,IAAA,CAAC,eAAmB,IAAA,CAAC,mBAAqB,EAAA;AAC1C,IAAA;AAAA;AAEJ,EAAA,KAAA,MAAW,UAAU,OAAS,EAAA;AAC1B,IAAI,IAAA,MAAA,CAAO,SAAS,eAAiB,EAAA;AACjC,MAAW,KAAA,MAAA,OAAA,IAAW,OAAO,QAAU,EAAA;AACnC,QAAI,IAAA,OAAA,CAAQ,YAAY,mBAAqB,EAAA;AACzC,UAAO,OAAA,OAAA;AAAA;AACX;AACJ;AACJ;AAER;AAOO,SAAS,8BAA+B,CAAA;AAAA,EAC3C,QAAA;AAAA,EACA,UAAa,GAAA;AACjB,CAGG,EAAA;AACC,EAAM,MAAA,EAAE,OAAQ,EAAA,GAAI,kBAAmB,EAAA;AACvC,EAAA,MAAM,UAAUC,kBAAW,EAAA;AAC3B,EAAM,MAAA,CAAC,OAAS,EAAA,kBAAkB,CAAI,GAAAC,gBAAA;AAAA,IAAsC,MACxE,qBAAsB,CAAA,OAAA,EAAS,UAAU;AAAA,GAC7C;AAEA,EAAA,SAAS,WAAW,cAAmE,EAAA;AACnF,IAAA,kBAAA,CAAmB,CAAe,WAAA,KAAA;AAC9B,MAAmB,gBAAA,GAAA,IAAA;AACnB,MAAA,MAAM,oBACF,OAAO,cAAA,KAAmB,UAAa,GAAA,cAAA,CAAe,WAAW,CAAI,GAAA,cAAA;AACzE,MAAA,MAAM,UAAa,GAAA,iBAAA,GAAoBC,oCAA6B,CAAA,iBAAiB,CAAI,GAAA,MAAA;AACzF,MAAA,IAAI,UAAY,EAAA;AACZ,QAAa,YAAA,CAAA,OAAA,CAAQ,YAAY,UAAU,CAAA;AAAA,OACxC,MAAA;AACH,QAAA,YAAA,CAAa,WAAW,UAAU,CAAA;AAAA;AAEtC,MAAO,OAAA,iBAAA;AAAA,KACV,CAAA;AAAA;AAGL,EAAAX,kBAAU,MAAM;AACZ,IAAM,MAAA,kBAAA,GAAqB,qBAAsB,CAAA,OAAA,EAAS,UAAU,CAAA;AACpE,IAAA,IAAI,kBAAoB,EAAA;AACpB,MAAA,kBAAA,CAAmB,kBAAkB,CAAA;AAAA;AACzC,GACJ,EAAG,CAAC,OAAO,CAAC,CAAA;AACZ,EAAM,MAAA,aAAA,GAAgBQ,gBAAQ,MAAM;AAChC,IAAA,IAAI,OAAS,EAAA;AACT,MAAA,KAAA,MAAW,YAAY,OAAS,EAAA;AAC5B,QAAW,KAAA,MAAA,eAAA,IAAmB,SAAS,QAAU,EAAA;AAC7C,UAAI,IAAAI,+BAAA,CAAwB,OAAS,EAAA,eAAe,CAAG,EAAA;AACnD,YAAO,OAAA,eAAA;AAAA;AACX;AAEJ,QAAA,IAAIC,yCAAiC,OAAS,EAAA,QAAQ,KAAK,QAAS,CAAA,QAAA,CAAS,CAAC,CAAG,EAAA;AAG7E,UAAO,OAAA,QAAA,CAAS,SAAS,CAAC,CAAA;AAAA;AAC9B;AACJ;AACJ,GACD,EAAA,CAAC,OAAS,EAAA,OAAO,CAAC,CAAA;AACrB,EAAAb,kBAAU,MAAM;AAGZ,IAAI,IAAA,OAAA,IAAW,CAAC,aAAe,EAAA;AAC3B,MAAA,kBAAA,CAAmB,MAAS,CAAA;AAAA;AAChC,GACD,EAAA,CAAC,OAAS,EAAA,aAAa,CAAC,CAAA;AAE3B,EAAM,MAAA,MAAA,GAASQ,gBAAQ,MAAM;AACzB,IAAA,IAAI,CAAC,aAAe,EAAA;AAChB,MAAO,OAAA,MAAA;AAAA;AAEX,IAAA,KAAA,MAAW,YAAY,OAAS,EAAA;AAC5B,MAAW,KAAA,MAAA,eAAA,IAAmB,SAAS,QAAU,EAAA;AAC7C,QAAI,IAAAI,+BAAA,CAAwB,aAAe,EAAA,eAAe,CAAG,EAAA;AACzD,UAAO,OAAA,QAAA;AAAA;AACX;AAEJ,MAAA,IAAIC,yCAAiC,aAAe,EAAA,QAAQ,KAAK,QAAS,CAAA,QAAA,CAAS,CAAC,CAAG,EAAA;AAGnF,QAAO,OAAA,QAAA;AAAA;AACX;AACJ,GACD,EAAA,CAAC,aAAe,EAAA,OAAO,CAAC,CAAA;AAG3B,EAAM,MAAA,WAAA,GAAcL,gBAAQ,MAAM;AAC9B,IAAA,IAAI,CAAC,OAAS,EAAA;AACV,MAAA,OAAO,EAAC;AAAA;AAEZ,IAAO,OAAA,CAAC,QAAQ,EAAI,EAAAG,oCAAA,CAA6B,OAAO,CAAC,CAAA,CAAE,OAAO,OAAO,CAAA;AAAA,GAC7E,EAAG,CAAC,OAAO,CAAC,CAAA;AACZ,EAAA,uBACIjB,wBAAA,CAAA,aAAA;AAAA,IAAC,sBAAuB,CAAA,QAAA;AAAA,IAAvB;AAAA,MACG,KAAOc,EAAAA,eAAAA;AAAA,QACH,OAAO;AAAA,UACH,OAAS,EAAA,aAAA;AAAA,UACT,WAAA;AAAA,UACA,UAAA;AAAA,UACA;AAAA,SACJ,CAAA;AAAA,QACA,CAAC,aAAe,EAAA,MAAA,EAAQ,WAAW;AAAA;AACvC,KAAA;AAAA,IAEC;AAAA,GACL;AAER;ACzIO,SAAS,6BAA8B,CAAA,EAAE,QAAU,EAAA,YAAA,EAA0D,EAAA;AAChH,EAAA,uBACId,wBAAA,CAAA,aAAA;AAAA,IAAC,2BAA4B,CAAA,QAAA;AAAA,IAA5B;AAAA,MACG,KAAA,EAAOc,eAAQ,CAAA,MAAMM,uBAAmB,CAAA,EAAE,cAAc,CAAA,EAAmB,CAAC,YAAY,CAAC;AAAA,KAAA;AAAA,IAExF;AAAA,GACL;AAER;ACdO,SAAS,eAAA,CAAmB,KAAa,YAAiB,EAAA;AAE7D,EAAA,MAAM,CAAC,WAAA,EAAa,cAAc,CAAA,GAAIJ,iBAAY,MAAM;AACpD,IAAI,IAAA;AAEA,MAAI,IAAA,OAAO,WAAW,WAAa,EAAA;AAC/B,QAAO,OAAA,YAAA;AAAA;AAGX,MAAA,MAAM,IAAO,GAAA,MAAA,CAAO,YAAa,CAAA,OAAA,CAAQ,GAAG,CAAA;AAE5C,MAAA,IAAI,IAAI,QAAS,CAAA,QAAQ,KAAK,GAAI,CAAA,QAAA,CAAS,SAAS,CAAG,EAAA;AAEnD,QAAO,OAAA,YAAA;AAAA;AAEX,MAAA,OAAO,IAAO,GAAA,IAAA,CAAK,KAAM,CAAA,IAAI,CAAI,GAAA,YAAA;AAAA,aAC5B,KAAO,EAAA;AACZ,MAAA,OAAA,CAAQ,IAAK,CAAA,CAAA,gCAAA,EAAmC,GAAG,CAAA,EAAA,CAAA,EAAM,KAAK,CAAA;AAC9D,MAAO,OAAA,YAAA;AAAA;AACX,GACH,CAAA;AAGD,EAAA,MAAM,QAAW,GAAAK,mBAAA;AAAA,IACb,CAAC,KAA+B,KAAA;AAC5B,MAAI,IAAA;AAEA,QAAA,MAAM,YAAe,GAAA,KAAA,YAAiB,QAAW,GAAA,KAAA,CAAM,WAAW,CAAI,GAAA,KAAA;AAGtE,QAAA,cAAA,CAAe,YAAY,CAAA;AAG3B,QAAI,IAAA,OAAO,WAAW,WAAa,EAAA;AAC/B,UAAI,IAAA,YAAA,KAAiB,KAAa,CAAA,IAAA,YAAA,KAAiB,IAAM,EAAA;AACrD,YAAO,MAAA,CAAA,YAAA,CAAa,WAAW,GAAG,CAAA;AAAA,WAC/B,MAAA;AACH,YAAA,MAAA,CAAO,aAAa,OAAQ,CAAA,GAAA,EAAK,IAAK,CAAA,SAAA,CAAU,YAAY,CAAC,CAAA;AAAA;AACjE;AACJ,eACK,KAAO,EAAA;AACZ,QAAA,OAAA,CAAQ,IAAK,CAAA,CAAA,gCAAA,EAAmC,GAAG,CAAA,EAAA,CAAA,EAAM,KAAK,CAAA;AAAA;AAClE,KACJ;AAAA,IACA,CAAC,KAAK,WAAW;AAAA,GACrB;AAEA,EAAO,OAAA,CAAC,aAAa,QAAQ,CAAA;AACjC;;;ACxCO,SAAS,8BAA+B,CAAA;AAAA,EAC3C,QAAA;AAAA,EACA,MAAA;AAAA,EACA,UAAa,GAAA;AACjB,CAAwC,EAAA;AACpC,EAAA,MAAM,CAAC,SAAW,EAAA,YAAY,CAAI,GAAA,eAAA,CAAgB,YAAY,eAAe,CAAA;AAC7E,EAAI,IAAA,CAAC,SAAS,MAAQ,EAAA;AAClB,IAAM,MAAA,IAAI,MAAM,sBAAsB,CAAA;AAAA;AAE1C,EAAM,MAAA,OAAA,GAAUP,gBAAuB,MAAM;AACzC,IAAA,KAAA,MAAWQ,YAAW,QAAU,EAAA;AAC5B,MAAIA,IAAAA,QAAAA,CAAQ,OAAO,SAAW,EAAA;AAC1B,QAAOA,OAAAA,QAAAA;AAAA;AACX;AAEJ,IAAA,OAAO,SAAS,CAAC,CAAA;AAAA,GAClB,EAAA,CAAC,SAAW,EAAA,QAAQ,CAAC,CAAA;AAExB,EAAA,MAAM,KAAqC,GAAA;AAAA,IACvC,OAAA;AAAA,IACA,QAAA;AAAA,IACA,UAAA,EAAY,CAACA,QAA6B,KAAA;AACtC,MAAa,YAAA,CAAA,OAAA,CAAQ,YAAYA,QAAO,CAAA;AACxC,MAAA,YAAA,CAAaA,QAAO,CAAA;AAAA;AACxB,GACJ;AAEA,EAAO,uBAAAtB,yBAAA,aAAC,CAAA,sBAAA,CAAuB,UAAvB,EAAgC,KAAA,EAAA,EAAe,MAAO,CAAA,KAAK,CAAE,CAAA;AACzE;AC7BO,SAAS,uBAAwB,CAAA,EAAE,QAAU,EAAA,IAAA,GAAO,MAAsC,EAAA;AAC7F,EAAA,MAAM,EAAE,OAAA,EAAS,UAAY,EAAA,MAAA,KAAW,kBAAmB,EAAA;AAC3D,EAAA,MAAM,UAAU,kBAAmB,EAAA;AACnC,EAAA,MAAM,SAAS,uBAAwB,EAAA;AACvC,EAAA,MAAM,oBAAoB,OAAQ,CAAA,MAAA,IAAU,MAAQ,EAAA,QAAA,CAAS,SAAS,CAAC,CAAA;AAEvE,EAAA,SAASG,SAAQoB,QAA0B,EAAA;AACvC,IAAA,UAAA,CAAWA,QAAO,CAAA;AAAA;AAGtB,EAAA,SAAS,UAAa,GAAA;AAClB,IAAA,UAAA,CAAW,MAAS,CAAA;AAAA;AAGxB,EAAA,SAAS,IAAO,GAAA;AACZ,IAAA,IAAI,CAAC,OAAS,EAAA;AACV,MAAA;AAAA;AAEJ,IAAAC,qBAAA,CAAe,QAAQ,OAAO,CAAA;AAAA;AAGlC,EAAA,MAAM,KAAsC,GAAA;AAAA,IACxC,OAAA;AAAA,IACA,MAAA;AAAA,IACA,OAAArB,EAAAA,QAAAA;AAAA,IACA,SAAW,EAAA,iBAAA;AAAA,IACX,IAAA;AAAA,IACA,UAAA;AAAA,IACA,IAAA;AAAA,IACA,MAAA;AAAA,IACA;AAAA,GACJ;AAEA,EAAA,uBAAOH,wBAAA,CAAA,aAAA,CAAC,gBAAgB,QAAhB,EAAA,EAAyB,SAAe,QAAS,CAAA;AAC7D;;;AC5BO,SAAS,qBAAqB,KAAuC,EAAA;AACxE,EAAO,OAAA,EAAE,GAAG,KAAM,EAAA;AACtB;AAOO,SAAS,QAAS,CAAA;AAAA,EACrB,QAAA;AAAA,EACA,QAAQ,EAAE,QAAA,EAAU,iBAAmB,EAAA,yBAAA,EAA2B,GAAG,MAAO;AAChF,CAAkB,EAAA;AACd,EAAA,uBACIA,wBAAA,CAAA,aAAA,CAACA,yBAAM,QAAN,EAAA,IAAA,kBACGA,wBAAA,CAAA,aAAA;AAAA,IAAC,8BAAA;AAAA,IAAA;AAAA,MACG,QAAA;AAAA,MACA,UAAY,EAAA,iBAAA;AAAA,MACZ,MAAQ,EAAA,CAAC,EAAE,OAAA,EAAc,KAAA;AACrB,QACI,uBAAAA,yBAAA,aAAC,CAAA,6BAAA,EAAA,EAA8B,cAAc,OAAQ,CAAA,YAAA,EAAA,kBACjDA,wBAAA,CAAA,aAAA,CAAC,kCAA+B,UAAY,EAAA,yBAAA,EAAA,kBACxCA,wBAAA,CAAA,aAAA,CAAC,2BAAyB,GAAG,MAAA,EAAA,EAAS,QAAS,CACnD,CACJ,CAAA;AAAA;AAER;AAAA,GAER,CAAA;AAER;ACpCO,SAAS,cAAe,CAAA,EAAE,GAAG,KAAA,EAA8B,EAAA;AAC9D,EAAA,uBAAOA,wBAAA,CAAA,aAAA,CAAC,cAAY,GAAG,KAAA,EAAO,OAAO,OAAS,EAAA,CAAA;AAClD;ACEO,SAAS,wBAAwB,EAAE,WAAA,EAAa,OAAO,IAAM,EAAA,GAAG,OAAuC,EAAA;AAC1G,EAAA,MAAM,WAAW,eAAgB,EAAA;AACjC,EAAA,MAAM,EAAE,OAAA,EAAS,QAAU,EAAA,UAAA,KAAe,kBAAmB,EAAA;AAC7D,EAAA,uBACIA,wBAAA,CAAA,aAAA;AAAA,IAAC,YAAA;AAAA,IAAA;AAAA,MACG,aAAa,EAAE,GAAG,aAAa,KAAO,EAAA,OAAA,CAAQ,OAAO,IAAW,EAAA;AAAA,MAChE,KAAO,EAAA,QAAA,CAAS,GAAI,CAAA,CAAAsB,QAAY,MAAA;AAAA,QAC5B,SAAS,YAAY;AACjB,UAAA,UAAA,CAAWA,SAAQ,EAAE,CAAA;AACrB,UAAA,MAAM,QAAQ,OAAQ,EAAA;AAAA,SAC1B;AAAA,QACA,OAAOA,QAAQ,CAAA,KAAA;AAAA,QACf,IAAA,EAAA,MAAA;AAAA,QACA,OAAOA,QAAQ,CAAA;AAAA,OACjB,CAAA,CAAA;AAAA,MACF,QAAA;AAAA,MACC,GAAG;AAAA;AAAA,GACR;AAER;ACrBO,SAAS,iBAAiB,EAAE,IAAA,GAAO,IAAM,EAAA,GAAG,OAAgC,EAAA;AAC/E,EAAM,MAAA,EAAE,aAAa,KAAO,EAAA,QAAA,KAAa,mBAAoB,CAAA,EAAE,MAAM,CAAA;AACrE,EAAA,uBAAOtB,wBAAAA,CAAA,aAAC,CAAA,YAAA,EAAA,EAAc,GAAG,KAAA,EAAO,WAAa,EAAA,EAAE,GAAG,WAAA,EAAa,IAAK,EAAA,EAAG,OAAc,QAAoB,EAAA,CAAA;AAC7G;ACVO,SAAS,oBAAqB,CAAA,EAAE,IAAM,EAAA,GAAG,OAAkD,EAAA;AAC9F,EAAA,uBACIA,wBAAA,CAAA,aAAA,CAAC,OAAQ,EAAA,EAAA,IAAA,EAAY,OAAO,EAAE,EAAA,EAAI,GAAK,EAAA,EAAA,EAAI,KAAK,EAAI,EAAA,EAAA,EAAM,EAAA,IAAA,EAAK,QAAO,OAAQ,EAAA,WAAA,EAAa,GAAG,KAAA,EAAA,kBAC1FA,wBAAA,CAAA,aAAA,CAAC,QAAO,EAAA,EAAA,EAAA,EAAG,QAAO,EAAG,EAAA,IAAA,EAAK,CAAE,EAAA,IAAA,EAAK,MAAK,8BAA+B,EAAA,WAAA,EAAY,KAAM,EAAA,CAAA,kBACvFA,wBAAA,CAAA,aAAA;AAAA,IAAC,QAAA;AAAA,IAAA;AAAA,MACG,EAAG,EAAA,MAAA;AAAA,MACH,EAAG,EAAA,IAAA;AAAA,MACH,CAAE,EAAA,IAAA;AAAA,MACF,MAAO,EAAA,8BAAA;AAAA,MACP,aAAc,EAAA,KAAA;AAAA,MACd,WAAY,EAAA;AAAA;AAAA,GACf,kBACDA,wBAAA,CAAA,aAAA,CAAC,OAAE,QAAS,EAAA,sBAAA,EAAA,kBACRA,wBAAA,CAAA,aAAA;AAAA,IAAC,MAAA;AAAA,IAAA;AAAA,MACG,CAAE,EAAA,6sBAAA;AAAA,MACF,IAAK,EAAA;AAAA;AAAA,GACR,kBACDA,wBAAA,CAAA,aAAA;AAAA,IAAC,MAAA;AAAA,IAAA;AAAA,MACG,CAAE,EAAA,iOAAA;AAAA,MACF,IAAK,EAAA;AAAA;AAAA,GAEb,CACA,kBAAAA,yBAAA,aAAC,CAAA,MAAA,EAAA,IAAA,kBACGA,wBAAA,CAAA,aAAA;AAAA,IAAC,gBAAA;AAAA,IAAA;AAAA,MACG,EAAG,EAAA,wBAAA;AAAA,MACH,EAAG,EAAA,SAAA;AAAA,MACH,EAAG,EAAA,SAAA;AAAA,MACH,EAAG,EAAA,QAAA;AAAA,MACH,EAAG,EAAA,SAAA;AAAA,MACH,aAAc,EAAA;AAAA,KAAA;AAAA,oBAEdA,wBAAAA,CAAA,aAAC,CAAA,MAAA,EAAA,EAAK,WAAU,SAAU,EAAA,CAAA;AAAA,oBAC1BA,wBAAA,CAAA,aAAA,CAAC,UAAK,MAAO,EAAA,MAAA,EAAO,WAAU,SAAU,EAAA,CAAA;AAAA,oBACxCA,wBAAA,CAAA,aAAA,CAAC,UAAK,MAAO,EAAA,MAAA,EAAO,WAAU,SAAU,EAAA,CAAA;AAAA,oBACxCA,wBAAA,CAAA,aAAA,CAAC,UAAK,MAAO,EAAA,MAAA,EAAO,WAAU,SAAU,EAAA,CAAA;AAAA,oBACxCA,wBAAA,CAAA,aAAA,CAAC,UAAK,MAAO,EAAA,MAAA,EAAO,WAAU,SAAU,EAAA,CAAA;AAAA,oBACxCA,wBAAA,CAAA,aAAA,CAAC,UAAK,MAAO,EAAA,GAAA,EAAI,WAAU,SAAU,EAAA;AAAA,GACzC,kBACAA,wBAAA,CAAA,aAAA;AAAA,IAAC,gBAAA;AAAA,IAAA;AAAA,MACG,EAAG,EAAA,wBAAA;AAAA,MACH,EAAG,EAAA,SAAA;AAAA,MACH,EAAG,EAAA,SAAA;AAAA,MACH,EAAG,EAAA,QAAA;AAAA,MACH,EAAG,EAAA,SAAA;AAAA,MACH,aAAc,EAAA;AAAA,KAAA;AAAA,oBAEdA,wBAAAA,CAAA,aAAC,CAAA,MAAA,EAAA,EAAK,WAAU,SAAU,EAAA,CAAA;AAAA,oBAC1BA,wBAAA,CAAA,aAAA,CAAC,UAAK,MAAO,EAAA,MAAA,EAAO,WAAU,SAAU,EAAA,CAAA;AAAA,oBACxCA,wBAAA,CAAA,aAAA,CAAC,UAAK,MAAO,EAAA,MAAA,EAAO,WAAU,SAAU,EAAA,CAAA;AAAA,oBACxCA,wBAAA,CAAA,aAAA,CAAC,UAAK,MAAO,EAAA,MAAA,EAAO,WAAU,SAAU,EAAA,CAAA;AAAA,oBACxCA,wBAAA,CAAA,aAAA,CAAC,UAAK,MAAO,EAAA,MAAA,EAAO,WAAU,SAAU,EAAA,CAAA;AAAA,oBACxCA,wBAAA,CAAA,aAAA,CAAC,UAAK,MAAO,EAAA,GAAA,EAAI,WAAU,SAAU,EAAA;AAAA,GACzC,kBACAA,wBAAA,CAAA,aAAA;AAAA,IAAC,gBAAA;AAAA,IAAA;AAAA,MACG,EAAG,EAAA,wBAAA;AAAA,MACH,EAAG,EAAA,SAAA;AAAA,MACH,EAAG,EAAA,SAAA;AAAA,MACH,EAAG,EAAA,SAAA;AAAA,MACH,EAAG,EAAA,SAAA;AAAA,MACH,aAAc,EAAA;AAAA,KAAA;AAAA,oBAEdA,wBAAAA,CAAA,aAAC,CAAA,MAAA,EAAA,EAAK,WAAU,SAAU,EAAA,CAAA;AAAA,oBAC1BA,wBAAA,CAAA,aAAA,CAAC,UAAK,MAAO,EAAA,MAAA,EAAO,WAAU,SAAU,EAAA,CAAA;AAAA,oBACxCA,wBAAA,CAAA,aAAA,CAAC,UAAK,MAAO,EAAA,MAAA,EAAO,WAAU,SAAU,EAAA,CAAA;AAAA,oBACxCA,wBAAA,CAAA,aAAA,CAAC,UAAK,MAAO,EAAA,MAAA,EAAO,WAAU,SAAU,EAAA,CAAA;AAAA,oBACxCA,wBAAA,CAAA,aAAA,CAAC,UAAK,MAAO,EAAA,MAAA,EAAO,WAAU,SAAU,EAAA,CAAA;AAAA,oBACxCA,wBAAA,CAAA,aAAA,CAAC,UAAK,MAAO,EAAA,GAAA,EAAI,WAAU,SAAU,EAAA;AAAA,GACzC,kBACAA,wBAAA,CAAA,aAAA;AAAA,IAAC,gBAAA;AAAA,IAAA;AAAA,MACG,EAAG,EAAA,wBAAA;AAAA,MACH,EAAG,EAAA,SAAA;AAAA,MACH,EAAG,EAAA,SAAA;AAAA,MACH,EAAG,EAAA,SAAA;AAAA,MACH,EAAG,EAAA,SAAA;AAAA,MACH,aAAc,EAAA;AAAA,KAAA;AAAA,oBAEdA,wBAAAA,CAAA,aAAC,CAAA,MAAA,EAAA,EAAK,WAAU,SAAU,EAAA,CAAA;AAAA,oBAC1BA,wBAAA,CAAA,aAAA,CAAC,UAAK,MAAO,EAAA,MAAA,EAAO,WAAU,SAAU,EAAA,CAAA;AAAA,oBACxCA,wBAAA,CAAA,aAAA,CAAC,UAAK,MAAO,EAAA,MAAA,EAAO,WAAU,SAAU,EAAA,CAAA;AAAA,oBACxCA,wBAAA,CAAA,aAAA,CAAC,UAAK,MAAO,EAAA,MAAA,EAAO,WAAU,SAAU,EAAA,CAAA;AAAA,oBACxCA,wBAAA,CAAA,aAAA,CAAC,UAAK,MAAO,EAAA,MAAA,EAAO,WAAU,SAAU,EAAA,CAAA;AAAA,oBACxCA,wBAAA,CAAA,aAAA,CAAC,UAAK,MAAO,EAAA,GAAA,EAAI,WAAU,SAAU,EAAA;AAAA,GACzC,kBACAA,wBAAA,CAAA,aAAA,CAAC,cAAS,EAAG,EAAA,gBAAA,EAAA,kBACTA,wBAAA,CAAA,aAAA,CAAC,UAAK,KAAM,EAAA,IAAA,EAAK,QAAO,IAAK,EAAA,IAAA,EAAK,SAAQ,SAAU,EAAA,oBAAA,EAAqB,CAC7E,CACJ,CACJ,CAAA;AAER;AClFO,SAAS,cAAc,EAAE,SAAA,EAAW,MAAM,MAAQ,EAAA,GAAG,OAA6B,EAAA;AACrF,EAAA,IAAI,CAAC,MAAQ,EAAA;AACT,IAAO,OAAA,IAAA;AAAA;AAGX,EAAA,uBACIA,wBAAAA,CAAA,aAAC,CAAA,MAAA,EAAA,EAAK,WAAW,CAAwB,qBAAA,EAAA,IAAA,IAAQ,IAAI,CAAA,CAAA,EAAI,aAAa,EAAE,CAAA,CAAA,EAAK,GAAG,KAAA,EAAA,EAC3E,OAAO,IACZ,CAAA;AAER;ACPO,SAAS,kBAAA,CAAmB,EAAE,SAAW,EAAA,MAAA,EAAQ,OAAO,IAAM,EAAA,MAAA,EAAQ,GAAG,KAAA,EAAkC,EAAA;AAC9G,EAAA,MAAM,CAAC,OAAS,EAAA,UAAU,CAAIA,GAAAA,wBAAAA,CAAM,SAAS,KAAK,CAAA;AAElD,EAAA,SAAS,YAAe,GAAA;AACpB,IAAA,IAAI,CAAC,MAAQ,EAAA;AACT,MAAA;AAAA;AAEJ,IAAA,UAAA,CAAW,IAAI,CAAA;AAEf,IAAM,MAAA,OAAA,GAAU,OAAO,QAAS,CAAA,MAAA,GAAS,IAAI,MAAO,CAAA,QAAA,CAAS,CAAC,CAAI,GAAA,MAAA;AAClE,IAAA,IAAI,CAAC,OAAS,EAAA;AACV,MAAA;AAAA;AAEJ,IAAA,KAAK,OAAO,OAAO,CAAA,CAAE,QAAQ,MAAM,UAAA,CAAW,KAAK,CAAC,CAAA;AAAA;AAGxD,EAAA,uBACIA,wBAAA,CAAA,aAAA;AAAA,IAAC,QAAA;AAAA,IAAA;AAAA,MACG,QAAU,EAAA,OAAA;AAAA,MACV,SAAA,EAAW,yBAAyB,IAAI,CAAA,CAAA,EAAI,UAAU,+BAAkC,GAAA,EAAE,CAAI,CAAA,EAAA,SAAA,IAAa,EAAE,CAAA,CAAA;AAAA,MAC7G,OAAS,EAAA,YAAA;AAAA,MACR,GAAG;AAAA,KAAA;AAAA,oBAEJA,wBAAA,CAAA,aAAA,CAAC,gBAAa,SAAU,EAAA,4BAAA,EAA6B,QAAgB,IAAY,EAAA,CAAA;AAAA,oBACjFA,wBAAA,CAAA,aAAA,CAAC,iBAAc,SAAU,EAAA,6BAAA,EAA8B,QAAgB,IAAY,EAAA;AAAA,GACvF;AAER;;;AC5BO,SAAS,YAAA,CAAa,EAAE,SAAW,EAAA,MAAA,EAAQ,OAAO,IAAM,EAAA,OAAA,EAAS,GAAG,KAAA,EAA4B,EAAA;AACnG,EACI,uBAAAA,wBAAA,CAAA,aAAA,CAAC,KAAI,EAAA,EAAA,SAAA,EAAW,CAAkB,eAAA,EAAA,IAAI,CAAI,CAAA,EAAA,SAAA,IAAa,EAAE,CAAA,CAAA,EAAK,GAAG,KAAA,EAAA,EAC5D,OAAQ,CAAA,GAAA,CAAI,CACT,MAAA,qBAAAA,wBAAA,CAAA,aAAA,CAAC,kBAAmB,EAAA,EAAA,GAAA,EAAK,MAAO,CAAA,IAAA,EAAM,MAAgB,EAAA,IAAA,EAAY,MAAgB,EAAA,CACrF,CACL,CAAA;AAER;ACRO,SAAS,aAAA,CAAc,EAAE,IAAO,GAAA,IAAA,EAAM,SAAS,MAAQ,EAAA,GAAG,OAA6B,EAAA;AAC1F,EAAA,uBACIA,wBAAA,CAAA,aAAA,CAAC,SAAU,EAAA,EAAA,WAAA,EAAY,0CAAyC,IAAa,EAAA,GAAG,KAC5E,EAAA,kBAAAA,yBAAA,aAAC,CAAA,YAAA,EAAA,EAAa,IAAY,EAAA,OAAA,EAAkB,QAAgB,CAChE,CAAA;AAER;ACTO,SAAS,qBAAqB,EAAE,KAAA,GAAQ,iBAAiB,KAAO,EAAA,GAAG,OAAoC,EAAA;AAC1G,EAAA,uBAAOA,wBAAAA,CAAA,aAAC,CAAA,UAAA,EAAA,EAAW,KAAc,EAAA,OAAA,EAAS,MAAM,KAAK,KAAM,CAAA,IAAA,EAAS,EAAA,GAAG,KAAO,EAAA,CAAA;AAClF","file":"index.browser.cjs","sourcesContent":["import React from 'react';\n\nimport { WalletUiButton } from './types/wallet-ui-button';\nimport { WalletUiSize } from './types/wallet-ui-size';\n\nexport interface BaseButtonProps extends Omit<WalletUiButton, 'children'> {\n label: React.ReactNode;\n leftSection?: React.ReactNode;\n onClick?: (event: React.MouseEvent<HTMLButtonElement>) => void;\n rightSection?: React.ReactNode;\n size?: WalletUiSize;\n}\n\nexport function BaseButton({ className, label, leftSection, onClick, rightSection, size, ...props }: BaseButtonProps) {\n return (\n <button className={`wallet-ui-base-button ${size ?? 'md'} ${className ?? ''}`} onClick={onClick} {...props}>\n {leftSection ? <span className=\"wallet-ui-base-button-left-section\">{leftSection}</span> : null}\n {label}\n {rightSection ? <span className=\"wallet-ui-base-button-right-section\">{rightSection}</span> : null}\n </button>\n );\n}\n","import { UiWallet, UiWalletAccount } from '@wallet-standard/react';\nimport { SolanaClient } from 'gill';\nimport React, { ReactNode } from 'react';\n\nimport { WalletUiSize } from './types/wallet-ui-size';\n\nexport interface WalletUiContextProviderProps {\n children: ReactNode;\n size?: WalletUiSize;\n}\n\nexport interface WalletUiProviderContextValue {\n account?: UiWalletAccount;\n client: SolanaClient;\n connect: (wallet: UiWalletAccount) => void;\n connected: boolean;\n copy: () => void;\n disconnect: () => void;\n size: WalletUiSize;\n wallet?: UiWallet;\n wallets: UiWallet[];\n}\n\nexport interface WalletUiContextProviderProps {\n children: ReactNode;\n size?: WalletUiSize;\n}\n\nexport const WalletUiContext = React.createContext<WalletUiProviderContextValue>({} as WalletUiProviderContextValue);\n","import React from 'react';\n\nimport { WalletUiContext } from './wallet-ui-context';\n\nexport function useWalletUi() {\n return React.useContext(WalletUiContext);\n}\n","import { UiWallet, UiWalletAccount } from '@wallet-standard/react';\nimport React, { createContext } from 'react';\n\nexport interface WalletUiAccountInfo {\n account: UiWalletAccount;\n accountKeys: string[];\n wallet: UiWallet | undefined;\n}\n\nexport interface WalletUiAccountState extends Omit<WalletUiAccountInfo, 'account'> {\n account: UiWalletAccount | undefined;\n setAccount: React.Dispatch<React.SetStateAction<UiWalletAccount | undefined>>;\n}\n\nexport const WalletUiAccountContext = createContext<WalletUiAccountState>({} as WalletUiAccountState);\n","import { useContext } from 'react';\n\nimport { WalletUiAccountContext } from './wallet-ui-account-context';\n\nexport function useWalletUiAccount() {\n return useContext(WalletUiAccountContext);\n}\n","import { UiWallet, useConnect, useDisconnect } from '@wallet-standard/react';\nimport { useEffect } from 'react';\n\nimport { useWalletUi } from './use-wallet-ui';\nimport { useWalletUiAccount } from './use-wallet-ui-account';\n\nexport function useWalletUiWallet({ wallet }: { wallet: UiWallet }) {\n const { connect: connectAccount } = useWalletUi();\n const { setAccount } = useWalletUiAccount();\n const [isConnecting, connect] = useConnect(wallet);\n const [isDisconnecting, disconnect] = useDisconnect(wallet);\n useEffect(() => {}, [isDisconnecting]);\n\n return {\n connect: async () => {\n const connectedAccount = await connect();\n console.log('connectedAccount', connectedAccount);\n if (!connectedAccount.length) {\n console.log('connect, no accounts');\n return connectedAccount;\n }\n const first = connectedAccount[0];\n console.log('connect, setting first account => ', first);\n setAccount(first);\n connectAccount(first);\n return connectedAccount;\n },\n disconnect,\n isConnecting,\n isDisconnecting,\n };\n}\n","import { UiWallet } from '@wallet-standard/react';\nimport React, { HTMLAttributes } from 'react';\n\nimport { BaseButton, BaseButtonProps } from './base-button';\nimport { BaseDropdownControl } from './use-base-dropdown';\nimport { useWalletUiWallet } from './use-wallet-ui-wallet';\n\nexport enum BaseDropdownItemType {\n Item = 'Item',\n WalletConnect = 'WalletConnect',\n WalletCopy = 'WalletCopy',\n WalletDisconnect = 'WalletDisconnect',\n WalletNeeded = 'WalletNeeded',\n}\n\nexport interface BaseDropdownItem {\n closeMenu?: boolean;\n disabled?: boolean;\n handler: () => Promise<void>;\n label: string;\n leftSection?: React.ReactNode;\n rightSection?: React.ReactNode;\n type: BaseDropdownItemType;\n value: string;\n wallet?: UiWallet;\n}\n\nexport interface BaseDropdownProps {\n buttonProps: BaseButtonProps;\n dropdown: BaseDropdownControl;\n items: BaseDropdownItem[];\n showIndicator?: boolean;\n}\n\nexport function BaseDropdown({ buttonProps, dropdown, showIndicator, items }: BaseDropdownProps) {\n const api = dropdown.api;\n const trigger = (\n <BaseButton\n {...api.getTriggerProps()}\n className={`wallet-ui-base-dropdown-trigger`}\n data-part=\"trigger\"\n rightSection={\n showIndicator ? (\n <span className=\"wallet-actions\">\n <span {...api.getIndicatorProps()} className=\"indicator\">\n <BaseDropdownChevronDown size={12} />\n </span>\n </span>\n ) : null\n }\n {...buttonProps}\n />\n );\n\n return (\n <div className=\"wallet-ui-base-dropdown\">\n {trigger}\n <div {...api.getPositionerProps()} className=\"wallet-positioner\">\n <div {...api.getContentProps()} className=\"wallet-ui-base-dropdown-list\" data-part=\"content\">\n {items.map(item => {\n return (\n <BaseDropdownItem\n {...api.getItemProps({ value: item.value })}\n key={item.value}\n item={item}\n afterClick={() => {\n if (item.disabled) {\n return;\n }\n if (item.closeMenu !== false) {\n dropdown.close();\n }\n }}\n />\n );\n })}\n </div>\n </div>\n </div>\n );\n}\n\nfunction BaseDropdownItem({ afterClick, item }: BaseDropdownItemRenderProps) {\n if (!item.wallet) {\n return <BaseDropdownItemRender afterClick={afterClick} item={item} />;\n }\n switch (item.type) {\n case BaseDropdownItemType.Item:\n return <BaseDropdownItemRender afterClick={afterClick} item={item} />;\n case BaseDropdownItemType.WalletConnect:\n return <BaseDropdownItemWalletConnect afterClick={afterClick} item={item} wallet={item.wallet} />;\n case BaseDropdownItemType.WalletCopy:\n return <BaseDropdownItemRender afterClick={afterClick} item={item} />;\n case BaseDropdownItemType.WalletDisconnect:\n return <BaseDropdownItemWalletDisconnect afterClick={afterClick} item={item} wallet={item.wallet} />;\n }\n}\n\nfunction BaseDropdownItemWalletConnect({\n afterClick,\n item,\n wallet,\n}: BaseDropdownItemRenderProps & {\n wallet: UiWallet;\n}) {\n const { connect } = useWalletUiWallet({ wallet });\n return (\n <BaseDropdownItemRender\n afterClick={afterClick}\n item={{\n ...item,\n handler: async () => {\n //\n await connect();\n return await item.handler();\n },\n }}\n />\n );\n}\n\nfunction BaseDropdownItemWalletDisconnect({\n afterClick,\n item,\n wallet,\n}: BaseDropdownItemRenderProps & {\n wallet: UiWallet;\n}) {\n const { disconnect } = useWalletUiWallet({ wallet });\n return (\n <BaseDropdownItemRender\n afterClick={afterClick}\n item={{\n ...item,\n handler: async () => {\n //\n await disconnect();\n return await item.handler();\n },\n }}\n />\n );\n}\n\ninterface BaseDropdownItemRenderProps {\n afterClick: () => void;\n item: BaseDropdownItem;\n}\n\nfunction BaseDropdownItemRender({ afterClick, item }: BaseDropdownItemRenderProps) {\n function onClick() {\n if (item.disabled) {\n return;\n }\n void item.handler().then(() => {\n afterClick();\n });\n }\n\n return (\n <div className=\"wallet-ui-base-dropdown-item\" data-part=\"item\" onClick={onClick}>\n {item.leftSection ? (\n <span className=\"wallet-ui-base-dropdown-item-left-section\">{item.leftSection}</span>\n ) : null}\n {item.label}\n {item.rightSection ? (\n <span className=\"wallet-ui-base-dropdown-item-right-section\">{item.rightSection}</span>\n ) : null}\n </div>\n );\n}\n\nexport function BaseDropdownChevronDown(props: HTMLAttributes<SVGElement> & { size?: number }) {\n return (\n <svg\n xmlns=\"http://www.w3.org/2000/svg\"\n width={props.size ?? 24}\n height={props.size ?? 24}\n viewBox=\"0 0 24 24\"\n fill=\"none\"\n stroke=\"currentColor\"\n strokeWidth=\"2\"\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n {...props}\n >\n <path d=\"m6 9 6 6 6-6\" />\n </svg>\n );\n}\n","import React from 'react';\n\nimport { WalletUiSize } from './types/wallet-ui-size';\nimport { WalletUiSvg } from './types/wallet-ui-svg';\n\nexport interface BaseSvgProps extends WalletUiSvg {\n size: WalletUiSize;\n sizes: { [key: string]: number };\n viewBox: string;\n}\n\nexport function BaseSvg({ sizes = {}, ...props }: BaseSvgProps) {\n const size = props.size ? sizes[props.size] : 12;\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" width={size} height={size} {...props}>\n {props.children}\n </svg>\n );\n}\n","import React from 'react';\n\nimport { BaseSvg, BaseSvgProps } from './base-svg';\n\nexport function WalletUiIconClose({ size = 'md', ...props }: Omit<BaseSvgProps, 'sizes' | 'viewBox'>) {\n return (\n <BaseSvg\n size={size}\n sizes={{ lg: 16, md: 12, sm: 8 }}\n fill=\"none\"\n stroke=\"currentColor\"\n strokeWidth=\"3\"\n viewBox=\"0 0 14 14\"\n {...props}\n >\n <path d=\"M14 12.461 8.3 6.772l5.234-5.233L12.006 0 6.772 5.234 1.54 0 0 1.539l5.234 5.233L0 12.006l1.539 1.528L6.772 8.3l5.69 5.7L14 12.461z\"></path>\n </BaseSvg>\n );\n}\n","import { Portal } from '@zag-js/react';\nimport React from 'react';\n\nimport { BaseButton, BaseButtonProps } from './base-button';\nimport { WalletUiSize } from './types/wallet-ui-size';\nimport { BaseModalControl } from './use-base-modal';\nimport { WalletUiIconClose } from './wallet-ui-icon-close';\n\nexport interface BaseModalProps {\n buttonLabel?: React.ReactNode;\n buttonProps?: Partial<BaseButtonProps>;\n children: React.ReactNode;\n description?: React.ReactNode;\n modal: BaseModalControl;\n size?: WalletUiSize;\n title?: React.ReactNode;\n}\n\nexport function BaseModal({ modal, buttonLabel, buttonProps = {}, size = 'md', ...props }: BaseModalProps) {\n const api = modal.api;\n return (\n <>\n {buttonLabel ? (\n <BaseButton label={buttonLabel} size={size} {...buttonProps} {...api.getTriggerProps()} />\n ) : null}\n {api.open && (\n <Portal>\n <div {...api.getBackdropProps()} />\n <div {...api.getPositionerProps()}>\n <div {...api.getContentProps()} className={size}>\n <header>\n <button {...api.getCloseTriggerProps()}>\n <WalletUiIconClose size={size} />\n </button>\n </header>\n {props.description ? <p {...api.getDescriptionProps()}>{props.description}</p> : null}\n <main>{props.children}</main>\n </div>\n </div>\n </Portal>\n )}\n </>\n );\n}\n","import * as menu from '@zag-js/menu';\nimport { normalizeProps, useMachine } from '@zag-js/react';\nimport { useId } from 'react';\n\nexport type BaseDropdownApi = ReturnType<typeof menu.connect>;\n\nexport interface BaseDropdownControl {\n api: BaseDropdownApi;\n close: () => void;\n open: () => void;\n}\n\nexport function useBaseDropdown(): BaseDropdownControl {\n const service = useMachine(menu.machine, { id: useId() });\n const api = menu.connect(service, normalizeProps);\n\n return {\n api,\n close: () => service.send({ type: 'CLOSE' }),\n open: () => service.send({ type: 'OPEN' }),\n };\n}\n","import * as dialog from '@zag-js/dialog';\nimport { normalizeProps, useMachine } from '@zag-js/react';\nimport { useId } from 'react';\n\nexport type BaseModalApi = ReturnType<typeof dialog.connect>;\n\nexport interface BaseModalControl {\n api: BaseModalApi;\n close: () => void;\n open: () => void;\n}\n\nexport function useBaseModal(): BaseModalControl {\n const service = useMachine(dialog.machine, { id: useId(), modal: true });\n const api = dialog.connect(service, normalizeProps);\n\n return {\n api,\n close: () => service.send({ type: 'CLOSE' }),\n open: () => service.send({ type: 'OPEN' }),\n };\n}\n","import { SolanaClient, SolanaClientUrlOrMoniker } from 'gill';\nimport { createContext, ReactNode } from 'react';\n\nexport interface WalletUiSolanaClientContextProviderProps {\n children: ReactNode;\n urlOrMoniker: SolanaClientUrlOrMoniker;\n}\n\nexport const WalletUiSolanaClientContext = createContext<SolanaClient>({} as SolanaClient);\n","import { useContext } from 'react';\n\nimport { WalletUiSolanaClientContext } from './wallet-ui-solana-client-context';\n\nexport function useWalletUiSolanaClient() {\n return useContext(WalletUiSolanaClientContext);\n}\n","import { SolanaCluster, SolanaClusterId } from '@wallet-ui/core';\nimport { createContext, ReactNode } from 'react';\n\nexport interface WalletUiClusterContextProviderProps {\n clusters: SolanaCluster[];\n render: (props: WalletUiClusterContextValue) => ReactNode;\n storageKey?: string;\n}\n\nexport interface WalletUiClusterContextValue {\n cluster: SolanaCluster;\n clusters: SolanaCluster[];\n\n setCluster(cluster: SolanaClusterId): void;\n}\n\nexport const WalletUiClusterContext = createContext<WalletUiClusterContextValue>({} as WalletUiClusterContextValue);\n","import { useContext } from 'react';\n\nimport { WalletUiClusterContext } from './wallet-ui-cluster-context';\n\nexport function useWalletUiCluster() {\n return useContext(WalletUiClusterContext);\n}\n","import { UiWallet } from '@wallet-standard/react';\nimport React from 'react';\n\nimport { WalletUiImg } from './types/wallet-ui-img';\nimport { WalletUiSize } from './types/wallet-ui-size';\n\nexport interface WalletUiIconProps extends WalletUiImg {\n size?: WalletUiSize;\n wallet?: Pick<UiWallet, 'icon' | 'name'>;\n}\n\nexport function WalletUiIcon({ className, size, wallet, ...props }: WalletUiIconProps) {\n if (!wallet) {\n return null;\n }\n\n return (\n <img\n src={wallet.icon}\n alt={wallet.name}\n className={`wallet-ui-list-icon ${size ?? 'md'} ${className ?? ''}`}\n {...props}\n />\n );\n}\n","import { UiWallet, UiWalletAccount } from '@wallet-standard/react';\nimport React, { useMemo } from 'react';\n\nimport { BaseButtonProps } from './base-button';\nimport { BaseDropdownItem, BaseDropdownItemType } from './base-dropdown';\nimport { WalletUiSize } from './types/wallet-ui-size';\nimport { BaseDropdownControl, useBaseDropdown } from './use-base-dropdown';\nimport { useWalletUi } from './use-wallet-ui';\nimport { WalletUiIcon } from './wallet-ui-icon';\n\nfunction getDropdownItemsWallets({\n wallets,\n connect,\n size,\n}: {\n connect: (wallet: UiWalletAccount) => void;\n size: WalletUiSize;\n wallets: UiWallet[];\n}): BaseDropdownItem[] {\n return wallets.length\n ? wallets.map(wallet => ({\n handler: async () => {\n // TODO: Add support for multiple accounts, properly handle no accounts\n const account = wallet.accounts.length > 0 ? wallet.accounts[0] : undefined;\n if (!account) {\n return;\n }\n connect(account);\n await Promise.resolve();\n },\n label: wallet.name,\n leftSection: <WalletUiIcon wallet={wallet} size={size} />,\n type: BaseDropdownItemType.WalletConnect,\n value: wallet.name,\n wallet,\n }))\n : [\n {\n handler: async () => {\n window.open('https://solana.com/solana-wallets', '_blank');\n await Promise.resolve();\n },\n label: \"You'll need a wallet on Solana to continue\",\n type: BaseDropdownItemType.WalletNeeded,\n value: 'no-wallets',\n },\n ];\n}\n\nexport function useWalletUiDropdown({ size = 'md' }: { size?: WalletUiSize } = {}): {\n buttonProps: BaseButtonProps;\n connected: boolean;\n dropdown: BaseDropdownControl;\n items: BaseDropdownItem[];\n} {\n const dropdown = useBaseDropdown();\n\n const { account, connect, copy, disconnect, connected, wallet, wallets } = useWalletUi();\n\n const itemsWallets = useMemo(() => {\n return getDropdownItemsWallets({ connect, size, wallets });\n }, [wallets, size, connect]);\n\n const itemsConnected: BaseDropdownItem[] = useMemo(\n () => [\n {\n handler: async () => {\n copy();\n void (await Promise.resolve());\n },\n label: 'Copy Address',\n type: BaseDropdownItemType.WalletCopy,\n value: 'copy',\n },\n {\n handler: async () => {\n disconnect();\n dropdown.close();\n await Promise.resolve();\n },\n label: 'Disconnect',\n type: BaseDropdownItemType.WalletDisconnect,\n value: 'disconnect',\n },\n ...itemsWallets,\n ],\n [connect, copy, disconnect, dropdown, size, wallets],\n );\n const items = useMemo(() => {\n return connected ? itemsConnected : itemsWallets;\n }, [connected, itemsConnected, itemsWallets]);\n\n const buttonProps: BaseButtonProps = useMemo(() => {\n return {\n label: connected ? ((account ? ellipsify(account.address) : wallet?.name) ?? 'Connected') : 'Select Wallet',\n leftSection: connected ? <WalletUiIcon size={size} wallet={wallet} /> : undefined,\n };\n }, [account, connected, size, wallet]);\n\n return {\n buttonProps,\n connected,\n dropdown,\n items,\n };\n}\n\nexport function ellipsify(str = '', len = 4, delimiter = '..') {\n const strLen = str.length;\n const limit = len * 2 + delimiter.length;\n\n return strLen >= limit ? str.substring(0, len) + delimiter + str.substring(strLen - len, strLen) : str;\n}\n","import { useWallets } from '@wallet-standard/react';\nimport { useMemo } from 'react';\n\nexport function useWalletUiWallets() {\n const readonlyWallets = useWallets();\n return useMemo(\n () =>\n readonlyWallets\n .filter(wallet => wallet.chains.some(i => i.startsWith('solana:')))\n .sort((a, b) => a.name.localeCompare(b.name)),\n [readonlyWallets],\n );\n}\n","import {\n getUiWalletAccountStorageKey,\n UiWallet,\n UiWalletAccount,\n uiWalletAccountBelongsToUiWallet,\n uiWalletAccountsAreSame,\n useWallets,\n} from '@wallet-standard/react';\nimport React, { useEffect, useMemo, useState } from 'react';\n\nimport { useWalletUiCluster } from './use-wallet-ui-cluster';\nimport { WalletUiAccountContext } from './wallet-ui-account-context';\n\nconst STORAGE_KEY = 'wallet-ui:selected-wallet-account';\n\nlet wasSetterInvoked = false;\n\nfunction getSavedWalletAccount(wallets: readonly UiWallet[], storageKey: string): UiWalletAccount | undefined {\n if (wasSetterInvoked) {\n // After the user makes an explicit choice of wallet, stop trying to auto-select the\n // saved wallet, if and when it appears.\n return;\n }\n const savedWalletNameAndAddress = localStorage.getItem(storageKey);\n if (!savedWalletNameAndAddress || typeof savedWalletNameAndAddress !== 'string') {\n return;\n }\n const [savedWalletName, savedAccountAddress] = savedWalletNameAndAddress.split(':');\n if (!savedWalletName || !savedAccountAddress) {\n return;\n }\n for (const wallet of wallets) {\n if (wallet.name === savedWalletName) {\n for (const account of wallet.accounts) {\n if (account.address === savedAccountAddress) {\n return account;\n }\n }\n }\n }\n}\n\n/**\n * Saves the selected wallet account's storage key to the browser's local storage. In future\n * sessions it will try to return that same wallet account, or at least one from the same brand of\n * wallet if the wallet from which it came is still in the Wallet Standard registry.\n */\nexport function WalletUiAccountContextProvider({\n children,\n storageKey = STORAGE_KEY,\n}: {\n children: React.ReactNode;\n storageKey?: string;\n}) {\n const { cluster } = useWalletUiCluster();\n const wallets = useWallets();\n const [account, setAccountInternal] = useState<UiWalletAccount | undefined>(() =>\n getSavedWalletAccount(wallets, storageKey),\n );\n\n function setAccount(setStateAction: React.SetStateAction<UiWalletAccount | undefined>) {\n setAccountInternal(prevAccount => {\n wasSetterInvoked = true;\n const nextWalletAccount =\n typeof setStateAction === 'function' ? setStateAction(prevAccount) : setStateAction;\n const accountKey = nextWalletAccount ? getUiWalletAccountStorageKey(nextWalletAccount) : undefined;\n if (accountKey) {\n localStorage.setItem(storageKey, accountKey);\n } else {\n localStorage.removeItem(storageKey);\n }\n return nextWalletAccount;\n });\n }\n\n useEffect(() => {\n const savedWalletAccount = getSavedWalletAccount(wallets, storageKey);\n if (savedWalletAccount) {\n setAccountInternal(savedWalletAccount);\n }\n }, [wallets]);\n const walletAccount = useMemo(() => {\n if (account) {\n for (const uiWallet of wallets) {\n for (const uiWalletAccount of uiWallet.accounts) {\n if (uiWalletAccountsAreSame(account, uiWalletAccount)) {\n return uiWalletAccount;\n }\n }\n if (uiWalletAccountBelongsToUiWallet(account, uiWallet) && uiWallet.accounts[0]) {\n // If the selected account belongs to this connected wallet, at least, then\n // select one of its accounts.\n return uiWallet.accounts[0];\n }\n }\n }\n }, [account, wallets]);\n useEffect(() => {\n // If there is a selected wallet account but the wallet to which it belongs has since\n // disconnected, clear the selected wallet.\n if (account && !walletAccount) {\n setAccountInternal(undefined);\n }\n }, [account, walletAccount]);\n\n const wallet = useMemo(() => {\n if (!walletAccount) {\n return undefined;\n }\n for (const uiWallet of wallets) {\n for (const uiWalletAccount of uiWallet.accounts) {\n if (uiWalletAccountsAreSame(walletAccount, uiWalletAccount)) {\n return uiWallet;\n }\n }\n if (uiWalletAccountBelongsToUiWallet(walletAccount, uiWallet) && uiWallet.accounts[0]) {\n // If the selected account belongs to this connected wallet, at least, then\n // select one of its accounts.\n return uiWallet;\n }\n }\n }, [walletAccount, wallets]);\n\n // Expose the error boundary reset keys to the context\n const accountKeys = useMemo(() => {\n if (!account) {\n return [];\n }\n return [cluster.id, getUiWalletAccountStorageKey(account)].filter(Boolean);\n }, [account]);\n return (\n <WalletUiAccountContext.Provider\n value={useMemo(\n () => ({\n account: walletAccount,\n accountKeys,\n setAccount,\n wallet,\n }),\n [walletAccount, wallet, accountKeys],\n )}\n >\n {children}\n </WalletUiAccountContext.Provider>\n );\n}\n","import { createSolanaClient, SolanaClient } from 'gill';\nimport React, { useMemo } from 'react';\n\nimport {\n WalletUiSolanaClientContext,\n WalletUiSolanaClientContextProviderProps,\n} from './wallet-ui-solana-client-context';\n\nexport function WalletUiClientContextProvider({ children, urlOrMoniker }: WalletUiSolanaClientContextProviderProps) {\n return (\n <WalletUiSolanaClientContext.Provider\n value={useMemo(() => createSolanaClient({ urlOrMoniker }) as SolanaClient, [urlOrMoniker])}\n >\n {children}\n </WalletUiSolanaClientContext.Provider>\n );\n}\n","import { useCallback, useState } from 'react';\n\nexport function useLocalStorage<T>(key: string, initialValue: T) {\n // State to store our value\n const [storedValue, setStoredValue] = useState<T>(() => {\n try {\n // Check if we're on the client side\n if (typeof window === 'undefined') {\n return initialValue;\n }\n\n const item = window.localStorage.getItem(key);\n // For wallet-related data, validate the stored value\n if (key.includes('wallet') || key.includes('account')) {\n // Return initial value if stored data might be stale\n return initialValue;\n }\n return item ? JSON.parse(item) : initialValue;\n } catch (error) {\n console.warn(`Error reading localStorage key \"${key}\":`, error);\n return initialValue;\n }\n });\n\n // Return a wrapped version of useState's setter function that persists the new value to localStorage\n const setValue = useCallback(\n (value: T | ((val: T) => T)) => {\n try {\n // Allow value to be a function so we have same API as useState\n const valueToStore = value instanceof Function ? value(storedValue) : value;\n\n // Save state\n setStoredValue(valueToStore);\n\n // Save to localStorage\n if (typeof window !== 'undefined') {\n if (valueToStore === undefined || valueToStore === null) {\n window.localStorage.removeItem(key);\n } else {\n window.localStorage.setItem(key, JSON.stringify(valueToStore));\n }\n }\n } catch (error) {\n console.warn(`Error setting localStorage key \"${key}\":`, error);\n }\n },\n [key, storedValue],\n );\n\n return [storedValue, setValue] as const;\n}\n","import { SolanaCluster, SolanaClusterId } from '@wallet-ui/core';\nimport React, { useMemo } from 'react';\n\nimport { useLocalStorage } from './use-local-storage';\nimport {\n WalletUiClusterContext,\n WalletUiClusterContextProviderProps,\n WalletUiClusterContextValue,\n} from './wallet-ui-cluster-context';\n\nexport function WalletUiClusterContextProvider({\n clusters,\n render,\n storageKey = '__wallet-ui:selected-cluster',\n}: WalletUiClusterContextProviderProps) {\n const [clusterId, setClusterId] = useLocalStorage(storageKey, 'solana:devnet');\n if (!clusters.length) {\n throw new Error('No clusters provided');\n }\n const cluster = useMemo<SolanaCluster>(() => {\n for (const cluster of clusters) {\n if (cluster.id === clusterId) {\n return cluster;\n }\n }\n return clusters[0];\n }, [clusterId, clusters]);\n\n const value: WalletUiClusterContextValue = {\n cluster,\n clusters,\n setCluster: (cluster: SolanaClusterId) => {\n localStorage.setItem(storageKey, cluster);\n setClusterId(cluster);\n },\n };\n\n return <WalletUiClusterContext.Provider value={value}>{render(value)}</WalletUiClusterContext.Provider>;\n}\n","import { UiWalletAccount } from '@wallet-standard/react';\nimport { handleCopyText } from '@wallet-ui/core';\nimport React from 'react';\n\nimport { useWalletUiAccount } from './use-wallet-ui-account';\nimport { useWalletUiSolanaClient } from './use-wallet-ui-solana-client';\nimport { useWalletUiWallets } from './use-wallet-ui-wallets';\nimport { WalletUiContext, WalletUiContextProviderProps, WalletUiProviderContextValue } from './wallet-ui-context';\n\nexport function WalletUiContextProvider({ children, size = 'md' }: WalletUiContextProviderProps) {\n const { account, setAccount, wallet } = useWalletUiAccount();\n const wallets = useWalletUiWallets();\n const client = useWalletUiSolanaClient();\n const walletHasAccounts = Boolean(wallet && wallet?.accounts.length > 0);\n\n function connect(account: UiWalletAccount) {\n setAccount(account);\n }\n\n function disconnect() {\n setAccount(undefined);\n }\n\n function copy() {\n if (!account) {\n return;\n }\n handleCopyText(account.address);\n }\n\n const value: WalletUiProviderContextValue = {\n account,\n client,\n connect,\n connected: walletHasAccounts,\n copy,\n disconnect,\n size,\n wallet,\n wallets,\n };\n\n return <WalletUiContext.Provider value={value}>{children}</WalletUiContext.Provider>;\n}\n","import { SolanaCluster } from '@wallet-ui/core';\nimport React from 'react';\n\nimport { WalletUiAccountContextProvider } from './wallet-ui-account-context-provider';\nimport { WalletUiClientContextProvider } from './wallet-ui-client-context-provider';\nimport { WalletUiClusterContextProvider } from './wallet-ui-cluster-context-provider';\nimport { WalletUiContextProviderProps } from './wallet-ui-context';\nimport { WalletUiContextProvider } from './wallet-ui-context-provider';\n\nexport interface WalletUiConfig extends Omit<WalletUiContextProviderProps, 'children'> {\n clusterStorageKey?: string;\n clusters: SolanaCluster[];\n selectedAccountStorageKey?: string;\n}\n\nexport function createWalletUiConfig(props: WalletUiConfig): WalletUiConfig {\n return { ...props };\n}\n\nexport interface WalletUiProps {\n children: React.ReactNode;\n config: WalletUiConfig;\n}\n\nexport function WalletUi({\n children,\n config: { clusters, clusterStorageKey, selectedAccountStorageKey, ...config },\n}: WalletUiProps) {\n return (\n <React.Fragment>\n <WalletUiClusterContextProvider\n clusters={clusters}\n storageKey={clusterStorageKey}\n render={({ cluster }) => {\n return (\n <WalletUiClientContextProvider urlOrMoniker={cluster.urlOrMoniker}>\n <WalletUiAccountContextProvider storageKey={selectedAccountStorageKey}>\n <WalletUiContextProvider {...config}>{children}</WalletUiContextProvider>\n </WalletUiAccountContextProvider>\n </WalletUiClientContextProvider>\n );\n }}\n />\n </React.Fragment>\n );\n}\n","import React from 'react';\n\nimport { BaseButton, BaseButtonProps } from './base-button';\nimport { WalletUiSize } from './types/wallet-ui-size';\n\nexport interface WalletUiButtonProps extends Omit<BaseButtonProps, 'label'> {\n size?: WalletUiSize;\n}\n\nexport function WalletUiButton({ ...props }: WalletUiButtonProps) {\n return <BaseButton {...props} label={'CLICK'} />;\n}\n","import React from 'react';\n\nimport { BaseDropdown, BaseDropdownItemType, BaseDropdownProps } from './base-dropdown';\nimport { WalletUiSize } from './types/wallet-ui-size';\nimport { useBaseDropdown } from './use-base-dropdown';\nimport { useWalletUiCluster } from './use-wallet-ui-cluster';\n\nexport interface WalletUiClusterDropdownProps\n extends Omit<BaseDropdownProps, 'buttonProps' | 'dropdown' | 'items' | 'label'> {\n buttonProps?: Partial<BaseDropdownProps['buttonProps']>;\n size?: WalletUiSize;\n}\n\nexport function WalletUiClusterDropdown({ buttonProps, size = 'md', ...props }: WalletUiClusterDropdownProps) {\n const dropdown = useBaseDropdown();\n const { cluster, clusters, setCluster } = useWalletUiCluster();\n return (\n <BaseDropdown\n buttonProps={{ ...buttonProps, label: cluster.label, size: size }}\n items={clusters.map(cluster => ({\n handler: async () => {\n setCluster(cluster.id);\n await Promise.resolve();\n },\n label: cluster.label,\n type: BaseDropdownItemType.Item,\n value: cluster.id,\n }))}\n dropdown={dropdown}\n {...props}\n />\n );\n}\n","import React from 'react';\n\nimport { BaseDropdown } from './base-dropdown';\nimport { WalletUiSize } from './types/wallet-ui-size';\nimport { useWalletUiDropdown } from './use-wallet-ui-dropdown';\n\nexport interface WalletUiDropdownProps {\n label?: string;\n size?: WalletUiSize;\n}\n\nexport function WalletUiDropdown({ size = 'md', ...props }: WalletUiDropdownProps) {\n const { buttonProps, items, dropdown } = useWalletUiDropdown({ size });\n return <BaseDropdown {...props} buttonProps={{ ...buttonProps, size }} items={items} dropdown={dropdown} />;\n}\n","import React from 'react';\n\nimport { BaseSvg, BaseSvgProps } from './base-svg';\n\nexport function WalletUiIconNoWallet({ size, ...props }: Omit<BaseSvgProps, 'sizes' | 'viewBox'>) {\n return (\n <BaseSvg size={size} sizes={{ lg: 125, md: 100, sm: 75 }} fill=\"none\" viewBox=\"0 0 97 96\" {...props}>\n <circle cx=\"48.5\" cy=\"48\" r=\"48\" fill=\"url(#paint0_linear_880_5115)\" fillOpacity=\"0.1\"></circle>\n <circle\n cx=\"48.5\"\n cy=\"48\"\n r=\"47\"\n stroke=\"url(#paint1_linear_880_5115)\"\n strokeOpacity=\"0.4\"\n strokeWidth=\"2\"\n ></circle>\n <g clipPath=\"url(#clip0_880_5115)\">\n <path\n d=\"M65.5769 28.1523H31.4231C27.6057 28.1523 24.5 31.258 24.5 35.0754V60.9215C24.5 64.7389 27.6057 67.8446 31.4231 67.8446H65.5769C69.3943 67.8446 72.5 64.7389 72.5 60.9215V35.0754C72.5 31.258 69.3943 28.1523 65.5769 28.1523ZM69.7308 52.1523H59.5769C57.2865 52.1523 55.4231 50.289 55.4231 47.9985C55.4231 45.708 57.2864 43.8446 59.5769 43.8446H69.7308V52.1523ZM69.7308 41.0754H59.5769C55.7595 41.0754 52.6539 44.1811 52.6539 47.9985C52.6539 51.8159 55.7595 54.9215 59.5769 54.9215H69.7308V60.9215C69.7308 63.2119 67.8674 65.0754 65.5769 65.0754H31.4231C29.1327 65.0754 27.2692 63.212 27.2692 60.9215V35.0754C27.2692 32.785 29.1326 30.9215 31.4231 30.9215H65.5769C67.8673 30.9215 69.7308 32.7849 69.7308 35.0754V41.0754Z\"\n fill=\"url(#paint2_linear_880_5115)\"\n ></path>\n <path\n d=\"M61.4231 46.6172H59.577C58.8123 46.6172 58.1924 47.2371 58.1924 48.0018C58.1924 48.7665 58.8123 49.3863 59.577 49.3863H61.4231C62.1878 49.3863 62.8077 48.7664 62.8077 48.0018C62.8077 47.2371 62.1878 46.6172 61.4231 46.6172Z\"\n fill=\"url(#paint3_linear_880_5115)\"\n ></path>\n </g>\n <defs>\n <linearGradient\n id=\"paint0_linear_880_5115\"\n x1=\"3.41664\"\n y1=\"98.0933\"\n x2=\"103.05\"\n y2=\"8.42498\"\n gradientUnits=\"userSpaceOnUse\"\n >\n <stop stopColor=\"#9945FF\"></stop>\n <stop offset=\"0.14\" stopColor=\"#8A53F4\"></stop>\n <stop offset=\"0.42\" stopColor=\"#6377D6\"></stop>\n <stop offset=\"0.79\" stopColor=\"#24B0A7\"></stop>\n <stop offset=\"0.99\" stopColor=\"#00D18C\"></stop>\n <stop offset=\"1\" stopColor=\"#00D18C\"></stop>\n </linearGradient>\n <linearGradient\n id=\"paint1_linear_880_5115\"\n x1=\"3.41664\"\n y1=\"98.0933\"\n x2=\"103.05\"\n y2=\"8.42498\"\n gradientUnits=\"userSpaceOnUse\"\n >\n <stop stopColor=\"#9945FF\"></stop>\n <stop offset=\"0.14\" stopColor=\"#8A53F4\"></stop>\n <stop offset=\"0.42\" stopColor=\"#6377D6\"></stop>\n <stop offset=\"0.79\" stopColor=\"#24B0A7\"></stop>\n <stop offset=\"0.99\" stopColor=\"#00D18C\"></stop>\n <stop offset=\"1\" stopColor=\"#00D18C\"></stop>\n </linearGradient>\n <linearGradient\n id=\"paint2_linear_880_5115\"\n x1=\"25.9583\"\n y1=\"68.7101\"\n x2=\"67.2337\"\n y2=\"23.7879\"\n gradientUnits=\"userSpaceOnUse\"\n >\n <stop stopColor=\"#9945FF\"></stop>\n <stop offset=\"0.14\" stopColor=\"#8A53F4\"></stop>\n <stop offset=\"0.42\" stopColor=\"#6377D6\"></stop>\n <stop offset=\"0.79\" stopColor=\"#24B0A7\"></stop>\n <stop offset=\"0.99\" stopColor=\"#00D18C\"></stop>\n <stop offset=\"1\" stopColor=\"#00D18C\"></stop>\n </linearGradient>\n <linearGradient\n id=\"paint3_linear_880_5115\"\n x1=\"58.3326\"\n y1=\"49.4467\"\n x2=\"61.0002\"\n y2=\"45.4453\"\n gradientUnits=\"userSpaceOnUse\"\n >\n <stop stopColor=\"#9945FF\"></stop>\n <stop offset=\"0.14\" stopColor=\"#8A53F4\"></stop>\n <stop offset=\"0.42\" stopColor=\"#6377D6\"></stop>\n <stop offset=\"0.79\" stopColor=\"#24B0A7\"></stop>\n <stop offset=\"0.99\" stopColor=\"#00D18C\"></stop>\n <stop offset=\"1\" stopColor=\"#00D18C\"></stop>\n </linearGradient>\n <clipPath id=\"clip0_880_5115\">\n <rect width=\"48\" height=\"48\" fill=\"white\" transform=\"translate(24.5 24)\"></rect>\n </clipPath>\n </defs>\n </BaseSvg>\n );\n}\n","import { UiWallet } from '@wallet-standard/react';\nimport React from 'react';\n\nimport { WalletUiSize } from './types/wallet-ui-size';\n\nexport interface WalletUiLabelProps\n extends React.DetailedHTMLProps<React.HTMLAttributes<HTMLSpanElement>, HTMLSpanElement> {\n size?: WalletUiSize;\n wallet?: Pick<UiWallet, 'name'>;\n}\n\nexport function WalletUiLabel({ className, size, wallet, ...props }: WalletUiLabelProps) {\n if (!wallet) {\n return null;\n }\n\n return (\n <span className={`wallet-ui-list-label ${size ?? 'md'} ${className ?? ''}`} {...props}>\n {wallet.name}\n </span>\n );\n}\n","import { UiWallet, UiWalletAccount } from '@wallet-standard/react';\nimport React from 'react';\n\nimport { WalletUiButton } from './types/wallet-ui-button';\nimport { WalletUiSize } from './types/wallet-ui-size';\nimport { WalletUiIcon } from './wallet-ui-icon';\nimport { WalletUiLabel } from './wallet-ui-label';\n\nexport interface WalletUiListButtonProps extends Omit<WalletUiButton, 'onClick'> {\n select?: (wallet: UiWalletAccount) => Promise<void>;\n size?: WalletUiSize;\n wallet: UiWallet;\n}\n\nexport function WalletUiListButton({ className, select, size = 'md', wallet, ...props }: WalletUiListButtonProps) {\n const [pending, setPending] = React.useState(false);\n\n function handleSelect() {\n if (!select) {\n return;\n }\n setPending(true);\n // TODO: Add support for multiple accounts, properly handle no accounts\n const account = wallet.accounts.length > 0 ? wallet.accounts[0] : undefined;\n if (!account) {\n return;\n }\n void select(account).finally(() => setPending(false));\n }\n\n return (\n <button\n disabled={pending}\n className={`wallet-ui-list-button ${size} ${pending ? 'wallet-ui-list-button-pending' : ''} ${className ?? ''}`}\n onClick={handleSelect}\n {...props}\n >\n <WalletUiIcon className=\"wallet-ui-list-button-icon\" wallet={wallet} size={size} />\n <WalletUiLabel className=\"wallet-ui-list-button-label\" wallet={wallet} size={size} />\n </button>\n );\n}\n","import { UiWallet, UiWalletAccount } from '@wallet-standard/react';\nimport React from 'react';\n\nimport { WalletUiDiv } from './types/wallet-ui-div';\nimport { WalletUiSize } from './types/wallet-ui-size';\nimport { WalletUiListButton } from './wallet-ui-list-button';\n\nexport interface WalletUiListProps extends WalletUiDiv {\n select?: (account: UiWalletAccount) => Promise<void>;\n size?: WalletUiSize;\n wallets: UiWallet[];\n}\n\nexport function WalletUiList({ className, select, size = 'md', wallets, ...props }: WalletUiListProps) {\n return (\n <div className={`wallet-ui-list ${size} ${className ?? ''}`} {...props}>\n {wallets.map(wallet => (\n <WalletUiListButton key={wallet.name} select={select} size={size} wallet={wallet} />\n ))}\n </div>\n );\n}\n","import { UiWallet, UiWalletAccount } from '@wallet-standard/react';\nimport React from 'react';\n\nimport { BaseModal, BaseModalProps } from './base-modal';\nimport { WalletUiSize } from './types/wallet-ui-size';\nimport { WalletUiList } from './wallet-ui-list';\n\nexport interface WalletUiModalProps extends Omit<BaseModalProps, 'children'> {\n select: (account: UiWalletAccount) => Promise<void>;\n size?: WalletUiSize;\n wallets: UiWallet[];\n}\n\nexport function WalletUiModal({ size = 'md', wallets, select, ...props }: WalletUiModalProps) {\n return (\n <BaseModal description=\"Connect a wallet on Solana to continue\" size={size} {...props}>\n <WalletUiList size={size} wallets={wallets} select={select} />\n </BaseModal>\n );\n}\n","import React from 'react';\n\nimport { BaseButton, BaseButtonProps } from './base-button';\nimport { BaseModalControl } from './use-base-modal';\n\nexport interface WalletUiModalTriggerProps extends Omit<BaseButtonProps, 'label'> {\n label?: string;\n modal: BaseModalControl;\n}\n\nexport function WalletUiModalTrigger({ label = 'Select Wallet', modal, ...props }: WalletUiModalTriggerProps) {\n return <BaseButton label={label} onClick={() => void modal.open()} {...props} />;\n}\n"]}
1
+ {"version":3,"sources":["../src/base-button.tsx","../src/wallet-ui-context.tsx","../src/use-wallet-ui.tsx","../src/wallet-ui-account-context.tsx","../src/use-wallet-ui-account.tsx","../src/use-wallet-ui-wallet.tsx","../src/base-dropdown.tsx","../src/base-svg.tsx","../src/wallet-ui-icon-close.tsx","../src/base-modal.tsx","../src/use-base-dropdown.tsx","../src/use-base-modal.tsx","../src/wallet-ui-cluster-context.tsx","../src/use-wallet-ui-cluster.tsx","../src/wallet-ui-icon.tsx","../src/use-wallet-ui-dropdown.tsx","../src/wallet-ui-solana-client-context.tsx","../src/use-wallet-ui-solana-client.tsx","../src/use-wallet-ui-wallets.tsx","../src/wallet-ui-account-context-provider.tsx","../src/use-local-storage.ts","../src/wallet-ui-cluster-context-provider.tsx","../src/wallet-ui-context-provider.tsx","../src/wallet-ui-solana-client-context-provider.tsx","../src/wallet-ui.tsx","../src/wallet-ui-button.tsx","../src/wallet-ui-cluster-dropdown.tsx","../src/wallet-ui-dropdown.tsx","../src/wallet-ui-icon-no-wallet.tsx","../src/wallet-ui-label.tsx","../src/wallet-ui-list-button.tsx","../src/wallet-ui-list.tsx","../src/wallet-ui-modal.tsx","../src/wallet-ui-modal-trigger.tsx"],"names":["React","createContext","useContext","connect","useConnect","useDisconnect","useEffect","BaseDropdownItemType","Portal","useMachine","menu","useId","normalizeProps","dialog","useMemo","useWallets","useState","getUiWalletAccountStorageKey","uiWalletAccountsAreSame","uiWalletAccountBelongsToUiWallet","useCallback","cluster","account","handleCopyText","createSolanaClient"],"mappings":"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","file":"index.browser.cjs","sourcesContent":["import React from 'react';\n\nimport { WalletUiButton } from './types/wallet-ui-button';\nimport { WalletUiSize } from './types/wallet-ui-size';\n\nexport interface BaseButtonProps extends Omit<WalletUiButton, 'children'> {\n label: React.ReactNode;\n leftSection?: React.ReactNode;\n onClick?: (event: React.MouseEvent<HTMLButtonElement>) => void;\n rightSection?: React.ReactNode;\n size?: WalletUiSize;\n}\n\nexport function BaseButton({ className, label, leftSection, onClick, rightSection, size, ...props }: BaseButtonProps) {\n return (\n <button className={`wallet-ui-base-button ${size ?? 'md'} ${className ?? ''}`} onClick={onClick} {...props}>\n {leftSection ? <span className=\"wallet-ui-base-button-left-section\">{leftSection}</span> : null}\n {label}\n {rightSection ? <span className=\"wallet-ui-base-button-right-section\">{rightSection}</span> : null}\n </button>\n );\n}\n","import { UiWallet, UiWalletAccount } from '@wallet-standard/react';\nimport { SolanaClient } from 'gill';\nimport React, { ReactNode } from 'react';\n\nimport { WalletUiSize } from './types/wallet-ui-size';\n\nexport interface WalletUiContextProviderProps {\n children: ReactNode;\n size?: WalletUiSize;\n}\n\nexport interface WalletUiProviderContextValue {\n account?: UiWalletAccount;\n client: SolanaClient;\n connect: (wallet: UiWalletAccount) => void;\n connected: boolean;\n copy: () => void;\n disconnect: () => void;\n size: WalletUiSize;\n wallet?: UiWallet;\n wallets: UiWallet[];\n}\n\nexport interface WalletUiContextProviderProps {\n children: ReactNode;\n size?: WalletUiSize;\n}\n\nexport const WalletUiContext = React.createContext<WalletUiProviderContextValue>({} as WalletUiProviderContextValue);\n","import React from 'react';\n\nimport { WalletUiContext } from './wallet-ui-context';\n\nexport function useWalletUi() {\n return React.useContext(WalletUiContext);\n}\n","import { UiWallet, UiWalletAccount } from '@wallet-standard/react';\nimport React, { createContext } from 'react';\n\nexport interface WalletUiAccountInfo {\n account: UiWalletAccount;\n accountKeys: string[];\n wallet: UiWallet | undefined;\n}\n\nexport interface WalletUiAccountState extends Omit<WalletUiAccountInfo, 'account'> {\n account: UiWalletAccount | undefined;\n setAccount: React.Dispatch<React.SetStateAction<UiWalletAccount | undefined>>;\n}\n\nexport const WalletUiAccountContext = createContext<WalletUiAccountState>({} as WalletUiAccountState);\n","import { useContext } from 'react';\n\nimport { WalletUiAccountContext } from './wallet-ui-account-context';\n\nexport function useWalletUiAccount() {\n return useContext(WalletUiAccountContext);\n}\n","import { UiWallet, useConnect, useDisconnect } from '@wallet-standard/react';\nimport { useEffect } from 'react';\n\nimport { useWalletUi } from './use-wallet-ui';\nimport { useWalletUiAccount } from './use-wallet-ui-account';\n\nexport function useWalletUiWallet({ wallet }: { wallet: UiWallet }) {\n const { connect: connectAccount } = useWalletUi();\n const { setAccount } = useWalletUiAccount();\n const [isConnecting, connect] = useConnect(wallet);\n const [isDisconnecting, disconnect] = useDisconnect(wallet);\n useEffect(() => {}, [isDisconnecting]);\n\n return {\n connect: async () => {\n const connectedAccount = await connect();\n console.log('connectedAccount', connectedAccount);\n if (!connectedAccount.length) {\n console.log('connect, no accounts');\n return connectedAccount;\n }\n const first = connectedAccount[0];\n console.log('connect, setting first account => ', first);\n setAccount(first);\n connectAccount(first);\n return connectedAccount;\n },\n disconnect,\n isConnecting,\n isDisconnecting,\n };\n}\n","import { UiWallet } from '@wallet-standard/react';\nimport React, { HTMLAttributes } from 'react';\n\nimport { BaseButton, BaseButtonProps } from './base-button';\nimport { BaseDropdownControl } from './use-base-dropdown';\nimport { useWalletUiWallet } from './use-wallet-ui-wallet';\n\nexport enum BaseDropdownItemType {\n Item = 'Item',\n WalletConnect = 'WalletConnect',\n WalletCopy = 'WalletCopy',\n WalletDisconnect = 'WalletDisconnect',\n WalletNeeded = 'WalletNeeded',\n}\n\nexport interface BaseDropdownItem {\n closeMenu?: boolean;\n disabled?: boolean;\n handler: () => Promise<void>;\n label: string;\n leftSection?: React.ReactNode;\n rightSection?: React.ReactNode;\n type: BaseDropdownItemType;\n value: string;\n wallet?: UiWallet;\n}\n\nexport interface BaseDropdownProps {\n buttonProps: BaseButtonProps;\n dropdown: BaseDropdownControl;\n items: BaseDropdownItem[];\n showIndicator?: boolean;\n}\n\nexport function BaseDropdown({ buttonProps, dropdown, showIndicator, items }: BaseDropdownProps) {\n const api = dropdown.api;\n const trigger = (\n <BaseButton\n {...api.getTriggerProps()}\n className={`wallet-ui-base-dropdown-trigger`}\n data-part=\"trigger\"\n rightSection={\n showIndicator ? (\n <span className=\"wallet-actions\">\n <span {...api.getIndicatorProps()} className=\"indicator\">\n <BaseDropdownChevronDown size={12} />\n </span>\n </span>\n ) : null\n }\n {...buttonProps}\n />\n );\n\n return (\n <div className=\"wallet-ui-base-dropdown\">\n {trigger}\n <div {...api.getPositionerProps()} className=\"wallet-positioner\">\n <div {...api.getContentProps()} className=\"wallet-ui-base-dropdown-list\" data-part=\"content\">\n {items.map(item => {\n return (\n <BaseDropdownItem\n {...api.getItemProps({ value: item.value })}\n key={item.value}\n item={item}\n afterClick={() => {\n if (item.disabled) {\n return;\n }\n if (item.closeMenu !== false) {\n dropdown.close();\n }\n }}\n />\n );\n })}\n </div>\n </div>\n </div>\n );\n}\n\nfunction BaseDropdownItem({ afterClick, item }: BaseDropdownItemRenderProps) {\n if (!item.wallet) {\n return <BaseDropdownItemRender afterClick={afterClick} item={item} />;\n }\n switch (item.type) {\n case BaseDropdownItemType.Item:\n return <BaseDropdownItemRender afterClick={afterClick} item={item} />;\n case BaseDropdownItemType.WalletConnect:\n return <BaseDropdownItemWalletConnect afterClick={afterClick} item={item} wallet={item.wallet} />;\n case BaseDropdownItemType.WalletCopy:\n return <BaseDropdownItemRender afterClick={afterClick} item={item} />;\n case BaseDropdownItemType.WalletDisconnect:\n return <BaseDropdownItemWalletDisconnect afterClick={afterClick} item={item} wallet={item.wallet} />;\n }\n}\n\nfunction BaseDropdownItemWalletConnect({\n afterClick,\n item,\n wallet,\n}: BaseDropdownItemRenderProps & {\n wallet: UiWallet;\n}) {\n const { connect } = useWalletUiWallet({ wallet });\n return (\n <BaseDropdownItemRender\n afterClick={afterClick}\n item={{\n ...item,\n handler: async () => {\n //\n await connect();\n return await item.handler();\n },\n }}\n />\n );\n}\n\nfunction BaseDropdownItemWalletDisconnect({\n afterClick,\n item,\n wallet,\n}: BaseDropdownItemRenderProps & {\n wallet: UiWallet;\n}) {\n const { disconnect } = useWalletUiWallet({ wallet });\n return (\n <BaseDropdownItemRender\n afterClick={afterClick}\n item={{\n ...item,\n handler: async () => {\n //\n await disconnect();\n return await item.handler();\n },\n }}\n />\n );\n}\n\ninterface BaseDropdownItemRenderProps {\n afterClick: () => void;\n item: BaseDropdownItem;\n}\n\nfunction BaseDropdownItemRender({ afterClick, item }: BaseDropdownItemRenderProps) {\n function onClick() {\n if (item.disabled) {\n return;\n }\n void item.handler().then(() => {\n afterClick();\n });\n }\n\n return (\n <div className=\"wallet-ui-base-dropdown-item\" data-part=\"item\" onClick={onClick}>\n {item.leftSection ? (\n <span className=\"wallet-ui-base-dropdown-item-left-section\">{item.leftSection}</span>\n ) : null}\n {item.label}\n {item.rightSection ? (\n <span className=\"wallet-ui-base-dropdown-item-right-section\">{item.rightSection}</span>\n ) : null}\n </div>\n );\n}\n\nexport function BaseDropdownChevronDown(props: HTMLAttributes<SVGElement> & { size?: number }) {\n return (\n <svg\n xmlns=\"http://www.w3.org/2000/svg\"\n width={props.size ?? 24}\n height={props.size ?? 24}\n viewBox=\"0 0 24 24\"\n fill=\"none\"\n stroke=\"currentColor\"\n strokeWidth=\"2\"\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n {...props}\n >\n <path d=\"m6 9 6 6 6-6\" />\n </svg>\n );\n}\n","import React from 'react';\n\nimport { WalletUiSize } from './types/wallet-ui-size';\nimport { WalletUiSvg } from './types/wallet-ui-svg';\n\nexport interface BaseSvgProps extends WalletUiSvg {\n size: WalletUiSize;\n sizes: { [key: string]: number };\n viewBox: string;\n}\n\nexport function BaseSvg({ sizes = {}, ...props }: BaseSvgProps) {\n const size = props.size ? sizes[props.size] : 12;\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" width={size} height={size} {...props}>\n {props.children}\n </svg>\n );\n}\n","import React from 'react';\n\nimport { BaseSvg, BaseSvgProps } from './base-svg';\n\nexport function WalletUiIconClose({ size = 'md', ...props }: Omit<BaseSvgProps, 'sizes' | 'viewBox'>) {\n return (\n <BaseSvg\n size={size}\n sizes={{ lg: 16, md: 12, sm: 8 }}\n fill=\"none\"\n stroke=\"currentColor\"\n strokeWidth=\"3\"\n viewBox=\"0 0 14 14\"\n {...props}\n >\n <path d=\"M14 12.461 8.3 6.772l5.234-5.233L12.006 0 6.772 5.234 1.54 0 0 1.539l5.234 5.233L0 12.006l1.539 1.528L6.772 8.3l5.69 5.7L14 12.461z\"></path>\n </BaseSvg>\n );\n}\n","import { Portal } from '@zag-js/react';\nimport React from 'react';\n\nimport { BaseButton, BaseButtonProps } from './base-button';\nimport { WalletUiSize } from './types/wallet-ui-size';\nimport { BaseModalControl } from './use-base-modal';\nimport { WalletUiIconClose } from './wallet-ui-icon-close';\n\nexport interface BaseModalProps {\n buttonLabel?: React.ReactNode;\n buttonProps?: Partial<BaseButtonProps>;\n children: React.ReactNode;\n description?: React.ReactNode;\n modal: BaseModalControl;\n size?: WalletUiSize;\n title?: React.ReactNode;\n}\n\nexport function BaseModal({ modal, buttonLabel, buttonProps = {}, size = 'md', ...props }: BaseModalProps) {\n const api = modal.api;\n return (\n <>\n {buttonLabel ? (\n <BaseButton label={buttonLabel} size={size} {...buttonProps} {...api.getTriggerProps()} />\n ) : null}\n {api.open && (\n <Portal>\n <div {...api.getBackdropProps()} />\n <div {...api.getPositionerProps()}>\n <div {...api.getContentProps()} className={size}>\n <header>\n <button {...api.getCloseTriggerProps()}>\n <WalletUiIconClose size={size} />\n </button>\n </header>\n {props.description ? <p {...api.getDescriptionProps()}>{props.description}</p> : null}\n <main>{props.children}</main>\n </div>\n </div>\n </Portal>\n )}\n </>\n );\n}\n","import * as menu from '@zag-js/menu';\nimport { normalizeProps, useMachine } from '@zag-js/react';\nimport { useId } from 'react';\n\nexport type BaseDropdownApi = ReturnType<typeof menu.connect>;\n\nexport interface BaseDropdownControl {\n api: BaseDropdownApi;\n close: () => void;\n open: () => void;\n}\n\nexport function useBaseDropdown(): BaseDropdownControl {\n const service = useMachine(menu.machine, { id: useId() });\n const api = menu.connect(service, normalizeProps);\n\n return {\n api,\n close: () => service.send({ type: 'CLOSE' }),\n open: () => service.send({ type: 'OPEN' }),\n };\n}\n","import * as dialog from '@zag-js/dialog';\nimport { normalizeProps, useMachine } from '@zag-js/react';\nimport { useId } from 'react';\n\nexport type BaseModalApi = ReturnType<typeof dialog.connect>;\n\nexport interface BaseModalControl {\n api: BaseModalApi;\n close: () => void;\n open: () => void;\n}\n\nexport function useBaseModal(): BaseModalControl {\n const service = useMachine(dialog.machine, { id: useId(), modal: true });\n const api = dialog.connect(service, normalizeProps);\n\n return {\n api,\n close: () => service.send({ type: 'CLOSE' }),\n open: () => service.send({ type: 'OPEN' }),\n };\n}\n","import { SolanaCluster, SolanaClusterId } from '@wallet-ui/core';\nimport { createContext, ReactNode } from 'react';\n\nexport interface WalletUiClusterContextProviderProps {\n clusters: SolanaCluster[];\n render: (props: WalletUiClusterContextValue) => ReactNode;\n storageKey?: string;\n}\n\nexport interface WalletUiClusterContextValue {\n cluster: SolanaCluster;\n clusters: SolanaCluster[];\n\n setCluster(cluster: SolanaClusterId): void;\n}\n\nexport const WalletUiClusterContext = createContext<WalletUiClusterContextValue>({} as WalletUiClusterContextValue);\n","import { useContext } from 'react';\n\nimport { WalletUiClusterContext } from './wallet-ui-cluster-context';\n\nexport function useWalletUiCluster() {\n return useContext(WalletUiClusterContext);\n}\n","import { UiWallet } from '@wallet-standard/react';\nimport React from 'react';\n\nimport { WalletUiImg } from './types/wallet-ui-img';\nimport { WalletUiSize } from './types/wallet-ui-size';\n\nexport interface WalletUiIconProps extends WalletUiImg {\n size?: WalletUiSize;\n wallet?: Pick<UiWallet, 'icon' | 'name'>;\n}\n\nexport function WalletUiIcon({ className, size, wallet, ...props }: WalletUiIconProps) {\n if (!wallet) {\n return null;\n }\n\n return (\n <img\n src={wallet.icon}\n alt={wallet.name}\n className={`wallet-ui-list-icon ${size ?? 'md'} ${className ?? ''}`}\n {...props}\n />\n );\n}\n","import { UiWallet, UiWalletAccount } from '@wallet-standard/react';\nimport React, { useMemo } from 'react';\n\nimport { BaseButtonProps } from './base-button';\nimport { BaseDropdownItem, BaseDropdownItemType } from './base-dropdown';\nimport { WalletUiSize } from './types/wallet-ui-size';\nimport { BaseDropdownControl, useBaseDropdown } from './use-base-dropdown';\nimport { useWalletUi } from './use-wallet-ui';\nimport { WalletUiIcon } from './wallet-ui-icon';\n\nfunction getDropdownItemsWallets({\n wallets,\n connect,\n size,\n}: {\n connect: (wallet: UiWalletAccount) => void;\n size: WalletUiSize;\n wallets: UiWallet[];\n}): BaseDropdownItem[] {\n return wallets.length\n ? wallets.map(wallet => ({\n handler: async () => {\n // TODO: Add support for multiple accounts, properly handle no accounts\n const account = wallet.accounts.length > 0 ? wallet.accounts[0] : undefined;\n if (!account) {\n return;\n }\n connect(account);\n await Promise.resolve();\n },\n label: wallet.name,\n leftSection: <WalletUiIcon wallet={wallet} size={size} />,\n type: BaseDropdownItemType.WalletConnect,\n value: wallet.name,\n wallet,\n }))\n : [\n {\n handler: async () => {\n window.open('https://solana.com/solana-wallets', '_blank');\n await Promise.resolve();\n },\n label: \"You'll need a wallet on Solana to continue\",\n type: BaseDropdownItemType.WalletNeeded,\n value: 'no-wallets',\n },\n ];\n}\n\nexport function useWalletUiDropdown({ size = 'md' }: { size?: WalletUiSize } = {}): {\n buttonProps: BaseButtonProps;\n connected: boolean;\n dropdown: BaseDropdownControl;\n items: BaseDropdownItem[];\n} {\n const dropdown = useBaseDropdown();\n\n const { account, connect, copy, disconnect, connected, wallet, wallets } = useWalletUi();\n\n const itemsWallets = useMemo(() => {\n return getDropdownItemsWallets({ connect, size, wallets });\n }, [wallets, size, connect]);\n\n const itemsConnected: BaseDropdownItem[] = useMemo(\n () => [\n {\n handler: async () => {\n copy();\n void (await Promise.resolve());\n },\n label: 'Copy Address',\n type: BaseDropdownItemType.WalletCopy,\n value: 'copy',\n },\n {\n handler: async () => {\n disconnect();\n dropdown.close();\n await Promise.resolve();\n },\n label: 'Disconnect',\n type: BaseDropdownItemType.WalletDisconnect,\n value: 'disconnect',\n },\n ...itemsWallets,\n ],\n [connect, copy, disconnect, dropdown, size, wallets],\n );\n const items = useMemo(() => {\n return connected ? itemsConnected : itemsWallets;\n }, [connected, itemsConnected, itemsWallets]);\n\n const buttonProps: BaseButtonProps = useMemo(() => {\n return {\n label: connected ? ((account ? ellipsify(account.address) : wallet?.name) ?? 'Connected') : 'Select Wallet',\n leftSection: connected ? <WalletUiIcon size={size} wallet={wallet} /> : undefined,\n };\n }, [account, connected, size, wallet]);\n\n return {\n buttonProps,\n connected,\n dropdown,\n items,\n };\n}\n\nexport function ellipsify(str = '', len = 4, delimiter = '..') {\n const strLen = str.length;\n const limit = len * 2 + delimiter.length;\n\n return strLen >= limit ? str.substring(0, len) + delimiter + str.substring(strLen - len, strLen) : str;\n}\n","import { SolanaClient, SolanaClientUrlOrMoniker } from 'gill';\nimport { createContext, ReactNode } from 'react';\n\nexport interface WalletUiSolanaClientContextProviderProps {\n children: ReactNode;\n urlOrMoniker: SolanaClientUrlOrMoniker;\n}\n\nexport const WalletUiSolanaClientContext = createContext<SolanaClient>({} as SolanaClient);\n","import { useContext } from 'react';\n\nimport { WalletUiSolanaClientContext } from './wallet-ui-solana-client-context';\n\nexport function useWalletUiSolanaClient() {\n return useContext(WalletUiSolanaClientContext);\n}\n","import { useWallets } from '@wallet-standard/react';\nimport { useMemo } from 'react';\n\nexport function useWalletUiWallets() {\n const readonlyWallets = useWallets();\n return useMemo(\n () =>\n readonlyWallets\n .filter(wallet => wallet.chains.some(i => i.startsWith('solana:')))\n .sort((a, b) => a.name.localeCompare(b.name)),\n [readonlyWallets],\n );\n}\n","import {\n getUiWalletAccountStorageKey,\n UiWallet,\n UiWalletAccount,\n uiWalletAccountBelongsToUiWallet,\n uiWalletAccountsAreSame,\n useWallets,\n} from '@wallet-standard/react';\nimport React, { useEffect, useMemo, useState } from 'react';\n\nimport { useWalletUiCluster } from './use-wallet-ui-cluster';\nimport { WalletUiAccountContext } from './wallet-ui-account-context';\n\nconst STORAGE_KEY = 'wallet-ui:selected-wallet-account';\n\nlet wasSetterInvoked = false;\n\nfunction getSavedWalletAccount(wallets: readonly UiWallet[], storageKey: string): UiWalletAccount | undefined {\n if (wasSetterInvoked) {\n // After the user makes an explicit choice of wallet, stop trying to auto-select the\n // saved wallet, if and when it appears.\n return;\n }\n const savedWalletNameAndAddress = localStorage.getItem(storageKey);\n if (!savedWalletNameAndAddress || typeof savedWalletNameAndAddress !== 'string') {\n return;\n }\n const [savedWalletName, savedAccountAddress] = savedWalletNameAndAddress.split(':');\n if (!savedWalletName || !savedAccountAddress) {\n return;\n }\n for (const wallet of wallets) {\n if (wallet.name === savedWalletName) {\n for (const account of wallet.accounts) {\n if (account.address === savedAccountAddress) {\n return account;\n }\n }\n }\n }\n}\n\n/**\n * Saves the selected wallet account's storage key to the browser's local storage. In future\n * sessions it will try to return that same wallet account, or at least one from the same brand of\n * wallet if the wallet from which it came is still in the Wallet Standard registry.\n */\nexport function WalletUiAccountContextProvider({\n children,\n storageKey = STORAGE_KEY,\n}: {\n children: React.ReactNode;\n storageKey?: string;\n}) {\n const { cluster } = useWalletUiCluster();\n const wallets = useWallets();\n const [account, setAccountInternal] = useState<UiWalletAccount | undefined>(() =>\n getSavedWalletAccount(wallets, storageKey),\n );\n\n function setAccount(setStateAction: React.SetStateAction<UiWalletAccount | undefined>) {\n setAccountInternal(prevAccount => {\n wasSetterInvoked = true;\n const nextWalletAccount =\n typeof setStateAction === 'function' ? setStateAction(prevAccount) : setStateAction;\n const accountKey = nextWalletAccount ? getUiWalletAccountStorageKey(nextWalletAccount) : undefined;\n if (accountKey) {\n localStorage.setItem(storageKey, accountKey);\n } else {\n localStorage.removeItem(storageKey);\n }\n return nextWalletAccount;\n });\n }\n\n useEffect(() => {\n const savedWalletAccount = getSavedWalletAccount(wallets, storageKey);\n if (savedWalletAccount) {\n setAccountInternal(savedWalletAccount);\n }\n }, [wallets]);\n const walletAccount = useMemo(() => {\n if (account) {\n for (const uiWallet of wallets) {\n for (const uiWalletAccount of uiWallet.accounts) {\n if (uiWalletAccountsAreSame(account, uiWalletAccount)) {\n return uiWalletAccount;\n }\n }\n if (uiWalletAccountBelongsToUiWallet(account, uiWallet) && uiWallet.accounts[0]) {\n // If the selected account belongs to this connected wallet, at least, then\n // select one of its accounts.\n return uiWallet.accounts[0];\n }\n }\n }\n }, [account, wallets]);\n useEffect(() => {\n // If there is a selected wallet account but the wallet to which it belongs has since\n // disconnected, clear the selected wallet.\n if (account && !walletAccount) {\n setAccountInternal(undefined);\n }\n }, [account, walletAccount]);\n\n const wallet = useMemo(() => {\n if (!walletAccount) {\n return undefined;\n }\n for (const uiWallet of wallets) {\n for (const uiWalletAccount of uiWallet.accounts) {\n if (uiWalletAccountsAreSame(walletAccount, uiWalletAccount)) {\n return uiWallet;\n }\n }\n if (uiWalletAccountBelongsToUiWallet(walletAccount, uiWallet) && uiWallet.accounts[0]) {\n // If the selected account belongs to this connected wallet, at least, then\n // select one of its accounts.\n return uiWallet;\n }\n }\n }, [walletAccount, wallets]);\n\n // Expose the error boundary reset keys to the context\n const accountKeys = useMemo(() => {\n if (!account) {\n return [];\n }\n return [cluster.id, getUiWalletAccountStorageKey(account)].filter(Boolean);\n }, [account]);\n return (\n <WalletUiAccountContext.Provider\n value={useMemo(\n () => ({\n account: walletAccount,\n accountKeys,\n setAccount,\n wallet,\n }),\n [walletAccount, wallet, accountKeys],\n )}\n >\n {children}\n </WalletUiAccountContext.Provider>\n );\n}\n","import { useCallback, useState } from 'react';\n\nexport function useLocalStorage<T>(key: string, initialValue: T) {\n // State to store our value\n const [storedValue, setStoredValue] = useState<T>(() => {\n try {\n // Check if we're on the client side\n if (typeof window === 'undefined') {\n return initialValue;\n }\n\n const item = window.localStorage.getItem(key);\n // For wallet-related data, validate the stored value\n if (key.includes('wallet') || key.includes('account')) {\n // Return initial value if stored data might be stale\n return initialValue;\n }\n return item ? JSON.parse(item) : initialValue;\n } catch (error) {\n console.warn(`Error reading localStorage key \"${key}\":`, error);\n return initialValue;\n }\n });\n\n // Return a wrapped version of useState's setter function that persists the new value to localStorage\n const setValue = useCallback(\n (value: T | ((val: T) => T)) => {\n try {\n // Allow value to be a function so we have same API as useState\n const valueToStore = value instanceof Function ? value(storedValue) : value;\n\n // Save state\n setStoredValue(valueToStore);\n\n // Save to localStorage\n if (typeof window !== 'undefined') {\n if (valueToStore === undefined || valueToStore === null) {\n window.localStorage.removeItem(key);\n } else {\n window.localStorage.setItem(key, JSON.stringify(valueToStore));\n }\n }\n } catch (error) {\n console.warn(`Error setting localStorage key \"${key}\":`, error);\n }\n },\n [key, storedValue],\n );\n\n return [storedValue, setValue] as const;\n}\n","import { SolanaCluster, SolanaClusterId } from '@wallet-ui/core';\nimport React, { useMemo } from 'react';\n\nimport { useLocalStorage } from './use-local-storage';\nimport {\n WalletUiClusterContext,\n WalletUiClusterContextProviderProps,\n WalletUiClusterContextValue,\n} from './wallet-ui-cluster-context';\n\nexport function WalletUiClusterContextProvider({\n clusters,\n render,\n storageKey = '__wallet-ui:selected-cluster',\n}: WalletUiClusterContextProviderProps) {\n const [clusterId, setClusterId] = useLocalStorage(storageKey, 'solana:devnet');\n if (!clusters.length) {\n throw new Error('No clusters provided');\n }\n const cluster = useMemo<SolanaCluster>(() => {\n for (const cluster of clusters) {\n if (cluster.id === clusterId) {\n return cluster;\n }\n }\n return clusters[0];\n }, [clusterId, clusters]);\n\n const value: WalletUiClusterContextValue = {\n cluster,\n clusters,\n setCluster: (cluster: SolanaClusterId) => {\n localStorage.setItem(storageKey, cluster);\n setClusterId(cluster);\n },\n };\n\n return <WalletUiClusterContext.Provider value={value}>{render(value)}</WalletUiClusterContext.Provider>;\n}\n","import { UiWalletAccount } from '@wallet-standard/react';\nimport { handleCopyText } from '@wallet-ui/core';\nimport React from 'react';\n\nimport { useWalletUiAccount } from './use-wallet-ui-account';\nimport { useWalletUiSolanaClient } from './use-wallet-ui-solana-client';\nimport { useWalletUiWallets } from './use-wallet-ui-wallets';\nimport { WalletUiContext, WalletUiContextProviderProps, WalletUiProviderContextValue } from './wallet-ui-context';\n\nexport function WalletUiContextProvider({ children, size = 'md' }: WalletUiContextProviderProps) {\n const { account, setAccount, wallet } = useWalletUiAccount();\n const wallets = useWalletUiWallets();\n const client = useWalletUiSolanaClient();\n const walletHasAccounts = Boolean(wallet && wallet?.accounts.length > 0);\n\n function connect(account: UiWalletAccount) {\n setAccount(account);\n }\n\n function disconnect() {\n setAccount(undefined);\n }\n\n function copy() {\n if (!account) {\n return;\n }\n handleCopyText(account.address);\n }\n\n const value: WalletUiProviderContextValue = {\n account,\n client,\n connect,\n connected: walletHasAccounts,\n copy,\n disconnect,\n size,\n wallet,\n wallets,\n };\n\n return <WalletUiContext.Provider value={value}>{children}</WalletUiContext.Provider>;\n}\n","import { createSolanaClient, SolanaClient } from 'gill';\nimport React, { useMemo } from 'react';\n\nimport {\n WalletUiSolanaClientContext,\n WalletUiSolanaClientContextProviderProps,\n} from './wallet-ui-solana-client-context';\n\nexport function WalletUiSolanaClientContextProvider({\n children,\n urlOrMoniker,\n}: WalletUiSolanaClientContextProviderProps) {\n return (\n <WalletUiSolanaClientContext.Provider\n value={useMemo(() => createSolanaClient({ urlOrMoniker }) as SolanaClient, [urlOrMoniker])}\n >\n {children}\n </WalletUiSolanaClientContext.Provider>\n );\n}\n","import { SolanaCluster } from '@wallet-ui/core';\nimport React from 'react';\n\nimport { WalletUiAccountContextProvider } from './wallet-ui-account-context-provider';\nimport { WalletUiClusterContextProvider } from './wallet-ui-cluster-context-provider';\nimport { WalletUiContextProviderProps } from './wallet-ui-context';\nimport { WalletUiContextProvider } from './wallet-ui-context-provider';\nimport { WalletUiSolanaClientContextProvider } from './wallet-ui-solana-client-context-provider';\n\nexport interface WalletUiConfig extends Omit<WalletUiContextProviderProps, 'children'> {\n clusterStorageKey?: string;\n clusters: SolanaCluster[];\n selectedAccountStorageKey?: string;\n}\n\nexport function createWalletUiConfig(props: WalletUiConfig): WalletUiConfig {\n return { ...props };\n}\n\nexport interface WalletUiProps {\n children: React.ReactNode;\n config: WalletUiConfig;\n}\n\nexport function WalletUi({\n children,\n config: { clusters, clusterStorageKey, selectedAccountStorageKey, ...config },\n}: WalletUiProps) {\n return (\n <React.Fragment>\n <WalletUiClusterContextProvider\n clusters={clusters}\n storageKey={clusterStorageKey}\n render={({ cluster }) => {\n return (\n <WalletUiSolanaClientContextProvider urlOrMoniker={cluster.urlOrMoniker}>\n <WalletUiAccountContextProvider storageKey={selectedAccountStorageKey}>\n <WalletUiContextProvider {...config}>{children}</WalletUiContextProvider>\n </WalletUiAccountContextProvider>\n </WalletUiSolanaClientContextProvider>\n );\n }}\n />\n </React.Fragment>\n );\n}\n","import React from 'react';\n\nimport { BaseButton, BaseButtonProps } from './base-button';\nimport { WalletUiSize } from './types/wallet-ui-size';\n\nexport interface WalletUiButtonProps extends Omit<BaseButtonProps, 'label'> {\n size?: WalletUiSize;\n}\n\nexport function WalletUiButton({ ...props }: WalletUiButtonProps) {\n return <BaseButton {...props} label={'CLICK'} />;\n}\n","import React from 'react';\n\nimport { BaseDropdown, BaseDropdownItemType, BaseDropdownProps } from './base-dropdown';\nimport { WalletUiSize } from './types/wallet-ui-size';\nimport { useBaseDropdown } from './use-base-dropdown';\nimport { useWalletUiCluster } from './use-wallet-ui-cluster';\n\nexport interface WalletUiClusterDropdownProps\n extends Omit<BaseDropdownProps, 'buttonProps' | 'dropdown' | 'items' | 'label'> {\n buttonProps?: Partial<BaseDropdownProps['buttonProps']>;\n size?: WalletUiSize;\n}\n\nexport function WalletUiClusterDropdown({ buttonProps, size = 'md', ...props }: WalletUiClusterDropdownProps) {\n const dropdown = useBaseDropdown();\n const { cluster, clusters, setCluster } = useWalletUiCluster();\n return (\n <BaseDropdown\n buttonProps={{ ...buttonProps, label: cluster.label, size: size }}\n items={clusters.map(cluster => ({\n handler: async () => {\n setCluster(cluster.id);\n await Promise.resolve();\n },\n label: cluster.label,\n type: BaseDropdownItemType.Item,\n value: cluster.id,\n }))}\n dropdown={dropdown}\n {...props}\n />\n );\n}\n","import React from 'react';\n\nimport { BaseDropdown } from './base-dropdown';\nimport { WalletUiSize } from './types/wallet-ui-size';\nimport { useWalletUiDropdown } from './use-wallet-ui-dropdown';\n\nexport interface WalletUiDropdownProps {\n label?: string;\n size?: WalletUiSize;\n}\n\nexport function WalletUiDropdown({ size = 'md', ...props }: WalletUiDropdownProps) {\n const { buttonProps, items, dropdown } = useWalletUiDropdown({ size });\n return <BaseDropdown {...props} buttonProps={{ ...buttonProps, size }} items={items} dropdown={dropdown} />;\n}\n","import React from 'react';\n\nimport { BaseSvg, BaseSvgProps } from './base-svg';\n\nexport function WalletUiIconNoWallet({ size, ...props }: Omit<BaseSvgProps, 'sizes' | 'viewBox'>) {\n return (\n <BaseSvg size={size} sizes={{ lg: 125, md: 100, sm: 75 }} fill=\"none\" viewBox=\"0 0 97 96\" {...props}>\n <circle cx=\"48.5\" cy=\"48\" r=\"48\" fill=\"url(#paint0_linear_880_5115)\" fillOpacity=\"0.1\"></circle>\n <circle\n cx=\"48.5\"\n cy=\"48\"\n r=\"47\"\n stroke=\"url(#paint1_linear_880_5115)\"\n strokeOpacity=\"0.4\"\n strokeWidth=\"2\"\n ></circle>\n <g clipPath=\"url(#clip0_880_5115)\">\n <path\n d=\"M65.5769 28.1523H31.4231C27.6057 28.1523 24.5 31.258 24.5 35.0754V60.9215C24.5 64.7389 27.6057 67.8446 31.4231 67.8446H65.5769C69.3943 67.8446 72.5 64.7389 72.5 60.9215V35.0754C72.5 31.258 69.3943 28.1523 65.5769 28.1523ZM69.7308 52.1523H59.5769C57.2865 52.1523 55.4231 50.289 55.4231 47.9985C55.4231 45.708 57.2864 43.8446 59.5769 43.8446H69.7308V52.1523ZM69.7308 41.0754H59.5769C55.7595 41.0754 52.6539 44.1811 52.6539 47.9985C52.6539 51.8159 55.7595 54.9215 59.5769 54.9215H69.7308V60.9215C69.7308 63.2119 67.8674 65.0754 65.5769 65.0754H31.4231C29.1327 65.0754 27.2692 63.212 27.2692 60.9215V35.0754C27.2692 32.785 29.1326 30.9215 31.4231 30.9215H65.5769C67.8673 30.9215 69.7308 32.7849 69.7308 35.0754V41.0754Z\"\n fill=\"url(#paint2_linear_880_5115)\"\n ></path>\n <path\n d=\"M61.4231 46.6172H59.577C58.8123 46.6172 58.1924 47.2371 58.1924 48.0018C58.1924 48.7665 58.8123 49.3863 59.577 49.3863H61.4231C62.1878 49.3863 62.8077 48.7664 62.8077 48.0018C62.8077 47.2371 62.1878 46.6172 61.4231 46.6172Z\"\n fill=\"url(#paint3_linear_880_5115)\"\n ></path>\n </g>\n <defs>\n <linearGradient\n id=\"paint0_linear_880_5115\"\n x1=\"3.41664\"\n y1=\"98.0933\"\n x2=\"103.05\"\n y2=\"8.42498\"\n gradientUnits=\"userSpaceOnUse\"\n >\n <stop stopColor=\"#9945FF\"></stop>\n <stop offset=\"0.14\" stopColor=\"#8A53F4\"></stop>\n <stop offset=\"0.42\" stopColor=\"#6377D6\"></stop>\n <stop offset=\"0.79\" stopColor=\"#24B0A7\"></stop>\n <stop offset=\"0.99\" stopColor=\"#00D18C\"></stop>\n <stop offset=\"1\" stopColor=\"#00D18C\"></stop>\n </linearGradient>\n <linearGradient\n id=\"paint1_linear_880_5115\"\n x1=\"3.41664\"\n y1=\"98.0933\"\n x2=\"103.05\"\n y2=\"8.42498\"\n gradientUnits=\"userSpaceOnUse\"\n >\n <stop stopColor=\"#9945FF\"></stop>\n <stop offset=\"0.14\" stopColor=\"#8A53F4\"></stop>\n <stop offset=\"0.42\" stopColor=\"#6377D6\"></stop>\n <stop offset=\"0.79\" stopColor=\"#24B0A7\"></stop>\n <stop offset=\"0.99\" stopColor=\"#00D18C\"></stop>\n <stop offset=\"1\" stopColor=\"#00D18C\"></stop>\n </linearGradient>\n <linearGradient\n id=\"paint2_linear_880_5115\"\n x1=\"25.9583\"\n y1=\"68.7101\"\n x2=\"67.2337\"\n y2=\"23.7879\"\n gradientUnits=\"userSpaceOnUse\"\n >\n <stop stopColor=\"#9945FF\"></stop>\n <stop offset=\"0.14\" stopColor=\"#8A53F4\"></stop>\n <stop offset=\"0.42\" stopColor=\"#6377D6\"></stop>\n <stop offset=\"0.79\" stopColor=\"#24B0A7\"></stop>\n <stop offset=\"0.99\" stopColor=\"#00D18C\"></stop>\n <stop offset=\"1\" stopColor=\"#00D18C\"></stop>\n </linearGradient>\n <linearGradient\n id=\"paint3_linear_880_5115\"\n x1=\"58.3326\"\n y1=\"49.4467\"\n x2=\"61.0002\"\n y2=\"45.4453\"\n gradientUnits=\"userSpaceOnUse\"\n >\n <stop stopColor=\"#9945FF\"></stop>\n <stop offset=\"0.14\" stopColor=\"#8A53F4\"></stop>\n <stop offset=\"0.42\" stopColor=\"#6377D6\"></stop>\n <stop offset=\"0.79\" stopColor=\"#24B0A7\"></stop>\n <stop offset=\"0.99\" stopColor=\"#00D18C\"></stop>\n <stop offset=\"1\" stopColor=\"#00D18C\"></stop>\n </linearGradient>\n <clipPath id=\"clip0_880_5115\">\n <rect width=\"48\" height=\"48\" fill=\"white\" transform=\"translate(24.5 24)\"></rect>\n </clipPath>\n </defs>\n </BaseSvg>\n );\n}\n","import { UiWallet } from '@wallet-standard/react';\nimport React from 'react';\n\nimport { WalletUiSize } from './types/wallet-ui-size';\n\nexport interface WalletUiLabelProps\n extends React.DetailedHTMLProps<React.HTMLAttributes<HTMLSpanElement>, HTMLSpanElement> {\n size?: WalletUiSize;\n wallet?: Pick<UiWallet, 'name'>;\n}\n\nexport function WalletUiLabel({ className, size, wallet, ...props }: WalletUiLabelProps) {\n if (!wallet) {\n return null;\n }\n\n return (\n <span className={`wallet-ui-list-label ${size ?? 'md'} ${className ?? ''}`} {...props}>\n {wallet.name}\n </span>\n );\n}\n","import { UiWallet, UiWalletAccount } from '@wallet-standard/react';\nimport React from 'react';\n\nimport { WalletUiButton } from './types/wallet-ui-button';\nimport { WalletUiSize } from './types/wallet-ui-size';\nimport { WalletUiIcon } from './wallet-ui-icon';\nimport { WalletUiLabel } from './wallet-ui-label';\n\nexport interface WalletUiListButtonProps extends Omit<WalletUiButton, 'onClick'> {\n select?: (wallet: UiWalletAccount) => Promise<void>;\n size?: WalletUiSize;\n wallet: UiWallet;\n}\n\nexport function WalletUiListButton({ className, select, size = 'md', wallet, ...props }: WalletUiListButtonProps) {\n const [pending, setPending] = React.useState(false);\n\n function handleSelect() {\n if (!select) {\n return;\n }\n setPending(true);\n // TODO: Add support for multiple accounts, properly handle no accounts\n const account = wallet.accounts.length > 0 ? wallet.accounts[0] : undefined;\n if (!account) {\n return;\n }\n void select(account).finally(() => setPending(false));\n }\n\n return (\n <button\n disabled={pending}\n className={`wallet-ui-list-button ${size} ${pending ? 'wallet-ui-list-button-pending' : ''} ${className ?? ''}`}\n onClick={handleSelect}\n {...props}\n >\n <WalletUiIcon className=\"wallet-ui-list-button-icon\" wallet={wallet} size={size} />\n <WalletUiLabel className=\"wallet-ui-list-button-label\" wallet={wallet} size={size} />\n </button>\n );\n}\n","import { UiWallet, UiWalletAccount } from '@wallet-standard/react';\nimport React from 'react';\n\nimport { WalletUiDiv } from './types/wallet-ui-div';\nimport { WalletUiSize } from './types/wallet-ui-size';\nimport { WalletUiListButton } from './wallet-ui-list-button';\n\nexport interface WalletUiListProps extends WalletUiDiv {\n select?: (account: UiWalletAccount) => Promise<void>;\n size?: WalletUiSize;\n wallets: UiWallet[];\n}\n\nexport function WalletUiList({ className, select, size = 'md', wallets, ...props }: WalletUiListProps) {\n return (\n <div className={`wallet-ui-list ${size} ${className ?? ''}`} {...props}>\n {wallets.map(wallet => (\n <WalletUiListButton key={wallet.name} select={select} size={size} wallet={wallet} />\n ))}\n </div>\n );\n}\n","import { UiWallet, UiWalletAccount } from '@wallet-standard/react';\nimport React from 'react';\n\nimport { BaseModal, BaseModalProps } from './base-modal';\nimport { WalletUiSize } from './types/wallet-ui-size';\nimport { WalletUiList } from './wallet-ui-list';\n\nexport interface WalletUiModalProps extends Omit<BaseModalProps, 'children'> {\n select: (account: UiWalletAccount) => Promise<void>;\n size?: WalletUiSize;\n wallets: UiWallet[];\n}\n\nexport function WalletUiModal({ size = 'md', wallets, select, ...props }: WalletUiModalProps) {\n return (\n <BaseModal description=\"Connect a wallet on Solana to continue\" size={size} {...props}>\n <WalletUiList size={size} wallets={wallets} select={select} />\n </BaseModal>\n );\n}\n","import React from 'react';\n\nimport { BaseButton, BaseButtonProps } from './base-button';\nimport { BaseModalControl } from './use-base-modal';\n\nexport interface WalletUiModalTriggerProps extends Omit<BaseButtonProps, 'label'> {\n label?: string;\n modal: BaseModalControl;\n}\n\nexport function WalletUiModalTrigger({ label = 'Select Wallet', modal, ...props }: WalletUiModalTriggerProps) {\n return <BaseButton label={label} onClick={() => void modal.open()} {...props} />;\n}\n"]}
@@ -4,9 +4,9 @@ export * from '@wallet-standard/react';
4
4
  import { Portal, useMachine, normalizeProps } from '@zag-js/react';
5
5
  import * as menu from '@zag-js/menu';
6
6
  import * as dialog from '@zag-js/dialog';
7
- import { createSolanaClient } from 'gill';
8
7
  import { handleCopyText } from '@wallet-ui/core';
9
8
  export * from '@wallet-ui/core';
9
+ import { createSolanaClient } from 'gill';
10
10
  export * from '@solana/react';
11
11
  export * from '@solana/wallet-standard-features';
12
12
  export * from '@wallet-standard/core';
@@ -225,12 +225,6 @@ function useBaseModal() {
225
225
  open: () => service.send({ type: "OPEN" })
226
226
  };
227
227
  }
228
- var WalletUiSolanaClientContext = createContext({});
229
-
230
- // src/use-wallet-ui-solana-client.tsx
231
- function useWalletUiSolanaClient() {
232
- return useContext(WalletUiSolanaClientContext);
233
- }
234
228
  var WalletUiClusterContext = createContext({});
235
229
 
236
230
  // src/use-wallet-ui-cluster.tsx
@@ -336,6 +330,12 @@ function ellipsify(str = "", len = 4, delimiter = "..") {
336
330
  const limit = len * 2 + delimiter.length;
337
331
  return strLen >= limit ? str.substring(0, len) + delimiter + str.substring(strLen - len, strLen) : str;
338
332
  }
333
+ var WalletUiSolanaClientContext = createContext({});
334
+
335
+ // src/use-wallet-ui-solana-client.tsx
336
+ function useWalletUiSolanaClient() {
337
+ return useContext(WalletUiSolanaClientContext);
338
+ }
339
339
  function useWalletUiWallets() {
340
340
  const readonlyWallets = useWallets();
341
341
  return useMemo(
@@ -451,15 +451,6 @@ function WalletUiAccountContextProvider({
451
451
  children
452
452
  );
453
453
  }
454
- function WalletUiClientContextProvider({ children, urlOrMoniker }) {
455
- return /* @__PURE__ */ React19.createElement(
456
- WalletUiSolanaClientContext.Provider,
457
- {
458
- value: useMemo(() => createSolanaClient({ urlOrMoniker }), [urlOrMoniker])
459
- },
460
- children
461
- );
462
- }
463
454
  function useLocalStorage(key, initialValue) {
464
455
  const [storedValue, setStoredValue] = useState(() => {
465
456
  try {
@@ -555,6 +546,18 @@ function WalletUiContextProvider({ children, size = "md" }) {
555
546
  };
556
547
  return /* @__PURE__ */ React19.createElement(WalletUiContext.Provider, { value }, children);
557
548
  }
549
+ function WalletUiSolanaClientContextProvider({
550
+ children,
551
+ urlOrMoniker
552
+ }) {
553
+ return /* @__PURE__ */ React19.createElement(
554
+ WalletUiSolanaClientContext.Provider,
555
+ {
556
+ value: useMemo(() => createSolanaClient({ urlOrMoniker }), [urlOrMoniker])
557
+ },
558
+ children
559
+ );
560
+ }
558
561
 
559
562
  // src/wallet-ui.tsx
560
563
  function createWalletUiConfig(props) {
@@ -570,7 +573,7 @@ function WalletUi({
570
573
  clusters,
571
574
  storageKey: clusterStorageKey,
572
575
  render: ({ cluster }) => {
573
- return /* @__PURE__ */ React19.createElement(WalletUiClientContextProvider, { urlOrMoniker: cluster.urlOrMoniker }, /* @__PURE__ */ React19.createElement(WalletUiAccountContextProvider, { storageKey: selectedAccountStorageKey }, /* @__PURE__ */ React19.createElement(WalletUiContextProvider, { ...config }, children)));
576
+ return /* @__PURE__ */ React19.createElement(WalletUiSolanaClientContextProvider, { urlOrMoniker: cluster.urlOrMoniker }, /* @__PURE__ */ React19.createElement(WalletUiAccountContextProvider, { storageKey: selectedAccountStorageKey }, /* @__PURE__ */ React19.createElement(WalletUiContextProvider, { ...config }, children)));
574
577
  }
575
578
  }
576
579
  ));
@@ -735,6 +738,6 @@ function WalletUiModalTrigger({ label = "Select Wallet", modal, ...props }) {
735
738
  return /* @__PURE__ */ React19.createElement(BaseButton, { label, onClick: () => void modal.open(), ...props });
736
739
  }
737
740
 
738
- export { BaseButton, BaseDropdown, BaseDropdownChevronDown, BaseDropdownItemType, BaseModal, BaseSvg, WalletUi, WalletUiButton, WalletUiClientContextProvider, WalletUiClusterContext, WalletUiClusterContextProvider, WalletUiClusterDropdown, WalletUiContext, WalletUiContextProvider, WalletUiDropdown, WalletUiIcon, WalletUiIconClose, WalletUiIconNoWallet, WalletUiLabel, WalletUiList, WalletUiListButton, WalletUiModal, WalletUiModalTrigger, WalletUiSolanaClientContext, createWalletUiConfig, ellipsify, useBaseDropdown, useBaseModal, useWalletUi, useWalletUiAccount, useWalletUiCluster, useWalletUiDropdown, useWalletUiSolanaClient, useWalletUiWallet, useWalletUiWallets };
741
+ export { BaseButton, BaseDropdown, BaseDropdownChevronDown, BaseDropdownItemType, BaseModal, BaseSvg, WalletUi, WalletUiAccountContext, WalletUiAccountContextProvider, WalletUiButton, WalletUiClusterContext, WalletUiClusterContextProvider, WalletUiClusterDropdown, WalletUiContext, WalletUiContextProvider, WalletUiDropdown, WalletUiIcon, WalletUiIconClose, WalletUiIconNoWallet, WalletUiLabel, WalletUiList, WalletUiListButton, WalletUiModal, WalletUiModalTrigger, WalletUiSolanaClientContext, WalletUiSolanaClientContextProvider, createWalletUiConfig, ellipsify, useBaseDropdown, useBaseModal, useWalletUi, useWalletUiAccount, useWalletUiCluster, useWalletUiDropdown, useWalletUiSolanaClient, useWalletUiWallet, useWalletUiWallets };
739
742
  //# sourceMappingURL=index.browser.mjs.map
740
743
  //# sourceMappingURL=index.browser.mjs.map