You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
// This should be either `useClient` or `client` depending on optionimport{useClient,client}from"client-path";exportfunctionuseFoo(options: {mutation?: UseMutationOptions<...>;client?: Foo['client'];}={},){const{mutation: mutationOptions,client: clientWithParams={}}=options;constclient=useClient(clientWithParams.options);returnuseMutation({mutationFn: async(data)=>{constres=await(clientWithParams.return||client)<...>({method: 'post',url: `...`,
data,
...clientWithParams.parameters,});returnres.data;},
...mutationOptions,});}
// tanstack-query plugin optionstypeOptions={//...client?: {importPath?: stringimportHook?: boolean;// if true - import `useClient` instead of `client`}};
What alternatives have you considered?
Replacing the template.
It seems like the template is a rendered react component which means it's basically non-modifiable, I have to rewrite it from scratch.
It's easier to replace lines by regex after generating.
The text was updated successfully, but these errors were encountered:
importclientfrom'@kubb/plugin-client/clients/axios'importuseClientfrom'./path'importtype{AddPetMutationRequest,AddPetMutationResponse,AddPet405}from'../../models/AddPet.ts'importtype{RequestConfig,ResponseErrorConfig}from'@kubb/plugin-client/clients/axios'importtype{UseMutationOptions}from'@tanstack/react-query'import{useMutation}from'@tanstack/react-query'exportconstaddPetMutationKey=()=>[{url: '/pet'}]asconstexporttypeAddPetMutationKey=ReturnType<typeofaddPetMutationKey>/** * @description Add a new pet to the store * @summary Add a new pet to the store * {@link /pet} */exportasyncfunctionaddPetHook(data: AddPetMutationRequest,config: Partial<RequestConfig<AddPetMutationRequest>>={}){constres=awaitclient<AddPetMutationResponse,ResponseErrorConfig<AddPet405>,AddPetMutationRequest>({method: 'POST',url: `/pet`, data, ...config})returnres.data}asyncfunctionaddPetHookFactory(_client: typeofclient){returnasyncfunctionaddPetHook(data: AddPetMutationRequest,config: Partial<RequestConfig<AddPetMutationRequest>>={}){constres=await_client<AddPetMutationResponse,ResponseErrorConfig<AddPet405>,AddPetMutationRequest>({method: 'POST',url: `/pet`, data, ...config})returnres.data}}/** * @description Add a new pet to the store * @summary Add a new pet to the store * {@link /pet} */exportfunctionuseAddPetHook(options: {mutation?: UseMutationOptions<AddPetMutationResponse,ResponseErrorConfig<AddPet405>,{data: AddPetMutationRequest}>client?: Partial<RequestConfig<AddPetMutationRequest>>}={},){const{mutation: mutationOptions,client: config={}}=options??{}constmutationKey=mutationOptions?.mutationKey??addPetMutationKey()constclient=useClient(config)returnuseMutation<AddPetMutationResponse,ResponseErrorConfig<AddPet405>,{data: AddPetMutationRequest}>({mutationFn: async({ data })=>{returnaddPetHookFactory(client)(data,config)},
mutationKey,
...mutationOptions,})}
What is the problem this feature would solve?
I need to use multiple clients for the same set of
useQuery
/useMutation
generated hooks.External documents/projects?
No response
What is the feature you are proposing to solve the problem?
Currently I have generated code:
I want it be changed to:
What alternatives have you considered?
Replacing the template.
It seems like the template is a rendered react component which means it's basically non-modifiable, I have to rewrite it from scratch.
It's easier to replace lines by regex after generating.
The text was updated successfully, but these errors were encountered: