From fcd6ffed8c8a14e565396fa0af4377eaabd985aa Mon Sep 17 00:00:00 2001 From: Francesco Ceccon Date: Wed, 26 Jun 2024 17:02:55 +0200 Subject: [PATCH] core: fix enable/disable query --- .changeset/real-ducks-dress.md | 5 +++++ packages/core/src/hooks/useBalance.test.ts | 12 ++++++------ packages/core/src/hooks/useBalance.ts | 1 + packages/core/src/hooks/useContractRead.ts | 1 + packages/core/src/hooks/useEstimateFees.ts | 1 + packages/core/src/hooks/useStarkName.ts | 6 +++--- packages/core/src/hooks/useStarkProfile.ts | 14 +++++++------- website/components/demos/contract-read.tsx | 17 +++++++++++++++++ 8 files changed, 41 insertions(+), 16 deletions(-) create mode 100644 .changeset/real-ducks-dress.md diff --git a/.changeset/real-ducks-dress.md b/.changeset/real-ducks-dress.md new file mode 100644 index 00000000..c981a1eb --- /dev/null +++ b/.changeset/real-ducks-dress.md @@ -0,0 +1,5 @@ +--- +"@starknet-react/core": patch +--- + +Fix disabling queries diff --git a/packages/core/src/hooks/useBalance.test.ts b/packages/core/src/hooks/useBalance.test.ts index 35290eb4..3407a928 100644 --- a/packages/core/src/hooks/useBalance.test.ts +++ b/packages/core/src/hooks/useBalance.test.ts @@ -10,21 +10,21 @@ describe("useBalance", () => { const { result } = renderHook(() => useBalance({})); await waitFor(() => { - expect(result.current.status).toEqual("error"); + expect(result.current.status).toEqual("pending"); }); expect(result.current).toMatchInlineSnapshot(` { "data": undefined, - "error": [Error: address is required], + "error": null, "fetchStatus": "idle", - "isError": true, + "isError": false, "isFetching": false, "isLoading": false, - "isPending": false, + "isPending": true, "isSuccess": false, "refetch": [Function], - "status": "error", + "status": "pending", } `); }); @@ -34,7 +34,7 @@ describe("useBalance", () => { // Some issue with the RPC provider. it.skip("returns the balance", async () => { const { result } = renderHook(() => - useBalance({ address: accounts.goerli[0].address }), + useBalance({ address: accounts.goerli[0].address }) ); await waitFor(() => { diff --git a/packages/core/src/hooks/useBalance.ts b/packages/core/src/hooks/useBalance.ts index 381989b4..fc745e07 100644 --- a/packages/core/src/hooks/useBalance.ts +++ b/packages/core/src/hooks/useBalance.ts @@ -81,6 +81,7 @@ export function useBalance({ }); return useQuery({ + enabled, queryKey: queryKey_, queryFn: queryFn({ chain, contract, token, address, blockIdentifier }), refetchInterval, diff --git a/packages/core/src/hooks/useContractRead.ts b/packages/core/src/hooks/useContractRead.ts index 6c0a17a3..a22165ee 100644 --- a/packages/core/src/hooks/useContractRead.ts +++ b/packages/core/src/hooks/useContractRead.ts @@ -90,6 +90,7 @@ export function useContractRead({ }); return useQuery({ + enabled, queryKey: queryKey_, queryFn: queryFn({ contract, diff --git a/packages/core/src/hooks/useEstimateFees.ts b/packages/core/src/hooks/useEstimateFees.ts index c435dbf3..e43cd493 100644 --- a/packages/core/src/hooks/useEstimateFees.ts +++ b/packages/core/src/hooks/useEstimateFees.ts @@ -62,6 +62,7 @@ export function useEstimateFees({ }); return useQuery({ + enabled, queryKey: queryKey_, queryFn: queryFn({ account, diff --git a/packages/core/src/hooks/useStarkName.ts b/packages/core/src/hooks/useStarkName.ts index d48b9b4c..71b1be1c 100644 --- a/packages/core/src/hooks/useStarkName.ts +++ b/packages/core/src/hooks/useStarkName.ts @@ -76,7 +76,7 @@ export function useStarkName({ const enabled = useMemo( () => Boolean(enabled_ && address), - [enabled_, address] + [enabled_, address], ); return useQuery({ @@ -132,7 +132,7 @@ function queryFn({ const hexDomain = await executeWithFallback( p, calldata, - fallbackCalldata + fallbackCalldata, ); const decimalDomain = hexDomain.result .map((element) => BigInt(element)) @@ -151,7 +151,7 @@ function queryFn({ const executeWithFallback = async ( provider: ProviderInterface, initialCall: Call, - fallbackCall: Call + fallbackCall: Call, ) => { try { // Attempt the initial call with the hint parameter diff --git a/packages/core/src/hooks/useStarkProfile.ts b/packages/core/src/hooks/useStarkProfile.ts index 478ec767..1179d14d 100644 --- a/packages/core/src/hooks/useStarkProfile.ts +++ b/packages/core/src/hooks/useStarkProfile.ts @@ -123,7 +123,7 @@ export function useStarkProfile({ const enabled = useMemo( () => Boolean(enabled_ && address), - [enabled_, address] + [enabled_, address], ); return useQuery({ @@ -180,13 +180,13 @@ function queryFn({ address, naming, identity, - contracts + contracts, ); const data = await executeMulticallWithFallback( multicallContract, "aggregate", initialCalldata, - fallbackCalldata + fallbackCalldata, ); if (Array.isArray(data)) { @@ -207,7 +207,7 @@ function queryFn({ ? data[8] .slice(1) .map((val: BigInt) => - shortString.decodeShortString(val.toString()) + shortString.decodeShortString(val.toString()), ) .join("") : undefined; @@ -339,7 +339,7 @@ const executeMulticallWithFallback = async ( contract: ContractInterface, functionName: string, initialCalldata: RawArgsArray, - fallbackCalldata: RawArgsArray + fallbackCalldata: RawArgsArray, ) => { try { // Attempt the initial call with the new hint parameter @@ -358,7 +358,7 @@ const getStarkProfileCalldata = ( address: string, namingContract: string, identityContract: string, - contracts: Record + contracts: Record, ): { initialCalldata: RawArgsArray; fallbackCalldata: RawArgsArray; @@ -446,7 +446,7 @@ const getStarkProfileCalldata = ( execution: staticExecution(), to: hardcoded(identityContract), selector: hardcoded( - hash.getSelectorFromName("get_extended_verifier_data") + hash.getSelectorFromName("get_extended_verifier_data"), ), calldata: [ reference(1, 0), diff --git a/website/components/demos/contract-read.tsx b/website/components/demos/contract-read.tsx index 4ceca9b5..311bd1f1 100644 --- a/website/components/demos/contract-read.tsx +++ b/website/components/demos/contract-read.tsx @@ -16,9 +16,12 @@ import { SelectValue, } from "@/components/ui/select"; import { Button } from "@/components/ui/button"; +import { Checkbox } from "../ui/checkbox"; function ContractRead() { const [blockIdentifier, setBlockIdentifier] = useState("latest"); + const [enabled, setEnabled] = useState(false); + const { chain } = useNetwork(); const { data, refetch, fetchStatus, status } = useContractRead({ @@ -40,6 +43,7 @@ function ContractRead() { address: chain.nativeCurrency.address, args: [], watch: true, + enabled, blockIdentifier: blockIdentifier === "latest" ? BlockTag.latest : BlockTag.pending, }); @@ -70,6 +74,19 @@ function ContractRead() { +
+ setEnabled(c === true)} + /> + +

{fetchStatus}