@aave/react 0.7.0 → 4.0.0-next.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (54) hide show
  1. package/README.md +42 -28
  2. package/dist/chunk-GTUQRT5Q.js +2 -0
  3. package/dist/chunk-GTUQRT5Q.js.map +1 -0
  4. package/dist/chunk-XIDOSID3.js +2 -0
  5. package/dist/chunk-XIDOSID3.js.map +1 -0
  6. package/dist/ethers.cjs +1 -1
  7. package/dist/ethers.cjs.map +1 -1
  8. package/dist/ethers.d.cts +41 -71
  9. package/dist/ethers.d.ts +41 -71
  10. package/dist/ethers.js +1 -1
  11. package/dist/ethers.js.map +1 -1
  12. package/dist/index.cjs +1 -1
  13. package/dist/index.cjs.map +1 -1
  14. package/dist/index.d.cts +2114 -793
  15. package/dist/index.d.ts +2114 -793
  16. package/dist/index.js +1 -1
  17. package/dist/index.js.map +1 -1
  18. package/dist/misc-BkG5G4yl.d.cts +377 -0
  19. package/dist/misc-gmAnSdm5.d.ts +377 -0
  20. package/dist/privy.cjs +1 -1
  21. package/dist/privy.cjs.map +1 -1
  22. package/dist/privy.d.cts +36 -76
  23. package/dist/privy.d.ts +36 -76
  24. package/dist/privy.js +1 -1
  25. package/dist/privy.js.map +1 -1
  26. package/dist/thirdweb.cjs +2 -2
  27. package/dist/thirdweb.cjs.map +1 -1
  28. package/dist/thirdweb.d.cts +35 -85
  29. package/dist/thirdweb.d.ts +35 -85
  30. package/dist/thirdweb.js +2 -2
  31. package/dist/thirdweb.js.map +1 -1
  32. package/dist/utils.cjs +2 -0
  33. package/dist/utils.cjs.map +1 -0
  34. package/dist/utils.d.cts +1 -0
  35. package/dist/utils.d.ts +1 -0
  36. package/dist/utils.js +2 -0
  37. package/dist/utils.js.map +1 -0
  38. package/dist/viem/index.cjs +2 -0
  39. package/dist/viem/index.cjs.map +1 -0
  40. package/dist/viem/index.d.cts +97 -0
  41. package/dist/viem/index.d.ts +97 -0
  42. package/dist/viem/index.js +2 -0
  43. package/dist/viem/index.js.map +1 -0
  44. package/dist/{tasks-DUn7x8pK.d.cts → writes-BXnwYgAQ.d.cts} +37 -1
  45. package/dist/{tasks-DUn7x8pK.d.ts → writes-BXnwYgAQ.d.ts} +37 -1
  46. package/package.json +37 -12
  47. package/dist/chunk-SECI6TSB.js +0 -2
  48. package/dist/chunk-SECI6TSB.js.map +0 -1
  49. package/dist/viem.cjs +0 -2
  50. package/dist/viem.cjs.map +0 -1
  51. package/dist/viem.d.cts +0 -115
  52. package/dist/viem.d.ts +0 -115
  53. package/dist/viem.js +0 -2
  54. package/dist/viem.js.map +0 -1
package/README.md CHANGED
@@ -1,62 +1,76 @@
1
1
  # `@aave/react`
2
2
 
3
- The official React bindings for the Aave Protocol.
3
+ The official React hooks for the Aave Protocol v4.
4
4
 
5
5
  ---
6
6
 
7
- ## Usage
7
+ `@aave/react` provides a collection of React hooks for building decentralized applications on top of the Aave Protocol v4.
8
+
9
+ ## Install SDK
10
+
11
+ First, install the AaveKit React package using your package manager of choice.
12
+
13
+ ```bash
14
+ pnpm add @aave/react@v4
15
+
16
+ // OR
17
+
18
+ yarn add @aave/react@v4
8
19
 
9
- ### Setup
20
+ // OR
10
21
 
11
- ```typescript
22
+ npm install @aave/react@v4
23
+ ```
24
+
25
+ ## Setup Client
26
+
27
+ Next, create an `AaveClient` instance that will be used to interact with the protocol.
28
+
29
+ ```ts
12
30
  // client.ts
13
- import { AaveClient } from '@aave/react';
31
+ import { AaveClient } from "@aave/react";
14
32
 
15
33
  export const client = AaveClient.create();
16
34
  ```
17
35
 
36
+ ## Setup Provider
37
+
38
+ Finally, wrap your app with the `<AaveProvider>` component and pass the client instance.
39
+
18
40
  ```tsx
19
41
  // App.tsx
20
- import { AaveProvider } from '@aave/react';
21
- import { client } from './client';
42
+ import { AaveProvider } from "@aave/react";
43
+
44
+ import { client } from "./client";
22
45
 
23
46
  export function App() {
24
47
  return (
25
48
  <AaveProvider client={client}>
26
- <MarketData />
27
- <UserPositions />
49
+ {/* Your application components */}
28
50
  </AaveProvider>
29
51
  );
30
52
  }
31
53
  ```
32
54
 
33
- ### Query Data
55
+ ## Usage
56
+
57
+ That's it—you can now start using AaveKit React hooks.
34
58
 
35
59
  ```tsx
