@tuwaio/nova-transactions 0.2.6 → 0.3.0
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 +61 -60
- package/dist/{TransactionsInfoModal-DSBueMY4.d.cts → TransactionsInfoModal-D7eykTZp.d.cts} +3 -6
- package/dist/{TransactionsInfoModal-DSBueMY4.d.ts → TransactionsInfoModal-D7eykTZp.d.ts} +3 -6
- package/dist/chunk-IUJ7P7EE.cjs +1 -0
- package/dist/chunk-PUSPAQGZ.js +1 -0
- package/dist/index.cjs +1 -1
- package/dist/index.css +11 -13
- package/dist/index.d.cts +2 -2
- package/dist/index.d.ts +2 -2
- package/dist/index.js +1 -1
- package/dist/providers/index.cjs +1 -1
- package/dist/providers/index.d.cts +2 -2
- package/dist/providers/index.d.ts +2 -2
- package/dist/providers/index.js +1 -1
- package/package.json +14 -14
- package/dist/chunk-B3JQWEZF.cjs +0 -1
- package/dist/chunk-QZL22XK4.js +0 -1
package/README.md
CHANGED
|
@@ -16,10 +16,10 @@ This package provides the **View Layer** for TUWA's transaction tracking ecosyst
|
|
|
16
16
|
|
|
17
17
|
## ✨ Core Features
|
|
18
18
|
|
|
19
|
-
-
|
|
20
|
-
-
|
|
21
|
-
-
|
|
22
|
-
-
|
|
19
|
+
- **🧩 Pre-built UI Suite:** A set of accessible components including `TrackingTxModal`, `TransactionsInfoModal`, and `ToastTransaction`, all managed internally by the `NovaTransactionsProvider`.
|
|
20
|
+
- **🔌 Plug-and-Play Integration:** Once connected to your Pulsar store, the UI automatically reacts to all transaction state changes.
|
|
21
|
+
- **🌐 Internationalization (custom version of i18n):** Built-in support for multiple languages with easy overrides for all text content via the `labels` prop.
|
|
22
|
+
- **🎨 Highly Customizable:** Styled with `@tuwaio/nova-core` to be easily themed using CSS variables. Almost every sub-component can be replaced with your own implementation via the `customization` prop.
|
|
23
23
|
|
|
24
24
|
---
|
|
25
25
|
|
|
@@ -28,12 +28,15 @@ This package provides the **View Layer** for TUWA's transaction tracking ecosyst
|
|
|
28
28
|
### Basic Installation
|
|
29
29
|
|
|
30
30
|
Install the main package:
|
|
31
|
+
|
|
31
32
|
```bash
|
|
32
33
|
pnpm add @tuwaio/nova-transactions
|
|
33
34
|
```
|
|
35
|
+
|
|
34
36
|
### Peer Dependencies
|
|
35
37
|
|
|
36
38
|
This package requires several peer dependencies for UI rendering:
|
|
39
|
+
|
|
37
40
|
```bash
|
|
38
41
|
# Core dependencies
|
|
39
42
|
pnpm add @tuwaio/nova-core @tuwaio/pulsar-core @tuwaio/orbit-core
|
|
@@ -52,16 +55,12 @@ pnpm add dayjs clsx tailwind-merge
|
|
|
52
55
|
### Complete Installation (All Packages)
|
|
53
56
|
|
|
54
57
|
For a complete setup with all TUWA packages:
|
|
58
|
+
|
|
55
59
|
```bash
|
|
56
|
-
# Using pnpm (recommended)
|
|
60
|
+
# Using pnpm (recommended), but you can use npm, yarn or bun as well
|
|
57
61
|
pnpm add @tuwaio/nova-transactions @tuwaio/nova-core @tuwaio/pulsar-core @tuwaio/orbit-core react-toastify framer-motion @radix-ui/react-dialog @heroicons/react @web3icons/common @web3icons/react dayjs react immer zustand clsx tailwind-merge
|
|
58
|
-
|
|
59
|
-
# Using npm
|
|
60
|
-
npm install @tuwaio/nova-transactions @tuwaio/nova-core @tuwaio/pulsar-core @tuwaio/orbit-core react-toastify framer-motion @radix-ui/react-dialog @heroicons/react @web3icons/common @web3icons/react dayjs react immer zustand clsx tailwind-merge
|
|
61
|
-
|
|
62
|
-
# Using yarn
|
|
63
|
-
yarn add @tuwaio/nova-transactions @tuwaio/nova-core @tuwaio/pulsar-core @tuwaio/orbit-core react-toastify framer-motion @radix-ui/react-dialog @heroicons/react @web3icons/common @web3icons/react dayjs react immer zustand clsx tailwind-merge
|
|
64
62
|
```
|
|
63
|
+
|
|
65
64
|
---
|
|
66
65
|
|
|
67
66
|
## 🚀 Getting Started
|
|
@@ -71,6 +70,7 @@ To use this library, you must render the `<NovaTransactionsProvider />` componen
|
|
|
71
70
|
Here is a complete example of a `src/providers/index.tsx` file that configures the entire system.
|
|
72
71
|
|
|
73
72
|
### 1. Create Transaction Store
|
|
73
|
+
|
|
74
74
|
```tsx
|
|
75
75
|
// src/hooks/txTrackingHooks.tsx
|
|
76
76
|
import { createBoundedUseStore, createPulsarStore } from '@tuwaio/pulsar-core';
|
|
@@ -85,23 +85,24 @@ export enum TxType {
|
|
|
85
85
|
}
|
|
86
86
|
|
|
87
87
|
type ExampleTx = Transaction & {
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
88
|
+
type: TxType.example;
|
|
89
|
+
payload: {
|
|
90
|
+
value: number;
|
|
91
|
+
};
|
|
92
92
|
};
|
|
93
93
|
|
|
94
94
|
export type TransactionUnion = ExampleTx;
|
|
95
95
|
|
|
96
96
|
export const usePulsarStore = createBoundedUseStore(
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
|
|
97
|
+
createPulsarStore<TransactionUnion>({
|
|
98
|
+
name: storageName,
|
|
99
|
+
adapter: evmAdapter(config, appChains),
|
|
100
|
+
}),
|
|
101
101
|
);
|
|
102
102
|
```
|
|
103
103
|
|
|
104
104
|
### 2. Setup Provider Component
|
|
105
|
+
|
|
105
106
|
```tsx
|
|
106
107
|
// src/providers/NovaTransactionsProvider.tsx
|
|
107
108
|
import { NovaTransactionsProvider as NP } from '@tuwaio/nova-transactions/providers';
|
|
@@ -112,35 +113,35 @@ import { useAccount } from 'wagmi';
|
|
|
112
113
|
import { usePulsarStore } from '@/hooks/txTrackingHooks';
|
|
113
114
|
|
|
114
115
|
export function NovaTransactionsProvider() {
|
|
115
|
-
const transactionsPool = usePulsarStore((state) => state.transactionsPool);
|
|
116
|
-
const initialTx = usePulsarStore((state) => state.initialTx);
|
|
117
|
-
const closeTxTrackedModal = usePulsarStore((state) => state.closeTxTrackedModal);
|
|
118
|
-
const handleTransaction = usePulsarStore((state) => state.handleTransaction);
|
|
119
|
-
const initializeTransactionsPool = usePulsarStore((state) => state.initializeTransactionsPool);
|
|
120
|
-
const getAdapter = usePulsarStore((state) => state.getAdapter);
|
|
116
|
+
const transactionsPool = usePulsarStore((state) => state.transactionsPool);
|
|
117
|
+
const initialTx = usePulsarStore((state) => state.initialTx);
|
|
118
|
+
const closeTxTrackedModal = usePulsarStore((state) => state.closeTxTrackedModal);
|
|
119
|
+
const handleTransaction = usePulsarStore((state) => state.handleTransaction);
|
|
120
|
+
const initializeTransactionsPool = usePulsarStore((state) => state.initializeTransactionsPool);
|
|
121
|
+
const getAdapter = usePulsarStore((state) => state.getAdapter);
|
|
121
122
|
|
|
122
|
-
useInitializeTransactionsPool({ initializeTransactionsPool });
|
|
123
|
+
useInitializeTransactionsPool({ initializeTransactionsPool });
|
|
123
124
|
|
|
124
|
-
const { address } = useAccount();
|
|
125
|
+
const { address } = useAccount();
|
|
125
126
|
|
|
126
|
-
return (
|
|
127
|
+
return (
|
|
127
128
|
<NP
|
|
128
|
-
|
|
129
|
-
|
|
130
|
-
|
|
131
|
-
|
|
132
|
-
|
|
133
|
-
|
|
134
|
-
|
|
129
|
+
transactionsPool={transactionsPool}
|
|
130
|
+
initialTx={initialTx}
|
|
131
|
+
closeTxTrackedModal={closeTxTrackedModal}
|
|
132
|
+
handleTransaction={handleTransaction}
|
|
133
|
+
connectedWalletAddress={address}
|
|
134
|
+
connectedAdapterType={TransactionAdapter.EVM}
|
|
135
|
+
adapter={getAdapter()}
|
|
135
136
|
/>
|
|
136
137
|
);
|
|
137
138
|
}
|
|
138
|
-
|
|
139
139
|
```
|
|
140
|
+
|
|
140
141
|
### 3. Integrate into App
|
|
142
|
+
|
|
141
143
|
```tsx
|
|
142
144
|
// src/providers/index.tsx
|
|
143
|
-
import { RainbowKitProvider } from '@rainbow-me/rainbowkit';
|
|
144
145
|
import { QueryClient, QueryClientProvider } from '@tanstack/react-query';
|
|
145
146
|
import { ReactNode } from 'react';
|
|
146
147
|
import { WagmiProvider } from 'wagmi';
|
|
@@ -152,41 +153,41 @@ import { NovaTransactionsProvider } from './NovaTransactionsProvider';
|
|
|
152
153
|
const queryClient = new QueryClient();
|
|
153
154
|
|
|
154
155
|
export function Providers({ children }: { children: ReactNode }) {
|
|
155
|
-
|
|
156
|
-
|
|
157
|
-
|
|
158
|
-
|
|
159
|
-
|
|
160
|
-
|
|
161
|
-
|
|
162
|
-
|
|
163
|
-
</WagmiProvider>
|
|
164
|
-
);
|
|
156
|
+
return (
|
|
157
|
+
<WagmiProvider config={config}>
|
|
158
|
+
<QueryClientProvider client={queryClient}>
|
|
159
|
+
<NovaTransactionsProvider />
|
|
160
|
+
{children}
|
|
161
|
+
</QueryClientProvider>
|
|
162
|
+
</WagmiProvider>
|
|
163
|
+
);
|
|
165
164
|
}
|
|
166
165
|
```
|
|
167
166
|
|
|
168
167
|
## 🎨 Customization
|
|
169
168
|
|
|
170
169
|
You can easily override the default English text by passing a `labels` prop, or replace entire components using the `customization` prop.
|
|
170
|
+
|
|
171
171
|
```tsx
|
|
172
172
|
<NovaTransactionsProvider
|
|
173
|
-
|
|
174
|
-
|
|
175
|
-
|
|
176
|
-
|
|
177
|
-
|
|
178
|
-
|
|
179
|
-
|
|
173
|
+
// 1. Override text labels
|
|
174
|
+
labels={{
|
|
175
|
+
statuses: {
|
|
176
|
+
pending: 'В обработке...',
|
|
177
|
+
success: 'Успешно!',
|
|
178
|
+
failed: 'Ошибка!',
|
|
179
|
+
},
|
|
180
180
|
// ... other keys
|
|
181
|
-
|
|
182
|
-
|
|
183
|
-
|
|
184
|
-
|
|
185
|
-
}
|
|
186
|
-
}
|
|
181
|
+
}}
|
|
182
|
+
customization={{
|
|
183
|
+
components: {
|
|
184
|
+
statusBadge: ({ tx }) => <MyCustomBadge status={tx.status} />,
|
|
185
|
+
},
|
|
186
|
+
}}
|
|
187
187
|
// ... other required props
|
|
188
188
|
/>
|
|
189
189
|
```
|
|
190
|
+
|
|
190
191
|
---
|
|
191
192
|
|
|
192
193
|
## 🤝 Contributing & Support
|
|
@@ -2,7 +2,7 @@ import * as react_jsx_runtime from 'react/jsx-runtime';
|
|
|
2
2
|
import { ToastCloseButtonProps, DialogContent } from '@tuwaio/nova-core';
|
|
3
3
|
import { TransactionStatus, Transaction, TxAdapter, TransactionPool, ITxTrackingStore, InitialTransaction } from '@tuwaio/pulsar-core';
|
|
4
4
|
import { ReactNode, ComponentType, JSX, ComponentPropsWithoutRef } from 'react';
|
|
5
|
-
import { OrbitAdapter } from '@tuwaio/orbit-core';
|
|
5
|
+
import { OrbitAdapter, TuwaErrorState } from '@tuwaio/orbit-core';
|
|
6
6
|
import { ToastContainerProps, ToastContentProps } from 'react-toastify';
|
|
7
7
|
import { MotionProps } from 'framer-motion';
|
|
8
8
|
|
|
@@ -410,9 +410,6 @@ type TrackingTxModalProps<T extends Transaction> = Pick<NovaTransactionsProvider
|
|
|
410
410
|
};
|
|
411
411
|
declare function TrackingTxModal<T extends Transaction>({ adapter, onClose, onOpenAllTransactions, className, customization, transactionsPool, executeTxAction, initialTx, connectedWalletAddress, }: TrackingTxModalProps<T>): react_jsx_runtime.JSX.Element | null;
|
|
412
412
|
|
|
413
|
-
/**
|
|
414
|
-
* @file This file contains the `TxErrorBlock` component for displaying transaction error messages.
|
|
415
|
-
*/
|
|
416
413
|
type TxErrorBlockClassNames = {
|
|
417
414
|
/** Classes for the container */
|
|
418
415
|
container?: string;
|
|
@@ -430,8 +427,8 @@ type TxErrorBlockClassNames = {
|
|
|
430
427
|
messageText?: string;
|
|
431
428
|
};
|
|
432
429
|
type TxErrorBlockProps = {
|
|
433
|
-
/** The error
|
|
434
|
-
error?: string;
|
|
430
|
+
/** The error to display. Can be a string or a TuwaErrorState. If undefined or empty, the component renders nothing. */
|
|
431
|
+
error?: string | TuwaErrorState;
|
|
435
432
|
/** Optional additional CSS classes for the container. */
|
|
436
433
|
className?: string;
|
|
437
434
|
/** Granular classNames for sub-elements */
|
|
@@ -2,7 +2,7 @@ import * as react_jsx_runtime from 'react/jsx-runtime';
|
|
|
2
2
|
import { ToastCloseButtonProps, DialogContent } from '@tuwaio/nova-core';
|
|
3
3
|
import { TransactionStatus, Transaction, TxAdapter, TransactionPool, ITxTrackingStore, InitialTransaction } from '@tuwaio/pulsar-core';
|
|
4
4
|
import { ReactNode, ComponentType, JSX, ComponentPropsWithoutRef } from 'react';
|
|
5
|
-
import { OrbitAdapter } from '@tuwaio/orbit-core';
|
|
5
|
+
import { OrbitAdapter, TuwaErrorState } from '@tuwaio/orbit-core';
|
|
6
6
|
import { ToastContainerProps, ToastContentProps } from 'react-toastify';
|
|
7
7
|
import { MotionProps } from 'framer-motion';
|
|
8
8
|
|
|
@@ -410,9 +410,6 @@ type TrackingTxModalProps<T extends Transaction> = Pick<NovaTransactionsProvider
|
|
|
410
410
|
};
|
|
411
411
|
declare function TrackingTxModal<T extends Transaction>({ adapter, onClose, onOpenAllTransactions, className, customization, transactionsPool, executeTxAction, initialTx, connectedWalletAddress, }: TrackingTxModalProps<T>): react_jsx_runtime.JSX.Element | null;
|
|
412
412
|
|
|
413
|
-
/**
|
|
414
|
-
* @file This file contains the `TxErrorBlock` component for displaying transaction error messages.
|
|
415
|
-
*/
|
|
416
413
|
type TxErrorBlockClassNames = {
|
|
417
414
|
/** Classes for the container */
|
|
418
415
|
container?: string;
|
|
@@ -430,8 +427,8 @@ type TxErrorBlockClassNames = {
|
|
|
430
427
|
messageText?: string;
|
|
431
428
|
};
|
|
432
429
|
type TxErrorBlockProps = {
|
|
433
|
-
/** The error
|
|
434
|
-
error?: string;
|
|
430
|
+
/** The error to display. Can be a string or a TuwaErrorState. If undefined or empty, the component renders nothing. */
|
|
431
|
+
error?: string | TuwaErrorState;
|
|
435
432
|
/** Optional additional CSS classes for the container. */
|
|
436
433
|
className?: string;
|
|
437
434
|
/** Granular classNames for sub-elements */
|
|
@@ -0,0 +1 @@
|
|
|
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'),orbitCore=require('@tuwaio/orbit-core'),Vt=require('dayjs'),eo=require('dayjs/plugin/relativeTime');function _interopDefault(e){return e&&e.__esModule?e:{default:e}}var Vt__default=/*#__PURE__*/_interopDefault(Vt);var eo__default=/*#__PURE__*/_interopDefault(eo);var Z={transactionsModal:{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:{openTransactionsInfo:"Open transactions"},statuses:{pending:"Pending",success:"Success",failed:"Failed",reverted:"Reverted",replaced:"Replaced",unknown:"Unknown",confirmationsLabel:"Confirmations"},hashLabels:{gelato:"Gelato Task ID",safe:"Safe Tx Hash",original:"Original Tx Hash",replaced:"Replaced Tx Hash",default:"Tx Hash",recentBlockhash:"Recent Blockhash",solana:"Signature"},txInfo:{started:"Started",network:"Network",slot:"Slot"},txError:{title:"Error",copied:"Copied!"},trackingModal:{title:"Transaction Overview",processing:"Processing...",close:"Close",allTransactions:"All transactions",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 wt=react.createContext(Z),Pt=({labels:t,children:a})=>jsxRuntime.jsx(wt.Provider,{value:t,children:a}),g=()=>react.useContext(wt);function Y({label:t,hash:a,explorerUrl:n,variant:r="default",className:o,classNames:l}){let{isCopied:c,copy:i}=novaCore.useCopyToClipboard(),{actions:p,txError:s}=g(),e=novaCore.cn("novatx:flex novatx:items-center novatx:justify-between",{"novatx:text-sm":r==="default","novatx:text-xs":r==="compact"},o),x=novaCore.cn("novatx:pr-1",{"novatx:font-bold novatx:text-[var(--tuwa-text-primary)]":r==="default","novatx:font-medium novatx:text-[var(--tuwa-text-secondary)]":r==="compact"},l?.label),u=jsxRuntime.jsx("span",{className:novaCore.cn("novatx:font-mono",l?.hash),children:novaCore.textCenterEllipsis(a,5,5)});return jsxRuntime.jsxs("div",{className:e,children:[t&&jsxRuntime.jsxs("span",{className:x,children:[t,":"]}),jsxRuntime.jsxs("div",{className:"novatx:flex novatx:items-center novatx:gap-x-2",children:[n?jsxRuntime.jsxs("a",{href:n,target:"_blank",rel:"noopener noreferrer",className:novaCore.cn("novatx:flex novatx:items-center novatx:gap-x-1 novatx:text-[var(--tuwa-text-accent)] novatx:transition-colors novatx:hover:underline",l?.link),title:p.viewOnExplorer,"aria-label":p.viewOnExplorer,children:[u,jsxRuntime.jsx(solid.ArrowTopRightOnSquareIcon,{className:novaCore.cn("novatx:h-4 novatx:w-4",l?.linkIcon)})]}):jsxRuntime.jsx("span",{className:novaCore.cn("novatx:text-[var(--tuwa-text-primary)]",l?.link),children:u}),jsxRuntime.jsx("button",{type:"button",onClick:()=>i(a),className:novaCore.cn("novatx:cursor-pointer novatx:text-[var(--tuwa-text-tertiary)] novatx:transition-colors novatx:hover:text-[var(--tuwa-text-secondary)]",l?.copyButton),title:c?s.copied:p.copy,"aria-label":c?s.copied:p.copy,children:c?jsxRuntime.jsx(solid.CheckIcon,{className:"novatx:h-4 novatx:w-4 novatx:text-[var(--tuwa-success-icon)]"}):jsxRuntime.jsx(solid.DocumentDuplicateIcon,{className:"novatx:h-4 novatx:w-4"})})]})]})}var kt={[pulsarCore.TransactionStatus.Success]:{index:1,colorClass:"novatx:text-[var(--tuwa-success-text)]"},[pulsarCore.TransactionStatus.Failed]:{index:2,colorClass:"novatx:text-[var(--tuwa-error-text)]"},[pulsarCore.TransactionStatus.Replaced]:{index:3,colorClass:"novatx:text-[var(--tuwa-text-secondary)]"},default:{index:0,colorClass:"novatx:text-[var(--tuwa-text-primary)]"}};function O({txStatus:t,source:a,fallback:n,variant:r,className:o,applyColor:l=false}){let c,i="";if(typeof a=="string")c=a;else if(Array.isArray(a)){let e=kt[t||"default"]??kt.default;c=a[e.index],l&&(i=e.colorClass);}else c=n;return c?jsxRuntime.jsx("div",{className:novaCore.cn(r==="title"?"novatx:text-sm novatx:font-semibold novatx:text-[var(--tuwa-text-primary)]":"novatx:mt-1 novatx:text-xs novatx:text-[var(--tuwa-text-secondary)]",i,o),children:c}):null}function V({tx:t,adapter:a,variant:n="toast",className:r,renderHashLink:o,confirmations:l,hashLinkClassNames:c,originalHashLinkClassNames:i}){let{hashLabels:p,statuses:s}=g(),e=orbitCore.selectAdapterByKey({adapterKey:t.adapter,adapter:a});if(!e)return null;let x=(T,f)=>o?o(T):jsxRuntime.jsx(Y,{...T,classNames:f??c}),u=n==="toast"?"novatx:mt-2 novatx:flex novatx:w-full novatx:flex-col novatx:gap-y-2 novatx:border-t novatx:border-[var(--tuwa-border-primary)] novatx:pt-2":"novatx:flex novatx:w-full novatx:flex-col novatx:gap-y-2",m=p[String(t.tracker)],N=m?x({label:m,hash:t.txKey,variant:t.tracker!==pulsarCore.TransactionTracker.Solana?"compact":"default",explorerUrl:e.getExplorerTxUrl&&t.tracker===pulsarCore.TransactionTracker.Solana?e?.getExplorerTxUrl(t):void 0}):null,y=(()=>{let T=t.hash,f=t.replacedTxHash;return !T&&!f?null:f?jsxRuntime.jsxs(jsxRuntime.Fragment,{children:[T&&x({label:p.original,hash:T,variant:"compact"},i),typeof e.getExplorerTxUrl<"u"&&x({label:p.replaced,hash:f,explorerUrl:e.getExplorerTxUrl(t)})]}):T&&typeof e.getExplorerTxUrl<"u"&&x({label:p.default,hash:T,explorerUrl:e.getExplorerTxUrl(t)})})(),C=m&&m!==p.default&&t.txKey!==t.hash;return jsxRuntime.jsxs("div",{className:novaCore.cn(u,r),children:[C&&N,y,typeof l=="number"&&jsxRuntime.jsxs("p",{className:"novatx:text-xs novatx:text-[var(--tuwa-text-tertiary)]",children:[s.confirmationsLabel,": ",l]})]})}var va=t=>({Pending:{label:t.pending,Icon:solid.ArrowPathIcon,badgeClasses:"novatx:bg-[var(--tuwa-pending-bg)] novatx:text-[var(--tuwa-pending-text)]",iconClasses:"novatx:animate-spin novatx:text-[var(--tuwa-pending-icon)]"},[pulsarCore.TransactionStatus.Success]:{label:t.success,Icon:solid.CheckCircleIcon,badgeClasses:"novatx:bg-[var(--tuwa-success-bg)] novatx:text-[var(--tuwa-success-text)]",iconClasses:"novatx:text-[var(--tuwa-success-icon)]"},[pulsarCore.TransactionStatus.Failed]:{label:t.failed,Icon:solid.XCircleIcon,badgeClasses:"novatx:bg-[var(--tuwa-error-bg)] novatx:text-[var(--tuwa-error-text)]",iconClasses:"novatx:text-[var(--tuwa-error-icon)]"},[pulsarCore.TransactionStatus.Replaced]:{label:t.replaced,Icon:solid.ArrowPathIcon,badgeClasses:"novatx:bg-[var(--tuwa-info-bg)] novatx:text-[var(--tuwa-info-text)]",iconClasses:"novatx:text-[var(--tuwa-info-icon)]"}});function tt({tx:t,className:a,classNames:n}){let{statuses:r}=g(),o=va(r),l="novatx:inline-flex novatx:items-center novatx:gap-x-1.5 novatx:rounded-full novatx:px-2 novatx:py-1 novatx:text-xs novatx:font-medium",c=t.pending?"Pending":t.status,i=c?o[c]:null;if(!i)return jsxRuntime.jsx("div",{className:novaCore.cn(l,"novatx:bg-[var(--tuwa-info-bg)] novatx:text-[var(--tuwa-info-text)]",n?.container,a),children:jsxRuntime.jsx("span",{className:n?.label,children:t.status??r.unknown})});let{label:p,Icon:s,badgeClasses:e,iconClasses:x}=i;return jsxRuntime.jsxs("div",{className:novaCore.cn(l,e,n?.container,a),children:[jsxRuntime.jsx(s,{className:novaCore.cn("novatx:h-4 novatx:w-4",x,n?.icon)}),jsxRuntime.jsx("span",{className:n?.label,children:p})]})}var ya=({onClick:t,children:a,className:n})=>jsxRuntime.jsx("button",{onClick:t,type:"button",className:novaCore.cn("novatx:cursor-pointer novatx:text-sm novatx:font-medium novatx:text-[var(--tuwa-text-accent)] novatx:transition-opacity novatx:hover:opacity-80",n),children:a}),Ca=({onClick:t,children:a,className:n})=>jsxRuntime.jsx("button",{onClick:t,type:"button",className:novaCore.cn("novatx:cursor-pointer novatx:text-sm novatx:font-medium novatx:text-[var(--tuwa-text-secondary)] novatx:transition-opacity novatx:hover:opacity-80",n),children:a}),ba=({onClick:t,children:a,className:n})=>jsxRuntime.jsx("button",{className:n||"novatx:cursor-pointer novatx:rounded-[var(--tuwa-rounded-corners)] novatx:bg-gradient-to-r novatx:from-[var(--tuwa-button-gradient-from)] novatx:to-[var(--tuwa-button-gradient-to)] novatx:px-3 novatx:py-1 novatx:text-xs novatx:font-bold novatx:text-[var(--tuwa-text-on-accent)] novatx:shadow-lg novatx:transition-all novatx:duration-200 novatx:ease-in-out novatx:hover:shadow-xl novatx:hover:from-[var(--tuwa-button-gradient-from-hover)] novatx:hover:to-[var(--tuwa-button-gradient-to-hover)] novatx:active:scale-95",onClick:t,type:"button",children:a});function Lt({openTxInfoModal:t,tx:a,icon:n,className:r,customization:o,connectedWalletAddress:l,adapter:c}){let{actions:i,toast:p}=g(),s=orbitCore.selectAdapterByKey({adapterKey:a.adapter,adapter:c}),e=!!(a.tracker==="ethereum"&&a.pending&&s?.speedUpTxAction&&s?.cancelTxAction&&a.from.toLowerCase()===l?.toLowerCase()&&["metamask"].includes(a.connectorType.split(":")[1])),x=()=>{e&&s.cancelTxAction(a);},u=()=>{e&&s.speedUpTxAction(a);},{StatusAwareText:m=O,TransactionKey:N=V,StatusBadge:y=tt,SpeedUpButton:C=ya,CancelButton:T=Ca,TxInfoButton:f=ba}=o?.components??{},d=o?.classNames;return jsxRuntime.jsxs("div",{className:novaCore.cn("novatx:flex novatx:w-full novatx:flex-col novatx:gap-3 novatx:rounded-[var(--tuwa-rounded-corners)] novatx:bg-[var(--tuwa-bg-primary)] novatx:p-4 novatx:shadow-md",d?.container,r),children:[jsxRuntime.jsxs("div",{className:novaCore.cn("novatx:flex novatx:items-center novatx:gap-3",d?.header),children:[jsxRuntime.jsx("div",{className:novaCore.cn("novatx:w-[40px] novatx:flex-shrink-0",d?.iconWrapper),title:novaCore.getChainName(orbitCore.setChainId(a.chainId)).name,children:n??jsxRuntime.jsx(novaCore.NetworkIcon,{chainId:orbitCore.setChainId(a.chainId)})}),jsxRuntime.jsxs("div",{className:novaCore.cn("novatx:flex-1",d?.contentWrapper),children:[jsxRuntime.jsx(m,{txStatus:a.status,source:a.title,fallback:a.type,variant:"title",applyColor:true,className:d?.title}),jsxRuntime.jsx(m,{txStatus:a.status,source:a.description,variant:"description",className:d?.description})]})]}),jsxRuntime.jsxs("div",{children:[jsxRuntime.jsx(N,{adapter:c,tx:a,variant:"toast",className:d?.transactionKey,hashLinkClassNames:{label:d?.hashLabel,link:d?.hashLink,copyButton:d?.hashCopyButton},originalHashLinkClassNames:{label:d?.originalHashLabel,link:d?.originalHashLink,copyButton:d?.originalHashCopyButton}}),jsxRuntime.jsxs("div",{className:novaCore.cn("novatx:mt-3 novatx:flex novatx:items-center novatx:justify-between",d?.footer),children:[jsxRuntime.jsx(y,{tx:a,className:d?.statusBadge,classNames:{icon:d?.statusBadgeIcon,label:d?.statusBadgeLabel}}),e?jsxRuntime.jsxs("div",{className:novaCore.cn("novatx:flex novatx:items-center novatx:gap-4",d?.actionsContainer),children:[jsxRuntime.jsx(C,{onClick:u,className:d?.speedUpButton,children:i.speedUp}),jsxRuntime.jsx(T,{onClick:x,className:d?.cancelButton,children:i.cancel})]}):t&&a.from.toLowerCase()===l?.toLowerCase()&&jsxRuntime.jsx(f,{onClick:t,className:d?.txInfoButton,children:p.openTransactionsInfo})]})]})]})}function Mt({adapter:t,onClose:a,onOpenAllTransactions:n,className:r,customization:o,transactionsPool:l,executeTxAction:c,initialTx:i,connectedWalletAddress:p}){let s=i?.lastTxKey?l[i.lastTxKey]:void 0,e=s??i,x=i?.withTrackedModal&&!s||(s?.isTrackedModalOpen??false),u=s?.status,m=i?.isInitializing??false,N=s?.pending??false,y=m||N,C=u===pulsarCore.TransactionStatus.Success,T=s?.isError||!!i?.error,f=u===pulsarCore.TransactionStatus.Replaced,d=e?orbitCore.selectAdapterByKey({adapterKey:e.adapter,adapter:t}):void 0,M=!!(T&&e&&i?.actionFunction&&c),K=!!(d?.speedUpTxAction&&d?.cancelTxAction&&s?.pending&&s.tracker==="ethereum"),b=()=>{if(!M||!d?.retryTxAction)return;let it={adapter:e.adapter,type:e.type,desiredChainID:"desiredChainID"in e?e.desiredChainID:e.chainId,actionFunction:i?.actionFunction,title:e.title,description:e.description,payload:e.payload,rpcUrl:"rpcUrl"in e?e?.rpcUrl:"desiredChainID"in e?e.desiredChainID:e.chainId.split(":")[1],withTrackedModal:"withTrackedModal"in e?e.withTrackedModal:false};d.retryTxAction({tx:it,txKey:s?.txKey??"",onClose:a,executeTxAction:c});},h=K&&s&&["metamask"].includes(s?.connectorType.split(":")[1]),w=()=>{h&&d.cancelTxAction(s);},Q=()=>{h&&d.speedUpTxAction(s);},ft=o?.components?.Header,yt=o?.components?.Footer,Ct=o?.components?.StatusVisual,bt=o?.components?.ProgressIndicator,ht=o?.components?.InfoBlock,Nt=o?.components?.ErrorBlock;if(!e)return null;let W=o?.classNames;return jsxRuntime.jsx(novaCore.Dialog,{open:x,onOpenChange:it=>!it&&a(s?.txKey),children:jsxRuntime.jsx(novaCore.DialogContent,{className:novaCore.cn("novatx:w-full novatx:sm:max-w-md",o?.modalProps?.className),...o?.modalProps,children:jsxRuntime.jsxs("div",{className:novaCore.cn("novatx:relative novatx:flex novatx:w-full novatx:flex-col",W?.container,r),children:[ft?jsxRuntime.jsx(ft,{onClose:()=>a(s?.txKey),title:jsxRuntime.jsx(At,{tx:e,className:W?.headerTitle})}):jsxRuntime.jsx(Sa,{onClose:()=>a(s?.txKey),title:jsxRuntime.jsx(At,{tx:e,className:W?.headerTitle}),classNames:W}),jsxRuntime.jsxs("main",{className:novaCore.cn("novatx:flex novatx:flex-col novatx:gap-4 novatx:p-4",W?.main),children:[Ct?jsxRuntime.jsx(Ct,{isProcessing:y,isSucceed:C,isFailed:T,isReplaced:f}):jsxRuntime.jsx(Dt,{isProcessing:y,isSucceed:C,isFailed:T,isReplaced:f,className:o?.statusVisualCustomization?.className,iconClassNames:o?.statusVisualCustomization?.iconClassNames}),bt?jsxRuntime.jsx(bt,{isProcessing:y,isSucceed:C,isFailed:T,isReplaced:f}):jsxRuntime.jsx(Ot,{isProcessing:y,isSucceed:C,isFailed:T,isReplaced:f,className:o?.progressIndicatorCustomization?.className,stepClassNames:o?.progressIndicatorCustomization?.stepClassNames}),ht?jsxRuntime.jsx(ht,{tx:e,adapter:t}):jsxRuntime.jsx(Rt,{tx:e,adapter:t,customization:o?.infoBlockCustomization}),Nt?jsxRuntime.jsx(Nt,{error:s?.error||i?.error}):jsxRuntime.jsx(Kt,{error:s?.error||i?.error,className:o?.errorBlockCustomization?.className,classNames:o?.errorBlockCustomization?.classNames})]}),yt?jsxRuntime.jsx(yt,{onClose:()=>a(s?.txKey),onOpenAllTransactions:n,isProcessing:y,isFailed:T,canReplace:K,onRetry:M?b:void 0,onSpeedUp:h?Q:void 0,onCancel:h?w:void 0,connectedWalletAddress:p}):jsxRuntime.jsx(Ha,{onClose:()=>a(s?.txKey),onOpenAllTransactions:n,isProcessing:y,isFailed:T,canReplace:K,onRetry:M?b:void 0,onSpeedUp:h?Q:void 0,onCancel:h?w:void 0,connectedWalletAddress:p,classNames:W})]})})})}function At({tx:t,className:a}){return jsxRuntime.jsx(O,{txStatus:"status"in t?t.status:void 0,source:t.title,fallback:t.type,variant:"title",className:novaCore.cn("novatx:text-lg",a)})}var Sa=({onClose:t,title:a,classNames:n})=>{let{actions:r}=g();return jsxRuntime.jsxs(novaCore.DialogHeader,{className:n?.header,children:[jsxRuntime.jsx(novaCore.DialogTitle,{className:n?.headerTitle,children:a}),jsxRuntime.jsx(novaCore.DialogClose,{asChild:true,children:jsxRuntime.jsx("button",{type:"button",onClick:()=>t(),"aria-label":r.close,className:novaCore.cn("novatx:cursor-pointer novatx:rounded-full novatx:p-1 novatx:text-[var(--tuwa-text-tertiary)] novatx:transition-colors novatx:hover:bg-[var(--tuwa-bg-muted)] novatx:hover:text-[var(--tuwa-text-primary)]",n?.closeButton),children:jsxRuntime.jsx(novaCore.CloseIcon,{})})})]})},La=({isFailed:t,onRetry:a,isProcessing:n,canReplace:r,connectedWalletAddress:o,onOpenAllTransactions:l,classNames:c})=>{let{trackingModal:i}=g();return t&&a?jsxRuntime.jsx("button",{type:"button",onClick:a,className:novaCore.cn("novatx:cursor-pointer novatx:rounded-t-[var(--tuwa-rounded-corners)] novatx:sm:rounded-[var(--tuwa-rounded-corners)] novatx:bg-gradient-to-r novatx:from-[var(--tuwa-button-gradient-from)] novatx:to-[var(--tuwa-button-gradient-to)] novatx:px-4 novatx:py-2 novatx:text-sm novatx:font-semibold novatx:text-[var(--tuwa-text-on-accent)] novatx:transition-opacity novatx:hover:from-[var(--tuwa-button-gradient-from-hover)] novatx:hover:to-[var(--tuwa-button-gradient-to-hover)]",c?.retryButton),children:i.retry}):!n&&!r&&o?jsxRuntime.jsx("button",{type:"button",onClick:l,className:novaCore.cn("novatx:cursor-pointer novatx:rounded-[var(--tuwa-rounded-corners)] novatx:bg-[var(--tuwa-bg-muted)] novatx:px-4 novatx:py-2 novatx:text-sm novatx:font-semibold novatx:text-[var(--tuwa-text-primary)] novatx:transition-colors novatx:hover:bg-[var(--tuwa-border-primary)]",c?.allTransactionsButton),children:i.allTransactions}):null},Ha=({onClose:t,onOpenAllTransactions:a,isProcessing:n,onRetry:r,onSpeedUp:o,onCancel:l,canReplace:c,isFailed:i,connectedWalletAddress:p,classNames:s})=>{let{trackingModal:e,actions:x}=g();return jsxRuntime.jsxs("footer",{className:novaCore.cn("novatx:flex novatx:w-full novatx:items-center novatx:justify-between novatx:border-t novatx:border-[var(--tuwa-border-primary)] novatx:p-4",s?.footer),children:[jsxRuntime.jsx("div",{className:novaCore.cn("novatx:flex novatx:items-center novatx:gap-4",s?.footerActions),children:c&&o&&l&&jsxRuntime.jsxs(jsxRuntime.Fragment,{children:[jsxRuntime.jsx("button",{type:"button",onClick:o,className:novaCore.cn("novatx:cursor-pointer novatx:text-sm novatx:font-medium novatx:text-[var(--tuwa-text-accent)] novatx:transition-opacity novatx:hover:opacity-80",s?.speedUpButton),children:x.speedUp}),jsxRuntime.jsx("button",{type:"button",onClick:l,className:novaCore.cn("novatx:cursor-pointer novatx:text-sm novatx:font-medium novatx:text-[var(--tuwa-text-secondary)] novatx:transition-opacity novatx:hover:opacity-80",s?.cancelButton),children:x.cancel})]})}),jsxRuntime.jsxs("div",{className:novaCore.cn("novatx:flex novatx:items-center novatx:gap-3",s?.footerButtons),children:[jsxRuntime.jsx(La,{isFailed:i,onRetry:r,isProcessing:n,canReplace:c,connectedWalletAddress:p,onOpenAllTransactions:a,classNames:s}),jsxRuntime.jsx("button",{type:"button",onClick:t,disabled:n&&!c,className:novaCore.cn("novatx:cursor-pointer novatx:rounded-[var(--tuwa-rounded-corners)] novatx:bg-[var(--tuwa-bg-muted)] novatx:px-4 novatx:py-2 novatx:text-sm novatx:font-semibold novatx:text-[var(--tuwa-text-primary)] novatx:transition-colors novatx:hover:bg-[var(--tuwa-border-primary)] novatx:disabled:cursor-not-allowed novatx:disabled:opacity-50",s?.closeModalButton),children:n&&!c?e.processing:e.close})]})]})};function Kt({error:t,className:a,classNames:n}){let{isCopied:r,copy:o}=novaCore.useCopyToClipboard(),{actions:l,txError:c}=g(),{displayMessage:i,copyMessage:p}=react.useMemo(()=>t?typeof t=="string"?{displayMessage:t,copyMessage:t}:{displayMessage:t.message,copyMessage:JSON.stringify(t.raw,null,2)}:{displayMessage:"",copyMessage:""},[t]);return !t||!i?null:jsxRuntime.jsxs("div",{className:novaCore.cn("novatx:rounded-[var(--tuwa-rounded-corners)] novatx:border novatx:border-[var(--tuwa-error-icon)]/30 novatx:bg-[var(--tuwa-error-bg)] novatx:p-3 novatx:text-sm",n?.container,a),children:[jsxRuntime.jsxs("div",{className:novaCore.cn("novatx:mb-2 novatx:flex novatx:items-center novatx:justify-between",n?.header),children:[jsxRuntime.jsxs("div",{className:novaCore.cn("novatx:flex novatx:items-center novatx:gap-2 novatx:font-bold novatx:text-[var(--tuwa-error-icon)]",n?.title),children:[jsxRuntime.jsx(solid.ExclamationTriangleIcon,{className:novaCore.cn("novatx:h-5 novatx:w-5",n?.icon)}),jsxRuntime.jsx("span",{children:c.title})]}),jsxRuntime.jsx("button",{type:"button",onClick:()=>o(p),title:r?c.copied:l.copy,"aria-label":r?c.copied:`${l.copy} error message`,className:novaCore.cn("novatx:cursor-pointer novatx:text-[var(--tuwa-error-icon)]/50 novatx:transition-colors novatx:hover:text-[var(--tuwa-error-icon)]",n?.copyButton),children:r?jsxRuntime.jsx(solid.CheckIcon,{className:"novatx:h-5 novatx:w-5 novatx:text-[var(--tuwa-success-icon)]"}):jsxRuntime.jsx(solid.DocumentDuplicateIcon,{className:"novatx:h-5 novatx:w-5"})})]}),jsxRuntime.jsx("div",{className:novaCore.cn("novatx:max-h-24 novatx:overflow-y-auto novatx:rounded novatx:bg-[var(--tuwa-bg-primary)] novatx:p-2",n?.messageContainer),children:jsxRuntime.jsx("p",{className:novaCore.cn("novatx:font-mono novatx:text-xs novatx:text-[var(--tuwa-error-text)] novatx:break-all",n?.messageText),children:i})})]})}function _a({label:t,value:a,classNames:n}){return jsxRuntime.jsxs("div",{className:novaCore.cn("novatx:flex novatx:items-center novatx:justify-between novatx:text-sm novatx:gap-2",n?.row),children:[jsxRuntime.jsx("span",{className:novaCore.cn("novatx:text-[var(--tuwa-text-secondary)]",n?.label),children:t}),jsxRuntime.jsx("span",{className:novaCore.cn("novatx:font-medium novatx:text-[var(--tuwa-text-primary)]",n?.value),children:a})]})}function Rt({tx:t,adapter:a,className:n,customization:r}){let{txInfo:o,statuses:l,hashLabels:c}=g(),i=orbitCore.selectAdapterByKey({adapterKey:t.adapter,adapter:a});if(!i)return null;let{InfoRow:p=_a}=r?.components??{},s=r?.classNames,e={row:s?.row,label:s?.rowLabel,value:s?.rowValue},x="chainId"in t?t.chainId:t.desiredChainID,u=t.adapter===orbitCore.OrbitAdapter.SOLANA,m=u?t:void 0;return jsxRuntime.jsxs("div",{className:novaCore.cn("novatx:flex novatx:flex-col novatx:gap-3 novatx:rounded-[var(--tuwa-rounded-corners)] novatx:border novatx:border-[var(--tuwa-border-primary)] novatx:bg-[var(--tuwa-bg-primary)] novatx:p-3",s?.container,n),children:[jsxRuntime.jsx(p,{label:o.network,value:jsxRuntime.jsxs("div",{className:"novatx:flex novatx:items-center novatx:justify-end novatx:gap-2",children:[jsxRuntime.jsx("div",{className:"novatx:h-4 novatx:w-4",children:jsxRuntime.jsx(novaCore.NetworkIcon,{chainId:orbitCore.setChainId(x)})}),jsxRuntime.jsx("span",{children:novaCore.getChainName(orbitCore.setChainId(x)).name})]}),classNames:e}),t.localTimestamp&&jsxRuntime.jsx(p,{label:o.started,value:Vt__default.default.unix(t.localTimestamp).format("MMM D, HH:mm:ss"),classNames:e}),u&&jsxRuntime.jsxs(jsxRuntime.Fragment,{children:[m?.slot&&jsxRuntime.jsx(p,{label:o.slot,value:jsxRuntime.jsx(Y,{hash:m.slot.toString(),explorerUrl:i?.getExplorerUrl?`${i?.getExplorerUrl(`/block/${m.slot}`)}`:void 0}),classNames:e}),(typeof m?.confirmations=="number"||typeof m?.confirmations=="string")&&jsxRuntime.jsx(p,{label:l.confirmationsLabel,value:m.confirmations,classNames:e}),m?.recentBlockhash&&jsxRuntime.jsx(p,{label:c.recentBlockhash,value:jsxRuntime.jsx(Y,{hash:m.recentBlockhash}),classNames:e})]}),"txKey"in t&&t.txKey&&jsxRuntime.jsx("div",{className:novaCore.cn("novatx:border-t novatx:border-[var(--tuwa-border-primary)] novatx:pt-3",s?.separator),children:jsxRuntime.jsx(V,{tx:t,adapter:a,variant:"history",renderHashLink:r?.components?.transactionKey,hashLinkClassNames:s?.hashLink,originalHashLinkClassNames:s?.originalHashLink})})]})}var $a={completed:{line:"novatx:bg-[var(--tuwa-success-icon)]",border:"novatx:border-[var(--tuwa-success-icon)]",fill:"novatx:bg-[var(--tuwa-success-icon)]"},error:{line:"novatx:bg-[var(--tuwa-error-icon)]",border:"novatx:border-[var(--tuwa-error-icon)]",fill:"novatx:bg-[var(--tuwa-error-icon)]"},replaced:{line:"novatx:bg-[var(--tuwa-info-icon)]",border:"novatx:border-[var(--tuwa-info-icon)]",fill:"novatx:bg-[var(--tuwa-info-icon)]"},active:{line:"novatx:bg-[var(--tuwa-pending-icon)]",border:"novatx:border-[var(--tuwa-pending-icon)]",fill:"novatx:bg-transparent",pulse:"novatx:bg-[var(--tuwa-pending-icon)]"},inactive:{line:"novatx:bg-[var(--tuwa-border-primary)]",border:"novatx:border-[var(--tuwa-border-primary)]",fill:"novatx:bg-transparent"}};function qa({status:t,label:a,isFirst:n=false,classNames:r}){let o=$a[t],l=r?.statusOverrides?.[t],c=()=>{switch(t){case "completed":return jsxRuntime.jsx(solid.CheckIcon,{className:"novatx:h-3 novatx:w-3 novatx:text-white"});case "error":return jsxRuntime.jsx(solid.ExclamationTriangleIcon,{className:"novatx:h-3 novatx:w-3 novatx:text-white"});case "replaced":return jsxRuntime.jsx(solid.ArrowPathIcon,{className:"novatx:h-3 novatx:w-3 novatx:text-white"});case "active":return jsxRuntime.jsx("div",{className:novaCore.cn("novatx:h-2 novatx:w-2 novatx:animate-pulse novatx:rounded-full",o.pulse)});default:return null}};return jsxRuntime.jsxs("div",{className:novaCore.cn("novatx:relative novatx:flex novatx:min-w-[80px] novatx:flex-1 novatx:flex-col novatx:items-center",r?.container),children:[!n&&jsxRuntime.jsx("div",{className:novaCore.cn("novatx:absolute novatx:right-1/2 novatx:top-[10px] novatx:h-0.5 novatx:w-full",o.line,r?.line,l?.line)}),jsxRuntime.jsx("div",{className:novaCore.cn("novatx:relative novatx:z-10 novatx:flex novatx:h-5 novatx:w-5 novatx:items-center novatx:justify-center novatx:rounded-full novatx:border-2",o.border,o.fill,r?.circle,l?.circle),children:c()}),jsxRuntime.jsx("span",{className:novaCore.cn("novatx:mt-2 novatx:text-center novatx:text-xs",t!=="inactive"?"novatx:font-semibold novatx:text-[var(--tuwa-text-primary)]":"novatx:text-[var(--tuwa-text-secondary)]",r?.label,l?.label),children:a})]})}function Ot({isProcessing:t,isSucceed:a,isFailed:n,isReplaced:r,className:o,StepComponent:l=qa,stepClassNames:c}){let{trackingModal:i,statuses:p}=g(),s=u=>{if(u===1)return "completed";if(u===2){if(a||n||r)return "completed";if(t)return "active"}if(u===3){if(a)return "completed";if(n)return "error";if(r)return "replaced";if(t)return "active"}return "inactive"},e=u=>u===1?i.progressIndicator.created:u===2?i.progressIndicator.processing:n?p.failed:r?p.replaced:i.progressIndicator.succeed,x=[{status:s(1),label:e(1),isFirst:true,classNames:c},{status:s(2),label:e(2),classNames:c},{status:s(3),label:e(3),isLast:true,classNames:c}];return jsxRuntime.jsx("div",{className:novaCore.cn("novatx:flex novatx:w-full novatx:items-start novatx:px-4 novatx:pt-2 novatx:pb-1",o),children:x.map((u,m)=>jsxRuntime.jsx(l,{...u},m))})}var to={succeed:{Icon:solid.CheckCircleIcon,className:"novatx:text-[var(--tuwa-success-icon)]"},failed:{Icon:solid.ExclamationCircleIcon,className:"novatx:text-[var(--tuwa-error-icon)]"},replaced:{Icon:solid.ArrowPathIcon,className:"novatx:text-[var(--tuwa-info-icon)]"},processing:{Icon:solid.ArrowPathIcon,className:"novatx:animate-spin novatx:text-[var(--tuwa-text-accent)]"},initializing:{Icon:solid.ClockIcon,className:"novatx:animate-pulse novatx:text-[var(--tuwa-pending-icon)]"}};function Dt({isProcessing:t,isSucceed:a,isFailed:n,isReplaced:r,className:o,iconClassNames:l}){let c=a&&"succeed"||n&&"failed"||r&&"replaced"||t&&"processing"||"initializing",{Icon:i,className:p}=to[c],s=l?.statusOverrides?.[c];return jsxRuntime.jsx("div",{className:novaCore.cn("novatx:flex novatx:justify-center novatx:py-4",o),children:jsxRuntime.jsx(i,{className:novaCore.cn("novatx:h-16 novatx:w-16",p,l?.icon,s)})})}Vt__default.default.extend(eo__default.default);var no=({chainId:t,className:a})=>jsxRuntime.jsx("div",{className:novaCore.cn("novatx:h-8 novatx:w-8 novatx:text-[var(--tuwa-text-secondary)]",a),children:jsxRuntime.jsx(novaCore.NetworkIcon,{chainId:orbitCore.setChainId(t)})}),so=({timestamp:t,className:a})=>jsxRuntime.jsx("span",{className:novaCore.cn("novatx:mb-1 novatx:block novatx:text-xs novatx:text-[var(--tuwa-text-secondary)]",a),children:t?Vt__default.default.unix(t).fromNow():"..."});function _t({tx:t,adapter:a,className:n,customization:r}){let{Icon:o=no,Title:l=O,Description:c=O,Timestamp:i=so,StatusBadge:p=tt,TransactionKey:s=V}=r?.components??{},e=r?.classNames;return jsxRuntime.jsxs("div",{className:novaCore.cn("novatx:flex novatx:flex-col novatx:gap-2 novatx:border-b novatx:border-[var(--tuwa-border-secondary)] novatx:p-3 novatx:transition-colors novatx:hover:bg-[var(--tuwa-bg-secondary)]",e?.container,n),children:[jsxRuntime.jsxs("div",{className:"novatx:flex novatx:items-start novatx:justify-between",children:[jsxRuntime.jsxs("div",{className:"novatx:flex novatx:items-center novatx:gap-4",children:[jsxRuntime.jsx("div",{className:novaCore.cn("novatx:flex novatx:h-10 novatx:w-10 novatx:flex-shrink-0 novatx:items-center novatx:justify-center novatx:rounded-full novatx:bg-[var(--tuwa-bg-muted)]",e?.iconWrapper),children:jsxRuntime.jsx(o,{chainId:t.chainId,className:e?.icon})}),jsxRuntime.jsxs("div",{className:e?.contentWrapper,children:[jsxRuntime.jsx(l,{txStatus:t.status,source:t.title,fallback:t.type,variant:"title",applyColor:true,className:e?.title}),jsxRuntime.jsx(i,{timestamp:t.localTimestamp,className:e?.timestamp}),jsxRuntime.jsx(c,{txStatus:t.status,source:t.description,variant:"description",className:e?.description})]})]}),jsxRuntime.jsx(p,{tx:t,className:e?.statusBadge,classNames:{icon:e?.statusBadgeIcon,label:e?.statusBadgeLabel}})]}),jsxRuntime.jsx(s,{tx:t,adapter:a,variant:"history",className:e?.txKeyContainer,hashLinkClassNames:{label:e?.hashLabel,link:e?.hashLink,copyButton:e?.hashCopyButton},originalHashLinkClassNames:{label:e?.originalHashLabel,link:e?.originalHashLink,copyButton:e?.originalHashCopyButton}})]})}function io({title:t,message:a,className:n,classNames:r}){return jsxRuntime.jsxs("div",{className:novaCore.cn("novatx:rounded-[var(--tuwa-rounded-corners)] novatx:bg-[var(--tuwa-bg-muted)] novatx:p-8 novatx:text-center",n),children:[jsxRuntime.jsx("h4",{className:novaCore.cn("novatx:font-semibold novatx:text-[var(--tuwa-text-primary)]",r?.title),children:t}),jsxRuntime.jsx("p",{className:novaCore.cn("novatx:mt-1 novatx:text-sm novatx:text-[var(--tuwa-text-secondary)]",r?.message),children:a})]})}function Jt({adapter:t,connectedWalletAddress:a,transactionsPool:n,className:r,customization:o}){let{transactionsModal:l}=g(),c=a?pulsarCore.selectAllTransactionsByActiveWallet(n,a).sort((x,u)=>(u.localTimestamp??0)-(x.localTimestamp??0)):[],{Placeholder:i=io,HistoryItem:p=_t}=o?.components??{},s=()=>{if(!a)return jsxRuntime.jsx(i,{title:l.history.connectWalletTitle,message:l.history.connectWalletMessage,className:o?.classNames?.placeholderContainer,classNames:{title:o?.classNames?.placeholderTitle,message:o?.classNames?.placeholderMessage}});if(c.length>0){let e={container:o?.classNames?.itemContainer,iconWrapper:o?.classNames?.itemIconWrapper,icon:o?.classNames?.itemIcon,contentWrapper:o?.classNames?.itemContentWrapper,title:o?.classNames?.itemTitle,timestamp:o?.classNames?.itemTimestamp,description:o?.classNames?.itemDescription,statusBadge:o?.classNames?.itemStatusBadge,statusBadgeIcon:o?.classNames?.itemStatusBadgeIcon,statusBadgeLabel:o?.classNames?.itemStatusBadgeLabel,txKeyContainer:o?.classNames?.itemTxKeyContainer,hashLabel:o?.classNames?.itemHashLabel,hashLink:o?.classNames?.itemHashLink,hashCopyButton:o?.classNames?.itemHashCopyButton,originalHashLabel:o?.classNames?.itemOriginalHashLabel,originalHashLink:o?.classNames?.itemOriginalHashLink,originalHashCopyButton:o?.classNames?.itemOriginalHashCopyButton};return jsxRuntime.jsx("div",{className:novaCore.cn("NovaCustomScroll novatx:max-h-[400px] novatx:overflow-y-auto novatx:rounded-[var(--tuwa-rounded-corners)] novatx:border novatx:border-[var(--tuwa-border-primary)] novatx:bg-[var(--tuwa-bg-primary)]",o?.classNames?.listWrapper),children:c.map(x=>jsxRuntime.jsx(p,{tx:x,adapter:t,customization:{classNames:e}},x.txKey))})}return jsxRuntime.jsx(i,{title:l.history.noTransactionsTitle,message:l.history.noTransactionsMessage,className:o?.classNames?.placeholderContainer,classNames:{title:o?.classNames?.placeholderTitle,message:o?.classNames?.placeholderMessage}})};return jsxRuntime.jsxs("div",{className:novaCore.cn("novatx:flex novatx:flex-col novatx:gap-y-3",o?.classNames?.container,r),children:[o?.title&&jsxRuntime.jsx("h3",{className:novaCore.cn("novatx:text-lg novatx:font-bold novatx:text-[var(--tuwa-text-primary)]",o?.classNames?.titleText),children:o?.title}),s()]})}var mo=({closeModal:t,title:a,classNames:n})=>{let{actions:r}=g();return jsxRuntime.jsxs(novaCore.DialogHeader,{className:n?.header,children:[jsxRuntime.jsx(novaCore.DialogTitle,{className:n?.title,children:a}),jsxRuntime.jsx(novaCore.DialogClose,{asChild:true,children:jsxRuntime.jsx("button",{type:"button",onClick:t,"aria-label":r.close,className:novaCore.cn("novatx:cursor-pointer novatx:rounded-full novatx:p-1 novatx:text-[var(--tuwa-text-tertiary)] novatx:transition-colors novatx:hover:bg-[var(--tuwa-bg-muted)] novatx:hover:text-[var(--tuwa-text-primary)]",n?.closeButton),children:jsxRuntime.jsx(novaCore.CloseIcon,{})})})]})};function Gt({isOpen:t,setIsOpen:a,customization:n,adapter:r,connectedWalletAddress:o,transactionsPool:l}){let{transactionsModal:c}=g(),i=()=>a(false),p=n?.components?.Header,s=n?.components?.History;return jsxRuntime.jsx(novaCore.Dialog,{open:t,onOpenChange:e=>!e&&i(),children:jsxRuntime.jsx(novaCore.DialogContent,{className:novaCore.cn("novatx:w-full novatx:sm:max-w-2xl",n?.modalProps?.className),...n?.modalProps,children:jsxRuntime.jsxs("div",{className:novaCore.cn("novatx:relative novatx:max-h-[95dvh] novatx:w-full novatx:flex novatx:flex-col",n?.classNames?.contentWrapper),children:[p?jsxRuntime.jsx(p,{closeModal:i}):jsxRuntime.jsx(mo,{closeModal:i,title:c.history.title,classNames:{header:n?.classNames?.header,title:n?.classNames?.headerTitle,closeButton:n?.classNames?.closeButton}}),s?jsxRuntime.jsx(s,{adapter:r,transactionsPool:l,connectedWalletAddress:o,customization:n?.historyCustomization}):jsxRuntime.jsx(Jt,{adapter:r,transactionsPool:l,connectedWalletAddress:o,customization:n?.historyCustomization})]})})})}var yo=t=>({replaced:jsxRuntime.jsxs(jsxRuntime.Fragment,{children:[jsxRuntime.jsx(solid.ArrowPathIcon,{className:"novatx:h-4 novatx:w-4"}),jsxRuntime.jsx("span",{children:t.replaced})]}),loading:jsxRuntime.jsxs(jsxRuntime.Fragment,{children:[jsxRuntime.jsx(solid.ArrowPathIcon,{className:"novatx:h-4 novatx:w-4 novatx:animate-spin"}),jsxRuntime.jsx("span",{children:t.loading})]}),succeed:jsxRuntime.jsxs(jsxRuntime.Fragment,{children:[jsxRuntime.jsx(solid.CheckCircleIcon,{className:"novatx:h-4 novatx:w-4"}),jsxRuntime.jsx("span",{children:t.succeed})]}),failed:jsxRuntime.jsxs(jsxRuntime.Fragment,{children:[jsxRuntime.jsx(solid.ExclamationCircleIcon,{className:"novatx:h-4 novatx:w-4"}),jsxRuntime.jsx("span",{children:t.failed})]})});function zn({children:t,action:a,getLastTxKey:n,transactionsPool:r,walletAddress:o,loadingContent:l,succeedContent:c,failedContent:i,replacedContent:p,resetTimeout:s=2500,className:e,classNames:x,...u}){let{trackedTxButton:m}=g(),[N,y]=react.useState("idle"),[C,T]=react.useState(void 0),f=yo(m);react.useEffect(()=>{y("idle"),T(void 0);},[o]),react.useEffect(()=>{if(!C)return;let w=r[C];if(w)switch(w.status){case pulsarCore.TransactionStatus.Success:y("succeed");break;case pulsarCore.TransactionStatus.Replaced:y("replaced");break;case pulsarCore.TransactionStatus.Failed:y("failed");break}},[r,C,o]),react.useEffect(()=>{if(["succeed","failed","replaced"].includes(N)){let w=setTimeout(()=>{y("idle"),T(void 0);},s);return ()=>clearTimeout(w)}},[N,s]);let d=async()=>{y("loading");try{await a(),T(n());}catch(w){console.error("Transaction initiation failed:",w),y("failed");}},M=()=>{switch(N){case "loading":return l??f.loading;case "succeed":return c??f.succeed;case "failed":return i??f.failed;case "replaced":return p??f.replaced;default:return t}},K={idle:"novatx:bg-[var(--tuwa-button-gradient-from)] novatx:text-[var(--tuwa-text-on-accent)] novatx:hover:opacity-90",loading:"novatx:bg-gray-400 novatx:text-white",replaced:"novatx:bg-gray-500 novatx:text-white",succeed:"novatx:bg-[var(--tuwa-success-bg)] novatx:text-[var(--tuwa-success-text)]",failed:"novatx:bg-[var(--tuwa-error-bg)] novatx:text-[var(--tuwa-error-text)]"},b=x?.[N]??K[N],h=x?.base??"novatx:flex novatx:cursor-pointer novatx:items-center novatx:justify-center novatx:gap-1.5 novatx:rounded-[var(--tuwa-rounded-corners)] novatx:px-3 novatx:py-1.5 novatx:text-sm novatx:font-medium novatx:transition-all novatx:duration-200 novatx:disabled:cursor-not-allowed novatx:disabled:opacity-70";return jsxRuntime.jsx("button",{...u,disabled:N!=="idle"||u.disabled,onClick:d,className:novaCore.cn(h,b,e),children:M()})}var ko={[pulsarCore.TransactionStatus.Success]:"success",[pulsarCore.TransactionStatus.Failed]:"error",[pulsarCore.TransactionStatus.Replaced]:"info"};function Hs({adapter:t,connectedWalletAddress:a,connectedAdapterType:n,transactionsPool:r,initialTx:o,executeTxAction:l,closeTxTrackedModal:c,labels:i,features:p,customization:s,...e}){let[x,u]=react.useState(false),m=react.useRef(r),N="nova-transactions",y=novaCore.useMediaQuery("(max-width: 767px)"),C=react.useMemo(()=>({toasts:p?.toasts??true,transactionsModal:p?.transactionsModal??true,trackingTxModal:p?.trackingTxModal??true}),[p]),T=react.useMemo(()=>novaCore.deepMerge(Z,i||{}),[i]),f=react.useCallback(b=>{if(!C.toasts)return;let h=b.pending?"info":ko[b.status]??"info",w=Q=>jsxRuntime.jsx(Lt,{...Q,tx:b,openTxInfoModal:C.transactionsModal?()=>u(true):void 0,customization:s?.toast,adapter:t,connectedWalletAddress:a});reactToastify.toast.isActive(b.txKey)?reactToastify.toast.update(b.txKey,{render:w,type:h,containerId:N}):reactToastify.toast(w,{toastId:b.txKey,type:h,closeOnClick:false,containerId:N});},[r,C,s?.toast,t,a]);react.useEffect(()=>{let b=m.current;Object.values(r).forEach(h=>{let w=b[h.txKey];if(!w&&h.pending){f(h);return}w&&JSON.stringify(w)!==JSON.stringify(h)&&f(h);}),m.current=r;},[r,f]),react.useEffect(()=>{Object.values(r).forEach(b=>{reactToastify.toast.isActive(b.txKey,N)&&f(b);});},[a,f,r]);let d=!!o?.withTrackedModal&&r[o?.lastTxKey??""]?.isTrackedModalOpen,M=C.toasts&&(!y||!d&&!x),K=react.useMemo(()=>{let b=s?.toastCloseButton;return b?({closeToast:h})=>jsxRuntime.jsx(novaCore.ToastCloseButton,{closeToast:h,...b}):novaCore.ToastCloseButton},[s?.toastCloseButton]);return jsxRuntime.jsxs(Pt,{labels:T,children:[M&&jsxRuntime.jsx(reactToastify.ToastContainer,{position:"bottom-right",stacked:true,autoClose:false,hideProgressBar:true,closeOnClick:false,icon:false,closeButton:K,containerId:N,toastClassName:"novatx:!p-0 novatx:!bg-transparent novatx:!shadow-none novatx:!min-h-0",...e}),C.transactionsModal&&jsxRuntime.jsx(Gt,{isOpen:x,setIsOpen:u,customization:s?.transactionsInfoModal,adapter:t,connectedWalletAddress:a,connectedAdapterType:n,transactionsPool:r}),C.trackingTxModal&&jsxRuntime.jsx(Mt,{initialTx:o,onClose:c,onOpenAllTransactions:()=>u(true),transactionsPool:r,customization:s?.trackingTxModal,executeTxAction:l,adapter:t,connectedWalletAddress:a})]})}exports.a=Z;exports.b=Pt;exports.c=g;exports.d=Hs;exports.e=Y;exports.f=O;exports.g=V;exports.h=tt;exports.i=Lt;exports.j=Mt;exports.k=Kt;exports.l=Rt;exports.m=Ot;exports.n=Dt;exports.o=_t;exports.p=Jt;exports.q=Gt;exports.r=zn;
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
import {createContext,useContext,useMemo,useState,useEffect,useRef,useCallback}from'react';import {jsx,jsxs,Fragment}from'react/jsx-runtime';import {useCopyToClipboard,cn,textCenterEllipsis,getChainName,NetworkIcon,Dialog,DialogContent,DialogHeader,DialogTitle,DialogClose,CloseIcon,useMediaQuery,deepMerge,ToastCloseButton}from'@tuwaio/nova-core';import {TransactionStatus,TransactionTracker,selectAllTransactionsByActiveWallet}from'@tuwaio/pulsar-core';import {toast,ToastContainer}from'react-toastify';import {ArrowTopRightOnSquareIcon,CheckIcon,DocumentDuplicateIcon,ArrowPathIcon,XCircleIcon,CheckCircleIcon,ExclamationTriangleIcon,ClockIcon,ExclamationCircleIcon}from'@heroicons/react/24/solid';import {selectAdapterByKey,setChainId,OrbitAdapter}from'@tuwaio/orbit-core';import Vt from'dayjs';import eo from'dayjs/plugin/relativeTime';var Z={transactionsModal:{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:{openTransactionsInfo:"Open transactions"},statuses:{pending:"Pending",success:"Success",failed:"Failed",reverted:"Reverted",replaced:"Replaced",unknown:"Unknown",confirmationsLabel:"Confirmations"},hashLabels:{gelato:"Gelato Task ID",safe:"Safe Tx Hash",original:"Original Tx Hash",replaced:"Replaced Tx Hash",default:"Tx Hash",recentBlockhash:"Recent Blockhash",solana:"Signature"},txInfo:{started:"Started",network:"Network",slot:"Slot"},txError:{title:"Error",copied:"Copied!"},trackingModal:{title:"Transaction Overview",processing:"Processing...",close:"Close",allTransactions:"All transactions",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 wt=createContext(Z),Pt=({labels:t,children:a})=>jsx(wt.Provider,{value:t,children:a}),g=()=>useContext(wt);function Y({label:t,hash:a,explorerUrl:n,variant:r="default",className:o,classNames:l}){let{isCopied:c,copy:i}=useCopyToClipboard(),{actions:p,txError:s}=g(),e=cn("novatx:flex novatx:items-center novatx:justify-between",{"novatx:text-sm":r==="default","novatx:text-xs":r==="compact"},o),x=cn("novatx:pr-1",{"novatx:font-bold novatx:text-[var(--tuwa-text-primary)]":r==="default","novatx:font-medium novatx:text-[var(--tuwa-text-secondary)]":r==="compact"},l?.label),u=jsx("span",{className:cn("novatx:font-mono",l?.hash),children:textCenterEllipsis(a,5,5)});return jsxs("div",{className:e,children:[t&&jsxs("span",{className:x,children:[t,":"]}),jsxs("div",{className:"novatx:flex novatx:items-center novatx:gap-x-2",children:[n?jsxs("a",{href:n,target:"_blank",rel:"noopener noreferrer",className:cn("novatx:flex novatx:items-center novatx:gap-x-1 novatx:text-[var(--tuwa-text-accent)] novatx:transition-colors novatx:hover:underline",l?.link),title:p.viewOnExplorer,"aria-label":p.viewOnExplorer,children:[u,jsx(ArrowTopRightOnSquareIcon,{className:cn("novatx:h-4 novatx:w-4",l?.linkIcon)})]}):jsx("span",{className:cn("novatx:text-[var(--tuwa-text-primary)]",l?.link),children:u}),jsx("button",{type:"button",onClick:()=>i(a),className:cn("novatx:cursor-pointer novatx:text-[var(--tuwa-text-tertiary)] novatx:transition-colors novatx:hover:text-[var(--tuwa-text-secondary)]",l?.copyButton),title:c?s.copied:p.copy,"aria-label":c?s.copied:p.copy,children:c?jsx(CheckIcon,{className:"novatx:h-4 novatx:w-4 novatx:text-[var(--tuwa-success-icon)]"}):jsx(DocumentDuplicateIcon,{className:"novatx:h-4 novatx:w-4"})})]})]})}var kt={[TransactionStatus.Success]:{index:1,colorClass:"novatx:text-[var(--tuwa-success-text)]"},[TransactionStatus.Failed]:{index:2,colorClass:"novatx:text-[var(--tuwa-error-text)]"},[TransactionStatus.Replaced]:{index:3,colorClass:"novatx:text-[var(--tuwa-text-secondary)]"},default:{index:0,colorClass:"novatx:text-[var(--tuwa-text-primary)]"}};function O({txStatus:t,source:a,fallback:n,variant:r,className:o,applyColor:l=false}){let c,i="";if(typeof a=="string")c=a;else if(Array.isArray(a)){let e=kt[t||"default"]??kt.default;c=a[e.index],l&&(i=e.colorClass);}else c=n;return c?jsx("div",{className:cn(r==="title"?"novatx:text-sm novatx:font-semibold novatx:text-[var(--tuwa-text-primary)]":"novatx:mt-1 novatx:text-xs novatx:text-[var(--tuwa-text-secondary)]",i,o),children:c}):null}function V({tx:t,adapter:a,variant:n="toast",className:r,renderHashLink:o,confirmations:l,hashLinkClassNames:c,originalHashLinkClassNames:i}){let{hashLabels:p,statuses:s}=g(),e=selectAdapterByKey({adapterKey:t.adapter,adapter:a});if(!e)return null;let x=(T,f)=>o?o(T):jsx(Y,{...T,classNames:f??c}),u=n==="toast"?"novatx:mt-2 novatx:flex novatx:w-full novatx:flex-col novatx:gap-y-2 novatx:border-t novatx:border-[var(--tuwa-border-primary)] novatx:pt-2":"novatx:flex novatx:w-full novatx:flex-col novatx:gap-y-2",m=p[String(t.tracker)],N=m?x({label:m,hash:t.txKey,variant:t.tracker!==TransactionTracker.Solana?"compact":"default",explorerUrl:e.getExplorerTxUrl&&t.tracker===TransactionTracker.Solana?e?.getExplorerTxUrl(t):void 0}):null,y=(()=>{let T=t.hash,f=t.replacedTxHash;return !T&&!f?null:f?jsxs(Fragment,{children:[T&&x({label:p.original,hash:T,variant:"compact"},i),typeof e.getExplorerTxUrl<"u"&&x({label:p.replaced,hash:f,explorerUrl:e.getExplorerTxUrl(t)})]}):T&&typeof e.getExplorerTxUrl<"u"&&x({label:p.default,hash:T,explorerUrl:e.getExplorerTxUrl(t)})})(),C=m&&m!==p.default&&t.txKey!==t.hash;return jsxs("div",{className:cn(u,r),children:[C&&N,y,typeof l=="number"&&jsxs("p",{className:"novatx:text-xs novatx:text-[var(--tuwa-text-tertiary)]",children:[s.confirmationsLabel,": ",l]})]})}var va=t=>({Pending:{label:t.pending,Icon:ArrowPathIcon,badgeClasses:"novatx:bg-[var(--tuwa-pending-bg)] novatx:text-[var(--tuwa-pending-text)]",iconClasses:"novatx:animate-spin novatx:text-[var(--tuwa-pending-icon)]"},[TransactionStatus.Success]:{label:t.success,Icon:CheckCircleIcon,badgeClasses:"novatx:bg-[var(--tuwa-success-bg)] novatx:text-[var(--tuwa-success-text)]",iconClasses:"novatx:text-[var(--tuwa-success-icon)]"},[TransactionStatus.Failed]:{label:t.failed,Icon:XCircleIcon,badgeClasses:"novatx:bg-[var(--tuwa-error-bg)] novatx:text-[var(--tuwa-error-text)]",iconClasses:"novatx:text-[var(--tuwa-error-icon)]"},[TransactionStatus.Replaced]:{label:t.replaced,Icon:ArrowPathIcon,badgeClasses:"novatx:bg-[var(--tuwa-info-bg)] novatx:text-[var(--tuwa-info-text)]",iconClasses:"novatx:text-[var(--tuwa-info-icon)]"}});function tt({tx:t,className:a,classNames:n}){let{statuses:r}=g(),o=va(r),l="novatx:inline-flex novatx:items-center novatx:gap-x-1.5 novatx:rounded-full novatx:px-2 novatx:py-1 novatx:text-xs novatx:font-medium",c=t.pending?"Pending":t.status,i=c?o[c]:null;if(!i)return jsx("div",{className:cn(l,"novatx:bg-[var(--tuwa-info-bg)] novatx:text-[var(--tuwa-info-text)]",n?.container,a),children:jsx("span",{className:n?.label,children:t.status??r.unknown})});let{label:p,Icon:s,badgeClasses:e,iconClasses:x}=i;return jsxs("div",{className:cn(l,e,n?.container,a),children:[jsx(s,{className:cn("novatx:h-4 novatx:w-4",x,n?.icon)}),jsx("span",{className:n?.label,children:p})]})}var ya=({onClick:t,children:a,className:n})=>jsx("button",{onClick:t,type:"button",className:cn("novatx:cursor-pointer novatx:text-sm novatx:font-medium novatx:text-[var(--tuwa-text-accent)] novatx:transition-opacity novatx:hover:opacity-80",n),children:a}),Ca=({onClick:t,children:a,className:n})=>jsx("button",{onClick:t,type:"button",className:cn("novatx:cursor-pointer novatx:text-sm novatx:font-medium novatx:text-[var(--tuwa-text-secondary)] novatx:transition-opacity novatx:hover:opacity-80",n),children:a}),ba=({onClick:t,children:a,className:n})=>jsx("button",{className:n||"novatx:cursor-pointer novatx:rounded-[var(--tuwa-rounded-corners)] novatx:bg-gradient-to-r novatx:from-[var(--tuwa-button-gradient-from)] novatx:to-[var(--tuwa-button-gradient-to)] novatx:px-3 novatx:py-1 novatx:text-xs novatx:font-bold novatx:text-[var(--tuwa-text-on-accent)] novatx:shadow-lg novatx:transition-all novatx:duration-200 novatx:ease-in-out novatx:hover:shadow-xl novatx:hover:from-[var(--tuwa-button-gradient-from-hover)] novatx:hover:to-[var(--tuwa-button-gradient-to-hover)] novatx:active:scale-95",onClick:t,type:"button",children:a});function Lt({openTxInfoModal:t,tx:a,icon:n,className:r,customization:o,connectedWalletAddress:l,adapter:c}){let{actions:i,toast:p}=g(),s=selectAdapterByKey({adapterKey:a.adapter,adapter:c}),e=!!(a.tracker==="ethereum"&&a.pending&&s?.speedUpTxAction&&s?.cancelTxAction&&a.from.toLowerCase()===l?.toLowerCase()&&["metamask"].includes(a.connectorType.split(":")[1])),x=()=>{e&&s.cancelTxAction(a);},u=()=>{e&&s.speedUpTxAction(a);},{StatusAwareText:m=O,TransactionKey:N=V,StatusBadge:y=tt,SpeedUpButton:C=ya,CancelButton:T=Ca,TxInfoButton:f=ba}=o?.components??{},d=o?.classNames;return jsxs("div",{className:cn("novatx:flex novatx:w-full novatx:flex-col novatx:gap-3 novatx:rounded-[var(--tuwa-rounded-corners)] novatx:bg-[var(--tuwa-bg-primary)] novatx:p-4 novatx:shadow-md",d?.container,r),children:[jsxs("div",{className:cn("novatx:flex novatx:items-center novatx:gap-3",d?.header),children:[jsx("div",{className:cn("novatx:w-[40px] novatx:flex-shrink-0",d?.iconWrapper),title:getChainName(setChainId(a.chainId)).name,children:n??jsx(NetworkIcon,{chainId:setChainId(a.chainId)})}),jsxs("div",{className:cn("novatx:flex-1",d?.contentWrapper),children:[jsx(m,{txStatus:a.status,source:a.title,fallback:a.type,variant:"title",applyColor:true,className:d?.title}),jsx(m,{txStatus:a.status,source:a.description,variant:"description",className:d?.description})]})]}),jsxs("div",{children:[jsx(N,{adapter:c,tx:a,variant:"toast",className:d?.transactionKey,hashLinkClassNames:{label:d?.hashLabel,link:d?.hashLink,copyButton:d?.hashCopyButton},originalHashLinkClassNames:{label:d?.originalHashLabel,link:d?.originalHashLink,copyButton:d?.originalHashCopyButton}}),jsxs("div",{className:cn("novatx:mt-3 novatx:flex novatx:items-center novatx:justify-between",d?.footer),children:[jsx(y,{tx:a,className:d?.statusBadge,classNames:{icon:d?.statusBadgeIcon,label:d?.statusBadgeLabel}}),e?jsxs("div",{className:cn("novatx:flex novatx:items-center novatx:gap-4",d?.actionsContainer),children:[jsx(C,{onClick:u,className:d?.speedUpButton,children:i.speedUp}),jsx(T,{onClick:x,className:d?.cancelButton,children:i.cancel})]}):t&&a.from.toLowerCase()===l?.toLowerCase()&&jsx(f,{onClick:t,className:d?.txInfoButton,children:p.openTransactionsInfo})]})]})]})}function Mt({adapter:t,onClose:a,onOpenAllTransactions:n,className:r,customization:o,transactionsPool:l,executeTxAction:c,initialTx:i,connectedWalletAddress:p}){let s=i?.lastTxKey?l[i.lastTxKey]:void 0,e=s??i,x=i?.withTrackedModal&&!s||(s?.isTrackedModalOpen??false),u=s?.status,m=i?.isInitializing??false,N=s?.pending??false,y=m||N,C=u===TransactionStatus.Success,T=s?.isError||!!i?.error,f=u===TransactionStatus.Replaced,d=e?selectAdapterByKey({adapterKey:e.adapter,adapter:t}):void 0,M=!!(T&&e&&i?.actionFunction&&c),K=!!(d?.speedUpTxAction&&d?.cancelTxAction&&s?.pending&&s.tracker==="ethereum"),b=()=>{if(!M||!d?.retryTxAction)return;let it={adapter:e.adapter,type:e.type,desiredChainID:"desiredChainID"in e?e.desiredChainID:e.chainId,actionFunction:i?.actionFunction,title:e.title,description:e.description,payload:e.payload,rpcUrl:"rpcUrl"in e?e?.rpcUrl:"desiredChainID"in e?e.desiredChainID:e.chainId.split(":")[1],withTrackedModal:"withTrackedModal"in e?e.withTrackedModal:false};d.retryTxAction({tx:it,txKey:s?.txKey??"",onClose:a,executeTxAction:c});},h=K&&s&&["metamask"].includes(s?.connectorType.split(":")[1]),w=()=>{h&&d.cancelTxAction(s);},Q=()=>{h&&d.speedUpTxAction(s);},ft=o?.components?.Header,yt=o?.components?.Footer,Ct=o?.components?.StatusVisual,bt=o?.components?.ProgressIndicator,ht=o?.components?.InfoBlock,Nt=o?.components?.ErrorBlock;if(!e)return null;let W=o?.classNames;return jsx(Dialog,{open:x,onOpenChange:it=>!it&&a(s?.txKey),children:jsx(DialogContent,{className:cn("novatx:w-full novatx:sm:max-w-md",o?.modalProps?.className),...o?.modalProps,children:jsxs("div",{className:cn("novatx:relative novatx:flex novatx:w-full novatx:flex-col",W?.container,r),children:[ft?jsx(ft,{onClose:()=>a(s?.txKey),title:jsx(At,{tx:e,className:W?.headerTitle})}):jsx(Sa,{onClose:()=>a(s?.txKey),title:jsx(At,{tx:e,className:W?.headerTitle}),classNames:W}),jsxs("main",{className:cn("novatx:flex novatx:flex-col novatx:gap-4 novatx:p-4",W?.main),children:[Ct?jsx(Ct,{isProcessing:y,isSucceed:C,isFailed:T,isReplaced:f}):jsx(Dt,{isProcessing:y,isSucceed:C,isFailed:T,isReplaced:f,className:o?.statusVisualCustomization?.className,iconClassNames:o?.statusVisualCustomization?.iconClassNames}),bt?jsx(bt,{isProcessing:y,isSucceed:C,isFailed:T,isReplaced:f}):jsx(Ot,{isProcessing:y,isSucceed:C,isFailed:T,isReplaced:f,className:o?.progressIndicatorCustomization?.className,stepClassNames:o?.progressIndicatorCustomization?.stepClassNames}),ht?jsx(ht,{tx:e,adapter:t}):jsx(Rt,{tx:e,adapter:t,customization:o?.infoBlockCustomization}),Nt?jsx(Nt,{error:s?.error||i?.error}):jsx(Kt,{error:s?.error||i?.error,className:o?.errorBlockCustomization?.className,classNames:o?.errorBlockCustomization?.classNames})]}),yt?jsx(yt,{onClose:()=>a(s?.txKey),onOpenAllTransactions:n,isProcessing:y,isFailed:T,canReplace:K,onRetry:M?b:void 0,onSpeedUp:h?Q:void 0,onCancel:h?w:void 0,connectedWalletAddress:p}):jsx(Ha,{onClose:()=>a(s?.txKey),onOpenAllTransactions:n,isProcessing:y,isFailed:T,canReplace:K,onRetry:M?b:void 0,onSpeedUp:h?Q:void 0,onCancel:h?w:void 0,connectedWalletAddress:p,classNames:W})]})})})}function At({tx:t,className:a}){return jsx(O,{txStatus:"status"in t?t.status:void 0,source:t.title,fallback:t.type,variant:"title",className:cn("novatx:text-lg",a)})}var Sa=({onClose:t,title:a,classNames:n})=>{let{actions:r}=g();return jsxs(DialogHeader,{className:n?.header,children:[jsx(DialogTitle,{className:n?.headerTitle,children:a}),jsx(DialogClose,{asChild:true,children:jsx("button",{type:"button",onClick:()=>t(),"aria-label":r.close,className:cn("novatx:cursor-pointer novatx:rounded-full novatx:p-1 novatx:text-[var(--tuwa-text-tertiary)] novatx:transition-colors novatx:hover:bg-[var(--tuwa-bg-muted)] novatx:hover:text-[var(--tuwa-text-primary)]",n?.closeButton),children:jsx(CloseIcon,{})})})]})},La=({isFailed:t,onRetry:a,isProcessing:n,canReplace:r,connectedWalletAddress:o,onOpenAllTransactions:l,classNames:c})=>{let{trackingModal:i}=g();return t&&a?jsx("button",{type:"button",onClick:a,className:cn("novatx:cursor-pointer novatx:rounded-t-[var(--tuwa-rounded-corners)] novatx:sm:rounded-[var(--tuwa-rounded-corners)] novatx:bg-gradient-to-r novatx:from-[var(--tuwa-button-gradient-from)] novatx:to-[var(--tuwa-button-gradient-to)] novatx:px-4 novatx:py-2 novatx:text-sm novatx:font-semibold novatx:text-[var(--tuwa-text-on-accent)] novatx:transition-opacity novatx:hover:from-[var(--tuwa-button-gradient-from-hover)] novatx:hover:to-[var(--tuwa-button-gradient-to-hover)]",c?.retryButton),children:i.retry}):!n&&!r&&o?jsx("button",{type:"button",onClick:l,className:cn("novatx:cursor-pointer novatx:rounded-[var(--tuwa-rounded-corners)] novatx:bg-[var(--tuwa-bg-muted)] novatx:px-4 novatx:py-2 novatx:text-sm novatx:font-semibold novatx:text-[var(--tuwa-text-primary)] novatx:transition-colors novatx:hover:bg-[var(--tuwa-border-primary)]",c?.allTransactionsButton),children:i.allTransactions}):null},Ha=({onClose:t,onOpenAllTransactions:a,isProcessing:n,onRetry:r,onSpeedUp:o,onCancel:l,canReplace:c,isFailed:i,connectedWalletAddress:p,classNames:s})=>{let{trackingModal:e,actions:x}=g();return jsxs("footer",{className:cn("novatx:flex novatx:w-full novatx:items-center novatx:justify-between novatx:border-t novatx:border-[var(--tuwa-border-primary)] novatx:p-4",s?.footer),children:[jsx("div",{className:cn("novatx:flex novatx:items-center novatx:gap-4",s?.footerActions),children:c&&o&&l&&jsxs(Fragment,{children:[jsx("button",{type:"button",onClick:o,className:cn("novatx:cursor-pointer novatx:text-sm novatx:font-medium novatx:text-[var(--tuwa-text-accent)] novatx:transition-opacity novatx:hover:opacity-80",s?.speedUpButton),children:x.speedUp}),jsx("button",{type:"button",onClick:l,className:cn("novatx:cursor-pointer novatx:text-sm novatx:font-medium novatx:text-[var(--tuwa-text-secondary)] novatx:transition-opacity novatx:hover:opacity-80",s?.cancelButton),children:x.cancel})]})}),jsxs("div",{className:cn("novatx:flex novatx:items-center novatx:gap-3",s?.footerButtons),children:[jsx(La,{isFailed:i,onRetry:r,isProcessing:n,canReplace:c,connectedWalletAddress:p,onOpenAllTransactions:a,classNames:s}),jsx("button",{type:"button",onClick:t,disabled:n&&!c,className:cn("novatx:cursor-pointer novatx:rounded-[var(--tuwa-rounded-corners)] novatx:bg-[var(--tuwa-bg-muted)] novatx:px-4 novatx:py-2 novatx:text-sm novatx:font-semibold novatx:text-[var(--tuwa-text-primary)] novatx:transition-colors novatx:hover:bg-[var(--tuwa-border-primary)] novatx:disabled:cursor-not-allowed novatx:disabled:opacity-50",s?.closeModalButton),children:n&&!c?e.processing:e.close})]})]})};function Kt({error:t,className:a,classNames:n}){let{isCopied:r,copy:o}=useCopyToClipboard(),{actions:l,txError:c}=g(),{displayMessage:i,copyMessage:p}=useMemo(()=>t?typeof t=="string"?{displayMessage:t,copyMessage:t}:{displayMessage:t.message,copyMessage:JSON.stringify(t.raw,null,2)}:{displayMessage:"",copyMessage:""},[t]);return !t||!i?null:jsxs("div",{className:cn("novatx:rounded-[var(--tuwa-rounded-corners)] novatx:border novatx:border-[var(--tuwa-error-icon)]/30 novatx:bg-[var(--tuwa-error-bg)] novatx:p-3 novatx:text-sm",n?.container,a),children:[jsxs("div",{className:cn("novatx:mb-2 novatx:flex novatx:items-center novatx:justify-between",n?.header),children:[jsxs("div",{className:cn("novatx:flex novatx:items-center novatx:gap-2 novatx:font-bold novatx:text-[var(--tuwa-error-icon)]",n?.title),children:[jsx(ExclamationTriangleIcon,{className:cn("novatx:h-5 novatx:w-5",n?.icon)}),jsx("span",{children:c.title})]}),jsx("button",{type:"button",onClick:()=>o(p),title:r?c.copied:l.copy,"aria-label":r?c.copied:`${l.copy} error message`,className:cn("novatx:cursor-pointer novatx:text-[var(--tuwa-error-icon)]/50 novatx:transition-colors novatx:hover:text-[var(--tuwa-error-icon)]",n?.copyButton),children:r?jsx(CheckIcon,{className:"novatx:h-5 novatx:w-5 novatx:text-[var(--tuwa-success-icon)]"}):jsx(DocumentDuplicateIcon,{className:"novatx:h-5 novatx:w-5"})})]}),jsx("div",{className:cn("novatx:max-h-24 novatx:overflow-y-auto novatx:rounded novatx:bg-[var(--tuwa-bg-primary)] novatx:p-2",n?.messageContainer),children:jsx("p",{className:cn("novatx:font-mono novatx:text-xs novatx:text-[var(--tuwa-error-text)] novatx:break-all",n?.messageText),children:i})})]})}function _a({label:t,value:a,classNames:n}){return jsxs("div",{className:cn("novatx:flex novatx:items-center novatx:justify-between novatx:text-sm novatx:gap-2",n?.row),children:[jsx("span",{className:cn("novatx:text-[var(--tuwa-text-secondary)]",n?.label),children:t}),jsx("span",{className:cn("novatx:font-medium novatx:text-[var(--tuwa-text-primary)]",n?.value),children:a})]})}function Rt({tx:t,adapter:a,className:n,customization:r}){let{txInfo:o,statuses:l,hashLabels:c}=g(),i=selectAdapterByKey({adapterKey:t.adapter,adapter:a});if(!i)return null;let{InfoRow:p=_a}=r?.components??{},s=r?.classNames,e={row:s?.row,label:s?.rowLabel,value:s?.rowValue},x="chainId"in t?t.chainId:t.desiredChainID,u=t.adapter===OrbitAdapter.SOLANA,m=u?t:void 0;return jsxs("div",{className:cn("novatx:flex novatx:flex-col novatx:gap-3 novatx:rounded-[var(--tuwa-rounded-corners)] novatx:border novatx:border-[var(--tuwa-border-primary)] novatx:bg-[var(--tuwa-bg-primary)] novatx:p-3",s?.container,n),children:[jsx(p,{label:o.network,value:jsxs("div",{className:"novatx:flex novatx:items-center novatx:justify-end novatx:gap-2",children:[jsx("div",{className:"novatx:h-4 novatx:w-4",children:jsx(NetworkIcon,{chainId:setChainId(x)})}),jsx("span",{children:getChainName(setChainId(x)).name})]}),classNames:e}),t.localTimestamp&&jsx(p,{label:o.started,value:Vt.unix(t.localTimestamp).format("MMM D, HH:mm:ss"),classNames:e}),u&&jsxs(Fragment,{children:[m?.slot&&jsx(p,{label:o.slot,value:jsx(Y,{hash:m.slot.toString(),explorerUrl:i?.getExplorerUrl?`${i?.getExplorerUrl(`/block/${m.slot}`)}`:void 0}),classNames:e}),(typeof m?.confirmations=="number"||typeof m?.confirmations=="string")&&jsx(p,{label:l.confirmationsLabel,value:m.confirmations,classNames:e}),m?.recentBlockhash&&jsx(p,{label:c.recentBlockhash,value:jsx(Y,{hash:m.recentBlockhash}),classNames:e})]}),"txKey"in t&&t.txKey&&jsx("div",{className:cn("novatx:border-t novatx:border-[var(--tuwa-border-primary)] novatx:pt-3",s?.separator),children:jsx(V,{tx:t,adapter:a,variant:"history",renderHashLink:r?.components?.transactionKey,hashLinkClassNames:s?.hashLink,originalHashLinkClassNames:s?.originalHashLink})})]})}var $a={completed:{line:"novatx:bg-[var(--tuwa-success-icon)]",border:"novatx:border-[var(--tuwa-success-icon)]",fill:"novatx:bg-[var(--tuwa-success-icon)]"},error:{line:"novatx:bg-[var(--tuwa-error-icon)]",border:"novatx:border-[var(--tuwa-error-icon)]",fill:"novatx:bg-[var(--tuwa-error-icon)]"},replaced:{line:"novatx:bg-[var(--tuwa-info-icon)]",border:"novatx:border-[var(--tuwa-info-icon)]",fill:"novatx:bg-[var(--tuwa-info-icon)]"},active:{line:"novatx:bg-[var(--tuwa-pending-icon)]",border:"novatx:border-[var(--tuwa-pending-icon)]",fill:"novatx:bg-transparent",pulse:"novatx:bg-[var(--tuwa-pending-icon)]"},inactive:{line:"novatx:bg-[var(--tuwa-border-primary)]",border:"novatx:border-[var(--tuwa-border-primary)]",fill:"novatx:bg-transparent"}};function qa({status:t,label:a,isFirst:n=false,classNames:r}){let o=$a[t],l=r?.statusOverrides?.[t],c=()=>{switch(t){case "completed":return jsx(CheckIcon,{className:"novatx:h-3 novatx:w-3 novatx:text-white"});case "error":return jsx(ExclamationTriangleIcon,{className:"novatx:h-3 novatx:w-3 novatx:text-white"});case "replaced":return jsx(ArrowPathIcon,{className:"novatx:h-3 novatx:w-3 novatx:text-white"});case "active":return jsx("div",{className:cn("novatx:h-2 novatx:w-2 novatx:animate-pulse novatx:rounded-full",o.pulse)});default:return null}};return jsxs("div",{className:cn("novatx:relative novatx:flex novatx:min-w-[80px] novatx:flex-1 novatx:flex-col novatx:items-center",r?.container),children:[!n&&jsx("div",{className:cn("novatx:absolute novatx:right-1/2 novatx:top-[10px] novatx:h-0.5 novatx:w-full",o.line,r?.line,l?.line)}),jsx("div",{className:cn("novatx:relative novatx:z-10 novatx:flex novatx:h-5 novatx:w-5 novatx:items-center novatx:justify-center novatx:rounded-full novatx:border-2",o.border,o.fill,r?.circle,l?.circle),children:c()}),jsx("span",{className:cn("novatx:mt-2 novatx:text-center novatx:text-xs",t!=="inactive"?"novatx:font-semibold novatx:text-[var(--tuwa-text-primary)]":"novatx:text-[var(--tuwa-text-secondary)]",r?.label,l?.label),children:a})]})}function Ot({isProcessing:t,isSucceed:a,isFailed:n,isReplaced:r,className:o,StepComponent:l=qa,stepClassNames:c}){let{trackingModal:i,statuses:p}=g(),s=u=>{if(u===1)return "completed";if(u===2){if(a||n||r)return "completed";if(t)return "active"}if(u===3){if(a)return "completed";if(n)return "error";if(r)return "replaced";if(t)return "active"}return "inactive"},e=u=>u===1?i.progressIndicator.created:u===2?i.progressIndicator.processing:n?p.failed:r?p.replaced:i.progressIndicator.succeed,x=[{status:s(1),label:e(1),isFirst:true,classNames:c},{status:s(2),label:e(2),classNames:c},{status:s(3),label:e(3),isLast:true,classNames:c}];return jsx("div",{className:cn("novatx:flex novatx:w-full novatx:items-start novatx:px-4 novatx:pt-2 novatx:pb-1",o),children:x.map((u,m)=>jsx(l,{...u},m))})}var to={succeed:{Icon:CheckCircleIcon,className:"novatx:text-[var(--tuwa-success-icon)]"},failed:{Icon:ExclamationCircleIcon,className:"novatx:text-[var(--tuwa-error-icon)]"},replaced:{Icon:ArrowPathIcon,className:"novatx:text-[var(--tuwa-info-icon)]"},processing:{Icon:ArrowPathIcon,className:"novatx:animate-spin novatx:text-[var(--tuwa-text-accent)]"},initializing:{Icon:ClockIcon,className:"novatx:animate-pulse novatx:text-[var(--tuwa-pending-icon)]"}};function Dt({isProcessing:t,isSucceed:a,isFailed:n,isReplaced:r,className:o,iconClassNames:l}){let c=a&&"succeed"||n&&"failed"||r&&"replaced"||t&&"processing"||"initializing",{Icon:i,className:p}=to[c],s=l?.statusOverrides?.[c];return jsx("div",{className:cn("novatx:flex novatx:justify-center novatx:py-4",o),children:jsx(i,{className:cn("novatx:h-16 novatx:w-16",p,l?.icon,s)})})}Vt.extend(eo);var no=({chainId:t,className:a})=>jsx("div",{className:cn("novatx:h-8 novatx:w-8 novatx:text-[var(--tuwa-text-secondary)]",a),children:jsx(NetworkIcon,{chainId:setChainId(t)})}),so=({timestamp:t,className:a})=>jsx("span",{className:cn("novatx:mb-1 novatx:block novatx:text-xs novatx:text-[var(--tuwa-text-secondary)]",a),children:t?Vt.unix(t).fromNow():"..."});function _t({tx:t,adapter:a,className:n,customization:r}){let{Icon:o=no,Title:l=O,Description:c=O,Timestamp:i=so,StatusBadge:p=tt,TransactionKey:s=V}=r?.components??{},e=r?.classNames;return jsxs("div",{className:cn("novatx:flex novatx:flex-col novatx:gap-2 novatx:border-b novatx:border-[var(--tuwa-border-secondary)] novatx:p-3 novatx:transition-colors novatx:hover:bg-[var(--tuwa-bg-secondary)]",e?.container,n),children:[jsxs("div",{className:"novatx:flex novatx:items-start novatx:justify-between",children:[jsxs("div",{className:"novatx:flex novatx:items-center novatx:gap-4",children:[jsx("div",{className:cn("novatx:flex novatx:h-10 novatx:w-10 novatx:flex-shrink-0 novatx:items-center novatx:justify-center novatx:rounded-full novatx:bg-[var(--tuwa-bg-muted)]",e?.iconWrapper),children:jsx(o,{chainId:t.chainId,className:e?.icon})}),jsxs("div",{className:e?.contentWrapper,children:[jsx(l,{txStatus:t.status,source:t.title,fallback:t.type,variant:"title",applyColor:true,className:e?.title}),jsx(i,{timestamp:t.localTimestamp,className:e?.timestamp}),jsx(c,{txStatus:t.status,source:t.description,variant:"description",className:e?.description})]})]}),jsx(p,{tx:t,className:e?.statusBadge,classNames:{icon:e?.statusBadgeIcon,label:e?.statusBadgeLabel}})]}),jsx(s,{tx:t,adapter:a,variant:"history",className:e?.txKeyContainer,hashLinkClassNames:{label:e?.hashLabel,link:e?.hashLink,copyButton:e?.hashCopyButton},originalHashLinkClassNames:{label:e?.originalHashLabel,link:e?.originalHashLink,copyButton:e?.originalHashCopyButton}})]})}function io({title:t,message:a,className:n,classNames:r}){return jsxs("div",{className:cn("novatx:rounded-[var(--tuwa-rounded-corners)] novatx:bg-[var(--tuwa-bg-muted)] novatx:p-8 novatx:text-center",n),children:[jsx("h4",{className:cn("novatx:font-semibold novatx:text-[var(--tuwa-text-primary)]",r?.title),children:t}),jsx("p",{className:cn("novatx:mt-1 novatx:text-sm novatx:text-[var(--tuwa-text-secondary)]",r?.message),children:a})]})}function Jt({adapter:t,connectedWalletAddress:a,transactionsPool:n,className:r,customization:o}){let{transactionsModal:l}=g(),c=a?selectAllTransactionsByActiveWallet(n,a).sort((x,u)=>(u.localTimestamp??0)-(x.localTimestamp??0)):[],{Placeholder:i=io,HistoryItem:p=_t}=o?.components??{},s=()=>{if(!a)return jsx(i,{title:l.history.connectWalletTitle,message:l.history.connectWalletMessage,className:o?.classNames?.placeholderContainer,classNames:{title:o?.classNames?.placeholderTitle,message:o?.classNames?.placeholderMessage}});if(c.length>0){let e={container:o?.classNames?.itemContainer,iconWrapper:o?.classNames?.itemIconWrapper,icon:o?.classNames?.itemIcon,contentWrapper:o?.classNames?.itemContentWrapper,title:o?.classNames?.itemTitle,timestamp:o?.classNames?.itemTimestamp,description:o?.classNames?.itemDescription,statusBadge:o?.classNames?.itemStatusBadge,statusBadgeIcon:o?.classNames?.itemStatusBadgeIcon,statusBadgeLabel:o?.classNames?.itemStatusBadgeLabel,txKeyContainer:o?.classNames?.itemTxKeyContainer,hashLabel:o?.classNames?.itemHashLabel,hashLink:o?.classNames?.itemHashLink,hashCopyButton:o?.classNames?.itemHashCopyButton,originalHashLabel:o?.classNames?.itemOriginalHashLabel,originalHashLink:o?.classNames?.itemOriginalHashLink,originalHashCopyButton:o?.classNames?.itemOriginalHashCopyButton};return jsx("div",{className:cn("NovaCustomScroll novatx:max-h-[400px] novatx:overflow-y-auto novatx:rounded-[var(--tuwa-rounded-corners)] novatx:border novatx:border-[var(--tuwa-border-primary)] novatx:bg-[var(--tuwa-bg-primary)]",o?.classNames?.listWrapper),children:c.map(x=>jsx(p,{tx:x,adapter:t,customization:{classNames:e}},x.txKey))})}return jsx(i,{title:l.history.noTransactionsTitle,message:l.history.noTransactionsMessage,className:o?.classNames?.placeholderContainer,classNames:{title:o?.classNames?.placeholderTitle,message:o?.classNames?.placeholderMessage}})};return jsxs("div",{className:cn("novatx:flex novatx:flex-col novatx:gap-y-3",o?.classNames?.container,r),children:[o?.title&&jsx("h3",{className:cn("novatx:text-lg novatx:font-bold novatx:text-[var(--tuwa-text-primary)]",o?.classNames?.titleText),children:o?.title}),s()]})}var mo=({closeModal:t,title:a,classNames:n})=>{let{actions:r}=g();return jsxs(DialogHeader,{className:n?.header,children:[jsx(DialogTitle,{className:n?.title,children:a}),jsx(DialogClose,{asChild:true,children:jsx("button",{type:"button",onClick:t,"aria-label":r.close,className:cn("novatx:cursor-pointer novatx:rounded-full novatx:p-1 novatx:text-[var(--tuwa-text-tertiary)] novatx:transition-colors novatx:hover:bg-[var(--tuwa-bg-muted)] novatx:hover:text-[var(--tuwa-text-primary)]",n?.closeButton),children:jsx(CloseIcon,{})})})]})};function Gt({isOpen:t,setIsOpen:a,customization:n,adapter:r,connectedWalletAddress:o,transactionsPool:l}){let{transactionsModal:c}=g(),i=()=>a(false),p=n?.components?.Header,s=n?.components?.History;return jsx(Dialog,{open:t,onOpenChange:e=>!e&&i(),children:jsx(DialogContent,{className:cn("novatx:w-full novatx:sm:max-w-2xl",n?.modalProps?.className),...n?.modalProps,children:jsxs("div",{className:cn("novatx:relative novatx:max-h-[95dvh] novatx:w-full novatx:flex novatx:flex-col",n?.classNames?.contentWrapper),children:[p?jsx(p,{closeModal:i}):jsx(mo,{closeModal:i,title:c.history.title,classNames:{header:n?.classNames?.header,title:n?.classNames?.headerTitle,closeButton:n?.classNames?.closeButton}}),s?jsx(s,{adapter:r,transactionsPool:l,connectedWalletAddress:o,customization:n?.historyCustomization}):jsx(Jt,{adapter:r,transactionsPool:l,connectedWalletAddress:o,customization:n?.historyCustomization})]})})})}var yo=t=>({replaced:jsxs(Fragment,{children:[jsx(ArrowPathIcon,{className:"novatx:h-4 novatx:w-4"}),jsx("span",{children:t.replaced})]}),loading:jsxs(Fragment,{children:[jsx(ArrowPathIcon,{className:"novatx:h-4 novatx:w-4 novatx:animate-spin"}),jsx("span",{children:t.loading})]}),succeed:jsxs(Fragment,{children:[jsx(CheckCircleIcon,{className:"novatx:h-4 novatx:w-4"}),jsx("span",{children:t.succeed})]}),failed:jsxs(Fragment,{children:[jsx(ExclamationCircleIcon,{className:"novatx:h-4 novatx:w-4"}),jsx("span",{children:t.failed})]})});function zn({children:t,action:a,getLastTxKey:n,transactionsPool:r,walletAddress:o,loadingContent:l,succeedContent:c,failedContent:i,replacedContent:p,resetTimeout:s=2500,className:e,classNames:x,...u}){let{trackedTxButton:m}=g(),[N,y]=useState("idle"),[C,T]=useState(void 0),f=yo(m);useEffect(()=>{y("idle"),T(void 0);},[o]),useEffect(()=>{if(!C)return;let w=r[C];if(w)switch(w.status){case TransactionStatus.Success:y("succeed");break;case TransactionStatus.Replaced:y("replaced");break;case TransactionStatus.Failed:y("failed");break}},[r,C,o]),useEffect(()=>{if(["succeed","failed","replaced"].includes(N)){let w=setTimeout(()=>{y("idle"),T(void 0);},s);return ()=>clearTimeout(w)}},[N,s]);let d=async()=>{y("loading");try{await a(),T(n());}catch(w){console.error("Transaction initiation failed:",w),y("failed");}},M=()=>{switch(N){case "loading":return l??f.loading;case "succeed":return c??f.succeed;case "failed":return i??f.failed;case "replaced":return p??f.replaced;default:return t}},K={idle:"novatx:bg-[var(--tuwa-button-gradient-from)] novatx:text-[var(--tuwa-text-on-accent)] novatx:hover:opacity-90",loading:"novatx:bg-gray-400 novatx:text-white",replaced:"novatx:bg-gray-500 novatx:text-white",succeed:"novatx:bg-[var(--tuwa-success-bg)] novatx:text-[var(--tuwa-success-text)]",failed:"novatx:bg-[var(--tuwa-error-bg)] novatx:text-[var(--tuwa-error-text)]"},b=x?.[N]??K[N],h=x?.base??"novatx:flex novatx:cursor-pointer novatx:items-center novatx:justify-center novatx:gap-1.5 novatx:rounded-[var(--tuwa-rounded-corners)] novatx:px-3 novatx:py-1.5 novatx:text-sm novatx:font-medium novatx:transition-all novatx:duration-200 novatx:disabled:cursor-not-allowed novatx:disabled:opacity-70";return jsx("button",{...u,disabled:N!=="idle"||u.disabled,onClick:d,className:cn(h,b,e),children:M()})}var ko={[TransactionStatus.Success]:"success",[TransactionStatus.Failed]:"error",[TransactionStatus.Replaced]:"info"};function Hs({adapter:t,connectedWalletAddress:a,connectedAdapterType:n,transactionsPool:r,initialTx:o,executeTxAction:l,closeTxTrackedModal:c,labels:i,features:p,customization:s,...e}){let[x,u]=useState(false),m=useRef(r),N="nova-transactions",y=useMediaQuery("(max-width: 767px)"),C=useMemo(()=>({toasts:p?.toasts??true,transactionsModal:p?.transactionsModal??true,trackingTxModal:p?.trackingTxModal??true}),[p]),T=useMemo(()=>deepMerge(Z,i||{}),[i]),f=useCallback(b=>{if(!C.toasts)return;let h=b.pending?"info":ko[b.status]??"info",w=Q=>jsx(Lt,{...Q,tx:b,openTxInfoModal:C.transactionsModal?()=>u(true):void 0,customization:s?.toast,adapter:t,connectedWalletAddress:a});toast.isActive(b.txKey)?toast.update(b.txKey,{render:w,type:h,containerId:N}):toast(w,{toastId:b.txKey,type:h,closeOnClick:false,containerId:N});},[r,C,s?.toast,t,a]);useEffect(()=>{let b=m.current;Object.values(r).forEach(h=>{let w=b[h.txKey];if(!w&&h.pending){f(h);return}w&&JSON.stringify(w)!==JSON.stringify(h)&&f(h);}),m.current=r;},[r,f]),useEffect(()=>{Object.values(r).forEach(b=>{toast.isActive(b.txKey,N)&&f(b);});},[a,f,r]);let d=!!o?.withTrackedModal&&r[o?.lastTxKey??""]?.isTrackedModalOpen,M=C.toasts&&(!y||!d&&!x),K=useMemo(()=>{let b=s?.toastCloseButton;return b?({closeToast:h})=>jsx(ToastCloseButton,{closeToast:h,...b}):ToastCloseButton},[s?.toastCloseButton]);return jsxs(Pt,{labels:T,children:[M&&jsx(ToastContainer,{position:"bottom-right",stacked:true,autoClose:false,hideProgressBar:true,closeOnClick:false,icon:false,closeButton:K,containerId:N,toastClassName:"novatx:!p-0 novatx:!bg-transparent novatx:!shadow-none novatx:!min-h-0",...e}),C.transactionsModal&&jsx(Gt,{isOpen:x,setIsOpen:u,customization:s?.transactionsInfoModal,adapter:t,connectedWalletAddress:a,connectedAdapterType:n,transactionsPool:r}),C.trackingTxModal&&jsx(Mt,{initialTx:o,onClose:c,onOpenAllTransactions:()=>u(true),transactionsPool:r,customization:s?.trackingTxModal,executeTxAction:l,adapter:t,connectedWalletAddress:a})]})}export{Z as a,Pt as b,g as c,Hs as d,Y as e,O as f,V as g,tt as h,Lt as i,Mt as j,Kt as k,Rt as l,Ot as m,Dt as n,_t as o,Jt as p,Gt as q,zn as r};
|
package/dist/index.cjs
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
'use strict';var
|
|
1
|
+
'use strict';var chunkIUJ7P7EE_cjs=require('./chunk-IUJ7P7EE.cjs');Object.defineProperty(exports,"HashLink",{enumerable:true,get:function(){return chunkIUJ7P7EE_cjs.e}});Object.defineProperty(exports,"StatusAwareText",{enumerable:true,get:function(){return chunkIUJ7P7EE_cjs.f}});Object.defineProperty(exports,"ToastTransaction",{enumerable:true,get:function(){return chunkIUJ7P7EE_cjs.i}});Object.defineProperty(exports,"TrackingTxModal",{enumerable:true,get:function(){return chunkIUJ7P7EE_cjs.j}});Object.defineProperty(exports,"TransactionHistoryItem",{enumerable:true,get:function(){return chunkIUJ7P7EE_cjs.o}});Object.defineProperty(exports,"TransactionKey",{enumerable:true,get:function(){return chunkIUJ7P7EE_cjs.g}});Object.defineProperty(exports,"TransactionStatusBadge",{enumerable:true,get:function(){return chunkIUJ7P7EE_cjs.h}});Object.defineProperty(exports,"TransactionsHistory",{enumerable:true,get:function(){return chunkIUJ7P7EE_cjs.p}});Object.defineProperty(exports,"TransactionsInfoModal",{enumerable:true,get:function(){return chunkIUJ7P7EE_cjs.q}});Object.defineProperty(exports,"TxActionButton",{enumerable:true,get:function(){return chunkIUJ7P7EE_cjs.r}});Object.defineProperty(exports,"TxErrorBlock",{enumerable:true,get:function(){return chunkIUJ7P7EE_cjs.k}});Object.defineProperty(exports,"TxInfoBlock",{enumerable:true,get:function(){return chunkIUJ7P7EE_cjs.l}});Object.defineProperty(exports,"TxProgressIndicator",{enumerable:true,get:function(){return chunkIUJ7P7EE_cjs.m}});Object.defineProperty(exports,"TxStatusVisual",{enumerable:true,get:function(){return chunkIUJ7P7EE_cjs.n}});Object.defineProperty(exports,"defaultLabels",{enumerable:true,get:function(){return chunkIUJ7P7EE_cjs.a}});
|
package/dist/index.css
CHANGED
|
@@ -20,8 +20,6 @@
|
|
|
20
20
|
--novatx-font-weight-medium: 500;
|
|
21
21
|
--novatx-font-weight-semibold: 600;
|
|
22
22
|
--novatx-font-weight-bold: 700;
|
|
23
|
-
--novatx-radius-md: 0.375rem;
|
|
24
|
-
--novatx-radius-lg: 0.5rem;
|
|
25
23
|
--novatx-ease-in-out: cubic-bezier(0.4, 0, 0.2, 1);
|
|
26
24
|
--novatx-animate-spin: spin 1s linear infinite;
|
|
27
25
|
--novatx-animate-pulse: pulse 2s cubic-bezier(0.4, 0, 0.6, 1) infinite;
|
|
@@ -204,18 +202,15 @@
|
|
|
204
202
|
.novatx\:rounded {
|
|
205
203
|
border-radius: 0.25rem;
|
|
206
204
|
}
|
|
205
|
+
.novatx\:rounded-\[var\(--tuwa-rounded-corners\)\] {
|
|
206
|
+
border-radius: var(--tuwa-rounded-corners);
|
|
207
|
+
}
|
|
207
208
|
.novatx\:rounded-full {
|
|
208
209
|
border-radius: calc(infinity * 1px);
|
|
209
210
|
}
|
|
210
|
-
.novatx\:rounded-
|
|
211
|
-
border-radius: var(--
|
|
212
|
-
|
|
213
|
-
.novatx\:rounded-md {
|
|
214
|
-
border-radius: var(--novatx-radius-md);
|
|
215
|
-
}
|
|
216
|
-
.novatx\:rounded-t-md {
|
|
217
|
-
border-top-left-radius: var(--novatx-radius-md);
|
|
218
|
-
border-top-right-radius: var(--novatx-radius-md);
|
|
211
|
+
.novatx\:rounded-t-\[var\(--tuwa-rounded-corners\)\] {
|
|
212
|
+
border-top-left-radius: var(--tuwa-rounded-corners);
|
|
213
|
+
border-top-right-radius: var(--tuwa-rounded-corners);
|
|
219
214
|
}
|
|
220
215
|
.novatx\:border {
|
|
221
216
|
border-style: var(--tw-border-style);
|
|
@@ -269,6 +264,9 @@
|
|
|
269
264
|
.novatx\:bg-\[var\(--tuwa-border-primary\)\] {
|
|
270
265
|
background-color: var(--tuwa-border-primary);
|
|
271
266
|
}
|
|
267
|
+
.novatx\:bg-\[var\(--tuwa-button-gradient-from\)\] {
|
|
268
|
+
background-color: var(--tuwa-button-gradient-from);
|
|
269
|
+
}
|
|
272
270
|
.novatx\:bg-\[var\(--tuwa-error-bg\)\] {
|
|
273
271
|
background-color: var(--tuwa-error-bg);
|
|
274
272
|
}
|
|
@@ -601,9 +599,9 @@
|
|
|
601
599
|
max-width: var(--novatx-container-md);
|
|
602
600
|
}
|
|
603
601
|
}
|
|
604
|
-
.novatx\:sm\:rounded-
|
|
602
|
+
.novatx\:sm\:rounded-\[var\(--tuwa-rounded-corners\)\] {
|
|
605
603
|
@media (width >= 40rem) {
|
|
606
|
-
border-radius: var(--
|
|
604
|
+
border-radius: var(--tuwa-rounded-corners);
|
|
607
605
|
}
|
|
608
606
|
}
|
|
609
607
|
}
|
package/dist/index.d.cts
CHANGED
|
@@ -1,5 +1,5 @@
|
|
|
1
|
-
import { N as NovaTransactionsLabels } from './TransactionsInfoModal-
|
|
2
|
-
export { a as HashLink, H as HashLinkProps, b as StatusAwareText, S as StatusAwareTextProps, o as StepClassNames, p as StepProps, n as StepStatus, d as ToastTransaction, T as ToastTransactionCustomization, c as ToastTransactionProps, g as TrackingTxModal, e as TrackingTxModalCustomization, f as TrackingTxModalProps, x as TransactionHistoryItem, v as TransactionHistoryItemCustomization, w as TransactionHistoryItemProps, z as TransactionKey, y as TransactionKeyProps, I as TransactionStatusBadge, G as TransactionStatusBadgeProps, C as TransactionsHistory, A as TransactionsHistoryCustomization, B as TransactionsHistoryProps, F as TransactionsInfoModal, D as TransactionsInfoModalCustomization, E as TransactionsInfoModalProps, j as TxErrorBlock, h as TxErrorBlockClassNames, i as TxErrorBlockProps, m as TxInfoBlock, k as TxInfoBlockCustomization, l as TxInfoBlockProps, r as TxProgressIndicator, q as TxProgressIndicatorProps, u as TxStatusVisual, s as TxStatusVisualClassNames, t as TxStatusVisualProps } from './TransactionsInfoModal-
|
|
1
|
+
import { N as NovaTransactionsLabels } from './TransactionsInfoModal-D7eykTZp.cjs';
|
|
2
|
+
export { a as HashLink, H as HashLinkProps, b as StatusAwareText, S as StatusAwareTextProps, o as StepClassNames, p as StepProps, n as StepStatus, d as ToastTransaction, T as ToastTransactionCustomization, c as ToastTransactionProps, g as TrackingTxModal, e as TrackingTxModalCustomization, f as TrackingTxModalProps, x as TransactionHistoryItem, v as TransactionHistoryItemCustomization, w as TransactionHistoryItemProps, z as TransactionKey, y as TransactionKeyProps, I as TransactionStatusBadge, G as TransactionStatusBadgeProps, C as TransactionsHistory, A as TransactionsHistoryCustomization, B as TransactionsHistoryProps, F as TransactionsInfoModal, D as TransactionsInfoModalCustomization, E as TransactionsInfoModalProps, j as TxErrorBlock, h as TxErrorBlockClassNames, i as TxErrorBlockProps, m as TxInfoBlock, k as TxInfoBlockCustomization, l as TxInfoBlockProps, r as TxProgressIndicator, q as TxProgressIndicatorProps, u as TxStatusVisual, s as TxStatusVisualClassNames, t as TxStatusVisualProps } from './TransactionsInfoModal-D7eykTZp.cjs';
|
|
3
3
|
import * as react_jsx_runtime from 'react/jsx-runtime';
|
|
4
4
|
import { Transaction, TransactionPool } from '@tuwaio/pulsar-core';
|
|
5
5
|
import { ButtonHTMLAttributes, ReactNode } from 'react';
|
package/dist/index.d.ts
CHANGED
|
@@ -1,5 +1,5 @@
|
|
|
1
|
-
import { N as NovaTransactionsLabels } from './TransactionsInfoModal-
|
|
2
|
-
export { a as HashLink, H as HashLinkProps, b as StatusAwareText, S as StatusAwareTextProps, o as StepClassNames, p as StepProps, n as StepStatus, d as ToastTransaction, T as ToastTransactionCustomization, c as ToastTransactionProps, g as TrackingTxModal, e as TrackingTxModalCustomization, f as TrackingTxModalProps, x as TransactionHistoryItem, v as TransactionHistoryItemCustomization, w as TransactionHistoryItemProps, z as TransactionKey, y as TransactionKeyProps, I as TransactionStatusBadge, G as TransactionStatusBadgeProps, C as TransactionsHistory, A as TransactionsHistoryCustomization, B as TransactionsHistoryProps, F as TransactionsInfoModal, D as TransactionsInfoModalCustomization, E as TransactionsInfoModalProps, j as TxErrorBlock, h as TxErrorBlockClassNames, i as TxErrorBlockProps, m as TxInfoBlock, k as TxInfoBlockCustomization, l as TxInfoBlockProps, r as TxProgressIndicator, q as TxProgressIndicatorProps, u as TxStatusVisual, s as TxStatusVisualClassNames, t as TxStatusVisualProps } from './TransactionsInfoModal-
|
|
1
|
+
import { N as NovaTransactionsLabels } from './TransactionsInfoModal-D7eykTZp.js';
|
|
2
|
+
export { a as HashLink, H as HashLinkProps, b as StatusAwareText, S as StatusAwareTextProps, o as StepClassNames, p as StepProps, n as StepStatus, d as ToastTransaction, T as ToastTransactionCustomization, c as ToastTransactionProps, g as TrackingTxModal, e as TrackingTxModalCustomization, f as TrackingTxModalProps, x as TransactionHistoryItem, v as TransactionHistoryItemCustomization, w as TransactionHistoryItemProps, z as TransactionKey, y as TransactionKeyProps, I as TransactionStatusBadge, G as TransactionStatusBadgeProps, C as TransactionsHistory, A as TransactionsHistoryCustomization, B as TransactionsHistoryProps, F as TransactionsInfoModal, D as TransactionsInfoModalCustomization, E as TransactionsInfoModalProps, j as TxErrorBlock, h as TxErrorBlockClassNames, i as TxErrorBlockProps, m as TxInfoBlock, k as TxInfoBlockCustomization, l as TxInfoBlockProps, r as TxProgressIndicator, q as TxProgressIndicatorProps, u as TxStatusVisual, s as TxStatusVisualClassNames, t as TxStatusVisualProps } from './TransactionsInfoModal-D7eykTZp.js';
|
|
3
3
|
import * as react_jsx_runtime from 'react/jsx-runtime';
|
|
4
4
|
import { Transaction, TransactionPool } from '@tuwaio/pulsar-core';
|
|
5
5
|
import { ButtonHTMLAttributes, ReactNode } from 'react';
|
package/dist/index.js
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
export{e as HashLink,f as StatusAwareText,i as ToastTransaction,j as TrackingTxModal,o as TransactionHistoryItem,g as TransactionKey,h as TransactionStatusBadge,p as TransactionsHistory,q as TransactionsInfoModal,r as TxActionButton,k as TxErrorBlock,l as TxInfoBlock,m as TxProgressIndicator,n as TxStatusVisual,a as defaultLabels}from'./chunk-
|
|
1
|
+
export{e as HashLink,f as StatusAwareText,i as ToastTransaction,j as TrackingTxModal,o as TransactionHistoryItem,g as TransactionKey,h as TransactionStatusBadge,p as TransactionsHistory,q as TransactionsInfoModal,r as TxActionButton,k as TxErrorBlock,l as TxInfoBlock,m as TxProgressIndicator,n as TxStatusVisual,a as defaultLabels}from'./chunk-PUSPAQGZ.js';
|
package/dist/providers/index.cjs
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
'use strict';var
|
|
1
|
+
'use strict';var chunkIUJ7P7EE_cjs=require('../chunk-IUJ7P7EE.cjs');Object.defineProperty(exports,"NovaTransactionsLabelsProvider",{enumerable:true,get:function(){return chunkIUJ7P7EE_cjs.b}});Object.defineProperty(exports,"NovaTransactionsProvider",{enumerable:true,get:function(){return chunkIUJ7P7EE_cjs.d}});Object.defineProperty(exports,"useLabels",{enumerable:true,get:function(){return chunkIUJ7P7EE_cjs.c}});
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import * as react_jsx_runtime from 'react/jsx-runtime';
|
|
2
2
|
import { ReactNode } from 'react';
|
|
3
|
-
import { N as NovaTransactionsLabels } from '../TransactionsInfoModal-
|
|
4
|
-
export { K as NovaTransactionsProvider, J as NovaTransactionsProviderProps } from '../TransactionsInfoModal-
|
|
3
|
+
import { N as NovaTransactionsLabels } from '../TransactionsInfoModal-D7eykTZp.cjs';
|
|
4
|
+
export { K as NovaTransactionsProvider, J as NovaTransactionsProviderProps } from '../TransactionsInfoModal-D7eykTZp.cjs';
|
|
5
5
|
import '@tuwaio/nova-core';
|
|
6
6
|
import '@tuwaio/pulsar-core';
|
|
7
7
|
import '@tuwaio/orbit-core';
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import * as react_jsx_runtime from 'react/jsx-runtime';
|
|
2
2
|
import { ReactNode } from 'react';
|
|
3
|
-
import { N as NovaTransactionsLabels } from '../TransactionsInfoModal-
|
|
4
|
-
export { K as NovaTransactionsProvider, J as NovaTransactionsProviderProps } from '../TransactionsInfoModal-
|
|
3
|
+
import { N as NovaTransactionsLabels } from '../TransactionsInfoModal-D7eykTZp.js';
|
|
4
|
+
export { K as NovaTransactionsProvider, J as NovaTransactionsProviderProps } from '../TransactionsInfoModal-D7eykTZp.js';
|
|
5
5
|
import '@tuwaio/nova-core';
|
|
6
6
|
import '@tuwaio/pulsar-core';
|
|
7
7
|
import '@tuwaio/orbit-core';
|
package/dist/providers/index.js
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
export{b as NovaTransactionsLabelsProvider,d as NovaTransactionsProvider,c as useLabels}from'../chunk-
|
|
1
|
+
export{b as NovaTransactionsLabelsProvider,d as NovaTransactionsProvider,c as useLabels}from'../chunk-PUSPAQGZ.js';
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@tuwaio/nova-transactions",
|
|
3
|
-
"version": "0.
|
|
3
|
+
"version": "0.3.0",
|
|
4
4
|
"private": false,
|
|
5
5
|
"author": "Oleksandr Tkach",
|
|
6
6
|
"license": "Apache-2.0",
|
|
@@ -69,34 +69,34 @@
|
|
|
69
69
|
"framer-motion": "12.x.x",
|
|
70
70
|
"react": ">=19.2.3",
|
|
71
71
|
"react-toastify": ">=11",
|
|
72
|
-
"@tuwaio/pulsar-core": ">=0.
|
|
73
|
-
"@tuwaio/nova-core": ">=0.
|
|
74
|
-
"@tuwaio/orbit-core": ">=0.2.
|
|
72
|
+
"@tuwaio/pulsar-core": ">=0.5",
|
|
73
|
+
"@tuwaio/nova-core": ">=0.3",
|
|
74
|
+
"@tuwaio/orbit-core": ">=0.2.7",
|
|
75
75
|
"dayjs": "1.x.x"
|
|
76
76
|
},
|
|
77
77
|
"devDependencies": {
|
|
78
|
-
"@tuwaio/orbit-core": "^0.2.
|
|
79
|
-
"@tuwaio/pulsar-core": "^0.
|
|
78
|
+
"@tuwaio/orbit-core": "^0.2.7",
|
|
79
|
+
"@tuwaio/pulsar-core": "^0.5.0",
|
|
80
80
|
"dayjs": "^1.11.19",
|
|
81
|
-
"@web3icons/react": "^4.1.
|
|
82
|
-
"@web3icons/common": "^0.11.
|
|
81
|
+
"@web3icons/react": "^4.1.16",
|
|
82
|
+
"@web3icons/common": "^0.11.45",
|
|
83
83
|
"@heroicons/react": "^2.2.0",
|
|
84
84
|
"@radix-ui/react-dialog": "^1.1.15",
|
|
85
85
|
"@tailwindcss/postcss": "^4.1.18",
|
|
86
|
-
"@types/react": "^19.2.
|
|
87
|
-
"autoprefixer": "^10.4.
|
|
86
|
+
"@types/react": "^19.2.10",
|
|
87
|
+
"autoprefixer": "^10.4.24",
|
|
88
88
|
"clsx": "^2.1.1",
|
|
89
|
-
"framer-motion": "^12.
|
|
89
|
+
"framer-motion": "^12.29.2",
|
|
90
90
|
"immer": "^11.1.3",
|
|
91
91
|
"postcss": "^8.5.6",
|
|
92
92
|
"postcss-cli": "^11.0.1",
|
|
93
|
-
"react": "^19.2.
|
|
93
|
+
"react": "^19.2.4",
|
|
94
94
|
"react-toastify": "^11.0.5",
|
|
95
95
|
"tsup": "^8.5.1",
|
|
96
96
|
"typescript": "~5.9.3",
|
|
97
97
|
"tailwindcss": "^4.1.18",
|
|
98
|
-
"zustand": "^5.0.
|
|
99
|
-
"@tuwaio/nova-core": "^0.
|
|
98
|
+
"zustand": "^5.0.11",
|
|
99
|
+
"@tuwaio/nova-core": "^0.3.0"
|
|
100
100
|
},
|
|
101
101
|
"scripts": {
|
|
102
102
|
"build": "tsup && pnpm exec postcss ./src/styles/app.css -o ./dist/index.css"
|
package/dist/chunk-B3JQWEZF.cjs
DELETED
|
@@ -1 +0,0 @@
|
|
|
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'),orbitCore=require('@tuwaio/orbit-core'),Wt=require('dayjs'),no=require('dayjs/plugin/relativeTime');function _interopDefault(e){return e&&e.__esModule?e:{default:e}}var Wt__default=/*#__PURE__*/_interopDefault(Wt);var no__default=/*#__PURE__*/_interopDefault(no);var j={transactionsModal:{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:{openTransactionsInfo:"Open transactions"},statuses:{pending:"Pending",success:"Success",failed:"Failed",reverted:"Reverted",replaced:"Replaced",unknown:"Unknown",confirmationsLabel:"Confirmations"},hashLabels:{gelato:"Gelato Task ID",safe:"Safe Tx Hash",original:"Original Tx Hash",replaced:"Replaced Tx Hash",default:"Tx Hash",recentBlockhash:"Recent Blockhash",solana:"Signature"},txInfo:{started:"Started",network:"Network",slot:"Slot"},txError:{title:"Error",copied:"Copied!"},trackingModal:{title:"Transaction Overview",processing:"Processing...",close:"Close",allTransactions:"All transactions",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 ht=react.createContext(j),Nt=({labels:t,children:a})=>jsxRuntime.jsx(ht.Provider,{value:t,children:a}),g=()=>react.useContext(ht);function $({label:t,hash:a,explorerUrl:n,variant:s="default",className:o,classNames:l}){let{isCopied:i,copy:c}=novaCore.useCopyToClipboard(),{actions:p,txError:r}=g(),e=novaCore.cn("novatx:flex novatx:items-center novatx:justify-between",{"novatx:text-sm":s==="default","novatx:text-xs":s==="compact"},o),d=novaCore.cn("novatx:pr-1",{"novatx:font-bold novatx:text-[var(--tuwa-text-primary)]":s==="default","novatx:font-medium novatx:text-[var(--tuwa-text-secondary)]":s==="compact"},l?.label),x=jsxRuntime.jsx("span",{className:novaCore.cn("novatx:font-mono",l?.hash),children:novaCore.textCenterEllipsis(a,5,5)});return jsxRuntime.jsxs("div",{className:e,children:[t&&jsxRuntime.jsxs("span",{className:d,children:[t,":"]}),jsxRuntime.jsxs("div",{className:"novatx:flex novatx:items-center novatx:gap-x-2",children:[n?jsxRuntime.jsxs("a",{href:n,target:"_blank",rel:"noopener noreferrer",className:novaCore.cn("novatx:flex novatx:items-center novatx:gap-x-1 novatx:text-[var(--tuwa-text-accent)] novatx:transition-colors novatx:hover:underline",l?.link),title:p.viewOnExplorer,"aria-label":p.viewOnExplorer,children:[x,jsxRuntime.jsx(solid.ArrowTopRightOnSquareIcon,{className:novaCore.cn("novatx:h-4 novatx:w-4",l?.linkIcon)})]}):jsxRuntime.jsx("span",{className:novaCore.cn("novatx:text-[var(--tuwa-text-primary)]",l?.link),children:x}),jsxRuntime.jsx("button",{type:"button",onClick:()=>c(a),className:novaCore.cn("novatx:cursor-pointer novatx:text-[var(--tuwa-text-tertiary)] novatx:transition-colors novatx:hover:text-[var(--tuwa-text-secondary)]",l?.copyButton),title:i?r.copied:p.copy,"aria-label":i?r.copied:p.copy,children:i?jsxRuntime.jsx(solid.CheckIcon,{className:"novatx:h-4 novatx:w-4 novatx:text-[var(--tuwa-success-icon)]"}):jsxRuntime.jsx(solid.DocumentDuplicateIcon,{className:"novatx:h-4 novatx:w-4"})})]})]})}var wt={[pulsarCore.TransactionStatus.Success]:{index:1,colorClass:"novatx:text-[var(--tuwa-success-text)]"},[pulsarCore.TransactionStatus.Failed]:{index:2,colorClass:"novatx:text-[var(--tuwa-error-text)]"},[pulsarCore.TransactionStatus.Replaced]:{index:3,colorClass:"novatx:text-[var(--tuwa-text-secondary)]"},default:{index:0,colorClass:"novatx:text-[var(--tuwa-text-primary)]"}};function R({txStatus:t,source:a,fallback:n,variant:s,className:o,applyColor:l=false}){let i,c="";if(typeof a=="string")i=a;else if(Array.isArray(a)){let e=wt[t||"default"]??wt.default;i=a[e.index],l&&(c=e.colorClass);}else i=n;return i?jsxRuntime.jsx("div",{className:novaCore.cn(s==="title"?"novatx:text-sm novatx:font-semibold novatx:text-[var(--tuwa-text-primary)]":"novatx:mt-1 novatx:text-xs novatx:text-[var(--tuwa-text-secondary)]",c,o),children:i}):null}function _({tx:t,adapter:a,variant:n="toast",className:s,renderHashLink:o,confirmations:l,hashLinkClassNames:i,originalHashLinkClassNames:c}){let{hashLabels:p,statuses:r}=g(),e=orbitCore.selectAdapterByKey({adapterKey:t.adapter,adapter:a});if(!e)return null;let d=(C,f)=>o?o(C):jsxRuntime.jsx($,{...C,classNames:f??i}),x=n==="toast"?"novatx:mt-2 novatx:flex novatx:w-full novatx:flex-col novatx:gap-y-2 novatx:border-t novatx:border-[var(--tuwa-border-primary)] novatx:pt-2":"novatx:flex novatx:w-full novatx:flex-col novatx:gap-y-2",u=p[String(t.tracker)],T=u?d({label:u,hash:t.txKey,variant:t.tracker!==pulsarCore.TransactionTracker.Solana?"compact":"default",explorerUrl:e.getExplorerTxUrl&&t.tracker===pulsarCore.TransactionTracker.Solana?e?.getExplorerTxUrl(t):void 0}):null,h=(()=>{let C=t.hash,f=t.replacedTxHash;return !C&&!f?null:f?jsxRuntime.jsxs(jsxRuntime.Fragment,{children:[C&&d({label:p.original,hash:C,variant:"compact"},c),typeof e.getExplorerTxUrl<"u"&&d({label:p.replaced,hash:f,explorerUrl:e.getExplorerTxUrl(t)})]}):C&&typeof e.getExplorerTxUrl<"u"&&d({label:p.default,hash:C,explorerUrl:e.getExplorerTxUrl(t)})})(),y=u&&u!==p.default&&t.txKey!==t.hash;return jsxRuntime.jsxs("div",{className:novaCore.cn(x,s),children:[y&&T,h,typeof l=="number"&&jsxRuntime.jsxs("p",{className:"novatx:text-xs novatx:text-[var(--tuwa-text-tertiary)]",children:[r.confirmationsLabel,": ",l]})]})}var ua=t=>({Pending:{label:t.pending,Icon:solid.ArrowPathIcon,badgeClasses:"novatx:bg-[var(--tuwa-pending-bg)] novatx:text-[var(--tuwa-pending-text)]",iconClasses:"novatx:animate-spin novatx:text-[var(--tuwa-pending-icon)]"},[pulsarCore.TransactionStatus.Success]:{label:t.success,Icon:solid.CheckCircleIcon,badgeClasses:"novatx:bg-[var(--tuwa-success-bg)] novatx:text-[var(--tuwa-success-text)]",iconClasses:"novatx:text-[var(--tuwa-success-icon)]"},[pulsarCore.TransactionStatus.Failed]:{label:t.failed,Icon:solid.XCircleIcon,badgeClasses:"novatx:bg-[var(--tuwa-error-bg)] novatx:text-[var(--tuwa-error-text)]",iconClasses:"novatx:text-[var(--tuwa-error-icon)]"},[pulsarCore.TransactionStatus.Replaced]:{label:t.replaced,Icon:solid.ArrowPathIcon,badgeClasses:"novatx:bg-[var(--tuwa-info-bg)] novatx:text-[var(--tuwa-info-text)]",iconClasses:"novatx:text-[var(--tuwa-info-icon)]"}});function at({tx:t,className:a,classNames:n}){let{statuses:s}=g(),o=react.useMemo(()=>ua(s),[s]),l="novatx:inline-flex novatx:items-center novatx:gap-x-1.5 novatx:rounded-full novatx:px-2 novatx:py-1 novatx:text-xs novatx:font-medium",i=t.pending?"Pending":t.status,c=i?o[i]:null;if(!c)return jsxRuntime.jsx("div",{className:novaCore.cn(l,"novatx:bg-[var(--tuwa-info-bg)] novatx:text-[var(--tuwa-info-text)]",n?.container,a),children:jsxRuntime.jsx("span",{className:n?.label,children:t.status??s.unknown})});let{label:p,Icon:r,badgeClasses:e,iconClasses:d}=c;return jsxRuntime.jsxs("div",{className:novaCore.cn(l,e,n?.container,a),children:[jsxRuntime.jsx(r,{className:novaCore.cn("novatx:h-4 novatx:w-4",d,n?.icon)}),jsxRuntime.jsx("span",{className:n?.label,children:p})]})}var Ca=({onClick:t,children:a,className:n})=>jsxRuntime.jsx("button",{onClick:t,type:"button",className:novaCore.cn("novatx:cursor-pointer novatx:text-sm novatx:font-medium novatx:text-[var(--tuwa-text-accent)] novatx:transition-opacity novatx:hover:opacity-80",n),children:a}),ba=({onClick:t,children:a,className:n})=>jsxRuntime.jsx("button",{onClick:t,type:"button",className:novaCore.cn("novatx:cursor-pointer novatx:text-sm novatx:font-medium novatx:text-[var(--tuwa-text-secondary)] novatx:transition-opacity novatx:hover:opacity-80",n),children:a}),ha=({onClick:t,children:a,className:n})=>jsxRuntime.jsx("button",{className:n||"novatx:cursor-pointer novatx:rounded-md novatx:bg-gradient-to-r novatx:from-[var(--tuwa-button-gradient-from)] novatx:to-[var(--tuwa-button-gradient-to)] novatx:px-3 novatx:py-1 novatx:text-xs novatx:font-bold novatx:text-[var(--tuwa-text-on-accent)] novatx:shadow-lg novatx:transition-all novatx:duration-200 novatx:ease-in-out novatx:hover:shadow-xl novatx:hover:from-[var(--tuwa-button-gradient-from-hover)] novatx:hover:to-[var(--tuwa-button-gradient-to-hover)] novatx:active:scale-95",onClick:t,type:"button",children:a});function Bt({openTxInfoModal:t,tx:a,icon:n,className:s,customization:o,connectedWalletAddress:l,adapter:i}){let{actions:c,toast:p}=g(),r=orbitCore.selectAdapterByKey({adapterKey:a.adapter,adapter:i}),e=!!(a.tracker==="ethereum"&&a.pending&&r?.speedUpTxAction&&r?.cancelTxAction&&a.from.toLowerCase()===l?.toLowerCase()&&["metamask"].includes(a.connectorType.split(":")[1])),d=()=>{e&&r.cancelTxAction(a);},x=()=>{e&&r.speedUpTxAction(a);},{StatusAwareText:u=R,TransactionKey:T=_,StatusBadge:h=at,SpeedUpButton:y=Ca,CancelButton:C=ba,TxInfoButton:f=ha}=o?.components??{},m=o?.classNames;return jsxRuntime.jsxs("div",{className:novaCore.cn("novatx:flex novatx:w-full novatx:flex-col novatx:gap-3 novatx:rounded-lg novatx:bg-[var(--tuwa-bg-primary)] novatx:p-4 novatx:shadow-md",m?.container,s),children:[jsxRuntime.jsxs("div",{className:novaCore.cn("novatx:flex novatx:items-center novatx:gap-3",m?.header),children:[jsxRuntime.jsx("div",{className:novaCore.cn("novatx:w-[40px] novatx:flex-shrink-0",m?.iconWrapper),title:novaCore.getChainName(orbitCore.setChainId(a.chainId)),children:n??jsxRuntime.jsx(novaCore.NetworkIcon,{chainId:orbitCore.setChainId(a.chainId)})}),jsxRuntime.jsxs("div",{className:novaCore.cn("novatx:flex-1",m?.contentWrapper),children:[jsxRuntime.jsx(u,{txStatus:a.status,source:a.title,fallback:a.type,variant:"title",applyColor:true,className:m?.title}),jsxRuntime.jsx(u,{txStatus:a.status,source:a.description,variant:"description",className:m?.description})]})]}),jsxRuntime.jsxs("div",{children:[jsxRuntime.jsx(T,{adapter:i,tx:a,variant:"toast",className:m?.transactionKey,hashLinkClassNames:{label:m?.hashLabel,link:m?.hashLink,copyButton:m?.hashCopyButton},originalHashLinkClassNames:{label:m?.originalHashLabel,link:m?.originalHashLink,copyButton:m?.originalHashCopyButton}}),jsxRuntime.jsxs("div",{className:novaCore.cn("novatx:mt-3 novatx:flex novatx:items-center novatx:justify-between",m?.footer),children:[jsxRuntime.jsx(h,{tx:a,className:m?.statusBadge,classNames:{icon:m?.statusBadgeIcon,label:m?.statusBadgeLabel}}),e?jsxRuntime.jsxs("div",{className:novaCore.cn("novatx:flex novatx:items-center novatx:gap-4",m?.actionsContainer),children:[jsxRuntime.jsx(y,{onClick:x,className:m?.speedUpButton,children:c.speedUp}),jsxRuntime.jsx(C,{onClick:d,className:m?.cancelButton,children:c.cancel})]}):t&&!!l&&jsxRuntime.jsx(f,{onClick:t,className:m?.txInfoButton,children:p.openTransactionsInfo})]})]})]})}function Ht({adapter:t,onClose:a,onOpenAllTransactions:n,className:s,customization:o,transactionsPool:l,executeTxAction:i,initialTx:c,connectedWalletAddress:p}){let r=react.useMemo(()=>c?.lastTxKey?l[c.lastTxKey]:void 0,[l,c]),e=r??c,d=c?.withTrackedModal&&!r||(r?.isTrackedModalOpen??false),{isProcessing:x,isSucceed:u,isFailed:T,isReplaced:h}=react.useMemo(()=>{let F=r?.status,Qt=c?.isInitializing??false,Zt=r?.pending??false;return {isProcessing:Qt||Zt,isSucceed:F===pulsarCore.TransactionStatus.Success,isFailed:r?.isError||!!c?.errorMessage,isReplaced:F===pulsarCore.TransactionStatus.Replaced}},[r,c]),y=react.useMemo(()=>e?orbitCore.selectAdapterByKey({adapterKey:e.adapter,adapter:t}):void 0,[e,t]),C=!!(T&&e&&c?.actionFunction&&i),f=!!(y?.speedUpTxAction&&y?.cancelTxAction&&r?.pending&&r.tracker==="ethereum"),m=()=>{if(!C||!y?.retryTxAction)return;let F={adapter:e.adapter,type:e.type,desiredChainID:"desiredChainID"in e?e.desiredChainID:e.chainId,actionFunction:c?.actionFunction,title:e.title,description:e.description,payload:e.payload,rpcUrl:"rpcUrl"in e?e?.rpcUrl:"desiredChainID"in e?e.desiredChainID:e.chainId.split(":")[1],withTrackedModal:"withTrackedModal"in e?e.withTrackedModal:false};y.retryTxAction({tx:F,txKey:r?.txKey??"",onClose:a,executeTxAction:i});},B=f&&r&&["metamask"].includes(r?.connectorType.split(":")[1]),U=()=>{B&&y.cancelTxAction(r);},b=()=>{B&&y.speedUpTxAction(r);},w=o?.components?.Header,N=o?.components?.Footer,Z=o?.components?.StatusVisual,yt=o?.components?.ProgressIndicator,Ct=o?.components?.InfoBlock,bt=o?.components?.ErrorBlock;if(!e)return null;let W=o?.classNames;return jsxRuntime.jsx(novaCore.Dialog,{open:d,onOpenChange:F=>!F&&a(r?.txKey),children:jsxRuntime.jsx(novaCore.DialogContent,{className:novaCore.cn("novatx:w-full novatx:sm:max-w-md",o?.modalProps?.className),...o?.modalProps,children:jsxRuntime.jsxs("div",{className:novaCore.cn("novatx:relative novatx:flex novatx:w-full novatx:flex-col",W?.container,s),children:[w?jsxRuntime.jsx(w,{onClose:()=>a(r?.txKey),title:jsxRuntime.jsx(Lt,{tx:e,className:W?.headerTitle})}):jsxRuntime.jsx(La,{onClose:()=>a(r?.txKey),title:jsxRuntime.jsx(Lt,{tx:e,className:W?.headerTitle}),classNames:W}),jsxRuntime.jsxs("main",{className:novaCore.cn("novatx:flex novatx:flex-col novatx:gap-4 novatx:p-4",W?.main),children:[Z?jsxRuntime.jsx(Z,{isProcessing:x,isSucceed:u,isFailed:T,isReplaced:h}):jsxRuntime.jsx(Rt,{isProcessing:x,isSucceed:u,isFailed:T,isReplaced:h,className:o?.statusVisualCustomization?.className,iconClassNames:o?.statusVisualCustomization?.iconClassNames}),yt?jsxRuntime.jsx(yt,{isProcessing:x,isSucceed:u,isFailed:T,isReplaced:h}):jsxRuntime.jsx(Kt,{isProcessing:x,isSucceed:u,isFailed:T,isReplaced:h,className:o?.progressIndicatorCustomization?.className,stepClassNames:o?.progressIndicatorCustomization?.stepClassNames}),Ct?jsxRuntime.jsx(Ct,{tx:e,adapter:t}):jsxRuntime.jsx(At,{tx:e,adapter:t,customization:o?.infoBlockCustomization}),bt?jsxRuntime.jsx(bt,{error:r?.errorMessage||c?.errorMessage}):jsxRuntime.jsx(Mt,{error:r?.errorMessage||c?.errorMessage,className:o?.errorBlockCustomization?.className,classNames:o?.errorBlockCustomization?.classNames})]}),N?jsxRuntime.jsx(N,{onClose:()=>a(r?.txKey),onOpenAllTransactions:n,isProcessing:x,isFailed:T,canReplace:f,onRetry:C?m:void 0,onSpeedUp:B?b:void 0,onCancel:B?U:void 0,connectedWalletAddress:p}):jsxRuntime.jsx(Ma,{onClose:()=>a(r?.txKey),onOpenAllTransactions:n,isProcessing:x,isFailed:T,canReplace:f,onRetry:C?m:void 0,onSpeedUp:B?b:void 0,onCancel:B?U:void 0,connectedWalletAddress:p,classNames:W})]})})})}function Lt({tx:t,className:a}){return jsxRuntime.jsx(R,{txStatus:"status"in t?t.status:void 0,source:t.title,fallback:t.type,variant:"title",className:novaCore.cn("novatx:text-lg",a)})}var La=({onClose:t,title:a,classNames:n})=>{let{actions:s}=g();return jsxRuntime.jsxs(novaCore.DialogHeader,{className:n?.header,children:[jsxRuntime.jsx(novaCore.DialogTitle,{className:n?.headerTitle,children:a}),jsxRuntime.jsx(novaCore.DialogClose,{asChild:true,children:jsxRuntime.jsx("button",{type:"button",onClick:()=>t(),"aria-label":s.close,className:novaCore.cn("novatx:cursor-pointer novatx:rounded-full novatx:p-1 novatx:text-[var(--tuwa-text-tertiary)] novatx:transition-colors novatx:hover:bg-[var(--tuwa-bg-muted)] novatx:hover:text-[var(--tuwa-text-primary)]",n?.closeButton),children:jsxRuntime.jsx(novaCore.CloseIcon,{})})})]})},Ha=({isFailed:t,onRetry:a,isProcessing:n,canReplace:s,connectedWalletAddress:o,onOpenAllTransactions:l,classNames:i})=>{let{trackingModal:c}=g();return t&&a?jsxRuntime.jsx("button",{type:"button",onClick:a,className:novaCore.cn("novatx:cursor-pointer novatx:rounded-t-md novatx:sm:rounded-md novatx:bg-gradient-to-r novatx:from-[var(--tuwa-button-gradient-from)] novatx:to-[var(--tuwa-button-gradient-to)] novatx:px-4 novatx:py-2 novatx:text-sm novatx:font-semibold novatx:text-[var(--tuwa-text-on-accent)] novatx:transition-opacity novatx:hover:from-[var(--tuwa-button-gradient-from-hover)] novatx:hover:to-[var(--tuwa-button-gradient-to-hover)]",i?.retryButton),children:c.retry}):!n&&!s&&o?jsxRuntime.jsx("button",{type:"button",onClick:l,className:novaCore.cn("novatx:cursor-pointer novatx:rounded-md novatx:bg-[var(--tuwa-bg-muted)] novatx:px-4 novatx:py-2 novatx:text-sm novatx:font-semibold novatx:text-[var(--tuwa-text-primary)] novatx:transition-colors novatx:hover:bg-[var(--tuwa-border-primary)]",i?.allTransactionsButton),children:c.allTransactions}):null},Ma=({onClose:t,onOpenAllTransactions:a,isProcessing:n,onRetry:s,onSpeedUp:o,onCancel:l,canReplace:i,isFailed:c,connectedWalletAddress:p,classNames:r})=>{let{trackingModal:e,actions:d}=g();return jsxRuntime.jsxs("footer",{className:novaCore.cn("novatx:flex novatx:w-full novatx:items-center novatx:justify-between novatx:border-t novatx:border-[var(--tuwa-border-primary)] novatx:p-4",r?.footer),children:[jsxRuntime.jsx("div",{className:novaCore.cn("novatx:flex novatx:items-center novatx:gap-4",r?.footerActions),children:i&&o&&l&&jsxRuntime.jsxs(jsxRuntime.Fragment,{children:[jsxRuntime.jsx("button",{type:"button",onClick:o,className:novaCore.cn("novatx:cursor-pointer novatx:text-sm novatx:font-medium novatx:text-[var(--tuwa-text-accent)] novatx:transition-opacity novatx:hover:opacity-80",r?.speedUpButton),children:d.speedUp}),jsxRuntime.jsx("button",{type:"button",onClick:l,className:novaCore.cn("novatx:cursor-pointer novatx:text-sm novatx:font-medium novatx:text-[var(--tuwa-text-secondary)] novatx:transition-opacity novatx:hover:opacity-80",r?.cancelButton),children:d.cancel})]})}),jsxRuntime.jsxs("div",{className:novaCore.cn("novatx:flex novatx:items-center novatx:gap-3",r?.footerButtons),children:[jsxRuntime.jsx(Ha,{isFailed:c,onRetry:s,isProcessing:n,canReplace:i,connectedWalletAddress:p,onOpenAllTransactions:a,classNames:r}),jsxRuntime.jsx("button",{type:"button",onClick:t,disabled:n&&!i,className:novaCore.cn("novatx:cursor-pointer novatx:rounded-md novatx:bg-[var(--tuwa-bg-muted)] novatx:px-4 novatx:py-2 novatx:text-sm novatx:font-semibold novatx:text-[var(--tuwa-text-primary)] novatx:transition-colors novatx:hover:bg-[var(--tuwa-border-primary)] novatx:disabled:cursor-not-allowed novatx:disabled:opacity-50",r?.closeModalButton),children:n&&!i?e.processing:e.close})]})]})};function Mt({error:t,className:a,classNames:n}){let{isCopied:s,copy:o}=novaCore.useCopyToClipboard(),{actions:l,txError:i}=g();return t?jsxRuntime.jsxs("div",{className:novaCore.cn("novatx:rounded-lg novatx:border novatx:border-[var(--tuwa-error-icon)]/30 novatx:bg-[var(--tuwa-error-bg)] novatx:p-3 novatx:text-sm",n?.container,a),children:[jsxRuntime.jsxs("div",{className:novaCore.cn("novatx:mb-2 novatx:flex novatx:items-center novatx:justify-between",n?.header),children:[jsxRuntime.jsxs("div",{className:novaCore.cn("novatx:flex novatx:items-center novatx:gap-2 novatx:font-bold novatx:text-[var(--tuwa-error-icon)]",n?.title),children:[jsxRuntime.jsx(solid.ExclamationTriangleIcon,{className:novaCore.cn("novatx:h-5 novatx:w-5",n?.icon)}),jsxRuntime.jsx("span",{children:i.title})]}),jsxRuntime.jsx("button",{type:"button",onClick:()=>o(t),title:s?i.copied:l.copy,"aria-label":s?i.copied:`${l.copy} error message`,className:novaCore.cn("novatx:cursor-pointer novatx:text-[var(--tuwa-error-icon)]/50 novatx:transition-colors novatx:hover:text-[var(--tuwa-error-icon)]",n?.copyButton),children:s?jsxRuntime.jsx(solid.CheckIcon,{className:"novatx:h-5 novatx:w-5 novatx:text-[var(--tuwa-success-icon)]"}):jsxRuntime.jsx(solid.DocumentDuplicateIcon,{className:"novatx:h-5 novatx:w-5"})})]}),jsxRuntime.jsx("div",{className:novaCore.cn("novatx:max-h-24 novatx:overflow-y-auto novatx:rounded novatx:bg-[var(--tuwa-bg-primary)] novatx:p-2",n?.messageContainer),children:jsxRuntime.jsx("p",{className:novaCore.cn("novatx:font-mono novatx:text-xs novatx:text-[var(--tuwa-error-text)] novatx:break-all",n?.messageText),children:t})})]}):null}function _a({label:t,value:a,classNames:n}){return jsxRuntime.jsxs("div",{className:novaCore.cn("novatx:flex novatx:items-center novatx:justify-between novatx:text-sm",n?.row),children:[jsxRuntime.jsx("span",{className:novaCore.cn("novatx:text-[var(--tuwa-text-secondary)]",n?.label),children:t}),jsxRuntime.jsx("span",{className:novaCore.cn("novatx:font-medium novatx:text-[var(--tuwa-text-primary)]",n?.value),children:a})]})}function At({tx:t,adapter:a,className:n,customization:s}){let{txInfo:o,statuses:l,hashLabels:i}=g(),c=orbitCore.selectAdapterByKey({adapterKey:t.adapter,adapter:a});if(!c)return null;let{InfoRow:p=_a}=s?.components??{},r=s?.classNames,e={row:r?.row,label:r?.rowLabel,value:r?.rowValue},d="chainId"in t?t.chainId:t.desiredChainID,x=t.adapter===orbitCore.OrbitAdapter.SOLANA,u=x?t:void 0;return jsxRuntime.jsxs("div",{className:novaCore.cn("novatx:flex novatx:flex-col novatx:gap-3 novatx:rounded-lg novatx:border novatx:border-[var(--tuwa-border-primary)] novatx:bg-[var(--tuwa-bg-primary)] novatx:p-3",r?.container,n),children:[jsxRuntime.jsx(p,{label:o.network,value:jsxRuntime.jsxs("div",{className:"novatx:flex novatx:items-center novatx:justify-end novatx:gap-2",children:[jsxRuntime.jsx("div",{className:"novatx:h-4 novatx:w-4",children:jsxRuntime.jsx(novaCore.NetworkIcon,{chainId:orbitCore.setChainId(d)})}),jsxRuntime.jsx("span",{children:novaCore.getChainName(orbitCore.setChainId(d))})]}),classNames:e}),t.localTimestamp&&jsxRuntime.jsx(p,{label:o.started,value:Wt__default.default.unix(t.localTimestamp).format("MMM D, HH:mm:ss"),classNames:e}),x&&jsxRuntime.jsxs(jsxRuntime.Fragment,{children:[u?.slot&&jsxRuntime.jsx(p,{label:o.slot,value:jsxRuntime.jsx($,{hash:u.slot.toString(),explorerUrl:c?.getExplorerUrl?`${c?.getExplorerUrl(`/block/${u.slot}`)}`:void 0}),classNames:e}),(typeof u?.confirmations=="number"||typeof u?.confirmations=="string")&&jsxRuntime.jsx(p,{label:l.confirmationsLabel,value:u.confirmations,classNames:e}),u?.recentBlockhash&&jsxRuntime.jsx(p,{label:i.recentBlockhash,value:jsxRuntime.jsx($,{hash:u.recentBlockhash}),classNames:e})]}),"txKey"in t&&t.txKey&&jsxRuntime.jsx("div",{className:novaCore.cn("novatx:border-t novatx:border-[var(--tuwa-border-primary)] novatx:pt-3",r?.separator),children:jsxRuntime.jsx(_,{tx:t,adapter:a,variant:"history",renderHashLink:s?.components?.transactionKey,hashLinkClassNames:r?.hashLink,originalHashLinkClassNames:r?.originalHashLink})})]})}var qa={completed:{line:"novatx:bg-[var(--tuwa-success-icon)]",border:"novatx:border-[var(--tuwa-success-icon)]",fill:"novatx:bg-[var(--tuwa-success-icon)]"},error:{line:"novatx:bg-[var(--tuwa-error-icon)]",border:"novatx:border-[var(--tuwa-error-icon)]",fill:"novatx:bg-[var(--tuwa-error-icon)]"},replaced:{line:"novatx:bg-[var(--tuwa-info-icon)]",border:"novatx:border-[var(--tuwa-info-icon)]",fill:"novatx:bg-[var(--tuwa-info-icon)]"},active:{line:"novatx:bg-[var(--tuwa-pending-icon)]",border:"novatx:border-[var(--tuwa-pending-icon)]",fill:"novatx:bg-transparent",pulse:"novatx:bg-[var(--tuwa-pending-icon)]"},inactive:{line:"novatx:bg-[var(--tuwa-border-primary)]",border:"novatx:border-[var(--tuwa-border-primary)]",fill:"novatx:bg-transparent"}};function Qa({status:t,label:a,isFirst:n=false,classNames:s}){let o=qa[t],l=s?.statusOverrides?.[t],i=()=>{switch(t){case "completed":return jsxRuntime.jsx(solid.CheckIcon,{className:"novatx:h-3 novatx:w-3 novatx:text-white"});case "error":return jsxRuntime.jsx(solid.ExclamationTriangleIcon,{className:"novatx:h-3 novatx:w-3 novatx:text-white"});case "replaced":return jsxRuntime.jsx(solid.ArrowPathIcon,{className:"novatx:h-3 novatx:w-3 novatx:text-white"});case "active":return jsxRuntime.jsx("div",{className:novaCore.cn("novatx:h-2 novatx:w-2 novatx:animate-pulse novatx:rounded-full",o.pulse)});default:return null}};return jsxRuntime.jsxs("div",{className:novaCore.cn("novatx:relative novatx:flex novatx:min-w-[80px] novatx:flex-1 novatx:flex-col novatx:items-center",s?.container),children:[!n&&jsxRuntime.jsx("div",{className:novaCore.cn("novatx:absolute novatx:right-1/2 novatx:top-[10px] novatx:h-0.5 novatx:w-full",o.line,s?.line,l?.line)}),jsxRuntime.jsx("div",{className:novaCore.cn("novatx:relative novatx:z-10 novatx:flex novatx:h-5 novatx:w-5 novatx:items-center novatx:justify-center novatx:rounded-full novatx:border-2",o.border,o.fill,s?.circle,l?.circle),children:i()}),jsxRuntime.jsx("span",{className:novaCore.cn("novatx:mt-2 novatx:text-center novatx:text-xs",t!=="inactive"?"novatx:font-semibold novatx:text-[var(--tuwa-text-primary)]":"novatx:text-[var(--tuwa-text-secondary)]",s?.label,l?.label),children:a})]})}function Kt({isProcessing:t,isSucceed:a,isFailed:n,isReplaced:s,className:o,StepComponent:l=Qa,stepClassNames:i}){let{trackingModal:c,statuses:p}=g(),r=react.useMemo(()=>{let e=x=>{if(x===1)return "completed";if(x===2){if(a||n||s)return "completed";if(t)return "active"}if(x===3){if(a)return "completed";if(n)return "error";if(s)return "replaced";if(t)return "active"}return "inactive"},d=x=>x===1?c.progressIndicator.created:x===2?c.progressIndicator.processing:n?p.failed:s?p.replaced:c.progressIndicator.succeed;return [{status:e(1),label:d(1),isFirst:true,classNames:i},{status:e(2),label:d(2),classNames:i},{status:e(3),label:d(3),isLast:true,classNames:i}]},[t,a,n,s,c,p,i]);return jsxRuntime.jsx("div",{className:novaCore.cn("novatx:flex novatx:w-full novatx:items-start novatx:px-4 novatx:pt-2 novatx:pb-1",o),children:r.map((e,d)=>jsxRuntime.jsx(l,{...e},d))})}var ao={succeed:{Icon:solid.CheckCircleIcon,className:"novatx:text-[var(--tuwa-success-icon)]"},failed:{Icon:solid.ExclamationCircleIcon,className:"novatx:text-[var(--tuwa-error-icon)]"},replaced:{Icon:solid.ArrowPathIcon,className:"novatx:text-[var(--tuwa-info-icon)]"},processing:{Icon:solid.ArrowPathIcon,className:"novatx:animate-spin novatx:text-[var(--tuwa-text-accent)]"},initializing:{Icon:solid.ClockIcon,className:"novatx:animate-pulse novatx:text-[var(--tuwa-pending-icon)]"}};function Rt({isProcessing:t,isSucceed:a,isFailed:n,isReplaced:s,className:o,iconClassNames:l}){let i=a&&"succeed"||n&&"failed"||s&&"replaced"||t&&"processing"||"initializing",{Icon:c,className:p}=ao[i],r=l?.statusOverrides?.[i];return jsxRuntime.jsx("div",{className:novaCore.cn("novatx:flex novatx:justify-center novatx:py-4",o),children:jsxRuntime.jsx(c,{className:novaCore.cn("novatx:h-16 novatx:w-16",p,l?.icon,r)})})}Wt__default.default.extend(no__default.default);var so=({chainId:t,className:a})=>jsxRuntime.jsx("div",{className:novaCore.cn("novatx:h-8 novatx:w-8 novatx:text-[var(--tuwa-text-secondary)]",a),children:jsxRuntime.jsx(novaCore.NetworkIcon,{chainId:orbitCore.setChainId(t)})}),ro=({timestamp:t,className:a})=>jsxRuntime.jsx("span",{className:novaCore.cn("novatx:mb-1 novatx:block novatx:text-xs novatx:text-[var(--tuwa-text-secondary)]",a),children:t?Wt__default.default.unix(t).fromNow():"..."});function Ft({tx:t,adapter:a,className:n,customization:s}){let{Icon:o=so,Title:l=R,Description:i=R,Timestamp:c=ro,StatusBadge:p=at,TransactionKey:r=_}=s?.components??{},e=s?.classNames;return jsxRuntime.jsxs("div",{className:novaCore.cn("novatx:flex novatx:flex-col novatx:gap-2 novatx:border-b novatx:border-[var(--tuwa-border-secondary)] novatx:p-3 novatx:transition-colors novatx:hover:bg-[var(--tuwa-bg-secondary)]",e?.container,n),children:[jsxRuntime.jsxs("div",{className:"novatx:flex novatx:items-start novatx:justify-between",children:[jsxRuntime.jsxs("div",{className:"novatx:flex novatx:items-center novatx:gap-4",children:[jsxRuntime.jsx("div",{className:novaCore.cn("novatx:flex novatx:h-10 novatx:w-10 novatx:flex-shrink-0 novatx:items-center novatx:justify-center novatx:rounded-full novatx:bg-[var(--tuwa-bg-muted)]",e?.iconWrapper),children:jsxRuntime.jsx(o,{chainId:t.chainId,className:e?.icon})}),jsxRuntime.jsxs("div",{className:e?.contentWrapper,children:[jsxRuntime.jsx(l,{txStatus:t.status,source:t.title,fallback:t.type,variant:"title",applyColor:true,className:e?.title}),jsxRuntime.jsx(c,{timestamp:t.localTimestamp,className:e?.timestamp}),jsxRuntime.jsx(i,{txStatus:t.status,source:t.description,variant:"description",className:e?.description})]})]}),jsxRuntime.jsx(p,{tx:t,className:e?.statusBadge,classNames:{icon:e?.statusBadgeIcon,label:e?.statusBadgeLabel}})]}),jsxRuntime.jsx(r,{tx:t,adapter:a,variant:"history",className:e?.txKeyContainer,hashLinkClassNames:{label:e?.hashLabel,link:e?.hashLink,copyButton:e?.hashCopyButton},originalHashLinkClassNames:{label:e?.originalHashLabel,link:e?.originalHashLink,copyButton:e?.originalHashCopyButton}})]})}function lo({title:t,message:a,className:n,classNames:s}){return jsxRuntime.jsxs("div",{className:novaCore.cn("novatx:rounded-lg novatx:bg-[var(--tuwa-bg-muted)] novatx:p-8 novatx:text-center",n),children:[jsxRuntime.jsx("h4",{className:novaCore.cn("novatx:font-semibold novatx:text-[var(--tuwa-text-primary)]",s?.title),children:t}),jsxRuntime.jsx("p",{className:novaCore.cn("novatx:mt-1 novatx:text-sm novatx:text-[var(--tuwa-text-secondary)]",s?.message),children:a})]})}function Vt({adapter:t,connectedWalletAddress:a,transactionsPool:n,className:s,customization:o}){let{transactionsModal:l}=g(),i=react.useMemo(()=>a?pulsarCore.selectAllTransactionsByActiveWallet(n,a).sort((d,x)=>(x.localTimestamp??0)-(d.localTimestamp??0)):[],[n,a]),{Placeholder:c=lo,HistoryItem:p=Ft}=o?.components??{},r=()=>{if(!a)return jsxRuntime.jsx(c,{title:l.history.connectWalletTitle,message:l.history.connectWalletMessage,className:o?.classNames?.placeholderContainer,classNames:{title:o?.classNames?.placeholderTitle,message:o?.classNames?.placeholderMessage}});if(i.length>0){let e={container:o?.classNames?.itemContainer,iconWrapper:o?.classNames?.itemIconWrapper,icon:o?.classNames?.itemIcon,contentWrapper:o?.classNames?.itemContentWrapper,title:o?.classNames?.itemTitle,timestamp:o?.classNames?.itemTimestamp,description:o?.classNames?.itemDescription,statusBadge:o?.classNames?.itemStatusBadge,statusBadgeIcon:o?.classNames?.itemStatusBadgeIcon,statusBadgeLabel:o?.classNames?.itemStatusBadgeLabel,txKeyContainer:o?.classNames?.itemTxKeyContainer,hashLabel:o?.classNames?.itemHashLabel,hashLink:o?.classNames?.itemHashLink,hashCopyButton:o?.classNames?.itemHashCopyButton,originalHashLabel:o?.classNames?.itemOriginalHashLabel,originalHashLink:o?.classNames?.itemOriginalHashLink,originalHashCopyButton:o?.classNames?.itemOriginalHashCopyButton};return jsxRuntime.jsx("div",{className:novaCore.cn("NovaCustomScroll novatx:max-h-[400px] novatx:overflow-y-auto novatx:rounded-lg novatx:border novatx:border-[var(--tuwa-border-primary)] novatx:bg-[var(--tuwa-bg-primary)]",o?.classNames?.listWrapper),children:i.map(d=>jsxRuntime.jsx(p,{tx:d,adapter:t,customization:{classNames:e}},d.txKey))})}return jsxRuntime.jsx(c,{title:l.history.noTransactionsTitle,message:l.history.noTransactionsMessage,className:o?.classNames?.placeholderContainer,classNames:{title:o?.classNames?.placeholderTitle,message:o?.classNames?.placeholderMessage}})};return jsxRuntime.jsxs("div",{className:novaCore.cn("novatx:flex novatx:flex-col novatx:gap-y-3",o?.classNames?.container,s),children:[o?.title&&jsxRuntime.jsx("h3",{className:novaCore.cn("novatx:text-lg novatx:font-bold novatx:text-[var(--tuwa-text-primary)]",o?.classNames?.titleText),children:o?.title}),r()]})}var To=({closeModal:t,title:a,classNames:n})=>{let{actions:s}=g();return jsxRuntime.jsxs(novaCore.DialogHeader,{className:n?.header,children:[jsxRuntime.jsx(novaCore.DialogTitle,{className:n?.title,children:a}),jsxRuntime.jsx(novaCore.DialogClose,{asChild:true,children:jsxRuntime.jsx("button",{type:"button",onClick:t,"aria-label":s.close,className:novaCore.cn("novatx:cursor-pointer novatx:rounded-full novatx:p-1 novatx:text-[var(--tuwa-text-tertiary)] novatx:transition-colors novatx:hover:bg-[var(--tuwa-bg-muted)] novatx:hover:text-[var(--tuwa-text-primary)]",n?.closeButton),children:jsxRuntime.jsx(novaCore.CloseIcon,{})})})]})};function Jt({isOpen:t,setIsOpen:a,customization:n,adapter:s,connectedWalletAddress:o,transactionsPool:l}){let{transactionsModal:i}=g(),c=()=>a(false),p=n?.components?.Header,r=n?.components?.History;return jsxRuntime.jsx(novaCore.Dialog,{open:t,onOpenChange:e=>!e&&c(),children:jsxRuntime.jsx(novaCore.DialogContent,{className:novaCore.cn("novatx:w-full novatx:sm:max-w-2xl",n?.modalProps?.className),...n?.modalProps,children:jsxRuntime.jsxs("div",{className:novaCore.cn("novatx:relative novatx:max-h-[95dvh] novatx:w-full novatx:flex novatx:flex-col",n?.classNames?.contentWrapper),children:[p?jsxRuntime.jsx(p,{closeModal:c}):jsxRuntime.jsx(To,{closeModal:c,title:i.history.title,classNames:{header:n?.classNames?.header,title:n?.classNames?.headerTitle,closeButton:n?.classNames?.closeButton}}),r?jsxRuntime.jsx(r,{adapter:s,transactionsPool:l,connectedWalletAddress:o,customization:n?.historyCustomization}):jsxRuntime.jsx(Vt,{adapter:s,transactionsPool:l,connectedWalletAddress:o,customization:n?.historyCustomization})]})})})}var ho=t=>({replaced:jsxRuntime.jsxs(jsxRuntime.Fragment,{children:[jsxRuntime.jsx(solid.ArrowPathIcon,{className:"novatx:h-4 novatx:w-4"}),jsxRuntime.jsx("span",{children:t.replaced})]}),loading:jsxRuntime.jsxs(jsxRuntime.Fragment,{children:[jsxRuntime.jsx(solid.ArrowPathIcon,{className:"novatx:h-4 novatx:w-4 novatx:animate-spin"}),jsxRuntime.jsx("span",{children:t.loading})]}),succeed:jsxRuntime.jsxs(jsxRuntime.Fragment,{children:[jsxRuntime.jsx(solid.CheckCircleIcon,{className:"novatx:h-4 novatx:w-4"}),jsxRuntime.jsx("span",{children:t.succeed})]}),failed:jsxRuntime.jsxs(jsxRuntime.Fragment,{children:[jsxRuntime.jsx(solid.ExclamationCircleIcon,{className:"novatx:h-4 novatx:w-4"}),jsxRuntime.jsx("span",{children:t.failed})]})});function ps({children:t,action:a,getLastTxKey:n,transactionsPool:s,walletAddress:o,loadingContent:l,succeedContent:i,failedContent:c,replacedContent:p,resetTimeout:r=2500,className:e,classNames:d,...x}){let{trackedTxButton:u}=g(),[T,h]=react.useState("idle"),[y,C]=react.useState(void 0),f=react.useMemo(()=>ho(u),[u]);react.useEffect(()=>{h("idle"),C(void 0);},[o]),react.useEffect(()=>{if(!y)return;let N=s[y];if(N)switch(N.status){case pulsarCore.TransactionStatus.Success:h("succeed");break;case pulsarCore.TransactionStatus.Replaced:h("replaced");break;case pulsarCore.TransactionStatus.Failed:h("failed");break}},[s,y,o]),react.useEffect(()=>{if(["succeed","failed","replaced"].includes(T)){let N=setTimeout(()=>{h("idle"),C(void 0);},r);return ()=>clearTimeout(N)}},[T,r]);let m=async()=>{h("loading");try{await a(),C(n());}catch(N){console.error("Transaction initiation failed:",N),h("failed");}},B=()=>{switch(T){case "loading":return l??f.loading;case "succeed":return i??f.succeed;case "failed":return c??f.failed;case "replaced":return p??f.replaced;default:return t}},U={idle:"novatx:bg-gradient-to-r novatx:from-[var(--tuwa-button-gradient-from)] novatx:to-[var(--tuwa-button-gradient-to)] novatx:text-[var(--tuwa-text-on-accent)] novatx:hover:opacity-90",loading:"novatx:bg-gray-400 novatx:text-white",replaced:"novatx:bg-gray-500 novatx:text-white",succeed:"novatx:bg-[var(--tuwa-success-bg)] novatx:text-[var(--tuwa-success-text)]",failed:"novatx:bg-[var(--tuwa-error-bg)] novatx:text-[var(--tuwa-error-text)]"},b=d?.[T]??U[T],w=d?.base??"novatx:flex novatx:cursor-pointer novatx:items-center novatx:justify-center novatx:gap-1.5 novatx:rounded-md novatx:px-3 novatx:py-1.5 novatx:text-sm novatx:font-medium novatx:transition-all novatx:duration-200 novatx:disabled:cursor-not-allowed novatx:disabled:opacity-70";return jsxRuntime.jsx("button",{...x,disabled:T!=="idle"||x.disabled,onClick:m,className:novaCore.cn(w,b,e),children:B()})}var So={[pulsarCore.TransactionStatus.Success]:"success",[pulsarCore.TransactionStatus.Failed]:"error",[pulsarCore.TransactionStatus.Replaced]:"info"};function Vs({adapter:t,connectedWalletAddress:a,connectedAdapterType:n,transactionsPool:s,initialTx:o,executeTxAction:l,closeTxTrackedModal:i,labels:c,features:p,customization:r,...e}){let[d,x]=react.useState(false),u=react.useRef(s),T="nova-transactions",h=novaCore.useMediaQuery("(max-width: 767px)"),y=react.useMemo(()=>({toasts:p?.toasts??true,transactionsModal:p?.transactionsModal??true,trackingTxModal:p?.trackingTxModal??true}),[p]),C=react.useMemo(()=>novaCore.deepMerge(j,c||{}),[c]),f=react.useCallback(b=>{if(!y.toasts)return;let w=b.pending?"info":So[b.status]??"info",N=Z=>jsxRuntime.jsx(Bt,{...Z,tx:b,openTxInfoModal:y.transactionsModal?()=>x(true):void 0,customization:r?.toast,adapter:t,connectedWalletAddress:a});reactToastify.toast.isActive(b.txKey)?reactToastify.toast.update(b.txKey,{render:N,type:w,containerId:T}):reactToastify.toast(N,{toastId:b.txKey,type:w,closeOnClick:false,containerId:T});},[s,y,r?.toast,t,a]);react.useEffect(()=>{let b=u.current;Object.values(s).forEach(w=>{let N=b[w.txKey];if(!N&&w.pending){f(w);return}N&&JSON.stringify(N)!==JSON.stringify(w)&&f(w);}),u.current=s;},[s,f]),react.useEffect(()=>{Object.values(s).forEach(b=>{reactToastify.toast.isActive(b.txKey,T)&&f(b);});},[a,f,s]);let m=!!o?.withTrackedModal&&s[o?.lastTxKey??""]?.isTrackedModalOpen,B=y.toasts&&(!h||!m&&!d),U=react.useMemo(()=>{let b=r?.toastCloseButton;return b?({closeToast:w})=>jsxRuntime.jsx(novaCore.ToastCloseButton,{closeToast:w,...b}):novaCore.ToastCloseButton},[r?.toastCloseButton]);return jsxRuntime.jsxs(Nt,{labels:C,children:[B&&jsxRuntime.jsx(reactToastify.ToastContainer,{position:"bottom-right",stacked:true,autoClose:false,hideProgressBar:true,closeOnClick:false,icon:false,closeButton:U,containerId:T,toastClassName:"novatx:!p-0 novatx:!bg-transparent novatx:!shadow-none novatx:!min-h-0",...e}),y.transactionsModal&&jsxRuntime.jsx(Jt,{isOpen:d,setIsOpen:x,customization:r?.transactionsInfoModal,adapter:t,connectedWalletAddress:a,connectedAdapterType:n,transactionsPool:s}),y.trackingTxModal&&jsxRuntime.jsx(Ht,{initialTx:o,onClose:i,onOpenAllTransactions:()=>x(true),transactionsPool:s,customization:r?.trackingTxModal,executeTxAction:l,adapter:t,connectedWalletAddress:a})]})}exports.a=j;exports.b=Nt;exports.c=g;exports.d=Vs;exports.e=$;exports.f=R;exports.g=_;exports.h=at;exports.i=Bt;exports.j=Ht;exports.k=Mt;exports.l=At;exports.m=Kt;exports.n=Rt;exports.o=Ft;exports.p=Vt;exports.q=Jt;exports.r=ps;
|
package/dist/chunk-QZL22XK4.js
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
import {createContext,useContext,useMemo,useState,useEffect,useRef,useCallback}from'react';import {jsx,jsxs,Fragment}from'react/jsx-runtime';import {useCopyToClipboard,cn,textCenterEllipsis,getChainName,NetworkIcon,Dialog,DialogContent,DialogHeader,DialogTitle,DialogClose,CloseIcon,useMediaQuery,deepMerge,ToastCloseButton}from'@tuwaio/nova-core';import {TransactionStatus,TransactionTracker,selectAllTransactionsByActiveWallet}from'@tuwaio/pulsar-core';import {toast,ToastContainer}from'react-toastify';import {ArrowTopRightOnSquareIcon,CheckIcon,DocumentDuplicateIcon,ArrowPathIcon,XCircleIcon,CheckCircleIcon,ExclamationTriangleIcon,ClockIcon,ExclamationCircleIcon}from'@heroicons/react/24/solid';import {selectAdapterByKey,setChainId,OrbitAdapter}from'@tuwaio/orbit-core';import Wt from'dayjs';import no from'dayjs/plugin/relativeTime';var j={transactionsModal:{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:{openTransactionsInfo:"Open transactions"},statuses:{pending:"Pending",success:"Success",failed:"Failed",reverted:"Reverted",replaced:"Replaced",unknown:"Unknown",confirmationsLabel:"Confirmations"},hashLabels:{gelato:"Gelato Task ID",safe:"Safe Tx Hash",original:"Original Tx Hash",replaced:"Replaced Tx Hash",default:"Tx Hash",recentBlockhash:"Recent Blockhash",solana:"Signature"},txInfo:{started:"Started",network:"Network",slot:"Slot"},txError:{title:"Error",copied:"Copied!"},trackingModal:{title:"Transaction Overview",processing:"Processing...",close:"Close",allTransactions:"All transactions",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 ht=createContext(j),Nt=({labels:t,children:a})=>jsx(ht.Provider,{value:t,children:a}),g=()=>useContext(ht);function $({label:t,hash:a,explorerUrl:n,variant:s="default",className:o,classNames:l}){let{isCopied:i,copy:c}=useCopyToClipboard(),{actions:p,txError:r}=g(),e=cn("novatx:flex novatx:items-center novatx:justify-between",{"novatx:text-sm":s==="default","novatx:text-xs":s==="compact"},o),d=cn("novatx:pr-1",{"novatx:font-bold novatx:text-[var(--tuwa-text-primary)]":s==="default","novatx:font-medium novatx:text-[var(--tuwa-text-secondary)]":s==="compact"},l?.label),x=jsx("span",{className:cn("novatx:font-mono",l?.hash),children:textCenterEllipsis(a,5,5)});return jsxs("div",{className:e,children:[t&&jsxs("span",{className:d,children:[t,":"]}),jsxs("div",{className:"novatx:flex novatx:items-center novatx:gap-x-2",children:[n?jsxs("a",{href:n,target:"_blank",rel:"noopener noreferrer",className:cn("novatx:flex novatx:items-center novatx:gap-x-1 novatx:text-[var(--tuwa-text-accent)] novatx:transition-colors novatx:hover:underline",l?.link),title:p.viewOnExplorer,"aria-label":p.viewOnExplorer,children:[x,jsx(ArrowTopRightOnSquareIcon,{className:cn("novatx:h-4 novatx:w-4",l?.linkIcon)})]}):jsx("span",{className:cn("novatx:text-[var(--tuwa-text-primary)]",l?.link),children:x}),jsx("button",{type:"button",onClick:()=>c(a),className:cn("novatx:cursor-pointer novatx:text-[var(--tuwa-text-tertiary)] novatx:transition-colors novatx:hover:text-[var(--tuwa-text-secondary)]",l?.copyButton),title:i?r.copied:p.copy,"aria-label":i?r.copied:p.copy,children:i?jsx(CheckIcon,{className:"novatx:h-4 novatx:w-4 novatx:text-[var(--tuwa-success-icon)]"}):jsx(DocumentDuplicateIcon,{className:"novatx:h-4 novatx:w-4"})})]})]})}var wt={[TransactionStatus.Success]:{index:1,colorClass:"novatx:text-[var(--tuwa-success-text)]"},[TransactionStatus.Failed]:{index:2,colorClass:"novatx:text-[var(--tuwa-error-text)]"},[TransactionStatus.Replaced]:{index:3,colorClass:"novatx:text-[var(--tuwa-text-secondary)]"},default:{index:0,colorClass:"novatx:text-[var(--tuwa-text-primary)]"}};function R({txStatus:t,source:a,fallback:n,variant:s,className:o,applyColor:l=false}){let i,c="";if(typeof a=="string")i=a;else if(Array.isArray(a)){let e=wt[t||"default"]??wt.default;i=a[e.index],l&&(c=e.colorClass);}else i=n;return i?jsx("div",{className:cn(s==="title"?"novatx:text-sm novatx:font-semibold novatx:text-[var(--tuwa-text-primary)]":"novatx:mt-1 novatx:text-xs novatx:text-[var(--tuwa-text-secondary)]",c,o),children:i}):null}function _({tx:t,adapter:a,variant:n="toast",className:s,renderHashLink:o,confirmations:l,hashLinkClassNames:i,originalHashLinkClassNames:c}){let{hashLabels:p,statuses:r}=g(),e=selectAdapterByKey({adapterKey:t.adapter,adapter:a});if(!e)return null;let d=(C,f)=>o?o(C):jsx($,{...C,classNames:f??i}),x=n==="toast"?"novatx:mt-2 novatx:flex novatx:w-full novatx:flex-col novatx:gap-y-2 novatx:border-t novatx:border-[var(--tuwa-border-primary)] novatx:pt-2":"novatx:flex novatx:w-full novatx:flex-col novatx:gap-y-2",u=p[String(t.tracker)],T=u?d({label:u,hash:t.txKey,variant:t.tracker!==TransactionTracker.Solana?"compact":"default",explorerUrl:e.getExplorerTxUrl&&t.tracker===TransactionTracker.Solana?e?.getExplorerTxUrl(t):void 0}):null,h=(()=>{let C=t.hash,f=t.replacedTxHash;return !C&&!f?null:f?jsxs(Fragment,{children:[C&&d({label:p.original,hash:C,variant:"compact"},c),typeof e.getExplorerTxUrl<"u"&&d({label:p.replaced,hash:f,explorerUrl:e.getExplorerTxUrl(t)})]}):C&&typeof e.getExplorerTxUrl<"u"&&d({label:p.default,hash:C,explorerUrl:e.getExplorerTxUrl(t)})})(),y=u&&u!==p.default&&t.txKey!==t.hash;return jsxs("div",{className:cn(x,s),children:[y&&T,h,typeof l=="number"&&jsxs("p",{className:"novatx:text-xs novatx:text-[var(--tuwa-text-tertiary)]",children:[r.confirmationsLabel,": ",l]})]})}var ua=t=>({Pending:{label:t.pending,Icon:ArrowPathIcon,badgeClasses:"novatx:bg-[var(--tuwa-pending-bg)] novatx:text-[var(--tuwa-pending-text)]",iconClasses:"novatx:animate-spin novatx:text-[var(--tuwa-pending-icon)]"},[TransactionStatus.Success]:{label:t.success,Icon:CheckCircleIcon,badgeClasses:"novatx:bg-[var(--tuwa-success-bg)] novatx:text-[var(--tuwa-success-text)]",iconClasses:"novatx:text-[var(--tuwa-success-icon)]"},[TransactionStatus.Failed]:{label:t.failed,Icon:XCircleIcon,badgeClasses:"novatx:bg-[var(--tuwa-error-bg)] novatx:text-[var(--tuwa-error-text)]",iconClasses:"novatx:text-[var(--tuwa-error-icon)]"},[TransactionStatus.Replaced]:{label:t.replaced,Icon:ArrowPathIcon,badgeClasses:"novatx:bg-[var(--tuwa-info-bg)] novatx:text-[var(--tuwa-info-text)]",iconClasses:"novatx:text-[var(--tuwa-info-icon)]"}});function at({tx:t,className:a,classNames:n}){let{statuses:s}=g(),o=useMemo(()=>ua(s),[s]),l="novatx:inline-flex novatx:items-center novatx:gap-x-1.5 novatx:rounded-full novatx:px-2 novatx:py-1 novatx:text-xs novatx:font-medium",i=t.pending?"Pending":t.status,c=i?o[i]:null;if(!c)return jsx("div",{className:cn(l,"novatx:bg-[var(--tuwa-info-bg)] novatx:text-[var(--tuwa-info-text)]",n?.container,a),children:jsx("span",{className:n?.label,children:t.status??s.unknown})});let{label:p,Icon:r,badgeClasses:e,iconClasses:d}=c;return jsxs("div",{className:cn(l,e,n?.container,a),children:[jsx(r,{className:cn("novatx:h-4 novatx:w-4",d,n?.icon)}),jsx("span",{className:n?.label,children:p})]})}var Ca=({onClick:t,children:a,className:n})=>jsx("button",{onClick:t,type:"button",className:cn("novatx:cursor-pointer novatx:text-sm novatx:font-medium novatx:text-[var(--tuwa-text-accent)] novatx:transition-opacity novatx:hover:opacity-80",n),children:a}),ba=({onClick:t,children:a,className:n})=>jsx("button",{onClick:t,type:"button",className:cn("novatx:cursor-pointer novatx:text-sm novatx:font-medium novatx:text-[var(--tuwa-text-secondary)] novatx:transition-opacity novatx:hover:opacity-80",n),children:a}),ha=({onClick:t,children:a,className:n})=>jsx("button",{className:n||"novatx:cursor-pointer novatx:rounded-md novatx:bg-gradient-to-r novatx:from-[var(--tuwa-button-gradient-from)] novatx:to-[var(--tuwa-button-gradient-to)] novatx:px-3 novatx:py-1 novatx:text-xs novatx:font-bold novatx:text-[var(--tuwa-text-on-accent)] novatx:shadow-lg novatx:transition-all novatx:duration-200 novatx:ease-in-out novatx:hover:shadow-xl novatx:hover:from-[var(--tuwa-button-gradient-from-hover)] novatx:hover:to-[var(--tuwa-button-gradient-to-hover)] novatx:active:scale-95",onClick:t,type:"button",children:a});function Bt({openTxInfoModal:t,tx:a,icon:n,className:s,customization:o,connectedWalletAddress:l,adapter:i}){let{actions:c,toast:p}=g(),r=selectAdapterByKey({adapterKey:a.adapter,adapter:i}),e=!!(a.tracker==="ethereum"&&a.pending&&r?.speedUpTxAction&&r?.cancelTxAction&&a.from.toLowerCase()===l?.toLowerCase()&&["metamask"].includes(a.connectorType.split(":")[1])),d=()=>{e&&r.cancelTxAction(a);},x=()=>{e&&r.speedUpTxAction(a);},{StatusAwareText:u=R,TransactionKey:T=_,StatusBadge:h=at,SpeedUpButton:y=Ca,CancelButton:C=ba,TxInfoButton:f=ha}=o?.components??{},m=o?.classNames;return jsxs("div",{className:cn("novatx:flex novatx:w-full novatx:flex-col novatx:gap-3 novatx:rounded-lg novatx:bg-[var(--tuwa-bg-primary)] novatx:p-4 novatx:shadow-md",m?.container,s),children:[jsxs("div",{className:cn("novatx:flex novatx:items-center novatx:gap-3",m?.header),children:[jsx("div",{className:cn("novatx:w-[40px] novatx:flex-shrink-0",m?.iconWrapper),title:getChainName(setChainId(a.chainId)),children:n??jsx(NetworkIcon,{chainId:setChainId(a.chainId)})}),jsxs("div",{className:cn("novatx:flex-1",m?.contentWrapper),children:[jsx(u,{txStatus:a.status,source:a.title,fallback:a.type,variant:"title",applyColor:true,className:m?.title}),jsx(u,{txStatus:a.status,source:a.description,variant:"description",className:m?.description})]})]}),jsxs("div",{children:[jsx(T,{adapter:i,tx:a,variant:"toast",className:m?.transactionKey,hashLinkClassNames:{label:m?.hashLabel,link:m?.hashLink,copyButton:m?.hashCopyButton},originalHashLinkClassNames:{label:m?.originalHashLabel,link:m?.originalHashLink,copyButton:m?.originalHashCopyButton}}),jsxs("div",{className:cn("novatx:mt-3 novatx:flex novatx:items-center novatx:justify-between",m?.footer),children:[jsx(h,{tx:a,className:m?.statusBadge,classNames:{icon:m?.statusBadgeIcon,label:m?.statusBadgeLabel}}),e?jsxs("div",{className:cn("novatx:flex novatx:items-center novatx:gap-4",m?.actionsContainer),children:[jsx(y,{onClick:x,className:m?.speedUpButton,children:c.speedUp}),jsx(C,{onClick:d,className:m?.cancelButton,children:c.cancel})]}):t&&!!l&&jsx(f,{onClick:t,className:m?.txInfoButton,children:p.openTransactionsInfo})]})]})]})}function Ht({adapter:t,onClose:a,onOpenAllTransactions:n,className:s,customization:o,transactionsPool:l,executeTxAction:i,initialTx:c,connectedWalletAddress:p}){let r=useMemo(()=>c?.lastTxKey?l[c.lastTxKey]:void 0,[l,c]),e=r??c,d=c?.withTrackedModal&&!r||(r?.isTrackedModalOpen??false),{isProcessing:x,isSucceed:u,isFailed:T,isReplaced:h}=useMemo(()=>{let F=r?.status,Qt=c?.isInitializing??false,Zt=r?.pending??false;return {isProcessing:Qt||Zt,isSucceed:F===TransactionStatus.Success,isFailed:r?.isError||!!c?.errorMessage,isReplaced:F===TransactionStatus.Replaced}},[r,c]),y=useMemo(()=>e?selectAdapterByKey({adapterKey:e.adapter,adapter:t}):void 0,[e,t]),C=!!(T&&e&&c?.actionFunction&&i),f=!!(y?.speedUpTxAction&&y?.cancelTxAction&&r?.pending&&r.tracker==="ethereum"),m=()=>{if(!C||!y?.retryTxAction)return;let F={adapter:e.adapter,type:e.type,desiredChainID:"desiredChainID"in e?e.desiredChainID:e.chainId,actionFunction:c?.actionFunction,title:e.title,description:e.description,payload:e.payload,rpcUrl:"rpcUrl"in e?e?.rpcUrl:"desiredChainID"in e?e.desiredChainID:e.chainId.split(":")[1],withTrackedModal:"withTrackedModal"in e?e.withTrackedModal:false};y.retryTxAction({tx:F,txKey:r?.txKey??"",onClose:a,executeTxAction:i});},B=f&&r&&["metamask"].includes(r?.connectorType.split(":")[1]),U=()=>{B&&y.cancelTxAction(r);},b=()=>{B&&y.speedUpTxAction(r);},w=o?.components?.Header,N=o?.components?.Footer,Z=o?.components?.StatusVisual,yt=o?.components?.ProgressIndicator,Ct=o?.components?.InfoBlock,bt=o?.components?.ErrorBlock;if(!e)return null;let W=o?.classNames;return jsx(Dialog,{open:d,onOpenChange:F=>!F&&a(r?.txKey),children:jsx(DialogContent,{className:cn("novatx:w-full novatx:sm:max-w-md",o?.modalProps?.className),...o?.modalProps,children:jsxs("div",{className:cn("novatx:relative novatx:flex novatx:w-full novatx:flex-col",W?.container,s),children:[w?jsx(w,{onClose:()=>a(r?.txKey),title:jsx(Lt,{tx:e,className:W?.headerTitle})}):jsx(La,{onClose:()=>a(r?.txKey),title:jsx(Lt,{tx:e,className:W?.headerTitle}),classNames:W}),jsxs("main",{className:cn("novatx:flex novatx:flex-col novatx:gap-4 novatx:p-4",W?.main),children:[Z?jsx(Z,{isProcessing:x,isSucceed:u,isFailed:T,isReplaced:h}):jsx(Rt,{isProcessing:x,isSucceed:u,isFailed:T,isReplaced:h,className:o?.statusVisualCustomization?.className,iconClassNames:o?.statusVisualCustomization?.iconClassNames}),yt?jsx(yt,{isProcessing:x,isSucceed:u,isFailed:T,isReplaced:h}):jsx(Kt,{isProcessing:x,isSucceed:u,isFailed:T,isReplaced:h,className:o?.progressIndicatorCustomization?.className,stepClassNames:o?.progressIndicatorCustomization?.stepClassNames}),Ct?jsx(Ct,{tx:e,adapter:t}):jsx(At,{tx:e,adapter:t,customization:o?.infoBlockCustomization}),bt?jsx(bt,{error:r?.errorMessage||c?.errorMessage}):jsx(Mt,{error:r?.errorMessage||c?.errorMessage,className:o?.errorBlockCustomization?.className,classNames:o?.errorBlockCustomization?.classNames})]}),N?jsx(N,{onClose:()=>a(r?.txKey),onOpenAllTransactions:n,isProcessing:x,isFailed:T,canReplace:f,onRetry:C?m:void 0,onSpeedUp:B?b:void 0,onCancel:B?U:void 0,connectedWalletAddress:p}):jsx(Ma,{onClose:()=>a(r?.txKey),onOpenAllTransactions:n,isProcessing:x,isFailed:T,canReplace:f,onRetry:C?m:void 0,onSpeedUp:B?b:void 0,onCancel:B?U:void 0,connectedWalletAddress:p,classNames:W})]})})})}function Lt({tx:t,className:a}){return jsx(R,{txStatus:"status"in t?t.status:void 0,source:t.title,fallback:t.type,variant:"title",className:cn("novatx:text-lg",a)})}var La=({onClose:t,title:a,classNames:n})=>{let{actions:s}=g();return jsxs(DialogHeader,{className:n?.header,children:[jsx(DialogTitle,{className:n?.headerTitle,children:a}),jsx(DialogClose,{asChild:true,children:jsx("button",{type:"button",onClick:()=>t(),"aria-label":s.close,className:cn("novatx:cursor-pointer novatx:rounded-full novatx:p-1 novatx:text-[var(--tuwa-text-tertiary)] novatx:transition-colors novatx:hover:bg-[var(--tuwa-bg-muted)] novatx:hover:text-[var(--tuwa-text-primary)]",n?.closeButton),children:jsx(CloseIcon,{})})})]})},Ha=({isFailed:t,onRetry:a,isProcessing:n,canReplace:s,connectedWalletAddress:o,onOpenAllTransactions:l,classNames:i})=>{let{trackingModal:c}=g();return t&&a?jsx("button",{type:"button",onClick:a,className:cn("novatx:cursor-pointer novatx:rounded-t-md novatx:sm:rounded-md novatx:bg-gradient-to-r novatx:from-[var(--tuwa-button-gradient-from)] novatx:to-[var(--tuwa-button-gradient-to)] novatx:px-4 novatx:py-2 novatx:text-sm novatx:font-semibold novatx:text-[var(--tuwa-text-on-accent)] novatx:transition-opacity novatx:hover:from-[var(--tuwa-button-gradient-from-hover)] novatx:hover:to-[var(--tuwa-button-gradient-to-hover)]",i?.retryButton),children:c.retry}):!n&&!s&&o?jsx("button",{type:"button",onClick:l,className:cn("novatx:cursor-pointer novatx:rounded-md novatx:bg-[var(--tuwa-bg-muted)] novatx:px-4 novatx:py-2 novatx:text-sm novatx:font-semibold novatx:text-[var(--tuwa-text-primary)] novatx:transition-colors novatx:hover:bg-[var(--tuwa-border-primary)]",i?.allTransactionsButton),children:c.allTransactions}):null},Ma=({onClose:t,onOpenAllTransactions:a,isProcessing:n,onRetry:s,onSpeedUp:o,onCancel:l,canReplace:i,isFailed:c,connectedWalletAddress:p,classNames:r})=>{let{trackingModal:e,actions:d}=g();return jsxs("footer",{className:cn("novatx:flex novatx:w-full novatx:items-center novatx:justify-between novatx:border-t novatx:border-[var(--tuwa-border-primary)] novatx:p-4",r?.footer),children:[jsx("div",{className:cn("novatx:flex novatx:items-center novatx:gap-4",r?.footerActions),children:i&&o&&l&&jsxs(Fragment,{children:[jsx("button",{type:"button",onClick:o,className:cn("novatx:cursor-pointer novatx:text-sm novatx:font-medium novatx:text-[var(--tuwa-text-accent)] novatx:transition-opacity novatx:hover:opacity-80",r?.speedUpButton),children:d.speedUp}),jsx("button",{type:"button",onClick:l,className:cn("novatx:cursor-pointer novatx:text-sm novatx:font-medium novatx:text-[var(--tuwa-text-secondary)] novatx:transition-opacity novatx:hover:opacity-80",r?.cancelButton),children:d.cancel})]})}),jsxs("div",{className:cn("novatx:flex novatx:items-center novatx:gap-3",r?.footerButtons),children:[jsx(Ha,{isFailed:c,onRetry:s,isProcessing:n,canReplace:i,connectedWalletAddress:p,onOpenAllTransactions:a,classNames:r}),jsx("button",{type:"button",onClick:t,disabled:n&&!i,className:cn("novatx:cursor-pointer novatx:rounded-md novatx:bg-[var(--tuwa-bg-muted)] novatx:px-4 novatx:py-2 novatx:text-sm novatx:font-semibold novatx:text-[var(--tuwa-text-primary)] novatx:transition-colors novatx:hover:bg-[var(--tuwa-border-primary)] novatx:disabled:cursor-not-allowed novatx:disabled:opacity-50",r?.closeModalButton),children:n&&!i?e.processing:e.close})]})]})};function Mt({error:t,className:a,classNames:n}){let{isCopied:s,copy:o}=useCopyToClipboard(),{actions:l,txError:i}=g();return t?jsxs("div",{className:cn("novatx:rounded-lg novatx:border novatx:border-[var(--tuwa-error-icon)]/30 novatx:bg-[var(--tuwa-error-bg)] novatx:p-3 novatx:text-sm",n?.container,a),children:[jsxs("div",{className:cn("novatx:mb-2 novatx:flex novatx:items-center novatx:justify-between",n?.header),children:[jsxs("div",{className:cn("novatx:flex novatx:items-center novatx:gap-2 novatx:font-bold novatx:text-[var(--tuwa-error-icon)]",n?.title),children:[jsx(ExclamationTriangleIcon,{className:cn("novatx:h-5 novatx:w-5",n?.icon)}),jsx("span",{children:i.title})]}),jsx("button",{type:"button",onClick:()=>o(t),title:s?i.copied:l.copy,"aria-label":s?i.copied:`${l.copy} error message`,className:cn("novatx:cursor-pointer novatx:text-[var(--tuwa-error-icon)]/50 novatx:transition-colors novatx:hover:text-[var(--tuwa-error-icon)]",n?.copyButton),children:s?jsx(CheckIcon,{className:"novatx:h-5 novatx:w-5 novatx:text-[var(--tuwa-success-icon)]"}):jsx(DocumentDuplicateIcon,{className:"novatx:h-5 novatx:w-5"})})]}),jsx("div",{className:cn("novatx:max-h-24 novatx:overflow-y-auto novatx:rounded novatx:bg-[var(--tuwa-bg-primary)] novatx:p-2",n?.messageContainer),children:jsx("p",{className:cn("novatx:font-mono novatx:text-xs novatx:text-[var(--tuwa-error-text)] novatx:break-all",n?.messageText),children:t})})]}):null}function _a({label:t,value:a,classNames:n}){return jsxs("div",{className:cn("novatx:flex novatx:items-center novatx:justify-between novatx:text-sm",n?.row),children:[jsx("span",{className:cn("novatx:text-[var(--tuwa-text-secondary)]",n?.label),children:t}),jsx("span",{className:cn("novatx:font-medium novatx:text-[var(--tuwa-text-primary)]",n?.value),children:a})]})}function At({tx:t,adapter:a,className:n,customization:s}){let{txInfo:o,statuses:l,hashLabels:i}=g(),c=selectAdapterByKey({adapterKey:t.adapter,adapter:a});if(!c)return null;let{InfoRow:p=_a}=s?.components??{},r=s?.classNames,e={row:r?.row,label:r?.rowLabel,value:r?.rowValue},d="chainId"in t?t.chainId:t.desiredChainID,x=t.adapter===OrbitAdapter.SOLANA,u=x?t:void 0;return jsxs("div",{className:cn("novatx:flex novatx:flex-col novatx:gap-3 novatx:rounded-lg novatx:border novatx:border-[var(--tuwa-border-primary)] novatx:bg-[var(--tuwa-bg-primary)] novatx:p-3",r?.container,n),children:[jsx(p,{label:o.network,value:jsxs("div",{className:"novatx:flex novatx:items-center novatx:justify-end novatx:gap-2",children:[jsx("div",{className:"novatx:h-4 novatx:w-4",children:jsx(NetworkIcon,{chainId:setChainId(d)})}),jsx("span",{children:getChainName(setChainId(d))})]}),classNames:e}),t.localTimestamp&&jsx(p,{label:o.started,value:Wt.unix(t.localTimestamp).format("MMM D, HH:mm:ss"),classNames:e}),x&&jsxs(Fragment,{children:[u?.slot&&jsx(p,{label:o.slot,value:jsx($,{hash:u.slot.toString(),explorerUrl:c?.getExplorerUrl?`${c?.getExplorerUrl(`/block/${u.slot}`)}`:void 0}),classNames:e}),(typeof u?.confirmations=="number"||typeof u?.confirmations=="string")&&jsx(p,{label:l.confirmationsLabel,value:u.confirmations,classNames:e}),u?.recentBlockhash&&jsx(p,{label:i.recentBlockhash,value:jsx($,{hash:u.recentBlockhash}),classNames:e})]}),"txKey"in t&&t.txKey&&jsx("div",{className:cn("novatx:border-t novatx:border-[var(--tuwa-border-primary)] novatx:pt-3",r?.separator),children:jsx(_,{tx:t,adapter:a,variant:"history",renderHashLink:s?.components?.transactionKey,hashLinkClassNames:r?.hashLink,originalHashLinkClassNames:r?.originalHashLink})})]})}var qa={completed:{line:"novatx:bg-[var(--tuwa-success-icon)]",border:"novatx:border-[var(--tuwa-success-icon)]",fill:"novatx:bg-[var(--tuwa-success-icon)]"},error:{line:"novatx:bg-[var(--tuwa-error-icon)]",border:"novatx:border-[var(--tuwa-error-icon)]",fill:"novatx:bg-[var(--tuwa-error-icon)]"},replaced:{line:"novatx:bg-[var(--tuwa-info-icon)]",border:"novatx:border-[var(--tuwa-info-icon)]",fill:"novatx:bg-[var(--tuwa-info-icon)]"},active:{line:"novatx:bg-[var(--tuwa-pending-icon)]",border:"novatx:border-[var(--tuwa-pending-icon)]",fill:"novatx:bg-transparent",pulse:"novatx:bg-[var(--tuwa-pending-icon)]"},inactive:{line:"novatx:bg-[var(--tuwa-border-primary)]",border:"novatx:border-[var(--tuwa-border-primary)]",fill:"novatx:bg-transparent"}};function Qa({status:t,label:a,isFirst:n=false,classNames:s}){let o=qa[t],l=s?.statusOverrides?.[t],i=()=>{switch(t){case "completed":return jsx(CheckIcon,{className:"novatx:h-3 novatx:w-3 novatx:text-white"});case "error":return jsx(ExclamationTriangleIcon,{className:"novatx:h-3 novatx:w-3 novatx:text-white"});case "replaced":return jsx(ArrowPathIcon,{className:"novatx:h-3 novatx:w-3 novatx:text-white"});case "active":return jsx("div",{className:cn("novatx:h-2 novatx:w-2 novatx:animate-pulse novatx:rounded-full",o.pulse)});default:return null}};return jsxs("div",{className:cn("novatx:relative novatx:flex novatx:min-w-[80px] novatx:flex-1 novatx:flex-col novatx:items-center",s?.container),children:[!n&&jsx("div",{className:cn("novatx:absolute novatx:right-1/2 novatx:top-[10px] novatx:h-0.5 novatx:w-full",o.line,s?.line,l?.line)}),jsx("div",{className:cn("novatx:relative novatx:z-10 novatx:flex novatx:h-5 novatx:w-5 novatx:items-center novatx:justify-center novatx:rounded-full novatx:border-2",o.border,o.fill,s?.circle,l?.circle),children:i()}),jsx("span",{className:cn("novatx:mt-2 novatx:text-center novatx:text-xs",t!=="inactive"?"novatx:font-semibold novatx:text-[var(--tuwa-text-primary)]":"novatx:text-[var(--tuwa-text-secondary)]",s?.label,l?.label),children:a})]})}function Kt({isProcessing:t,isSucceed:a,isFailed:n,isReplaced:s,className:o,StepComponent:l=Qa,stepClassNames:i}){let{trackingModal:c,statuses:p}=g(),r=useMemo(()=>{let e=x=>{if(x===1)return "completed";if(x===2){if(a||n||s)return "completed";if(t)return "active"}if(x===3){if(a)return "completed";if(n)return "error";if(s)return "replaced";if(t)return "active"}return "inactive"},d=x=>x===1?c.progressIndicator.created:x===2?c.progressIndicator.processing:n?p.failed:s?p.replaced:c.progressIndicator.succeed;return [{status:e(1),label:d(1),isFirst:true,classNames:i},{status:e(2),label:d(2),classNames:i},{status:e(3),label:d(3),isLast:true,classNames:i}]},[t,a,n,s,c,p,i]);return jsx("div",{className:cn("novatx:flex novatx:w-full novatx:items-start novatx:px-4 novatx:pt-2 novatx:pb-1",o),children:r.map((e,d)=>jsx(l,{...e},d))})}var ao={succeed:{Icon:CheckCircleIcon,className:"novatx:text-[var(--tuwa-success-icon)]"},failed:{Icon:ExclamationCircleIcon,className:"novatx:text-[var(--tuwa-error-icon)]"},replaced:{Icon:ArrowPathIcon,className:"novatx:text-[var(--tuwa-info-icon)]"},processing:{Icon:ArrowPathIcon,className:"novatx:animate-spin novatx:text-[var(--tuwa-text-accent)]"},initializing:{Icon:ClockIcon,className:"novatx:animate-pulse novatx:text-[var(--tuwa-pending-icon)]"}};function Rt({isProcessing:t,isSucceed:a,isFailed:n,isReplaced:s,className:o,iconClassNames:l}){let i=a&&"succeed"||n&&"failed"||s&&"replaced"||t&&"processing"||"initializing",{Icon:c,className:p}=ao[i],r=l?.statusOverrides?.[i];return jsx("div",{className:cn("novatx:flex novatx:justify-center novatx:py-4",o),children:jsx(c,{className:cn("novatx:h-16 novatx:w-16",p,l?.icon,r)})})}Wt.extend(no);var so=({chainId:t,className:a})=>jsx("div",{className:cn("novatx:h-8 novatx:w-8 novatx:text-[var(--tuwa-text-secondary)]",a),children:jsx(NetworkIcon,{chainId:setChainId(t)})}),ro=({timestamp:t,className:a})=>jsx("span",{className:cn("novatx:mb-1 novatx:block novatx:text-xs novatx:text-[var(--tuwa-text-secondary)]",a),children:t?Wt.unix(t).fromNow():"..."});function Ft({tx:t,adapter:a,className:n,customization:s}){let{Icon:o=so,Title:l=R,Description:i=R,Timestamp:c=ro,StatusBadge:p=at,TransactionKey:r=_}=s?.components??{},e=s?.classNames;return jsxs("div",{className:cn("novatx:flex novatx:flex-col novatx:gap-2 novatx:border-b novatx:border-[var(--tuwa-border-secondary)] novatx:p-3 novatx:transition-colors novatx:hover:bg-[var(--tuwa-bg-secondary)]",e?.container,n),children:[jsxs("div",{className:"novatx:flex novatx:items-start novatx:justify-between",children:[jsxs("div",{className:"novatx:flex novatx:items-center novatx:gap-4",children:[jsx("div",{className:cn("novatx:flex novatx:h-10 novatx:w-10 novatx:flex-shrink-0 novatx:items-center novatx:justify-center novatx:rounded-full novatx:bg-[var(--tuwa-bg-muted)]",e?.iconWrapper),children:jsx(o,{chainId:t.chainId,className:e?.icon})}),jsxs("div",{className:e?.contentWrapper,children:[jsx(l,{txStatus:t.status,source:t.title,fallback:t.type,variant:"title",applyColor:true,className:e?.title}),jsx(c,{timestamp:t.localTimestamp,className:e?.timestamp}),jsx(i,{txStatus:t.status,source:t.description,variant:"description",className:e?.description})]})]}),jsx(p,{tx:t,className:e?.statusBadge,classNames:{icon:e?.statusBadgeIcon,label:e?.statusBadgeLabel}})]}),jsx(r,{tx:t,adapter:a,variant:"history",className:e?.txKeyContainer,hashLinkClassNames:{label:e?.hashLabel,link:e?.hashLink,copyButton:e?.hashCopyButton},originalHashLinkClassNames:{label:e?.originalHashLabel,link:e?.originalHashLink,copyButton:e?.originalHashCopyButton}})]})}function lo({title:t,message:a,className:n,classNames:s}){return jsxs("div",{className:cn("novatx:rounded-lg novatx:bg-[var(--tuwa-bg-muted)] novatx:p-8 novatx:text-center",n),children:[jsx("h4",{className:cn("novatx:font-semibold novatx:text-[var(--tuwa-text-primary)]",s?.title),children:t}),jsx("p",{className:cn("novatx:mt-1 novatx:text-sm novatx:text-[var(--tuwa-text-secondary)]",s?.message),children:a})]})}function Vt({adapter:t,connectedWalletAddress:a,transactionsPool:n,className:s,customization:o}){let{transactionsModal:l}=g(),i=useMemo(()=>a?selectAllTransactionsByActiveWallet(n,a).sort((d,x)=>(x.localTimestamp??0)-(d.localTimestamp??0)):[],[n,a]),{Placeholder:c=lo,HistoryItem:p=Ft}=o?.components??{},r=()=>{if(!a)return jsx(c,{title:l.history.connectWalletTitle,message:l.history.connectWalletMessage,className:o?.classNames?.placeholderContainer,classNames:{title:o?.classNames?.placeholderTitle,message:o?.classNames?.placeholderMessage}});if(i.length>0){let e={container:o?.classNames?.itemContainer,iconWrapper:o?.classNames?.itemIconWrapper,icon:o?.classNames?.itemIcon,contentWrapper:o?.classNames?.itemContentWrapper,title:o?.classNames?.itemTitle,timestamp:o?.classNames?.itemTimestamp,description:o?.classNames?.itemDescription,statusBadge:o?.classNames?.itemStatusBadge,statusBadgeIcon:o?.classNames?.itemStatusBadgeIcon,statusBadgeLabel:o?.classNames?.itemStatusBadgeLabel,txKeyContainer:o?.classNames?.itemTxKeyContainer,hashLabel:o?.classNames?.itemHashLabel,hashLink:o?.classNames?.itemHashLink,hashCopyButton:o?.classNames?.itemHashCopyButton,originalHashLabel:o?.classNames?.itemOriginalHashLabel,originalHashLink:o?.classNames?.itemOriginalHashLink,originalHashCopyButton:o?.classNames?.itemOriginalHashCopyButton};return jsx("div",{className:cn("NovaCustomScroll novatx:max-h-[400px] novatx:overflow-y-auto novatx:rounded-lg novatx:border novatx:border-[var(--tuwa-border-primary)] novatx:bg-[var(--tuwa-bg-primary)]",o?.classNames?.listWrapper),children:i.map(d=>jsx(p,{tx:d,adapter:t,customization:{classNames:e}},d.txKey))})}return jsx(c,{title:l.history.noTransactionsTitle,message:l.history.noTransactionsMessage,className:o?.classNames?.placeholderContainer,classNames:{title:o?.classNames?.placeholderTitle,message:o?.classNames?.placeholderMessage}})};return jsxs("div",{className:cn("novatx:flex novatx:flex-col novatx:gap-y-3",o?.classNames?.container,s),children:[o?.title&&jsx("h3",{className:cn("novatx:text-lg novatx:font-bold novatx:text-[var(--tuwa-text-primary)]",o?.classNames?.titleText),children:o?.title}),r()]})}var To=({closeModal:t,title:a,classNames:n})=>{let{actions:s}=g();return jsxs(DialogHeader,{className:n?.header,children:[jsx(DialogTitle,{className:n?.title,children:a}),jsx(DialogClose,{asChild:true,children:jsx("button",{type:"button",onClick:t,"aria-label":s.close,className:cn("novatx:cursor-pointer novatx:rounded-full novatx:p-1 novatx:text-[var(--tuwa-text-tertiary)] novatx:transition-colors novatx:hover:bg-[var(--tuwa-bg-muted)] novatx:hover:text-[var(--tuwa-text-primary)]",n?.closeButton),children:jsx(CloseIcon,{})})})]})};function Jt({isOpen:t,setIsOpen:a,customization:n,adapter:s,connectedWalletAddress:o,transactionsPool:l}){let{transactionsModal:i}=g(),c=()=>a(false),p=n?.components?.Header,r=n?.components?.History;return jsx(Dialog,{open:t,onOpenChange:e=>!e&&c(),children:jsx(DialogContent,{className:cn("novatx:w-full novatx:sm:max-w-2xl",n?.modalProps?.className),...n?.modalProps,children:jsxs("div",{className:cn("novatx:relative novatx:max-h-[95dvh] novatx:w-full novatx:flex novatx:flex-col",n?.classNames?.contentWrapper),children:[p?jsx(p,{closeModal:c}):jsx(To,{closeModal:c,title:i.history.title,classNames:{header:n?.classNames?.header,title:n?.classNames?.headerTitle,closeButton:n?.classNames?.closeButton}}),r?jsx(r,{adapter:s,transactionsPool:l,connectedWalletAddress:o,customization:n?.historyCustomization}):jsx(Vt,{adapter:s,transactionsPool:l,connectedWalletAddress:o,customization:n?.historyCustomization})]})})})}var ho=t=>({replaced:jsxs(Fragment,{children:[jsx(ArrowPathIcon,{className:"novatx:h-4 novatx:w-4"}),jsx("span",{children:t.replaced})]}),loading:jsxs(Fragment,{children:[jsx(ArrowPathIcon,{className:"novatx:h-4 novatx:w-4 novatx:animate-spin"}),jsx("span",{children:t.loading})]}),succeed:jsxs(Fragment,{children:[jsx(CheckCircleIcon,{className:"novatx:h-4 novatx:w-4"}),jsx("span",{children:t.succeed})]}),failed:jsxs(Fragment,{children:[jsx(ExclamationCircleIcon,{className:"novatx:h-4 novatx:w-4"}),jsx("span",{children:t.failed})]})});function ps({children:t,action:a,getLastTxKey:n,transactionsPool:s,walletAddress:o,loadingContent:l,succeedContent:i,failedContent:c,replacedContent:p,resetTimeout:r=2500,className:e,classNames:d,...x}){let{trackedTxButton:u}=g(),[T,h]=useState("idle"),[y,C]=useState(void 0),f=useMemo(()=>ho(u),[u]);useEffect(()=>{h("idle"),C(void 0);},[o]),useEffect(()=>{if(!y)return;let N=s[y];if(N)switch(N.status){case TransactionStatus.Success:h("succeed");break;case TransactionStatus.Replaced:h("replaced");break;case TransactionStatus.Failed:h("failed");break}},[s,y,o]),useEffect(()=>{if(["succeed","failed","replaced"].includes(T)){let N=setTimeout(()=>{h("idle"),C(void 0);},r);return ()=>clearTimeout(N)}},[T,r]);let m=async()=>{h("loading");try{await a(),C(n());}catch(N){console.error("Transaction initiation failed:",N),h("failed");}},B=()=>{switch(T){case "loading":return l??f.loading;case "succeed":return i??f.succeed;case "failed":return c??f.failed;case "replaced":return p??f.replaced;default:return t}},U={idle:"novatx:bg-gradient-to-r novatx:from-[var(--tuwa-button-gradient-from)] novatx:to-[var(--tuwa-button-gradient-to)] novatx:text-[var(--tuwa-text-on-accent)] novatx:hover:opacity-90",loading:"novatx:bg-gray-400 novatx:text-white",replaced:"novatx:bg-gray-500 novatx:text-white",succeed:"novatx:bg-[var(--tuwa-success-bg)] novatx:text-[var(--tuwa-success-text)]",failed:"novatx:bg-[var(--tuwa-error-bg)] novatx:text-[var(--tuwa-error-text)]"},b=d?.[T]??U[T],w=d?.base??"novatx:flex novatx:cursor-pointer novatx:items-center novatx:justify-center novatx:gap-1.5 novatx:rounded-md novatx:px-3 novatx:py-1.5 novatx:text-sm novatx:font-medium novatx:transition-all novatx:duration-200 novatx:disabled:cursor-not-allowed novatx:disabled:opacity-70";return jsx("button",{...x,disabled:T!=="idle"||x.disabled,onClick:m,className:cn(w,b,e),children:B()})}var So={[TransactionStatus.Success]:"success",[TransactionStatus.Failed]:"error",[TransactionStatus.Replaced]:"info"};function Vs({adapter:t,connectedWalletAddress:a,connectedAdapterType:n,transactionsPool:s,initialTx:o,executeTxAction:l,closeTxTrackedModal:i,labels:c,features:p,customization:r,...e}){let[d,x]=useState(false),u=useRef(s),T="nova-transactions",h=useMediaQuery("(max-width: 767px)"),y=useMemo(()=>({toasts:p?.toasts??true,transactionsModal:p?.transactionsModal??true,trackingTxModal:p?.trackingTxModal??true}),[p]),C=useMemo(()=>deepMerge(j,c||{}),[c]),f=useCallback(b=>{if(!y.toasts)return;let w=b.pending?"info":So[b.status]??"info",N=Z=>jsx(Bt,{...Z,tx:b,openTxInfoModal:y.transactionsModal?()=>x(true):void 0,customization:r?.toast,adapter:t,connectedWalletAddress:a});toast.isActive(b.txKey)?toast.update(b.txKey,{render:N,type:w,containerId:T}):toast(N,{toastId:b.txKey,type:w,closeOnClick:false,containerId:T});},[s,y,r?.toast,t,a]);useEffect(()=>{let b=u.current;Object.values(s).forEach(w=>{let N=b[w.txKey];if(!N&&w.pending){f(w);return}N&&JSON.stringify(N)!==JSON.stringify(w)&&f(w);}),u.current=s;},[s,f]),useEffect(()=>{Object.values(s).forEach(b=>{toast.isActive(b.txKey,T)&&f(b);});},[a,f,s]);let m=!!o?.withTrackedModal&&s[o?.lastTxKey??""]?.isTrackedModalOpen,B=y.toasts&&(!h||!m&&!d),U=useMemo(()=>{let b=r?.toastCloseButton;return b?({closeToast:w})=>jsx(ToastCloseButton,{closeToast:w,...b}):ToastCloseButton},[r?.toastCloseButton]);return jsxs(Nt,{labels:C,children:[B&&jsx(ToastContainer,{position:"bottom-right",stacked:true,autoClose:false,hideProgressBar:true,closeOnClick:false,icon:false,closeButton:U,containerId:T,toastClassName:"novatx:!p-0 novatx:!bg-transparent novatx:!shadow-none novatx:!min-h-0",...e}),y.transactionsModal&&jsx(Jt,{isOpen:d,setIsOpen:x,customization:r?.transactionsInfoModal,adapter:t,connectedWalletAddress:a,connectedAdapterType:n,transactionsPool:s}),y.trackingTxModal&&jsx(Ht,{initialTx:o,onClose:i,onOpenAllTransactions:()=>x(true),transactionsPool:s,customization:r?.trackingTxModal,executeTxAction:l,adapter:t,connectedWalletAddress:a})]})}export{j as a,Nt as b,g as c,Vs as d,$ as e,R as f,_ as g,at as h,Bt as i,Ht as j,Mt as k,At as l,Kt as m,Rt as n,Ft as o,Vt as p,Jt as q,ps as r};
|