@kubb/plugin-react-query 3.0.0-alpha.9 → 3.0.0-beta.2

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 (78) hide show
  1. package/README.md +14 -5
  2. package/dist/chunk-37VO6QXJ.cjs +669 -0
  3. package/dist/chunk-37VO6QXJ.cjs.map +1 -0
  4. package/dist/chunk-C2H3KPHM.cjs +658 -0
  5. package/dist/chunk-C2H3KPHM.cjs.map +1 -0
  6. package/dist/chunk-IRW2Y3EC.js +660 -0
  7. package/dist/chunk-IRW2Y3EC.js.map +1 -0
  8. package/dist/chunk-Y3DM2P6L.js +647 -0
  9. package/dist/chunk-Y3DM2P6L.js.map +1 -0
  10. package/dist/components.cjs +39 -12
  11. package/dist/components.cjs.map +1 -1
  12. package/dist/components.d.cts +161 -6
  13. package/dist/components.d.ts +161 -6
  14. package/dist/components.js +2 -12
  15. package/dist/components.js.map +1 -1
  16. package/dist/generators.cjs +25 -0
  17. package/dist/generators.cjs.map +1 -0
  18. package/dist/generators.d.cts +14 -0
  19. package/dist/generators.d.ts +14 -0
  20. package/dist/generators.js +4 -0
  21. package/dist/generators.js.map +1 -0
  22. package/dist/index.cjs +78 -130
  23. package/dist/index.cjs.map +1 -1
  24. package/dist/index.d.cts +1 -4
  25. package/dist/index.d.ts +1 -4
  26. package/dist/index.js +61 -120
  27. package/dist/index.js.map +1 -1
  28. package/dist/types-5pnOmDmM.d.cts +231 -0
  29. package/dist/types-5pnOmDmM.d.ts +231 -0
  30. package/package.json +22 -17
  31. package/src/components/InfiniteQuery.tsx +129 -0
  32. package/src/components/InfiniteQueryOptions.tsx +130 -0
  33. package/src/components/Mutation.tsx +137 -321
  34. package/src/components/MutationKey.tsx +48 -0
  35. package/src/components/Query.tsx +91 -594
  36. package/src/components/QueryKey.tsx +51 -182
  37. package/src/components/QueryOptions.tsx +71 -473
  38. package/src/components/SuspenseQuery.tsx +129 -0
  39. package/src/components/index.ts +4 -0
  40. package/src/generators/__snapshots__/clientDataReturnTypeFull.ts +51 -0
  41. package/src/generators/__snapshots__/clientGetImportPath.ts +51 -0
  42. package/src/generators/__snapshots__/clientPostImportPath.ts +44 -0
  43. package/src/generators/__snapshots__/findByTags.ts +51 -0
  44. package/src/generators/__snapshots__/findByTagsPathParamsObject.ts +51 -0
  45. package/src/generators/__snapshots__/findByTagsWithCustomQueryKey.ts +51 -0
  46. package/src/generators/__snapshots__/findByTagsWithZod.ts +51 -0
  47. package/src/generators/__snapshots__/findInfiniteByTags.ts +57 -0
  48. package/src/generators/__snapshots__/findInfiniteByTagsCursor.ts +57 -0
  49. package/src/generators/__snapshots__/getAsMutation.ts +31 -0
  50. package/src/generators/__snapshots__/postAsQuery.ts +50 -0
  51. package/src/generators/__snapshots__/updatePetById.ts +44 -0
  52. package/src/generators/__snapshots__/updatePetByIdPathParamsObject.ts +46 -0
  53. package/src/generators/index.ts +4 -0
  54. package/src/generators/infiniteQueryGenerator.tsx +124 -0
  55. package/src/generators/mutationGenerator.tsx +108 -0
  56. package/src/generators/queryGenerator.tsx +121 -0
  57. package/src/generators/suspenseQueryGenerator.tsx +120 -0
  58. package/src/plugin.ts +60 -76
  59. package/src/types.ts +42 -115
  60. package/dist/chunk-7ZODZVKP.cjs +0 -1470
  61. package/dist/chunk-7ZODZVKP.cjs.map +0 -1
  62. package/dist/chunk-ZYTZV43V.js +0 -1470
  63. package/dist/chunk-ZYTZV43V.js.map +0 -1
  64. package/dist/index-5kpkk-7M.d.cts +0 -545
  65. package/dist/index-5kpkk-7M.d.ts +0 -545
  66. package/src/OperationGenerator.tsx +0 -57
  67. package/src/__snapshots__/mutateAsQuery/updatePetWithForm.ts +0 -69
  68. package/src/__snapshots__/pathParamsTypeInline/getPetById.ts +0 -62
  69. package/src/__snapshots__/pathParamsTypeObject/getPetById.ts +0 -68
  70. package/src/__snapshots__/queryOptions/getPetById.ts +0 -41
  71. package/src/__snapshots__/queryWithoutQueryOptions/getPetById.ts +0 -51
  72. package/src/__snapshots__/variablesTypeMutate/deletePet.ts +0 -24
  73. package/src/components/QueryImports.tsx +0 -167
  74. package/src/components/SchemaType.tsx +0 -59
  75. package/src/components/__snapshots__/gen/showPetById.ts +0 -67
  76. package/src/components/__snapshots__/gen/useCreatePets.ts +0 -46
  77. package/src/components/__snapshots__/gen/useCreatePetsMutate.ts +0 -46
  78. package/src/utils.ts +0 -96