36
- import { evmAddress, useAaveChains, useUserSupplies } from '@aave/react';
60
+ function ChainsList() {
61
+ const { data, error, loading } = useAaveChains();
62
+
63
+
64
+ if (loading) return <div>Loading…</div>;
65
+
66
+ if (error) return <div>Error: {error.message}</div>;
37
67
 
38
- function MarketData() {
39
- const { data: chains, loading } = useAaveChains();
40
-
41
- if (loading) return <div>Loading...</div>;
42
-
43
68
  return (
44
69
  <div>
45
- {chains?.map(chain => (
70
+ {chains.map((chain) => (
46
71
  <div key={chain.id}>{chain.name}</div>
47
72
  ))}
48
73
  </div>
49
74
  );
50
75
  }
51
-
52
- function UserPositions() {
53
- const { data: supplies, loading } = useUserSupplies({
54
- markets: [evmAddress('0x87870bca3f3fd6335c3f4ce8392d69350b4fa4e2')],
55
- user: evmAddress('0x742d35cc6e5c4ce3b69a2a8c7c8e5f7e9a0b1234'),
56
- });
57
-
58
- if (loading) return <div>Loading...</div>;
59
-
60
- return <div>Supplies: {supplies?.length || 0}</div>;
61
- }
62
76
  ```
@@ -0,0 +1,2 @@
1
+ import {invariant}from'@aave/types';import s,{useState,useRef,useCallback,useContext}from'react';import {CancelError}from'@aave/core';import {Provider}from'urql';import {permitTypedData}from'@aave/client/actions';var o={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 u(e,r){let[y,a]=useState(o.Idle()),n=useRef(false),i=useCallback(e,r);return [useCallback(A=>{invariant(!n.current,"Cannot execute a task while another is in progress."),n.current=true,a(({data:t})=>({called:true,loading:true,data:t,error:void 0}));let c=i(A);return c.match(t=>{n.current=false,a(o.Success(t));},t=>{n.current=false,a(o.Failed(t));}),c},[i]),y]}var h=e=>CancelError.from(e).asResultAsync(),T=class e{constructor(r){this.wait=r;}static ensure(r){return invariant(r instanceof e,"Expected PendingTransaction"),r}};var p=s.createContext(null);function b({children:e,client:r}){return s.createElement(p.Provider,{value:r},s.createElement(Provider,{value:r.urql},e))}function d(){let e=useContext(p);return invariant(e,"Could not find Aave SDK context, ensure your code is wrapped in a <AaveProvider>"),e}function j(){let e=d();return u(r=>permitTypedData(e,r),[e])}export{u as a,h as b,T as c,b as d,d as e,j as f};//# sourceMappingURL=chunk-GTUQRT5Q.js.map
2
+ //# sourceMappingURL=chunk-GTUQRT5Q.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/helpers/tasks.ts","../src/helpers/writes.ts","../src/context.tsx","../src/permits.ts"],"names":["AsyncTaskState","data","error","useAsyncTask","handler","deps","state","setState","useState","loadingRef","useRef","handle","useCallback","input","invariant","result","value","cancel","message","CancelError","PendingTransaction","_PendingTransaction","wait","AaveContext","React","AaveContextProvider","children","client","UrqlProvider","useAaveClient","useContext","usePermitTypedDataAction","request","permitTypedData"],"mappings":"qNA6DA,IAAMA,EAAiB,CACrB,IAAA,CAAM,KAAqD,CACzD,MAAA,CAAQ,KAAA,CACR,OAAA,CAAS,KAAA,CACT,KAAM,MAAA,CACN,KAAA,CAAO,MACT,CAAA,CAAA,CACA,OAAA,CAAyBC,CAAAA,GAAiD,CACxE,MAAA,CAAQ,KACR,OAAA,CAAS,IAAA,CACT,IAAA,CAAAA,CAAAA,CACA,KAAA,CAAO,MACT,CAAA,CAAA,CACA,OAAA,CAAyBA,IAAgD,CACvE,MAAA,CAAQ,IAAA,CACR,OAAA,CAAS,KAAA,CACT,IAAA,CAAAA,CAAAA,CACA,KAAA,CAAO,MACT,CAAA,CAAA,CACA,MAAA,CAAwBC,CAAAA,GAAkD,CACxE,MAAA,CAAQ,IAAA,CACR,OAAA,CAAS,KAAA,CACT,KAAM,MAAA,CACN,KAAA,CAAAA,CACF,CAAA,CACF,CAAA,CA2CO,SAASC,CAAAA,CAMdC,CAAAA,CACAC,EACsC,CACtC,GAAM,CAACC,CAAAA,CAAOC,CAAQ,CAAA,CAAIC,QAAAA,CAASR,CAAAA,CAAe,MAAsB,CAAA,CAClES,CAAAA,CAAaC,MAAAA,CAAO,KAAK,CAAA,CAEzBC,CAAAA,CAASC,WAAAA,CAAYR,EAASC,CAAI,CAAA,CAqCxC,OAAO,CAnCSO,WAAAA,CACbC,CAAAA,EAAkB,CACjBC,SAAAA,CACE,CAACL,CAAAA,CAAW,OAAA,CACZ,qDACF,CAAA,CAEAA,CAAAA,CAAW,OAAA,CAAU,IAAA,CACrBF,CAAAA,CAAS,CAAC,CAAE,IAAA,CAAAN,CAAK,CAAA,IACR,CACL,MAAA,CAAQ,IAAA,CACR,OAAA,CAAS,KACT,IAAA,CAAAA,CAAAA,CACA,KAAA,CAAO,MACT,CAAA,CACD,CAAA,CAED,IAAMc,CAAAA,CAASJ,EAAOE,CAAK,CAAA,CAE3B,OAAAE,CAAAA,CAAO,KAAA,CACJC,CAAAA,EAAU,CACTP,CAAAA,CAAW,QAAU,KAAA,CACrBF,CAAAA,CAASP,CAAAA,CAAe,OAAA,CAAQgB,CAAK,CAAC,EACxC,CAAA,CACCd,GAAU,CACTO,CAAAA,CAAW,OAAA,CAAU,KAAA,CACrBF,CAAAA,CAASP,CAAAA,CAAe,MAAA,CAAOE,CAAK,CAAC,EACvC,CACF,CAAA,CAEOa,CACT,CAAA,CACA,CAACJ,CAAM,CACT,EAEiBL,CAAK,CACxB,CCtJO,IAAMW,CAAAA,CAA2BC,CAAAA,EACtCC,WAAAA,CAAY,IAAA,CAAKD,CAAO,EAAE,aAAA,EAAc,CAe7BE,CAAAA,CAAN,MAAMC,CAAmB,CAC9B,WAAA,CAIkBC,CAAAA,CAIhB,CAJgB,IAAA,CAAA,IAAA,CAAAA,EAIf,CAKH,OAAO,MAAA,CAAUN,CAAAA,CAAkC,CACjD,OAAAF,UACEE,CAAAA,YAAiBK,CAAAA,CACjB,6BACF,CAAA,CACOL,CACT,CACF,EC7DA,IAAMO,CAAAA,CAAcC,CAAAA,CAAM,aAAA,CAAiC,IAAI,CAAA,CAaxD,SAASC,CAAAA,CAAoB,CAClC,QAAA,CAAAC,CAAAA,CACA,MAAA,CAAAC,CACF,CAAA,CAA6B,CAC3B,OACEH,CAAAA,CAAA,aAAA,CAACD,CAAAA,CAAY,QAAA,CAAZ,CAAqB,KAAA,CAAOI,CAAAA,CAAAA,CAC3BH,CAAAA,CAAA,cAACI,QAAAA,CAAA,CAAa,KAAA,CAAOD,CAAAA,CAAO,IAAA,CAAA,CAAOD,CAAS,CAC9C,CAEJ,CAKO,SAASG,CAAAA,EAA4B,CAC1C,IAAMF,CAAAA,CAASG,UAAAA,CAAWP,CAAW,CAAA,CAErC,OAAAT,SAAAA,CACEa,CAAAA,CACA,kFACF,CAAA,CAEOA,CACT,CChCO,SAASI,CAAAA,EAId,CACA,IAAMJ,CAAAA,CAASE,CAAAA,EAAc,CAE7B,OAAO1B,CAAAA,CACJ6B,CAAAA,EAA2BC,eAAAA,CAAgBN,CAAAA,CAAQK,CAAO,CAAA,CAC3D,CAACL,CAAM,CACT,CACF","file":"chunk-GTUQRT5Q.js","sourcesContent":["import { invariant, type ResultAsync } from '@aave/types';\nimport { type DependencyList, useCallback, useRef, useState } from 'react';\n\n/**\n * An async task is a function that can be executed multiple times and that can be in a pending state.\n *\n * @internal\n */\nexport type AsyncTask<TInput, TResult extends ResultAsync<unknown, unknown>> = (\n input: TInput,\n) => TResult;\n\n/**\n * The initial state of a async task.\n */\nexport type AsyncTaskIdle = {\n called: boolean;\n loading: false;\n data: undefined;\n error: undefined;\n};\n\n/**\n * The state of a async task during the loading.\n */\nexport type AsyncTaskLoading<TData> = {\n called: true;\n loading: true;\n data: TData | undefined;\n error: undefined;\n};\n\n/**\n * The state of a async task after a successful call.\n */\nexport type AsyncTaskSuccess<TData> = {\n called: true;\n loading: false;\n data: TData;\n error: undefined;\n};\n\n/**\n * The state of a async task after a failed call.\n */\nexport type AsyncTaskError<TError> = {\n called: true;\n loading: false;\n data: undefined;\n error: TError;\n};\n\n/**\n * The possible statuses of a async task.\n */\nexport type AsyncTaskState<TData, TError> =\n | AsyncTaskIdle\n | AsyncTaskLoading<TData>\n | AsyncTaskSuccess<TData>\n | AsyncTaskError<TError>;\n\nconst AsyncTaskState = {\n Idle: <TData, TError>(): AsyncTaskState<TData, TError> => ({\n called: false,\n loading: false,\n data: undefined,\n error: undefined,\n }),\n Loading: <TData, TError>(data?: TData): AsyncTaskState<TData, TError> => ({\n called: true,\n loading: true,\n data,\n error: undefined,\n }),\n Success: <TData, TError>(data: TData): AsyncTaskState<TData, TError> => ({\n called: true,\n loading: false,\n data,\n error: undefined,\n }),\n Failed: <TData, TError>(error: TError): AsyncTaskState<TData, TError> => ({\n called: true,\n loading: false,\n data: undefined,\n error,\n }),\n};\n\n/**\n * A async task React Hook is a lightweight wrapper for an asynchronous function.\n * It allows tracking of the task's execution status and provides access to the\n * last error that occurred during the task's execution, if any.\n *\n * ```ts\n * const [execute, { called, loading, data, error }]: UseAsyncTask<TData, TError, TInput> = useAnyAsyncTask();\n *\n * if (!called) {\n * // data === undefined\n * // error === undefined\n * return <p>Click the button to execute the task</p>;\n * }\n *\n * if (loading) {\n * // data === undefined on first call\n * // data === TData from previous successful call\n * // error === undefined\n * return <Loader />;\n * }\n *\n * if (error) {\n * // data === undefined\n * // error === TError\n * return <p>Something went wrong: {error.message}</p>;\n * }\n *\n * // called === true\n * // data === TData\n * // error === undefined\n * return <p>Task completed: {data}</p>;\n * ```\n */\nexport type UseAsyncTask<TInput, TValue, TError> = [\n AsyncTask<TInput, ResultAsync<TValue, TError>>,\n AsyncTaskState<TValue, TError>,\n];\n\n/**\n * @internal\n */\nexport function useAsyncTask<\n TInput,\n TValue,\n TError,\n TResult extends ResultAsync<TValue, TError>,\n>(\n handler: AsyncTask<TInput, TResult>,\n deps: DependencyList,\n): UseAsyncTask<TInput, TValue, TError> {\n const [state, setState] = useState(AsyncTaskState.Idle<TValue, TError>());\n const loadingRef = useRef(false);\n // biome-ignore lint/correctness/useExhaustiveDependencies: useAsyncTask is a low-level hook\n const handle = useCallback(handler, deps);\n\n const execute = useCallback(\n (input: TInput) => {\n invariant(\n !loadingRef.current,\n 'Cannot execute a task while another is in progress.',\n );\n\n loadingRef.current = true;\n setState(({ data }) => {\n return {\n called: true,\n loading: true,\n data,\n error: undefined,\n };\n });\n\n const result = handle(input);\n\n result.match(\n (value) => {\n loadingRef.current = false;\n setState(AsyncTaskState.Success(value));\n },\n (error) => {\n loadingRef.current = false;\n setState(AsyncTaskState.Failed(error));\n },\n );\n\n return result;\n },\n [handle],\n );\n\n return [execute, state];\n}\n","import type { TransactionResult } from '@aave/client';\nimport {\n CancelError,\n type SigningError,\n type TimeoutError,\n type TransactionError,\n type UnexpectedError,\n} from '@aave/core';\nimport type {\n Erc20ApprovalRequired,\n PreContractActionRequired,\n TransactionRequest,\n} from '@aave/graphql';\nimport type { ResultAsync } from '@aave/types';\nimport { invariant } from '@aave/types';\nimport type { UseAsyncTask } from './tasks';\n\n/**\n * The errors that could occur in the early stage of sending a transaction.\n */\nexport type SendTransactionError = CancelError | SigningError | UnexpectedError;\n\nexport type CancelOperation = (\n message: string,\n) => ResultAsync<never, CancelError>;\n\n/**\n * @internal\n */\nexport const cancel: CancelOperation = (message: string) =>\n CancelError.from(message).asResultAsync();\n\nexport type TransactionHandlerOptions = {\n cancel: CancelOperation;\n};\n\n/**\n * The errors that could occur in the late stages of a transaction.\n */\nexport type PendingTransactionError =\n | CancelError\n | TimeoutError\n | TransactionError\n | UnexpectedError;\n\nexport class PendingTransaction {\n constructor(\n /**\n * @internal Do NOT rely on this method. It's used internally by the SDK and may be subject to breaking changes.\n */\n public readonly wait: () => ResultAsync<\n TransactionResult,\n PendingTransactionError\n >,\n ) {}\n\n /**\n * @internal\n */\n static ensure<T>(value: T): PendingTransaction & T {\n invariant(\n value instanceof PendingTransaction,\n 'Expected PendingTransaction',\n );\n return value as PendingTransaction & T;\n }\n}\n\nexport type UseSendTransactionResult = UseAsyncTask<\n TransactionRequest,\n PendingTransaction,\n SendTransactionError\n>;\n\n/**\n * The handler for sending Aave transactions.\n */\nexport type TransactionHandler = (\n result:\n | TransactionRequest\n | Erc20ApprovalRequired\n | PreContractActionRequired,\n options: TransactionHandlerOptions,\n) => ResultAsync<PendingTransaction, SendTransactionError>;\n","import type { AaveClient } from '@aave/client';\nimport { invariant } from '@aave/types';\nimport React, { type ReactNode, useContext } from 'react';\nimport { Provider as UrqlProvider } from 'urql';\n\nconst AaveContext = React.createContext<AaveClient | null>(null);\n\n/**\n * @internal\n */\nexport type AaveContextProviderProps = {\n children: ReactNode;\n client: AaveClient;\n};\n\n/**\n * @internal\n */\nexport function AaveContextProvider({\n children,\n client,\n}: AaveContextProviderProps) {\n return (\n <AaveContext.Provider value={client}>\n <UrqlProvider value={client.urql}>{children}</UrqlProvider>\n </AaveContext.Provider>\n );\n}\n\n/**\n * @internal\n */\nexport function useAaveClient(): AaveClient {\n const client = useContext(AaveContext);\n\n invariant(\n client,\n 'Could not find Aave SDK context, ensure your code is wrapped in a <AaveProvider>',\n );\n\n return client;\n}\n","import type { UnexpectedError } from '@aave/client';\nimport { permitTypedData } from '@aave/client/actions';\nimport type { PermitRequest, PermitTypedDataResponse } from '@aave/graphql';\nimport { useAaveClient } from './context';\nimport { type UseAsyncTask, useAsyncTask } from './helpers';\n\n/**\n * @internal\n */\nexport function usePermitTypedDataAction(): UseAsyncTask<\n PermitRequest,\n PermitTypedDataResponse,\n UnexpectedError\n> {\n const client = useAaveClient();\n\n return useAsyncTask(\n (request: PermitRequest) => permitTypedData(client, request),\n [client],\n );\n}\n"]}
@@ -0,0 +1,2 @@
1
+ import {e,a}from'./chunk-GTUQRT5Q.js';import {exchangeRate}from'@aave/client/actions';import {ChainsFilter,ChainQuery,ChainsQuery,ExchangeRateQuery}from'@aave/graphql';import {UnexpectedError}from'@aave/client';import {identity,invariant}from'@aave/types';import {useState,useMemo,useEffect}from'react';import {useQuery}from'urql';var u={Loading:()=>({data:void 0,error:void 0,loading:true,paused:false}),Success:e=>({data:e,error:void 0,loading:false,paused:false}),Failure:e=>({data:void 0,error:e,loading:false,paused:false}),Paused:(e,a)=>({data:e,error:a,loading:false,paused:true})};function p({document:e,variables:a,suspense:s,pause:t,selector:b=identity,pollInterval:i=0}){let[y,g]=useState(true),[{fetching:n,data:r,error:l},c]=useQuery({query:e,variables:a,pause:t,context:useMemo(()=>({suspense:s}),[s])});if(useEffect(()=>{t||n||g(false);},[n,t]),useEffect(()=>{if(i<=0||n||t)return;let o=setTimeout(()=>{c({requestPolicy:"network-only"});},i);return ()=>clearTimeout(o)},[n,c,i,t]),t)return u.Paused(r?b(r.value):void 0,l?UnexpectedError.from(l):void 0);if(!s&&y)return u.Loading();if(l){let o=UnexpectedError.from(l);if(s)throw o;return u.Failure(o)}return invariant(r,"No data returned"),u.Success(b(r.value))}function M({suspense:e=false,pause:a=false,...s}){return p({document:ChainQuery,variables:{request:s},suspense:e,pause:a})}function j({suspense:e=false,pause:a=false,filter:s}={filter:ChainsFilter.ALL}){return p({document:ChainsQuery,variables:{filter:s},suspense:e,pause:a})}function z(){let e$1=e();return a(a=>exchangeRate(e$1,a),[e$1])}function B({suspense:e$1=false,pause:a=false,...s}){let t=e();return p({document:ExchangeRateQuery,variables:{request:s},suspense:e$1,pause:a,pollInterval:s.at?0:t.context.environment.exchangeRateInterval})}export{u as a,p as b,M as c,j as d,z as e,B as f};//# sourceMappingURL=chunk-XIDOSID3.js.map
2
+ //# sourceMappingURL=chunk-XIDOSID3.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/helpers/results.ts","../src/helpers/reads.ts","../src/misc.ts"],"names":["ReadResult","data","error","useSuspendableQuery","document","variables","suspense","pause","selector","identity","pollInterval","loading","setLoading","useState","fetching","executeQuery","useQuery","useMemo","useEffect","timerId","UnexpectedError","unexpected","invariant","useChain","request","ChainQuery","useChains","filter","ChainsFilter","ChainsQuery","useExchangeRateAction","client","useAaveClient","useAsyncTask","exchangeRate","useExchangeRate","ExchangeRateQuery"],"mappings":"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","file":"chunk-XIDOSID3.js","sourcesContent":["import type { UnexpectedError } from '@aave/client';\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 extends UnexpectedError = UnexpectedError> =\n | {\n data: undefined;\n error: undefined;\n loading: true;\n }\n | {\n data: T;\n error: undefined;\n loading: false;\n }\n | {\n data: undefined;\n error: E;\n loading: false;\n };\n\n/**\n * A read hook result that supports pausing.\n */\nexport type PausableReadResult<T, E extends UnexpectedError = UnexpectedError> =\n | {\n data: T | undefined;\n error: E | undefined;\n loading: false;\n paused: true;\n }\n | {\n data: undefined;\n error: undefined;\n loading: true;\n paused: false;\n }\n | {\n data: T;\n error: undefined;\n loading: false;\n paused: false;\n }\n | {\n data: undefined;\n error: E;\n loading: false;\n paused: false;\n };\n\n/**\n * @internal\n */\nexport const ReadResult = {\n Loading: <\n T,\n E extends UnexpectedError = UnexpectedError,\n >(): PausableReadResult<T, E> => ({\n data: undefined,\n error: undefined,\n loading: true,\n paused: false,\n }),\n Success: <T, E extends UnexpectedError = UnexpectedError>(\n data: T,\n ): PausableReadResult<T, E> => ({\n data,\n error: undefined,\n loading: false,\n paused: false,\n }),\n Failure: <T, E extends UnexpectedError = UnexpectedError>(\n error: E,\n ): PausableReadResult<T, E> => ({\n data: undefined,\n error,\n loading: false,\n paused: false,\n }),\n Paused: <T, E extends UnexpectedError = UnexpectedError>(\n data: T | undefined,\n error: E | undefined,\n ): PausableReadResult<T, E> => ({\n data,\n error,\n loading: false,\n paused: true,\n }),\n};\n\n/**\n * A read hook result that supports React Suspense.\n */\nexport type SuspenseResult<T> = {\n data: T;\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 | {\n paused: false;\n data: T;\n };\n\nexport type SuspendableResult<T, E extends UnexpectedError = 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 identity,\n invariant,\n type NullishDeep,\n type Prettify,\n} from '@aave/types';\nimport { useEffect, useMemo, useState } from 'react';\nimport { type TypedDocumentNode, useQuery } from 'urql';\nimport {\n type PausableReadResult,\n type PausableSuspenseResult,\n ReadResult,\n type SuspendableResult,\n type SuspenseResult,\n} from './results';\n\nexport type Selector<T, V> = (data: T) => V;\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 Value,\n Output,\n Variables extends AnyVariables,\n Suspense extends boolean,\n Pause extends boolean = never,\n> = {\n document: TypedDocumentNode<StandardData<Value>, Variables>;\n variables?: Pause extends boolean ? NullishDeep<Variables> : Variables;\n suspense: Suspense;\n selector?: Selector<Value, Output>;\n pollInterval?: number;\n pause?: Pause;\n};\n\n/**\n * @internal\n */\nexport function useSuspendableQuery<\n Value,\n Output,\n Variables extends AnyVariables,\n Pausable extends boolean = never,\n>({\n document,\n variables,\n suspense,\n pause,\n}: UseSuspendableQueryArgs<Value, Output, Variables, false, Pausable>):\n | ReadResult<Output>\n | PausableReadResult<Output>;\n/**\n * @internal\n */\nexport function useSuspendableQuery<\n Value,\n Output,\n Variables extends AnyVariables,\n Pausable extends boolean = never,\n>({\n document,\n variables,\n suspense,\n pause,\n}: UseSuspendableQueryArgs<Value, Output, Variables, true, Pausable>):\n | SuspenseResult<Output>\n | PausableSuspenseResult<Output>;\n/**\n * @internal\n */\nexport function useSuspendableQuery<\n Value,\n Output,\n Variables extends AnyVariables,\n Pausable extends boolean = never,\n>({\n document,\n variables,\n suspense,\n pause,\n}: UseSuspendableQueryArgs<\n Value,\n Output,\n Variables,\n boolean,\n Pausable\n>): SuspendableResult<Output, UnexpectedError>;\n/**\n * Implementation.\n */\nexport function useSuspendableQuery<\n Value,\n Output,\n Variables extends AnyVariables,\n>({\n document,\n variables,\n suspense,\n pause,\n selector = identity as Selector<Value, Output>,\n pollInterval = 0,\n}: UseSuspendableQueryArgs<\n Value,\n Output,\n Variables,\n boolean,\n boolean\n>): SuspendableResult<Output, UnexpectedError> {\n const [loading, setLoading] = useState(true);\n const [{ fetching, data, error }, executeQuery] = useQuery({\n query: document,\n variables: variables as Variables,\n pause,\n context: useMemo(\n () => ({\n suspense,\n }),\n [suspense],\n ),\n });\n\n useEffect(() => {\n if (pause) return;\n\n if (!fetching) {\n setLoading(false);\n }\n }, [fetching, pause]);\n\n useEffect(() => {\n if (pollInterval <= 0 || fetching || pause) return undefined;\n\n const timerId = setTimeout(() => {\n executeQuery({\n requestPolicy: 'network-only',\n });\n }, pollInterval);\n\n return () => clearTimeout(timerId);\n }, [fetching, executeQuery, pollInterval, pause]);\n\n if (pause) {\n return ReadResult.Paused(\n data ? selector(data.value) : undefined,\n error ? UnexpectedError.from(error) : undefined,\n );\n }\n\n if (!suspense && loading) {\n return ReadResult.Loading();\n }\n\n if (error) {\n const unexpected = UnexpectedError.from(error);\n if (suspense) {\n throw unexpected;\n }\n\n return ReadResult.Failure(unexpected);\n }\n\n invariant(data, 'No data returned');\n\n return ReadResult.Success(selector(data.value));\n}\n","import type { CurrencyQueryOptions } from '@aave/client';\nimport { exchangeRate } from '@aave/client/actions';\nimport type { UnexpectedError } from '@aave/core';\nimport type { Chain, ExchangeRateRequest, FiatAmount } from '@aave/graphql';\nimport {\n type ActivityItem,\n ChainQuery,\n type ChainRequest,\n ChainsFilter,\n ChainsQuery,\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\nexport type UseChainsArgs = {\n filter: ChainsFilter;\n};\n/**\n * Fetches the list of supported chains.\n *\n * This signature supports React Suspense:\n *\n * ```tsx\n * const { data } = useChains({\n * 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 * 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 * 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 * 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 filter,\n }: NullishDeep<UseChainsArgs> & {\n suspense?: boolean;\n pause?: boolean;\n } = { filter: ChainsFilter.ALL },\n): SuspendableResult<Chain[], UnexpectedError> {\n return useSuspendableQuery({\n document: ChainsQuery,\n variables: { filter },\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 FiatAmount,\n UnexpectedError\n> {\n const client = useAaveClient();\n\n return useAsyncTask(\n (request: ExchangeRateRequest) => exchangeRate(client, request),\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<FiatAmount>;\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<FiatAmount>;\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<FiatAmount>;\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<FiatAmount>;\n\nexport function useExchangeRate({\n suspense = false,\n pause = false,\n ...request\n}: NullishDeep<UseExchangeRateArgs> & {\n suspense?: boolean;\n pause?: boolean;\n}): SuspendableResult<FiatAmount, 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"]}
package/dist/ethers.cjs CHANGED
@@ -1,2 +1,2 @@
1
- 'use strict';var actions=require('@aave/client/actions'),ethers=require('@aave/client/ethers'),types=require('@aave/types'),d=require('react');require('urql');function _interopDefault(e){return e&&e.__esModule?e:{default:e}}var d__default=/*#__PURE__*/_interopDefault(d);var l=d__default.default.createContext(null);function n(){let e=d.useContext(l);return types.invariant(e,"Could not find Aave SDK context, ensure your code is wrapped in a <AaveProvider>"),e}var o={Idle:()=>({called:false,loading:false,data:void 0,error:void 0}),Loading:e=>({called:true,loading:true,data:e,error:void 0}),Success:e=>({called:true,loading:false,data:e,error:void 0}),Failed:e=>({called:true,loading:false,data:void 0,error:e})};function s(e){let[r,t]=d.useState(o.Idle());return [d.useCallback(T=>{types.invariant(!r.loading,"Cannot execute a task while another is in progress."),t(({data:a})=>({called:true,loading:true,data:a,error:void 0}));let i=e(T);return i.match(a=>t(o.Success(a)),a=>t(o.Failed(a))),i},[e,r]),r]}function V(e){let r=n();return s(t=>ethers.sendTransactionAndWait(e,t).andThen(r.waitForSupportedTransaction))}function w(e){let r=n();return s(t=>actions.permitTypedData(r,t).andThen(ethers.signERC20PermitWith(e)))}exports.useERC20Permit=w;exports.useSendTransaction=V;//# sourceMappingURL=ethers.cjs.map
1
+ 'use strict';var ethers=require('@aave/client/ethers'),types=require('@aave/types'),S=require('react');require('@aave/core');var actions=require('@aave/client/actions');require('urql');function _interopDefault(e){return e&&e.__esModule?e:{default:e}}var S__default=/*#__PURE__*/_interopDefault(S);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 t(e,r){let[n,i]=S.useState(c.Idle()),o=S.useRef(false),p=S.useCallback(e,r);return [S.useCallback(y=>{types.invariant(!o.current,"Cannot execute a task while another is in progress."),o.current=true,i(({data:a})=>({called:true,loading:true,data:a,error:void 0}));let u=p(y);return u.match(a=>{o.current=false,i(c.Success(a));},a=>{o.current=false,i(c.Failed(a));}),u},[p]),n]}var s=class e{constructor(r){this.wait=r;}static ensure(r){return types.invariant(r instanceof e,"Expected PendingTransaction"),r}};var R=S__default.default.createContext(null);function d(){let e=S.useContext(R);return types.invariant(e,"Could not find Aave SDK context, ensure your code is wrapped in a <AaveProvider>"),e}function l(){let e=d();return t(r=>actions.permitTypedData(e,r),[e])}function Y(e){return t(r=>ethers.sendTransaction(e,r).map(n=>new s(()=>ethers.waitForTransactionResult(r,n))),[e])}function Z(e){let[r]=l();return t(n=>r(n).andThen(ethers.signERC20PermitWith(e)),[r,e])}function $(e){return t(r=>(types.invariant(e,"Expected a Signer to sign swap typed data"),ethers.signSwapTypedDataWith(e)(r)),[e])}exports.useERC20Permit=Z;exports.useSendTransaction=Y;exports.useSignSwapTypedDataWith=$;//# sourceMappingURL=ethers.cjs.map
2
2
  //# sourceMappingURL=ethers.cjs.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/context.tsx","../src/helpers/tasks.ts","../src/ethers.ts"],"names":["AaveContext","React","useAaveClient","client","useContext","invariant","AsyncTaskState","data","error","useAsyncTask","handler","state","setState","useState","useCallback","input","result","value","useSendTransaction","signer","request","sendTransactionAndWait","useERC20Permit","permitTypedData","signERC20PermitWith"],"mappings":"+QAKA,IAAMA,CAAAA,CAAcC,kBAAAA,CAAM,aAAA,CAAiC,IAAI,CAAA,CA2BxD,SAASC,CAAAA,EAA4B,CAC1C,IAAMC,CAAAA,CAASC,aAAWJ,CAAW,CAAA,CAErC,OAAAK,eAAAA,CACEF,CAAAA,CACA,kFACF,EAEOA,CACT,CCoBA,IAAMG,EAAiB,CACrB,IAAA,CAAM,KAAqD,CACzD,MAAA,CAAQ,KAAA,CACR,QAAS,KAAA,CACT,IAAA,CAAM,MAAA,CACN,KAAA,CAAO,MACT,CAAA,CAAA,CACA,QAAyBC,CAAAA,GAAiD,CACxE,MAAA,CAAQ,IAAA,CACR,OAAA,CAAS,IAAA,CACT,KAAAA,CAAAA,CACA,KAAA,CAAO,MACT,CAAA,CAAA,CACA,OAAA,CAAyBA,CAAAA,GAAgD,CACvE,MAAA,CAAQ,IAAA,CACR,OAAA,CAAS,KAAA,CACT,IAAA,CAAAA,CAAAA,CACA,MAAO,MACT,CAAA,CAAA,CACA,MAAA,CAAwBC,CAAAA,GAAkD,CACxE,MAAA,CAAQ,KACR,OAAA,CAAS,KAAA,CACT,IAAA,CAAM,MAAA,CACN,KAAA,CAAAA,CACF,EACF,CAAA,CA2CO,SAASC,CAAAA,CAKdC,CAAAA,CAA2E,CAC3E,GAAM,CAACC,CAAAA,CAAOC,CAAQ,CAAA,CAAIC,UAAAA,CAASP,CAAAA,CAAe,IAAA,EAAsB,CAAA,CA8BxE,OAAO,CA5BSQ,aAAAA,CACbC,CAAAA,EAAkB,CACjBV,gBACE,CAACM,CAAAA,CAAM,OAAA,CACP,qDACF,CAAA,CAEAC,CAAAA,CAAS,CAAC,CAAE,IAAA,CAAAL,CAAK,CAAA,IACR,CACL,MAAA,CAAQ,KACR,OAAA,CAAS,IAAA,CACT,IAAA,CAAAA,CAAAA,CACA,KAAA,CAAO,MACT,EACD,CAAA,CAED,IAAMS,CAAAA,CAASN,CAAAA,CAAQK,CAAK,CAAA,CAE5B,OAAAC,CAAAA,CAAO,KAAA,CACJC,CAAAA,EAAUL,CAAAA,CAASN,CAAAA,CAAe,OAAA,CAAQW,CAAK,CAAC,CAAA,CAChDT,CAAAA,EAAUI,CAAAA,CAASN,CAAAA,CAAe,MAAA,CAAOE,CAAK,CAAC,CAClD,CAAA,CAEOQ,CACT,CAAA,CACA,CAACN,EAASC,CAAK,CACjB,CAAA,CAEiBA,CAAK,CACxB,CC5DO,SAASO,CAAAA,CACdC,CAAAA,CACgE,CAChE,IAAMhB,CAAAA,CAASD,CAAAA,GAEf,OAAOO,CAAAA,CAAcW,CAAAA,EACZC,6BAAAA,CAAuBF,CAAAA,CAAQC,CAAO,EAAE,OAAA,CAC7CjB,CAAAA,CAAO,2BACT,CACD,CACH,CAoCO,SAASmB,CAAAA,CACdH,CAAAA,CAC6E,CAC7E,IAAMhB,CAAAA,CAASD,CAAAA,GAEf,OAAOO,CAAAA,CAAcW,CAAAA,EACZG,uBAAAA,CAAgBpB,CAAAA,CAAQiB,CAAO,CAAA,CAAE,OAAA,CACtCI,0BAAAA,CAAoBL,CAAM,CAC5B,CACD,CACH","file":"ethers.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 * Retrieve the injected {@link AaveClient} from the context.\n */\nexport function useAaveClient(): AaveClient {\n const client = useContext(AaveContext);\n\n invariant(\n client,\n 'Could not find Aave SDK context, ensure your code is wrapped in a <AaveProvider>',\n );\n\n return client;\n}\n","import { invariant, type ResultAsync } from '@aave/types';\nimport { useCallback, useState } from 'react';\n\n/**\n * An async task is a function that can be executed multiple times and that can be in a pending state.\n *\n * @internal\n */\nexport type AsyncTask<TInput, TResult extends ResultAsync<unknown, unknown>> = (\n input: TInput,\n) => TResult;\n\n/**\n * The initial state of a async task.\n */\nexport type AsyncTaskIdle = {\n called: boolean;\n loading: false;\n data: undefined;\n error: undefined;\n};\n\n/**\n * The state of a async task during the loading.\n */\nexport type AsyncTaskLoading<TData> = {\n called: true;\n loading: true;\n data: TData | undefined;\n error: undefined;\n};\n\n/**\n * The state of a async task after a successful call.\n */\nexport type AsyncTaskSuccess<TData> = {\n called: true;\n loading: false;\n data: TData;\n error: undefined;\n};\n\n/**\n * The state of a async task after a failed call.\n */\nexport type AsyncTaskError<TError> = {\n called: true;\n loading: false;\n data: undefined;\n error: TError;\n};\n\n/**\n * The possible statuses of a async task.\n */\nexport type AsyncTaskState<TData, TError> =\n | AsyncTaskIdle\n | AsyncTaskLoading<TData>\n | AsyncTaskSuccess<TData>\n | AsyncTaskError<TError>;\n\nconst AsyncTaskState = {\n Idle: <TData, TError>(): AsyncTaskState<TData, TError> => ({\n called: false,\n loading: false,\n data: undefined,\n error: undefined,\n }),\n Loading: <TData, TError>(data?: TData): AsyncTaskState<TData, TError> => ({\n called: true,\n loading: true,\n data,\n error: undefined,\n }),\n Success: <TData, TError>(data: TData): AsyncTaskState<TData, TError> => ({\n called: true,\n loading: false,\n data,\n error: undefined,\n }),\n Failed: <TData, TError>(error: TError): AsyncTaskState<TData, TError> => ({\n called: true,\n loading: false,\n data: undefined,\n error,\n }),\n};\n\n/**\n * A async task React Hook is a lightweight wrapper for an asynchronous function.\n * It allows tracking of the task's execution status and provides access to the\n * last error that occurred during the task's execution, if any.\n *\n * ```ts\n * const [execute, { called, loading, data, error }]: UseAsyncTask<TData, TError, TInput> = useAnyAsyncTask();\n *\n * if (!called) {\n * // data === undefined\n * // error === undefined\n * return <p>Click the button to execute the task</p>;\n * }\n *\n * if (loading) {\n * // data === undefined on first call\n * // data === TData from previous successful call\n * // error === undefined\n * return <Loader />;\n * }\n *\n * if (error) {\n * // data === undefined\n * // error === TError\n * return <p>Something went wrong: {error.message}</p>;\n * }\n *\n * // called === true\n * // data === TData\n * // error === undefined\n * return <p>Task completed: {data}</p>;\n * ```\n */\nexport type UseAsyncTask<TInput, TValue, TError> = [\n AsyncTask<TInput, ResultAsync<TValue, TError>>,\n AsyncTaskState<TValue, TError>,\n];\n\n/**\n * @internal\n */\nexport function useAsyncTask<\n TInput,\n TValue,\n TError,\n TResult extends ResultAsync<TValue, TError>,\n>(handler: AsyncTask<TInput, TResult>): UseAsyncTask<TInput, TValue, TError> {\n const [state, setState] = useState(AsyncTaskState.Idle<TValue, TError>());\n\n const execute = useCallback(\n (input: TInput) => {\n invariant(\n !state.loading,\n 'Cannot execute a task while another is in progress.',\n );\n\n setState(({ data }) => {\n return {\n called: true,\n loading: true,\n data,\n error: undefined,\n };\n });\n\n const result = handler(input);\n\n result.match(\n (value) => setState(AsyncTaskState.Success(value)),\n (error) => setState(AsyncTaskState.Failed(error)),\n );\n\n return result;\n },\n [handler, state],\n );\n\n return [execute, state];\n}\n","import type {\n SigningError,\n TimeoutError,\n TransactionError,\n UnexpectedError,\n} from '@aave/client';\nimport { permitTypedData } from '@aave/client/actions';\nimport {\n sendTransactionAndWait,\n signERC20PermitWith,\n} from '@aave/client/ethers';\nimport type {\n ERC712Signature,\n PermitTypedDataRequest,\n TransactionRequest,\n} from '@aave/graphql';\nimport type { TxHash } from '@aave/types';\nimport type { Signer } from 'ethers';\nimport { useAaveClient } from './context';\nimport { type UseAsyncTask, useAsyncTask } from './helpers';\n\nexport type SendTransactionError =\n | SigningError\n | TimeoutError\n | TransactionError\n | UnexpectedError;\n\n/**\n * A hook that provides a way to send Aave transactions using an ethers Signer instance.\n *\n * First, get the `Signer` instance from your ethers provider, then pass it to this hook to create a function that can be used to send transactions.\n *\n * ```ts\n * const provider = new ethers.providers.Web3Provider(window.ethereum);\n * const signer = provider.getSigner();\n *\n * // …\n *\n * const [sendTransaction, { loading, error, data }] = useSendTransaction(signer);\n * ```\n *\n * Then, use it to send a {@link TransactionRequest} as shown below.\n *\n * ```ts\n * const [toggle, { loading, error, data }] = useEModeToggle();\n *\n * const run = async () => {\n * const result = await toggle({\n * chainId: chainId(1), // Ethereum mainnet\n * market: evmAddress('0x1234…'),\n * user: evmAddress(await signer.getAddress()),\n * })\n * .andThen(sendTransaction);\n *\n * if (result.isErr()) {\n * console.error(result.error);\n * return;\n * }\n *\n * console.log('Transaction sent with hash:', result.value);\n * };\n * ```\n *\n * Or use it to handle an {@link ExecutionPlan} that may require multiple transactions as shown below.\n *\n * ```ts\n * const [supply, { loading, error, data }] = useSupply();\n *\n * const run = async () => {\n * const result = await supply({\n * chainId: chainId(1), // Ethereum mainnet\n * market: evmAddress('0x1234…'),\n * amount: {\n * erc20: {\n * currency: evmAddress('0x5678…'),\n * value: '42.42',\n * }\n * },\n * supplier: evmAddress(await signer.getAddress()),\n * })\n * .andThen((plan) => {\n * switch (plan.__typename) {\n * case 'TransactionRequest':\n * return sendTransaction(plan);\n *\n * case 'ApprovalRequired':\n * return sendTransaction(plan.approval).andThen(() =>\n * sendTransaction(plan.originalTransaction),\n * );\n *\n * case 'InsufficientBalanceError':\n * return errAsync(new Error(`Insufficient balance: ${error.cause.required.value} required.`));\n * }\n * });\n *\n * if (result.isErr()) {\n * console.error(result.error);\n * return;\n * }\n *\n * console.log('Transaction sent with hash:', result.value);\n * }\n * ```\n *\n * @param signer - The ethers Signer to use for sending transactions.\n */\nexport function useSendTransaction(\n signer: Signer,\n): UseAsyncTask<TransactionRequest, TxHash, SendTransactionError> {\n const client = useAaveClient();\n\n return useAsyncTask((request: TransactionRequest) => {\n return sendTransactionAndWait(signer, request).andThen(\n client.waitForSupportedTransaction,\n );\n });\n}\n\nexport type SignERC20PermitError = SigningError | UnexpectedError;\n\n/**\n * A hook that provides a way to sign ERC20 permits using an ethers Signer instance.\n *\n * ```ts\n * const provider = new ethers.providers.Web3Provider(window.ethereum);\n * const signer = provider.getSigner();\n *\n * // …\n *\n * const [signERC20Permit, { loading, error, data }] = useERC20Permit(signer);\n *\n * const run = async () => {\n * const result = await signERC20Permit({\n * chainId: chainId(1), // Ethereum mainnet\n * market: evmAddress('0x1234…'),\n * underlyingToken: evmAddress('0x5678…'),\n * amount: '42.42',\n * spender: evmAddress('0x9abc…'),\n * owner: evmAddress(await signer.getAddress()),\n * });\n *\n * if (result.isErr()) {\n * console.error(result.error);\n * return;\n * }\n *\n * console.log('ERC20 permit signed:', result.value);\n * };\n * ```\n *\n * @param signer - The ethers Signer to use for signing ERC20 permits.\n */\nexport function useERC20Permit(\n signer: Signer,\n): UseAsyncTask<PermitTypedDataRequest, ERC712Signature, SignERC20PermitError> {\n const client = useAaveClient();\n\n return useAsyncTask((request: PermitTypedDataRequest) => {\n return permitTypedData(client, request).andThen(\n signERC20PermitWith(signer),\n );\n });\n}\n"]}
1
+ {"version":3,"sources":["../src/helpers/tasks.ts","../src/helpers/writes.ts","../src/context.tsx","../src/permits.ts","../src/ethers.ts"],"names":["AsyncTaskState","data","error","useAsyncTask","handler","deps","state","setState","useState","loadingRef","useRef","handle","useCallback","input","invariant","result","value","PendingTransaction","_PendingTransaction","wait","AaveContext","React","useAaveClient","client","useContext","usePermitTypedDataAction","request","permitTypedData","useSendTransaction","signer","sendTransaction","response","waitForTransactionResult","useERC20Permit","signERC20PermitWith","useSignSwapTypedDataWith","typedData","signSwapTypedDataWith"],"mappings":"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","file":"ethers.cjs","sourcesContent":["import { invariant, type ResultAsync } from '@aave/types';\nimport { type DependencyList, useCallback, useRef, useState } from 'react';\n\n/**\n * An async task is a function that can be executed multiple times and that can be in a pending state.\n *\n * @internal\n */\nexport type AsyncTask<TInput, TResult extends ResultAsync<unknown, unknown>> = (\n input: TInput,\n) => TResult;\n\n/**\n * The initial state of a async task.\n */\nexport type AsyncTaskIdle = {\n called: boolean;\n loading: false;\n data: undefined;\n error: undefined;\n};\n\n/**\n * The state of a async task during the loading.\n */\nexport type AsyncTaskLoading<TData> = {\n called: true;\n loading: true;\n data: TData | undefined;\n error: undefined;\n};\n\n/**\n * The state of a async task after a successful call.\n */\nexport type AsyncTaskSuccess<TData> = {\n called: true;\n loading: false;\n data: TData;\n error: undefined;\n};\n\n/**\n * The state of a async task after a failed call.\n */\nexport type AsyncTaskError<TError> = {\n called: true;\n loading: false;\n data: undefined;\n error: TError;\n};\n\n/**\n * The possible statuses of a async task.\n */\nexport type AsyncTaskState<TData, TError> =\n | AsyncTaskIdle\n | AsyncTaskLoading<TData>\n | AsyncTaskSuccess<TData>\n | AsyncTaskError<TError>;\n\nconst AsyncTaskState = {\n Idle: <TData, TError>(): AsyncTaskState<TData, TError> => ({\n called: false,\n loading: false,\n data: undefined,\n error: undefined,\n }),\n Loading: <TData, TError>(data?: TData): AsyncTaskState<TData, TError> => ({\n called: true,\n loading: true,\n data,\n error: undefined,\n }),\n Success: <TData, TError>(data: TData): AsyncTaskState<TData, TError> => ({\n called: true,\n loading: false,\n data,\n error: undefined,\n }),\n Failed: <TData, TError>(error: TError): AsyncTaskState<TData, TError> => ({\n called: true,\n loading: false,\n data: undefined,\n error,\n }),\n};\n\n/**\n * A async task React Hook is a lightweight wrapper for an asynchronous function.\n * It allows tracking of the task's execution status and provides access to the\n * last error that occurred during the task's execution, if any.\n *\n * ```ts\n * const [execute, { called, loading, data, error }]: UseAsyncTask<TData, TError, TInput> = useAnyAsyncTask();\n *\n * if (!called) {\n * // data === undefined\n * // error === undefined\n * return <p>Click the button to execute the task</p>;\n * }\n *\n * if (loading) {\n * // data === undefined on first call\n * // data === TData from previous successful call\n * // error === undefined\n * return <Loader />;\n * }\n *\n * if (error) {\n * // data === undefined\n * // error === TError\n * return <p>Something went wrong: {error.message}</p>;\n * }\n *\n * // called === true\n * // data === TData\n * // error === undefined\n * return <p>Task completed: {data}</p>;\n * ```\n */\nexport type UseAsyncTask<TInput, TValue, TError> = [\n AsyncTask<TInput, ResultAsync<TValue, TError>>,\n AsyncTaskState<TValue, TError>,\n];\n\n/**\n * @internal\n */\nexport function useAsyncTask<\n TInput,\n TValue,\n TError,\n TResult extends ResultAsync<TValue, TError>,\n>(\n handler: AsyncTask<TInput, TResult>,\n deps: DependencyList,\n): UseAsyncTask<TInput, TValue, TError> {\n const [state, setState] = useState(AsyncTaskState.Idle<TValue, TError>());\n const loadingRef = useRef(false);\n // biome-ignore lint/correctness/useExhaustiveDependencies: useAsyncTask is a low-level hook\n const handle = useCallback(handler, deps);\n\n const execute = useCallback(\n (input: TInput) => {\n invariant(\n !loadingRef.current,\n 'Cannot execute a task while another is in progress.',\n );\n\n loadingRef.current = true;\n setState(({ data }) => {\n return {\n called: true,\n loading: true,\n data,\n error: undefined,\n };\n });\n\n const result = handle(input);\n\n result.match(\n (value) => {\n loadingRef.current = false;\n setState(AsyncTaskState.Success(value));\n },\n (error) => {\n loadingRef.current = false;\n setState(AsyncTaskState.Failed(error));\n },\n );\n\n return result;\n },\n [handle],\n );\n\n return [execute, state];\n}\n","import type { TransactionResult } from '@aave/client';\nimport {\n CancelError,\n type SigningError,\n type TimeoutError,\n type TransactionError,\n type UnexpectedError,\n} from '@aave/core';\nimport type {\n Erc20ApprovalRequired,\n PreContractActionRequired,\n TransactionRequest,\n} from '@aave/graphql';\nimport type { ResultAsync } from '@aave/types';\nimport { invariant } from '@aave/types';\nimport type { UseAsyncTask } from './tasks';\n\n/**\n * The errors that could occur in the early stage of sending a transaction.\n */\nexport type SendTransactionError = CancelError | SigningError | UnexpectedError;\n\nexport type CancelOperation = (\n message: string,\n) => ResultAsync<never, CancelError>;\n\n/**\n * @internal\n */\nexport const cancel: CancelOperation = (message: string) =>\n CancelError.from(message).asResultAsync();\n\nexport type TransactionHandlerOptions = {\n cancel: CancelOperation;\n};\n\n/**\n * The errors that could occur in the late stages of a transaction.\n */\nexport type PendingTransactionError =\n | CancelError\n | TimeoutError\n | TransactionError\n | UnexpectedError;\n\nexport class PendingTransaction {\n constructor(\n /**\n * @internal Do NOT rely on this method. It's used internally by the SDK and may be subject to breaking changes.\n */\n public readonly wait: () => ResultAsync<\n TransactionResult,\n PendingTransactionError\n >,\n ) {}\n\n /**\n * @internal\n */\n static ensure<T>(value: T): PendingTransaction & T {\n invariant(\n value instanceof PendingTransaction,\n 'Expected PendingTransaction',\n );\n return value as PendingTransaction & T;\n }\n}\n\nexport type UseSendTransactionResult = UseAsyncTask<\n TransactionRequest,\n PendingTransaction,\n SendTransactionError\n>;\n\n/**\n * The handler for sending Aave transactions.\n */\nexport type TransactionHandler = (\n result:\n | TransactionRequest\n | Erc20ApprovalRequired\n | PreContractActionRequired,\n options: TransactionHandlerOptions,\n) => ResultAsync<PendingTransaction, SendTransactionError>;\n","import type { AaveClient } from '@aave/client';\nimport { invariant } from '@aave/types';\nimport React, { type ReactNode, useContext } from 'react';\nimport { Provider as UrqlProvider } from 'urql';\n\nconst AaveContext = React.createContext<AaveClient | null>(null);\n\n/**\n * @internal\n */\nexport type AaveContextProviderProps = {\n children: ReactNode;\n client: AaveClient;\n};\n\n/**\n * @internal\n */\nexport function AaveContextProvider({\n children,\n client,\n}: AaveContextProviderProps) {\n return (\n <AaveContext.Provider value={client}>\n <UrqlProvider value={client.urql}>{children}</UrqlProvider>\n </AaveContext.Provider>\n );\n}\n\n/**\n * @internal\n */\nexport function useAaveClient(): AaveClient {\n const client = useContext(AaveContext);\n\n invariant(\n client,\n 'Could not find Aave SDK context, ensure your code is wrapped in a <AaveProvider>',\n );\n\n return client;\n}\n","import type { UnexpectedError } from '@aave/client';\nimport { permitTypedData } from '@aave/client/actions';\nimport type { PermitRequest, PermitTypedDataResponse } from '@aave/graphql';\nimport { useAaveClient } from './context';\nimport { type UseAsyncTask, useAsyncTask } from './helpers';\n\n/**\n * @internal\n */\nexport function usePermitTypedDataAction(): UseAsyncTask<\n PermitRequest,\n PermitTypedDataResponse,\n UnexpectedError\n> {\n const client = useAaveClient();\n\n return useAsyncTask(\n (request: PermitRequest) => permitTypedData(client, request),\n [client],\n );\n}\n","import type { SigningError, UnexpectedError } from '@aave/client';\nimport {\n sendTransaction,\n signERC20PermitWith,\n signSwapTypedDataWith,\n waitForTransactionResult,\n} from '@aave/client/ethers';\nimport type {\n CancelSwapTypedData,\n ERC20PermitSignature,\n PermitRequest,\n SwapByIntentTypedData,\n TransactionRequest,\n} from '@aave/graphql';\n\nimport { invariant } from '@aave/types';\nimport type { Signer } from 'ethers';\nimport {\n PendingTransaction,\n type UseAsyncTask,\n type UseSendTransactionResult,\n useAsyncTask,\n} from './helpers';\nimport { usePermitTypedDataAction } from './permits';\n\n/**\n * A hook that provides a way to send Aave transactions using an ethers Signer instance.\n *\n * Retrieve the `Signer` instance from your ethers provider, then pass it to this hook to create a function that can be used to send transactions.\n *\n * ```ts\n * const provider = new ethers.providers.Web3Provider(window.ethereum);\n * const signer = provider.getSigner();\n *\n * // …\n *\n * const [sendTransaction, { loading, error, data }] = useSendTransaction(signer);\n * ```\n *\n * @param signer - The ethers Signer to use for sending transactions.\n */\nexport function useSendTransaction(signer: Signer): UseSendTransactionResult {\n return useAsyncTask(\n (request: TransactionRequest) => {\n return sendTransaction(signer, request).map(\n (response) =>\n new PendingTransaction(() =>\n waitForTransactionResult(request, response),\n ),\n );\n },\n [signer],\n );\n}\n\nexport type SignERC20PermitError = SigningError | UnexpectedError;\n\n/**\n * A hook that provides a way to sign ERC20 permits using an ethers Signer instance.\n *\n * ```ts\n * const provider = new ethers.providers.Web3Provider(window.ethereum);\n * const signer = provider.getSigner();\n *\n * // …\n *\n * const [signERC20Permit, { loading, error, data }] = useERC20Permit(signer);\n *\n * const run = async () => {\n * const result = await signERC20Permit({\n * supply: {\n * sender: evmAddress(await signer.getAddress()), // User's address\n * reserve: {\n * reserveId: reserve.id,\n * chainId: reserve.chain.chainId,\n * spoke: reserve.spoke.address,\n * },\n * amount: {\n * value: bigDecimal(42), // 42 USDC\n * },\n * },\n * });\n *\n * if (result.isErr()) {\n * console.error(result.error);\n * return;\n * }\n *\n * console.log('ERC20 Permit signature:', result.value);\n * };\n * ```\n *\n * @param signer - The ethers Signer to use for signing ERC20 permits.\n */\nexport function useERC20Permit(\n signer: Signer,\n): UseAsyncTask<PermitRequest, ERC20PermitSignature, SignERC20PermitError> {\n const [permitTypedData] = usePermitTypedDataAction();\n\n return useAsyncTask(\n (request: PermitRequest) => {\n return permitTypedData(request).andThen(signERC20PermitWith(signer));\n },\n [permitTypedData, signer],\n );\n}\n\nexport type SignSwapTypedDataError = SigningError | UnexpectedError;\n\n/**\n * @internal\n * A hook that provides a way to sign swap typed data using an ethers Signer instance.\n *\n * ```ts\n * const provider = new ethers.providers.Web3Provider(window.ethereum);\n * const signer = provider.getSigner();\n *\n * // …\n *\n * const [signSwapTypedData, { loading, error, data }] = useSignSwapTypedDataWith(signer);\n *\n * const run = async () => {\n * const result = await signSwapTypedData(swapTypedData);\n *\n * if (result.isErr()) {\n * console.error(result.error);\n * return;\n * }\n *\n * console.log('Swap typed data signed:', result.value);\n * };\n * ```\n *\n * @param signer - The ethers Signer to use for signing swap typed data.\n */\nexport function useSignSwapTypedDataWith(\n signer: Signer | undefined,\n): UseAsyncTask<\n SwapByIntentTypedData | CancelSwapTypedData,\n ERC20PermitSignature,\n SignSwapTypedDataError\n> {\n return useAsyncTask(\n (typedData: SwapByIntentTypedData | CancelSwapTypedData) => {\n invariant(signer, 'Expected a Signer to sign swap typed data');\n\n return signSwapTypedDataWith(signer)(typedData);\n },\n [signer],\n );\n}\n"]}
package/dist/ethers.d.cts CHANGED
@@ -1,14 +1,14 @@
1
- import { SigningError, TimeoutError, TransactionError, UnexpectedError } from '@aave/client';
2
- import { TransactionRequest, PermitTypedDataRequest, ERC712Signature } from '@aave/graphql';
3
- import { TxHash } from '@aave/types';
1
+ import { SigningError, UnexpectedError } from '@aave/client';
2
+ import { PermitRequest, ERC20PermitSignature, SwapByIntentTypedData, CancelSwapTypedData } from '@aave/graphql';
4
3
  import { Signer } from 'ethers';
5
- import { U as UseAsyncTask } from './tasks-DUn7x8pK.cjs';
4
+ import { U as UseSendTransactionResult, a as UseAsyncTask } from './writes-BXnwYgAQ.cjs';
5
+ import '@aave/core';
6
+ import '@aave/types';
6
7
 
7
- type SendTransactionError = SigningError | TimeoutError | TransactionError | UnexpectedError;
8
8
  /**
9
9
  * A hook that provides a way to send Aave transactions using an ethers Signer instance.
10
10
  *
11
- * First, get the `Signer` instance from your ethers provider, then pass it to this hook to create a function that can be used to send transactions.
11
+ * Retrieve the `Signer` instance from your ethers provider, then pass it to this hook to create a function that can be used to send transactions.
12
12
  *
13
13
  * ```ts
14
14
  * const provider = new ethers.providers.Web3Provider(window.ethereum);
@@ -19,75 +19,52 @@ type SendTransactionError = SigningError | TimeoutError | TransactionError | Une
19
19
  * const [sendTransaction, { loading, error, data }] = useSendTransaction(signer);
20
20
  * ```
21
21
  *
22
- * Then, use it to send a {@link TransactionRequest} as shown below.
22
+ * @param signer - The ethers Signer to use for sending transactions.
23
+ */
24
+ declare function useSendTransaction(signer: Signer): UseSendTransactionResult;
25
+ type SignERC20PermitError = SigningError | UnexpectedError;
26
+ /**
27
+ * A hook that provides a way to sign ERC20 permits using an ethers Signer instance.
23
28
  *
24
29
  * ```ts
25
- * const [toggle, { loading, error, data }] = useEModeToggle();
26
- *
27
- * const run = async () => {
28
- * const result = await toggle({
29
- * chainId: chainId(1), // Ethereum mainnet
30
- * market: evmAddress('0x1234…'),
31
- * user: evmAddress(await signer.getAddress()),
32
- * })
33
- * .andThen(sendTransaction);
34
- *
35
- * if (result.isErr()) {
36
- * console.error(result.error);
37
- * return;
38
- * }
39
- *
40
- * console.log('Transaction sent with hash:', result.value);
41
- * };
42
- * ```
30
+ * const provider = new ethers.providers.Web3Provider(window.ethereum);
31
+ * const signer = provider.getSigner();
43
32
  *
44
- * Or use it to handle an {@link ExecutionPlan} that may require multiple transactions as shown below.
33
+ * //
45
34
  *
46
- * ```ts
47
- * const [supply, { loading, error, data }] = useSupply();
35
+ * const [signERC20Permit, { loading, error, data }] = useERC20Permit(signer);
48
36
  *
49
37
  * const run = async () => {
50
- * const result = await supply({
51
- * chainId: chainId(1), // Ethereum mainnet
52
- * market: evmAddress('0x1234…'),
53
- * amount: {
54
- * erc20: {
55
- * currency: evmAddress('0x5678…'),
56
- * value: '42.42',
57
- * }
38
+ * const result = await signERC20Permit({
39
+ * supply: {
40
+ * sender: evmAddress(await signer.getAddress()), // User's address
41
+ * reserve: {
42
+ * reserveId: reserve.id,
43
+ * chainId: reserve.chain.chainId,
44
+ * spoke: reserve.spoke.address,
45
+ * },
46
+ * amount: {
47
+ * value: bigDecimal(42), // 42 USDC
48
+ * },
58
49
  * },
59
- * supplier: evmAddress(await signer.getAddress()),
60
- * })
61
- * .andThen((plan) => {
62
- * switch (plan.__typename) {
63
- * case 'TransactionRequest':
64
- * return sendTransaction(plan);
65
- *
66
- * case 'ApprovalRequired':
67
- * return sendTransaction(plan.approval).andThen(() =>
68
- * sendTransaction(plan.originalTransaction),
69
- * );
70
- *
71
- * case 'InsufficientBalanceError':
72
- * return errAsync(new Error(`Insufficient balance: ${error.cause.required.value} required.`));
73
- * }
74
- * });
50
+ * });
75
51
  *
76
52
  * if (result.isErr()) {
77
53
  * console.error(result.error);
78
54
  * return;
79
55
  * }
80
56
  *
81
- * console.log('Transaction sent with hash:', result.value);
82
- * }
57
+ * console.log('ERC20 Permit signature:', result.value);
58
+ * };
83
59
  * ```
84
60
  *
85
- * @param signer - The ethers Signer to use for sending transactions.
61
+ * @param signer - The ethers Signer to use for signing ERC20 permits.
86
62
  */
87
- declare function useSendTransaction(signer: Signer): UseAsyncTask<TransactionRequest, TxHash, SendTransactionError>;
88
- type SignERC20PermitError = SigningError | UnexpectedError;
63
+ declare function useERC20Permit(signer: Signer): UseAsyncTask<PermitRequest, ERC20PermitSignature, SignERC20PermitError>;
64
+ type SignSwapTypedDataError = SigningError | UnexpectedError;
89
65
  /**
90
- * A hook that provides a way to sign ERC20 permits using an ethers Signer instance.
66
+ * @internal
67
+ * A hook that provides a way to sign swap typed data using an ethers Signer instance.
91
68
  *
92
69
  * ```ts
93
70
  * const provider = new ethers.providers.Web3Provider(window.ethereum);
@@ -95,29 +72,22 @@ type SignERC20PermitError = SigningError | UnexpectedError;
95
72
  *
96
73
  * // …
97
74
  *
98
- * const [signERC20Permit, { loading, error, data }] = useERC20Permit(signer);
75
+ * const [signSwapTypedData, { loading, error, data }] = useSignSwapTypedDataWith(signer);
99
76
  *
100
77
  * const run = async () => {
101
- * const result = await signERC20Permit({
102
- * chainId: chainId(1), // Ethereum mainnet
103
- * market: evmAddress('0x1234…'),
104
- * underlyingToken: evmAddress('0x5678…'),
105
- * amount: '42.42',
106
- * spender: evmAddress('0x9abc…'),
107
- * owner: evmAddress(await signer.getAddress()),
108
- * });
78
+ * const result = await signSwapTypedData(swapTypedData);
109
79
  *
110
80
  * if (result.isErr()) {
111
81
  * console.error(result.error);
112
82
  * return;
113
83
  * }
114
84
  *
115
- * console.log('ERC20 permit signed:', result.value);
85
+ * console.log('Swap typed data signed:', result.value);
116
86
  * };
117
87
  * ```
118
88
  *
119
- * @param signer - The ethers Signer to use for signing ERC20 permits.
89
+ * @param signer - The ethers Signer to use for signing swap typed data.
120
90
  */
121
- declare function useERC20Permit(signer: Signer): UseAsyncTask<PermitTypedDataRequest, ERC712Signature, SignERC20PermitError>;
91
+ declare function useSignSwapTypedDataWith(signer: Signer | undefined): UseAsyncTask<SwapByIntentTypedData | CancelSwapTypedData, ERC20PermitSignature, SignSwapTypedDataError>;
122
92
 
123
- export { type SendTransactionError, type SignERC20PermitError, useERC20Permit, useSendTransaction };
93
+ export { type SignERC20PermitError, type SignSwapTypedDataError, useERC20Permit, useSendTransaction, useSignSwapTypedDataWith };
package/dist/ethers.d.ts CHANGED
@@ -1,14 +1,14 @@
1
- import { SigningError, TimeoutError, TransactionError, UnexpectedError } from '@aave/client';
2
- import { TransactionRequest, PermitTypedDataRequest, ERC712Signature } from '@aave/graphql';
3
- import { TxHash } from '@aave/types';
1
+ import { SigningError, UnexpectedError } from '@aave/client';
2
+ import { PermitRequest, ERC20PermitSignature, SwapByIntentTypedData, CancelSwapTypedData } from '@aave/graphql';
4
3
  import { Signer } from 'ethers';
5
- import { U as UseAsyncTask } from './tasks-DUn7x8pK.js';
4
+ import { U as UseSendTransactionResult, a as UseAsyncTask } from './writes-BXnwYgAQ.js';
5
+ import '@aave/core';
6
+ import '@aave/types';
6
7
 
7
- type SendTransactionError = SigningError | TimeoutError | TransactionError | UnexpectedError;
8
8
  /**
9
9
  * A hook that provides a way to send Aave transactions using an ethers Signer instance.
10
10
  *
11
- * First, get the `Signer` instance from your ethers provider, then pass it to this hook to create a function that can be used to send transactions.
11
+ * Retrieve the `Signer` instance from your ethers provider, then pass it to this hook to create a function that can be used to send transactions.
12
12
  *
13
13
  * ```ts
14
14
  * const provider = new ethers.providers.Web3Provider(window.ethereum);
@@ -19,75 +19,52 @@ type SendTransactionError = SigningError | TimeoutError | TransactionError | Une
19
19
  * const [sendTransaction, { loading, error, data }] = useSendTransaction(signer);
20
20
  * ```
21
21
  *
22
- * Then, use it to send a {@link TransactionRequest} as shown below.
22
+ * @param signer - The ethers Signer to use for sending transactions.
23
+ */
24
+ declare function useSendTransaction(signer: Signer): UseSendTransactionResult;
25
+ type SignERC20PermitError = SigningError | UnexpectedError;
26
+ /**
27
+ * A hook that provides a way to sign ERC20 permits using an ethers Signer instance.
23
28
  *
24
29
  * ```ts
25
- * const [toggle, { loading, error, data }] = useEModeToggle();
26
- *
27
- * const run = async () => {
28
- * const result = await toggle({
29
- * chainId: chainId(1), // Ethereum mainnet
30
- * market: evmAddress('0x1234…'),
31
- * user: evmAddress(await signer.getAddress()),
32
- * })
33
- * .andThen(sendTransaction);
34
- *
35
- * if (result.isErr()) {
36
- * console.error(result.error);
37
- * return;
38
- * }
39
- *
40
- * console.log('Transaction sent with hash:', result.value);
41
- * };
42
- * ```
30
+ * const provider = new ethers.providers.Web3Provider(window.ethereum);
31
+ * const signer = provider.getSigner();
43
32
  *
44
- * Or use it to handle an {@link ExecutionPlan} that may require multiple transactions as shown below.
33
+ * //
45
34
  *
46
- * ```ts
47
- * const [supply, { loading, error, data }] = useSupply();
35
+ * const [signERC20Permit, { loading, error, data }] = useERC20Permit(signer);
48
36
  *
49
37
  * const run = async () => {
50
- * const result = await supply({
51
- * chainId: chainId(1), // Ethereum mainnet
52
- * market: evmAddress('0x1234…'),
53
- * amount: {
54
- * erc20: {
55
- * currency: evmAddress('0x5678…'),
56
- * value: '42.42',
57
- * }
38
+ * const result = await signERC20Permit({
39
+ * supply: {
40
+ * sender: evmAddress(await signer.getAddress()), // User's address
41
+ * reserve: {
42
+ * reserveId: reserve.id,
43
+ * chainId: reserve.chain.chainId,
44
+ * spoke: reserve.spoke.address,
45
+ * },
46
+ * amount: {
47
+ * value: bigDecimal(42), // 42 USDC
48
+ * },
58
49
  * },
59
- * supplier: evmAddress(await signer.getAddress()),
60
- * })
61
- * .andThen((plan) => {
62
- * switch (plan.__typename) {
63
- * case 'TransactionRequest':
64
- * return sendTransaction(plan);
65
- *
66
- * case 'ApprovalRequired':
67
- * return sendTransaction(plan.approval).andThen(() =>
68
- * sendTransaction(plan.originalTransaction),
69
- * );
70
- *
71
- * case 'InsufficientBalanceError':
72
- * return errAsync(new Error(`Insufficient balance: ${error.cause.required.value} required.`));
73
- * }
74
- * });
50
+ * });
75
51
  *
76
52
  * if (result.isErr()) {
77
53
  * console.error(result.error);
78
54
  * return;
79
55
  * }
80
56
  *
81
- * console.log('Transaction sent with hash:', result.value);
82
- * }
57
+ * console.log('ERC20 Permit signature:', result.value);
58
+ * };
83
59
  * ```
84
60
  *
85
- * @param signer - The ethers Signer to use for sending transactions.
61
+ * @param signer - The ethers Signer to use for signing ERC20 permits.
86
62
  */
87
- declare function useSendTransaction(signer: Signer): UseAsyncTask<TransactionRequest, TxHash, SendTransactionError>;
88
- type SignERC20PermitError = SigningError | UnexpectedError;
63
+ declare function useERC20Permit(signer: Signer): UseAsyncTask<PermitRequest, ERC20PermitSignature, SignERC20PermitError>;
64
+ type SignSwapTypedDataError = SigningError | UnexpectedError;
89
65
  /**
90
- * A hook that provides a way to sign ERC20 permits using an ethers Signer instance.
66
+ * @internal
67
+ * A hook that provides a way to sign swap typed data using an ethers Signer instance.
91
68
  *
92
69
  * ```ts
93
70
  * const provider = new ethers.providers.Web3Provider(window.ethereum);
@@ -95,29 +72,22 @@ type SignERC20PermitError = SigningError | UnexpectedError;
95
72
  *
96
73
  * // …
97
74
  *
98
- * const [signERC20Permit, { loading, error, data }] = useERC20Permit(signer);
75
+ * const [signSwapTypedData, { loading, error, data }] = useSignSwapTypedDataWith(signer);
99
76
  *
100
77
  * const run = async () => {
101
- * const result = await signERC20Permit({
102
- * chainId: chainId(1), // Ethereum mainnet
103
- * market: evmAddress('0x1234…'),
104
- * underlyingToken: evmAddress('0x5678…'),
105
- * amount: '42.42',
106
- * spender: evmAddress('0x9abc…'),
107
- * owner: evmAddress(await signer.getAddress()),
108
- * });
78
+ * const result = await signSwapTypedData(swapTypedData);
109
79
  *
110
80
  * if (result.isErr()) {
111
81
  * console.error(result.error);
112
82
  * return;
113
83
  * }
114
84
  *
115
- * console.log('ERC20 permit signed:', result.value);
85
+ * console.log('Swap typed data signed:', result.value);
116
86
  * };
117
87
  * ```
118
88
  *
119
- * @param signer - The ethers Signer to use for signing ERC20 permits.
89
+ * @param signer - The ethers Signer to use for signing swap typed data.
120
90
  */
121
- declare function useERC20Permit(signer: Signer): UseAsyncTask<PermitTypedDataRequest, ERC712Signature, SignERC20PermitError>;
91
+ declare function useSignSwapTypedDataWith(signer: Signer | undefined): UseAsyncTask<SwapByIntentTypedData | CancelSwapTypedData, ERC20PermitSignature, SignSwapTypedDataError>;
122
92
 
123
- export { type SendTransactionError, type SignERC20PermitError, useERC20Permit, useSendTransaction };
93
+ export { type SignERC20PermitError, type SignSwapTypedDataError, useERC20Permit, useSendTransaction, useSignSwapTypedDataWith };
package/dist/ethers.js CHANGED
@@ -1,2 +1,2 @@
1
- import {b,c}from'./chunk-SECI6TSB.js';import {permitTypedData}from'@aave/client/actions';import {sendTransactionAndWait,signERC20PermitWith}from'@aave/client/ethers';function u(r){let e=b();return c(t=>sendTransactionAndWait(r,t).andThen(e.waitForSupportedTransaction))}function E(r){let e=b();return c(t=>permitTypedData(e,t).andThen(signERC20PermitWith(r)))}export{E as useERC20Permit,u as useSendTransaction};//# sourceMappingURL=ethers.js.map
1
+ import {a,c,f}from'./chunk-GTUQRT5Q.js';import {sendTransaction,waitForTransactionResult,signERC20PermitWith,signSwapTypedDataWith}from'@aave/client/ethers';import {invariant}from'@aave/types';function T(e){return a(t=>sendTransaction(e,t).map(n=>new c(()=>waitForTransactionResult(t,n))),[e])}function g(e){let[t]=f();return a(n=>t(n).andThen(signERC20PermitWith(e)),[t,e])}function E(e){return a(t=>(invariant(e,"Expected a Signer to sign swap typed data"),signSwapTypedDataWith(e)(t)),[e])}export{g as useERC20Permit,T as useSendTransaction,E as useSignSwapTypedDataWith};//# sourceMappingURL=ethers.js.map
2
2
  //# sourceMappingURL=ethers.js.map