@aave/react 4.0.0-next.6 → 4.0.0-next.8

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.
@@ -1,6 +1,6 @@
1
1
  import { UnexpectedError, CurrencyQueryOptions } from '@aave/client';
2
2
  import { UnexpectedError as UnexpectedError$1 } from '@aave/core';
3
- import { ChainRequest, Chain, ChainsFilter, ExchangeRateRequest, FiatAmount, ActivityItem, PreviewAction, NativeAmount } from '@aave/graphql';
3
+ import { ChainRequest, Chain, ChainsRequest, ExchangeRateRequest, ExchangeAmount, ActivityItem, PreviewAction, NativeAmount } from '@aave/graphql';
4
4
  import { NullishDeep, Prettify } from '@aave/types';
5
5
  import { a as UseAsyncTask } from './writes-BXnwYgAQ.js';
6
6
 
@@ -145,9 +145,7 @@ declare function useChain(args: UseChainArgs): ReadResult<Chain | null>;
145
145
  * ```
146
146
  */
147
147
  declare function useChain(args: Pausable<UseChainArgs>): PausableReadResult<Chain | null>;
148
- type UseChainsArgs = {
149
- filter: ChainsFilter;
150
- };
148
+ type UseChainsArgs = ChainsRequest;
151
149
  /**
152
150
  * Fetches the list of supported chains.
153
151
  *
@@ -155,7 +153,7 @@ type UseChainsArgs = {
155
153
  *
156
154
  * ```tsx
157
155
  * const { data } = useChains({
158
- * filter: ChainsFilter.ALL,
156
+ * query: { filter: ChainsFilter.ALL },
159
157
  * suspense: true,
160
158
  * });
161
159
  * ```
@@ -168,7 +166,7 @@ declare function useChains(args: UseChainsArgs & Suspendable): SuspenseResult<Ch
168
166
  *
169
167
  * ```tsx
170
168
  * const { data } = useChains({
171
- * filter: ChainsFilter.ALL,
169
+ * query: { filter: ChainsFilter.ALL },
172
170
  * suspense: true,
173
171
  * pause: true,
174
172
  * });
@@ -180,7 +178,7 @@ declare function useChains(args: Pausable<UseChainsArgs> & Suspendable): Pausabl
180
178
  *
181
179
  * ```tsx
182
180
  * const { data, error, loading } = useChains({
183
- * filter: ChainsFilter.ALL,
181
+ * query: { filter: ChainsFilter.ALL },
184
182
  * });
185
183
  * ```
186
184
  */
@@ -192,7 +190,7 @@ declare function useChains(args?: UseChainsArgs): ReadResult<Chain[]>;
192
190
  *
193
191
  * ```tsx
194
192
  * const { data, error, loading, paused } = useChains({
195
- * filter: ChainsFilter.ALL,
193
+ * query: { filter: ChainsFilter.ALL },
196
194
  * pause: true,
197
195
  * });
198
196
  * ```
@@ -222,7 +220,7 @@ declare function useChains(args?: Pausable<UseChainsArgs>): PausableReadResult<C
222
220
  * console.log('Exchange rate:', result.value);
223
221
  * ```
224
222
  */
225
- declare function useExchangeRateAction(): UseAsyncTask<ExchangeRateRequest, FiatAmount, UnexpectedError$1>;
223
+ declare function useExchangeRateAction(): UseAsyncTask<ExchangeRateRequest, ExchangeAmount, UnexpectedError$1>;
226
224
  type UseExchangeRateArgs = ExchangeRateRequest;
227
225
  /**
228
226
  * Fetches exchange rates between tokens and fiat currencies with automatic polling.
@@ -242,7 +240,7 @@ type UseExchangeRateArgs = ExchangeRateRequest;
242
240
  * });
243
241
  * ```
244
242
  */
245
- declare function useExchangeRate(args: UseExchangeRateArgs & Suspendable): SuspenseResult<FiatAmount>;
243
+ declare function useExchangeRate(args: UseExchangeRateArgs & Suspendable): SuspenseResult<ExchangeAmount>;
246
244
  /**
247
245
  * Fetches exchange rates between tokens and fiat currencies with automatic polling.
248
246
  *
@@ -262,7 +260,7 @@ declare function useExchangeRate(args: UseExchangeRateArgs & Suspendable): Suspe
262
260
  * });
263
261
  * ```
264
262
  */
265
- declare function useExchangeRate(args: Pausable<UseExchangeRateArgs> & Suspendable): PausableSuspenseResult<FiatAmount>;
263
+ declare function useExchangeRate(args: Pausable<UseExchangeRateArgs> & Suspendable): PausableSuspenseResult<ExchangeAmount>;
266
264
  /**
267
265
  * Fetches exchange rates between tokens and fiat currencies with automatic polling.
268
266
  *
@@ -280,7 +278,7 @@ declare function useExchangeRate(args: Pausable<UseExchangeRateArgs> & Suspendab
280
278
  * <Component value={somewhere} fxRate={data} />
281
279
  * ```
282
280
  */
283
- declare function useExchangeRate(args: UseExchangeRateArgs): ReadResult<FiatAmount>;
281
+ declare function useExchangeRate(args: UseExchangeRateArgs): ReadResult<ExchangeAmount>;
284
282
  /**
285
283
  * Fetches exchange rates between tokens and fiat currencies with automatic polling.
286
284
  *
@@ -299,7 +297,7 @@ declare function useExchangeRate(args: UseExchangeRateArgs): ReadResult<FiatAmou
299
297
  * });
300
298
  * ```
301
299
  */
