/* * Code generated by Speakeasy (https://speakeasy.com). DO NOT EDIT. */ import { InvalidateQueryFilters, QueryClient, useQuery, UseQueryResult, useSuspenseQuery, UseSuspenseQueryResult, } from "@tanstack/react-query"; import { GustoEmbeddedError } from "../models/errors/gustoembeddederror.js"; import { ConnectionError, InvalidRequestError, RequestAbortedError, RequestTimeoutError, UnexpectedClientError, } from "../models/errors/httpclienterrors.js"; import { NotFoundErrorObject } from "../models/errors/notfounderrorobject.js"; import { ResponseValidationError } from "../models/errors/responsevalidationerror.js"; import { SDKValidationError } from "../models/errors/sdkvalidationerror.js"; import { GetV1ContractorsContractorUuidAddressHeaderXGustoAPIVersion, GetV1ContractorsContractorUuidAddressRequest, } from "../models/operations/getv1contractorscontractoruuidaddress.js"; import { useGustoEmbeddedContext } from "./_context.js"; import { QueryHookOptions, SuspenseQueryHookOptions, TupleToPrefixes, } from "./_types.js"; import { buildContractorsGetAddressQuery, ContractorsGetAddressQueryData, prefetchContractorsGetAddress, queryKeyContractorsGetAddress, } from "./contractorsGetAddress.core.js"; export { buildContractorsGetAddressQuery, type ContractorsGetAddressQueryData, prefetchContractorsGetAddress, queryKeyContractorsGetAddress, }; export type ContractorsGetAddressQueryError = | NotFoundErrorObject | GustoEmbeddedError | ResponseValidationError | ConnectionError | RequestAbortedError | RequestTimeoutError | InvalidRequestError | UnexpectedClientError | SDKValidationError; /** * Get a contractor address * * @remarks * The address of a contractor is used to determine certain tax information about them. Addresses are geocoded on create and update to ensure validity. * * scope: `contractors:read` */ export function useContractorsGetAddress( request: GetV1ContractorsContractorUuidAddressRequest, options?: QueryHookOptions< ContractorsGetAddressQueryData, ContractorsGetAddressQueryError >, ): UseQueryResult< ContractorsGetAddressQueryData, ContractorsGetAddressQueryError > { const client = useGustoEmbeddedContext(); return useQuery({ ...buildContractorsGetAddressQuery( client, request, options, ), ...options, }); } /** * Get a contractor address * * @remarks * The address of a contractor is used to determine certain tax information about them. Addresses are geocoded on create and update to ensure validity. * * scope: `contractors:read` */ export function useContractorsGetAddressSuspense( request: GetV1ContractorsContractorUuidAddressRequest, options?: SuspenseQueryHookOptions< ContractorsGetAddressQueryData, ContractorsGetAddressQueryError >, ): UseSuspenseQueryResult< ContractorsGetAddressQueryData, ContractorsGetAddressQueryError > { const client = useGustoEmbeddedContext(); return useSuspenseQuery({ ...buildContractorsGetAddressQuery( client, request, options, ), ...options, }); } export function setContractorsGetAddressData( client: QueryClient, queryKeyBase: [ contractorUuid: string, parameters: { xGustoAPIVersion?: | GetV1ContractorsContractorUuidAddressHeaderXGustoAPIVersion | undefined; }, ], data: ContractorsGetAddressQueryData, ): ContractorsGetAddressQueryData | undefined { const key = queryKeyContractorsGetAddress(...queryKeyBase); return client.setQueryData(key, data); } export function invalidateContractorsGetAddress( client: QueryClient, queryKeyBase: TupleToPrefixes< [ contractorUuid: string, parameters: { xGustoAPIVersion?: | GetV1ContractorsContractorUuidAddressHeaderXGustoAPIVersion | undefined; }, ] >, filters?: Omit, ): Promise { return client.invalidateQueries({ ...filters, queryKey: [ "@gusto/embedded-api", "Contractors", "getAddress", ...queryKeyBase, ], }); } export function invalidateAllContractorsGetAddress( client: QueryClient, filters?: Omit, ): Promise { return client.invalidateQueries({ ...filters, queryKey: ["@gusto/embedded-api", "Contractors", "getAddress"], }); }