@tuwaio/nova-transactions 1.0.0-alpha.3.78a2a23 → 1.0.0-alpha.4.a67b545
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.
- package/README.md +81 -84
- package/dist/{TransactionsHistory-Bz0XaDda.d.cts → WalletInfoModal-DP-qlvYl.d.cts} +203 -253
- package/dist/{TransactionsHistory-Bz0XaDda.d.ts → WalletInfoModal-DP-qlvYl.d.ts} +203 -253
- package/dist/index.cjs +1 -1
- package/dist/index.cjs.map +1 -1
- package/dist/index.css +2 -21
- package/dist/index.d.cts +32 -126
- package/dist/index.d.ts +32 -126
- package/dist/index.js +1 -1
- package/dist/index.js.map +1 -1
- package/dist/providers/index.cjs +1 -1
- package/dist/providers/index.cjs.map +1 -1
- package/dist/providers/index.d.cts +4 -4
- package/dist/providers/index.d.ts +4 -4
- package/dist/providers/index.js +1 -1
- package/dist/providers/index.js.map +1 -1
- package/package.json +13 -15
package/dist/providers/index.cjs
CHANGED
@@ -1,2 +1,2 @@
|
|
1
|
-
'use strict';var react=require('react'),jsxRuntime=require('react/jsx-runtime'),novaCore=require('@tuwaio/nova-core'),pulsarCore=require('@tuwaio/pulsar-core'),reactToastify=require('react-toastify'),solid=require('@heroicons/react/24/solid'),reactWeb3Icons=require('@bgd-labs/react-web3-icons'),utils=require('@bgd-labs/react-web3-icons/dist/utils'),pulsarEvm=require('@tuwaio/pulsar-evm'),w=require('@radix-ui/react-dialog'),framerMotion=require('framer-motion'),Ot=require('dayjs'),Fe=require('dayjs/plugin/relativeTime'),zt=require('ethereum-blockies-base64'),viem=require('viem');function _interopDefault(e){return e&&e.__esModule?e:{default:e}}function _interopNamespace(e){if(e&&e.__esModule)return e;var n=Object.create(null);if(e){Object.keys(e).forEach(function(k){if(k!=='default'){var d=Object.getOwnPropertyDescriptor(e,k);Object.defineProperty(n,k,d.get?d:{enumerable:true,get:function(){return e[k]}});}})}n.default=e;return Object.freeze(n)}var w__namespace=/*#__PURE__*/_interopNamespace(w);var Ot__default=/*#__PURE__*/_interopDefault(Ot);var Fe__default=/*#__PURE__*/_interopDefault(Fe);var zt__default=/*#__PURE__*/_interopDefault(zt);var q={walletModal:{title:"Wallet & Transactions",header:{notConnected:"Wallet not connected",avatarAlt:"Avatar for"},history:{title:"Transactions History",connectWalletTitle:"Connect Wallet",connectWalletMessage:"Please connect your wallet to see your past activity.",noTransactionsTitle:"No Transactions Yet",noTransactionsMessage:"Once you interact with the app, your transaction history will appear here."}},toast:{openWalletInfo:"Open wallet info"},statuses:{pending:"Pending",success:"Success",failed:"Failed",reverted:"Reverted",replaced:"Replaced",unknown:"Unknown"},hashLabels:{gelato:"Gelato Task ID",safe:"Safe Tx Hash",original:"Original Tx Hash",replaced:"Replaced Tx Hash",default:"Tx Hash"},txInfo:{started:"Started",network:"Network"},txError:{title:"Error",copied:"Copied!"},trackingModal:{title:"Transaction Overview",processing:"Processing...",close:"Close",walletInfo:"Wallet Info",retry:"Retry",progressIndicator:{created:"Created",processing:"Processing",succeed:"Succeed"}},trackedTxButton:{loading:"Processing...",succeed:"Success",failed:"Failed",replaced:"Replaced"},actions:{copy:"Copy address",viewOnExplorer:"View on explorer",close:"Close",cancel:"Cancel",speedUp:"Speed up"}};var xt=react.createContext(q),vt=({labels:t,children:e})=>jsxRuntime.jsx(xt.Provider,{value:t,children:e}),u=()=>react.useContext(xt);function gt({label:t,hash:e,explorerUrl:r,variant:a="default",className:s}){let{isCopied:o,copy:i}=novaCore.useCopyToClipboard(),d=u(),c=novaCore.cn("flex items-center justify-between",a==="default"&&"text-sm",a==="compact"&&"text-xs",s),p=novaCore.cn("pr-1",a==="default"&&"font-bold text-[var(--tuwa-text-primary)]",a==="compact"&&"font-medium text-[var(--tuwa-text-secondary)]"),n=jsxRuntime.jsx("span",{className:"font-mono",children:novaCore.textCenterEllipsis(e,5,5)});return jsxRuntime.jsxs("div",{className:c,children:[t&&jsxRuntime.jsxs("span",{className:p,children:[t,":"]}),jsxRuntime.jsxs("div",{className:"flex items-center gap-x-2",children:[r?jsxRuntime.jsxs("a",{href:r,target:"_blank",rel:"noopener noreferrer",className:"flex items-center gap-x-1 text-[var(--tuwa-text-accent)] hover:underline",title:d.actions.viewOnExplorer,"aria-label":d.actions.viewOnExplorer,children:[n,jsxRuntime.jsx(solid.ArrowTopRightOnSquareIcon,{className:"h-4 w-4"})]}):n,jsxRuntime.jsx("button",{type:"button",onClick:()=>i(e),className:"cursor-pointer text-[var(--tuwa-text-tertiary)] transition-colors hover:text-[var(--tuwa-text-secondary)]",title:o?d.txError.copied:d.actions.copy,"aria-label":o?d.txError.copied:d.actions.copy,children:o?jsxRuntime.jsx(solid.CheckIcon,{className:"h-4 w-4 text-[var(--tuwa-success-icon)]"}):jsxRuntime.jsx(solid.DocumentDuplicateIcon,{className:"h-4 w-4"})})]})]})}var bt={[pulsarCore.TransactionStatus.Success]:{index:1,colorClass:"text-[var(--tuwa-success-text)]"},[pulsarCore.TransactionStatus.Failed]:{index:2,colorClass:"text-[var(--tuwa-error-text)]"},[pulsarCore.TransactionStatus.Replaced]:{index:3,colorClass:"text-[var(--tuwa-text-secondary)]"},default:{index:0,colorClass:"text-[var(--tuwa-text-primary)]"}};function A({txStatus:t,source:e,fallback:r,variant:a,className:s,applyColor:o=false}){let i=a==="title"?"text-sm font-semibold text-[var(--tuwa-text-primary)]":"mt-1 text-xs text-[var(--tuwa-text-secondary)]";if(typeof e=="string")return jsxRuntime.jsx("div",{className:novaCore.cn(i,s),children:e});if(Array.isArray(e)){let c=bt[t||"default"]||bt.default,p=e[c.index],n=o?c.colorClass:"";return jsxRuntime.jsx("div",{className:novaCore.cn(i,n,s),children:p})}return r?jsxRuntime.jsx("div",{className:novaCore.cn(i,s),children:r}):null}function ht({closeToast:t}){let e=u();return jsxRuntime.jsx("button",{type:"button",onClick:t,"aria-label":e.actions.close,title:e.actions.close,className:"absolute top-2 right-2 cursor-pointer rounded-full p-1 text-[var(--tuwa-text-tertiary)] transition-colors hover:bg-[var(--tuwa-bg-muted)] hover:text-[var(--tuwa-text-primary)]",children:jsxRuntime.jsx(solid.XMarkIcon,{className:"h-5 w-5"})})}function U({tx:t,adapters:e,transactionsPool:r,variant:a="toast",className:s,renderHashLink:o}){let i=u();if(t?.adapter!==pulsarCore.TransactionAdapter.EVM)return null;let d=!!t.replacedTxHash,c=a==="toast"?"mt-2 flex w-full flex-col gap-y-2 border-t border-[var(--tuwa-border-primary)] pt-2":"flex w-full flex-col gap-y-2",p=m=>o?o(m):jsxRuntime.jsx(gt,{...m}),n=pulsarCore.selectAdapterByKey({adapterKey:t.adapter,adapters:e});return jsxRuntime.jsxs("div",{className:novaCore.cn(c,s),children:[t.tracker===pulsarEvm.TransactionTracker.Gelato&&p({label:i.hashLabels.gelato,hash:t.txKey,variant:"compact"}),t.tracker===pulsarEvm.TransactionTracker.Safe&&p({label:i.hashLabels.safe,hash:t.txKey,variant:"compact"}),d?jsxRuntime.jsxs(jsxRuntime.Fragment,{children:[t.hash&&p({label:i.hashLabels.original,hash:t.hash,variant:"compact"}),t.replacedTxHash&&n?.getExplorerTxUrl&&p({label:i.hashLabels.replaced,hash:t.replacedTxHash,explorerUrl:n.getExplorerTxUrl(r,t.txKey,t.replacedTxHash)})]}):t.hash&&n?.getExplorerTxUrl&&p({label:i.hashLabels.default,hash:t.hash,explorerUrl:n?.getExplorerTxUrl(r,t.txKey)})]})}function Q({tx:t,className:e}){let r=u(),a={Pending:{label:r.statuses.pending,Icon:solid.ArrowPathIcon,badgeClasses:"bg-[var(--tuwa-pending-bg)] text-[var(--tuwa-pending-text)]",iconClasses:"animate-spin text-[var(--tuwa-pending-icon)]"},[pulsarCore.TransactionStatus.Success]:{label:r.statuses.success,Icon:solid.CheckCircleIcon,badgeClasses:"bg-[var(--tuwa-success-bg)] text-[var(--tuwa-success-text)]",iconClasses:"text-[var(--tuwa-success-icon)]"},[pulsarCore.TransactionStatus.Failed]:{label:r.statuses.failed,Icon:solid.XCircleIcon,badgeClasses:"bg-[var(--tuwa-error-bg)] text-[var(--tuwa-error-text)]",iconClasses:"text-[var(--tuwa-error-icon)]"},[pulsarCore.TransactionStatus.Replaced]:{label:r.statuses.replaced,Icon:solid.ArrowPathIcon,badgeClasses:"bg-[var(--tuwa-info-bg)] text-[var(--tuwa-info-text)]",iconClasses:"text-[var(--tuwa-info-icon)]"}},s="inline-flex items-center gap-x-1.5 rounded-full px-2 py-1 text-xs font-medium",o=t.pending?"Pending":t.status,i=o?a[o]:null;if(!i)return jsxRuntime.jsx("div",{className:novaCore.cn(s,"bg-[var(--tuwa-info-bg)] text-[var(--tuwa-info-text)]",e),children:t.status??r.statuses.unknown});let{label:d,Icon:c,badgeClasses:p,iconClasses:n}=i;return jsxRuntime.jsxs("div",{className:novaCore.cn(s,p,e),children:[jsxRuntime.jsx(c,{className:novaCore.cn("h-4 w-4",n)}),d]})}function kt({openWalletInfoModal:t,tx:e,transactionsPool:r,icon:a,className:s,customization:o,connectedWalletAddress:i,adapters:d}){let c=u(),p=o?.components,n=pulsarCore.selectAdapterByKey({adapterKey:e.adapter??pulsarCore.TransactionAdapter.EVM,adapters:d}),m=i&&e?.adapter===pulsarCore.TransactionAdapter.EVM&&e.nonce!==void 0&&e.pending&&e.maxFeePerGas&&e.maxPriorityFeePerGas,l=async()=>{m&&n?.cancelTxAction&&await n.cancelTxAction(e);},b=async()=>{m&&n?.speedUpTxAction&&await n.speedUpTxAction(e);};return jsxRuntime.jsxs("div",{className:novaCore.cn("flex w-full flex-col gap-3 rounded-lg bg-[var(--tuwa-bg-primary)] p-4 shadow-md",s),children:[jsxRuntime.jsxs("div",{className:"flex items-start gap-3",children:[jsxRuntime.jsx("div",{className:"w-[40px] flex-shrink-0",title:utils.getChainName(e.chainId),children:a??jsxRuntime.jsx(reactWeb3Icons.Web3Icon,{chainId:e.chainId})}),jsxRuntime.jsxs("div",{className:"flex-1",children:[p?.statusAwareText?p.statusAwareText({txStatus:e.status,source:e.title,fallback:e.type,variant:"title",applyColor:true}):jsxRuntime.jsx(A,{txStatus:e.status,source:e.title,fallback:e.type,variant:"title",applyColor:true}),p?.statusAwareText?p.statusAwareText({txStatus:e.status,source:e.description,variant:"description"}):jsxRuntime.jsx(A,{txStatus:e.status,source:e.description,variant:"description"})]})]}),jsxRuntime.jsxs("div",{children:[p?.transactionKey?p.transactionKey({transactionsPool:r,adapters:d,tx:e,variant:"toast"}):jsxRuntime.jsx(U,{transactionsPool:r,adapters:d,tx:e,variant:"toast"}),jsxRuntime.jsxs("div",{className:"mt-3 flex items-center justify-between",children:[p?.statusBadge?p.statusBadge({tx:e}):jsxRuntime.jsx(Q,{tx:e}),m?jsxRuntime.jsxs("div",{className:"flex items-center gap-4",children:[p?.speedUpButton?p.speedUpButton({onClick:b,children:c.actions.speedUp}):jsxRuntime.jsx("button",{onClick:b,type:"button",className:"cursor-pointer text-sm font-medium text-[var(--tuwa-text-accent)] transition-opacity hover:opacity-80",children:c.actions.speedUp}),p?.cancelButton?p.cancelButton({onClick:l,children:c.actions.cancel}):jsxRuntime.jsx("button",{onClick:l,type:"button",className:"cursor-pointer text-sm font-medium text-[var(--tuwa-text-secondary)] transition-opacity hover:opacity-80",children:c.actions.cancel})]}):i&&t&&(p?.walletInfoButton?p.walletInfoButton({onClick:()=>t(true),children:c.toast.openWalletInfo}):jsxRuntime.jsx("button",{className:"cursor-pointer bg-gradient-to-r from-[var(--tuwa-button-gradient-from)] to-[var(--tuwa-button-gradient-to)] text-[var(--tuwa-text-on-accent)] font-bold text-xs py-1 px-3 rounded-md shadow-lg hover:shadow-xl hover:from-[var(--tuwa-button-gradient-from-hover)] hover:to-[var(--tuwa-button-gradient-to-hover)] active:scale-95 transition-all duration-200 ease-in-out",onClick:()=>t(true),type:"button",children:c.toast.openWalletInfo}))]})]})]})}function It({error:t,className:e}){let{isCopied:r,copy:a}=novaCore.useCopyToClipboard(),s=u();return t?jsxRuntime.jsxs("div",{className:novaCore.cn("rounded-lg border border-[var(--tuwa-error-icon)]/30 bg-[var(--tuwa-error-bg)] p-3 text-sm",e),children:[jsxRuntime.jsxs("div",{className:"mb-2 flex items-center justify-between",children:[jsxRuntime.jsxs("div",{className:"flex items-center gap-2 font-bold text-[var(--tuwa-error-icon)]",children:[jsxRuntime.jsx(solid.ExclamationTriangleIcon,{className:"h-5 w-5"}),jsxRuntime.jsx("span",{children:s.txError.title})]}),jsxRuntime.jsx("button",{type:"button",onClick:()=>a(t),title:s.actions.copy,"aria-label":s.actions.copy,className:"cursor-pointer text-[var(--tuwa-error-icon)]/50 transition-colors hover:text-[var(--tuwa-error-icon)]",children:jsxRuntime.jsx(solid.DocumentDuplicateIcon,{className:"h-5 w-5"})})]}),jsxRuntime.jsx("div",{className:"max-h-24 overflow-y-auto rounded bg-[var(--tuwa-bg-primary)] p-2",children:jsxRuntime.jsx("p",{className:"font-mono text-xs text-[var(--tuwa-error-text)] break-all",children:t})}),jsxRuntime.jsx("div",{className:"mt-1 h-5 text-right",children:jsxRuntime.jsx("p",{className:novaCore.cn("text-xs text-[var(--tuwa-success-icon)] transition-opacity duration-300 ease-in-out",r?"opacity-100":"opacity-0"),children:s.txError.copied})})]}):null}function ke({label:t,value:e}){return jsxRuntime.jsxs("div",{className:"flex items-center justify-between text-sm",children:[jsxRuntime.jsx("span",{className:"text-[var(--tuwa-text-secondary)]",children:t}),jsxRuntime.jsx("span",{className:"font-medium text-[var(--tuwa-text-primary)]",children:e})]})}function Mt({tx:t,adapters:e,transactionsPool:r,className:a,customization:s}){let o=u(),i=d=>s?.components?.infoRow?s.components.infoRow(d):jsxRuntime.jsx(ke,{...d});return jsxRuntime.jsxs("div",{className:novaCore.cn("flex flex-col gap-3 rounded-lg border border-[var(--tuwa-border-primary)] bg-[var(--tuwa-bg-primary)] p-3",a),children:[i({label:o.txInfo.network,value:jsxRuntime.jsxs("div",{className:"flex items-center justify-end gap-2",children:[jsxRuntime.jsx("div",{className:"h-4 w-4",children:jsxRuntime.jsx(reactWeb3Icons.Web3Icon,{chainId:t.chainId??t?.desiredChainID??1})}),jsxRuntime.jsx("span",{children:utils.getChainName(t.chainId??t?.desiredChainID??1)})]})}),t.localTimestamp&&i({label:o.txInfo.started,value:Ot__default.default.unix(t.localTimestamp).format("MMM D, HH:mm:ss")}),jsxRuntime.jsx("div",{className:"border-t border-[var(--tuwa-border-primary)] pt-3",children:jsxRuntime.jsx(U,{tx:t,adapters:e,transactionsPool:r,variant:"history",renderHashLink:s?.components?.transactionKey})})]})}function Ee({status:t,label:e,isFirst:r=false}){let a={isCompleted:t==="completed",isError:t==="error",isReplaced:t==="replaced",isActive:t==="active"},s={line:novaCore.cn({"bg-[var(--tuwa-success-icon)]":a.isCompleted,"bg-[var(--tuwa-error-icon)]":a.isError,"bg-[var(--tuwa-info-icon)]":a.isReplaced,"bg-[var(--tuwa-pending-icon)]":a.isActive,"bg-[var(--tuwa-border-primary)]":t==="inactive"}),border:novaCore.cn({"border-[var(--tuwa-success-icon)]":a.isCompleted,"border-[var(--tuwa-error-icon)]":a.isError,"border-[var(--tuwa-info-icon)]":a.isReplaced,"border-[var(--tuwa-pending-icon)]":a.isActive,"border-[var(--tuwa-border-primary)]":t==="inactive"}),fill:novaCore.cn({"bg-[var(--tuwa-success-icon)]":a.isCompleted,"bg-[var(--tuwa-error-icon)]":a.isError,"bg-[var(--tuwa-info-icon)]":a.isReplaced}),pulse:novaCore.cn({"bg-[var(--tuwa-pending-icon)]":a.isActive})};return jsxRuntime.jsxs("div",{className:"relative flex flex-1 flex-col items-center min-w-[80px]",children:[!r&&jsxRuntime.jsx("div",{className:novaCore.cn("absolute right-1/2 top-[10px] h-0.5 w-full",s.line)}),jsxRuntime.jsxs("div",{className:novaCore.cn("relative z-10 flex h-5 w-5 items-center justify-center rounded-full border-2",s.border,s.fill),children:[a.isCompleted&&jsxRuntime.jsx(solid.CheckIcon,{className:"h-3 w-3 text-white"}),a.isError&&jsxRuntime.jsx(solid.ExclamationTriangleIcon,{className:"h-3 w-3 text-white"}),a.isReplaced&&jsxRuntime.jsx(solid.ArrowPathIcon,{className:"h-3 w-3 text-white"}),a.isActive&&jsxRuntime.jsx("div",{className:novaCore.cn("h-2 w-2 animate-pulse rounded-full",s.pulse)})]}),jsxRuntime.jsx("span",{className:novaCore.cn("mt-2 text-center text-xs",t!=="inactive"?"font-semibold text-[var(--tuwa-text-primary)]":"text-[var(--tuwa-text-secondary)]"),children:e})]})}function Bt({isProcessing:t,isSucceed:e,isFailed:r,isReplaced:a,className:s,StepComponent:o=Ee}){let i=u(),d=n=>{if(n===1)return "completed";if(n===2){if(e||r||a)return "completed";if(t)return "active"}if(n===3){if(e)return "completed";if(r)return "error";if(a)return "replaced";if(t)return "active"}return "inactive"},c=n=>n===1?i.trackingModal.progressIndicator.created:n===2?i.trackingModal.progressIndicator.processing:r?i.statuses.failed:a?i.statuses.replaced:i.trackingModal.progressIndicator.succeed,p=[{status:d(1),label:c(1),isFirst:true},{status:d(2),label:c(2)},{status:d(3),label:c(3),isLast:true}];return jsxRuntime.jsx("div",{className:novaCore.cn("flex w-full items-start px-4 pt-2 pb-1",s),children:p.map((n,m)=>jsxRuntime.jsx(o,{...n},m))})}function Lt({isProcessing:t,isSucceed:e,isFailed:r,isReplaced:a}){let s;return e?s=jsxRuntime.jsx(solid.CheckCircleIcon,{className:"h-16 w-16 text-[var(--tuwa-success-icon)]"}):r?s=jsxRuntime.jsx(solid.ExclamationCircleIcon,{className:"h-16 w-16 text-[var(--tuwa-error-icon)]"}):a?s=jsxRuntime.jsx(solid.ArrowPathIcon,{className:"h-16 w-16 text-[var(--tuwa-info-icon)]"}):t?s=jsxRuntime.jsx(solid.ArrowPathIcon,{className:"h-16 w-16 animate-spin text-[var(--tuwa-text-accent)]"}):s=jsxRuntime.jsx(solid.ClockIcon,{className:"h-16 w-16 animate-pulse text-[var(--tuwa-pending-icon)]"}),jsxRuntime.jsx("div",{className:"flex justify-center py-4",children:s})}function Dt({adapters:t,onClose:e,onOpenWalletInfo:r,className:a,customization:s,transactionsPool:o,actions:i,handleTransaction:d,initialTx:c,connectedAdapterType:p}){let n=u(),m=s?.components,[l,b]=react.useState(void 0);react.useEffect(()=>{let X;o&&(c?.lastTxKey?X=o[c.lastTxKey]:l&&(X=o[l.txKey])),b(X);},[o,c,l]);let x=l??c,y=l?.status,W=c?.isInitializing??false,C=l?.pending??true,R=W||C,H=l?.isError||!!c?.errorMessage,D=x?.actionKey&&i?.[x.actionKey]&&d&&!!p,N=!!p&&l?.adapter===pulsarCore.TransactionAdapter.EVM&&l?.nonce!==void 0&&l.pending&&l.maxFeePerGas&&l.maxPriorityFeePerGas,f=pulsarCore.selectAdapterByKey({adapterKey:l?.adapter??pulsarCore.TransactionAdapter.EVM,adapters:t}),v={initial:{opacity:0,scale:.95},animate:{opacity:1,scale:1},exit:{opacity:0,scale:.95},transition:{duration:.2,ease:"easeOut"},...s?.motionProps},O=async()=>{if(!D||!x?.actionKey)return;let X={adapter:pulsarCore.TransactionAdapter.EVM,type:x.type,desiredChainID:l?.chainId||c?.desiredChainID||1,actionKey:x.actionKey,title:x.title,description:x.description,payload:x.payload,withTrackedModal:true};f?.retryTxAction&&await f.retryTxAction({tx:X,txKey:l?.txKey??"",actions:i,onClose:e,handleTransaction:d});},J=async()=>{N&&l&&f?.cancelTxAction&&await f.cancelTxAction(l);},$=async()=>{console.log("handleSpeedUp: trackedTx",l),N&&l&&f?.speedUpTxAction&&await f.speedUpTxAction(l);},Tt=(l?.isTrackedModalOpen||c?.withTrackedModal)??false;return jsxRuntime.jsx(w__namespace.Root,{open:Tt,onOpenChange:X=>!X&&e(l?.txKey),children:jsxRuntime.jsx(w__namespace.Portal,{children:jsxRuntime.jsx(framerMotion.AnimatePresence,{children:Tt&&jsxRuntime.jsxs(jsxRuntime.Fragment,{children:[jsxRuntime.jsx(w__namespace.Overlay,{asChild:true,children:jsxRuntime.jsx(framerMotion.motion.div,{className:"fixed inset-0 bg-black/60 z-50",initial:{opacity:0},animate:{opacity:1},exit:{opacity:0}})}),jsxRuntime.jsx(w__namespace.Content,{className:"fixed left-1/2 top-1/2 w-full max-w-md -translate-x-1/2 -translate-y-1/2 outline-none z-50",onOpenAutoFocus:()=>b(void 0),...s?.modalProps,asChild:true,children:jsxRuntime.jsx(framerMotion.motion.div,{...v,children:jsxRuntime.jsxs("div",{className:novaCore.cn("relative flex flex-col gap-3 rounded-2xl bg-[var(--tuwa-bg-primary)] p-5 pt-0 shadow-2xl max-h-[98dvh] overflow-y-auto",a),children:[m?.header?m.header({onClose:()=>e(l?.txKey)}):jsxRuntime.jsxs("header",{className:"flex items-start justify-between sticky top-0 w-full z-10 pt-5 pb-2 bg-[var(--tuwa-bg-primary)]",children:[jsxRuntime.jsx(w__namespace.Title,{className:"text-lg font-bold text-[var(--tuwa-text-primary)]",children:n.trackingModal.title}),jsxRuntime.jsx(w__namespace.Close,{asChild:true,children:jsxRuntime.jsx("button",{type:"button",onClick:()=>e(l?.txKey),"aria-label":n.actions.close,className:"cursor-pointer ml-2 -mt-1 rounded-full p-1 text-[var(--tuwa-text-tertiary)] transition-colors hover:bg-[var(--tuwa-bg-muted)] hover:text-[var(--tuwa-text-primary)]",children:jsxRuntime.jsx(solid.XMarkIcon,{className:"h-5 w-5"})})})]}),jsxRuntime.jsxs("main",{className:"flex flex-col gap-3",children:[m?.statusVisual?m.statusVisual({isProcessing:R,isSucceed:y===pulsarCore.TransactionStatus.Success,isFailed:H,isReplaced:y===pulsarCore.TransactionStatus.Replaced}):jsxRuntime.jsx(Lt,{isProcessing:R,isSucceed:y===pulsarCore.TransactionStatus.Success,isFailed:H,isReplaced:y===pulsarCore.TransactionStatus.Replaced}),jsxRuntime.jsxs("div",{className:"flex flex-col items-center text-center -mt-2",children:[jsxRuntime.jsx(A,{txStatus:y,source:x?.title,fallback:x?.type,variant:"title",applyColor:true,className:"text-xl"}),jsxRuntime.jsx(A,{txStatus:y,source:x?.description,variant:"description",className:"mt-0"})]}),m?.progressIndicator?m.progressIndicator({isProcessing:R,isSucceed:y===pulsarCore.TransactionStatus.Success,isFailed:H,isReplaced:y===pulsarCore.TransactionStatus.Replaced}):jsxRuntime.jsx(Bt,{isProcessing:R,isSucceed:y===pulsarCore.TransactionStatus.Success,isFailed:H,isReplaced:y===pulsarCore.TransactionStatus.Replaced}),m?.infoBlock?m.infoBlock({tx:x,adapters:t,transactionsPool:o}):jsxRuntime.jsx(Mt,{tx:x,adapters:t,transactionsPool:o}),m?.errorBlock?m.errorBlock({error:l?.errorMessage||c?.errorMessage}):jsxRuntime.jsx(It,{error:l?.errorMessage||c?.errorMessage})]}),m?.footer?m.footer({onClose:()=>e(l?.txKey),onOpenWalletInfo:r,isProcessing:R,onRetry:D?O:void 0,onSpeedUp:N?$:void 0,onCancel:N?J:void 0}):jsxRuntime.jsxs("footer",{className:"mt-2 flex w-full items-center justify-between border-t border-[var(--tuwa-border-primary)] pt-4",children:[jsxRuntime.jsx("div",{className:"flex items-center gap-4",children:N&&jsxRuntime.jsxs(jsxRuntime.Fragment,{children:[jsxRuntime.jsx("button",{type:"button",onClick:$,className:"cursor-pointer text-sm font-medium text-[var(--tuwa-text-accent)] transition-opacity hover:opacity-80",children:n.actions.speedUp}),jsxRuntime.jsx("button",{type:"button",onClick:J,className:"cursor-pointer text-sm font-medium text-[var(--tuwa-text-secondary)] transition-opacity hover:opacity-80",children:n.actions.cancel})]})}),jsxRuntime.jsxs("div",{className:"flex items-center gap-3",children:[H&&D?jsxRuntime.jsx("button",{type:"button",onClick:O,className:"cursor-pointer rounded-md bg-[var(--tuwa-button-gradient-from)] px-4 py-2 text-sm font-semibold text-[var(--tuwa-text-on-accent)] transition-opacity hover:opacity-90",children:n.trackingModal.retry}):!N&&jsxRuntime.jsx("button",{type:"button",onClick:r,className:"cursor-pointer rounded-md bg-[var(--tuwa-bg-muted)] px-4 py-2 text-sm font-semibold text-[var(--tuwa-text-primary)] transition-colors hover:bg-[var(--tuwa-border-primary)]",children:n.trackingModal.walletInfo}),jsxRuntime.jsx("button",{type:"button",onClick:()=>e(l?.txKey),disabled:R&&!N,className:"cursor-pointer rounded-md bg-[var(--tuwa-bg-muted)] px-4 py-2 text-sm font-semibold text-[var(--tuwa-text-primary)] transition-colors hover:bg-[var(--tuwa-border-primary)] disabled:cursor-not-allowed disabled:opacity-50",children:R&&!N?n.trackingModal.processing:n.trackingModal.close})]})]})]})})})]})})})})}Ot__default.default.extend(Fe__default.default);function Xt({tx:t,adapters:e,transactionsPool:r,className:a,customization:s}){let o=s?.components;return jsxRuntime.jsxs("div",{className:novaCore.cn("flex flex-col gap-2 border-b border-[var(--tuwa-border-secondary)] p-3 transition-colors hover:bg-[var(--tuwa-bg-secondary)]",a),children:[jsxRuntime.jsxs("div",{className:"flex items-start justify-between",children:[jsxRuntime.jsxs("div",{className:"flex items-center gap-4",children:[jsxRuntime.jsx("div",{className:"flex h-10 w-10 flex-shrink-0 items-center justify-center rounded-full bg-[var(--tuwa-bg-muted)]",children:o?.icon?o.icon({chainId:t.chainId}):jsxRuntime.jsx("div",{className:"h-8 w-8 text-[var(--tuwa-text-secondary)]",children:jsxRuntime.jsx(reactWeb3Icons.Web3Icon,{chainId:t.chainId})})}),jsxRuntime.jsxs("div",{children:[o?.title?o.title({txStatus:t.status,source:t.title,fallback:t.type,variant:"title",applyColor:true}):jsxRuntime.jsx(A,{txStatus:t.status,source:t.title,fallback:t.type,variant:"title",applyColor:true}),o?.timestamp?o.timestamp({timestamp:t.localTimestamp}):jsxRuntime.jsx("span",{className:"mb-1 block text-xs text-[var(--tuwa-text-secondary)]",children:t.localTimestamp?Ot__default.default.unix(t.localTimestamp).fromNow():"..."}),o?.description?o.description({txStatus:t.status,source:t.description,variant:"description"}):jsxRuntime.jsx(A,{txStatus:t.status,source:t.description,variant:"description"})]})]}),o?.statusBadge?o.statusBadge({tx:t}):jsxRuntime.jsx(Q,{tx:t})]}),o?.transactionKey?o.transactionKey({tx:t,adapters:e,transactionsPool:r,variant:"history"}):jsxRuntime.jsx(U,{tx:t,adapters:e,transactionsPool:r,variant:"history"})]})}function Ge({title:t,message:e,className:r}){return jsxRuntime.jsxs("div",{className:novaCore.cn("rounded-lg bg-[var(--tuwa-bg-muted)] p-8 text-center",r),children:[jsxRuntime.jsx("h4",{className:"font-semibold text-[var(--tuwa-text-primary)]",children:t}),jsxRuntime.jsx("p",{className:"mt-1 text-sm text-[var(--tuwa-text-secondary)]",children:e})]})}function Jt({adapters:t,connectedWalletAddress:e,transactionsPool:r,className:a,customization:s}){let o=u(),i=s?.components,c=[...e?pulsarCore.selectAllTransactionsByActiveWallet(r,e):[]].sort((m,l)=>(l.localTimestamp??0)-(m.localTimestamp??0)),p=(m,l)=>i?.placeholder?i.placeholder({title:m,message:l}):jsxRuntime.jsx(Ge,{title:m,message:l}),n=i?.HistoryItem||Xt;return jsxRuntime.jsxs("div",{className:novaCore.cn("flex flex-col gap-y-3",a),children:[jsxRuntime.jsx("h3",{className:"text-lg font-bold text-[var(--tuwa-text-primary)]",children:o.walletModal.history.title}),e?c.length>0?jsxRuntime.jsx("div",{className:novaCore.cn("max-h-[400px] overflow-y-auto rounded-lg border border-[var(--tuwa-border-primary)] bg-[var(--tuwa-bg-primary)]",s?.classNames?.listWrapper),children:c.map(m=>jsxRuntime.jsx(n,{tx:m,transactionsPool:r,adapters:t},m.txKey))}):p(o.walletModal.history.noTransactionsTitle,o.walletModal.history.noTransactionsMessage):p(o.walletModal.history.connectWalletTitle,o.walletModal.history.connectWalletMessage)]})}function dt({address:t,explorerUrl:e,className:r}){let{isCopied:a,copy:s}=novaCore.useCopyToClipboard(),o=u(),i=e?`${e}/address/${t}`:void 0;return jsxRuntime.jsxs("div",{className:novaCore.cn("flex items-center gap-x-3 rounded-full bg-[var(--tuwa-bg-muted)] px-3 py-1 font-mono text-xs text-[var(--tuwa-text-secondary)]",r),children:[jsxRuntime.jsx("span",{children:novaCore.textCenterEllipsis(t,6,6)}),jsxRuntime.jsx("button",{type:"button",title:a?o.txError.copied:o.actions.copy,"aria-label":a?o.txError.copied:o.actions.copy,onClick:()=>s(t),className:"cursor-pointer transition-colors hover:text-[var(--tuwa-text-primary)]",children:a?jsxRuntime.jsx(solid.CheckIcon,{className:"h-4 w-4 text-[var(--tuwa-success-icon)]"}):jsxRuntime.jsx(solid.DocumentDuplicateIcon,{className:"h-4 w-4"})}),i&&jsxRuntime.jsx("a",{href:i,target:"_blank",rel:"noopener noreferrer",className:"transition-colors hover:text-[var(--tuwa-text-accent)]",title:o.actions.viewOnExplorer,"aria-label":o.actions.viewOnExplorer,children:jsxRuntime.jsx(solid.ArrowTopRightOnSquareIcon,{className:"h-4 w-4"})})]})}function _t({address:t,ensAvatar:e,className:r}){let a=u(),s=`#${t.slice(2,8)}`,[o,i]=react.useState(void 0);return react.useEffect(()=>{i(e??zt__default.default(viem.isHex(t)?t:viem.zeroAddress));},[e,t]),jsxRuntime.jsx("div",{className:novaCore.cn("h-12 w-12 flex-shrink-0 rounded-full",r),style:{backgroundColor:s},children:jsxRuntime.jsx("img",{className:"h-full w-full rounded-full object-cover",src:o,alt:`${a.walletModal.header.avatarAlt} ${t}`,onError:()=>i(zt__default.default(viem.isHex(t)?t:viem.zeroAddress))})})}function Yt({walletAddress:t,className:e,renderAvatar:r,renderName:a,renderAddressDisplay:s,renderNoWalletContent:o,explorerUrl:i}){let d=u(),[c,p]=react.useState(void 0),[n,m]=react.useState(void 0),[l,b]=react.useState(true);if(react.useEffect(()=>{(async()=>{if(t){b(true),p(void 0),m(void 0);try{let W=await pulsarEvm.getName(t);if(W){p(W);let C=await pulsarEvm.getAvatar(W);m(C);}}finally{b(false);}}})();},[t]),!t)return o?jsxRuntime.jsx(jsxRuntime.Fragment,{children:o()}):jsxRuntime.jsx("div",{className:novaCore.cn("flex h-20 items-center justify-center rounded-lg bg-[var(--tuwa-bg-muted)] text-[var(--tuwa-text-secondary)]",e),children:d.walletModal.header.notConnected});let x=c?c.length>30?novaCore.textCenterEllipsis(c,12,12):c:void 0;return jsxRuntime.jsxs("div",{className:novaCore.cn("flex items-center gap-4 min-h-[4rem]",e),children:[jsxRuntime.jsx("div",{children:r?r({address:t,ensAvatar:n}):jsxRuntime.jsx(_t,{address:t,ensAvatar:n})}),jsxRuntime.jsx("div",{className:"flex flex-col justify-center min-h-[3.5rem] min-w-[200px]",children:a?a({ensName:x,isLoading:l,address:t}):jsxRuntime.jsxs("div",{className:"flex flex-col",children:[jsxRuntime.jsx("div",{className:"h-7 flex items-center mb-1.5",children:l?jsxRuntime.jsx("div",{className:"h-full w-48 animate-pulse rounded-md bg-[var(--tuwa-bg-muted)]"}):x?jsxRuntime.jsx("h2",{className:"text-xl font-bold text-[var(--tuwa-text-primary)]",children:x}):jsxRuntime.jsx(dt,{address:t,explorerUrl:i,className:"text-xl font-bold text-[var(--tuwa-text-primary)] bg-transparent px-0 py-0 rounded-none"})}),jsxRuntime.jsx("div",{className:"h-5 flex items-center",children:!l&&x&&(s?s({address:t,explorerUrl:i}):jsxRuntime.jsx(dt,{address:t,explorerUrl:i}))})]})})]})}function jt({isOpen:t,setIsOpen:e,customization:r,...a}){let s=u(),i={...{initial:{opacity:0,scale:.95},animate:{opacity:1,scale:1},exit:{opacity:0,scale:.95},transition:{duration:.2,ease:"easeOut"}},...r?.motionProps},d=()=>e&&e(false);return jsxRuntime.jsx(w__namespace.Root,{open:t,onOpenChange:c=>!c&&d(),children:jsxRuntime.jsx(w__namespace.Portal,{children:jsxRuntime.jsx(framerMotion.AnimatePresence,{children:t&&jsxRuntime.jsxs(jsxRuntime.Fragment,{children:[jsxRuntime.jsx(w__namespace.Overlay,{asChild:true,children:jsxRuntime.jsx(framerMotion.motion.div,{className:"fixed inset-0 bg-black/45 flex items-center justify-center p-2 z-50",initial:{opacity:0},animate:{opacity:1},exit:{opacity:0},transition:{duration:.15}})}),jsxRuntime.jsx(w__namespace.Content,{className:"fixed left-1/2 top-1/2 w-full max-w-2xl -translate-x-1/2 -translate-y-1/2 outline-none z-50",...r?.modalProps,asChild:true,children:jsxRuntime.jsx(framerMotion.motion.div,{...i,children:jsxRuntime.jsxs("div",{className:novaCore.cn("relative w-full max-w-2xl outline-none rounded-2xl bg-[var(--tuwa-bg-secondary)] shadow-xl max-h-[98dvh] overflow-y-auto",r?.classNames?.contentWrapper),children:[r?.components?.header?r.components.header({closeModal:d}):jsxRuntime.jsxs("div",{className:"flex items-center justify-between border-b border-[var(--tuwa-border-primary)] p-4 sticky top-0 left-0 w-full bg-[var(--tuwa-bg-secondary)] z-10",children:[jsxRuntime.jsx(w__namespace.Title,{className:"text-lg font-bold text-[var(--tuwa-text-primary)]",children:s.walletModal.title}),jsxRuntime.jsx(w__namespace.Close,{asChild:true,children:jsxRuntime.jsx("button",{type:"button",onClick:d,"aria-label":s.actions.close,className:"cursor-pointer rounded-full p-1 text-[var(--tuwa-text-tertiary)] transition-colors hover:bg-[var(--tuwa-bg-muted)] hover:text-[var(--tuwa-text-primary)]",children:jsxRuntime.jsx(solid.XMarkIcon,{className:"h-6 w-6"})})})]}),jsxRuntime.jsxs("div",{className:"flex flex-col gap-4 p-4 sm:p-6 sm:gap-6",children:[r?.components?.walletInfo?r.components.walletInfo(a):jsxRuntime.jsx(Yt,{explorerUrl:pulsarCore.selectAdapterByKey({adapterKey:a.connectedAdapterType??pulsarCore.TransactionAdapter.EVM,adapters:a.adapters})?.getExplorerUrl()??"",walletAddress:a.connectedWalletAddress}),r?.components?.history?r.components.history(a):jsxRuntime.jsx(Jt,{...a})]})]})})})]})})})})}var ba={[pulsarCore.TransactionStatus.Success]:"success",[pulsarCore.TransactionStatus.Failed]:"error",[pulsarCore.TransactionStatus.Replaced]:"info"};function wn({adapters:t,connectedWalletAddress:e,connectedAdapterType:r,labels:a,features:s,customization:o,closeTxTrackedModal:i,actions:d,handleTransaction:c,initialTx:p,transactionsPool:n,...m}){let[l,b]=react.useState(false),x=react.useRef(n),y=novaCore.useMediaQuery("(max-width: 767px)"),W=!!p?.withTrackedModal&&n[p?.lastTxKey??""]?.isTrackedModalOpen,C=react.useMemo(()=>({toasts:s?.toasts??true,walletInfoModal:s?.walletInfoModal??true,trackingTxModal:s?.trackingTxModal??true}),[s]),R=react.useMemo(()=>novaCore.deepMerge(q,a||{}),[a]);react.useEffect(()=>{if(!C.toasts)return;let D=(f,v)=>{let O=J=>jsxRuntime.jsx(kt,{...J,tx:f,transactionsPool:n,openWalletInfoModal:C.walletInfoModal?()=>b(true):void 0,customization:o?.toast,adapters:t,connectedWalletAddress:e});reactToastify.toast.isActive(f.txKey)?reactToastify.toast.update(f.txKey,{render:O,type:v}):reactToastify.toast(O,{toastId:f.txKey,type:v,closeOnClick:false});},N=x.current;Object.values(n).forEach(f=>{let v=N[f.txKey],O=v&&v.status!==f.status,J=v&&v?.adapter===pulsarCore.TransactionAdapter.EVM&&!v.hash&&f?.adapter===pulsarCore.TransactionAdapter.EVM&&f.hash;if(!v&&f.pending&&D(f,"info"),(v&&v?.adapter===pulsarCore.TransactionAdapter.EVM&&v.pending?v.nonce:void 0)!==(f?.adapter===pulsarCore.TransactionAdapter.EVM&&f.pending?f?.nonce:void 0))D(f,"info");else if(O||J){let $=ba[f.status]??"info";D(f,$);}}),x.current=n;},[n,o?.toast,C]);let H=C.toasts&&(!y||!W||!l);return jsxRuntime.jsxs(vt,{labels:R,children:[H&&jsxRuntime.jsx(reactToastify.ToastContainer,{position:"bottom-right",stacked:true,autoClose:false,hideProgressBar:true,closeOnClick:false,icon:false,closeButton:ht,toastClassName:"!p-0 !bg-transparent !shadow-none !min-h-0",...m}),C.walletInfoModal&&jsxRuntime.jsx(jt,{transactionsPool:n,connectedWalletAddress:e,isOpen:l,setIsOpen:b,customization:o?.walletInfoModal,adapters:t,connectedAdapterType:r}),C.trackingTxModal&&jsxRuntime.jsx(Dt,{initialTx:p,onClose:i,onOpenWalletInfo:()=>b(true),transactionsPool:n,customization:o?.trackingTxModal,actions:d,handleTransaction:c,adapters:t,connectedAdapterType:r})]})}exports.LabelsProvider=vt;exports.NovaProvider=wn;exports.useLabels=u;//# sourceMappingURL=index.cjs.map
|
1
|
+
'use strict';var react=require('react'),jsxRuntime=require('react/jsx-runtime'),novaCore=require('@tuwaio/nova-core'),pulsarCore=require('@tuwaio/pulsar-core'),reactToastify=require('react-toastify'),solid=require('@heroicons/react/24/solid'),reactWeb3Icons=require('@bgd-labs/react-web3-icons'),utils=require('@bgd-labs/react-web3-icons/dist/utils'),P=require('@radix-ui/react-dialog'),framerMotion=require('framer-motion'),Ht=require('dayjs'),je=require('dayjs/plugin/relativeTime'),To=require('ethereum-blockies-base64'),viem=require('viem');function _interopDefault(e){return e&&e.__esModule?e:{default:e}}function _interopNamespace(e){if(e&&e.__esModule)return e;var n=Object.create(null);if(e){Object.keys(e).forEach(function(k){if(k!=='default'){var d=Object.getOwnPropertyDescriptor(e,k);Object.defineProperty(n,k,d.get?d:{enumerable:true,get:function(){return e[k]}});}})}n.default=e;return Object.freeze(n)}var P__namespace=/*#__PURE__*/_interopNamespace(P);var Ht__default=/*#__PURE__*/_interopDefault(Ht);var je__default=/*#__PURE__*/_interopDefault(je);var To__default=/*#__PURE__*/_interopDefault(To);var $={walletModal:{title:"Wallet & Transactions",header:{notConnected:"Wallet not connected",avatarAlt:"Avatar for"},history:{title:"Transactions History",connectWalletTitle:"Connect Wallet",connectWalletMessage:"Please connect your wallet to see your past activity.",noTransactionsTitle:"No Transactions Yet",noTransactionsMessage:"Once you interact with the app, your transaction history will appear here."}},toast:{openWalletInfo:"Open wallet info"},statuses:{pending:"Pending",success:"Success",failed:"Failed",reverted:"Reverted",replaced:"Replaced",unknown:"Unknown"},hashLabels:{gelato:"Gelato Task ID",safe:"Safe Tx Hash",original:"Original Tx Hash",replaced:"Replaced Tx Hash",default:"Tx Hash"},txInfo:{started:"Started",network:"Network"},txError:{title:"Error",copied:"Copied!"},trackingModal:{title:"Transaction Overview",processing:"Processing...",close:"Close",walletInfo:"Wallet Info",retry:"Retry",progressIndicator:{created:"Created",processing:"Processing",succeed:"Succeed"}},trackedTxButton:{loading:"Processing...",succeed:"Success",failed:"Failed",replaced:"Replaced"},actions:{copy:"Copy address",viewOnExplorer:"View on explorer",close:"Close",cancel:"Cancel",speedUp:"Speed up"}};var dt=react.createContext($),mt=({labels:t,children:e})=>jsxRuntime.jsx(dt.Provider,{value:t,children:e}),m=()=>react.useContext(dt);function ft({label:t,hash:e,explorerUrl:o,variant:a="default",className:s}){let{isCopied:n,copy:i}=novaCore.useCopyToClipboard(),{actions:c,txError:p}=m(),l=novaCore.cn("flex items-center justify-between",{"text-sm":a==="default","text-xs":a==="compact"},s),r=novaCore.cn("pr-1",{"font-bold text-[var(--tuwa-text-primary)]":a==="default","font-medium text-[var(--tuwa-text-secondary)]":a==="compact"}),f=jsxRuntime.jsx("span",{className:"font-mono",children:novaCore.textCenterEllipsis(e,5,5)});return jsxRuntime.jsxs("div",{className:l,children:[t&&jsxRuntime.jsxs("span",{className:r,children:[t,":"]}),jsxRuntime.jsxs("div",{className:"flex items-center gap-x-2",children:[o?jsxRuntime.jsxs("a",{href:o,target:"_blank",rel:"noopener noreferrer",className:"flex items-center gap-x-1 text-[var(--tuwa-text-accent)] transition-colors hover:underline",title:c.viewOnExplorer,"aria-label":c.viewOnExplorer,children:[f,jsxRuntime.jsx(solid.ArrowTopRightOnSquareIcon,{className:"h-4 w-4"})]}):jsxRuntime.jsx("span",{className:"text-[var(--tuwa-text-primary)]",children:f}),jsxRuntime.jsx("button",{type:"button",onClick:()=>i(e),className:"cursor-pointer text-[var(--tuwa-text-tertiary)] transition-colors hover:text-[var(--tuwa-text-secondary)]",title:n?p.copied:c.copy,"aria-label":n?p.copied:c.copy,children:n?jsxRuntime.jsx(solid.CheckIcon,{className:"h-4 w-4 text-[var(--tuwa-success-icon)]"}):jsxRuntime.jsx(solid.DocumentDuplicateIcon,{className:"h-4 w-4"})})]})]})}var Tt={[pulsarCore.TransactionStatus.Success]:{index:1,colorClass:"text-[var(--tuwa-success-text)]"},[pulsarCore.TransactionStatus.Failed]:{index:2,colorClass:"text-[var(--tuwa-error-text)]"},[pulsarCore.TransactionStatus.Replaced]:{index:3,colorClass:"text-[var(--tuwa-text-secondary)]"},default:{index:0,colorClass:"text-[var(--tuwa-text-primary)]"}};function L({txStatus:t,source:e,fallback:o,variant:a,className:s,applyColor:n=false}){let i,c="";if(typeof e=="string")i=e;else if(Array.isArray(e)){let r=Tt[t||"default"]??Tt.default;i=e[r.index],n&&(c=r.colorClass);}else i=o;return i?jsxRuntime.jsx("div",{className:novaCore.cn(a==="title"?"text-sm font-semibold text-[var(--tuwa-text-primary)]":"mt-1 text-xs text-[var(--tuwa-text-secondary)]",c,s),children:i}):null}function vt({closeToast:t}){let{actions:e}=m();return jsxRuntime.jsx("button",{type:"button",onClick:t,"aria-label":e.close,title:e.close,className:novaCore.cn("absolute top-2 right-2 cursor-pointer rounded-full p-1","text-[var(--tuwa-text-tertiary)] transition-colors","hover:bg-[var(--tuwa-bg-muted)] hover:text-[var(--tuwa-text-primary)]"),children:jsxRuntime.jsx(solid.XMarkIcon,{className:"h-5 w-5"})})}function U({tx:t,adapters:e,transactionsPool:o,variant:a="toast",className:s,renderHashLink:n}){let{hashLabels:i}=m(),c=pulsarCore.selectAdapterByKey({adapterKey:t.adapter,adapters:e});if(!c)return null;let p=u=>n?n(u):jsxRuntime.jsx(ft,{...u}),l=a==="toast"?"mt-2 flex w-full flex-col gap-y-2 border-t border-[var(--tuwa-border-primary)] pt-2":"flex w-full flex-col gap-y-2",r=i[t.tracker],f=r?p({label:r,hash:t.txKey,variant:"compact"}):null,x=(()=>{let u=t.hash,v=t.replacedTxHash;return !u&&!v?null:v?jsxRuntime.jsxs(jsxRuntime.Fragment,{children:[u&&p({label:i.original,hash:u,variant:"compact"}),c.getExplorerTxUrl&&p({label:i.replaced,hash:v,explorerUrl:c.getExplorerTxUrl(o,t.txKey,v)})]}):u&&c.getExplorerTxUrl&&p({label:i.default,hash:u,explorerUrl:c.getExplorerTxUrl(o,t.txKey)})})(),y=r&&r!==i.default&&t.txKey!==t.hash;return jsxRuntime.jsxs("div",{className:novaCore.cn(l,s),children:[y&&f,x]})}var fe=t=>({Pending:{label:t.pending,Icon:solid.ArrowPathIcon,badgeClasses:"bg-[var(--tuwa-pending-bg)] text-[var(--tuwa-pending-text)]",iconClasses:"animate-spin text-[var(--tuwa-pending-icon)]"},[pulsarCore.TransactionStatus.Success]:{label:t.success,Icon:solid.CheckCircleIcon,badgeClasses:"bg-[var(--tuwa-success-bg)] text-[var(--tuwa-success-text)]",iconClasses:"text-[var(--tuwa-success-icon)]"},[pulsarCore.TransactionStatus.Failed]:{label:t.failed,Icon:solid.XCircleIcon,badgeClasses:"bg-[var(--tuwa-error-bg)] text-[var(--tuwa-error-text)]",iconClasses:"text-[var(--tuwa-error-icon)]"},[pulsarCore.TransactionStatus.Replaced]:{label:t.replaced,Icon:solid.ArrowPathIcon,badgeClasses:"bg-[var(--tuwa-info-bg)] text-[var(--tuwa-info-text)]",iconClasses:"text-[var(--tuwa-info-icon)]"}});function G({tx:t,className:e}){let{statuses:o}=m(),a=react.useMemo(()=>fe(o),[o]),s="inline-flex items-center gap-x-1.5 rounded-full px-2 py-1 text-xs font-medium",n=t.pending?"Pending":t.status,i=n?a[n]:null;if(!i)return jsxRuntime.jsx("div",{className:novaCore.cn(s,"bg-[var(--tuwa-info-bg)] text-[var(--tuwa-info-text)]",e),children:t.status??o.unknown});let{label:c,Icon:p,badgeClasses:l,iconClasses:r}=i;return jsxRuntime.jsxs("div",{className:novaCore.cn(s,l,e),children:[jsxRuntime.jsx(p,{className:novaCore.cn("h-4 w-4",r)}),c]})}var be=({onClick:t,children:e})=>jsxRuntime.jsx("button",{onClick:t,type:"button",className:"cursor-pointer text-sm font-medium text-[var(--tuwa-text-accent)] transition-opacity hover:opacity-80",children:e}),we=({onClick:t,children:e})=>jsxRuntime.jsx("button",{onClick:t,type:"button",className:"cursor-pointer text-sm font-medium text-[var(--tuwa-text-secondary)] transition-opacity hover:opacity-80",children:e}),Ce=({onClick:t,children:e})=>jsxRuntime.jsx("button",{className:"cursor-pointer rounded-md bg-gradient-to-r from-[var(--tuwa-button-gradient-from)] to-[var(--tuwa-button-gradient-to)] px-3 py-1 text-xs font-bold text-[var(--tuwa-text-on-accent)] shadow-lg transition-all duration-200 ease-in-out hover:shadow-xl hover:from-[var(--tuwa-button-gradient-from-hover)] hover:to-[var(--tuwa-button-gradient-to-hover)] active:scale-95",onClick:t,type:"button",children:e});function wt({openWalletInfoModal:t,tx:e,transactionsPool:o,icon:a,className:s,customization:n,connectedWalletAddress:i,adapters:c}){let{actions:p,toast:l}=m(),r=pulsarCore.selectAdapterByKey({adapterKey:e.adapter,adapters:c}),f=!!(e.pending&&r?.speedUpTxAction&&r?.cancelTxAction&&e.from.toLowerCase()===i?.toLowerCase()),x=()=>{f&&r.cancelTxAction(e);},y=()=>{f&&r.speedUpTxAction(e);},{StatusAwareText:u=L,TransactionKey:v=U,StatusBadge:g=G,SpeedUpButton:S=be,CancelButton:T=we,WalletInfoButton:M=Ce}=n?.components??{};return jsxRuntime.jsxs("div",{className:novaCore.cn("flex w-full flex-col gap-3 rounded-lg bg-[var(--tuwa-bg-primary)] p-4 shadow-md",s),children:[jsxRuntime.jsxs("div",{className:"flex items-start gap-3",children:[jsxRuntime.jsx("div",{className:"w-[40px] flex-shrink-0",title:utils.getChainName(e.chainId),children:a??jsxRuntime.jsx(reactWeb3Icons.Web3Icon,{chainId:e.chainId})}),jsxRuntime.jsxs("div",{className:"flex-1",children:[jsxRuntime.jsx(u,{txStatus:e.status,source:e.title,fallback:e.type,variant:"title",applyColor:true}),jsxRuntime.jsx(u,{txStatus:e.status,source:e.description,variant:"description"})]})]}),jsxRuntime.jsxs("div",{children:[jsxRuntime.jsx(v,{transactionsPool:o,adapters:c,tx:e,variant:"toast"}),jsxRuntime.jsxs("div",{className:"mt-3 flex items-center justify-between",children:[jsxRuntime.jsx(g,{tx:e}),f?jsxRuntime.jsxs("div",{className:"flex items-center gap-4",children:[jsxRuntime.jsx(S,{onClick:y,children:p.speedUp}),jsxRuntime.jsx(T,{onClick:x,children:p.cancel})]}):t&&jsxRuntime.jsx(M,{onClick:t,children:l.openWalletInfo})]})]})]})}function Ct({error:t,className:e}){let{isCopied:o,copy:a}=novaCore.useCopyToClipboard(),{actions:s,txError:n}=m();return t?jsxRuntime.jsxs("div",{className:novaCore.cn("rounded-lg border border-[var(--tuwa-error-icon)]/30 bg-[var(--tuwa-error-bg)] p-3 text-sm",e),children:[jsxRuntime.jsxs("div",{className:"mb-2 flex items-center justify-between",children:[jsxRuntime.jsxs("div",{className:"flex items-center gap-2 font-bold text-[var(--tuwa-error-icon)]",children:[jsxRuntime.jsx(solid.ExclamationTriangleIcon,{className:"h-5 w-5"}),jsxRuntime.jsx("span",{children:n.title})]}),jsxRuntime.jsx("button",{type:"button",onClick:()=>a(t),title:o?n.copied:s.copy,"aria-label":o?n.copied:`${s.copy} error message`,className:"cursor-pointer text-[var(--tuwa-error-icon)]/50 transition-colors hover:text-[var(--tuwa-error-icon)]",children:o?jsxRuntime.jsx(solid.CheckIcon,{className:"h-5 w-5 text-[var(--tuwa-success-icon)]"}):jsxRuntime.jsx(solid.DocumentDuplicateIcon,{className:"h-5 w-5"})})]}),jsxRuntime.jsx("div",{className:"max-h-24 overflow-y-auto rounded bg-[var(--tuwa-bg-primary)] p-2",children:jsxRuntime.jsx("p",{className:"font-mono text-xs text-[var(--tuwa-error-text)] break-all",children:t})})]}):null}function Be({label:t,value:e}){return jsxRuntime.jsxs("div",{className:"flex items-center justify-between text-sm",children:[jsxRuntime.jsx("span",{className:"text-[var(--tuwa-text-secondary)]",children:t}),jsxRuntime.jsx("span",{className:"font-medium text-[var(--tuwa-text-primary)]",children:e})]})}function Pt({tx:t,adapters:e,transactionsPool:o,className:a,customization:s}){let{txInfo:n}=m(),{InfoRow:i=Be}=s?.components??{},c="chainId"in t?t.chainId:t.desiredChainID;return jsxRuntime.jsxs("div",{className:novaCore.cn("flex flex-col gap-3 rounded-lg border border-[var(--tuwa-border-primary)] bg-[var(--tuwa-bg-primary)] p-3",a),children:[jsxRuntime.jsx(i,{label:n.network,value:jsxRuntime.jsxs("div",{className:"flex items-center justify-end gap-2",children:[jsxRuntime.jsx("div",{className:"h-4 w-4",children:jsxRuntime.jsx(reactWeb3Icons.Web3Icon,{chainId:c})}),jsxRuntime.jsx("span",{children:utils.getChainName(c)})]})}),t.localTimestamp&&jsxRuntime.jsx(i,{label:n.started,value:Ht__default.default.unix(t.localTimestamp).format("MMM D, HH:mm:ss")}),"txKey"in t&&t.txKey&&jsxRuntime.jsx("div",{className:"border-t border-[var(--tuwa-border-primary)] pt-3",children:jsxRuntime.jsx(U,{tx:t,adapters:e,transactionsPool:o,variant:"history",renderHashLink:s?.components?.transactionKey})})]})}var We={completed:{line:"bg-[var(--tuwa-success-icon)]",border:"border-[var(--tuwa-success-icon)]",fill:"bg-[var(--tuwa-success-icon)]"},error:{line:"bg-[var(--tuwa-error-icon)]",border:"border-[var(--tuwa-error-icon)]",fill:"bg-[var(--tuwa-error-icon)]"},replaced:{line:"bg-[var(--tuwa-info-icon)]",border:"border-[var(--tuwa-info-icon)]",fill:"bg-[var(--tuwa-info-icon)]"},active:{line:"bg-[var(--tuwa-pending-icon)]",border:"border-[var(--tuwa-pending-icon)]",fill:"bg-transparent",pulse:"bg-[var(--tuwa-pending-icon)]"},inactive:{line:"bg-[var(--tuwa-border-primary)]",border:"border-[var(--tuwa-border-primary)]",fill:"bg-transparent"}};function Ee({status:t,label:e,isFirst:o=false}){let a=We[t],s=()=>{switch(t){case "completed":return jsxRuntime.jsx(solid.CheckIcon,{className:"h-3 w-3 text-white"});case "error":return jsxRuntime.jsx(solid.ExclamationTriangleIcon,{className:"h-3 w-3 text-white"});case "replaced":return jsxRuntime.jsx(solid.ArrowPathIcon,{className:"h-3 w-3 text-white"});case "active":return jsxRuntime.jsx("div",{className:novaCore.cn("h-2 w-2 animate-pulse rounded-full",a.pulse)});default:return null}};return jsxRuntime.jsxs("div",{className:"relative flex min-w-[80px] flex-1 flex-col items-center",children:[!o&&jsxRuntime.jsx("div",{className:novaCore.cn("absolute right-1/2 top-[10px] h-0.5 w-full",a.line)}),jsxRuntime.jsx("div",{className:novaCore.cn("relative z-10 flex h-5 w-5 items-center justify-center rounded-full border-2",a.border,a.fill),children:s()}),jsxRuntime.jsx("span",{className:novaCore.cn("mt-2 text-center text-xs",t!=="inactive"?"font-semibold text-[var(--tuwa-text-primary)]":"text-[var(--tuwa-text-secondary)]"),children:e})]})}function ht({isProcessing:t,isSucceed:e,isFailed:o,isReplaced:a,className:s,StepComponent:n=Ee}){let{trackingModal:i,statuses:c}=m(),p=react.useMemo(()=>{let l=f=>{if(f===1)return "completed";if(f===2){if(e||o||a)return "completed";if(t)return "active"}if(f===3){if(e)return "completed";if(o)return "error";if(a)return "replaced";if(t)return "active"}return "inactive"},r=f=>f===1?i.progressIndicator.created:f===2?i.progressIndicator.processing:o?c.failed:a?c.replaced:i.progressIndicator.succeed;return [{status:l(1),label:r(1),isFirst:true},{status:l(2),label:r(2)},{status:l(3),label:r(3),isLast:true}]},[t,e,o,a,i,c]);return jsxRuntime.jsx("div",{className:novaCore.cn("flex w-full items-start px-4 pt-2 pb-1",s),children:p.map((l,r)=>jsxRuntime.jsx(n,{...l},r))})}var _e={succeed:{Icon:solid.CheckCircleIcon,className:"text-[var(--tuwa-success-icon)]"},failed:{Icon:solid.ExclamationCircleIcon,className:"text-[var(--tuwa-error-icon)]"},replaced:{Icon:solid.ArrowPathIcon,className:"text-[var(--tuwa-info-icon)]"},processing:{Icon:solid.ArrowPathIcon,className:"animate-spin text-[var(--tuwa-text-accent)]"},initializing:{Icon:solid.ClockIcon,className:"animate-pulse text-[var(--tuwa-pending-icon)]"}};function It({isProcessing:t,isSucceed:e,isFailed:o,isReplaced:a}){let s=e&&"succeed"||o&&"failed"||a&&"replaced"||t&&"processing"||"initializing",{Icon:n,className:i}=_e[s];return jsxRuntime.jsx("div",{className:"flex justify-center py-4",children:jsxRuntime.jsx(n,{className:novaCore.cn("h-16 w-16",i)})})}function Mt({adapters:t,onClose:e,onOpenWalletInfo:o,className:a,customization:s,transactionsPool:n,actions:i,handleTransaction:c,initialTx:p}){let l=react.useMemo(()=>p?.lastTxKey?n[p.lastTxKey]:void 0,[n,p]),r=l??p,f=p?.withTrackedModal&&!l||(l?.isTrackedModalOpen??false),{isProcessing:x,isSucceed:y,isFailed:u,isReplaced:v}=react.useMemo(()=>{let E=l?.status,Jt=p?.isInitializing??false,Gt=l?.pending??false;return {isProcessing:Jt||Gt,isSucceed:E===pulsarCore.TransactionStatus.Success,isFailed:l?.isError||!!p?.errorMessage,isReplaced:E===pulsarCore.TransactionStatus.Replaced}},[l,p]),g=react.useMemo(()=>r?pulsarCore.selectAdapterByKey({adapterKey:r.adapter,adapters:t}):void 0,[r,t]),S=!!(u&&r?.actionKey&&i?.[r.actionKey]&&c),T=!!(g?.speedUpTxAction&&g?.cancelTxAction&&l?.pending),M=()=>{if(!S||!r?.actionKey||!g?.retryTxAction)return;let E={adapter:r.adapter,type:r.type,desiredChainID:"desiredChainID"in r?r.desiredChainID:r.chainId,actionKey:r.actionKey,title:r.title,description:r.description,payload:r.payload,withTrackedModal:true};g.retryTxAction({tx:E,txKey:l?.txKey??"",actions:i,onClose:e,handleTransaction:c});},H=()=>{T&&l&&g.cancelTxAction(l);},R=()=>{T&&l&&g.speedUpTxAction(l);},b=s?.components?.Header,B=s?.components?.Footer,V=s?.components?.StatusVisual,X=s?.components?.ProgressIndicator,ct=s?.components?.InfoBlock,pt=s?.components?.ErrorBlock,$t={initial:{opacity:0,scale:.95},animate:{opacity:1,scale:1},exit:{opacity:0,scale:.95},transition:{duration:.2,ease:"easeOut"},...s?.motionProps};return r?jsxRuntime.jsx(P__namespace.Root,{open:f,onOpenChange:E=>!E&&e(l?.txKey),children:jsxRuntime.jsx(P__namespace.Portal,{children:jsxRuntime.jsx(framerMotion.AnimatePresence,{children:f&&jsxRuntime.jsxs(jsxRuntime.Fragment,{children:[jsxRuntime.jsx(P__namespace.Overlay,{asChild:true,children:jsxRuntime.jsx(framerMotion.motion.div,{className:"fixed inset-0 z-50 bg-black/60",initial:{opacity:0},animate:{opacity:1},exit:{opacity:0}})}),jsxRuntime.jsx(P__namespace.Content,{className:"fixed left-1/2 top-1/2 z-50 w-full max-w-md -translate-x-1/2 -translate-y-1/2 outline-none",...s?.modalProps,asChild:true,children:jsxRuntime.jsx(framerMotion.motion.div,{...$t,children:jsxRuntime.jsxs("div",{className:novaCore.cn("relative flex max-h-[98dvh] w-full flex-col gap-3 overflow-y-auto rounded-2xl bg-[var(--tuwa-bg-primary)] p-5 pt-0 shadow-2xl",a),children:[b?jsxRuntime.jsx(b,{onClose:()=>e(l?.txKey),title:jsxRuntime.jsx(St,{tx:r})}):jsxRuntime.jsx(Ye,{onClose:()=>e(l?.txKey),title:jsxRuntime.jsx(St,{tx:r})}),jsxRuntime.jsxs("main",{className:"flex flex-col gap-3",children:[V?jsxRuntime.jsx(V,{isProcessing:x,isSucceed:y,isFailed:u,isReplaced:v}):jsxRuntime.jsx(It,{isProcessing:x,isSucceed:y,isFailed:u,isReplaced:v}),X?jsxRuntime.jsx(X,{isProcessing:x,isSucceed:y,isFailed:u,isReplaced:v}):jsxRuntime.jsx(ht,{isProcessing:x,isSucceed:y,isFailed:u,isReplaced:v}),ct?jsxRuntime.jsx(ct,{tx:r,adapters:t,transactionsPool:n}):jsxRuntime.jsx(Pt,{tx:r,adapters:t,transactionsPool:n}),pt?jsxRuntime.jsx(pt,{error:l?.errorMessage||p?.errorMessage}):jsxRuntime.jsx(Ct,{error:l?.errorMessage||p?.errorMessage})]}),B?jsxRuntime.jsx(B,{onClose:()=>e(l?.txKey),onOpenWalletInfo:o,isProcessing:x,isFailed:u,canReplace:T,onRetry:S?M:void 0,onSpeedUp:T?R:void 0,onCancel:T?H:void 0}):jsxRuntime.jsx(qe,{onClose:()=>e(l?.txKey),onOpenWalletInfo:o,isProcessing:x,isFailed:u,canReplace:T,onRetry:S?M:void 0,onSpeedUp:T?R:void 0,onCancel:T?H:void 0})]})})})]})})})}):null}var St=({tx:t})=>jsxRuntime.jsx(L,{txStatus:"status"in t?t.status:void 0,source:t.title,fallback:t.type,variant:"title",className:"text-lg"}),Ye=({onClose:t,title:e})=>{let{actions:o}=m();return jsxRuntime.jsxs("header",{className:"sticky top-0 z-10 flex w-full items-start justify-between bg-[var(--tuwa-bg-primary)] pt-5 pb-2",children:[jsxRuntime.jsx(P__namespace.Title,{asChild:true,children:e}),jsxRuntime.jsx(P__namespace.Close,{asChild:true,children:jsxRuntime.jsx("button",{type:"button",onClick:()=>t(),"aria-label":o.close,className:"cursor-pointer -mt-1 ml-2 rounded-full p-1 text-[var(--tuwa-text-tertiary)] transition-colors hover:bg-[var(--tuwa-bg-muted)] hover:text-[var(--tuwa-text-primary)]",children:jsxRuntime.jsx(solid.XMarkIcon,{className:"h-5 w-5"})})})]})},qe=({onClose:t,onOpenWalletInfo:e,isProcessing:o,onRetry:a,onSpeedUp:s,onCancel:n,canReplace:i,isFailed:c})=>{let{trackingModal:p,actions:l}=m(),r=()=>c&&a?jsxRuntime.jsx("button",{type:"button",onClick:a,className:"cursor-pointer rounded-md bg-[var(--tuwa-button-gradient-from)] px-4 py-2 text-sm font-semibold text-[var(--tuwa-text-on-accent)] transition-opacity hover:opacity-90",children:p.retry}):!o&&!i?jsxRuntime.jsx("button",{type:"button",onClick:e,className:"cursor-pointer rounded-md bg-[var(--tuwa-bg-muted)] px-4 py-2 text-sm font-semibold text-[var(--tuwa-text-primary)] transition-colors hover:bg-[var(--tuwa-border-primary)]",children:p.walletInfo}):null;return jsxRuntime.jsxs("footer",{className:"mt-2 flex w-full items-center justify-between border-t border-[var(--tuwa-border-primary)] pt-4",children:[jsxRuntime.jsx("div",{className:"flex items-center gap-4",children:i&&s&&n&&jsxRuntime.jsxs(jsxRuntime.Fragment,{children:[jsxRuntime.jsx("button",{type:"button",onClick:s,className:"cursor-pointer text-sm font-medium text-[var(--tuwa-text-accent)] transition-opacity hover:opacity-80",children:l.speedUp}),jsxRuntime.jsx("button",{type:"button",onClick:n,className:"cursor-pointer text-sm font-medium text-[var(--tuwa-text-secondary)] transition-opacity hover:opacity-80",children:l.cancel})]})}),jsxRuntime.jsxs("div",{className:"flex items-center gap-3",children:[jsxRuntime.jsx(r,{}),jsxRuntime.jsx("button",{type:"button",onClick:t,disabled:o&&!i,className:"cursor-pointer rounded-md bg-[var(--tuwa-bg-muted)] px-4 py-2 text-sm font-semibold text-[var(--tuwa-text-primary)] transition-colors hover:bg-[var(--tuwa-border-primary)] disabled:cursor-not-allowed disabled:opacity-50",children:o&&!i?p.processing:p.close})]})]})};Ht__default.default.extend(je__default.default);var to=({chainId:t})=>jsxRuntime.jsx("div",{className:"h-8 w-8 text-[var(--tuwa-text-secondary)]",children:jsxRuntime.jsx(reactWeb3Icons.Web3Icon,{chainId:t})}),eo=({timestamp:t})=>jsxRuntime.jsx("span",{className:"mb-1 block text-xs text-[var(--tuwa-text-secondary)]",children:t?Ht__default.default.unix(t).fromNow():"..."});function Lt({tx:t,adapters:e,transactionsPool:o,className:a,customization:s}){let{Icon:n=to,Title:i=L,Description:c=L,Timestamp:p=eo,StatusBadge:l=G,TransactionKey:r=U}=s?.components??{};return jsxRuntime.jsxs("div",{className:novaCore.cn("flex flex-col gap-2 border-b border-[var(--tuwa-border-secondary)] p-3 transition-colors hover:bg-[var(--tuwa-bg-secondary)]",a),children:[jsxRuntime.jsxs("div",{className:"flex items-start justify-between",children:[jsxRuntime.jsxs("div",{className:"flex items-center gap-4",children:[jsxRuntime.jsx("div",{className:"flex h-10 w-10 flex-shrink-0 items-center justify-center rounded-full bg-[var(--tuwa-bg-muted)]",children:jsxRuntime.jsx(n,{chainId:t.chainId})}),jsxRuntime.jsxs("div",{children:[jsxRuntime.jsx(i,{txStatus:t.status,source:t.title,fallback:t.type,variant:"title",applyColor:true}),jsxRuntime.jsx(p,{timestamp:t.localTimestamp}),jsxRuntime.jsx(c,{txStatus:t.status,source:t.description,variant:"description"})]})]}),jsxRuntime.jsx(l,{tx:t})]}),jsxRuntime.jsx(r,{tx:t,adapters:e,transactionsPool:o,variant:"history"})]})}function ro({title:t,message:e,className:o}){return jsxRuntime.jsxs("div",{className:novaCore.cn("rounded-lg bg-[var(--tuwa-bg-muted)] p-8 text-center",o),children:[jsxRuntime.jsx("h4",{className:"font-semibold text-[var(--tuwa-text-primary)]",children:t}),jsxRuntime.jsx("p",{className:"mt-1 text-sm text-[var(--tuwa-text-secondary)]",children:e})]})}function Dt({adapters:t,connectedWalletAddress:e,transactionsPool:o,className:a,customization:s}){let{walletModal:n}=m(),i=react.useMemo(()=>e?pulsarCore.selectAllTransactionsByActiveWallet(o,e).sort((f,x)=>(x.localTimestamp??0)-(f.localTimestamp??0)):[],[o,e]),{Placeholder:c=ro,HistoryItem:p=Lt}=s?.components??{},l=()=>e?i.length>0?jsxRuntime.jsx("div",{className:novaCore.cn("max-h-[400px] overflow-y-auto rounded-lg border border-[var(--tuwa-border-primary)] bg-[var(--tuwa-bg-primary)]",s?.classNames?.listWrapper),children:i.map(r=>jsxRuntime.jsx(p,{tx:r,transactionsPool:o,adapters:t},r.txKey))}):jsxRuntime.jsx(c,{title:n.history.noTransactionsTitle,message:n.history.noTransactionsMessage}):jsxRuntime.jsx(c,{title:n.history.connectWalletTitle,message:n.history.connectWalletMessage});return jsxRuntime.jsxs("div",{className:novaCore.cn("flex flex-col gap-y-3",a),children:[jsxRuntime.jsx("h3",{className:"text-lg font-bold text-[var(--tuwa-text-primary)]",children:n.history.title}),l()]})}function st({address:t,explorerUrl:e,className:o}){let{isCopied:a,copy:s}=novaCore.useCopyToClipboard(),{actions:n,txError:i}=m(),c=react.useMemo(()=>e&&t?`${e}/address/${t}`:void 0,[e,t]);return jsxRuntime.jsxs("div",{className:novaCore.cn("flex items-center gap-x-3 rounded-full bg-[var(--tuwa-bg-muted)] px-3 py-1 font-mono text-xs text-[var(--tuwa-text-secondary)]",o),children:[jsxRuntime.jsx("span",{children:novaCore.textCenterEllipsis(t,6,6)}),jsxRuntime.jsx("button",{type:"button",title:a?i.copied:n.copy,"aria-label":a?i.copied:`${n.copy} address`,onClick:()=>s(t),className:"cursor-pointer transition-colors hover:text-[var(--tuwa-text-primary)]",children:a?jsxRuntime.jsx(solid.CheckIcon,{className:"h-4 w-4 text-[var(--tuwa-success-icon)]"}):jsxRuntime.jsx(solid.DocumentDuplicateIcon,{className:"h-4 w-4"})}),c&&jsxRuntime.jsx("a",{href:c,target:"_blank",rel:"noopener noreferrer",className:"transition-colors hover:text-[var(--tuwa-text-accent)]",title:n.viewOnExplorer,"aria-label":n.viewOnExplorer,children:jsxRuntime.jsx(solid.ArrowTopRightOnSquareIcon,{className:"h-4 w-4"})})]})}function Ot({address:t,ensAvatar:e,className:o}){let{walletModal:a}=m(),[s,n]=react.useState(e),i=react.useMemo(()=>To__default.default(viem.isHex(t)?t:viem.zeroAddress),[t]),c=react.useMemo(()=>`#${t.slice(2,8)}`,[t]);react.useEffect(()=>{n(e);},[e]);let p=()=>{n(i);};return jsxRuntime.jsx("div",{className:novaCore.cn("h-12 w-12 flex-shrink-0 rounded-full",o),style:{backgroundColor:c},children:jsxRuntime.jsx("img",{className:"h-full w-full rounded-full object-cover",src:s||i,alt:`${a.header.avatarAlt} ${t}`,onError:p},e)})}var Po=({isLoading:t,ensName:e,walletAddress:o,explorerUrl:a,renderAddressDisplay:s})=>jsxRuntime.jsxs("div",{className:"flex flex-col",children:[jsxRuntime.jsx("div",{className:"mb-1.5 flex h-7 items-center",children:t?jsxRuntime.jsx("div",{className:"h-full w-48 animate-pulse rounded-md bg-[var(--tuwa-bg-muted)]"}):e?jsxRuntime.jsx("h2",{className:"text-xl font-bold text-[var(--tuwa-text-primary)]",children:e}):jsxRuntime.jsx(st,{address:o,explorerUrl:a,className:"rounded-none bg-transparent px-0 py-0 text-xl font-bold text-[var(--tuwa-text-primary)]"})}),jsxRuntime.jsx("div",{className:"flex h-5 items-center",children:!t&&e&&(s?s({address:o,explorerUrl:a}):jsxRuntime.jsx(st,{address:o,explorerUrl:a}))})]});function Ft({walletAddress:t,adapters:e,connectedAdapterType:o,className:a,renderAvatar:s,renderName:n,renderAddressDisplay:i,renderNoWalletContent:c,explorerUrl:p}){let{walletModal:l}=m(),[r,f]=react.useState(null),[x,y]=react.useState(null),[u,v]=react.useState(true);if(react.useEffect(()=>{(async()=>{if(!t||!o){v(false);return}let T=pulsarCore.selectAdapterByKey({adapterKey:o,adapters:e}),M=T&&"getName"in T&&typeof T.getName=="function",H=T&&"getAvatar"in T&&typeof T.getAvatar=="function";if(!M){v(false);return}v(true),f(null),y(null);try{let R=T?.getName?await T.getName(t):null;if(R&&(f(R),H)){let b=T?.getAvatar?await T.getAvatar(R):null;y(b);}}catch(R){console.error("Failed to fetch name service data:",R);}finally{v(false);}})();},[t,e,o]),!t)return c?jsxRuntime.jsx(jsxRuntime.Fragment,{children:c()}):jsxRuntime.jsx("div",{className:novaCore.cn("flex h-20 items-center justify-center rounded-lg bg-[var(--tuwa-bg-muted)] text-[var(--tuwa-text-secondary)]",a),children:l.header.notConnected});let g=r?r.length>30?novaCore.textCenterEllipsis(r,12,12):r:void 0;return jsxRuntime.jsxs("div",{className:novaCore.cn("flex min-h-[4rem] items-center gap-4",a),children:[jsxRuntime.jsx("div",{children:s?s({address:t,ensAvatar:x}):jsxRuntime.jsx(Ot,{address:t,ensAvatar:x})}),jsxRuntime.jsx("div",{className:"flex min-h-[3.5rem] min-w-[200px] flex-col justify-center",children:n?n({ensName:g,isLoading:u,address:t}):jsxRuntime.jsx(Po,{isLoading:u,ensName:g,walletAddress:t,explorerUrl:p,renderAddressDisplay:i})})]})}var So=({closeModal:t,title:e})=>{let{actions:o}=m();return jsxRuntime.jsxs("div",{className:"sticky top-0 left-0 z-10 flex w-full items-center justify-between border-b border-[var(--tuwa-border-primary)] bg-[var(--tuwa-bg-secondary)] p-4",children:[jsxRuntime.jsx(P__namespace.Title,{className:"text-lg font-bold text-[var(--tuwa-text-primary)]",children:e}),jsxRuntime.jsx(P__namespace.Close,{asChild:true,children:jsxRuntime.jsx("button",{type:"button",onClick:t,"aria-label":o.close,className:"cursor-pointer rounded-full p-1 text-[var(--tuwa-text-tertiary)] transition-colors hover:bg-[var(--tuwa-bg-muted)] hover:text-[var(--tuwa-text-primary)]",children:jsxRuntime.jsx(solid.XMarkIcon,{className:"h-6 w-6"})})})]})};function _t({isOpen:t,setIsOpen:e,customization:o,adapters:a,connectedAdapterType:s,connectedWalletAddress:n,transactionsPool:i}){let{walletModal:c}=m(),{explorerUrl:p}=react.useMemo(()=>s?{explorerUrl:pulsarCore.selectAdapterByKey({adapterKey:s,adapters:a})?.getExplorerUrl()}:{explorerUrl:void 0},[s,a]),l=()=>e(false),f={...{initial:{opacity:0,scale:.95},animate:{opacity:1,scale:1},exit:{opacity:0,scale:.95},transition:{duration:.2,ease:"easeOut"}},...o?.motionProps},x=o?.components?.Header,y=o?.components?.WalletInfo,u=o?.components?.History;return jsxRuntime.jsx(P__namespace.Root,{open:t,onOpenChange:v=>!v&&l(),children:jsxRuntime.jsx(P__namespace.Portal,{children:jsxRuntime.jsx(framerMotion.AnimatePresence,{children:t&&jsxRuntime.jsxs(jsxRuntime.Fragment,{children:[jsxRuntime.jsx(P__namespace.Overlay,{asChild:true,children:jsxRuntime.jsx(framerMotion.motion.div,{className:"fixed inset-0 z-50 bg-black/45",initial:{opacity:0},animate:{opacity:1},exit:{opacity:0},transition:{duration:.15}})}),jsxRuntime.jsx(P__namespace.Content,{className:"fixed left-1/2 top-1/2 z-50 w-full max-w-2xl -translate-x-1/2 -translate-y-1/2 outline-none",...o?.modalProps,asChild:true,children:jsxRuntime.jsx(framerMotion.motion.div,{...f,children:jsxRuntime.jsxs("div",{className:novaCore.cn("relative max-h-[98dvh] w-full max-w-2xl overflow-y-auto rounded-2xl bg-[var(--tuwa-bg-secondary)] shadow-xl outline-none",o?.classNames?.contentWrapper),children:[x?jsxRuntime.jsx(x,{closeModal:l}):jsxRuntime.jsx(So,{closeModal:l,title:c.title}),jsxRuntime.jsxs("div",{className:"flex flex-col gap-4 p-4 sm:gap-6 sm:p-6",children:[y?jsxRuntime.jsx(y,{adapters:a,connectedAdapterType:s,walletAddress:n,explorerUrl:p}):jsxRuntime.jsx(Ft,{adapters:a,connectedAdapterType:s,walletAddress:n,explorerUrl:p}),u?jsxRuntime.jsx(u,{adapters:a,transactionsPool:i,connectedWalletAddress:n}):jsxRuntime.jsx(Dt,{adapters:a,transactionsPool:i,connectedWalletAddress:n})]})]})})})]})})})})}var Eo={[pulsarCore.TransactionStatus.Success]:"success",[pulsarCore.TransactionStatus.Failed]:"error",[pulsarCore.TransactionStatus.Replaced]:"info"};function ri({adapters:t,connectedWalletAddress:e,connectedAdapterType:o,transactionsPool:a,initialTx:s,handleTransaction:n,closeTxTrackedModal:i,actions:c,labels:p,features:l,customization:r,...f}){let[x,y]=react.useState(false),u=react.useRef(a),v=novaCore.useMediaQuery("(max-width: 767px)"),g=react.useMemo(()=>({toasts:l?.toasts??true,walletInfoModal:l?.walletInfoModal??true,trackingTxModal:l?.trackingTxModal??true}),[l]),S=react.useMemo(()=>novaCore.deepMerge($,p||{}),[p]);react.useEffect(()=>{if(!g.toasts)return;let H=b=>{let B=b.pending?"info":Eo[b.status]??"info",V=X=>jsxRuntime.jsx(wt,{...X,transactionsPool:a,tx:b,openWalletInfoModal:g.walletInfoModal?()=>y(true):void 0,customization:r?.toast,adapters:t,connectedWalletAddress:e});reactToastify.toast.isActive(b.txKey)?reactToastify.toast.update(b.txKey,{render:V,type:B}):reactToastify.toast(V,{toastId:b.txKey,type:B,closeOnClick:false});},R=u.current;Object.values(a).forEach(b=>{let B=R[b.txKey];if(!B){b.pending&&H(b);return}JSON.stringify(B)!==JSON.stringify(b)&&H(b);}),u.current=a;},[a,t,r?.toast,g,e]);let T=!!s?.withTrackedModal&&a[s?.lastTxKey??""]?.isTrackedModalOpen,M=g.toasts&&(!v||!T&&!x);return jsxRuntime.jsxs(mt,{labels:S,children:[M&&jsxRuntime.jsx(reactToastify.ToastContainer,{position:"bottom-right",stacked:true,autoClose:false,hideProgressBar:true,closeOnClick:false,icon:false,closeButton:vt,toastClassName:"!p-0 !bg-transparent !shadow-none !min-h-0",...f}),g.walletInfoModal&&jsxRuntime.jsx(_t,{transactionsPool:a,isOpen:x,setIsOpen:y,customization:r?.walletInfoModal,adapters:t,connectedWalletAddress:e,connectedAdapterType:o}),g.trackingTxModal&&jsxRuntime.jsx(Mt,{initialTx:s,onClose:i,onOpenWalletInfo:()=>y(true),transactionsPool:a,customization:r?.trackingTxModal,actions:c,handleTransaction:n,adapters:t})]})}exports.LabelsProvider=mt;exports.NovaProvider=ri;exports.useLabels=m;//# sourceMappingURL=index.cjs.map
|
2
2
|
//# sourceMappingURL=index.cjs.map
|