302
- declare function useExchangeRate(args: Pausable<UseExchangeRateArgs>): PausableReadResult<FiatAmount>;
300
+ declare function useExchangeRate(args: Pausable<UseExchangeRateArgs>): PausableReadResult<ExchangeAmount>;
303
301
  type UseNetworkFeeRequestQuery = {
304
302
  activity: ActivityItem;
305
303
  } | {
@@ -1,6 +1,6 @@
1
1
  import { UnexpectedError, CurrencyQueryOptions } from '@aave/client';
2
2
  import { UnexpectedError as UnexpectedError$1 } from '@aave/core';
3
- import { ChainRequest, Chain, ChainsFilter, ExchangeRateRequest, FiatAmount, ActivityItem, PreviewAction, NativeAmount } from '@aave/graphql';
3
+ import { ChainRequest, Chain, ChainsRequest, ExchangeRateRequest, ExchangeAmount, ActivityItem, PreviewAction, NativeAmount } from '@aave/graphql';
4
4
  import { NullishDeep, Prettify } from '@aave/types';
5
5
  import { a as UseAsyncTask } from './writes-BXnwYgAQ.cjs';
6
6
 
@@ -145,9 +145,7 @@ declare function useChain(args: UseChainArgs): ReadResult<Chain | null>;
145
145
  * ```
146
146
  */
147
147
  declare function useChain(args: Pausable<UseChainArgs>): PausableReadResult<Chain | null>;
148
- type UseChainsArgs = {
149
- filter: ChainsFilter;
150
- };
148
+ type UseChainsArgs = ChainsRequest;
151
149
  /**
152
150
  * Fetches the list of supported chains.
153
151
  *
@@ -155,7 +153,7 @@ type UseChainsArgs = {
155
153
  *
156
154
  * ```tsx
157
155
  * const { data } = useChains({
158
- * filter: ChainsFilter.ALL,
156
+ * query: { filter: ChainsFilter.ALL },
159
157
  * suspense: true,
160
158
  * });
161
159
  * ```
@@ -168,7 +166,7 @@ declare function useChains(args: UseChainsArgs & Suspendable): SuspenseResult<Ch
168
166
  *
169
167
  * ```tsx
170
168
  * const { data } = useChains({
171
- * filter: ChainsFilter.ALL,
169
+ * query: { filter: ChainsFilter.ALL },
172
170
  * suspense: true,
173
171
  * pause: true,
174
172
  * });
@@ -180,7 +178,7 @@ declare function useChains(args: Pausable<UseChainsArgs> & Suspendable): Pausabl
180
178
  *
181
179
  * ```tsx
182
180
  * const { data, error, loading } = useChains({
183
- * filter: ChainsFilter.ALL,
181
+ * query: { filter: ChainsFilter.ALL },
184
182
  * });
185
183
  * ```
186
184
  */
@@ -192,7 +190,7 @@ declare function useChains(args?: UseChainsArgs): ReadResult<Chain[]>;
192
190
  *
193
191
  * ```tsx
194
192
  * const { data, error, loading, paused } = useChains({
195
- * filter: ChainsFilter.ALL,
193
+ * query: { filter: ChainsFilter.ALL },
196
194
  * pause: true,
197
195
  * });
198
196
  * ```
@@ -222,7 +220,7 @@ declare function useChains(args?: Pausable<UseChainsArgs>): PausableReadResult<C
222
220
  * console.log('Exchange rate:', result.value);
223
221
  * ```
224
222
  */
225
- declare function useExchangeRateAction(): UseAsyncTask<ExchangeRateRequest, FiatAmount, UnexpectedError$1>;
223
+ declare function useExchangeRateAction(): UseAsyncTask<ExchangeRateRequest, ExchangeAmount, UnexpectedError$1>;
226
224
  type UseExchangeRateArgs = ExchangeRateRequest;
227
225
  /**
228
226
  * Fetches exchange rates between tokens and fiat currencies with automatic polling.
@@ -242,7 +240,7 @@ type UseExchangeRateArgs = ExchangeRateRequest;
242
240
  * });
243
241
  * ```
244
242
  */
245
- declare function useExchangeRate(args: UseExchangeRateArgs & Suspendable): SuspenseResult<FiatAmount>;
243
+ declare function useExchangeRate(args: UseExchangeRateArgs & Suspendable): SuspenseResult<ExchangeAmount>;
246
244
  /**
247
245
  * Fetches exchange rates between tokens and fiat currencies with automatic polling.
248
246
  *
@@ -262,7 +260,7 @@ declare function useExchangeRate(args: UseExchangeRateArgs & Suspendable): Suspe
262
260
  * });
263
261
  * ```
264
262
  */
265
- declare function useExchangeRate(args: Pausable<UseExchangeRateArgs> & Suspendable): PausableSuspenseResult<FiatAmount>;
263
+ declare function useExchangeRate(args: Pausable<UseExchangeRateArgs> & Suspendable): PausableSuspenseResult<ExchangeAmount>;
266
264
  /**
267
265
  * Fetches exchange rates between tokens and fiat currencies with automatic polling.
268
266
  *
@@ -280,7 +278,7 @@ declare function useExchangeRate(args: Pausable<UseExchangeRateArgs> & Suspendab
280
278
  * <Component value={somewhere} fxRate={data} />
281
279
  * ```
282
280
  */
283
- declare function useExchangeRate(args: UseExchangeRateArgs): ReadResult<FiatAmount>;
281
+ declare function useExchangeRate(args: UseExchangeRateArgs): ReadResult<ExchangeAmount>;
284
282
  /**
285
283
  * Fetches exchange rates between tokens and fiat currencies with automatic polling.
286
284
  *
@@ -299,7 +297,7 @@ declare function useExchangeRate(args: UseExchangeRateArgs): ReadResult<FiatAmou
299
297
  * });
300
298
  * ```
301
299
  */
302
- declare function useExchangeRate(args: Pausable<UseExchangeRateArgs>): PausableReadResult<FiatAmount>;
300
+ declare function useExchangeRate(args: Pausable<UseExchangeRateArgs>): PausableReadResult<ExchangeAmount>;
303
301
  type UseNetworkFeeRequestQuery = {
304
302
  activity: ActivityItem;
305
303
  } | {
package/dist/thirdweb.cjs CHANGED
@@ -1,2 +1,2 @@
1
- 'use strict';var client=require('@aave/client'),thirdweb=require('@aave/client/thirdweb'),types=require('@aave/types'),thirdweb$1=require('thirdweb'),react=require('thirdweb/react'),h=require('react');require('@aave/core');var actions=require('@aave/client/actions');require('urql');function _interopDefault(e){return e&&e.__esModule?e:{default:e}}var h__default=/*#__PURE__*/_interopDefault(h);var T={Idle:()=>({called:false,loading:false,data:void 0,error:void 0}),Loading:e=>({called:true,loading:true,data:e,error:void 0}),Success:e=>({called:true,loading:false,data:e,error:void 0}),Failed:e=>({called:true,loading:false,data:void 0,error:e})};function s(e,t){let[a,r]=h.useState(T.Idle()),n=h.useRef(false),o=h.useCallback(e,t);return [h.useCallback(u=>{types.invariant(!n.current,"Cannot execute a task while another is in progress."),n.current=true,r(({data:i})=>({called:true,loading:true,data:i,error:void 0}));let f=o(u);return f.match(i=>{n.current=false,r(T.Success(i));},i=>{n.current=false,r(T.Failed(i));}),f},[o]),a]}var d=class e{constructor(t){this.wait=t;}static ensure(t){return types.invariant(t instanceof e,"Expected PendingTransaction"),t}};var U=h__default.default.createContext(null);function E(){let e=h.useContext(U);return types.invariant(e,"Could not find Aave SDK context, ensure your code is wrapped in a <AaveProvider>"),e}function g(){let e=E();return s(t=>actions.permitTypedData(e,t),[e])}function pe(e){let t=react.useActiveAccount(),a=react.useSwitchActiveWalletChain();return s(r=>{types.invariant(t,"No Account found. Ensure you have connected your wallet.");let n=thirdweb.supportedChains[r.chainId]??types.never(`Chain not supported: ${r.chainId}`);return types.ResultAsync.fromPromise(a(n),o=>client.UnexpectedError.from(o)).andThen(()=>types.ResultAsync.fromPromise(thirdweb$1.sendTransaction({account:t,transaction:thirdweb$1.prepareTransaction({to:r.to,data:r.data,value:BigInt(r.value),chain:n,client:e})}),o=>client.SigningError.from(o))).map(({transactionHash:o})=>new d(()=>types.ResultAsync.fromPromise(thirdweb$1.waitForReceipt({client:e,chain:n,transactionHash:o}),p=>client.UnexpectedError.from(p)).andThen(({status:p,transactionHash:u})=>p==="reverted"?client.TransactionError.new({txHash:types.txHash(u),request:r}).asResultAsync():types.okAsync({operations:r.operations,txHash:types.txHash(u)}))))},[t,a,e])}function ue(){let[e]=g(),t=react.useActiveAccount();return s(a=>(types.invariant(t,"No Account found. Ensure you have connected your wallet."),e(a).andThen(r=>types.ResultAsync.fromPromise(t.signTypedData({types:r.types,domain:r.domain,primaryType:r.primaryType,message:r.message}),n=>client.SigningError.from(n)).map(n=>({deadline:r.message.deadline,value:types.signatureFrom(n)})))),[t,e])}function de(){let e=react.useActiveAccount();return s(t=>{types.invariant(e,"Expected an active account to sign swap typed data");let a=JSON.parse(t.message);return types.ResultAsync.fromPromise(e.signTypedData({types:t.types,domain:t.domain,primaryType:t.primaryType,message:a}),r=>client.SigningError.from(r)).map(r=>({deadline:a.deadline,value:types.signatureFrom(r)}))},[e])}exports.useERC20Permit=ue;exports.useSendTransaction=pe;exports.useSignSwapTypedDataWith=de;//# sourceMappingURL=thirdweb.cjs.map
1
+ 'use strict';var client=require('@aave/client'),actions=require('@aave/client/actions'),thirdweb=require('@aave/client/thirdweb'),types=require('@aave/types'),thirdweb$1=require('thirdweb'),react=require('thirdweb/react'),P=require('react');require('urql'),require('@aave/core');function _interopDefault(e){return e&&e.__esModule?e:{default:e}}var P__default=/*#__PURE__*/_interopDefault(P);var k=P__default.default.createContext(null);function T(){let e=P.useContext(k);return types.invariant(e,"Could not find Aave SDK context, ensure your code is wrapped in a <AaveProvider>"),e}var m={Idle:()=>({called:false,loading:false,data:void 0,error:void 0}),Loading:e=>({called:true,loading:true,data:e,error:void 0}),Success:e=>({called:true,loading:false,data:e,error:void 0}),Failed:e=>({called:true,loading:false,data:void 0,error:e})};function i(e,r){let[a,t]=P.useState(m.Idle()),n=P.useRef(false),o=P.useCallback(e,r);return [P.useCallback(c=>{types.invariant(!n.current,"Cannot execute a task while another is in progress."),n.current=true,t(({data:u})=>({called:true,loading:true,data:u,error:void 0}));let p=o(c);return p.match(u=>{n.current=false,t(m.Success(u));},u=>{n.current=false,t(m.Failed(u));}),p},[o]),a]}var l=class e{constructor(r){this.wait=r;}static ensure(r){return types.invariant(r instanceof e,"Expected PendingTransaction"),r}};function g(){let e=T();return i(r=>actions.permitTypedData(e,r),[e])}function de(e){let r=T(),a=react.useActiveAccount(),t=react.useSwitchActiveWalletChain();return i(n=>(types.invariant(a,"No Account found. Ensure you have connected your wallet."),actions.chain(r,{chainId:n.chainId},{batch:false}).map(o=>(types.invariant(o,`Chain ${n.chainId} is not supported`),thirdweb.toThirdwebChain(o))).andThen(o=>types.ResultAsync.fromPromise(t(o),s=>client.UnexpectedError.from(s)).andThen(()=>types.ResultAsync.fromPromise(thirdweb$1.sendTransaction({account:a,transaction:thirdweb$1.prepareTransaction({to:n.to,data:n.data,value:BigInt(n.value),chain:o,client:e})}),s=>client.SigningError.from(s))).map(({transactionHash:s})=>new l(()=>types.ResultAsync.fromPromise(thirdweb$1.waitForReceipt({client:e,chain:o,transactionHash:s}),c=>client.UnexpectedError.from(c)).andThen(({status:c,transactionHash:p})=>c==="reverted"?client.TransactionError.new({txHash:types.txHash(p),request:n}).asResultAsync():types.okAsync({operations:n.operations,txHash:types.txHash(p)})))))),[a,r,t,e])}function Te(){let[e]=g(),r=react.useActiveAccount();return i(a=>(types.invariant(r,"No Account found. Ensure you have connected your wallet."),e(a).andThen(t=>types.ResultAsync.fromPromise(r.signTypedData({types:t.types,domain:t.domain,primaryType:t.primaryType,message:t.message}),n=>client.SigningError.from(n)).map(n=>({deadline:t.message.deadline,value:types.signatureFrom(n)})))),[r,e])}function le(){let e=react.useActiveAccount();return i(r=>{types.invariant(e,"Expected an active account to sign swap typed data");let a=JSON.parse(r.message);return types.ResultAsync.fromPromise(e.signTypedData({types:r.types,domain:r.domain,primaryType:r.primaryType,message:a}),t=>client.SigningError.from(t)).map(t=>({deadline:a.deadline,value:types.signatureFrom(t)}))},[e])}exports.useERC20Permit=Te;exports.useSendTransaction=de;exports.useSignSwapTypedDataWith=le;//# sourceMappingURL=thirdweb.cjs.map
2
2
  //# sourceMappingURL=thirdweb.cjs.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/helpers/tasks.ts","../src/helpers/writes.ts","../src/context.tsx","../src/permits.ts","../src/thirdweb.ts"],"names":["AsyncTaskState","data","error","useAsyncTask","handler","deps","state","setState","useState","loadingRef","useRef","handle","useCallback","input","invariant","result","value","PendingTransaction","_PendingTransaction","wait","AaveContext","React","useAaveClient","client","useContext","usePermitTypedDataAction","request","permitTypedData","useSendTransaction","thirdwebClient","account","useActiveAccount","switchChain","useSwitchActiveWalletChain","chain","supportedChains","never","ResultAsync","err","UnexpectedError","sendTransaction","prepareTransaction","SigningError","transactionHash","waitForReceipt","status","TransactionError","txHash","okAsync","useERC20Permit","signature","signatureFrom","useSignSwapTypedDataWith","typedData","message"],"mappings":"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","file":"thirdweb.cjs","sourcesContent":["import { invariant, type ResultAsync } from '@aave/types';\nimport { type DependencyList, useCallback, useRef, useState } from 'react';\n\n/**\n * An async task is a function that can be executed multiple times and that can be in a pending state.\n *\n * @internal\n */\nexport type AsyncTask<TInput, TResult extends ResultAsync<unknown, unknown>> = (\n input: TInput,\n) => TResult;\n\n/**\n * The initial state of a async task.\n */\nexport type AsyncTaskIdle = {\n called: boolean;\n loading: false;\n data: undefined;\n error: undefined;\n};\n\n/**\n * The state of a async task during the loading.\n */\nexport type AsyncTaskLoading<TData> = {\n called: true;\n loading: true;\n data: TData | undefined;\n error: undefined;\n};\n\n/**\n * The state of a async task after a successful call.\n */\nexport type AsyncTaskSuccess<TData> = {\n called: true;\n loading: false;\n data: TData;\n error: undefined;\n};\n\n/**\n * The state of a async task after a failed call.\n */\nexport type AsyncTaskError<TError> = {\n called: true;\n loading: false;\n data: undefined;\n error: TError;\n};\n\n/**\n * The possible statuses of a async task.\n */\nexport type AsyncTaskState<TData, TError> =\n | AsyncTaskIdle\n | AsyncTaskLoading<TData>\n | AsyncTaskSuccess<TData>\n | AsyncTaskError<TError>;\n\nconst AsyncTaskState = {\n Idle: <TData, TError>(): AsyncTaskState<TData, TError> => ({\n called: false,\n loading: false,\n data: undefined,\n error: undefined,\n }),\n Loading: <TData, TError>(data?: TData): AsyncTaskState<TData, TError> => ({\n called: true,\n loading: true,\n data,\n error: undefined,\n }),\n Success: <TData, TError>(data: TData): AsyncTaskState<TData, TError> => ({\n called: true,\n loading: false,\n data,\n error: undefined,\n }),\n Failed: <TData, TError>(error: TError): AsyncTaskState<TData, TError> => ({\n called: true,\n loading: false,\n data: undefined,\n error,\n }),\n};\n\n/**\n * A async task React Hook is a lightweight wrapper for an asynchronous function.\n * It allows tracking of the task's execution status and provides access to the\n * last error that occurred during the task's execution, if any.\n *\n * ```ts\n * const [execute, { called, loading, data, error }]: UseAsyncTask<TData, TError, TInput> = useAnyAsyncTask();\n *\n * if (!called) {\n * // data === undefined\n * // error === undefined\n * return <p>Click the button to execute the task</p>;\n * }\n *\n * if (loading) {\n * // data === undefined on first call\n * // data === TData from previous successful call\n * // error === undefined\n * return <Loader />;\n * }\n *\n * if (error) {\n * // data === undefined\n * // error === TError\n * return <p>Something went wrong: {error.message}</p>;\n * }\n *\n * // called === true\n * // data === TData\n * // error === undefined\n * return <p>Task completed: {data}</p>;\n * ```\n */\nexport type UseAsyncTask<TInput, TValue, TError> = [\n AsyncTask<TInput, ResultAsync<TValue, TError>>,\n AsyncTaskState<TValue, TError>,\n];\n\n/**\n * @internal\n */\nexport function useAsyncTask<\n TInput,\n TValue,\n TError,\n TResult extends ResultAsync<TValue, TError>,\n>(\n handler: AsyncTask<TInput, TResult>,\n deps: DependencyList,\n): UseAsyncTask<TInput, TValue, TError> {\n const [state, setState] = useState(AsyncTaskState.Idle<TValue, TError>());\n const loadingRef = useRef(false);\n // biome-ignore lint/correctness/useExhaustiveDependencies: useAsyncTask is a low-level hook\n const handle = useCallback(handler, deps);\n\n const execute = useCallback(\n (input: TInput) => {\n invariant(\n !loadingRef.current,\n 'Cannot execute a task while another is in progress.',\n );\n\n loadingRef.current = true;\n setState(({ data }) => {\n return {\n called: true,\n loading: true,\n data,\n error: undefined,\n };\n });\n\n const result = handle(input);\n\n result.match(\n (value) => {\n loadingRef.current = false;\n setState(AsyncTaskState.Success(value));\n },\n (error) => {\n loadingRef.current = false;\n setState(AsyncTaskState.Failed(error));\n },\n );\n\n return result;\n },\n [handle],\n );\n\n return [execute, state];\n}\n","import type { TransactionResult } from '@aave/client';\nimport {\n CancelError,\n type SigningError,\n type TimeoutError,\n type TransactionError,\n type UnexpectedError,\n} from '@aave/core';\nimport type {\n Erc20ApprovalRequired,\n PreContractActionRequired,\n TransactionRequest,\n} from '@aave/graphql';\nimport type { ResultAsync } from '@aave/types';\nimport { invariant } from '@aave/types';\nimport type { UseAsyncTask } from './tasks';\n\n/**\n * The errors that could occur in the early stage of sending a transaction.\n */\nexport type SendTransactionError = CancelError | SigningError | UnexpectedError;\n\nexport type CancelOperation = (\n message: string,\n) => ResultAsync<never, CancelError>;\n\n/**\n * @internal\n */\nexport const cancel: CancelOperation = (message: string) =>\n CancelError.from(message).asResultAsync();\n\nexport type TransactionHandlerOptions = {\n cancel: CancelOperation;\n};\n\n/**\n * The errors that could occur in the late stages of a transaction.\n */\nexport type PendingTransactionError =\n | CancelError\n | TimeoutError\n | TransactionError\n | UnexpectedError;\n\nexport class PendingTransaction {\n constructor(\n /**\n * @internal Do NOT rely on this method. It's used internally by the SDK and may be subject to breaking changes.\n */\n public readonly wait: () => ResultAsync<\n TransactionResult,\n PendingTransactionError\n >,\n ) {}\n\n /**\n * @internal\n */\n static ensure<T>(value: T): PendingTransaction & T {\n invariant(\n value instanceof PendingTransaction,\n 'Expected PendingTransaction',\n );\n return value as PendingTransaction & T;\n }\n}\n\nexport type UseSendTransactionResult = UseAsyncTask<\n TransactionRequest,\n PendingTransaction,\n SendTransactionError\n>;\n\n/**\n * The handler for sending Aave transactions.\n */\nexport type TransactionHandler = (\n result:\n | TransactionRequest\n | Erc20ApprovalRequired\n | PreContractActionRequired,\n options: TransactionHandlerOptions,\n) => ResultAsync<PendingTransaction, SendTransactionError>;\n","import type { AaveClient } from '@aave/client';\nimport { invariant } from '@aave/types';\nimport React, { type ReactNode, useContext } from 'react';\nimport { Provider as UrqlProvider } from 'urql';\n\nconst AaveContext = React.createContext<AaveClient | null>(null);\n\n/**\n * @internal\n */\nexport type AaveContextProviderProps = {\n children: ReactNode;\n client: AaveClient;\n};\n\n/**\n * @internal\n */\nexport function AaveContextProvider({\n children,\n client,\n}: AaveContextProviderProps) {\n return (\n <AaveContext.Provider value={client}>\n <UrqlProvider value={client.urql}>{children}</UrqlProvider>\n </AaveContext.Provider>\n );\n}\n\n/**\n * @internal\n */\nexport function useAaveClient(): AaveClient {\n const client = useContext(AaveContext);\n\n invariant(\n client,\n 'Could not find Aave SDK context, ensure your code is wrapped in a <AaveProvider>',\n );\n\n return client;\n}\n","import type { UnexpectedError } from '@aave/client';\nimport { permitTypedData } from '@aave/client/actions';\nimport type { PermitRequest, PermitTypedDataResponse } from '@aave/graphql';\nimport { useAaveClient } from './context';\nimport { type UseAsyncTask, useAsyncTask } from './helpers';\n\n/**\n * @internal\n */\nexport function usePermitTypedDataAction(): UseAsyncTask<\n PermitRequest,\n PermitTypedDataResponse,\n UnexpectedError\n> {\n const client = useAaveClient();\n\n return useAsyncTask(\n (request: PermitRequest) => permitTypedData(client, request),\n [client],\n );\n}\n","import { SigningError, TransactionError, UnexpectedError } from '@aave/client';\nimport { supportedChains } from '@aave/client/thirdweb';\nimport type {\n CancelSwapTypedData,\n ERC20PermitSignature,\n PermitRequest,\n SwapByIntentTypedData,\n TransactionRequest,\n} from '@aave/graphql';\nimport {\n invariant,\n never,\n okAsync,\n ResultAsync,\n signatureFrom,\n txHash,\n} from '@aave/types';\nimport {\n prepareTransaction,\n sendTransaction,\n type ThirdwebClient,\n waitForReceipt,\n} from 'thirdweb';\nimport { useActiveAccount, useSwitchActiveWalletChain } from 'thirdweb/react';\nimport {\n PendingTransaction,\n type UseAsyncTask,\n type UseSendTransactionResult,\n useAsyncTask,\n} from './helpers';\nimport { usePermitTypedDataAction } from './permits';\n\n/**\n * A hook that provides a way to send Aave transactions using a Thirdweb wallet.\n *\n * Import the `useSendTransaction` hook from `@aave/react/thirdweb` entry point.\n */\nexport function useSendTransaction(\n thirdwebClient: ThirdwebClient,\n): UseSendTransactionResult {\n const account = useActiveAccount();\n const switchChain = useSwitchActiveWalletChain();\n\n return useAsyncTask(\n (request: TransactionRequest) => {\n invariant(\n account,\n 'No Account found. Ensure you have connected your wallet.',\n );\n\n const chain =\n supportedChains[request.chainId] ??\n never(`Chain not supported: ${request.chainId}`);\n\n return ResultAsync.fromPromise(switchChain(chain), (err) =>\n UnexpectedError.from(err),\n )\n .andThen(() =>\n ResultAsync.fromPromise(\n sendTransaction({\n account,\n transaction: prepareTransaction({\n to: request.to,\n data: request.data,\n value: BigInt(request.value),\n chain,\n client: thirdwebClient,\n }),\n }),\n (err) => SigningError.from(err),\n ),\n )\n .map(\n ({ transactionHash }) =>\n new PendingTransaction(() =>\n ResultAsync.fromPromise(\n waitForReceipt({\n client: thirdwebClient,\n chain,\n transactionHash,\n }),\n (err) => UnexpectedError.from(err),\n ).andThen(({ status, transactionHash }) => {\n if (status === 'reverted') {\n return TransactionError.new({\n txHash: txHash(transactionHash),\n request,\n }).asResultAsync();\n }\n return okAsync({\n operations: request.operations,\n txHash: txHash(transactionHash),\n });\n }),\n ),\n );\n },\n [account, switchChain, thirdwebClient],\n );\n}\n\nexport type SignERC20PermitError = SigningError | UnexpectedError;\n\n/**\n * A hook that provides a way to sign ERC20 permits using a Thirdweb wallet.\n *\n * ```ts\n * const account = useActiveAccount(); // thirdweb hook\n * const [signERC20Permit, { loading, error, data }] = useERC20Permit();\n *\n * const run = async () => {\n * const result = await signERC20Permit({\n * supply: {\n * sender: evmAddress(account.address), // User's address\n * reserve: {\n * reserveId: reserve.id,\n * chainId: reserve.chain.chainId,\n * spoke: reserve.spoke.address,\n * },\n * amount: {\n * value: bigDecimal(42), // 42 USDC\n * },\n * },\n * });\n *\n * if (result.isErr()) {\n * console.error(result.error);\n * return;\n * }\n *\n * console.log('ERC20 Permit signature:', result.value);\n * };\n * ```\n */\nexport function useERC20Permit(): UseAsyncTask<\n PermitRequest,\n ERC20PermitSignature,\n SignERC20PermitError\n> {\n const [permitTypedData] = usePermitTypedDataAction();\n const account = useActiveAccount();\n\n return useAsyncTask(\n (request: PermitRequest) => {\n invariant(\n account,\n 'No Account found. Ensure you have connected your wallet.',\n );\n\n return permitTypedData(request).andThen((result) =>\n ResultAsync.fromPromise(\n account.signTypedData({\n // silence the rest of the type inference\n types: result.types as Record<string, unknown>,\n domain: result.domain,\n primaryType: result.primaryType,\n message: result.message,\n }),\n (err) => SigningError.from(err),\n ).map((signature) => {\n return {\n deadline: result.message.deadline,\n value: signatureFrom(signature),\n };\n }),\n );\n },\n [account, permitTypedData],\n );\n}\n\nexport type SignSwapTypedDataError = SigningError | UnexpectedError;\n\n/**\n * @internal\n * A hook that provides a way to sign swap typed data using a Thirdweb wallet.\n *\n * ```ts\n * const [signSwapTypedData, { loading, error, data }] = useSignSwapTypedDataWith();\n *\n * const run = async () => {\n * const result = await signSwapTypedData(swapTypedData);\n *\n * if (result.isErr()) {\n * console.error(result.error);\n * return;\n * }\n *\n * console.log('Swap typed data signed:', result.value);\n * };\n * ```\n */\nexport function useSignSwapTypedDataWith(): UseAsyncTask<\n SwapByIntentTypedData | CancelSwapTypedData,\n ERC20PermitSignature,\n SignSwapTypedDataError\n> {\n const account = useActiveAccount();\n\n return useAsyncTask(\n (typedData: SwapByIntentTypedData | CancelSwapTypedData) => {\n invariant(account, 'Expected an active account to sign swap typed data');\n\n const message = JSON.parse(typedData.message);\n\n return ResultAsync.fromPromise(\n account.signTypedData({\n // silence the rest of the type inference\n types: typedData.types as Record<string, unknown>,\n domain: typedData.domain,\n primaryType: typedData.primaryType,\n message,\n }),\n (err) => SigningError.from(err),\n ).map((signature) => ({\n deadline: message.deadline,\n value: signatureFrom(signature),\n }));\n },\n [account],\n );\n}\n"]}
1
+ {"version":3,"sources":["../src/context.tsx","../src/helpers/tasks.ts","../src/helpers/writes.ts","../src/permits.ts","../src/thirdweb.ts"],"names":["AaveContext","React","useAaveClient","client","useContext","invariant","AsyncTaskState","data","error","useAsyncTask","handler","deps","state","setState","useState","loadingRef","useRef","handle","useCallback","input","result","value","PendingTransaction","_PendingTransaction","wait","usePermitTypedDataAction","request","permitTypedData","useSendTransaction","thirdwebClient","account","useActiveAccount","switchChain","useSwitchActiveWalletChain","fetchChain","chain","toThirdwebChain","ResultAsync","err","UnexpectedError","sendTransaction","prepareTransaction","SigningError","transactionHash","waitForReceipt","status","TransactionError","txHash","okAsync","useERC20Permit","signature","signatureFrom","useSignSwapTypedDataWith","typedData","message"],"mappings":"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","file":"thirdweb.cjs","sourcesContent":["import type { AaveClient } from '@aave/client';\nimport { invariant } from '@aave/types';\nimport React, { type ReactNode, useContext } from 'react';\nimport { Provider as UrqlProvider } from 'urql';\n\nconst AaveContext = React.createContext<AaveClient | null>(null);\n\n/**\n * @internal\n */\nexport type AaveContextProviderProps = {\n children: ReactNode;\n client: AaveClient;\n};\n\n/**\n * @internal\n */\nexport function AaveContextProvider({\n children,\n client,\n}: AaveContextProviderProps) {\n return (\n <AaveContext.Provider value={client}>\n <UrqlProvider value={client.urql}>{children}</UrqlProvider>\n </AaveContext.Provider>\n );\n}\n\n/**\n * @internal\n */\nexport function useAaveClient(): AaveClient {\n const client = useContext(AaveContext);\n\n invariant(\n client,\n 'Could not find Aave SDK context, ensure your code is wrapped in a <AaveProvider>',\n );\n\n return client;\n}\n","import { invariant, type ResultAsync } from '@aave/types';\nimport { type DependencyList, useCallback, useRef, useState } from 'react';\n\n/**\n * An async task is a function that can be executed multiple times and that can be in a pending state.\n *\n * @internal\n */\nexport type AsyncTask<TInput, TResult extends ResultAsync<unknown, unknown>> = (\n input: TInput,\n) => TResult;\n\n/**\n * The initial state of a async task.\n */\nexport type AsyncTaskIdle = {\n called: boolean;\n loading: false;\n data: undefined;\n error: undefined;\n};\n\n/**\n * The state of a async task during the loading.\n */\nexport type AsyncTaskLoading<TData> = {\n called: true;\n loading: true;\n data: TData | undefined;\n error: undefined;\n};\n\n/**\n * The state of a async task after a successful call.\n */\nexport type AsyncTaskSuccess<TData> = {\n called: true;\n loading: false;\n data: TData;\n error: undefined;\n};\n\n/**\n * The state of a async task after a failed call.\n */\nexport type AsyncTaskError<TError> = {\n called: true;\n loading: false;\n data: undefined;\n error: TError;\n};\n\n/**\n * The possible statuses of a async task.\n */\nexport type AsyncTaskState<TData, TError> =\n | AsyncTaskIdle\n | AsyncTaskLoading<TData>\n | AsyncTaskSuccess<TData>\n | AsyncTaskError<TError>;\n\nconst AsyncTaskState = {\n Idle: <TData, TError>(): AsyncTaskState<TData, TError> => ({\n called: false,\n loading: false,\n data: undefined,\n error: undefined,\n }),\n Loading: <TData, TError>(data?: TData): AsyncTaskState<TData, TError> => ({\n called: true,\n loading: true,\n data,\n error: undefined,\n }),\n Success: <TData, TError>(data: TData): AsyncTaskState<TData, TError> => ({\n called: true,\n loading: false,\n data,\n error: undefined,\n }),\n Failed: <TData, TError>(error: TError): AsyncTaskState<TData, TError> => ({\n called: true,\n loading: false,\n data: undefined,\n error,\n }),\n};\n\n/**\n * A async task React Hook is a lightweight wrapper for an asynchronous function.\n * It allows tracking of the task's execution status and provides access to the\n * last error that occurred during the task's execution, if any.\n *\n * ```ts\n * const [execute, { called, loading, data, error }]: UseAsyncTask<TData, TError, TInput> = useAnyAsyncTask();\n *\n * if (!called) {\n * // data === undefined\n * // error === undefined\n * return <p>Click the button to execute the task</p>;\n * }\n *\n * if (loading) {\n * // data === undefined on first call\n * // data === TData from previous successful call\n * // error === undefined\n * return <Loader />;\n * }\n *\n * if (error) {\n * // data === undefined\n * // error === TError\n * return <p>Something went wrong: {error.message}</p>;\n * }\n *\n * // called === true\n * // data === TData\n * // error === undefined\n * return <p>Task completed: {data}</p>;\n * ```\n */\nexport type UseAsyncTask<TInput, TValue, TError> = [\n AsyncTask<TInput, ResultAsync<TValue, TError>>,\n AsyncTaskState<TValue, TError>,\n];\n\n/**\n * @internal\n */\nexport function useAsyncTask<\n TInput,\n TValue,\n TError,\n TResult extends ResultAsync<TValue, TError>,\n>(\n handler: AsyncTask<TInput, TResult>,\n deps: DependencyList,\n): UseAsyncTask<TInput, TValue, TError> {\n const [state, setState] = useState(AsyncTaskState.Idle<TValue, TError>());\n const loadingRef = useRef(false);\n // biome-ignore lint/correctness/useExhaustiveDependencies: useAsyncTask is a low-level hook\n const handle = useCallback(handler, deps);\n\n const execute = useCallback(\n (input: TInput) => {\n invariant(\n !loadingRef.current,\n 'Cannot execute a task while another is in progress.',\n );\n\n loadingRef.current = true;\n setState(({ data }) => {\n return {\n called: true,\n loading: true,\n data,\n error: undefined,\n };\n });\n\n const result = handle(input);\n\n result.match(\n (value) => {\n loadingRef.current = false;\n setState(AsyncTaskState.Success(value));\n },\n (error) => {\n loadingRef.current = false;\n setState(AsyncTaskState.Failed(error));\n },\n );\n\n return result;\n },\n [handle],\n );\n\n return [execute, state];\n}\n","import type { TransactionResult } from '@aave/client';\nimport {\n CancelError,\n type SigningError,\n type TimeoutError,\n type TransactionError,\n type UnexpectedError,\n} from '@aave/core';\nimport type {\n Erc20ApprovalRequired,\n PreContractActionRequired,\n TransactionRequest,\n} from '@aave/graphql';\nimport type { ResultAsync } from '@aave/types';\nimport { invariant } from '@aave/types';\nimport type { UseAsyncTask } from './tasks';\n\n/**\n * The errors that could occur in the early stage of sending a transaction.\n */\nexport type SendTransactionError = CancelError | SigningError | UnexpectedError;\n\nexport type CancelOperation = (\n message: string,\n) => ResultAsync<never, CancelError>;\n\n/**\n * @internal\n */\nexport const cancel: CancelOperation = (message: string) =>\n CancelError.from(message).asResultAsync();\n\nexport type TransactionHandlerOptions = {\n cancel: CancelOperation;\n};\n\n/**\n * The errors that could occur in the late stages of a transaction.\n */\nexport type PendingTransactionError =\n | CancelError\n | TimeoutError\n | TransactionError\n | UnexpectedError;\n\nexport class PendingTransaction {\n constructor(\n /**\n * @internal Do NOT rely on this method. It's used internally by the SDK and may be subject to breaking changes.\n */\n public readonly wait: () => ResultAsync<\n TransactionResult,\n PendingTransactionError\n >,\n ) {}\n\n /**\n * @internal\n */\n static ensure<T>(value: T): PendingTransaction & T {\n invariant(\n value instanceof PendingTransaction,\n 'Expected PendingTransaction',\n );\n return value as PendingTransaction & T;\n }\n}\n\nexport type UseSendTransactionResult = UseAsyncTask<\n TransactionRequest,\n PendingTransaction,\n SendTransactionError\n>;\n\n/**\n * The handler for sending Aave transactions.\n */\nexport type TransactionHandler = (\n result:\n | TransactionRequest\n | Erc20ApprovalRequired\n | PreContractActionRequired,\n options: TransactionHandlerOptions,\n) => ResultAsync<PendingTransaction, SendTransactionError>;\n","import type { UnexpectedError } from '@aave/client';\nimport { permitTypedData } from '@aave/client/actions';\nimport type { PermitRequest, PermitTypedDataResponse } from '@aave/graphql';\nimport { useAaveClient } from './context';\nimport { type UseAsyncTask, useAsyncTask } from './helpers';\n\n/**\n * @internal\n */\nexport function usePermitTypedDataAction(): UseAsyncTask<\n PermitRequest,\n PermitTypedDataResponse,\n UnexpectedError\n> {\n const client = useAaveClient();\n\n return useAsyncTask(\n (request: PermitRequest) => permitTypedData(client, request),\n [client],\n );\n}\n","import { SigningError, TransactionError, UnexpectedError } from '@aave/client';\nimport { chain as fetchChain } from '@aave/client/actions';\nimport { toThirdwebChain } from '@aave/client/thirdweb';\nimport type {\n CancelSwapTypedData,\n ERC20PermitSignature,\n PermitRequest,\n SwapByIntentTypedData,\n TransactionRequest,\n} from '@aave/graphql';\nimport {\n invariant,\n okAsync,\n ResultAsync,\n signatureFrom,\n txHash,\n} from '@aave/types';\nimport {\n prepareTransaction,\n sendTransaction,\n type ThirdwebClient,\n waitForReceipt,\n} from 'thirdweb';\nimport { useActiveAccount, useSwitchActiveWalletChain } from 'thirdweb/react';\nimport { useAaveClient } from './context';\nimport {\n PendingTransaction,\n type UseAsyncTask,\n type UseSendTransactionResult,\n useAsyncTask,\n} from './helpers';\nimport { usePermitTypedDataAction } from './permits';\n\n/**\n * A hook that provides a way to send Aave transactions using a Thirdweb wallet.\n *\n * Import the `useSendTransaction` hook from `@aave/react/thirdweb` entry point.\n */\nexport function useSendTransaction(\n thirdwebClient: ThirdwebClient,\n): UseSendTransactionResult {\n const client = useAaveClient();\n const account = useActiveAccount();\n const switchChain = useSwitchActiveWalletChain();\n\n return useAsyncTask(\n (request: TransactionRequest) => {\n invariant(\n account,\n 'No Account found. Ensure you have connected your wallet.',\n );\n\n return fetchChain(\n client,\n { chainId: request.chainId },\n {\n batch: false,\n },\n )\n .map((chain) => {\n invariant(chain, `Chain ${request.chainId} is not supported`);\n\n return toThirdwebChain(chain);\n })\n .andThen((chain) => {\n return ResultAsync.fromPromise(switchChain(chain), (err) =>\n UnexpectedError.from(err),\n )\n .andThen(() =>\n ResultAsync.fromPromise(\n sendTransaction({\n account,\n transaction: prepareTransaction({\n to: request.to,\n data: request.data,\n value: BigInt(request.value),\n chain,\n client: thirdwebClient,\n }),\n }),\n (err) => SigningError.from(err),\n ),\n )\n .map(\n ({ transactionHash }) =>\n new PendingTransaction(() =>\n ResultAsync.fromPromise(\n waitForReceipt({\n client: thirdwebClient,\n chain,\n transactionHash,\n }),\n (err) => UnexpectedError.from(err),\n ).andThen(({ status, transactionHash }) => {\n if (status === 'reverted') {\n return TransactionError.new({\n txHash: txHash(transactionHash),\n request,\n }).asResultAsync();\n }\n return okAsync({\n operations: request.operations,\n txHash: txHash(transactionHash),\n });\n }),\n ),\n );\n });\n },\n [account, client, switchChain, thirdwebClient],\n );\n}\n\nexport type SignERC20PermitError = SigningError | UnexpectedError;\n\n/**\n * A hook that provides a way to sign ERC20 permits using a Thirdweb wallet.\n *\n * ```ts\n * const account = useActiveAccount(); // thirdweb hook\n * const [signERC20Permit, { loading, error, data }] = useERC20Permit();\n *\n * const run = async () => {\n * const result = await signERC20Permit({\n * supply: {\n * sender: evmAddress(account.address), // User's address\n * reserve: {\n * reserveId: reserve.id,\n * chainId: reserve.chain.chainId,\n * spoke: reserve.spoke.address,\n * },\n * amount: {\n * value: bigDecimal(42), // 42 USDC\n * },\n * },\n * });\n *\n * if (result.isErr()) {\n * console.error(result.error);\n * return;\n * }\n *\n * console.log('ERC20 Permit signature:', result.value);\n * };\n * ```\n */\nexport function useERC20Permit(): UseAsyncTask<\n PermitRequest,\n ERC20PermitSignature,\n SignERC20PermitError\n> {\n const [permitTypedData] = usePermitTypedDataAction();\n const account = useActiveAccount();\n\n return useAsyncTask(\n (request: PermitRequest) => {\n invariant(\n account,\n 'No Account found. Ensure you have connected your wallet.',\n );\n\n return permitTypedData(request).andThen((result) =>\n ResultAsync.fromPromise(\n account.signTypedData({\n // silence the rest of the type inference\n types: result.types as Record<string, unknown>,\n domain: result.domain,\n primaryType: result.primaryType,\n message: result.message,\n }),\n (err) => SigningError.from(err),\n ).map((signature) => {\n return {\n deadline: result.message.deadline,\n value: signatureFrom(signature),\n };\n }),\n );\n },\n [account, permitTypedData],\n );\n}\n\nexport type SignSwapTypedDataError = SigningError | UnexpectedError;\n\n/**\n * @internal\n * A hook that provides a way to sign swap typed data using a Thirdweb wallet.\n *\n * ```ts\n * const [signSwapTypedData, { loading, error, data }] = useSignSwapTypedDataWith();\n *\n * const run = async () => {\n * const result = await signSwapTypedData(swapTypedData);\n *\n * if (result.isErr()) {\n * console.error(result.error);\n * return;\n * }\n *\n * console.log('Swap typed data signed:', result.value);\n * };\n * ```\n */\nexport function useSignSwapTypedDataWith(): UseAsyncTask<\n SwapByIntentTypedData | CancelSwapTypedData,\n ERC20PermitSignature,\n SignSwapTypedDataError\n> {\n const account = useActiveAccount();\n\n return useAsyncTask(\n (typedData: SwapByIntentTypedData | CancelSwapTypedData) => {\n invariant(account, 'Expected an active account to sign swap typed data');\n\n const message = JSON.parse(typedData.message);\n\n return ResultAsync.fromPromise(\n account.signTypedData({\n // silence the rest of the type inference\n types: typedData.types as Record<string, unknown>,\n domain: typedData.domain,\n primaryType: typedData.primaryType,\n message,\n }),\n (err) => SigningError.from(err),\n ).map((signature) => ({\n deadline: message.deadline,\n value: signatureFrom(signature),\n }));\n },\n [account],\n );\n}\n"]}
package/dist/thirdweb.js CHANGED
@@ -1,2 +1,2 @@
1
- import {a,c,f}from'./chunk-GTUQRT5Q.js';import {UnexpectedError,SigningError,TransactionError}from'@aave/client';import {supportedChains}from'@aave/client/thirdweb';import {invariant,never,ResultAsync,okAsync,txHash,signatureFrom}from'@aave/types';import {sendTransaction,prepareTransaction,waitForReceipt}from'thirdweb';import {useActiveAccount,useSwitchActiveWalletChain}from'thirdweb/react';function N(r){let n=useActiveAccount(),a$1=useSwitchActiveWalletChain();return a(e=>{invariant(n,"No Account found. Ensure you have connected your wallet.");let t=supportedChains[e.chainId]??never(`Chain not supported: ${e.chainId}`);return ResultAsync.fromPromise(a$1(t),o=>UnexpectedError.from(o)).andThen(()=>ResultAsync.fromPromise(sendTransaction({account:n,transaction:prepareTransaction({to:e.to,data:e.data,value:BigInt(e.value),chain:t,client:r})}),o=>SigningError.from(o))).map(({transactionHash:o})=>new c(()=>ResultAsync.fromPromise(waitForReceipt({client:r,chain:t,transactionHash:o}),p=>UnexpectedError.from(p)).andThen(({status:p,transactionHash:u})=>p==="reverted"?TransactionError.new({txHash:txHash(u),request:e}).asResultAsync():okAsync({operations:e.operations,txHash:txHash(u)}))))},[n,a$1,r])}function F(){let[r]=f(),n=useActiveAccount();return a(a=>(invariant(n,"No Account found. Ensure you have connected your wallet."),r(a).andThen(e=>ResultAsync.fromPromise(n.signTypedData({types:e.types,domain:e.domain,primaryType:e.primaryType,message:e.message}),t=>SigningError.from(t)).map(t=>({deadline:e.message.deadline,value:signatureFrom(t)})))),[n,r])}function H(){let r=useActiveAccount();return a(n=>{invariant(r,"Expected an active account to sign swap typed data");let a=JSON.parse(n.message);return ResultAsync.fromPromise(r.signTypedData({types:n.types,domain:n.domain,primaryType:n.primaryType,message:a}),e=>SigningError.from(e)).map(e=>({deadline:a.deadline,value:signatureFrom(e)}))},[r])}export{F as useERC20Permit,N as useSendTransaction,H as useSignSwapTypedDataWith};//# sourceMappingURL=thirdweb.js.map
1
+ import {e,a,c,f}from'./chunk-GTUQRT5Q.js';import {UnexpectedError,SigningError,TransactionError}from'@aave/client';import {chain}from'@aave/client/actions';import {toThirdwebChain}from'@aave/client/thirdweb';import {invariant,ResultAsync,okAsync,txHash,signatureFrom}from'@aave/types';import {sendTransaction,prepareTransaction,waitForReceipt}from'thirdweb';import {useActiveAccount,useSwitchActiveWalletChain}from'thirdweb/react';function W(t){let n=e(),a$1=useActiveAccount(),e$1=useSwitchActiveWalletChain();return a(r=>(invariant(a$1,"No Account found. Ensure you have connected your wallet."),chain(n,{chainId:r.chainId},{batch:false}).map(o=>(invariant(o,`Chain ${r.chainId} is not supported`),toThirdwebChain(o))).andThen(o=>ResultAsync.fromPromise(e$1(o),i=>UnexpectedError.from(i)).andThen(()=>ResultAsync.fromPromise(sendTransaction({account:a$1,transaction:prepareTransaction({to:r.to,data:r.data,value:BigInt(r.value),chain:o,client:t})}),i=>SigningError.from(i))).map(({transactionHash:i})=>new c(()=>ResultAsync.fromPromise(waitForReceipt({client:t,chain:o,transactionHash:i}),m=>UnexpectedError.from(m)).andThen(({status:m,transactionHash:y})=>m==="reverted"?TransactionError.new({txHash:txHash(y),request:r}).asResultAsync():okAsync({operations:r.operations,txHash:txHash(y)})))))),[a$1,n,e$1,t])}function J(){let[t]=f(),n=useActiveAccount();return a(a=>(invariant(n,"No Account found. Ensure you have connected your wallet."),t(a).andThen(e=>ResultAsync.fromPromise(n.signTypedData({types:e.types,domain:e.domain,primaryType:e.primaryType,message:e.message}),r=>SigningError.from(r)).map(r=>({deadline:e.message.deadline,value:signatureFrom(r)})))),[n,t])}function O(){let t=useActiveAccount();return a(n=>{invariant(t,"Expected an active account to sign swap typed data");let a=JSON.parse(n.message);return ResultAsync.fromPromise(t.signTypedData({types:n.types,domain:n.domain,primaryType:n.primaryType,message:a}),e=>SigningError.from(e)).map(e=>({deadline:a.deadline,value:signatureFrom(e)}))},[t])}export{J as useERC20Permit,W as useSendTransaction,O as useSignSwapTypedDataWith};//# sourceMappingURL=thirdweb.js.map
2
2
  //# sourceMappingURL=thirdweb.js.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/thirdweb.ts"],"names":["useSendTransaction","thirdwebClient","account","useActiveAccount","switchChain","useSwitchActiveWalletChain","useAsyncTask","request","invariant","chain","supportedChains","never","ResultAsync","err","UnexpectedError","sendTransaction","prepareTransaction","SigningError","transactionHash","PendingTransaction","waitForReceipt","status","TransactionError","txHash","okAsync","useERC20Permit","permitTypedData","usePermitTypedDataAction","result","signature","signatureFrom","useSignSwapTypedDataWith","typedData","message"],"mappings":"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","file":"thirdweb.js","sourcesContent":["import { SigningError, TransactionError, UnexpectedError } from '@aave/client';\nimport { supportedChains } from '@aave/client/thirdweb';\nimport type {\n CancelSwapTypedData,\n ERC20PermitSignature,\n PermitRequest,\n SwapByIntentTypedData,\n TransactionRequest,\n} from '@aave/graphql';\nimport {\n invariant,\n never,\n okAsync,\n ResultAsync,\n signatureFrom,\n txHash,\n} from '@aave/types';\nimport {\n prepareTransaction,\n sendTransaction,\n type ThirdwebClient,\n waitForReceipt,\n} from 'thirdweb';\nimport { useActiveAccount, useSwitchActiveWalletChain } from 'thirdweb/react';\nimport {\n PendingTransaction,\n type UseAsyncTask,\n type UseSendTransactionResult,\n useAsyncTask,\n} from './helpers';\nimport { usePermitTypedDataAction } from './permits';\n\n/**\n * A hook that provides a way to send Aave transactions using a Thirdweb wallet.\n *\n * Import the `useSendTransaction` hook from `@aave/react/thirdweb` entry point.\n */\nexport function useSendTransaction(\n thirdwebClient: ThirdwebClient,\n): UseSendTransactionResult {\n const account = useActiveAccount();\n const switchChain = useSwitchActiveWalletChain();\n\n return useAsyncTask(\n (request: TransactionRequest) => {\n invariant(\n account,\n 'No Account found. Ensure you have connected your wallet.',\n );\n\n const chain =\n supportedChains[request.chainId] ??\n never(`Chain not supported: ${request.chainId}`);\n\n return ResultAsync.fromPromise(switchChain(chain), (err) =>\n UnexpectedError.from(err),\n )\n .andThen(() =>\n ResultAsync.fromPromise(\n sendTransaction({\n account,\n transaction: prepareTransaction({\n to: request.to,\n data: request.data,\n value: BigInt(request.value),\n chain,\n client: thirdwebClient,\n }),\n }),\n (err) => SigningError.from(err),\n ),\n )\n .map(\n ({ transactionHash }) =>\n new PendingTransaction(() =>\n ResultAsync.fromPromise(\n waitForReceipt({\n client: thirdwebClient,\n chain,\n transactionHash,\n }),\n (err) => UnexpectedError.from(err),\n ).andThen(({ status, transactionHash }) => {\n if (status === 'reverted') {\n return TransactionError.new({\n txHash: txHash(transactionHash),\n request,\n }).asResultAsync();\n }\n return okAsync({\n operations: request.operations,\n txHash: txHash(transactionHash),\n });\n }),\n ),\n );\n },\n [account, switchChain, thirdwebClient],\n );\n}\n\nexport type SignERC20PermitError = SigningError | UnexpectedError;\n\n/**\n * A hook that provides a way to sign ERC20 permits using a Thirdweb wallet.\n *\n * ```ts\n * const account = useActiveAccount(); // thirdweb hook\n * const [signERC20Permit, { loading, error, data }] = useERC20Permit();\n *\n * const run = async () => {\n * const result = await signERC20Permit({\n * supply: {\n * sender: evmAddress(account.address), // User's address\n * reserve: {\n * reserveId: reserve.id,\n * chainId: reserve.chain.chainId,\n * spoke: reserve.spoke.address,\n * },\n * amount: {\n * value: bigDecimal(42), // 42 USDC\n * },\n * },\n * });\n *\n * if (result.isErr()) {\n * console.error(result.error);\n * return;\n * }\n *\n * console.log('ERC20 Permit signature:', result.value);\n * };\n * ```\n */\nexport function useERC20Permit(): UseAsyncTask<\n PermitRequest,\n ERC20PermitSignature,\n SignERC20PermitError\n> {\n const [permitTypedData] = usePermitTypedDataAction();\n const account = useActiveAccount();\n\n return useAsyncTask(\n (request: PermitRequest) => {\n invariant(\n account,\n 'No Account found. Ensure you have connected your wallet.',\n );\n\n return permitTypedData(request).andThen((result) =>\n ResultAsync.fromPromise(\n account.signTypedData({\n // silence the rest of the type inference\n types: result.types as Record<string, unknown>,\n domain: result.domain,\n primaryType: result.primaryType,\n message: result.message,\n }),\n (err) => SigningError.from(err),\n ).map((signature) => {\n return {\n deadline: result.message.deadline,\n value: signatureFrom(signature),\n };\n }),\n );\n },\n [account, permitTypedData],\n );\n}\n\nexport type SignSwapTypedDataError = SigningError | UnexpectedError;\n\n/**\n * @internal\n * A hook that provides a way to sign swap typed data using a Thirdweb wallet.\n *\n * ```ts\n * const [signSwapTypedData, { loading, error, data }] = useSignSwapTypedDataWith();\n *\n * const run = async () => {\n * const result = await signSwapTypedData(swapTypedData);\n *\n * if (result.isErr()) {\n * console.error(result.error);\n * return;\n * }\n *\n * console.log('Swap typed data signed:', result.value);\n * };\n * ```\n */\nexport function useSignSwapTypedDataWith(): UseAsyncTask<\n SwapByIntentTypedData | CancelSwapTypedData,\n ERC20PermitSignature,\n SignSwapTypedDataError\n> {\n const account = useActiveAccount();\n\n return useAsyncTask(\n (typedData: SwapByIntentTypedData | CancelSwapTypedData) => {\n invariant(account, 'Expected an active account to sign swap typed data');\n\n const message = JSON.parse(typedData.message);\n\n return ResultAsync.fromPromise(\n account.signTypedData({\n // silence the rest of the type inference\n types: typedData.types as Record<string, unknown>,\n domain: typedData.domain,\n primaryType: typedData.primaryType,\n message,\n }),\n (err) => SigningError.from(err),\n ).map((signature) => ({\n deadline: message.deadline,\n value: signatureFrom(signature),\n }));\n },\n [account],\n );\n}\n"]}
1
+ {"version":3,"sources":["../src/thirdweb.ts"],"names":["useSendTransaction","thirdwebClient","client","useAaveClient","account","useActiveAccount","switchChain","useSwitchActiveWalletChain","useAsyncTask","request","invariant","fetchChain","chain","toThirdwebChain","ResultAsync","err","UnexpectedError","sendTransaction","prepareTransaction","SigningError","transactionHash","PendingTransaction","waitForReceipt","status","TransactionError","txHash","okAsync","useERC20Permit","permitTypedData","usePermitTypedDataAction","result","signature","signatureFrom","useSignSwapTypedDataWith","typedData","message"],"mappings":"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","file":"thirdweb.js","sourcesContent":["import { SigningError, TransactionError, UnexpectedError } from '@aave/client';\nimport { chain as fetchChain } from '@aave/client/actions';\nimport { toThirdwebChain } from '@aave/client/thirdweb';\nimport type {\n CancelSwapTypedData,\n ERC20PermitSignature,\n PermitRequest,\n SwapByIntentTypedData,\n TransactionRequest,\n} from '@aave/graphql';\nimport {\n invariant,\n okAsync,\n ResultAsync,\n signatureFrom,\n txHash,\n} from '@aave/types';\nimport {\n prepareTransaction,\n sendTransaction,\n type ThirdwebClient,\n waitForReceipt,\n} from 'thirdweb';\nimport { useActiveAccount, useSwitchActiveWalletChain } from 'thirdweb/react';\nimport { useAaveClient } from './context';\nimport {\n PendingTransaction,\n type UseAsyncTask,\n type UseSendTransactionResult,\n useAsyncTask,\n} from './helpers';\nimport { usePermitTypedDataAction } from './permits';\n\n/**\n * A hook that provides a way to send Aave transactions using a Thirdweb wallet.\n *\n * Import the `useSendTransaction` hook from `@aave/react/thirdweb` entry point.\n */\nexport function useSendTransaction(\n thirdwebClient: ThirdwebClient,\n): UseSendTransactionResult {\n const client = useAaveClient();\n const account = useActiveAccount();\n const switchChain = useSwitchActiveWalletChain();\n\n return useAsyncTask(\n (request: TransactionRequest) => {\n invariant(\n account,\n 'No Account found. Ensure you have connected your wallet.',\n );\n\n return fetchChain(\n client,\n { chainId: request.chainId },\n {\n batch: false,\n },\n )\n .map((chain) => {\n invariant(chain, `Chain ${request.chainId} is not supported`);\n\n return toThirdwebChain(chain);\n })\n .andThen((chain) => {\n return ResultAsync.fromPromise(switchChain(chain), (err) =>\n UnexpectedError.from(err),\n )\n .andThen(() =>\n ResultAsync.fromPromise(\n sendTransaction({\n account,\n transaction: prepareTransaction({\n to: request.to,\n data: request.data,\n value: BigInt(request.value),\n chain,\n client: thirdwebClient,\n }),\n }),\n (err) => SigningError.from(err),\n ),\n )\n .map(\n ({ transactionHash }) =>\n new PendingTransaction(() =>\n ResultAsync.fromPromise(\n waitForReceipt({\n client: thirdwebClient,\n chain,\n transactionHash,\n }),\n (err) => UnexpectedError.from(err),\n ).andThen(({ status, transactionHash }) => {\n if (status === 'reverted') {\n return TransactionError.new({\n txHash: txHash(transactionHash),\n request,\n }).asResultAsync();\n }\n return okAsync({\n operations: request.operations,\n txHash: txHash(transactionHash),\n });\n }),\n ),\n );\n });\n },\n [account, client, switchChain, thirdwebClient],\n );\n}\n\nexport type SignERC20PermitError = SigningError | UnexpectedError;\n\n/**\n * A hook that provides a way to sign ERC20 permits using a Thirdweb wallet.\n *\n * ```ts\n * const account = useActiveAccount(); // thirdweb hook\n * const [signERC20Permit, { loading, error, data }] = useERC20Permit();\n *\n * const run = async () => {\n * const result = await signERC20Permit({\n * supply: {\n * sender: evmAddress(account.address), // User's address\n * reserve: {\n * reserveId: reserve.id,\n * chainId: reserve.chain.chainId,\n * spoke: reserve.spoke.address,\n * },\n * amount: {\n * value: bigDecimal(42), // 42 USDC\n * },\n * },\n * });\n *\n * if (result.isErr()) {\n * console.error(result.error);\n * return;\n * }\n *\n * console.log('ERC20 Permit signature:', result.value);\n * };\n * ```\n */\nexport function useERC20Permit(): UseAsyncTask<\n PermitRequest,\n ERC20PermitSignature,\n SignERC20PermitError\n> {\n const [permitTypedData] = usePermitTypedDataAction();\n const account = useActiveAccount();\n\n return useAsyncTask(\n (request: PermitRequest) => {\n invariant(\n account,\n 'No Account found. Ensure you have connected your wallet.',\n );\n\n return permitTypedData(request).andThen((result) =>\n ResultAsync.fromPromise(\n account.signTypedData({\n // silence the rest of the type inference\n types: result.types as Record<string, unknown>,\n domain: result.domain,\n primaryType: result.primaryType,\n message: result.message,\n }),\n (err) => SigningError.from(err),\n ).map((signature) => {\n return {\n deadline: result.message.deadline,\n value: signatureFrom(signature),\n };\n }),\n );\n },\n [account, permitTypedData],\n );\n}\n\nexport type SignSwapTypedDataError = SigningError | UnexpectedError;\n\n/**\n * @internal\n * A hook that provides a way to sign swap typed data using a Thirdweb wallet.\n *\n * ```ts\n * const [signSwapTypedData, { loading, error, data }] = useSignSwapTypedDataWith();\n *\n * const run = async () => {\n * const result = await signSwapTypedData(swapTypedData);\n *\n * if (result.isErr()) {\n * console.error(result.error);\n * return;\n * }\n *\n * console.log('Swap typed data signed:', result.value);\n * };\n * ```\n */\nexport function useSignSwapTypedDataWith(): UseAsyncTask<\n SwapByIntentTypedData | CancelSwapTypedData,\n ERC20PermitSignature,\n SignSwapTypedDataError\n> {\n const account = useActiveAccount();\n\n return useAsyncTask(\n (typedData: SwapByIntentTypedData | CancelSwapTypedData) => {\n invariant(account, 'Expected an active account to sign swap typed data');\n\n const message = JSON.parse(typedData.message);\n\n return ResultAsync.fromPromise(\n account.signTypedData({\n // silence the rest of the type inference\n types: typedData.types as Record<string, unknown>,\n domain: typedData.domain,\n primaryType: typedData.primaryType,\n message,\n }),\n (err) => SigningError.from(err),\n ).map((signature) => ({\n deadline: message.deadline,\n value: signatureFrom(signature),\n }));\n },\n [account],\n );\n}\n"]}
@@ -1,2 +1,2 @@
1
- 'use strict';var viem=require('@aave/client/viem'),types=require('@aave/types'),V=require('react'),urql=require('urql'),client=require('@aave/client');require('@aave/core');var actions=require('@aave/client/actions'),graphql=require('@aave/graphql'),viem$1=require('viem');function _interopDefault(e){return e&&e.__esModule?e:{default:e}}var V__default=/*#__PURE__*/_interopDefault(V);var Q=V__default.default.createContext(null);function l(){let e=V.useContext(Q);return types.invariant(e,"Could not find Aave SDK context, ensure your code is wrapped in a <AaveProvider>"),e}var u={Loading:()=>({data:void 0,error:void 0,loading:true,paused:false}),Success:e=>({data:e,error:void 0,loading:false,paused:false}),Failure:e=>({data:void 0,error:e,loading:false,paused:false}),Paused:(e,t)=>({data:e,error:t,loading:false,paused:true})};function h({document:e,variables:t,suspense:r,pause:a,selector:n=types.identity,pollInterval:s=0,batch:o=true}){let[x,c]=V.useState(true),[{fetching:i,data:y,error:f},A]=urql.useQuery({query:e,variables:t,pause:a,context:V.useMemo(()=>({batch:o,suspense:r}),[o,r])});if(V.useEffect(()=>{a||i||c(false);},[i,a]),V.useEffect(()=>{if(s<=0||i||a)return;let m=setTimeout(()=>{A({requestPolicy:"network-only",batch:false});},s);return ()=>clearTimeout(m)},[i,A,s,a]),a)return u.Paused(y?n(y.value):void 0,f?client.UnexpectedError.from(f):void 0);if(!r&&x)return u.Loading();if(f){let m=client.UnexpectedError.from(f);if(r)throw m;return u.Failure(m)}return types.invariant(y,"No data returned"),u.Success(n(y.value))}var R={Idle:()=>({called:false,loading:false,data:void 0,error:void 0}),Loading:e=>({called:true,loading:true,data:e,error:void 0}),Success:e=>({called:true,loading:false,data:e,error:void 0}),Failed:e=>({called:true,loading:false,data:void 0,error:e})};function p(e,t){let[r,a]=V.useState(R.Idle()),n=V.useRef(false),s=V.useCallback(e,t);return [V.useCallback(x=>{types.invariant(!n.current,"Cannot execute a task while another is in progress."),n.current=true,a(({data:i})=>({called:true,loading:true,data:i,error:void 0}));let c=s(x);return c.match(i=>{n.current=false,a(R.Success(i));},i=>{n.current=false,a(R.Failed(i));}),c},[s]),r]}var T=class e{constructor(t){this.wait=t;}static ensure(t){return types.invariant(t instanceof e,"Expected PendingTransaction"),t}};function P(){let e=l();return p(t=>actions.permitTypedData(e,t),[e])}function Me(e){let t=l();return p(r=>(types.invariant(e,"Expected a WalletClient to handle the operation result."),viem.ensureChain(t,e,r).andThen(()=>viem.sendTransaction(e,r)).map(a=>new T(()=>viem.waitForTransactionResult(e,r,a)))),[t,e])}function je(e){let[t]=P();return p(r=>(types.invariant(e,"Expected a WalletClient to sign ERC20 permits"),t(r).andThen(viem.signERC20PermitWith(e))),[t,e])}function Ke(e){return p(t=>(types.invariant(e,"Expected a WalletClient to sign swap typed data"),viem.signSwapTypedDataWith(e)(t)),[e])}function U({suspense:e=false,pause:t=false,...r}){let a=l();return h({document:graphql.ExchangeRateQuery,variables:{request:r},suspense:e,pause:t,pollInterval:r.at?0:a.context.environment.exchangeRateInterval})}var k=55558n,pe={supply:132136n+k,borrow:250551n,withdraw:195049n,repay:217889n+k,setUserSupplyAsCollateral:240284n};function de(e){let t=Object.keys(e)[0];return pe[t]??types.never(`Expected gas estimate for action ${t}`)}function ce(e){return "supply"in e?e.supply.reserve:"borrow"in e?e.borrow.reserve:"withdraw"in e?e.withdraw.reserve:"repay"in e?e.repay.reserve:"setUserSupplyAsCollateral"in e?e.setUserSupplyAsCollateral.reserve:types.never("Expected reserve id")}function N(e){let t=ce(e);return graphql.decodeReserveId(t).chainId}function ye(e){if("activity"in e&&e.activity)return e.activity.chain.chainId;if("estimate"in e&&e.estimate)return N(e.estimate)}function fe(e){if("activity"in e&&e.activity)return e.activity.timestamp}function me(e,t){return "activity"in t&&t.activity?types.okAsync(t.activity.chain):"estimate"in t&&t.estimate?actions.chain(e,{chainId:N(t.estimate)}).map(types.nonNullable):types.never("Expected chain")}function Te(){let e=l();return p(t=>me(e,t).andThen(r=>{let a=viem$1.createPublicClient({chain:viem.toViemChain(r),transport:viem$1.http()});return "activity"in t?types.ResultAsync.fromPromise(a.getTransactionReceipt({hash:t.activity.txHash}),n=>client.UnexpectedError.from(n)).map(n=>({chain:t.activity.chain,gasPrice:n.effectiveGasPrice,gasUnits:n.gasUsed})):"estimate"in t&&t.estimate?types.ResultAsync.fromPromise(a.estimateFeesPerGas(),n=>client.UnexpectedError.from(n)).map(({maxFeePerGas:n})=>({chain:r,gasPrice:n,gasUnits:de(t.estimate)})):types.okAsync({chain:types.never("Expected chain"),gasPrice:0n,gasUnits:0n})}),[e])}function D(e,t){let r=e.gasPrice*e.gasUnits,a=types.bigDecimal(r).rescale(-e.chain.nativeInfo.decimals),n={__typename:"DecimalNumber",decimals:e.chain.nativeInfo.decimals,onChainValue:r,value:a};return {__typename:"NativeAmount",token:{__typename:"NativeToken",info:e.chain.nativeInfo,chain:e.chain},amount:n,fiatAmount:{__typename:"FiatAmount",value:a.mul(t.value),name:t.name,symbol:t.symbol},fiatRate:{__typename:"DecimalNumber",decimals:2,onChainValue:BigInt(t.value.rescale(2).toFixed(0,types.RoundingMode.Down)),value:t.value}}}var ft=({query:e,currency:t=graphql.Currency.Usd,pause:r=false,suspense:a=false})=>{let[n,s]=Te(),o=U({from:{native:ye(e)},to:t,at:fe(e),pause:r,...a?{suspense:a}:{}});return V.useEffect(()=>{r||s.called||!e||n(e);},[n,r,s.called]),o.paused?u.Paused(s.data&&o.data?D(s.data,o.data):void 0,o.error?o.error:void 0):!s.called||s.loading||o.loading?u.Loading():s.error||o.error?u.Failure(s.error??o.error??types.never("Unknown error")):(types.invariant(s.data&&o.data,"Expected receipt, chain, and rate data"),u.Success(D(s.data,o.data)))};Object.defineProperty(exports,"viemChainsFrom",{enumerable:true,get:function(){return viem.viemChainsFrom}});exports.useERC20Permit=je;exports.useNetworkFee=ft;exports.useSendTransaction=Me;exports.useSignSwapTypedDataWith=Ke;//# sourceMappingURL=index.cjs.map
1
+ 'use strict';var viem=require('@aave/client/viem'),types=require('@aave/types'),Q=require('react'),urql=require('urql'),client=require('@aave/client');require('@aave/core');var actions=require('@aave/client/actions'),graphql=require('@aave/graphql'),viem$1=require('viem');function _interopDefault(e){return e&&e.__esModule?e:{default:e}}var Q__default=/*#__PURE__*/_interopDefault(Q);var q=Q__default.default.createContext(null);function l(){let e=Q.useContext(q);return types.invariant(e,"Could not find Aave SDK context, ensure your code is wrapped in a <AaveProvider>"),e}var u={Loading:()=>({data:void 0,error:void 0,loading:true,paused:false}),Success:e=>({data:e,error:void 0,loading:false,paused:false}),Failure:e=>({data:void 0,error:e,loading:false,paused:false}),Paused:(e,t)=>({data:e,error:t,loading:false,paused:true})};function v({document:e,variables:t,suspense:a,pause:r,selector:n=types.identity,pollInterval:s=0,batch:o=true}){let[g,m]=Q.useState(true),[{fetching:i,data:y,error:f},h]=urql.useQuery({query:e,variables:t,pause:r,context:Q.useMemo(()=>({batch:o,suspense:a}),[o,a])});if(Q.useEffect(()=>{r||i||m(false);},[i,r]),Q.useEffect(()=>{if(s<=0||i||r)return;let x=setTimeout(()=>{h({requestPolicy:"network-only",batch:false});},s);return ()=>clearTimeout(x)},[i,h,s,r]),r)return u.Paused(y?n(y.value):void 0,f?client.UnexpectedError.from(f):void 0);if(!a&&g)return u.Loading();if(f){let x=client.UnexpectedError.from(f);if(a)throw x;return u.Failure(x)}return types.invariant(y,"No data returned"),u.Success(n(y.value))}var R={Idle:()=>({called:false,loading:false,data:void 0,error:void 0}),Loading:e=>({called:true,loading:true,data:e,error:void 0}),Success:e=>({called:true,loading:false,data:e,error:void 0}),Failed:e=>({called:true,loading:false,data:void 0,error:e})};function p(e,t){let[a,r]=Q.useState(R.Idle()),n=Q.useRef(false),s=Q.useCallback(e,t);return [Q.useCallback(g=>{types.invariant(!n.current,"Cannot execute a task while another is in progress."),n.current=true,r(({data:i})=>({called:true,loading:true,data:i,error:void 0}));let m=s(g);return m.match(i=>{n.current=false,r(R.Success(i));},i=>{n.current=false,r(R.Failed(i));}),m},[s]),a]}var T=class e{constructor(t){this.wait=t;}static ensure(t){return types.invariant(t instanceof e,"Expected PendingTransaction"),t}};function U(){let e=l();return p(t=>actions.permitTypedData(e,t),[e])}function He(e){let t=l();return p(a=>(types.invariant(e,"Expected a WalletClient to handle the operation result."),viem.ensureChain(t,e,a).andThen(()=>viem.sendTransaction(e,a)).map(r=>new T(()=>viem.waitForTransactionResult(e,a,r)))),[t,e])}function Me(e){let[t]=U();return p(a=>(types.invariant(e,"Expected a WalletClient to sign ERC20 permits"),t(a).andThen(viem.signERC20PermitWith(e))),[t,e])}function je(e){return p(t=>(types.invariant(e,"Expected a WalletClient to sign swap typed data"),viem.signSwapTypedDataWith(e)(t)),[e])}function C({suspense:e=false,pause:t=false,...a}){let r=l();return v({document:graphql.ExchangeRateQuery,variables:{request:a},suspense:e,pause:t,pollInterval:a.at?0:r.context.environment.exchangeRateInterval})}var D=55558n,pe={supply:132136n+D,borrow:250551n,withdraw:195049n,repay:217889n+D,setUserSuppliesAsCollateral:240284n};function de(e){let t=Object.keys(e)[0];return pe[t]??types.never(`Expected gas estimate for action ${t}`)}function I(e){if("supply"in e)return graphql.decodeReserveId(e.supply.reserve).chainId;if("borrow"in e)return graphql.decodeReserveId(e.borrow.reserve).chainId;if("withdraw"in e)return graphql.decodeReserveId(e.withdraw.reserve).chainId;if("repay"in e)return graphql.decodeReserveId(e.repay.reserve).chainId;if("setUserSuppliesAsCollateral"in e)return e.setUserSuppliesAsCollateral.changes.map(({reserve:t})=>graphql.decodeReserveId(t)).reduce((t,a)=>(types.invariant(t.chainId===a.chainId&&t.spoke===a.spoke,"All reserves MUST on the same spoke"),t)).chainId;types.never("Expected reserve id");}function ce(e){if("activity"in e&&e.activity)return e.activity.chain.chainId;if("estimate"in e&&e.estimate)return I(e.estimate)}function me(e){if("activity"in e&&e.activity)return e.activity.timestamp}function ye(e,t){return "activity"in t&&t.activity?types.okAsync(t.activity.chain):"estimate"in t&&t.estimate?actions.chain(e,{chainId:I(t.estimate)}).map(types.nonNullable):types.never("Expected chain")}function fe(){let e=l();return p(t=>ye(e,t).andThen(a=>{let r=viem$1.createPublicClient({chain:viem.toViemChain(a),transport:viem$1.http()});return "activity"in t?types.ResultAsync.fromPromise(r.getTransactionReceipt({hash:t.activity.txHash}),n=>client.UnexpectedError.from(n)).map(n=>({chain:t.activity.chain,gasPrice:n.effectiveGasPrice,gasUnits:n.gasUsed})):"estimate"in t&&t.estimate?types.ResultAsync.fromPromise(r.estimateFeesPerGas(),n=>client.UnexpectedError.from(n)).map(({maxFeePerGas:n})=>({chain:a,gasPrice:n,gasUnits:de(t.estimate)})):types.okAsync({chain:types.never("Expected chain"),gasPrice:0n,gasUnits:0n})}),[e])}function w(e,t){let a=e.gasPrice*e.gasUnits,r=types.bigDecimal(a).rescale(-e.chain.nativeInfo.decimals),n={__typename:"DecimalNumber",decimals:e.chain.nativeInfo.decimals,onChainValue:a,value:r};return {__typename:"NativeAmount",token:{__typename:"NativeToken",info:e.chain.nativeInfo,chain:e.chain},amount:n,exchange:{__typename:"ExchangeAmount",value:r.mul(t.value),name:t.name,symbol:t.symbol,icon:t.icon,decimals:t.decimals},exchangeRate:{__typename:"DecimalNumber",decimals:2,onChainValue:BigInt(t.value.rescale(2).toFixed(0,types.RoundingMode.Down)),value:t.value}}}var mt=(({query:e,currency:t=graphql.Currency.Usd,pause:a=false,suspense:r=false})=>{let[n,s]=fe(),o=C({from:{native:ce(e)},to:t,at:me(e),pause:a,...r?{suspense:r}:{}});return Q.useEffect(()=>{a||s.called||!e||n(e);},[n,a,s.called]),o.paused?u.Paused(s.data&&o.data?w(s.data,o.data):void 0,o.error?o.error:void 0):!s.called||s.loading||o.loading?u.Loading():s.error||o.error?u.Failure(s.error??o.error??types.never("Unknown error")):(types.invariant(s.data&&o.data,"Expected receipt, chain, and rate data"),u.Success(w(s.data,o.data)))});Object.defineProperty(exports,"viemChainsFrom",{enumerable:true,get:function(){return viem.viemChainsFrom}});exports.useERC20Permit=Me;exports.useNetworkFee=mt;exports.useSendTransaction=He;exports.useSignSwapTypedDataWith=je;//# sourceMappingURL=index.cjs.map
2
2
  //# sourceMappingURL=index.cjs.map