@@ -1 +0,0 @@
1
- {"version":3,"sources":["/home/runner/work/kubb/kubb/packages/plugin-react-query/dist/chunk-7ZODZVKP.cjs","../src/components/Mutation.tsx","../src/components/SchemaType.tsx","../src/components/Query.tsx","../src/utils.ts","../src/components/QueryImports.tsx","../src/components/QueryKey.tsx","../src/components/QueryOptions.tsx"],"names":["Fragment","useOperation","jsx","Template","RootTemplate","transformers","File","defaultTemplates","getASTParams","isRequired","URLPath","FunctionParams","Function","PackageManager","pluginZodName"],"mappings":"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","file":"/home/runner/work/kubb/kubb/packages/plugin-react-query/dist/chunk-7ZODZVKP.cjs","sourcesContent":[null,"import transformers from '@kubb/core/transformers'\nimport { FunctionParams, URLPath } from '@kubb/core/utils'\nimport { useOperation, useOperationManager } from '@kubb/plugin-oas/hooks'\nimport { getASTParams, getComments } from '@kubb/plugin-oas/utils'\nimport { File, Function, useApp } from '@kubb/react'\nimport { pluginTsName } from '@kubb/plugin-ts'\n\nimport { SchemaType } from './SchemaType.tsx'\n\nimport { isRequired } from '@kubb/oas'\nimport type { HttpMethod } from '@kubb/oas'\nimport type { ComponentProps, ComponentType, ReactNode } from 'react'\nimport type { FileMeta, PluginReactQuery } from '../types.ts'\n\ntype TemplateProps = {\n /**\n * Name of the function\n */\n name: string\n /**\n * Parameters/options/props that need to be used\n */\n params: string\n mutateParams: string\n /**\n * Options for JSdocs\n */\n JSDoc?: {\n comments: string[]\n }\n hook: {\n name: string\n generics?: string\n children?: string\n }\n client: {\n generics: string\n method: HttpMethod\n path: URLPath\n withQueryParams: boolean\n withPathParams: boolean\n withData: boolean\n withHeaders: boolean\n contentType: string\n }\n dataReturnType: NonNullable<PluginReactQuery['options']['dataReturnType']>\n}\n\nfunction Template({ name, params, mutateParams, JSDoc, client, hook, dataReturnType }: TemplateProps): ReactNode {\n const isFormData = client.contentType === 'multipart/form-data'\n const headers = [\n client.contentType !== 'application/json' ? `'Content-Type': '${client.contentType}'` : undefined,\n client.withHeaders ? '...headers' : undefined,\n ]\n .filter(Boolean)\n .join(', ')\n\n const clientOptions = [\n `method: \"${client.method}\"`,\n `url: ${client.path.template}`,\n client.withQueryParams ? 'params' : undefined,\n client.withData && !isFormData ? 'data' : undefined,\n client.withData && isFormData ? 'data: formData' : undefined,\n headers.length ? `headers: { ${headers}, ...clientOptions.headers }` : undefined,\n '...clientOptions',\n ].filter(Boolean)\n\n const resolvedClientOptions = `${transformers.createIndent(4)}${clientOptions.join(`,\\n${transformers.createIndent(4)}`)}`\n\n const formData = isFormData\n ? `\n const formData = new FormData()\n if(data) {\n Object.keys(data).forEach((key) => {\n const value = data[key];\n if (typeof key === \"string\" && (typeof value === \"string\" || value instanceof Blob)) {\n formData.append(key, value);\n }\n })\n }\n `\n : undefined\n\n return (\n <File.Source name={name} isExportable isIndexable>\n <Function export name={name} params={params} JSDoc={JSDoc}>\n {`\n const { mutation: mutationOptions, client: clientOptions = {} } = options ?? {}\n\n return ${hook.name}({\n mutationFn: async(${mutateParams}) => {\n ${hook.children || ''}\n ${formData || ''}\n const res = await client<${client.generics}>({\n ${resolvedClientOptions}\n })\n\n return ${dataReturnType === 'data' ? 'res.data' : 'res'}\n },\n ...mutationOptions\n })`}\n </Function>\n </File.Source>\n )\n}\n\ntype RootTemplateProps = {\n children?: React.ReactNode\n}\n\nfunction RootTemplate({ children }: RootTemplateProps) {\n const {\n plugin: {\n options: {\n client: { importPath },\n mutate,\n },\n },\n } = useApp<PluginReactQuery>()\n\n const { getSchemas, getFile } = useOperationManager()\n const operation = useOperation()\n\n const schemas = getSchemas(operation, { pluginKey: [pluginTsName], type: 'type' })\n const file = getFile(operation)\n const fileType = getFile(operation, { pluginKey: [pluginTsName] })\n\n return (\n <File<FileMeta> baseName={file.baseName} path={file.path} meta={file.meta}>\n <File.Import name={'client'} path={importPath} />\n <File.Import name={['ResponseConfig']} path={importPath} isTypeOnly />\n <File.Import\n name={[\n schemas.request?.name,\n schemas.response.name,\n schemas.pathParams?.name,\n schemas.queryParams?.name,\n schemas.headerParams?.name,\n ...(schemas.errors?.map((error) => error.name) || []),\n ].filter(Boolean)}\n root={file.path}\n path={fileType.path}\n isTypeOnly\n />\n <File.Import\n name={['UseMutationOptions', 'UseMutationResult']}\n path={typeof mutate !== 'boolean' && mutate.importPath ? mutate.importPath : '@tanstack/react-query'}\n isTypeOnly\n />\n <File.Import name={['useMutation']} path={typeof mutate !== 'boolean' && mutate.importPath ? mutate.importPath : '@tanstack/react-query'} />\n {children}\n </File>\n )\n}\n\nconst defaultTemplates = { default: Template, root: RootTemplate } as const\n\ntype Templates = Partial<typeof defaultTemplates>\n\ntype MutationProps = {\n /**\n * This will make it possible to override the default behaviour.\n */\n Template?: ComponentType<ComponentProps<typeof Template>>\n}\n\nexport function Mutation({ Template = defaultTemplates.default }: MutationProps): ReactNode {\n // TODO do checks on pathParamsType\n\n const {\n plugin: {\n options: { dataReturnType, mutate },\n },\n } = useApp<PluginReactQuery>()\n\n const operation = useOperation()\n const { getSchemas, getName } = useOperationManager()\n\n const name = getName(operation, { type: 'function' })\n const schemas = getSchemas(operation, { pluginKey: [pluginTsName], type: 'type' })\n const contentType = operation.getContentType()\n\n const params = new FunctionParams()\n const mutateParams = new FunctionParams()\n const factoryName = getName(operation, { type: 'type' })\n\n const requestType =\n mutate && mutate.variablesType === 'mutate'\n ? FunctionParams.toObject([\n ...getASTParams(schemas.pathParams, { typed: true }),\n {\n name: 'params',\n type: `${factoryName}['queryParams']`,\n enabled: !!schemas.queryParams?.name,\n required: isRequired(schemas.queryParams?.schema),\n },\n {\n name: 'headers',\n type: `${factoryName}['headerParams']`,\n enabled: !!schemas.headerParams?.name,\n required: isRequired(schemas.headerParams?.schema),\n },\n {\n name: 'data',\n type: `${factoryName}['request']`,\n enabled: !!schemas.request?.name,\n required: isRequired(schemas.request?.schema),\n },\n ])?.type\n : schemas.request?.name\n ? `${factoryName}['request']`\n : 'never'\n\n const client = {\n method: operation.method,\n path: new URLPath(operation.path),\n generics: [`${factoryName}[\"data\"]`, `${factoryName}[\"error\"]`, requestType ? `${factoryName}[\"request\"]` : 'void'].join(', '),\n withQueryParams: !!schemas.queryParams?.name,\n withData: !!schemas.request?.name,\n withPathParams: !!schemas.pathParams?.name,\n withHeaders: !!schemas.headerParams?.name,\n contentType,\n }\n const hook = {\n name: 'useMutation',\n generics: [`${factoryName}['response']`, `${factoryName}[\"error\"]`, requestType ? `${requestType}` : 'void'].join(', '),\n }\n\n const resultGenerics = [\n `${factoryName}[\"response\"]`,\n `${factoryName}[\"error\"]`,\n mutate && mutate?.variablesType === 'mutate' ? requestType : `${factoryName}[\"request\"]`,\n ]\n\n if (mutate && mutate?.variablesType === 'mutate') {\n params.add([\n {\n name: 'options',\n type: `{\n mutation?: UseMutationOptions<${resultGenerics.join(', ')}>,\n client?: ${factoryName}['client']['parameters']\n }`,\n default: '{}',\n },\n ])\n\n mutateParams.add([\n [\n ...getASTParams(schemas.pathParams, { typed: false }),\n {\n name: 'params',\n enabled: client.withQueryParams,\n required: isRequired(schemas.queryParams?.schema),\n },\n {\n name: 'headers',\n enabled: client.withHeaders,\n required: isRequired(schemas.headerParams?.schema),\n },\n {\n name: 'data',\n enabled: !!schemas.request?.name,\n required: isRequired(schemas.request?.schema),\n },\n ],\n ])\n } else {\n params.add([\n ...getASTParams(schemas.pathParams, { typed: true }),\n {\n name: 'params',\n type: `${factoryName}['queryParams']`,\n enabled: client.withQueryParams,\n required: isRequired(schemas.queryParams?.schema),\n },\n {\n name: 'headers',\n type: `${factoryName}['headerParams']`,\n enabled: client.withHeaders,\n required: isRequired(schemas.headerParams?.schema),\n },\n {\n name: 'options',\n type: `{\n mutation?: UseMutationOptions<${resultGenerics.join(', ')}>,\n client?: ${factoryName}['client']['parameters']\n }`,\n default: '{}',\n },\n ])\n\n mutateParams.add([\n {\n name: 'data',\n enabled: !!schemas.request?.name,\n required: isRequired(schemas.request?.schema),\n },\n ])\n }\n\n if (!mutate) {\n return null\n }\n\n return (\n <>\n <Template\n name={name}\n JSDoc={{ comments: getComments(operation) }}\n client={client}\n hook={hook}\n params={params.toString()}\n mutateParams={mutateParams.toString()}\n dataReturnType={dataReturnType}\n />\n </>\n )\n}\n\ntype FileProps = {\n /**\n * This will make it possible to override the default behaviour.\n */\n templates?: Templates\n}\n\nMutation.File = function ({ ...props }: FileProps): ReactNode {\n const templates = { ...defaultTemplates, ...props.templates }\n\n const Template = templates.default\n const RootTemplate = templates.root\n\n return (\n <RootTemplate>\n <SchemaType />\n <Mutation Template={Template} />\n </RootTemplate>\n )\n}\n\nMutation.templates = defaultTemplates\n","import { useOperation, useOperationManager } from '@kubb/plugin-oas/hooks'\nimport { File, Type, useApp } from '@kubb/react'\n\nimport type { ReactNode } from 'react'\nimport type { PluginReactQuery } from '../types.ts'\nimport { pluginTsName } from '@kubb/plugin-ts'\n\nexport function SchemaType(): ReactNode {\n const {\n plugin: {\n options: { dataReturnType },\n },\n } = useApp<PluginReactQuery>()\n const { getSchemas, getName } = useOperationManager()\n const operation = useOperation()\n\n const schemas = getSchemas(operation, { pluginKey: [pluginTsName], type: 'type' })\n\n const [TData, TError, TRequest, TPathParams, TQueryParams, THeaderParams, TResponse] = [\n schemas.response.name,\n schemas.errors?.map((item) => item.name).join(' | ') || 'never',\n schemas.request?.name || 'never',\n schemas.pathParams?.name || 'never',\n schemas.queryParams?.name || 'never',\n schemas.headerParams?.name || 'never',\n schemas.response.name,\n ]\n const factoryName = getName(operation, { type: 'type' })\n\n const clientType = `${factoryName}Client`\n const isFormData = operation.getContentType() === 'multipart/form-data'\n\n return (\n <>\n <File.Source name={clientType} isTypeOnly>\n <Type name={clientType}>{`typeof client<${TResponse}, ${TError}, ${isFormData ? 'FormData' : TRequest}>`}</Type>\n </File.Source>\n <File.Source name={factoryName} isTypeOnly>\n <Type name={factoryName}>\n {`\n {\n data: ${TData}\n error: ${TError}\n request: ${isFormData ? 'FormData' : TRequest}\n pathParams: ${TPathParams}\n queryParams: ${TQueryParams}\n headerParams: ${THeaderParams}\n response: ${dataReturnType === 'data' ? TData : `Awaited<ReturnType<${clientType}>>`}\n client: {\n parameters: Partial<Parameters<${clientType}>[0]>\n return: Awaited<ReturnType<${clientType}>>\n }\n }\n `}\n </Type>\n </File.Source>\n </>\n )\n}\n","import { PackageManager } from '@kubb/core'\nimport transformers from '@kubb/core/transformers'\nimport { FunctionParams, URLPath } from '@kubb/core/utils'\nimport { File, Function, useApp } from '@kubb/react'\nimport { pluginTsName } from '@kubb/plugin-ts'\nimport { pluginZodName } from '@kubb/plugin-zod'\nimport { useOperation, useOperationManager } from '@kubb/plugin-oas/hooks'\nimport { getASTParams, getComments } from '@kubb/plugin-oas/utils'\n\nimport { getImportNames, reactQueryDepRegex } from '../utils.ts'\nimport { QueryImports } from './QueryImports.tsx'\nimport { QueryKey } from './QueryKey.tsx'\nimport { QueryOptions } from './QueryOptions.tsx'\nimport { SchemaType } from './SchemaType.tsx'\n\nimport { isRequired } from '@kubb/oas'\nimport type { ReactNode } from 'react'\nimport type { QueryOptions as QueryOptionsPluginOptions, Query as QueryPluginOptions } from '../types.ts'\nimport type { FileMeta, Infinite, PluginReactQuery, Suspense } from '../types.ts'\n\ntype TemplateProps = {\n /**\n * Name of the function\n */\n name: string\n /**\n * Parameters/options/props that need to be used\n */\n params: string\n /**\n * Generics that needs to be added for TypeScript\n */\n generics?: string\n /**\n * ReturnType(see async for adding Promise type)\n */\n returnType?: string\n /**\n * Options for JSdocs\n */\n JSDoc?: {\n comments: string[]\n }\n hook: {\n name: string\n generics?: string\n queryKey: string\n queryOptions: string\n }\n infinite: Infinite | false\n}\n\nfunction Template({ name, generics, returnType, params, JSDoc, hook, infinite }: TemplateProps): ReactNode {\n const isV5 = new PackageManager().isValidSync(reactQueryDepRegex, '>=5')\n const resolvedReturnType = `${returnType} & { queryKey: TQueryKey }`\n\n if (isV5) {\n return (\n <File.Source name={name} isExportable isIndexable>\n <Function name={name} export generics={generics} returnType={resolvedReturnType} params={params} JSDoc={JSDoc}>\n {`\n const { query: queryOptions, client: clientOptions = {} } = options ?? {}\n const queryKey = queryOptions?.queryKey ?? ${hook.queryKey}\n\n const query = ${hook.name}({\n ...${hook.queryOptions} as unknown as ${infinite ? 'InfiniteQueryObserverOptions' : 'QueryObserverOptions'},\n queryKey,\n ...queryOptions as unknown as ${infinite ? 'Omit<InfiniteQueryObserverOptions, \"queryKey\">' : 'Omit<QueryObserverOptions, \"queryKey\">'}\n }) as ${resolvedReturnType}\n\n query.queryKey = queryKey as TQueryKey\n\n return query\n\n `}\n </Function>\n </File.Source>\n )\n }\n\n return (\n <File.Source name={name} isExportable isIndexable>\n <Function name={name} export generics={generics} returnType={resolvedReturnType} params={params} JSDoc={JSDoc}>\n {`\n const { query: queryOptions, client: clientOptions = {} } = options ?? {}\n const queryKey = queryOptions?.queryKey ?? ${hook.queryKey}\n\n const query = ${hook.name}<${hook.generics}>({\n ...${hook.queryOptions},\n queryKey,\n ...queryOptions\n }) as ${resolvedReturnType}\n\n query.queryKey = queryKey as TQueryKey\n\n return query\n\n `}\n </Function>\n </File.Source>\n )\n}\n\ntype FrameworkProps = TemplateProps & {\n context: {\n factory: {\n name: string\n }\n queryKey: string\n }\n}\n\nconst defaultTemplates = {\n get react() {\n return function (props: FrameworkProps): ReactNode {\n return <Template {...props} />\n }\n },\n get solid() {\n return function (props: FrameworkProps): ReactNode {\n return <Template {...props} />\n }\n },\n get svelte() {\n return function (props: FrameworkProps): ReactNode {\n return <Template {...props} />\n }\n },\n get vue() {\n return function ({ context, hook, ...rest }: FrameworkProps): ReactNode {\n const { factory, queryKey } = context\n\n const {\n pluginManager,\n plugin: {\n key: pluginKey,\n options: { pathParamsType },\n },\n } = useApp<PluginReactQuery>()\n const operation = useOperation()\n const { getSchemas } = useOperationManager()\n\n const importNames = getImportNames()\n\n const queryOptions = pluginManager.resolveName({\n name: `${factory.name}QueryOptions`,\n pluginKey,\n })\n\n const hookName = rest.infinite ? importNames.queryInfinite.vue.hookName : importNames.query.vue.hookName\n const resultType = rest.infinite ? importNames.queryInfinite.vue.resultType : importNames.query.vue.resultType\n const optionsType = rest.infinite ? importNames.queryInfinite.vue.optionsType : importNames.query.vue.optionsType\n\n const schemas = getSchemas(operation, { pluginKey: [pluginTsName], type: 'type' })\n const isV5 = new PackageManager().isValidSync(reactQueryDepRegex, '>=5')\n const params = new FunctionParams()\n const queryParams = new FunctionParams()\n const queryKeyParams = new FunctionParams()\n const client = {\n withQueryParams: !!schemas.queryParams?.name,\n withData: !!schemas.request?.name,\n withPathParams: !!schemas.pathParams?.name,\n withHeaders: !!schemas.headerParams?.name,\n }\n\n const resultGenerics = ['TData', `${factory.name}['error']`]\n\n // only needed for the options to override the useQuery options/params\n const queryOptionsOverrideGenerics = [`${factory.name}['response']`, `${factory.name}['error']`, 'TData', 'TQueryKey']\n const queryOptionsGenerics = ['TData', 'TQueryData']\n\n params.add([\n ...(pathParamsType === 'object'\n ? [\n getASTParams(schemas.pathParams, {\n typed: true,\n override: (item) => ({\n ...item,\n name: item.name ? `ref${transformers.pascalCase(item.name)}` : undefined,\n }),\n }),\n ]\n : getASTParams(schemas.pathParams, {\n typed: true,\n override: (item) => ({\n ...item,\n name: item.name ? `ref${transformers.pascalCase(item.name)}` : undefined,\n }),\n })),\n {\n name: 'refParams',\n type: `MaybeRef<${schemas.queryParams?.name}>`,\n enabled: client.withQueryParams,\n required: isRequired(schemas.queryParams?.schema),\n },\n {\n name: 'refHeaders',\n type: `MaybeRef<${schemas.headerParams?.name}>`,\n enabled: client.withHeaders,\n required: isRequired(schemas.headerParams?.schema),\n },\n {\n name: 'refData',\n type: `MaybeRef<${schemas.request?.name}>`,\n enabled: client.withData,\n required: isRequired(schemas.request?.schema),\n },\n {\n name: 'options',\n type: `{\n query?: Partial<${optionsType}<${queryOptionsOverrideGenerics.join(', ')}>>,\n client?: ${factory.name}['client']['parameters']\n }`,\n default: '{}',\n },\n ])\n\n queryParams.add([\n ...getASTParams(schemas.pathParams, {\n typed: false,\n override: (item) => ({\n ...item,\n name: item.name ? `ref${transformers.pascalCase(item.name)}` : undefined,\n }),\n }),\n {\n name: 'refParams',\n enabled: client.withQueryParams,\n required: isRequired(schemas.queryParams?.schema),\n },\n {\n name: 'refHeaders',\n enabled: client.withHeaders,\n required: isRequired(schemas.headerParams?.schema),\n },\n {\n name: 'clientOptions',\n required: false,\n },\n ])\n\n queryKeyParams.add([\n ...(pathParamsType === 'object'\n ? [\n getASTParams(schemas.pathParams, {\n override: (item) => ({\n ...item,\n name: item.name ? `ref${transformers.pascalCase(item.name)}` : undefined,\n }),\n }),\n ]\n : getASTParams(schemas.pathParams, {\n override: (item) => ({\n ...item,\n name: item.name ? `ref${transformers.pascalCase(item.name)}` : undefined,\n }),\n })),\n {\n name: 'refParams',\n enabled: client.withQueryParams,\n required: isRequired(schemas.queryParams?.schema),\n },\n {\n name: 'refData',\n enabled: client.withData,\n required: isRequired(schemas.request?.schema),\n },\n ])\n\n return (\n <Template\n {...rest}\n params={params.toString()}\n returnType={`${resultType}<${resultGenerics.join(', ')}>`}\n hook={{\n ...hook,\n name: hookName,\n queryOptions: isV5\n ? `${queryOptions}(${queryParams.toString()})`\n : `${queryOptions}<${queryOptionsGenerics.join(', ')}>(${queryParams.toString()})`,\n queryKey: `${queryKey}(${queryKeyParams.toString()})`,\n }}\n />\n )\n }\n },\n} as const\n\ntype Props = {\n factory: {\n name: string\n }\n resultType: string\n hookName: string\n optionsType: string\n infinite: Infinite | false\n query: QueryPluginOptions | false\n queryOptions: QueryOptionsPluginOptions | false\n suspense: Suspense | false\n /**\n * This will make it possible to override the default behaviour.\n */\n Template?: React.ComponentType<FrameworkProps>\n /**\n * This will make it possible to override the default behaviour.\n */\n QueryKeyTemplate?: React.ComponentType<React.ComponentProps<typeof QueryKey.templates.react>>\n /**\n * This will make it possible to override the default behaviour.\n */\n QueryOptionsTemplate?: React.ComponentType<React.ComponentProps<typeof QueryOptions.templates.react>>\n}\n\nexport function Query({\n factory,\n optionsType,\n hookName,\n resultType,\n Template = defaultTemplates.react,\n QueryKeyTemplate = QueryKey.templates.react,\n QueryOptionsTemplate = QueryOptions.templates.react,\n ...props\n}: Props): ReactNode {\n const {\n pluginManager,\n plugin: {\n key: pluginKey,\n options: { dataReturnType, pathParamsType },\n },\n } = useApp<PluginReactQuery>()\n\n const operation = useOperation()\n const { getSchemas, getName } = useOperationManager()\n\n const schemas = getSchemas(operation, { pluginKey: [pluginTsName], type: 'type' })\n const name = getName(operation, { type: 'function' })\n const isV5 = new PackageManager().isValidSync(reactQueryDepRegex, '>=5')\n\n const queryKey = pluginManager.resolveName({\n name: [factory.name, props.infinite ? 'Infinite' : undefined, props.suspense ? 'Suspense' : undefined, 'QueryKey'].filter(Boolean).join(''),\n pluginKey,\n })\n const queryKeyType = pluginManager.resolveName({\n name: [factory.name, props.infinite ? 'Infinite' : undefined, props.suspense ? 'Suspense' : undefined, 'QueryKey'].filter(Boolean).join(''),\n type: 'type',\n pluginKey,\n })\n const queryOptions = pluginManager.resolveName({\n name: [factory.name, props.infinite ? 'Infinite' : undefined, props.suspense ? 'Suspense' : undefined, 'QueryOptions'].filter(Boolean).join(''),\n pluginKey,\n })\n\n const generics = new FunctionParams()\n const params = new FunctionParams()\n const queryParams = new FunctionParams()\n const queryKeyParams = new FunctionParams()\n //TODO operationManager.getCleitn\n const client = {\n method: operation.method,\n path: new URLPath(operation.path),\n withQueryParams: !!schemas.queryParams?.name,\n withData: !!schemas.request?.name,\n withPathParams: !!schemas.pathParams?.name,\n withHeaders: !!schemas.headerParams?.name,\n }\n\n generics.add([\n {\n type: 'TData',\n default: props.infinite ? `InfiniteData<${factory.name}[\"response\"]>` : `${factory.name}[\"response\"]`,\n },\n props.suspense ? undefined : { type: 'TQueryData', default: `${factory.name}[\"response\"]` },\n { type: 'TQueryKey extends QueryKey', default: queryKeyType },\n ])\n\n const resultGenerics = ['TData', `${factory.name}['error']`]\n // only needed for the options to override the useQuery options/params\n // suspense is having 4 generics instead of 5, TQueryData is not needed because data will always be defined\n const queryOptionsOverrideGenerics = props.suspense\n ? [`${factory.name}['response']`, `${factory.name}['error']`, 'TData', 'TQueryKey']\n : [`${factory.name}['response']`, `${factory.name}['error']`, 'TData', 'TQueryData', 'TQueryKey']\n\n const queryOptionsGenerics = props.suspense ? ['TData'] : ['TData', 'TQueryData']\n\n params.add([\n ...(pathParamsType === 'object' ? [getASTParams(schemas.pathParams, { typed: true })] : getASTParams(schemas.pathParams, { typed: true })),\n {\n name: 'params',\n type: `${factory.name}['queryParams']`,\n enabled: client.withQueryParams,\n required: isRequired(schemas.queryParams?.schema),\n },\n {\n name: 'headers',\n type: `${factory.name}['headerParams']`,\n enabled: client.withHeaders,\n required: isRequired(schemas.headerParams?.schema),\n },\n {\n name: 'data',\n type: `${factory.name}['request']`,\n enabled: client.withData,\n required: isRequired(schemas.request?.schema),\n },\n {\n name: 'options',\n type: `{\n query?: Partial<${optionsType}<${queryOptionsOverrideGenerics.join(', ')}>>,\n client?: ${factory.name}['client']['parameters']\n}`,\n default: '{}',\n },\n ])\n\n queryParams.add([\n ...(pathParamsType === 'object' ? [getASTParams(schemas.pathParams)] : getASTParams(schemas.pathParams)),\n {\n name: 'params',\n enabled: client.withQueryParams,\n required: isRequired(schemas.queryParams?.schema),\n },\n {\n name: 'headers',\n enabled: client.withHeaders,\n required: isRequired(schemas.headerParams?.schema),\n },\n {\n name: 'data',\n enabled: client.withData,\n required: isRequired(schemas.request?.schema),\n },\n {\n name: 'clientOptions',\n required: false,\n },\n ])\n\n queryKeyParams.add([\n ...(pathParamsType === 'object' ? [getASTParams(schemas.pathParams)] : getASTParams(schemas.pathParams)),\n {\n name: 'params',\n enabled: client.withQueryParams,\n required: isRequired(schemas.queryParams?.schema),\n },\n {\n name: 'data',\n enabled: client.withData,\n required: isRequired(schemas.request?.schema),\n },\n ])\n\n const hook = {\n name: hookName,\n generics: [isV5 ? 'any' : `${factory.name}['data']`, `${factory.name}['error']`, 'TData', 'any'].join(', '),\n queryOptions: isV5 ? `${queryOptions}(${queryParams.toString()})` : `${queryOptions}<${queryOptionsGenerics.join(', ')}>(${queryParams.toString()})`,\n queryKey: `${queryKey}(${queryKeyParams.toString()})`,\n }\n\n return (\n <>\n <QueryKey\n keysFn={props.query ? props.query.queryKey : (keys: unknown[]) => keys}\n Template={QueryKeyTemplate}\n factory={factory}\n name={queryKey}\n typeName={queryKeyType}\n />\n\n {props.queryOptions && (\n <QueryOptions\n Template={QueryOptionsTemplate}\n factory={factory}\n resultType={optionsType}\n dataReturnType={dataReturnType}\n infinite={props.infinite}\n suspense={props.suspense}\n />\n )}\n\n {props.query && (\n <Template\n name={[name, props.infinite ? 'Infinite' : undefined, props.suspense ? 'Suspense' : undefined].filter(Boolean).join('')}\n generics={generics.toString()}\n JSDoc={{ comments: getComments(operation) }}\n params={params.toString()}\n returnType={`${resultType}<${resultGenerics.join(', ')}>`}\n hook={hook}\n infinite={props.infinite}\n context={{\n factory,\n queryKey,\n }}\n />\n )}\n </>\n )\n}\n\ntype FileProps = {\n /**\n * This will make it possible to override the default behaviour.\n */\n templates?: {\n query: typeof defaultTemplates\n queryKey: typeof QueryKey.templates\n queryOptions: typeof QueryOptions.templates\n queryImports: typeof QueryImports.templates\n }\n}\n\nQuery.File = function ({ templates }: FileProps): ReactNode {\n const {\n plugin: {\n options: {\n client: { importPath },\n infinite,\n suspense,\n query,\n queryOptions,\n parser,\n },\n },\n } = useApp<PluginReactQuery>()\n\n const { getSchemas, getFile, getName } = useOperationManager()\n const operation = useOperation()\n\n const schemas = getSchemas(operation, { pluginKey: [pluginTsName], type: 'type' })\n const zodSchemas = getSchemas(operation, { pluginKey: [pluginZodName], type: 'function' })\n const file = getFile(operation)\n const fileType = getFile(operation, { pluginKey: [pluginTsName] })\n const fileZodSchemas = getFile(operation, {\n pluginKey: [pluginZodName],\n })\n\n const factoryName = getName(operation, { type: 'type' })\n\n const importNames = getImportNames()\n const isV5 = new PackageManager().isValidSync(reactQueryDepRegex, '>=5')\n const Template = templates?.query['react'] || defaultTemplates['react']\n const QueryOptionsTemplate = templates?.queryOptions['react'] || QueryOptions.templates['react']\n const QueryKeyTemplate = templates?.queryKey['react'] || QueryKey.templates['react']\n const Import = templates?.queryImports['react'] || QueryImports.templates['react']\n\n const factory = {\n name: factoryName,\n }\n\n return (\n <File<FileMeta> baseName={file.baseName} path={file.path} meta={file.meta}>\n {parser === 'zod' && <File.Import name={[zodSchemas.response?.name]} root={file.path} path={fileZodSchemas.path} />}\n <File.Import name={'client'} path={importPath} />\n <File.Import name={['ResponseConfig']} path={importPath} isTypeOnly />\n <File.Import\n name={[\n schemas.request?.name,\n schemas.response.name,\n schemas.pathParams?.name,\n schemas.queryParams?.name,\n schemas.headerParams?.name,\n ...(schemas.errors?.map((error) => error.name) || []),\n ].filter(Boolean)}\n root={file.path}\n path={fileType.path}\n isTypeOnly\n />\n\n <QueryImports hookPath={typeof query !== 'boolean' ? query.importPath : undefined} Template={Import} isInfinite={false} isSuspense={false} />\n {!!infinite && (\n <QueryImports hookPath={typeof query !== 'boolean' ? query.importPath : undefined} Template={Import} isInfinite={true} isSuspense={false} />\n )}\n {!!suspense && isV5 && (\n <QueryImports hookPath={typeof query !== 'boolean' ? query.importPath : undefined} Template={Import} isInfinite={false} isSuspense={true} />\n )}\n <SchemaType />\n <Query\n factory={factory}\n Template={Template}\n QueryKeyTemplate={QueryKeyTemplate}\n QueryOptionsTemplate={QueryOptionsTemplate}\n infinite={false}\n suspense={false}\n query={query}\n queryOptions={queryOptions}\n hookName={importNames.query['react'].hookName}\n resultType={importNames.query['react'].resultType}\n optionsType={importNames.query['react'].optionsType}\n />\n {!!infinite && (\n <Query\n factory={factory}\n Template={Template}\n QueryKeyTemplate={QueryKeyTemplate}\n QueryOptionsTemplate={QueryOptionsTemplate}\n infinite={infinite}\n suspense={false}\n query={query}\n queryOptions={queryOptions}\n hookName={importNames.queryInfinite['react'].hookName}\n resultType={importNames.queryInfinite['react'].resultType}\n optionsType={importNames.queryInfinite['react'].optionsType}\n />\n )}\n {!!suspense && isV5 && (\n <Query\n factory={factory}\n Template={Template}\n QueryKeyTemplate={QueryKeyTemplate}\n QueryOptionsTemplate={QueryOptionsTemplate}\n infinite={false}\n suspense={suspense}\n query={query}\n queryOptions={queryOptions}\n hookName={importNames.querySuspense['react'].hookName}\n resultType={importNames.querySuspense['react'].resultType}\n optionsType={importNames.querySuspense['react'].optionsType}\n />\n )}\n </File>\n )\n}\n\nQuery.templates = defaultTemplates\n","import { PackageManager } from '@kubb/core'\n\nexport const reactQueryDepRegex = /@tanstack\\/(react|solid|vue|svelte)-query/\n\nexport function getImportNames() {\n const isV5 = new PackageManager().isValidSync(reactQueryDepRegex, '>=5')\n\n return {\n mutation: {\n react: {\n path: '@tanstack/react-query',\n hookName: 'useMutation',\n optionsType: 'UseMutationOptions',\n resultType: 'UseMutationResult',\n },\n solid: {\n path: '@tanstack/solid-query',\n hookName: 'createMutation',\n optionsType: 'CreateMutationOptions',\n resultType: 'CreateMutationResult',\n },\n svelte: {\n path: '@tanstack/svelte-query',\n hookName: 'createMutation',\n optionsType: 'CreateMutationOptions',\n resultType: 'CreateMutationResult',\n },\n vue: {\n path: '@tanstack/vue-query',\n hookName: 'useMutation',\n optionsType: isV5 ? 'UseMutationOptions' : 'VueMutationObserverOptions',\n resultType: 'UseMutationReturnType',\n },\n },\n query: {\n react: {\n path: '@tanstack/react-query',\n hookName: 'useQuery',\n optionsType: isV5 ? 'QueryObserverOptions' : 'UseBaseQueryOptions',\n resultType: 'UseQueryResult',\n },\n solid: {\n path: '@tanstack/solid-query',\n hookName: 'createQuery',\n optionsType: 'CreateBaseQueryOptions',\n resultType: 'CreateQueryResult',\n },\n svelte: {\n path: '@tanstack/svelte-query',\n hookName: 'createQuery',\n optionsType: 'CreateBaseQueryOptions',\n resultType: 'CreateQueryResult',\n },\n vue: {\n path: '@tanstack/vue-query',\n hookName: 'useQuery',\n optionsType: isV5 ? 'QueryObserverOptions' : 'VueQueryObserverOptions',\n resultType: isV5 ? 'UseQueryReturnType' : 'UseQueryReturnType',\n },\n },\n queryInfinite: {\n react: {\n path: '@tanstack/react-query',\n hookName: 'useInfiniteQuery',\n optionsType: isV5 ? 'InfiniteQueryObserverOptions' : 'UseInfiniteQueryOptions',\n resultType: 'UseInfiniteQueryResult',\n },\n solid: {\n path: '@tanstack/solid-query',\n hookName: 'createInfiniteQuery',\n optionsType: 'CreateInfiniteQueryOptions',\n resultType: 'CreateInfiniteQueryResult',\n },\n svelte: {\n path: '@tanstack/svelte-query',\n hookName: 'createInfiniteQuery',\n optionsType: 'CreateInfiniteQueryOptions',\n resultType: 'CreateInfiniteQueryResult',\n },\n vue: {\n path: '@tanstack/vue-query',\n hookName: 'useInfiniteQuery',\n optionsType: isV5 ? 'UseInfiniteQueryOptions' : 'VueInfiniteQueryObserverOptions',\n resultType: isV5 ? 'UseInfiniteQueryReturnType' : 'VueInfiniteQueryObserverOptions',\n },\n },\n querySuspense: {\n react: {\n path: '@tanstack/react-query',\n hookName: 'useSuspenseQuery',\n optionsType: 'UseSuspenseQueryOptions',\n resultType: 'UseSuspenseQueryResult',\n },\n },\n } as const\n}\n","import { PackageManager } from '@kubb/core'\nimport { File } from '@kubb/react'\n\nimport { getImportNames, reactQueryDepRegex } from '../utils.ts'\n\nimport type { ReactNode } from 'react'\n\ntype TemplateProps = {\n /**\n * Path to @tanstack-query\n */\n path: string\n /**\n * Override the path of 'useQuery'\n * @default 'path'\n */\n hookPath: string | undefined\n optionsType: string\n queryOptions: string | undefined\n resultType: string\n hookName: string\n isInfinite: boolean\n}\n\nfunction Template({ path, hookPath = path, isInfinite, hookName, queryOptions, optionsType, resultType }: TemplateProps): ReactNode {\n return (\n <>\n <File.Import name={[optionsType, resultType]} path={path} isTypeOnly />\n <File.Import name={[hookName]} path={hookPath} />\n\n {queryOptions && <File.Import name={[queryOptions].filter(Boolean)} path={path} />}\n <File.Import name={['QueryKey', 'WithRequired', isInfinite ? 'InfiniteData' : undefined].filter(Boolean)} path={path} isTypeOnly />\n </>\n )\n}\n\ntype FrameworkProps = Partial<TemplateProps> & {\n context: {\n isInfinite: boolean\n isSuspense: boolean\n }\n}\n\nconst defaultTemplates = {\n get react() {\n return function ({ context, hookPath, ...rest }: FrameworkProps): ReactNode {\n const importNames = getImportNames()\n const isV5 = new PackageManager().isValidSync(reactQueryDepRegex, '>=5')\n const { isInfinite, isSuspense } = context\n\n return (\n <Template\n isInfinite={isInfinite}\n {...(isSuspense ? importNames.querySuspense.react : isInfinite ? importNames.queryInfinite.react : importNames.query.react)}\n queryOptions={isV5 ? (isInfinite ? 'infiniteQueryOptions' : 'queryOptions') : undefined}\n hookPath={hookPath}\n {...rest}\n />\n )\n }\n },\n get solid() {\n return function ({ context, hookPath, ...rest }: FrameworkProps): ReactNode {\n const importNames = getImportNames()\n const isV5 = new PackageManager().isValidSync(reactQueryDepRegex, '>=5')\n const { isInfinite } = context\n\n return (\n <Template\n isInfinite={isInfinite}\n {...(isInfinite ? importNames.queryInfinite.solid : importNames.query.solid)}\n queryOptions={isV5 ? (isInfinite ? 'infiniteQueryOptions' : 'queryOptions') : undefined}\n hookPath={hookPath}\n {...rest}\n />\n )\n }\n },\n get svelte() {\n return function ({ context, hookPath, ...rest }: FrameworkProps): ReactNode {\n const importNames = getImportNames()\n const isV5 = new PackageManager().isValidSync(reactQueryDepRegex, '>=5')\n const { isInfinite } = context\n\n return (\n <Template\n isInfinite={isInfinite}\n {...(isInfinite ? importNames.queryInfinite.svelte : importNames.query.svelte)}\n queryOptions={isV5 ? (isInfinite ? 'infiniteQueryOptions' : 'queryOptions') : undefined}\n hookPath={hookPath}\n {...rest}\n />\n )\n }\n },\n get vue() {\n return function ({ context, hookPath, ...rest }: FrameworkProps): ReactNode {\n const importNames = getImportNames()\n const isV5 = new PackageManager().isValidSync(reactQueryDepRegex, '>=5')\n const { isInfinite } = context\n const path = '@tanstack/vue-query'\n\n return (\n <>\n {isV5 && (\n <>\n <Template\n isInfinite={isInfinite}\n {...(isInfinite ? importNames.queryInfinite.vue : importNames.query.vue)}\n queryOptions={isInfinite ? 'infiniteQueryOptions' : 'queryOptions'}\n hookPath={hookPath}\n {...rest}\n />\n <File.Import name={['QueryObserverOptions']} path={path} isTypeOnly />\n </>\n )}\n\n {!isV5 && isInfinite && (\n <>\n <File.Import name={[importNames.queryInfinite.vue.resultType]} path={path} isTypeOnly />\n <File.Import name={[importNames.queryInfinite.vue.optionsType]} path={'@tanstack/vue-query/build/lib/types'} isTypeOnly />\n <File.Import name={[importNames.queryInfinite.vue.hookName]} path={path} />\n </>\n )}\n\n {!isV5 && !isInfinite && (\n <>\n <File.Import name={[importNames.query.vue.resultType]} path={path} isTypeOnly />\n <File.Import name={[importNames.query.vue.optionsType]} path={'@tanstack/vue-query/build/lib/types'} isTypeOnly />\n <File.Import name={[importNames.query.vue.hookName]} path={path} />\n </>\n )}\n <File.Import name={['unref']} path={'vue'} />\n <File.Import name={['MaybeRef']} path={'vue'} isTypeOnly />\n <File.Import name={['QueryKey', 'WithRequired']} path={path} isTypeOnly />\n </>\n )\n }\n },\n} as const\n\ntype Props = {\n hookPath: string | undefined\n isInfinite: boolean\n /**\n * Only for React and v5\n */\n isSuspense: boolean\n /**\n * This will make it possible to override the default behaviour.\n */\n Template?: React.ComponentType<FrameworkProps>\n}\n\nexport function QueryImports({ hookPath, isInfinite, isSuspense, Template = defaultTemplates.react }: Props): ReactNode {\n return (\n <Template\n hookPath={hookPath}\n context={{\n isInfinite,\n isSuspense,\n }}\n />\n )\n}\n\nQueryImports.templates = defaultTemplates\n","import { FunctionParams, URLPath } from '@kubb/core/utils'\nimport { useOperation, useOperationManager } from '@kubb/plugin-oas/hooks'\nimport { getASTParams } from '@kubb/plugin-oas/utils'\nimport { File, Function, Type, useApp } from '@kubb/react'\n\nimport { isRequired } from '@kubb/oas'\nimport { pluginTsName } from '@kubb/plugin-ts'\nimport type { ReactNode } from 'react'\nimport type { PluginReactQuery } from '../types'\n\ntype TemplateProps = {\n /**\n * Name of the function\n */\n name: string\n /**\n * TypeName of the function in PascalCase\n */\n typeName: string\n /**\n * Parameters/options/props that need to be used\n */\n params: string\n /**\n * Generics that needs to be added for TypeScript\n */\n generics?: string\n /**\n * ReturnType(see async for adding Promise type)\n */\n returnType?: string\n /**\n * Options for JSdocs\n */\n JSDoc?: {\n comments: string[]\n }\n keys?: string\n}\n\nfunction Template({ name, typeName, params, generics, returnType, JSDoc, keys }: TemplateProps): ReactNode {\n return (\n <>\n <File.Source name={name} isExportable isIndexable>\n <Function.Arrow name={name} export generics={generics} params={params} returnType={returnType} singleLine JSDoc={JSDoc}>\n {`[${keys}] as const`}\n </Function.Arrow>\n </File.Source>\n\n <File.Source name={typeName} isExportable isIndexable isTypeOnly>\n <Type name={typeName} export>\n {`ReturnType<typeof ${name}>`}\n </Type>\n </File.Source>\n </>\n )\n}\n\ntype FrameworkProps = TemplateProps & {\n context: {\n factory: {\n name: string\n }\n }\n}\n\nconst defaultTemplates = {\n get react() {\n return function (props: FrameworkProps): ReactNode {\n return <Template {...props} />\n }\n },\n get solid() {\n return function (props: FrameworkProps): ReactNode {\n return <Template {...props} />\n }\n },\n get svelte() {\n return function (props: FrameworkProps): ReactNode {\n return <Template {...props} />\n }\n },\n get vue() {\n return function ({ context, ...rest }: FrameworkProps): ReactNode {\n const { factory } = context\n\n const {\n plugin: {\n options: { pathParamsType, query },\n },\n } = useApp<PluginReactQuery>()\n const { getSchemas } = useOperationManager()\n const operation = useOperation()\n\n const schemas = getSchemas(operation, { pluginKey: [pluginTsName], type: 'type' })\n const path = new URLPath(operation.path)\n const params = new FunctionParams()\n const withQueryParams = !!schemas.queryParams?.name\n const withRequest = !!schemas.request?.name\n\n params.add([\n ...(pathParamsType === 'object'\n ? [\n getASTParams(schemas.pathParams, {\n typed: true,\n override: (item) => ({\n ...item,\n type: `MaybeRef<${item.type}>`,\n }),\n }),\n ]\n : getASTParams(schemas.pathParams, {\n typed: true,\n override: (item) => ({\n ...item,\n type: `MaybeRef<${item.type}>`,\n }),\n })),\n {\n name: 'params',\n type: `MaybeRef<${`${factory.name}[\"queryParams\"]`}>`,\n enabled: withQueryParams,\n required: isRequired(schemas.queryParams?.schema),\n },\n {\n name: 'request',\n type: `MaybeRef<${`${factory.name}[\"request\"]`}>`,\n enabled: withRequest,\n required: isRequired(schemas.request?.schema),\n },\n ])\n\n const keys = [\n path.toObject({\n type: 'path',\n stringify: true,\n replacer: (pathParam) => `unref(${pathParam})`,\n }),\n withQueryParams ? '...(params ? [params] : [])' : undefined,\n withRequest ? '...(request ? [request] : [])' : undefined,\n ].filter(Boolean)\n\n return <Template {...rest} params={params.toString()} keys={keys.join(', ')} />\n }\n },\n} as const\n\ntype Props = {\n name: string\n typeName: string\n keysFn: (keys: unknown[]) => unknown[]\n factory: {\n name: string\n }\n /**\n * This will make it possible to override the default behaviour.\n */\n Template?: React.ComponentType<FrameworkProps>\n}\n\nexport function QueryKey({ name, typeName, factory, keysFn, Template = defaultTemplates.react }: Props): ReactNode {\n const {\n plugin: {\n options: { pathParamsType },\n },\n } = useApp<PluginReactQuery>()\n const { getSchemas } = useOperationManager()\n const operation = useOperation()\n\n const schemas = getSchemas(operation, { pluginKey: [pluginTsName], type: 'type' })\n const path = new URLPath(operation.path)\n const params = new FunctionParams()\n const withQueryParams = !!schemas.queryParams?.name\n const withRequest = !!schemas.request?.name\n\n params.add([\n ...(pathParamsType === 'object' ? [getASTParams(schemas.pathParams, { typed: true })] : getASTParams(schemas.pathParams, { typed: true })),\n {\n name: 'params',\n type: `${factory.name}[\"queryParams\"]`,\n enabled: withQueryParams,\n required: isRequired(schemas.queryParams?.schema),\n },\n {\n name: 'data',\n type: `${factory.name}[\"request\"]`,\n enabled: withRequest,\n required: isRequired(schemas.request?.schema),\n },\n ])\n\n const keys = [\n path.toObject({\n type: 'path',\n stringify: true,\n }),\n withQueryParams ? '...(params ? [params] : [])' : undefined,\n withRequest ? '...(data ? [data] : [])' : undefined,\n ].filter(Boolean)\n\n return <Template typeName={typeName} name={name} params={params.toString()} keys={keysFn(keys).join(', ')} context={{ factory }} />\n}\n\nQueryKey.templates = defaultTemplates\n","import { PackageManager } from '@kubb/core'\nimport transformers from '@kubb/core/transformers'\nimport { FunctionParams, URLPath } from '@kubb/core/utils'\nimport { useOperation, useOperationManager } from '@kubb/plugin-oas/hooks'\nimport { getASTParams } from '@kubb/plugin-oas/utils'\nimport { Function, useApp, File } from '@kubb/react'\nimport { pluginZodName } from '@kubb/plugin-zod'\n\nimport { isRequired } from '@kubb/oas'\nimport type { HttpMethod } from '@kubb/oas'\nimport type { ReactNode } from 'react'\nimport type { Infinite, PluginReactQuery, Suspense } from '../types.ts'\nimport { pluginTsName } from '@kubb/plugin-ts'\nimport { reactQueryDepRegex } from '../utils.ts'\n\ntype TemplateProps = {\n /**\n * Name of the function\n */\n name: string\n /**\n * Parameters/options/props that need to be used\n */\n params: string\n /**\n * Generics that needs to be added for TypeScript\n */\n generics?: string\n /**\n * ReturnType(see async for adding Promise type)\n */\n returnType?: string\n /**\n * Options for JSdocs\n */\n JSDoc?: {\n comments: string[]\n }\n hook: {\n queryKey: string\n children?: string\n }\n client: {\n generics: string\n method: HttpMethod\n path: URLPath\n withQueryParams: boolean\n withPathParams: boolean\n withData: boolean\n withHeaders: boolean\n contentType: string\n }\n infinite: Infinite | false\n dataReturnType: NonNullable<PluginReactQuery['options']['dataReturnType']>\n parser: string | undefined\n}\n\nfunction Template({ name, params, generics, returnType, JSDoc, hook, client, infinite, dataReturnType, parser }: TemplateProps): ReactNode {\n const isV5 = new PackageManager().isValidSync(reactQueryDepRegex, '>=5')\n const isFormData = client.contentType === 'multipart/form-data'\n const headers = [\n client.contentType !== 'application/json' ? `'Content-Type': '${client.contentType}'` : undefined,\n client.withHeaders ? '...headers' : undefined,\n ]\n .filter(Boolean)\n .join(', ')\n\n const clientOptions = [\n `method: \"${client.method}\"`,\n `url: ${client.path.template}`,\n client.withQueryParams && !infinite ? 'params' : undefined,\n client.withData && !isFormData ? 'data' : undefined,\n client.withData && isFormData ? 'data: formData' : undefined,\n headers.length ? `headers: { ${headers}, ...options.headers }` : undefined,\n '...options',\n client.withQueryParams && !!infinite\n ? `params: {\n ...params,\n ['${infinite.queryParam}']: pageParam,\n ...(options.params || {}),\n }`\n : undefined,\n ].filter(Boolean)\n\n const queryOptions = [\n isV5 && !!infinite ? `initialPageParam: ${infinite.initialPageParam}` : undefined,\n isV5 && !!infinite && !!infinite.cursorParam ? `getNextPageParam: (lastPage) => lastPage['${infinite.cursorParam}']` : undefined,\n isV5 && !!infinite && !!infinite.cursorParam ? `getPreviousPageParam: (firstPage) => firstPage['${infinite.cursorParam}']` : undefined,\n isV5 && !!infinite && !infinite.cursorParam && dataReturnType === 'full'\n ? 'getNextPageParam: (lastPage, _allPages, lastPageParam) => Array.isArray(lastPage.data) && lastPage.data.length === 0 ? undefined : lastPageParam + 1'\n : undefined,\n isV5 && !!infinite && !infinite.cursorParam && dataReturnType === 'data'\n ? 'getNextPageParam: (lastPage, _allPages, lastPageParam) => Array.isArray(lastPage) && lastPage.length === 0 ? undefined : lastPageParam + 1'\n : undefined,\n isV5 && !!infinite && !infinite.cursorParam\n ? 'getPreviousPageParam: (_firstPage, _allPages, firstPageParam) => firstPageParam <= 1 ? undefined : firstPageParam - 1'\n : undefined,\n ].filter(Boolean)\n\n const resolvedClientOptions = `${transformers.createIndent(4)}${clientOptions.join(`,\\n${transformers.createIndent(4)}`)}`\n const resolvedQueryOptions = `${transformers.createIndent(4)}${queryOptions.join(`,\\n${transformers.createIndent(4)}`)}`\n\n let returnRes = parser ? `return ${parser}(res.data)` : 'return res.data'\n\n if (dataReturnType === 'full') {\n returnRes = parser ? `return {...res, data: ${parser}(res.data)}` : 'return res'\n }\n\n const formData = isFormData\n ? `\n const formData = new FormData()\n if(data) {\n Object.keys(data).forEach((key) => {\n const value = data[key];\n if (typeof key === \"string\" && (typeof value === \"string\" || value instanceof Blob)) {\n formData.append(key, value);\n }\n })\n }\n `\n : undefined\n\n if (infinite) {\n if (isV5) {\n return (\n <File.Source name={name} isExportable isIndexable>\n <Function name={name} export params={params} JSDoc={JSDoc}>\n {`\n const queryKey = ${hook.queryKey}\n\n return infiniteQueryOptions({\n queryKey,\n queryFn: async ({ pageParam }) => {\n ${hook.children || ''}\n ${formData || ''}\n const res = await client<${client.generics}>({\n ${resolvedClientOptions}\n })\n\n ${returnRes}\n },\n ${resolvedQueryOptions}\n })\n\n `}\n </Function>\n </File.Source>\n )\n }\n\n return (\n <File.Source name={name} isExportable isIndexable>\n <Function name={name} export generics={generics} returnType={returnType} params={params} JSDoc={JSDoc}>\n {`\n const queryKey = ${hook.queryKey}\n\n return {\n queryKey,\n queryFn: async ({ pageParam }) => {\n ${hook.children || ''}\n ${formData || ''}\n const res = await client<${client.generics}>({\n ${resolvedClientOptions}\n })\n\n ${returnRes}\n },\n ${resolvedQueryOptions}\n }\n\n `}\n </Function>\n </File.Source>\n )\n }\n\n if (isV5) {\n return (\n <File.Source name={name} isExportable isIndexable>\n <Function name={name} export params={params} JSDoc={JSDoc}>\n {`\n const queryKey = ${hook.queryKey}\n\n return queryOptions({\n queryKey,\n queryFn: async () => {\n ${hook.children || ''}\n ${formData || ''}\n const res = await client<${client.generics}>({\n ${resolvedClientOptions}\n })\n\n ${returnRes}\n },\n ${resolvedQueryOptions}\n })\n\n `}\n </Function>\n </File.Source>\n )\n }\n\n return (\n <File.Source name={name} isExportable isIndexable>\n <Function name={name} export generics={generics} returnType={returnType} params={params} JSDoc={JSDoc}>\n {`\n const queryKey = ${hook.queryKey}\n\n return {\n queryKey,\n queryFn: async () => {\n ${hook.children || ''}\n ${formData || ''}\n const res = await client<${client.generics}>({\n ${resolvedClientOptions}\n })\n\n ${returnRes}\n },\n ${resolvedQueryOptions}\n }\n\n `}\n </Function>\n </File.Source>\n )\n}\n\ntype FrameworkProps = TemplateProps & {\n context: {\n factory: {\n name: string\n }\n queryKey: string\n }\n}\n\nconst defaultTemplates = {\n get react() {\n return function (props: FrameworkProps): ReactNode {\n return <Template {...props} />\n }\n },\n get solid() {\n return function (props: FrameworkProps): ReactNode {\n return <Template {...props} />\n }\n },\n get svelte() {\n return function (props: FrameworkProps): ReactNode {\n return <Template {...props} />\n }\n },\n get vue() {\n return function ({ client, context, ...rest }: FrameworkProps): ReactNode {\n const { factory, queryKey } = context\n\n const {\n plugin: {\n options: { pathParamsType },\n },\n } = useApp<PluginReactQuery>()\n\n const { getSchemas } = useOperationManager()\n const operation = useOperation()\n\n const schemas = getSchemas(operation, { pluginKey: [pluginTsName], type: 'type' })\n const params = new FunctionParams()\n const queryKeyParams = new FunctionParams()\n\n params.add([\n ...(pathParamsType === 'object'\n ? [\n getASTParams(schemas.pathParams, {\n typed: true,\n override: (item) => ({\n ...item,\n name: item.name ? `ref${transformers.pascalCase(item.name)}` : undefined,\n type: `MaybeRef<${item.type}>`,\n }),\n }),\n ]\n : getASTParams(schemas.pathParams, {\n typed: true,\n override: (item) => ({\n ...item,\n name: item.name ? `ref${transformers.pascalCase(item.name)}` : undefined,\n type: `MaybeRef<${item.type}>`,\n }),\n })),\n {\n name: 'refParams',\n type: `MaybeRef<${schemas.queryParams?.name}>`,\n enabled: client.withQueryParams,\n required: isRequired(schemas.queryParams?.schema),\n },\n {\n name: 'refHeaders',\n type: `MaybeRef<${schemas.headerParams?.name}>`,\n enabled: client.withHeaders,\n required: isRequired(schemas.headerParams?.schema),\n },\n {\n name: 'refData',\n type: `MaybeRef<${schemas.request?.name}>`,\n enabled: client.withData,\n required: isRequired(schemas.request?.schema),\n },\n {\n name: 'options',\n type: `${factory.name}['client']['parameters']`,\n default: '{}',\n },\n ])\n\n queryKeyParams.add([\n ...(pathParamsType === 'object'\n ? [\n getASTParams(schemas.pathParams, {\n override: (item) => ({\n ...item,\n name: item.name ? `ref${transformers.pascalCase(item.name)}` : undefined,\n }),\n }),\n ]\n : getASTParams(schemas.pathParams, {\n override: (item) => ({\n ...item,\n name: item.name ? `ref${transformers.pascalCase(item.name)}` : undefined,\n }),\n })),\n {\n name: 'refParams',\n enabled: client.withQueryParams,\n required: isRequired(schemas.queryParams?.schema),\n },\n {\n name: 'refData',\n enabled: client.withData,\n required: isRequired(schemas.request?.schema),\n },\n ])\n\n const unrefs = params.items\n .filter((item) => item.enabled)\n .map((item) => {\n return item.name ? `const ${transformers.camelCase(item.name.replace('ref', ''))} = unref(${item.name})` : undefined\n })\n .join('\\n')\n\n const hook = {\n queryKey: `${queryKey}(${queryKeyParams.toString()})`,\n children: unrefs,\n }\n\n return <Template {...rest} params={params.toString()} hook={hook} client={client} />\n }\n },\n} as const\n\ntype Props = {\n infinite: Infinite | false\n suspense: Suspense | false\n factory: {\n name: string\n }\n resultType: string\n /**\n * This will make it possible to override the default behaviour.\n */\n Template?: React.ComponentType<FrameworkProps>\n dataReturnType: NonNullable<PluginReactQuery['options']['dataReturnType']>\n}\n\nexport function QueryOptions({ factory, infinite, suspense, resultType, dataReturnType, Template = defaultTemplates.react }: Props): ReactNode {\n const {\n pluginManager,\n plugin: {\n key: pluginKey,\n options: { parser, pathParamsType, queryOptions },\n },\n } = useApp<PluginReactQuery>()\n\n const { getSchemas } = useOperationManager()\n const operation = useOperation()\n\n const contentType = operation.getContentType()\n const schemas = getSchemas(operation, { pluginKey: [pluginTsName], type: 'type' })\n const zodSchemas = getSchemas(operation, { pluginKey: [pluginZodName], type: 'function' })\n\n const queryKey = pluginManager.resolveName({\n name: [factory.name, infinite ? 'Infinite' : undefined, suspense ? 'Suspense' : undefined, 'QueryKey'].filter(Boolean).join(''),\n pluginKey,\n })\n const queryOptionsName = pluginManager.resolveName({\n name: [factory.name, infinite ? 'Infinite' : undefined, suspense ? 'Suspense' : undefined, 'QueryOptions'].filter(Boolean).join(''),\n pluginKey,\n })\n\n const generics = new FunctionParams()\n const params = new FunctionParams()\n const queryKeyParams = new FunctionParams()\n\n const clientGenerics = [`${factory.name}['data']`, `${factory.name}['error']`]\n // suspense is having 4 generics instead of 5, TQueryData is not needed because data will always be defined\n const resultGenerics = suspense\n ? [`${factory.name}['response']`, `${factory.name}[\"error\"]`, 'TData']\n : [`${factory.name}['response']`, `${factory.name}[\"error\"]`, 'TData', 'TQueryData']\n\n const client = {\n withQueryParams: !!schemas.queryParams?.name,\n withData: !!schemas.request?.name,\n withPathParams: !!schemas.pathParams?.name,\n withHeaders: !!schemas.headerParams?.name,\n method: operation.method,\n path: new URLPath(operation.path),\n generics: clientGenerics.toString(),\n contentType,\n }\n\n generics.add([\n { type: 'TData', default: `${factory.name}[\"response\"]` },\n suspense ? undefined : { type: 'TQueryData', default: `${factory.name}[\"response\"]` },\n ])\n\n params.add([\n ...(pathParamsType === 'object' ? [getASTParams(schemas.pathParams, { typed: true })] : getASTParams(schemas.pathParams, { typed: true })),\n {\n name: 'params',\n type: `${factory.name}['queryParams']`,\n enabled: client.withQueryParams,\n required: isRequired(schemas.queryParams?.schema),\n },\n {\n name: 'headers',\n type: `${factory.name}['headerParams']`,\n enabled: client.withHeaders,\n required: isRequired(schemas.headerParams?.schema),\n },\n {\n name: 'data',\n type: `${factory.name}['request']`,\n enabled: client.withData,\n required: isRequired(schemas.request?.schema),\n },\n {\n name: 'options',\n type: `${factory.name}['client']['parameters']`,\n default: '{}',\n },\n ])\n\n queryKeyParams.add([\n ...(pathParamsType === 'object' ? [getASTParams(schemas.pathParams)] : getASTParams(schemas.pathParams)),\n {\n name: 'params',\n enabled: client.withQueryParams,\n required: isRequired(schemas.queryParams?.schema),\n },\n {\n name: 'data',\n enabled: client.withData,\n required: isRequired(schemas.request?.schema),\n },\n ])\n\n const hook = {\n queryKey: `${queryKey}(${queryKeyParams.toString()})`,\n }\n\n if (!queryOptions) {\n return null\n }\n\n return (\n <Template\n name={queryOptionsName}\n params={params.toString()}\n generics={generics.toString()}\n returnType={`WithRequired<${resultType}<${resultGenerics.join(', ')}>, 'queryKey'>`}\n client={client}\n hook={hook}\n infinite={infinite}\n dataReturnType={dataReturnType}\n parser={parser === 'zod' ? `${zodSchemas.response.name}.parse` : undefined}\n context={{\n factory,\n queryKey,\n }}\n />\n )\n}\n\nQueryOptions.templates = defaultTemplates\n"]}