@aave/react 4.0.0-next.48 → 4.0.0-next.49
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/dist/chunk-V6Q6TCNV.js +2 -0
- package/dist/chunk-V6Q6TCNV.js.map +1 -0
- package/dist/index.cjs +1 -1
- package/dist/index.cjs.map +1 -1
- package/dist/index.js +1 -1
- package/dist/index.js.map +1 -1
- package/dist/privy.js +1 -1
- package/dist/viem/index.cjs +1 -1
- package/dist/viem/index.cjs.map +1 -1
- package/dist/viem/index.js +1 -1
- package/package.json +6 -6
- package/dist/chunk-IHI6MHZW.js +0 -2
- package/dist/chunk-IHI6MHZW.js.map +0 -1
package/dist/privy.js
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
import {d}from'./chunk-
|
|
1
|
+
import {d}from'./chunk-V6Q6TCNV.js';import'./chunk-4NA4FB6K.js';import {a,c}from'./chunk-4LHXPD6N.js';import {UnexpectedError,CancelError,SigningError}from'@aave/client';import {toViemChain,sendTransaction,waitForTransactionResult}from'@aave/client/viem';import {invariant,ResultAsync,signatureFrom}from'@aave/types';import {useWallets,useSignTypedData}from'@privy-io/react-auth';import {createWalletClient,custom}from'viem';function E(n){if(n&&typeof n=="object"){if("code"in n&&n.code===4001)return true;if("message"in n&&typeof n.message=="string"){let t=n.message.toLowerCase();return t.includes("user rejected")||t.includes("user denied")||t.includes("rejected the request")}}return false}function x(){let{wallets:n}=useWallets(),[t]=d();return a(e=>{let r=n.find(a=>a.address===e.from);return invariant(r,`Expected a connected wallet with address ${e.from} to be found.`),t({chainId:e.chainId}).map(a=>(invariant(a,`Chain ${e.chainId} is not supported`),toViemChain(a))).andThen(a=>ResultAsync.fromPromise(r.switchChain(e.chainId),s=>UnexpectedError.from(s)).map(()=>r.getEthereumProvider()).map(s=>createWalletClient({account:e.from,chain:a,transport:custom(s)})).andThen(s=>sendTransaction(s,e).map(d=>new c(()=>waitForTransactionResult(s,e,d)))))},[n,t])}function I(){let{signTypedData:n}=useSignTypedData();return a(t=>ResultAsync.fromPromise(n({domain:t.domain,types:t.types,primaryType:t.primaryType,message:t.message}),e=>E(e)?CancelError.from(e):SigningError.from(e)).map(({signature:e})=>signatureFrom(e)),[n])}export{x as useSendTransaction,I as useSignTypedData};//# sourceMappingURL=privy.js.map
|
|
2
2
|
//# sourceMappingURL=privy.js.map
|
package/dist/viem/index.cjs
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
'use strict';var viem=require('@aave/client/viem'),types=require('@aave/types')
|
|
1
|
+
'use strict';var viem=require('@aave/client/viem'),types=require('@aave/types'),j=require('react'),urql=require('urql'),client=require('@aave/client'),core=require('@aave/core'),actions=require('@aave/client/actions'),graphql=require('@aave/graphql'),viem$1=require('viem');function _interopDefault(e){return e&&e.__esModule?e:{default:e}}var j__default=/*#__PURE__*/_interopDefault(j);var z=j__default.default.createContext(null);function m(){let e=j.useContext(z);return types.invariant(e,"Could not find Aave SDK context, ensure your code is wrapped in a <AaveProvider>"),e}var l={Loading:e=>({data:void 0,error:void 0,loading:true,paused:false,reloading:false,metadata:e}),Success:(e,t,a=false)=>({data:e,error:void 0,loading:false,paused:false,reloading:a,metadata:t}),Failure:(e,t,a=false)=>({data:void 0,error:e,loading:false,paused:false,reloading:a,metadata:t}),Paused:(e,t,a)=>({data:e,error:t,loading:false,paused:true,reloading:false,metadata:a})};function N({document:e,variables:t,suspense:a,pause:r,selector:n=types.ok,pollInterval:s=0,batch:o=true}){let[i,T]=j.useState({operationKey:0,resultOperationKey:void 0}),[f,c]=j.useState(true),y=j.useMemo(()=>urql.createRequest(e,t).key,[e,t]),[{fetching:d,data:p,error:h,stale:S},P]=urql.useQuery({query:e,variables:t,pause:r,context:j.useMemo(()=>({batch:o,suspense:a}),[o,a])});if(j.useEffect(()=>{T(u=>({...u,operationKey:y}));},[y]),j.useEffect(()=>{r||d||c(false);},[d,r]),j.useEffect(()=>{r||d||T(u=>({...u,resultOperationKey:p&&!S?u.operationKey:u.resultOperationKey}));},[r,d,p,S]),j.useEffect(()=>{if(s<=0||d||r)return;let u=setTimeout(()=>{P({requestPolicy:"network-only",batch:false});},s);return ()=>clearTimeout(u)},[d,P,s,r]),r){let u=h?client.UnexpectedError.from(h):void 0;if(!p)return l.Paused(void 0,u,i);let U=n(p.value);return U.isErr()?l.Paused(void 0,U.error,i):l.Paused(U.value,u,i)}if(!a&&f)return l.Loading(i);let v=S||!f&&d;if(h){let u=client.UnexpectedError.from(h);if(a)throw u;return l.Failure(u,i,v)}types.invariant(p!==void 0,`Unexpected empty response from the API for '${core.extractDocumentName(e)??"unknown"}' query`);let G=p===null?null:p.value,E=n(G);if(E.isErr()){if(a)throw E.error;return l.Failure(E.error,i,v)}return l.Success(E.value,i,v)}var C={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 g(e,t){let[a,r]=j.useState(C.Idle()),n=j.useRef(false),s=j.useRef(true);j.useEffect(()=>()=>{s.current=false;},[]);let o=j.useCallback(e,t);return [j.useCallback(T=>{types.invariant(s.current,"Cannot execute a task on an unmounted component."),types.invariant(!n.current,"Cannot execute a task while another is in progress."),n.current=true;let f;r(c=>(f=c,{called:true,loading:true,data:c.data,error:void 0}));try{let c=o(T);return c.match(y=>{n.current=!1,r(C.Success(y));},y=>{n.current=!1,r(C.Failed(y));}),c}catch(c){throw n.current=false,f&&r(f),c}},[o]),a]}var A=class e{constructor(t){this.wait=t;}static isInstanceOf(t){return t instanceof e}static tryFrom(t){return e.isInstanceOf(t)?types.okAsync(t):core.UnexpectedError.from(t).asResultAsync()}};function Xe(e){let t=m();return g(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 A(()=>viem.waitForTransactionResult(e,a,r)))),[t,e])}function Ye(e){return g(t=>(types.invariant(e,"Expected a WalletClient to sign typed data"),viem.signTypedDataWith(e,t)),[e])}function M({suspense:e=false,pause:t=false,...a}){let r=m();return N({document:graphql.ExchangeRateQuery,variables:{request:a},suspense:e,pause:t,pollInterval:a.at?0:r.context.environment.exchangeRateInterval})}var q=55558n,he={supply:132136n+q,borrow:250551n,withdraw:195049n,repay:217889n+q,setUserSuppliesAsCollateral:240284n,updateUserPositionConditions:280000n};function Ee(e){let t=Object.keys(e)[0];return he[t]??types.never(`Expected gas estimate for action ${t}`)}function H(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;if("updateUserPositionConditions"in e)return graphql.decodeUserPositionId(e.updateUserPositionConditions.userPositionId).chainId;types.never("Expected reserve id");}function be(e){if("activity"in e&&e.activity)return e.activity.chain.chainId;if("estimate"in e&&e.estimate)return H(e.estimate)}function Ae(e){if("activity"in e&&e.activity)return e.activity.timestamp}function Se(e,t){return "activity"in t&&t.activity?types.okAsync(t.activity.chain):"estimate"in t&&t.estimate?actions.chain(e,{chainId:H(t.estimate)}).map(types.nonNullable):types.never("Expected chain")}function ve(){let e=m();return g(t=>Se(e,t).andThen(a=>{let r=viem$1.createPublicClient({chain:viem.toViemChain(a),transport:viem$1.http()});return "activity"in t&&t.activity.txHash?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:Ee(t.estimate)})):types.okAsync({chain:types.never("Expected chain"),gasPrice:0n,gasUnits:0n})}),[e])}function L(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 ht=(({query:e,currency:t=graphql.Currency.Usd,pause:a=false,suspense:r=false})=>{let[n,s]=ve(),o=M({from:{native:be(e)},to:t,at:Ae(e),pause:a,...r?{suspense:r}:{}}),i=o.metadata;return j.useEffect(()=>{a||s.called||!e||n(e);},[n,a,s.called]),o.paused?l.Paused(s.data&&o.data?L(s.data,o.data):void 0,o.error?o.error:void 0,i):!s.called||s.loading||o.loading?l.Loading(i):s.error||o.error?l.Failure(s.error??o.error??types.never("Unknown error"),i):(types.invariant(s.data&&o.data,"Expected receipt, chain, and rate data"),l.Success(L(s.data,o.data),i))});Object.defineProperty(exports,"viemChainsFrom",{enumerable:true,get:function(){return viem.viemChainsFrom}});exports.useNetworkFee=ht;exports.useSendTransaction=Xe;exports.useSignTypedData=Ye;//# sourceMappingURL=index.cjs.map
|
|
2
2
|
//# sourceMappingURL=index.cjs.map
|
package/dist/viem/index.cjs.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../src/context.tsx","../../src/helpers/results.ts","../../src/helpers/reads.ts","../../src/helpers/tasks.ts","../../src/helpers/writes.ts","../../src/viem/adapters.ts","../../src/misc.ts","../../src/viem/useNetworkFee.ts"],"names":["AaveContext","React","useAaveClient","client","useContext","invariant","ReadResult","metadata","data","reloading","error","useSuspendableQuery","document","variables","suspense","pause","selector","ok","pollInterval","batch","setMetadata","useState","loading","setLoading","operationId","useMemo","createRequest","fetching","stale","executeQuery","useQuery","useEffect","current","timerId","unexpectedError","UnexpectedError","selected","unexpected","AsyncTaskState","useAsyncTask","handler","deps","state","setState","loadingRef","useRef","mountedRef","handle","useCallback","input","previousState","result","value","PendingTransaction","_PendingTransaction","wait","okAsync","useSendTransaction","walletClient","request","ensureChain","sendTransaction","hash","waitForTransactionResult","useSignTypedData","typedData","signTypedDataWith","useExchangeRate","ExchangeRateQuery","estimatedApprovalGas","gasEstimates","inferGasEstimate","action","key","never","extractChainId","decodeReserveId","reserve","prev","decodeUserPositionId","inferChainId","query","inferTimestampForExchangeRateLookup","resolveChain","fetchChain","nonNullable","useExecutionDetails","chain","publicClient","createPublicClient","toViemChain","http","ResultAsync","receipt","maxFeePerGas","createNetworkFeeAmount","details","rate","gasCostInWei","gasCost","bigDecimal","amount","RoundingMode","useNetworkFee","currency","Currency","fetchDetails"],"mappings":"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","file":"index.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 type { UnexpectedError } from '@aave/client';\n\n/**\n * @internal\n */\nexport type QueryMetadata = {\n operationKey: number;\n resultOperationKey: number | undefined;\n};\n\n/**\n * A read hook result.\n *\n * It's a discriminated union of the possible results of a read operation:\n * - Rely on the `loading` value to determine if the `data` or `error` can be evaluated.\n * - If `error` is `undefined`, then `data` value will be available.\n */\nexport type ReadResult<T, E = UnexpectedError> =\n | {\n data: undefined;\n error: undefined;\n loading: true;\n reloading: false;\n /**\n * @internal\n */\n metadata: QueryMetadata;\n }\n | {\n data: T;\n error: undefined;\n loading: false;\n reloading: boolean;\n /**\n * @internal\n */\n metadata: QueryMetadata;\n }\n | {\n data: undefined;\n error: E;\n loading: false;\n reloading: boolean;\n /**\n * @internal\n */\n metadata: QueryMetadata;\n };\n\n/**\n * A read hook result that supports pausing.\n */\nexport type PausableReadResult<T, E = UnexpectedError> =\n | {\n data: T | undefined;\n error: E | undefined;\n loading: false;\n paused: true;\n reloading: false;\n /**\n * @internal\n */\n metadata: QueryMetadata;\n }\n | {\n data: undefined;\n error: undefined;\n loading: true;\n paused: false;\n reloading: false;\n /**\n * @internal\n */\n metadata: QueryMetadata;\n }\n | {\n data: T;\n error: undefined;\n loading: false;\n paused: false;\n reloading: boolean;\n /**\n * @internal\n */\n metadata: QueryMetadata;\n }\n | {\n data: undefined;\n error: E;\n loading: false;\n paused: false;\n reloading: boolean;\n /**\n * @internal\n */\n metadata: QueryMetadata;\n };\n\n/**\n * @internal\n */\nexport const ReadResult = {\n Loading: <T, E = UnexpectedError>(\n metadata: QueryMetadata,\n ): PausableReadResult<T, E> => ({\n data: undefined,\n error: undefined,\n loading: true,\n paused: false,\n reloading: false,\n metadata,\n }),\n Success: <T, E = UnexpectedError>(\n data: T,\n metadata: QueryMetadata,\n reloading = false,\n ): PausableReadResult<T, E> => ({\n data,\n error: undefined,\n loading: false,\n paused: false,\n reloading,\n metadata,\n }),\n Failure: <T, E = UnexpectedError>(\n error: E,\n metadata: QueryMetadata,\n reloading = false,\n ): PausableReadResult<T, E> => ({\n data: undefined,\n error,\n loading: false,\n paused: false,\n reloading,\n metadata,\n }),\n Paused: <T, E = UnexpectedError>(\n data: T | undefined,\n error: E | undefined,\n metadata: QueryMetadata,\n ): PausableReadResult<T, E> => ({\n data,\n error,\n loading: false,\n paused: true,\n reloading: false,\n metadata,\n }),\n};\n\n/**\n * A read hook result that supports React Suspense.\n */\nexport type SuspenseResult<T> = {\n data: T;\n /**\n * @internal\n */\n metadata: QueryMetadata;\n};\n\n/**\n * A read hook result that supports React Suspense and can be paused.\n */\nexport type PausableSuspenseResult<T> =\n | {\n paused: true;\n data: undefined;\n /**\n * @internal\n */\n metadata: QueryMetadata;\n }\n | {\n paused: false;\n data: T;\n /**\n * @internal\n */\n metadata: QueryMetadata;\n };\n\nexport type SuspendableResult<T, E = UnexpectedError> =\n | ReadResult<T, E>\n | SuspenseResult<T>\n | PausableReadResult<T, E>\n | PausableSuspenseResult<T>;\n","import { type StandardData, UnexpectedError } from '@aave/client';\nimport {\n type AnyVariables,\n invariant,\n type NullishDeep,\n ok,\n type Prettify,\n type Result,\n} from '@aave/types';\nimport { useEffect, useMemo, useState } from 'react';\nimport { createRequest, type TypedDocumentNode, useQuery } from 'urql';\nimport {\n type PausableReadResult,\n type PausableSuspenseResult,\n type QueryMetadata,\n ReadResult,\n type SuspendableResult,\n type SuspenseResult,\n} from './results';\n\nexport type Selector<ResponseValue, SelectorData, SelectorError> = (\n data: ResponseValue,\n) => Result<SelectorData, SelectorError>;\n\nexport type Pausable<T, WhenPaused = NullishDeep<T>> = Prettify<\n WhenPaused & {\n /**\n * Prevents the hook from automatically executing GraphQL query operations.\n *\n * @experimental This is an experimental feature and may change in the future.\n *\n * @remarks\n * `pause` may be set to `true` to stop the query operation from executing\n * automatically. The hook will stop receiving updates and won't execute the query\n * operation until it's set to `false`.\n */\n pause: boolean;\n }\n>;\n\nexport type Suspendable = { suspense: true };\n\n/**\n * @internal\n */\nexport type UseSuspendableQueryArgs<\n ResponseValue,\n SelectorData,\n SelectorError,\n Variables extends AnyVariables,\n Suspense extends boolean,\n Pause extends boolean = never,\n> = {\n document: TypedDocumentNode<StandardData<ResponseValue>, Variables>;\n variables?: Pause extends boolean ? NullishDeep<Variables> : Variables;\n suspense: Suspense;\n selector?: Selector<ResponseValue, SelectorData, SelectorError>;\n pollInterval?: number;\n batch?: boolean;\n pause?: Pause;\n};\n\n/**\n * @internal\n */\nexport function useSuspendableQuery<\n ResponseValue,\n SelectorData,\n SelectorError,\n Variables extends AnyVariables,\n Pausable extends boolean = never,\n>({\n document,\n variables,\n suspense,\n pause,\n}: UseSuspendableQueryArgs<\n ResponseValue,\n SelectorData,\n SelectorError,\n Variables,\n false,\n Pausable\n>):\n | ReadResult<SelectorData, SelectorError | UnexpectedError>\n | PausableReadResult<SelectorData, SelectorError | UnexpectedError>;\n/**\n * @internal\n */\nexport function useSuspendableQuery<\n ResponseValue,\n SelectorData,\n SelectorError,\n Variables extends AnyVariables,\n Pausable extends boolean = never,\n>({\n document,\n variables,\n suspense,\n pause,\n}: UseSuspendableQueryArgs<\n ResponseValue,\n SelectorData,\n SelectorError,\n Variables,\n true,\n Pausable\n>): SuspenseResult<SelectorData> | PausableSuspenseResult<SelectorData>;\n/**\n * @internal\n */\nexport function useSuspendableQuery<\n ResponseValue,\n SelectorData,\n SelectorError,\n Variables extends AnyVariables,\n Pausable extends boolean = never,\n>({\n document,\n variables,\n suspense,\n pause,\n}: UseSuspendableQueryArgs<\n ResponseValue,\n SelectorData,\n SelectorError,\n Variables,\n boolean,\n Pausable\n>): SuspendableResult<SelectorData, SelectorError | UnexpectedError>;\n/**\n * Implementation.\n */\nexport function useSuspendableQuery<\n ResponseValue,\n SelectorData,\n SelectorError,\n Variables extends AnyVariables,\n>({\n document,\n variables,\n suspense,\n pause,\n selector = ok as Selector<ResponseValue, SelectorData, SelectorError>,\n pollInterval = 0,\n batch = true,\n}: UseSuspendableQueryArgs<\n ResponseValue,\n SelectorData,\n SelectorError,\n Variables,\n boolean,\n boolean\n>): SuspendableResult<SelectorData, SelectorError | UnexpectedError> {\n const [metadata, setMetadata] = useState<QueryMetadata>({\n operationKey: 0,\n resultOperationKey: undefined,\n });\n const [loading, setLoading] = useState(true);\n const operationId = useMemo(\n () => createRequest(document, variables as Variables).key,\n [document, variables],\n );\n const [{ fetching, data, error, stale }, executeQuery] = useQuery({\n query: document,\n variables: variables as Variables,\n pause,\n context: useMemo(\n () => ({\n batch,\n suspense,\n }),\n [batch, suspense],\n ),\n });\n\n useEffect(() => {\n setMetadata((current) => ({\n ...current,\n operationKey: operationId,\n }));\n }, [operationId]);\n\n useEffect(() => {\n if (pause) return;\n\n if (!fetching) {\n setLoading(false);\n }\n }, [fetching, pause]);\n\n useEffect(() => {\n if (pause || fetching) {\n return;\n }\n\n setMetadata((current) => ({\n ...current,\n resultOperationKey:\n data && !stale ? current.operationKey : current.resultOperationKey,\n }));\n }, [pause, fetching, data, stale]);\n\n useEffect(() => {\n if (pollInterval <= 0 || fetching || pause) return undefined;\n\n const timerId = setTimeout(() => {\n executeQuery({\n requestPolicy: 'network-only',\n batch: false, // never batch, run now!\n });\n }, pollInterval);\n\n return () => clearTimeout(timerId);\n }, [fetching, executeQuery, pollInterval, pause]);\n\n if (pause) {\n const unexpectedError = error ? UnexpectedError.from(error) : undefined;\n\n if (!data) {\n return ReadResult.Paused<SelectorData, SelectorError | UnexpectedError>(\n undefined,\n unexpectedError,\n metadata,\n );\n }\n\n const selected = selector(data.value);\n\n if (selected.isErr()) {\n return ReadResult.Paused<SelectorData, SelectorError>(\n undefined,\n selected.error,\n metadata,\n );\n }\n\n return ReadResult.Paused<SelectorData, UnexpectedError>(\n selected.value,\n unexpectedError,\n metadata,\n );\n }\n\n if (!suspense && loading) {\n return ReadResult.Loading(metadata);\n }\n\n // stale indicates that the useQuery is fetching new data because the variables changed\n // !loading && fetching indicates that a re-fetch is happening as consequence of calling executeQuery (e.g., polling)\n const reloading = stale || (!loading && fetching);\n\n if (error) {\n const unexpected = UnexpectedError.from(error);\n if (suspense) {\n throw unexpected;\n }\n\n return ReadResult.Failure(unexpected, metadata, reloading);\n }\n\n invariant(data, 'No data returned');\n\n const selected = selector(data.value);\n\n if (selected.isErr()) {\n if (suspense) {\n throw selected.error;\n }\n return ReadResult.Failure(selected.error, metadata, reloading);\n }\n\n return ReadResult.Success(selected.value, metadata, reloading);\n}\n","import { invariant, type ResultAsync } from '@aave/types';\nimport {\n type DependencyList,\n useCallback,\n useEffect,\n useRef,\n useState,\n} 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 const mountedRef = useRef(true);\n\n useEffect(() => {\n return () => {\n mountedRef.current = false;\n };\n }, []);\n\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 mountedRef.current,\n 'Cannot execute a task on an unmounted component.',\n );\n\n invariant(\n !loadingRef.current,\n 'Cannot execute a task while another is in progress.',\n );\n\n loadingRef.current = true;\n\n let previousState: AsyncTaskState<TValue, TError> | undefined;\n setState((state) => {\n previousState = state;\n return {\n called: true,\n loading: true,\n data: state.data,\n error: undefined,\n };\n });\n\n try {\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 } catch (error) {\n loadingRef.current = false;\n if (previousState) {\n setState(previousState);\n }\n throw error;\n }\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 UnexpectedError,\n} from '@aave/core';\nimport type { TransactionRequest } from '@aave/graphql';\nimport type { ResultAsync, Signature } from '@aave/types';\nimport { isSignature, okAsync } 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 isInstanceOf(value: unknown): value is PendingTransaction {\n return value instanceof PendingTransaction;\n }\n\n /**\n * Narrows a value to PendingTransaction.\n * Only accepts types that include PendingTransaction in the union.\n *\n * @internal\n */\n static tryFrom<T>(\n value: PendingTransaction extends T ? T : never,\n ): ResultAsync<PendingTransaction, UnexpectedError> {\n if (PendingTransaction.isInstanceOf(value)) {\n return okAsync(value);\n }\n return UnexpectedError.from(value).asResultAsync();\n }\n}\n\nexport type UseSendTransactionResult = UseAsyncTask<\n TransactionRequest,\n PendingTransaction,\n SendTransactionError\n>;\n\n/**\n * The Aave execution plan handler\n */\nexport type ExecutionPlanHandler<\n T,\n R extends Signature | PendingTransaction,\n> = (\n plan: T,\n options: TransactionHandlerOptions,\n) => ResultAsync<R, SendTransactionError>;\n\n/**\n * Tries to create a Signature from an unknown value.\n *\n * @internal\n */\nexport function trySignatureFrom(\n value: unknown,\n): ResultAsync<Signature, UnexpectedError> {\n if (isSignature(value)) {\n return okAsync(value);\n }\n return UnexpectedError.from(\n `Expected Signature, but got ${String(value)}`,\n ).asResultAsync();\n}\n","import type { SignTypedDataError, TypedData } from '@aave/client';\nimport {\n ensureChain,\n sendTransaction,\n signTypedDataWith,\n waitForTransactionResult,\n} from '@aave/client/viem';\nimport type { TransactionRequest } from '@aave/graphql';\nimport { invariant, type Signature } from '@aave/types';\nimport type { WalletClient } from 'viem';\nimport { useAaveClient } from '../context';\nimport {\n PendingTransaction,\n type UseAsyncTask,\n type UseSendTransactionResult,\n useAsyncTask,\n} from '../helpers';\n\n/**\n * A hook that provides a way to send Aave transactions using a viem WalletClient instance.\n *\n * Use the `useWalletClient` wagmi hook to get the `WalletClient` instance, then pass it to this hook to create a function that can be used to send transactions.\n *\n * ```ts\n * const { data: wallet } = useWalletClient(); // wagmi hook\n *\n * const [sendTransaction] = useSendTransaction(wallet);\n * ```\n *\n * @param walletClient - The wallet client to use for sending transactions.\n */\nexport function useSendTransaction(\n walletClient: WalletClient | null | undefined,\n): UseSendTransactionResult {\n const client = useAaveClient();\n\n return useAsyncTask(\n (request: TransactionRequest) => {\n invariant(\n walletClient,\n 'Expected a WalletClient to handle the operation result.',\n );\n\n return ensureChain(client, walletClient, request)\n .andThen(() => sendTransaction(walletClient, request))\n .map(\n (hash) =>\n new PendingTransaction(() =>\n waitForTransactionResult(walletClient, request, hash),\n ),\n );\n },\n [client, walletClient],\n );\n}\n\n/**\n * A hook that provides a way to sign EIP-712 typed data (ERC-20 permits, swap intents, etc.)\n * using a viem WalletClient instance.\n *\n * ```ts\n * const { data: wallet } = useWalletClient(); // wagmi hook\n * const [signTypedData, { loading, error, data }] = useSignTypedData(wallet);\n * ```\n */\nexport function useSignTypedData(\n walletClient: WalletClient | null | undefined,\n): UseAsyncTask<TypedData, Signature, SignTypedDataError> {\n return useAsyncTask(\n (typedData: TypedData) => {\n invariant(walletClient, 'Expected a WalletClient to sign typed data');\n\n return signTypedDataWith(walletClient, typedData);\n },\n [walletClient],\n );\n}\n","import type { CurrencyQueryOptions } from '@aave/client';\nimport { exchangeRate, chain as fetchChain } from '@aave/client/actions';\nimport type { UnexpectedError } from '@aave/core';\nimport type { Chain, ExchangeAmount, ExchangeRateRequest } from '@aave/graphql';\nimport {\n type ActivityItem,\n ChainQuery,\n type ChainRequest,\n ChainsFilter,\n ChainsQuery,\n type ChainsRequest,\n ExchangeRateQuery,\n type NativeAmount,\n type PreviewAction,\n} from '@aave/graphql';\nimport type { NullishDeep, Prettify } from '@aave/types';\nimport { useAaveClient } from './context';\nimport {\n type Pausable,\n type PausableReadResult,\n type PausableSuspenseResult,\n type ReadResult,\n type Suspendable,\n type SuspendableResult,\n type SuspenseResult,\n useSuspendableQuery,\n} from './helpers';\nimport { type UseAsyncTask, useAsyncTask } from './helpers/tasks';\n\nexport type UseChainArgs = ChainRequest;\n\n/**\n * Fetch a specific chain by chain ID.\n *\n * This signature supports React Suspense:\n *\n * ```tsx\n * const { data } = useChain({\n * chainId: chainId(1),\n * suspense: true,\n * });\n * // data will be Chain | null\n * ```\n */\nexport function useChain(\n args: UseChainArgs & Suspendable,\n): SuspenseResult<Chain | null>;\n/**\n * Fetch a specific chain by chain ID.\n *\n * Pausable suspense mode.\n *\n * ```tsx\n * const { data } = useChain({\n * chainId: chainId(1),\n * suspense: true,\n * pause: true,\n * });\n * ```\n */\nexport function useChain(\n args: Pausable<UseChainArgs> & Suspendable,\n): PausableSuspenseResult<Chain | null>;\n/**\n * Fetch a specific chain by chain ID.\n *\n * ```tsx\n * const { data, error, loading } = useChain({\n * chainId: chainId(1),\n * });\n * // data will be Chain | null\n * ```\n */\nexport function useChain(args: UseChainArgs): ReadResult<Chain | null>;\n/**\n * Fetch a specific chain by chain ID.\n *\n * Pausable loading state mode.\n *\n * ```tsx\n * const { data, error, loading, paused } = useChain({\n * chainId: chainId(1),\n * pause: true,\n * });\n * ```\n */\nexport function useChain(\n args: Pausable<UseChainArgs>,\n): PausableReadResult<Chain | null>;\n\nexport function useChain({\n suspense = false,\n pause = false,\n ...request\n}: NullishDeep<UseChainArgs> & {\n suspense?: boolean;\n pause?: boolean;\n}): SuspendableResult<Chain | null, UnexpectedError> {\n return useSuspendableQuery({\n document: ChainQuery,\n variables: {\n request,\n },\n suspense,\n pause,\n });\n}\n\n/**\n * Low-level hook to execute a {@link chain} action directly.\n *\n * @experimental This hook is experimental and may be subject to breaking changes.\n * @remarks\n * This hook **does not** actively watch for updated data on the chain.\n * Use this hook to retrieve data on demand as part of a larger workflow\n * (e.g., in an event handler in order to move to the next step).\n *\n * ```ts\n * const [execute, { called, data, error, loading }] = useChainAction();\n *\n * // …\n *\n * const result = await execute({\n * chainId: chainId(1),\n * });\n *\n * if (result.isOk()) {\n * console.log(result.value); // Chain | null\n * } else {\n * console.error(result.error);\n * }\n * ```\n */\nexport function useChainAction(): UseAsyncTask<\n ChainRequest,\n Chain | null,\n UnexpectedError\n> {\n const client = useAaveClient();\n\n return useAsyncTask(\n (request: ChainRequest) =>\n fetchChain(client, request, {\n batch: false,\n requestPolicy: 'cache-first',\n }),\n [client],\n );\n}\n\nexport type UseChainsArgs = ChainsRequest;\n/**\n * Fetches the list of supported chains.\n *\n * This signature supports React Suspense:\n *\n * ```tsx\n * const { data } = useChains({\n * query: { filter: ChainsFilter.ALL },\n * suspense: true,\n * });\n * ```\n */\nexport function useChains(\n args: UseChainsArgs & Suspendable,\n): SuspenseResult<Chain[]>;\n/**\n * Fetches the list of supported chains.\n *\n * Pausable suspense mode.\n *\n * ```tsx\n * const { data } = useChains({\n * query: { filter: ChainsFilter.ALL },\n * suspense: true,\n * pause: true,\n * });\n * ```\n */\nexport function useChains(\n args: Pausable<UseChainsArgs> & Suspendable,\n): PausableSuspenseResult<Chain[]>;\n/**\n * Fetches the list of supported chains.\n *\n * ```tsx\n * const { data, error, loading } = useChains({\n * query: { filter: ChainsFilter.ALL },\n * });\n * ```\n */\nexport function useChains(args?: UseChainsArgs): ReadResult<Chain[]>;\n/**\n * Fetches the list of supported chains.\n *\n * Pausable loading state mode.\n *\n * ```tsx\n * const { data, error, loading, paused } = useChains({\n * query: { filter: ChainsFilter.ALL },\n * pause: true,\n * });\n * ```\n */\nexport function useChains(\n args?: Pausable<UseChainsArgs>,\n): PausableReadResult<Chain[]>;\n\nexport function useChains(\n {\n suspense = false,\n pause = false,\n ...request\n }: NullishDeep<UseChainsArgs> & {\n suspense?: boolean;\n pause?: boolean;\n } = { query: { filter: ChainsFilter.ALL } },\n): SuspendableResult<Chain[], UnexpectedError> {\n return useSuspendableQuery({\n document: ChainsQuery,\n variables: { request },\n suspense,\n pause,\n });\n}\n\n/**\n * Fetches exchange rates between tokens and fiat currencies.\n *\n * ```tsx\n * const [getExchangeRate, gettingRate] = useExchangeRateAction();\n *\n * const loading = gettingRate.loading;\n * const error = gettingRate.error;\n *\n * // …\n *\n * const result = await getExchangeRate({\n * from: { erc20: { chainId: chainId(1), address: evmAddress('0xA0b86a33E6...') } },\n * to: Currency.Usd,\n * });\n *\n * if (result.isErr()) {\n * console.error(result.error);\n * return;\n * }\n *\n * console.log('Exchange rate:', result.value);\n * ```\n */\nexport function useExchangeRateAction(): UseAsyncTask<\n ExchangeRateRequest,\n ExchangeAmount,\n UnexpectedError\n> {\n const client = useAaveClient();\n\n return useAsyncTask(\n (request: ExchangeRateRequest) =>\n exchangeRate(client, request, { requestPolicy: 'network-only' }),\n [client],\n );\n}\n\nexport type UseExchangeRateArgs = ExchangeRateRequest;\n\n/**\n * Fetches exchange rates between tokens and fiat currencies with automatic polling.\n *\n * This signature supports React Suspense:\n *\n * ```tsx\n * const { data } = useExchangeRate({\n * from: {\n * erc20: {\n * chainId: chainId(1),\n * address: evmAddress('0xA0b86a33E6...')\n * }\n * },\n * to: Currency.Usd,\n * suspense: true,\n * });\n * ```\n */\nexport function useExchangeRate(\n args: UseExchangeRateArgs & Suspendable,\n): SuspenseResult<ExchangeAmount>;\n/**\n * Fetches exchange rates between tokens and fiat currencies with automatic polling.\n *\n * Pausable suspense mode.\n *\n * ```tsx\n * const { data } = useExchangeRate({\n * from: {\n * erc20: {\n * chainId: chainId(1),\n * address: evmAddress('0xA0b86a33E6...')\n * }\n * },\n * to: Currency.Usd,\n * suspense: true,\n * pause: true,\n * });\n * ```\n */\nexport function useExchangeRate(\n args: Pausable<UseExchangeRateArgs> & Suspendable,\n): PausableSuspenseResult<ExchangeAmount>;\n/**\n * Fetches exchange rates between tokens and fiat currencies with automatic polling.\n *\n * ```tsx\n * const { data, error, loading } = useExchangeRate({\n * from: {\n * erc20: {\n * chainId: chainId(1),\n * address: evmAddress('0xA0b86a33E6...')\n * }\n * },\n * to: Currency.Usd,\n * });\n *\n * <Component value={somewhere} fxRate={data} />\n * ```\n */\nexport function useExchangeRate(\n args: UseExchangeRateArgs,\n): ReadResult<ExchangeAmount>;\n/**\n * Fetches exchange rates between tokens and fiat currencies with automatic polling.\n *\n * Pausable loading state mode.\n *\n * ```tsx\n * const { data, error, loading, paused } = useExchangeRate({\n * from: {\n * erc20: {\n * chainId: chainId(1),\n * address: evmAddress('0xA0b86a33E6...')\n * }\n * },\n * to: Currency.Usd,\n * pause: true,\n * });\n * ```\n */\nexport function useExchangeRate(\n args: Pausable<UseExchangeRateArgs>,\n): PausableReadResult<ExchangeAmount>;\n\nexport function useExchangeRate({\n suspense = false,\n pause = false,\n ...request\n}: NullishDeep<UseExchangeRateArgs> & {\n suspense?: boolean;\n pause?: boolean;\n}): SuspendableResult<ExchangeAmount, UnexpectedError> {\n const client = useAaveClient();\n\n return useSuspendableQuery({\n document: ExchangeRateQuery,\n variables: { request },\n suspense,\n pause,\n pollInterval: request.at\n ? 0\n : client.context.environment.exchangeRateInterval,\n });\n}\n\nexport type UseNetworkFeeRequestQuery =\n | {\n activity: ActivityItem;\n }\n | {\n estimate: PreviewAction;\n };\n\nexport type UseNetworkFeeArgs = Prettify<\n {\n query: UseNetworkFeeRequestQuery;\n } & CurrencyQueryOptions\n>;\n\ntype PausableUseNetworkFeeArgs = Partial<\n {\n query: Partial<UseNetworkFeeRequestQuery>;\n } & CurrencyQueryOptions\n>;\n\n/**\n * Fetch the network fee for an ActivityItem.\n *\n * @experimental This hook is experimental and may be subject to breaking changes.\n */\nexport type UseNetworkFee<T extends NativeAmount = NativeAmount> =\n /**\n * Fetches the network fee for a past ActivityItem.\n *\n * This signature supports React Suspense:\n *\n * ```tsx\n * const { data } = useNetworkFee({\n * query: { activity },\n * suspense: true,\n * });\n *\n * data: NativeAmount\n * ```\n */\n ((args: UseNetworkFeeArgs & Suspendable) => SuspenseResult<T>) &\n /**\n * Fetches the network fee for a past ActivityItem.\n *\n * Pausable suspense mode.\n *\n * ```tsx\n * const { data, paused } = useNetworkFee({\n * query: { activity },\n * suspense: true,\n * pause: true,\n * });\n *\n * data: NativeAmount | undefined\n * ```\n */\n ((\n args: Pausable<UseNetworkFeeArgs, PausableUseNetworkFeeArgs> &\n Suspendable,\n ) => PausableSuspenseResult<T>) &\n /**\n * Fetches the network fee for a past ActivityItem.\n *\n * ```tsx\n * const { data, error, loading } = useNetworkFee({\n * query: { activity },\n * });\n * ```\n */\n ((args: UseNetworkFeeArgs) => ReadResult<T>) &\n /**\n * Fetches the network fee for a past ActivityItem.\n *\n * Pausable loading state mode.\n *\n * ```tsx\n * const { data, error, loading, paused } = useNetworkFee({\n * query: { activity },\n * pause: true,\n * });\n *\n * data: NativeAmount | undefined\n * ```\n */\n ((\n args: Pausable<UseNetworkFeeArgs, PausableUseNetworkFeeArgs>,\n ) => PausableReadResult<T>);\n","import { type AaveClient, UnexpectedError } from '@aave/client';\nimport { chain as fetchChain } from '@aave/client/actions';\nimport { toViemChain } from '@aave/client/viem';\nimport {\n type Chain,\n Currency,\n type DecimalNumber,\n decodeReserveId,\n decodeUserPositionId,\n type ExchangeAmount,\n type NativeAmount,\n type PreviewAction,\n} from '@aave/graphql';\nimport {\n bigDecimal,\n type ChainId,\n invariant,\n never,\n nonNullable,\n okAsync,\n ResultAsync,\n RoundingMode,\n} from '@aave/types';\nimport { useEffect } from 'react';\nimport { createPublicClient, http } from 'viem';\nimport { useAaveClient } from '../context';\nimport {\n ReadResult,\n type SuspendableResult,\n type UseAsyncTask,\n useAsyncTask,\n} from '../helpers';\nimport {\n type UseNetworkFee,\n type UseNetworkFeeRequestQuery,\n useExchangeRate,\n} from '../misc';\n\nconst estimatedApprovalGas = 55_558n;\n\nconst gasEstimates: Record<keyof PreviewAction, bigint> = {\n supply: 132_136n + estimatedApprovalGas,\n borrow: 250_551n,\n withdraw: 195_049n,\n repay: 217_889n + estimatedApprovalGas,\n setUserSuppliesAsCollateral: 240_284n,\n updateUserPositionConditions: 280_000n,\n};\n\nfunction inferGasEstimate(action: PreviewAction): bigint {\n const key = Object.keys(action)[0] as keyof PreviewAction;\n return gasEstimates[key] ?? never(`Expected gas estimate for action ${key}`);\n}\n\nfunction extractChainId(action: PreviewAction): ChainId {\n if ('supply' in action) {\n return decodeReserveId(action.supply.reserve).chainId;\n }\n\n if ('borrow' in action) {\n return decodeReserveId(action.borrow.reserve).chainId;\n }\n\n if ('withdraw' in action) {\n return decodeReserveId(action.withdraw.reserve).chainId;\n }\n\n if ('repay' in action) {\n return decodeReserveId(action.repay.reserve).chainId;\n }\n\n if ('setUserSuppliesAsCollateral' in action) {\n return action.setUserSuppliesAsCollateral.changes\n .map(({ reserve }) => decodeReserveId(reserve))\n .reduce((prev, current) => {\n invariant(\n prev.chainId === current.chainId && prev.spoke === current.spoke,\n 'All reserves MUST on the same spoke',\n );\n return prev;\n }).chainId;\n }\n\n if ('updateUserPositionConditions' in action) {\n return decodeUserPositionId(\n action.updateUserPositionConditions.userPositionId,\n ).chainId;\n }\n\n never('Expected reserve id');\n}\n\nfunction inferChainId(query: UseNetworkFeeRequestQuery): ChainId | undefined {\n if ('activity' in query && query.activity) {\n return query.activity.chain.chainId;\n }\n\n if ('estimate' in query && query.estimate) {\n return extractChainId(query.estimate);\n }\n\n return undefined;\n}\n\nfunction inferTimestampForExchangeRateLookup(\n query: UseNetworkFeeRequestQuery,\n): Date | undefined {\n if ('activity' in query && query.activity) {\n return query.activity.timestamp;\n }\n return undefined; // i.e., now\n}\n\nfunction resolveChain(\n client: AaveClient,\n query: UseNetworkFeeRequestQuery,\n): ResultAsync<Chain, UnexpectedError> {\n if ('activity' in query && query.activity) {\n return okAsync(query.activity.chain);\n }\n\n if ('estimate' in query && query.estimate) {\n return fetchChain(client, {\n chainId: extractChainId(query.estimate),\n }).map(nonNullable);\n }\n\n return never('Expected chain');\n}\n\ntype ExecutionDetails = {\n chain: Chain;\n gasPrice: bigint;\n gasUnits: bigint;\n};\n\nfunction useExecutionDetails(): UseAsyncTask<\n UseNetworkFeeRequestQuery,\n ExecutionDetails,\n UnexpectedError\n> {\n const client = useAaveClient();\n\n return useAsyncTask(\n (query) =>\n resolveChain(client, query).andThen((chain) => {\n const publicClient = createPublicClient({\n chain: toViemChain(chain),\n transport: http(),\n });\n\n if ('activity' in query && query.activity.txHash) {\n return ResultAsync.fromPromise(\n publicClient.getTransactionReceipt({ hash: query.activity.txHash }),\n (error) => UnexpectedError.from(error),\n ).map((receipt) => {\n return {\n chain: query.activity.chain,\n gasPrice: receipt.effectiveGasPrice,\n gasUnits: receipt.gasUsed,\n };\n });\n }\n\n if ('estimate' in query && query.estimate) {\n return ResultAsync.fromPromise(\n publicClient.estimateFeesPerGas(),\n (error) => UnexpectedError.from(error),\n ).map(({ maxFeePerGas }) => {\n return {\n chain,\n gasPrice: maxFeePerGas,\n gasUnits: inferGasEstimate(query.estimate),\n };\n });\n }\n\n return okAsync({\n chain: never('Expected chain'),\n gasPrice: 0n,\n gasUnits: 0n,\n });\n }),\n [client],\n );\n}\n\nfunction createNetworkFeeAmount(\n details: ExecutionDetails,\n rate: ExchangeAmount,\n): NativeAmount {\n const gasCostInWei = details.gasPrice * details.gasUnits;\n const gasCost = bigDecimal(gasCostInWei).rescale(\n -details.chain.nativeInfo.decimals,\n );\n\n const amount: DecimalNumber = {\n __typename: 'DecimalNumber',\n decimals: details.chain.nativeInfo.decimals,\n onChainValue: gasCostInWei,\n value: gasCost,\n };\n\n return {\n __typename: 'NativeAmount',\n token: {\n __typename: 'NativeToken',\n info: details.chain.nativeInfo,\n chain: details.chain,\n },\n amount,\n exchange: {\n __typename: 'ExchangeAmount',\n value: gasCost.mul(rate.value),\n name: rate.name,\n symbol: rate.symbol,\n icon: rate.icon,\n decimals: rate.decimals,\n },\n exchangeRate: {\n __typename: 'DecimalNumber',\n decimals: 2,\n onChainValue: BigInt(rate.value.rescale(2).toFixed(0, RoundingMode.Down)),\n value: rate.value,\n },\n };\n}\n\n/**\n * Fetch the network fee for an ActivityItem or estimates networkf feed for a preview action.\n *\n * @experimental This hook is experimental and may be subject to breaking changes.\n */\nexport const useNetworkFee: UseNetworkFee = (({\n query,\n currency = Currency.Usd,\n pause = false,\n suspense = false,\n}: {\n query: UseNetworkFeeRequestQuery;\n currency?: Currency;\n pause?: boolean;\n suspense?: boolean;\n}): SuspendableResult<NativeAmount, UnexpectedError> => {\n const [fetchDetails, details] = useExecutionDetails();\n\n const rate = useExchangeRate({\n from: {\n native: inferChainId(query),\n },\n to: currency,\n at: inferTimestampForExchangeRateLookup(query),\n pause,\n ...(suspense ? { suspense } : {}),\n });\n const metadata = rate.metadata;\n\n // biome-ignore lint/correctness/useExhaustiveDependencies: query omitted since it's usually a literal object that changes at every render\n useEffect(() => {\n if (pause || details.called || !query) return;\n\n fetchDetails(query);\n }, [fetchDetails, pause, details.called]);\n\n if (rate.paused) {\n return ReadResult.Paused(\n details.data && rate.data\n ? createNetworkFeeAmount(details.data, rate.data)\n : undefined,\n rate.error ? rate.error : undefined,\n metadata,\n );\n }\n\n if (!details.called || details.loading || rate.loading) {\n return ReadResult.Loading(metadata);\n }\n\n if (details.error || rate.error) {\n return ReadResult.Failure(\n details.error ?? rate.error ?? never('Unknown error'),\n metadata,\n );\n }\n\n invariant(\n details.data && rate.data,\n 'Expected receipt, chain, and rate data',\n );\n\n return ReadResult.Success(\n createNetworkFeeAmount(details.data, rate.data),\n metadata,\n );\n}) as UseNetworkFee;\n"]}
|
|
1
|
+
{"version":3,"sources":["../../src/context.tsx","../../src/helpers/results.ts","../../src/helpers/reads.ts","../../src/helpers/tasks.ts","../../src/helpers/writes.ts","../../src/viem/adapters.ts","../../src/misc.ts","../../src/viem/useNetworkFee.ts"],"names":["AaveContext","React","useAaveClient","client","useContext","invariant","ReadResult","metadata","data","reloading","error","useSuspendableQuery","document","variables","suspense","pause","selector","ok","pollInterval","batch","setMetadata","useState","loading","setLoading","operationId","useMemo","createRequest","fetching","stale","executeQuery","useQuery","useEffect","current","timerId","unexpectedError","UnexpectedError","selected","unexpected","extractDocumentName","responseValue","AsyncTaskState","useAsyncTask","handler","deps","state","setState","loadingRef","useRef","mountedRef","handle","useCallback","input","previousState","result","value","PendingTransaction","_PendingTransaction","wait","okAsync","useSendTransaction","walletClient","request","ensureChain","sendTransaction","hash","waitForTransactionResult","useSignTypedData","typedData","signTypedDataWith","useExchangeRate","ExchangeRateQuery","estimatedApprovalGas","gasEstimates","inferGasEstimate","action","key","never","extractChainId","decodeReserveId","reserve","prev","decodeUserPositionId","inferChainId","query","inferTimestampForExchangeRateLookup","resolveChain","fetchChain","nonNullable","useExecutionDetails","chain","publicClient","createPublicClient","toViemChain","http","ResultAsync","receipt","maxFeePerGas","createNetworkFeeAmount","details","rate","gasCostInWei","gasCost","bigDecimal","amount","RoundingMode","useNetworkFee","currency","Currency","fetchDetails"],"mappings":"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","file":"index.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 type { UnexpectedError } from '@aave/client';\n\n/**\n * @internal\n */\nexport type QueryMetadata = {\n operationKey: number;\n resultOperationKey: number | undefined;\n};\n\n/**\n * A read hook result.\n *\n * It's a discriminated union of the possible results of a read operation:\n * - Rely on the `loading` value to determine if the `data` or `error` can be evaluated.\n * - If `error` is `undefined`, then `data` value will be available.\n */\nexport type ReadResult<T, E = UnexpectedError> =\n | {\n data: undefined;\n error: undefined;\n loading: true;\n reloading: false;\n /**\n * @internal\n */\n metadata: QueryMetadata;\n }\n | {\n data: T;\n error: undefined;\n loading: false;\n reloading: boolean;\n /**\n * @internal\n */\n metadata: QueryMetadata;\n }\n | {\n data: undefined;\n error: E;\n loading: false;\n reloading: boolean;\n /**\n * @internal\n */\n metadata: QueryMetadata;\n };\n\n/**\n * A read hook result that supports pausing.\n */\nexport type PausableReadResult<T, E = UnexpectedError> =\n | {\n data: T | undefined;\n error: E | undefined;\n loading: false;\n paused: true;\n reloading: false;\n /**\n * @internal\n */\n metadata: QueryMetadata;\n }\n | {\n data: undefined;\n error: undefined;\n loading: true;\n paused: false;\n reloading: false;\n /**\n * @internal\n */\n metadata: QueryMetadata;\n }\n | {\n data: T;\n error: undefined;\n loading: false;\n paused: false;\n reloading: boolean;\n /**\n * @internal\n */\n metadata: QueryMetadata;\n }\n | {\n data: undefined;\n error: E;\n loading: false;\n paused: false;\n reloading: boolean;\n /**\n * @internal\n */\n metadata: QueryMetadata;\n };\n\n/**\n * @internal\n */\nexport const ReadResult = {\n Loading: <T, E = UnexpectedError>(\n metadata: QueryMetadata,\n ): PausableReadResult<T, E> => ({\n data: undefined,\n error: undefined,\n loading: true,\n paused: false,\n reloading: false,\n metadata,\n }),\n Success: <T, E = UnexpectedError>(\n data: T,\n metadata: QueryMetadata,\n reloading = false,\n ): PausableReadResult<T, E> => ({\n data,\n error: undefined,\n loading: false,\n paused: false,\n reloading,\n metadata,\n }),\n Failure: <T, E = UnexpectedError>(\n error: E,\n metadata: QueryMetadata,\n reloading = false,\n ): PausableReadResult<T, E> => ({\n data: undefined,\n error,\n loading: false,\n paused: false,\n reloading,\n metadata,\n }),\n Paused: <T, E = UnexpectedError>(\n data: T | undefined,\n error: E | undefined,\n metadata: QueryMetadata,\n ): PausableReadResult<T, E> => ({\n data,\n error,\n loading: false,\n paused: true,\n reloading: false,\n metadata,\n }),\n};\n\n/**\n * A read hook result that supports React Suspense.\n */\nexport type SuspenseResult<T> = {\n data: T;\n /**\n * @internal\n */\n metadata: QueryMetadata;\n};\n\n/**\n * A read hook result that supports React Suspense and can be paused.\n */\nexport type PausableSuspenseResult<T> =\n | {\n paused: true;\n data: undefined;\n /**\n * @internal\n */\n metadata: QueryMetadata;\n }\n | {\n paused: false;\n data: T;\n /**\n * @internal\n */\n metadata: QueryMetadata;\n };\n\nexport type SuspendableResult<T, E = UnexpectedError> =\n | ReadResult<T, E>\n | SuspenseResult<T>\n | PausableReadResult<T, E>\n | PausableSuspenseResult<T>;\n","import { type StandardData, UnexpectedError } from '@aave/client';\nimport { extractDocumentName } from '@aave/core';\nimport {\n type AnyVariables,\n invariant,\n type NullishDeep,\n ok,\n type Prettify,\n type Result,\n} from '@aave/types';\nimport { useEffect, useMemo, useState } from 'react';\nimport { createRequest, type TypedDocumentNode, useQuery } from 'urql';\nimport {\n type PausableReadResult,\n type PausableSuspenseResult,\n type QueryMetadata,\n ReadResult,\n type SuspendableResult,\n type SuspenseResult,\n} from './results';\n\nexport type Selector<ResponseValue, SelectorData, SelectorError> = (\n data: ResponseValue,\n) => Result<SelectorData, SelectorError>;\n\nexport type Pausable<T, WhenPaused = NullishDeep<T>> = Prettify<\n WhenPaused & {\n /**\n * Prevents the hook from automatically executing GraphQL query operations.\n *\n * @experimental This is an experimental feature and may change in the future.\n *\n * @remarks\n * `pause` may be set to `true` to stop the query operation from executing\n * automatically. The hook will stop receiving updates and won't execute the query\n * operation until it's set to `false`.\n */\n pause: boolean;\n }\n>;\n\nexport type Suspendable = { suspense: true };\n\n/**\n * @internal\n */\nexport type UseSuspendableQueryArgs<\n ResponseValue,\n SelectorData,\n SelectorError,\n Variables extends AnyVariables,\n Suspense extends boolean,\n Pause extends boolean = never,\n> = {\n document: TypedDocumentNode<StandardData<ResponseValue>, Variables>;\n variables?: Pause extends boolean ? NullishDeep<Variables> : Variables;\n suspense: Suspense;\n selector?: Selector<ResponseValue, SelectorData, SelectorError>;\n pollInterval?: number;\n batch?: boolean;\n pause?: Pause;\n};\n\n/**\n * @internal\n */\nexport function useSuspendableQuery<\n ResponseValue,\n SelectorData,\n SelectorError,\n Variables extends AnyVariables,\n Pausable extends boolean = never,\n>({\n document,\n variables,\n suspense,\n pause,\n}: UseSuspendableQueryArgs<\n ResponseValue,\n SelectorData,\n SelectorError,\n Variables,\n false,\n Pausable\n>):\n | ReadResult<SelectorData, SelectorError | UnexpectedError>\n | PausableReadResult<SelectorData, SelectorError | UnexpectedError>;\n/**\n * @internal\n */\nexport function useSuspendableQuery<\n ResponseValue,\n SelectorData,\n SelectorError,\n Variables extends AnyVariables,\n Pausable extends boolean = never,\n>({\n document,\n variables,\n suspense,\n pause,\n}: UseSuspendableQueryArgs<\n ResponseValue,\n SelectorData,\n SelectorError,\n Variables,\n true,\n Pausable\n>): SuspenseResult<SelectorData> | PausableSuspenseResult<SelectorData>;\n/**\n * @internal\n */\nexport function useSuspendableQuery<\n ResponseValue,\n SelectorData,\n SelectorError,\n Variables extends AnyVariables,\n Pausable extends boolean = never,\n>({\n document,\n variables,\n suspense,\n pause,\n}: UseSuspendableQueryArgs<\n ResponseValue,\n SelectorData,\n SelectorError,\n Variables,\n boolean,\n Pausable\n>): SuspendableResult<SelectorData, SelectorError | UnexpectedError>;\n/**\n * Implementation.\n */\nexport function useSuspendableQuery<\n ResponseValue,\n SelectorData,\n SelectorError,\n Variables extends AnyVariables,\n>({\n document,\n variables,\n suspense,\n pause,\n selector = ok as Selector<ResponseValue, SelectorData, SelectorError>,\n pollInterval = 0,\n batch = true,\n}: UseSuspendableQueryArgs<\n ResponseValue,\n SelectorData,\n SelectorError,\n Variables,\n boolean,\n boolean\n>): SuspendableResult<SelectorData, SelectorError | UnexpectedError> {\n const [metadata, setMetadata] = useState<QueryMetadata>({\n operationKey: 0,\n resultOperationKey: undefined,\n });\n const [loading, setLoading] = useState(true);\n const operationId = useMemo(\n () => createRequest(document, variables as Variables).key,\n [document, variables],\n );\n const [{ fetching, data, error, stale }, executeQuery] = useQuery({\n query: document,\n variables: variables as Variables,\n pause,\n context: useMemo(\n () => ({\n batch,\n suspense,\n }),\n [batch, suspense],\n ),\n });\n\n useEffect(() => {\n setMetadata((current) => ({\n ...current,\n operationKey: operationId,\n }));\n }, [operationId]);\n\n useEffect(() => {\n if (pause) return;\n\n if (!fetching) {\n setLoading(false);\n }\n }, [fetching, pause]);\n\n useEffect(() => {\n if (pause || fetching) {\n return;\n }\n\n setMetadata((current) => ({\n ...current,\n resultOperationKey:\n data && !stale ? current.operationKey : current.resultOperationKey,\n }));\n }, [pause, fetching, data, stale]);\n\n useEffect(() => {\n if (pollInterval <= 0 || fetching || pause) return undefined;\n\n const timerId = setTimeout(() => {\n executeQuery({\n requestPolicy: 'network-only',\n batch: false, // never batch, run now!\n });\n }, pollInterval);\n\n return () => clearTimeout(timerId);\n }, [fetching, executeQuery, pollInterval, pause]);\n\n if (pause) {\n const unexpectedError = error ? UnexpectedError.from(error) : undefined;\n\n if (!data) {\n return ReadResult.Paused<SelectorData, SelectorError | UnexpectedError>(\n undefined,\n unexpectedError,\n metadata,\n );\n }\n\n const selected = selector(data.value);\n\n if (selected.isErr()) {\n return ReadResult.Paused<SelectorData, SelectorError>(\n undefined,\n selected.error,\n metadata,\n );\n }\n\n return ReadResult.Paused<SelectorData, UnexpectedError>(\n selected.value,\n unexpectedError,\n metadata,\n );\n }\n\n if (!suspense && loading) {\n return ReadResult.Loading(metadata);\n }\n\n // stale indicates that the useQuery is fetching new data because the variables changed\n // !loading && fetching indicates that a re-fetch is happening as consequence of calling executeQuery (e.g., polling)\n const reloading = stale || (!loading && fetching);\n\n if (error) {\n const unexpected = UnexpectedError.from(error);\n if (suspense) {\n throw unexpected;\n }\n\n return ReadResult.Failure(unexpected, metadata, reloading);\n }\n\n invariant(\n data !== undefined,\n `Unexpected empty response from the API for '${extractDocumentName(document) ?? 'unknown'}' query`,\n );\n\n // GraphQL responses can have `{ \"data\": null }` but urql types don't reflect this\n const responseValue = data === null ? null : data.value;\n const selected = selector(responseValue as ResponseValue);\n\n if (selected.isErr()) {\n if (suspense) {\n throw selected.error;\n }\n return ReadResult.Failure(selected.error, metadata, reloading);\n }\n\n return ReadResult.Success(selected.value, metadata, reloading);\n}\n","import { invariant, type ResultAsync } from '@aave/types';\nimport {\n type DependencyList,\n useCallback,\n useEffect,\n useRef,\n useState,\n} 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 const mountedRef = useRef(true);\n\n useEffect(() => {\n return () => {\n mountedRef.current = false;\n };\n }, []);\n\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 mountedRef.current,\n 'Cannot execute a task on an unmounted component.',\n );\n\n invariant(\n !loadingRef.current,\n 'Cannot execute a task while another is in progress.',\n );\n\n loadingRef.current = true;\n\n let previousState: AsyncTaskState<TValue, TError> | undefined;\n setState((state) => {\n previousState = state;\n return {\n called: true,\n loading: true,\n data: state.data,\n error: undefined,\n };\n });\n\n try {\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 } catch (error) {\n loadingRef.current = false;\n if (previousState) {\n setState(previousState);\n }\n throw error;\n }\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 UnexpectedError,\n} from '@aave/core';\nimport type { TransactionRequest } from '@aave/graphql';\nimport type { ResultAsync, Signature } from '@aave/types';\nimport { isSignature, okAsync } 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 isInstanceOf(value: unknown): value is PendingTransaction {\n return value instanceof PendingTransaction;\n }\n\n /**\n * Narrows a value to PendingTransaction.\n * Only accepts types that include PendingTransaction in the union.\n *\n * @internal\n */\n static tryFrom<T>(\n value: PendingTransaction extends T ? T : never,\n ): ResultAsync<PendingTransaction, UnexpectedError> {\n if (PendingTransaction.isInstanceOf(value)) {\n return okAsync(value);\n }\n return UnexpectedError.from(value).asResultAsync();\n }\n}\n\nexport type UseSendTransactionResult = UseAsyncTask<\n TransactionRequest,\n PendingTransaction,\n SendTransactionError\n>;\n\n/**\n * The Aave execution plan handler\n */\nexport type ExecutionPlanHandler<\n T,\n R extends Signature | PendingTransaction,\n> = (\n plan: T,\n options: TransactionHandlerOptions,\n) => ResultAsync<R, SendTransactionError>;\n\n/**\n * Tries to create a Signature from an unknown value.\n *\n * @internal\n */\nexport function trySignatureFrom(\n value: unknown,\n): ResultAsync<Signature, UnexpectedError> {\n if (isSignature(value)) {\n return okAsync(value);\n }\n return UnexpectedError.from(\n `Expected Signature, but got ${String(value)}`,\n ).asResultAsync();\n}\n","import type { SignTypedDataError, TypedData } from '@aave/client';\nimport {\n ensureChain,\n sendTransaction,\n signTypedDataWith,\n waitForTransactionResult,\n} from '@aave/client/viem';\nimport type { TransactionRequest } from '@aave/graphql';\nimport { invariant, type Signature } from '@aave/types';\nimport type { WalletClient } from 'viem';\nimport { useAaveClient } from '../context';\nimport {\n PendingTransaction,\n type UseAsyncTask,\n type UseSendTransactionResult,\n useAsyncTask,\n} from '../helpers';\n\n/**\n * A hook that provides a way to send Aave transactions using a viem WalletClient instance.\n *\n * Use the `useWalletClient` wagmi hook to get the `WalletClient` instance, then pass it to this hook to create a function that can be used to send transactions.\n *\n * ```ts\n * const { data: wallet } = useWalletClient(); // wagmi hook\n *\n * const [sendTransaction] = useSendTransaction(wallet);\n * ```\n *\n * @param walletClient - The wallet client to use for sending transactions.\n */\nexport function useSendTransaction(\n walletClient: WalletClient | null | undefined,\n): UseSendTransactionResult {\n const client = useAaveClient();\n\n return useAsyncTask(\n (request: TransactionRequest) => {\n invariant(\n walletClient,\n 'Expected a WalletClient to handle the operation result.',\n );\n\n return ensureChain(client, walletClient, request)\n .andThen(() => sendTransaction(walletClient, request))\n .map(\n (hash) =>\n new PendingTransaction(() =>\n waitForTransactionResult(walletClient, request, hash),\n ),\n );\n },\n [client, walletClient],\n );\n}\n\n/**\n * A hook that provides a way to sign EIP-712 typed data (ERC-20 permits, swap intents, etc.)\n * using a viem WalletClient instance.\n *\n * ```ts\n * const { data: wallet } = useWalletClient(); // wagmi hook\n * const [signTypedData, { loading, error, data }] = useSignTypedData(wallet);\n * ```\n */\nexport function useSignTypedData(\n walletClient: WalletClient | null | undefined,\n): UseAsyncTask<TypedData, Signature, SignTypedDataError> {\n return useAsyncTask(\n (typedData: TypedData) => {\n invariant(walletClient, 'Expected a WalletClient to sign typed data');\n\n return signTypedDataWith(walletClient, typedData);\n },\n [walletClient],\n );\n}\n","import type { CurrencyQueryOptions } from '@aave/client';\nimport { exchangeRate, chain as fetchChain } from '@aave/client/actions';\nimport type { UnexpectedError } from '@aave/core';\nimport type { Chain, ExchangeAmount, ExchangeRateRequest } from '@aave/graphql';\nimport {\n type ActivityItem,\n ChainQuery,\n type ChainRequest,\n ChainsFilter,\n ChainsQuery,\n type ChainsRequest,\n ExchangeRateQuery,\n type NativeAmount,\n type PreviewAction,\n} from '@aave/graphql';\nimport type { NullishDeep, Prettify } from '@aave/types';\nimport { useAaveClient } from './context';\nimport {\n type Pausable,\n type PausableReadResult,\n type PausableSuspenseResult,\n type ReadResult,\n type Suspendable,\n type SuspendableResult,\n type SuspenseResult,\n useSuspendableQuery,\n} from './helpers';\nimport { type UseAsyncTask, useAsyncTask } from './helpers/tasks';\n\nexport type UseChainArgs = ChainRequest;\n\n/**\n * Fetch a specific chain by chain ID.\n *\n * This signature supports React Suspense:\n *\n * ```tsx\n * const { data } = useChain({\n * chainId: chainId(1),\n * suspense: true,\n * });\n * // data will be Chain | null\n * ```\n */\nexport function useChain(\n args: UseChainArgs & Suspendable,\n): SuspenseResult<Chain | null>;\n/**\n * Fetch a specific chain by chain ID.\n *\n * Pausable suspense mode.\n *\n * ```tsx\n * const { data } = useChain({\n * chainId: chainId(1),\n * suspense: true,\n * pause: true,\n * });\n * ```\n */\nexport function useChain(\n args: Pausable<UseChainArgs> & Suspendable,\n): PausableSuspenseResult<Chain | null>;\n/**\n * Fetch a specific chain by chain ID.\n *\n * ```tsx\n * const { data, error, loading } = useChain({\n * chainId: chainId(1),\n * });\n * // data will be Chain | null\n * ```\n */\nexport function useChain(args: UseChainArgs): ReadResult<Chain | null>;\n/**\n * Fetch a specific chain by chain ID.\n *\n * Pausable loading state mode.\n *\n * ```tsx\n * const { data, error, loading, paused } = useChain({\n * chainId: chainId(1),\n * pause: true,\n * });\n * ```\n */\nexport function useChain(\n args: Pausable<UseChainArgs>,\n): PausableReadResult<Chain | null>;\n\nexport function useChain({\n suspense = false,\n pause = false,\n ...request\n}: NullishDeep<UseChainArgs> & {\n suspense?: boolean;\n pause?: boolean;\n}): SuspendableResult<Chain | null, UnexpectedError> {\n return useSuspendableQuery({\n document: ChainQuery,\n variables: {\n request,\n },\n suspense,\n pause,\n });\n}\n\n/**\n * Low-level hook to execute a {@link chain} action directly.\n *\n * @experimental This hook is experimental and may be subject to breaking changes.\n * @remarks\n * This hook **does not** actively watch for updated data on the chain.\n * Use this hook to retrieve data on demand as part of a larger workflow\n * (e.g., in an event handler in order to move to the next step).\n *\n * ```ts\n * const [execute, { called, data, error, loading }] = useChainAction();\n *\n * // …\n *\n * const result = await execute({\n * chainId: chainId(1),\n * });\n *\n * if (result.isOk()) {\n * console.log(result.value); // Chain | null\n * } else {\n * console.error(result.error);\n * }\n * ```\n */\nexport function useChainAction(): UseAsyncTask<\n ChainRequest,\n Chain | null,\n UnexpectedError\n> {\n const client = useAaveClient();\n\n return useAsyncTask(\n (request: ChainRequest) =>\n fetchChain(client, request, {\n batch: false,\n requestPolicy: 'cache-first',\n }),\n [client],\n );\n}\n\nexport type UseChainsArgs = ChainsRequest;\n/**\n * Fetches the list of supported chains.\n *\n * This signature supports React Suspense:\n *\n * ```tsx\n * const { data } = useChains({\n * query: { filter: ChainsFilter.ALL },\n * suspense: true,\n * });\n * ```\n */\nexport function useChains(\n args: UseChainsArgs & Suspendable,\n): SuspenseResult<Chain[]>;\n/**\n * Fetches the list of supported chains.\n *\n * Pausable suspense mode.\n *\n * ```tsx\n * const { data } = useChains({\n * query: { filter: ChainsFilter.ALL },\n * suspense: true,\n * pause: true,\n * });\n * ```\n */\nexport function useChains(\n args: Pausable<UseChainsArgs> & Suspendable,\n): PausableSuspenseResult<Chain[]>;\n/**\n * Fetches the list of supported chains.\n *\n * ```tsx\n * const { data, error, loading } = useChains({\n * query: { filter: ChainsFilter.ALL },\n * });\n * ```\n */\nexport function useChains(args?: UseChainsArgs): ReadResult<Chain[]>;\n/**\n * Fetches the list of supported chains.\n *\n * Pausable loading state mode.\n *\n * ```tsx\n * const { data, error, loading, paused } = useChains({\n * query: { filter: ChainsFilter.ALL },\n * pause: true,\n * });\n * ```\n */\nexport function useChains(\n args?: Pausable<UseChainsArgs>,\n): PausableReadResult<Chain[]>;\n\nexport function useChains(\n {\n suspense = false,\n pause = false,\n ...request\n }: NullishDeep<UseChainsArgs> & {\n suspense?: boolean;\n pause?: boolean;\n } = { query: { filter: ChainsFilter.ALL } },\n): SuspendableResult<Chain[], UnexpectedError> {\n return useSuspendableQuery({\n document: ChainsQuery,\n variables: { request },\n suspense,\n pause,\n });\n}\n\n/**\n * Fetches exchange rates between tokens and fiat currencies.\n *\n * ```tsx\n * const [getExchangeRate, gettingRate] = useExchangeRateAction();\n *\n * const loading = gettingRate.loading;\n * const error = gettingRate.error;\n *\n * // …\n *\n * const result = await getExchangeRate({\n * from: { erc20: { chainId: chainId(1), address: evmAddress('0xA0b86a33E6...') } },\n * to: Currency.Usd,\n * });\n *\n * if (result.isErr()) {\n * console.error(result.error);\n * return;\n * }\n *\n * console.log('Exchange rate:', result.value);\n * ```\n */\nexport function useExchangeRateAction(): UseAsyncTask<\n ExchangeRateRequest,\n ExchangeAmount,\n UnexpectedError\n> {\n const client = useAaveClient();\n\n return useAsyncTask(\n (request: ExchangeRateRequest) =>\n exchangeRate(client, request, { requestPolicy: 'network-only' }),\n [client],\n );\n}\n\nexport type UseExchangeRateArgs = ExchangeRateRequest;\n\n/**\n * Fetches exchange rates between tokens and fiat currencies with automatic polling.\n *\n * This signature supports React Suspense:\n *\n * ```tsx\n * const { data } = useExchangeRate({\n * from: {\n * erc20: {\n * chainId: chainId(1),\n * address: evmAddress('0xA0b86a33E6...')\n * }\n * },\n * to: Currency.Usd,\n * suspense: true,\n * });\n * ```\n */\nexport function useExchangeRate(\n args: UseExchangeRateArgs & Suspendable,\n): SuspenseResult<ExchangeAmount>;\n/**\n * Fetches exchange rates between tokens and fiat currencies with automatic polling.\n *\n * Pausable suspense mode.\n *\n * ```tsx\n * const { data } = useExchangeRate({\n * from: {\n * erc20: {\n * chainId: chainId(1),\n * address: evmAddress('0xA0b86a33E6...')\n * }\n * },\n * to: Currency.Usd,\n * suspense: true,\n * pause: true,\n * });\n * ```\n */\nexport function useExchangeRate(\n args: Pausable<UseExchangeRateArgs> & Suspendable,\n): PausableSuspenseResult<ExchangeAmount>;\n/**\n * Fetches exchange rates between tokens and fiat currencies with automatic polling.\n *\n * ```tsx\n * const { data, error, loading } = useExchangeRate({\n * from: {\n * erc20: {\n * chainId: chainId(1),\n * address: evmAddress('0xA0b86a33E6...')\n * }\n * },\n * to: Currency.Usd,\n * });\n *\n * <Component value={somewhere} fxRate={data} />\n * ```\n */\nexport function useExchangeRate(\n args: UseExchangeRateArgs,\n): ReadResult<ExchangeAmount>;\n/**\n * Fetches exchange rates between tokens and fiat currencies with automatic polling.\n *\n * Pausable loading state mode.\n *\n * ```tsx\n * const { data, error, loading, paused } = useExchangeRate({\n * from: {\n * erc20: {\n * chainId: chainId(1),\n * address: evmAddress('0xA0b86a33E6...')\n * }\n * },\n * to: Currency.Usd,\n * pause: true,\n * });\n * ```\n */\nexport function useExchangeRate(\n args: Pausable<UseExchangeRateArgs>,\n): PausableReadResult<ExchangeAmount>;\n\nexport function useExchangeRate({\n suspense = false,\n pause = false,\n ...request\n}: NullishDeep<UseExchangeRateArgs> & {\n suspense?: boolean;\n pause?: boolean;\n}): SuspendableResult<ExchangeAmount, UnexpectedError> {\n const client = useAaveClient();\n\n return useSuspendableQuery({\n document: ExchangeRateQuery,\n variables: { request },\n suspense,\n pause,\n pollInterval: request.at\n ? 0\n : client.context.environment.exchangeRateInterval,\n });\n}\n\nexport type UseNetworkFeeRequestQuery =\n | {\n activity: ActivityItem;\n }\n | {\n estimate: PreviewAction;\n };\n\nexport type UseNetworkFeeArgs = Prettify<\n {\n query: UseNetworkFeeRequestQuery;\n } & CurrencyQueryOptions\n>;\n\ntype PausableUseNetworkFeeArgs = Partial<\n {\n query: Partial<UseNetworkFeeRequestQuery>;\n } & CurrencyQueryOptions\n>;\n\n/**\n * Fetch the network fee for an ActivityItem.\n *\n * @experimental This hook is experimental and may be subject to breaking changes.\n */\nexport type UseNetworkFee<T extends NativeAmount = NativeAmount> =\n /**\n * Fetches the network fee for a past ActivityItem.\n *\n * This signature supports React Suspense:\n *\n * ```tsx\n * const { data } = useNetworkFee({\n * query: { activity },\n * suspense: true,\n * });\n *\n * data: NativeAmount\n * ```\n */\n ((args: UseNetworkFeeArgs & Suspendable) => SuspenseResult<T>) &\n /**\n * Fetches the network fee for a past ActivityItem.\n *\n * Pausable suspense mode.\n *\n * ```tsx\n * const { data, paused } = useNetworkFee({\n * query: { activity },\n * suspense: true,\n * pause: true,\n * });\n *\n * data: NativeAmount | undefined\n * ```\n */\n ((\n args: Pausable<UseNetworkFeeArgs, PausableUseNetworkFeeArgs> &\n Suspendable,\n ) => PausableSuspenseResult<T>) &\n /**\n * Fetches the network fee for a past ActivityItem.\n *\n * ```tsx\n * const { data, error, loading } = useNetworkFee({\n * query: { activity },\n * });\n * ```\n */\n ((args: UseNetworkFeeArgs) => ReadResult<T>) &\n /**\n * Fetches the network fee for a past ActivityItem.\n *\n * Pausable loading state mode.\n *\n * ```tsx\n * const { data, error, loading, paused } = useNetworkFee({\n * query: { activity },\n * pause: true,\n * });\n *\n * data: NativeAmount | undefined\n * ```\n */\n ((\n args: Pausable<UseNetworkFeeArgs, PausableUseNetworkFeeArgs>,\n ) => PausableReadResult<T>);\n","import { type AaveClient, UnexpectedError } from '@aave/client';\nimport { chain as fetchChain } from '@aave/client/actions';\nimport { toViemChain } from '@aave/client/viem';\nimport {\n type Chain,\n Currency,\n type DecimalNumber,\n decodeReserveId,\n decodeUserPositionId,\n type ExchangeAmount,\n type NativeAmount,\n type PreviewAction,\n} from '@aave/graphql';\nimport {\n bigDecimal,\n type ChainId,\n invariant,\n never,\n nonNullable,\n okAsync,\n ResultAsync,\n RoundingMode,\n} from '@aave/types';\nimport { useEffect } from 'react';\nimport { createPublicClient, http } from 'viem';\nimport { useAaveClient } from '../context';\nimport {\n ReadResult,\n type SuspendableResult,\n type UseAsyncTask,\n useAsyncTask,\n} from '../helpers';\nimport {\n type UseNetworkFee,\n type UseNetworkFeeRequestQuery,\n useExchangeRate,\n} from '../misc';\n\nconst estimatedApprovalGas = 55_558n;\n\nconst gasEstimates: Record<keyof PreviewAction, bigint> = {\n supply: 132_136n + estimatedApprovalGas,\n borrow: 250_551n,\n withdraw: 195_049n,\n repay: 217_889n + estimatedApprovalGas,\n setUserSuppliesAsCollateral: 240_284n,\n updateUserPositionConditions: 280_000n,\n};\n\nfunction inferGasEstimate(action: PreviewAction): bigint {\n const key = Object.keys(action)[0] as keyof PreviewAction;\n return gasEstimates[key] ?? never(`Expected gas estimate for action ${key}`);\n}\n\nfunction extractChainId(action: PreviewAction): ChainId {\n if ('supply' in action) {\n return decodeReserveId(action.supply.reserve).chainId;\n }\n\n if ('borrow' in action) {\n return decodeReserveId(action.borrow.reserve).chainId;\n }\n\n if ('withdraw' in action) {\n return decodeReserveId(action.withdraw.reserve).chainId;\n }\n\n if ('repay' in action) {\n return decodeReserveId(action.repay.reserve).chainId;\n }\n\n if ('setUserSuppliesAsCollateral' in action) {\n return action.setUserSuppliesAsCollateral.changes\n .map(({ reserve }) => decodeReserveId(reserve))\n .reduce((prev, current) => {\n invariant(\n prev.chainId === current.chainId && prev.spoke === current.spoke,\n 'All reserves MUST on the same spoke',\n );\n return prev;\n }).chainId;\n }\n\n if ('updateUserPositionConditions' in action) {\n return decodeUserPositionId(\n action.updateUserPositionConditions.userPositionId,\n ).chainId;\n }\n\n never('Expected reserve id');\n}\n\nfunction inferChainId(query: UseNetworkFeeRequestQuery): ChainId | undefined {\n if ('activity' in query && query.activity) {\n return query.activity.chain.chainId;\n }\n\n if ('estimate' in query && query.estimate) {\n return extractChainId(query.estimate);\n }\n\n return undefined;\n}\n\nfunction inferTimestampForExchangeRateLookup(\n query: UseNetworkFeeRequestQuery,\n): Date | undefined {\n if ('activity' in query && query.activity) {\n return query.activity.timestamp;\n }\n return undefined; // i.e., now\n}\n\nfunction resolveChain(\n client: AaveClient,\n query: UseNetworkFeeRequestQuery,\n): ResultAsync<Chain, UnexpectedError> {\n if ('activity' in query && query.activity) {\n return okAsync(query.activity.chain);\n }\n\n if ('estimate' in query && query.estimate) {\n return fetchChain(client, {\n chainId: extractChainId(query.estimate),\n }).map(nonNullable);\n }\n\n return never('Expected chain');\n}\n\ntype ExecutionDetails = {\n chain: Chain;\n gasPrice: bigint;\n gasUnits: bigint;\n};\n\nfunction useExecutionDetails(): UseAsyncTask<\n UseNetworkFeeRequestQuery,\n ExecutionDetails,\n UnexpectedError\n> {\n const client = useAaveClient();\n\n return useAsyncTask(\n (query) =>\n resolveChain(client, query).andThen((chain) => {\n const publicClient = createPublicClient({\n chain: toViemChain(chain),\n transport: http(),\n });\n\n if ('activity' in query && query.activity.txHash) {\n return ResultAsync.fromPromise(\n publicClient.getTransactionReceipt({ hash: query.activity.txHash }),\n (error) => UnexpectedError.from(error),\n ).map((receipt) => {\n return {\n chain: query.activity.chain,\n gasPrice: receipt.effectiveGasPrice,\n gasUnits: receipt.gasUsed,\n };\n });\n }\n\n if ('estimate' in query && query.estimate) {\n return ResultAsync.fromPromise(\n publicClient.estimateFeesPerGas(),\n (error) => UnexpectedError.from(error),\n ).map(({ maxFeePerGas }) => {\n return {\n chain,\n gasPrice: maxFeePerGas,\n gasUnits: inferGasEstimate(query.estimate),\n };\n });\n }\n\n return okAsync({\n chain: never('Expected chain'),\n gasPrice: 0n,\n gasUnits: 0n,\n });\n }),\n [client],\n );\n}\n\nfunction createNetworkFeeAmount(\n details: ExecutionDetails,\n rate: ExchangeAmount,\n): NativeAmount {\n const gasCostInWei = details.gasPrice * details.gasUnits;\n const gasCost = bigDecimal(gasCostInWei).rescale(\n -details.chain.nativeInfo.decimals,\n );\n\n const amount: DecimalNumber = {\n __typename: 'DecimalNumber',\n decimals: details.chain.nativeInfo.decimals,\n onChainValue: gasCostInWei,\n value: gasCost,\n };\n\n return {\n __typename: 'NativeAmount',\n token: {\n __typename: 'NativeToken',\n info: details.chain.nativeInfo,\n chain: details.chain,\n },\n amount,\n exchange: {\n __typename: 'ExchangeAmount',\n value: gasCost.mul(rate.value),\n name: rate.name,\n symbol: rate.symbol,\n icon: rate.icon,\n decimals: rate.decimals,\n },\n exchangeRate: {\n __typename: 'DecimalNumber',\n decimals: 2,\n onChainValue: BigInt(rate.value.rescale(2).toFixed(0, RoundingMode.Down)),\n value: rate.value,\n },\n };\n}\n\n/**\n * Fetch the network fee for an ActivityItem or estimates networkf feed for a preview action.\n *\n * @experimental This hook is experimental and may be subject to breaking changes.\n */\nexport const useNetworkFee: UseNetworkFee = (({\n query,\n currency = Currency.Usd,\n pause = false,\n suspense = false,\n}: {\n query: UseNetworkFeeRequestQuery;\n currency?: Currency;\n pause?: boolean;\n suspense?: boolean;\n}): SuspendableResult<NativeAmount, UnexpectedError> => {\n const [fetchDetails, details] = useExecutionDetails();\n\n const rate = useExchangeRate({\n from: {\n native: inferChainId(query),\n },\n to: currency,\n at: inferTimestampForExchangeRateLookup(query),\n pause,\n ...(suspense ? { suspense } : {}),\n });\n const metadata = rate.metadata;\n\n // biome-ignore lint/correctness/useExhaustiveDependencies: query omitted since it's usually a literal object that changes at every render\n useEffect(() => {\n if (pause || details.called || !query) return;\n\n fetchDetails(query);\n }, [fetchDetails, pause, details.called]);\n\n if (rate.paused) {\n return ReadResult.Paused(\n details.data && rate.data\n ? createNetworkFeeAmount(details.data, rate.data)\n : undefined,\n rate.error ? rate.error : undefined,\n metadata,\n );\n }\n\n if (!details.called || details.loading || rate.loading) {\n return ReadResult.Loading(metadata);\n }\n\n if (details.error || rate.error) {\n return ReadResult.Failure(\n details.error ?? rate.error ?? never('Unknown error'),\n metadata,\n );\n }\n\n invariant(\n details.data && rate.data,\n 'Expected receipt, chain, and rate data',\n );\n\n return ReadResult.Success(\n createNetworkFeeAmount(details.data, rate.data),\n metadata,\n );\n}) as UseNetworkFee;\n"]}
|
package/dist/viem/index.js
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
import {g as g$1,a as a$1}from'../chunk-
|
|
1
|
+
import {g as g$1,a as a$1}from'../chunk-V6Q6TCNV.js';import {b}from'../chunk-4NA4FB6K.js';import {a,c}from'../chunk-4LHXPD6N.js';import {ensureChain,sendTransaction,waitForTransactionResult,signTypedDataWith,toViemChain}from'@aave/client/viem';export{viemChainsFrom}from'@aave/client/viem';import {invariant,never,ResultAsync,okAsync,bigDecimal,RoundingMode,nonNullable}from'@aave/types';import {UnexpectedError}from'@aave/client';import {chain}from'@aave/client/actions';import {Currency,decodeReserveId,decodeUserPositionId}from'@aave/graphql';import {useEffect}from'react';import {createPublicClient,http}from'viem';function z(e){let t=b();return a(n=>(invariant(e,"Expected a WalletClient to handle the operation result."),ensureChain(t,e,n).andThen(()=>sendTransaction(e,n)).map(r=>new c(()=>waitForTransactionResult(e,n,r)))),[t,e])}function J(e){return a(t=>(invariant(e,"Expected a WalletClient to sign typed data"),signTypedDataWith(e,t)),[e])}var g=55558n,Q={supply:132136n+g,borrow:250551n,withdraw:195049n,repay:217889n+g,setUserSuppliesAsCollateral:240284n,updateUserPositionConditions:280000n};function G(e){let t=Object.keys(e)[0];return Q[t]??never(`Expected gas estimate for action ${t}`)}function C(e){if("supply"in e)return decodeReserveId(e.supply.reserve).chainId;if("borrow"in e)return decodeReserveId(e.borrow.reserve).chainId;if("withdraw"in e)return decodeReserveId(e.withdraw.reserve).chainId;if("repay"in e)return decodeReserveId(e.repay.reserve).chainId;if("setUserSuppliesAsCollateral"in e)return e.setUserSuppliesAsCollateral.changes.map(({reserve:t})=>decodeReserveId(t)).reduce((t,n)=>(invariant(t.chainId===n.chainId&&t.spoke===n.spoke,"All reserves MUST on the same spoke"),t)).chainId;if("updateUserPositionConditions"in e)return decodeUserPositionId(e.updateUserPositionConditions.userPositionId).chainId;never("Expected reserve id");}function V(e){if("activity"in e&&e.activity)return e.activity.chain.chainId;if("estimate"in e&&e.estimate)return C(e.estimate)}function H(e){if("activity"in e&&e.activity)return e.activity.timestamp}function L(e,t){return "activity"in t&&t.activity?okAsync(t.activity.chain):"estimate"in t&&t.estimate?chain(e,{chainId:C(t.estimate)}).map(nonNullable):never("Expected chain")}function M(){let e=b();return a(t=>L(e,t).andThen(n=>{let r=createPublicClient({chain:toViemChain(n),transport:http()});return "activity"in t&&t.activity.txHash?ResultAsync.fromPromise(r.getTransactionReceipt({hash:t.activity.txHash}),i=>UnexpectedError.from(i)).map(i=>({chain:t.activity.chain,gasPrice:i.effectiveGasPrice,gasUnits:i.gasUsed})):"estimate"in t&&t.estimate?ResultAsync.fromPromise(r.estimateFeesPerGas(),i=>UnexpectedError.from(i)).map(({maxFeePerGas:i})=>({chain:n,gasPrice:i,gasUnits:G(t.estimate)})):okAsync({chain:never("Expected chain"),gasPrice:0n,gasUnits:0n})}),[e])}function U(e,t){let n=e.gasPrice*e.gasUnits,r=bigDecimal(n).rescale(-e.chain.nativeInfo.decimals),i={__typename:"DecimalNumber",decimals:e.chain.nativeInfo.decimals,onChainValue:n,value:r};return {__typename:"NativeAmount",token:{__typename:"NativeToken",info:e.chain.nativeInfo,chain:e.chain},amount:i,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,RoundingMode.Down)),value:t.value}}}var se=(({query:e,currency:t=Currency.Usd,pause:n=false,suspense:r=false})=>{let[i,s]=M(),a=g$1({from:{native:V(e)},to:t,at:H(e),pause:n,...r?{suspense:r}:{}}),m=a.metadata;return useEffect(()=>{n||s.called||!e||i(e);},[i,n,s.called]),a.paused?a$1.Paused(s.data&&a.data?U(s.data,a.data):void 0,a.error?a.error:void 0,m):!s.called||s.loading||a.loading?a$1.Loading(m):s.error||a.error?a$1.Failure(s.error??a.error??never("Unknown error"),m):(invariant(s.data&&a.data,"Expected receipt, chain, and rate data"),a$1.Success(U(s.data,a.data),m))});export{se as useNetworkFee,z as useSendTransaction,J as useSignTypedData};//# sourceMappingURL=index.js.map
|
|
2
2
|
//# sourceMappingURL=index.js.map
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@aave/react",
|
|
3
|
-
"version": "4.0.0-next.
|
|
3
|
+
"version": "4.0.0-next.49",
|
|
4
4
|
"description": "The official React bindings for the Aave Protocol",
|
|
5
5
|
"keywords": [
|
|
6
6
|
"aave",
|
|
@@ -72,10 +72,10 @@
|
|
|
72
72
|
"sideEffects": false,
|
|
73
73
|
"dependencies": {
|
|
74
74
|
"urql": "^5.0.1",
|
|
75
|
-
"@aave/client": "4.0.0-next.
|
|
76
|
-
"@aave/
|
|
75
|
+
"@aave/client": "4.0.0-next.49",
|
|
76
|
+
"@aave/graphql": "1.0.0-next.34",
|
|
77
77
|
"@aave/core": "1.0.0-next.18",
|
|
78
|
-
"@aave/
|
|
78
|
+
"@aave/types": "1.0.0-next.8"
|
|
79
79
|
},
|
|
80
80
|
"devDependencies": {
|
|
81
81
|
"@privy-io/react-auth": "^2.20.0",
|
|
@@ -91,7 +91,7 @@
|
|
|
91
91
|
"tsup": "^8.5.1",
|
|
92
92
|
"typescript": "^5.9.2",
|
|
93
93
|
"vitest": "^3.2.4",
|
|
94
|
-
"viem": "^2.
|
|
94
|
+
"viem": "^2.47.0"
|
|
95
95
|
},
|
|
96
96
|
"peerDependencies": {
|
|
97
97
|
"@privy-io/react-auth": "^2.20.0",
|
|
@@ -100,7 +100,7 @@
|
|
|
100
100
|
"react": "^19.1.0",
|
|
101
101
|
"react-dom": "^19.1.0",
|
|
102
102
|
"thirdweb": "^5.105.25",
|
|
103
|
-
"viem": "^2.
|
|
103
|
+
"viem": "^2.47.0"
|
|
104
104
|
},
|
|
105
105
|
"peerDependenciesMeta": {
|
|
106
106
|
"@privy-io/react-auth": {
|
package/dist/chunk-IHI6MHZW.js
DELETED
|
@@ -1,2 +0,0 @@
|
|
|
1
|
-
import {b}from'./chunk-4NA4FB6K.js';import {a}from'./chunk-4LHXPD6N.js';import {chain,exchangeRate}from'@aave/client/actions';import {ChainsFilter,ChainQuery,ChainsQuery,ExchangeRateQuery}from'@aave/graphql';import {UnexpectedError}from'@aave/client';import {ok,invariant}from'@aave/types';import {useState,useMemo,useEffect}from'react';import {createRequest,useQuery}from'urql';var n={Loading:e=>({data:void 0,error:void 0,loading:true,paused:false,reloading:false,metadata:e}),Success:(e,a,t=false)=>({data:e,error:void 0,loading:false,paused:false,reloading:t,metadata:a}),Failure:(e,a,t=false)=>({data:void 0,error:e,loading:false,paused:false,reloading:t,metadata:a}),Paused:(e,a,t)=>({data:e,error:a,loading:false,paused:true,reloading:false,metadata:t})};function y({document:e,variables:a,suspense:t,pause:s,selector:S=ok,pollInterval:b=0,batch:h=true}){let[u,E]=useState({operationKey:0,resultOperationKey:void 0}),[m,Q]=useState(true),P=useMemo(()=>createRequest(e,a).key,[e,a]),[{fetching:o,data:l,error:d,stale:R},A]=useQuery({query:e,variables:a,pause:s,context:useMemo(()=>({batch:h,suspense:t}),[h,t])});if(useEffect(()=>{E(r=>({...r,operationKey:P}));},[P]),useEffect(()=>{s||o||Q(false);},[o,s]),useEffect(()=>{s||o||E(r=>({...r,resultOperationKey:l&&!R?r.operationKey:r.resultOperationKey}));},[s,o,l,R]),useEffect(()=>{if(b<=0||o||s)return;let r=setTimeout(()=>{A({requestPolicy:"network-only",batch:false});},b);return ()=>clearTimeout(r)},[o,A,b,s]),s){let r=d?UnexpectedError.from(d):void 0;if(!l)return n.Paused(void 0,r,u);let x=S(l.value);return x.isErr()?n.Paused(void 0,x.error,u):n.Paused(x.value,r,u)}if(!t&&m)return n.Loading(u);let f=R||!m&&o;if(d){let r=UnexpectedError.from(d);if(t)throw r;return n.Failure(r,u,f)}invariant(l,"No data returned");let i=S(l.value);if(i.isErr()){if(t)throw i.error;return n.Failure(i.error,u,f)}return n.Success(i.value,u,f)}function Z({suspense:e=false,pause:a=false,...t}){return y({document:ChainQuery,variables:{request:t},suspense:e,pause:a})}function _(){let e=b();return a(a=>chain(e,a,{batch:false,requestPolicy:"cache-first"}),[e])}function $({suspense:e=false,pause:a=false,...t}={query:{filter:ChainsFilter.ALL}}){return y({document:ChainsQuery,variables:{request:t},suspense:e,pause:a})}function ee(){let e=b();return a(a=>exchangeRate(e,a,{requestPolicy:"network-only"}),[e])}function ae({suspense:e=false,pause:a=false,...t}){let s=b();return y({document:ExchangeRateQuery,variables:{request:t},suspense:e,pause:a,pollInterval:t.at?0:s.context.environment.exchangeRateInterval})}export{n as a,y as b,Z as c,_ as d,$ as e,ee as f,ae as g};//# sourceMappingURL=chunk-IHI6MHZW.js.map
|
|
2
|
-
//# sourceMappingURL=chunk-IHI6MHZW.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/helpers/results.ts","../src/helpers/reads.ts","../src/misc.ts"],"names":["ReadResult","metadata","data","reloading","error","useSuspendableQuery","document","variables","suspense","pause","selector","ok","pollInterval","batch","setMetadata","useState","loading","setLoading","operationId","useMemo","createRequest","fetching","stale","executeQuery","useQuery","useEffect","current","timerId","unexpectedError","UnexpectedError","selected","unexpected","invariant","useChain","request","ChainQuery","useChainAction","client","useAaveClient","useAsyncTask","fetchChain","useChains","ChainsFilter","ChainsQuery","useExchangeRateAction","exchangeRate","useExchangeRate","ExchangeRateQuery"],"mappings":"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","file":"chunk-IHI6MHZW.js","sourcesContent":["import type { UnexpectedError } from '@aave/client';\n\n/**\n * @internal\n */\nexport type QueryMetadata = {\n operationKey: number;\n resultOperationKey: number | undefined;\n};\n\n/**\n * A read hook result.\n *\n * It's a discriminated union of the possible results of a read operation:\n * - Rely on the `loading` value to determine if the `data` or `error` can be evaluated.\n * - If `error` is `undefined`, then `data` value will be available.\n */\nexport type ReadResult<T, E = UnexpectedError> =\n | {\n data: undefined;\n error: undefined;\n loading: true;\n reloading: false;\n /**\n * @internal\n */\n metadata: QueryMetadata;\n }\n | {\n data: T;\n error: undefined;\n loading: false;\n reloading: boolean;\n /**\n * @internal\n */\n metadata: QueryMetadata;\n }\n | {\n data: undefined;\n error: E;\n loading: false;\n reloading: boolean;\n /**\n * @internal\n */\n metadata: QueryMetadata;\n };\n\n/**\n * A read hook result that supports pausing.\n */\nexport type PausableReadResult<T, E = UnexpectedError> =\n | {\n data: T | undefined;\n error: E | undefined;\n loading: false;\n paused: true;\n reloading: false;\n /**\n * @internal\n */\n metadata: QueryMetadata;\n }\n | {\n data: undefined;\n error: undefined;\n loading: true;\n paused: false;\n reloading: false;\n /**\n * @internal\n */\n metadata: QueryMetadata;\n }\n | {\n data: T;\n error: undefined;\n loading: false;\n paused: false;\n reloading: boolean;\n /**\n * @internal\n */\n metadata: QueryMetadata;\n }\n | {\n data: undefined;\n error: E;\n loading: false;\n paused: false;\n reloading: boolean;\n /**\n * @internal\n */\n metadata: QueryMetadata;\n };\n\n/**\n * @internal\n */\nexport const ReadResult = {\n Loading: <T, E = UnexpectedError>(\n metadata: QueryMetadata,\n ): PausableReadResult<T, E> => ({\n data: undefined,\n error: undefined,\n loading: true,\n paused: false,\n reloading: false,\n metadata,\n }),\n Success: <T, E = UnexpectedError>(\n data: T,\n metadata: QueryMetadata,\n reloading = false,\n ): PausableReadResult<T, E> => ({\n data,\n error: undefined,\n loading: false,\n paused: false,\n reloading,\n metadata,\n }),\n Failure: <T, E = UnexpectedError>(\n error: E,\n metadata: QueryMetadata,\n reloading = false,\n ): PausableReadResult<T, E> => ({\n data: undefined,\n error,\n loading: false,\n paused: false,\n reloading,\n metadata,\n }),\n Paused: <T, E = UnexpectedError>(\n data: T | undefined,\n error: E | undefined,\n metadata: QueryMetadata,\n ): PausableReadResult<T, E> => ({\n data,\n error,\n loading: false,\n paused: true,\n reloading: false,\n metadata,\n }),\n};\n\n/**\n * A read hook result that supports React Suspense.\n */\nexport type SuspenseResult<T> = {\n data: T;\n /**\n * @internal\n */\n metadata: QueryMetadata;\n};\n\n/**\n * A read hook result that supports React Suspense and can be paused.\n */\nexport type PausableSuspenseResult<T> =\n | {\n paused: true;\n data: undefined;\n /**\n * @internal\n */\n metadata: QueryMetadata;\n }\n | {\n paused: false;\n data: T;\n /**\n * @internal\n */\n metadata: QueryMetadata;\n };\n\nexport type SuspendableResult<T, E = UnexpectedError> =\n | ReadResult<T, E>\n | SuspenseResult<T>\n | PausableReadResult<T, E>\n | PausableSuspenseResult<T>;\n","import { type StandardData, UnexpectedError } from '@aave/client';\nimport {\n type AnyVariables,\n invariant,\n type NullishDeep,\n ok,\n type Prettify,\n type Result,\n} from '@aave/types';\nimport { useEffect, useMemo, useState } from 'react';\nimport { createRequest, type TypedDocumentNode, useQuery } from 'urql';\nimport {\n type PausableReadResult,\n type PausableSuspenseResult,\n type QueryMetadata,\n ReadResult,\n type SuspendableResult,\n type SuspenseResult,\n} from './results';\n\nexport type Selector<ResponseValue, SelectorData, SelectorError> = (\n data: ResponseValue,\n) => Result<SelectorData, SelectorError>;\n\nexport type Pausable<T, WhenPaused = NullishDeep<T>> = Prettify<\n WhenPaused & {\n /**\n * Prevents the hook from automatically executing GraphQL query operations.\n *\n * @experimental This is an experimental feature and may change in the future.\n *\n * @remarks\n * `pause` may be set to `true` to stop the query operation from executing\n * automatically. The hook will stop receiving updates and won't execute the query\n * operation until it's set to `false`.\n */\n pause: boolean;\n }\n>;\n\nexport type Suspendable = { suspense: true };\n\n/**\n * @internal\n */\nexport type UseSuspendableQueryArgs<\n ResponseValue,\n SelectorData,\n SelectorError,\n Variables extends AnyVariables,\n Suspense extends boolean,\n Pause extends boolean = never,\n> = {\n document: TypedDocumentNode<StandardData<ResponseValue>, Variables>;\n variables?: Pause extends boolean ? NullishDeep<Variables> : Variables;\n suspense: Suspense;\n selector?: Selector<ResponseValue, SelectorData, SelectorError>;\n pollInterval?: number;\n batch?: boolean;\n pause?: Pause;\n};\n\n/**\n * @internal\n */\nexport function useSuspendableQuery<\n ResponseValue,\n SelectorData,\n SelectorError,\n Variables extends AnyVariables,\n Pausable extends boolean = never,\n>({\n document,\n variables,\n suspense,\n pause,\n}: UseSuspendableQueryArgs<\n ResponseValue,\n SelectorData,\n SelectorError,\n Variables,\n false,\n Pausable\n>):\n | ReadResult<SelectorData, SelectorError | UnexpectedError>\n | PausableReadResult<SelectorData, SelectorError | UnexpectedError>;\n/**\n * @internal\n */\nexport function useSuspendableQuery<\n ResponseValue,\n SelectorData,\n SelectorError,\n Variables extends AnyVariables,\n Pausable extends boolean = never,\n>({\n document,\n variables,\n suspense,\n pause,\n}: UseSuspendableQueryArgs<\n ResponseValue,\n SelectorData,\n SelectorError,\n Variables,\n true,\n Pausable\n>): SuspenseResult<SelectorData> | PausableSuspenseResult<SelectorData>;\n/**\n * @internal\n */\nexport function useSuspendableQuery<\n ResponseValue,\n SelectorData,\n SelectorError,\n Variables extends AnyVariables,\n Pausable extends boolean = never,\n>({\n document,\n variables,\n suspense,\n pause,\n}: UseSuspendableQueryArgs<\n ResponseValue,\n SelectorData,\n SelectorError,\n Variables,\n boolean,\n Pausable\n>): SuspendableResult<SelectorData, SelectorError | UnexpectedError>;\n/**\n * Implementation.\n */\nexport function useSuspendableQuery<\n ResponseValue,\n SelectorData,\n SelectorError,\n Variables extends AnyVariables,\n>({\n document,\n variables,\n suspense,\n pause,\n selector = ok as Selector<ResponseValue, SelectorData, SelectorError>,\n pollInterval = 0,\n batch = true,\n}: UseSuspendableQueryArgs<\n ResponseValue,\n SelectorData,\n SelectorError,\n Variables,\n boolean,\n boolean\n>): SuspendableResult<SelectorData, SelectorError | UnexpectedError> {\n const [metadata, setMetadata] = useState<QueryMetadata>({\n operationKey: 0,\n resultOperationKey: undefined,\n });\n const [loading, setLoading] = useState(true);\n const operationId = useMemo(\n () => createRequest(document, variables as Variables).key,\n [document, variables],\n );\n const [{ fetching, data, error, stale }, executeQuery] = useQuery({\n query: document,\n variables: variables as Variables,\n pause,\n context: useMemo(\n () => ({\n batch,\n suspense,\n }),\n [batch, suspense],\n ),\n });\n\n useEffect(() => {\n setMetadata((current) => ({\n ...current,\n operationKey: operationId,\n }));\n }, [operationId]);\n\n useEffect(() => {\n if (pause) return;\n\n if (!fetching) {\n setLoading(false);\n }\n }, [fetching, pause]);\n\n useEffect(() => {\n if (pause || fetching) {\n return;\n }\n\n setMetadata((current) => ({\n ...current,\n resultOperationKey:\n data && !stale ? current.operationKey : current.resultOperationKey,\n }));\n }, [pause, fetching, data, stale]);\n\n useEffect(() => {\n if (pollInterval <= 0 || fetching || pause) return undefined;\n\n const timerId = setTimeout(() => {\n executeQuery({\n requestPolicy: 'network-only',\n batch: false, // never batch, run now!\n });\n }, pollInterval);\n\n return () => clearTimeout(timerId);\n }, [fetching, executeQuery, pollInterval, pause]);\n\n if (pause) {\n const unexpectedError = error ? UnexpectedError.from(error) : undefined;\n\n if (!data) {\n return ReadResult.Paused<SelectorData, SelectorError | UnexpectedError>(\n undefined,\n unexpectedError,\n metadata,\n );\n }\n\n const selected = selector(data.value);\n\n if (selected.isErr()) {\n return ReadResult.Paused<SelectorData, SelectorError>(\n undefined,\n selected.error,\n metadata,\n );\n }\n\n return ReadResult.Paused<SelectorData, UnexpectedError>(\n selected.value,\n unexpectedError,\n metadata,\n );\n }\n\n if (!suspense && loading) {\n return ReadResult.Loading(metadata);\n }\n\n // stale indicates that the useQuery is fetching new data because the variables changed\n // !loading && fetching indicates that a re-fetch is happening as consequence of calling executeQuery (e.g., polling)\n const reloading = stale || (!loading && fetching);\n\n if (error) {\n const unexpected = UnexpectedError.from(error);\n if (suspense) {\n throw unexpected;\n }\n\n return ReadResult.Failure(unexpected, metadata, reloading);\n }\n\n invariant(data, 'No data returned');\n\n const selected = selector(data.value);\n\n if (selected.isErr()) {\n if (suspense) {\n throw selected.error;\n }\n return ReadResult.Failure(selected.error, metadata, reloading);\n }\n\n return ReadResult.Success(selected.value, metadata, reloading);\n}\n","import type { CurrencyQueryOptions } from '@aave/client';\nimport { exchangeRate, chain as fetchChain } from '@aave/client/actions';\nimport type { UnexpectedError } from '@aave/core';\nimport type { Chain, ExchangeAmount, ExchangeRateRequest } from '@aave/graphql';\nimport {\n type ActivityItem,\n ChainQuery,\n type ChainRequest,\n ChainsFilter,\n ChainsQuery,\n type ChainsRequest,\n ExchangeRateQuery,\n type NativeAmount,\n type PreviewAction,\n} from '@aave/graphql';\nimport type { NullishDeep, Prettify } from '@aave/types';\nimport { useAaveClient } from './context';\nimport {\n type Pausable,\n type PausableReadResult,\n type PausableSuspenseResult,\n type ReadResult,\n type Suspendable,\n type SuspendableResult,\n type SuspenseResult,\n useSuspendableQuery,\n} from './helpers';\nimport { type UseAsyncTask, useAsyncTask } from './helpers/tasks';\n\nexport type UseChainArgs = ChainRequest;\n\n/**\n * Fetch a specific chain by chain ID.\n *\n * This signature supports React Suspense:\n *\n * ```tsx\n * const { data } = useChain({\n * chainId: chainId(1),\n * suspense: true,\n * });\n * // data will be Chain | null\n * ```\n */\nexport function useChain(\n args: UseChainArgs & Suspendable,\n): SuspenseResult<Chain | null>;\n/**\n * Fetch a specific chain by chain ID.\n *\n * Pausable suspense mode.\n *\n * ```tsx\n * const { data } = useChain({\n * chainId: chainId(1),\n * suspense: true,\n * pause: true,\n * });\n * ```\n */\nexport function useChain(\n args: Pausable<UseChainArgs> & Suspendable,\n): PausableSuspenseResult<Chain | null>;\n/**\n * Fetch a specific chain by chain ID.\n *\n * ```tsx\n * const { data, error, loading } = useChain({\n * chainId: chainId(1),\n * });\n * // data will be Chain | null\n * ```\n */\nexport function useChain(args: UseChainArgs): ReadResult<Chain | null>;\n/**\n * Fetch a specific chain by chain ID.\n *\n * Pausable loading state mode.\n *\n * ```tsx\n * const { data, error, loading, paused } = useChain({\n * chainId: chainId(1),\n * pause: true,\n * });\n * ```\n */\nexport function useChain(\n args: Pausable<UseChainArgs>,\n): PausableReadResult<Chain | null>;\n\nexport function useChain({\n suspense = false,\n pause = false,\n ...request\n}: NullishDeep<UseChainArgs> & {\n suspense?: boolean;\n pause?: boolean;\n}): SuspendableResult<Chain | null, UnexpectedError> {\n return useSuspendableQuery({\n document: ChainQuery,\n variables: {\n request,\n },\n suspense,\n pause,\n });\n}\n\n/**\n * Low-level hook to execute a {@link chain} action directly.\n *\n * @experimental This hook is experimental and may be subject to breaking changes.\n * @remarks\n * This hook **does not** actively watch for updated data on the chain.\n * Use this hook to retrieve data on demand as part of a larger workflow\n * (e.g., in an event handler in order to move to the next step).\n *\n * ```ts\n * const [execute, { called, data, error, loading }] = useChainAction();\n *\n * // …\n *\n * const result = await execute({\n * chainId: chainId(1),\n * });\n *\n * if (result.isOk()) {\n * console.log(result.value); // Chain | null\n * } else {\n * console.error(result.error);\n * }\n * ```\n */\nexport function useChainAction(): UseAsyncTask<\n ChainRequest,\n Chain | null,\n UnexpectedError\n> {\n const client = useAaveClient();\n\n return useAsyncTask(\n (request: ChainRequest) =>\n fetchChain(client, request, {\n batch: false,\n requestPolicy: 'cache-first',\n }),\n [client],\n );\n}\n\nexport type UseChainsArgs = ChainsRequest;\n/**\n * Fetches the list of supported chains.\n *\n * This signature supports React Suspense:\n *\n * ```tsx\n * const { data } = useChains({\n * query: { filter: ChainsFilter.ALL },\n * suspense: true,\n * });\n * ```\n */\nexport function useChains(\n args: UseChainsArgs & Suspendable,\n): SuspenseResult<Chain[]>;\n/**\n * Fetches the list of supported chains.\n *\n * Pausable suspense mode.\n *\n * ```tsx\n * const { data } = useChains({\n * query: { filter: ChainsFilter.ALL },\n * suspense: true,\n * pause: true,\n * });\n * ```\n */\nexport function useChains(\n args: Pausable<UseChainsArgs> & Suspendable,\n): PausableSuspenseResult<Chain[]>;\n/**\n * Fetches the list of supported chains.\n *\n * ```tsx\n * const { data, error, loading } = useChains({\n * query: { filter: ChainsFilter.ALL },\n * });\n * ```\n */\nexport function useChains(args?: UseChainsArgs): ReadResult<Chain[]>;\n/**\n * Fetches the list of supported chains.\n *\n * Pausable loading state mode.\n *\n * ```tsx\n * const { data, error, loading, paused } = useChains({\n * query: { filter: ChainsFilter.ALL },\n * pause: true,\n * });\n * ```\n */\nexport function useChains(\n args?: Pausable<UseChainsArgs>,\n): PausableReadResult<Chain[]>;\n\nexport function useChains(\n {\n suspense = false,\n pause = false,\n ...request\n }: NullishDeep<UseChainsArgs> & {\n suspense?: boolean;\n pause?: boolean;\n } = { query: { filter: ChainsFilter.ALL } },\n): SuspendableResult<Chain[], UnexpectedError> {\n return useSuspendableQuery({\n document: ChainsQuery,\n variables: { request },\n suspense,\n pause,\n });\n}\n\n/**\n * Fetches exchange rates between tokens and fiat currencies.\n *\n * ```tsx\n * const [getExchangeRate, gettingRate] = useExchangeRateAction();\n *\n * const loading = gettingRate.loading;\n * const error = gettingRate.error;\n *\n * // …\n *\n * const result = await getExchangeRate({\n * from: { erc20: { chainId: chainId(1), address: evmAddress('0xA0b86a33E6...') } },\n * to: Currency.Usd,\n * });\n *\n * if (result.isErr()) {\n * console.error(result.error);\n * return;\n * }\n *\n * console.log('Exchange rate:', result.value);\n * ```\n */\nexport function useExchangeRateAction(): UseAsyncTask<\n ExchangeRateRequest,\n ExchangeAmount,\n UnexpectedError\n> {\n const client = useAaveClient();\n\n return useAsyncTask(\n (request: ExchangeRateRequest) =>\n exchangeRate(client, request, { requestPolicy: 'network-only' }),\n [client],\n );\n}\n\nexport type UseExchangeRateArgs = ExchangeRateRequest;\n\n/**\n * Fetches exchange rates between tokens and fiat currencies with automatic polling.\n *\n * This signature supports React Suspense:\n *\n * ```tsx\n * const { data } = useExchangeRate({\n * from: {\n * erc20: {\n * chainId: chainId(1),\n * address: evmAddress('0xA0b86a33E6...')\n * }\n * },\n * to: Currency.Usd,\n * suspense: true,\n * });\n * ```\n */\nexport function useExchangeRate(\n args: UseExchangeRateArgs & Suspendable,\n): SuspenseResult<ExchangeAmount>;\n/**\n * Fetches exchange rates between tokens and fiat currencies with automatic polling.\n *\n * Pausable suspense mode.\n *\n * ```tsx\n * const { data } = useExchangeRate({\n * from: {\n * erc20: {\n * chainId: chainId(1),\n * address: evmAddress('0xA0b86a33E6...')\n * }\n * },\n * to: Currency.Usd,\n * suspense: true,\n * pause: true,\n * });\n * ```\n */\nexport function useExchangeRate(\n args: Pausable<UseExchangeRateArgs> & Suspendable,\n): PausableSuspenseResult<ExchangeAmount>;\n/**\n * Fetches exchange rates between tokens and fiat currencies with automatic polling.\n *\n * ```tsx\n * const { data, error, loading } = useExchangeRate({\n * from: {\n * erc20: {\n * chainId: chainId(1),\n * address: evmAddress('0xA0b86a33E6...')\n * }\n * },\n * to: Currency.Usd,\n * });\n *\n * <Component value={somewhere} fxRate={data} />\n * ```\n */\nexport function useExchangeRate(\n args: UseExchangeRateArgs,\n): ReadResult<ExchangeAmount>;\n/**\n * Fetches exchange rates between tokens and fiat currencies with automatic polling.\n *\n * Pausable loading state mode.\n *\n * ```tsx\n * const { data, error, loading, paused } = useExchangeRate({\n * from: {\n * erc20: {\n * chainId: chainId(1),\n * address: evmAddress('0xA0b86a33E6...')\n * }\n * },\n * to: Currency.Usd,\n * pause: true,\n * });\n * ```\n */\nexport function useExchangeRate(\n args: Pausable<UseExchangeRateArgs>,\n): PausableReadResult<ExchangeAmount>;\n\nexport function useExchangeRate({\n suspense = false,\n pause = false,\n ...request\n}: NullishDeep<UseExchangeRateArgs> & {\n suspense?: boolean;\n pause?: boolean;\n}): SuspendableResult<ExchangeAmount, UnexpectedError> {\n const client = useAaveClient();\n\n return useSuspendableQuery({\n document: ExchangeRateQuery,\n variables: { request },\n suspense,\n pause,\n pollInterval: request.at\n ? 0\n : client.context.environment.exchangeRateInterval,\n });\n}\n\nexport type UseNetworkFeeRequestQuery =\n | {\n activity: ActivityItem;\n }\n | {\n estimate: PreviewAction;\n };\n\nexport type UseNetworkFeeArgs = Prettify<\n {\n query: UseNetworkFeeRequestQuery;\n } & CurrencyQueryOptions\n>;\n\ntype PausableUseNetworkFeeArgs = Partial<\n {\n query: Partial<UseNetworkFeeRequestQuery>;\n } & CurrencyQueryOptions\n>;\n\n/**\n * Fetch the network fee for an ActivityItem.\n *\n * @experimental This hook is experimental and may be subject to breaking changes.\n */\nexport type UseNetworkFee<T extends NativeAmount = NativeAmount> =\n /**\n * Fetches the network fee for a past ActivityItem.\n *\n * This signature supports React Suspense:\n *\n * ```tsx\n * const { data } = useNetworkFee({\n * query: { activity },\n * suspense: true,\n * });\n *\n * data: NativeAmount\n * ```\n */\n ((args: UseNetworkFeeArgs & Suspendable) => SuspenseResult<T>) &\n /**\n * Fetches the network fee for a past ActivityItem.\n *\n * Pausable suspense mode.\n *\n * ```tsx\n * const { data, paused } = useNetworkFee({\n * query: { activity },\n * suspense: true,\n * pause: true,\n * });\n *\n * data: NativeAmount | undefined\n * ```\n */\n ((\n args: Pausable<UseNetworkFeeArgs, PausableUseNetworkFeeArgs> &\n Suspendable,\n ) => PausableSuspenseResult<T>) &\n /**\n * Fetches the network fee for a past ActivityItem.\n *\n * ```tsx\n * const { data, error, loading } = useNetworkFee({\n * query: { activity },\n * });\n * ```\n */\n ((args: UseNetworkFeeArgs) => ReadResult<T>) &\n /**\n * Fetches the network fee for a past ActivityItem.\n *\n * Pausable loading state mode.\n *\n * ```tsx\n * const { data, error, loading, paused } = useNetworkFee({\n * query: { activity },\n * pause: true,\n * });\n *\n * data: NativeAmount | undefined\n * ```\n */\n ((\n args: Pausable<UseNetworkFeeArgs, PausableUseNetworkFeeArgs>,\n ) => PausableReadResult<T>);\n"]}
|