@kubb/plugin-swr 3.0.0-alpha.7 → 3.0.0-alpha.8
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.
- package/dist/{chunk-PX3AB367.cjs → chunk-TGLXUPN4.cjs} +6 -6
- package/dist/chunk-TGLXUPN4.cjs.map +1 -0
- package/dist/{chunk-I4GGJ5YS.js → chunk-XWXMQJD6.js} +6 -6
- package/dist/chunk-XWXMQJD6.js.map +1 -0
- package/dist/components.cjs +2 -2
- package/dist/components.js +1 -1
- package/dist/index.cjs +6 -6
- package/dist/index.js +1 -1
- package/package.json +14 -14
- package/src/components/Mutation.tsx +2 -2
- package/src/components/Query.tsx +2 -2
- package/src/components/QueryOptions.tsx +1 -1
- package/dist/chunk-I4GGJ5YS.js.map +0 -1
- package/dist/chunk-PX3AB367.cjs.map +0 -1
|
@@ -64,7 +64,7 @@ function Template({ name, generics, returnType, params, JSDoc, client, hook, dat
|
|
|
64
64
|
const resolvedClientOptions = `${_transformers2.default.createIndent(4)}${clientOptions.join(`,
|
|
65
65
|
${_transformers2.default.createIndent(4)}`)}`;
|
|
66
66
|
if (client.withQueryParams) {
|
|
67
|
-
return /* @__PURE__ */ _jsxruntime.jsx.call(void 0, _react.File.Source, { name, isExportable: true, children: /* @__PURE__ */ _jsxruntime.jsx.call(void 0, _react.Function, { export: true, name, generics, returnType, params, JSDoc, children: `
|
|
67
|
+
return /* @__PURE__ */ _jsxruntime.jsx.call(void 0, _react.File.Source, { name, isExportable: true, isIndexable: true, children: /* @__PURE__ */ _jsxruntime.jsx.call(void 0, _react.Function, { export: true, name, generics, returnType, params, JSDoc, children: `
|
|
68
68
|
const { mutation: mutationOptions, client: clientOptions = {}, shouldFetch = true } = options ?? {}
|
|
69
69
|
|
|
70
70
|
const url = ${client.path.template} as const
|
|
@@ -81,7 +81,7 @@ ${_transformers2.default.createIndent(4)}`)}`;
|
|
|
81
81
|
)
|
|
82
82
|
` }) });
|
|
83
83
|
}
|
|
84
|
-
return /* @__PURE__ */ _jsxruntime.jsx.call(void 0, _react.File.Source, { name, isExportable: true, children: /* @__PURE__ */ _jsxruntime.jsx.call(void 0, _react.Function, { export: true, name, generics, returnType, params, JSDoc, children: `
|
|
84
|
+
return /* @__PURE__ */ _jsxruntime.jsx.call(void 0, _react.File.Source, { name, isExportable: true, isIndexable: true, children: /* @__PURE__ */ _jsxruntime.jsx.call(void 0, _react.Function, { export: true, name, generics, returnType, params, JSDoc, children: `
|
|
85
85
|
const { mutation: mutationOptions, client: clientOptions = {}, shouldFetch = true } = options ?? {}
|
|
86
86
|
|
|
87
87
|
const url = ${client.path.template} as const
|
|
@@ -259,7 +259,7 @@ ${_transformers2.default.createIndent(4)}`)}`;
|
|
|
259
259
|
})
|
|
260
260
|
}
|
|
261
261
|
` : void 0;
|
|
262
|
-
return /* @__PURE__ */ _jsxruntime.jsx.call(void 0, _react.File.Source, { name, isExportable: true, children: /* @__PURE__ */ _jsxruntime.jsx.call(void 0, _react.Function, { name, export: true, generics, returnType, params, JSDoc, children: `
|
|
262
|
+
return /* @__PURE__ */ _jsxruntime.jsx.call(void 0, _react.File.Source, { name, isExportable: true, isIndexable: true, children: /* @__PURE__ */ _jsxruntime.jsx.call(void 0, _react.Function, { name, export: true, generics, returnType, params, JSDoc, children: `
|
|
263
263
|
return {
|
|
264
264
|
fetcher: async () => {
|
|
265
265
|
${formData || ""}
|
|
@@ -347,7 +347,7 @@ QueryOptions.templates = defaultTemplates2;
|
|
|
347
347
|
|
|
348
348
|
function Template3({ name, generics, returnType, params, JSDoc, hook, client }) {
|
|
349
349
|
if (client.withQueryParams) {
|
|
350
|
-
return /* @__PURE__ */ _jsxruntime.jsx.call(void 0, _react.File.Source, { name, isExportable: true, children: /* @__PURE__ */ _jsxruntime.jsx.call(void 0, _react.Function, { name, export: true, generics, returnType, params, JSDoc, children: `
|
|
350
|
+
return /* @__PURE__ */ _jsxruntime.jsx.call(void 0, _react.File.Source, { name, isExportable: true, isIndexable: true, children: /* @__PURE__ */ _jsxruntime.jsx.call(void 0, _react.Function, { name, export: true, generics, returnType, params, JSDoc, children: `
|
|
351
351
|
const { query: queryOptions, client: clientOptions = {}, shouldFetch = true } = options ?? {}
|
|
352
352
|
|
|
353
353
|
const url = ${client.path.template}
|
|
@@ -362,7 +362,7 @@ function Template3({ name, generics, returnType, params, JSDoc, hook, client })
|
|
|
362
362
|
return query
|
|
363
363
|
` }) });
|
|
364
364
|
}
|
|
365
|
-
return /* @__PURE__ */ _jsxruntime.jsx.call(void 0, _react.File.Source, { name, isExportable: true, children: /* @__PURE__ */ _jsxruntime.jsx.call(void 0, _react.Function, { name, export: true, generics, returnType, params, JSDoc, children: `
|
|
365
|
+
return /* @__PURE__ */ _jsxruntime.jsx.call(void 0, _react.File.Source, { name, isExportable: true, isIndexable: true, children: /* @__PURE__ */ _jsxruntime.jsx.call(void 0, _react.Function, { name, export: true, generics, returnType, params, JSDoc, children: `
|
|
366
366
|
const { query: queryOptions, client: clientOptions = {}, shouldFetch = true } = options ?? {}
|
|
367
367
|
|
|
368
368
|
const url = ${client.path.template}
|
|
@@ -533,4 +533,4 @@ Query.templates = defaultTemplates3;
|
|
|
533
533
|
|
|
534
534
|
|
|
535
535
|
exports.Mutation = Mutation; exports.QueryOptions = QueryOptions; exports.Query = Query;
|
|
536
|
-
//# sourceMappingURL=chunk-
|
|
536
|
+
//# sourceMappingURL=chunk-TGLXUPN4.cjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["/home/runner/work/kubb/kubb/packages/plugin-swr/dist/chunk-TGLXUPN4.cjs","../src/components/Mutation.tsx","../src/components/SchemaType.tsx","../src/components/Query.tsx","../src/components/QueryOptions.tsx"],"names":["useOperation","Template","jsx","File","transformers","Function","defaultTemplates","FunctionParams","URLPath","Fragment","pluginZodName"],"mappings":"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","file":"/home/runner/work/kubb/kubb/packages/plugin-swr/dist/chunk-TGLXUPN4.cjs","sourcesContent":[null,"import 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 { useOperation, useOperationManager } from '@kubb/plugin-oas/hooks'\nimport { getASTParams, getComments } from '@kubb/plugin-oas/utils'\n\nimport { SchemaType } from './SchemaType.tsx'\n\nimport type { HttpMethod } from '@kubb/oas'\nimport type { ReactNode } from 'react'\nimport type { FileMeta, PluginSwr } 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 }\n client: {\n method: HttpMethod\n generics: string\n withQueryParams: boolean\n withPathParams: boolean\n withData: boolean\n withHeaders: boolean\n path: URLPath\n }\n dataReturnType: NonNullable<PluginSwr['options']['dataReturnType']>\n}\n\nfunction Template({ name, generics, returnType, params, JSDoc, client, hook, dataReturnType }: TemplateProps): ReactNode {\n const clientOptions = [\n `method: \"${client.method}\"`,\n 'url',\n client.withQueryParams ? 'params' : undefined,\n client.withData ? 'data' : undefined,\n client.withHeaders ? 'headers: { ...headers, ...clientOptions.headers }' : undefined,\n '...clientOptions',\n ].filter(Boolean)\n\n const resolvedClientOptions = `${transformers.createIndent(4)}${clientOptions.join(`,\\n${transformers.createIndent(4)}`)}`\n if (client.withQueryParams) {\n return (\n <File.Source name={name} isExportable isIndexable>\n <Function export name={name} generics={generics} returnType={returnType} params={params} JSDoc={JSDoc}>\n {`\n const { mutation: mutationOptions, client: clientOptions = {}, shouldFetch = true } = options ?? {}\n\n const url = ${client.path.template} as const\n return ${hook.name}<${hook.generics}>(\n shouldFetch ? [url, params]: null,\n async (_url${client.withData ? ', { arg: data }' : ''}) => {\n const res = await client<${client.generics}>({\n ${resolvedClientOptions}\n })\n\n return ${dataReturnType === 'data' ? 'res.data' : 'res'}\n },\n mutationOptions\n )\n `}\n </Function>\n </File.Source>\n )\n }\n\n return (\n <File.Source name={name} isExportable isIndexable>\n <Function export name={name} generics={generics} returnType={returnType} params={params} JSDoc={JSDoc}>\n {`\n const { mutation: mutationOptions, client: clientOptions = {}, shouldFetch = true } = options ?? {}\n\n const url = ${client.path.template} as const\n return ${hook.name}<${hook.generics}>(\n shouldFetch ? url : null,\n async (_url${client.withData ? ', { arg: data }' : ''}) => {\n const res = await client<${client.generics}>({\n ${resolvedClientOptions}\n })\n\n return ${dataReturnType === 'data' ? 'res.data' : 'res'}\n },\n mutationOptions\n )\n `}\n </Function>\n </File.Source>\n )\n}\n\nconst defaultTemplates = {\n default: Template,\n} as const\n\ntype Props = {\n factory: {\n name: string\n }\n /**\n * This will make it possible to override the default behaviour.\n */\n Template?: React.ComponentType<TemplateProps>\n}\n\nexport function Mutation({ factory, Template = defaultTemplates.default }: Props): ReactNode {\n const {\n plugin: {\n options: { dataReturnType },\n },\n } = useApp<PluginSwr>()\n const { getSchemas, getName } = useOperationManager()\n const operation = useOperation()\n\n const name = getName(operation, { type: 'function' })\n const schemas = getSchemas(operation, { pluginKey: [pluginTsName], type: 'type' })\n\n const params = new FunctionParams()\n const client = {\n method: operation.method,\n path: new URLPath(operation.path),\n generics: [`${factory.name}[\"data\"]`, `${factory.name}[\"error\"]`, schemas.request?.name ? `${factory.name}[\"request\"]` : ''].filter(Boolean).join(', '),\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 = [`${factory.name}[\"response\"]`, `${factory.name}[\"error\"]`]\n\n params.add([\n ...getASTParams(schemas.pathParams, { typed: true }),\n {\n name: 'params',\n type: `${factory.name}['queryParams']`,\n enabled: client.withQueryParams,\n required: false,\n },\n {\n name: 'headers',\n type: `${factory.name}['headerParams']`,\n enabled: client.withHeaders,\n required: false,\n },\n {\n name: 'options',\n required: false,\n type: `{\n mutation?: SWRMutationConfiguration<${resultGenerics.join(', ')}>,\n client?: ${factory.name}['client']['parameters'],\n shouldFetch?: boolean,\n }`,\n default: '{}',\n },\n ])\n\n const hook = {\n name: 'useSWRMutation',\n generics: [...resultGenerics, client.withQueryParams ? '[typeof url, typeof params] | null' : 'typeof url | null'].join(', '),\n }\n\n return (\n <Template\n name={name}\n JSDoc={{ comments: getComments(operation) }}\n client={client}\n hook={hook}\n params={params.toString()}\n returnType={`SWRMutationResponse<${resultGenerics.join(', ')}>`}\n dataReturnType={dataReturnType}\n />\n )\n}\n\ntype FileProps = {\n /**\n * This will make it possible to override the default behaviour.\n */\n templates?: typeof defaultTemplates\n}\n\nMutation.File = function ({ templates = defaultTemplates }: FileProps): ReactNode {\n const {\n plugin: {\n options: {\n extName,\n client: { importPath },\n },\n },\n } = useApp<PluginSwr>()\n\n const { getSchemas, getFile, getName } = 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 const factoryName = getName(operation, { type: 'type' })\n\n const Template = templates.default\n const factory = {\n name: factoryName,\n }\n\n return (\n <File<FileMeta> baseName={file.baseName} path={file.path} meta={file.meta}>\n <File.Import name=\"useSWRMutation\" path=\"swr/mutation\" />\n <File.Import name={['SWRMutationConfiguration', 'SWRMutationResponse']} path=\"swr/mutation\" isTypeOnly />\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 <SchemaType factory={factory} />\n <Mutation Template={Template} factory={factory} />\n </File>\n )\n}\n\nMutation.templates = defaultTemplates\n","import { File, Type, useApp } from '@kubb/react'\n\nimport { useOperation, useOperationManager } from '@kubb/plugin-oas/hooks'\nimport { pluginTsName } from '@kubb/plugin-ts'\nimport type { ReactNode } from 'react'\nimport type { PluginSwr } from '../types.ts'\n\ntype Props = {\n factory: {\n name: string\n }\n}\n\nexport function SchemaType({ factory }: Props): ReactNode {\n const {\n plugin: {\n options: { dataReturnType },\n },\n } = useApp<PluginSwr>()\n const { getSchemas } = 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\n const clientType = `${factory.name}Client`\n\n return (\n <>\n <File.Source name={clientType} isTypeOnly>\n <Type name={clientType}>{`typeof client<${TResponse}, ${TError}, ${TRequest}>`}</Type>\n </File.Source>\n <File.Source name={factory.name} isTypeOnly>\n <Type name={factory.name}>\n {`\n {\n data: ${TData}\n error: ${TError}\n request: ${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 { FunctionParams, URLPath } from '@kubb/core/utils'\nimport { useOperation, useOperationManager } from '@kubb/plugin-oas/hooks'\nimport { getASTParams, getComments } from '@kubb/plugin-oas/utils'\nimport { pluginTsName } from '@kubb/plugin-ts'\nimport { pluginZodName } from '@kubb/plugin-zod'\nimport { File, Function, useApp } from '@kubb/react'\n\nimport { QueryOptions } from './QueryOptions.tsx'\nimport { SchemaType } from './SchemaType.tsx'\n\nimport type { ReactNode } from 'react'\nimport type { FileMeta, PluginSwr } 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 queryOptions: string\n }\n client: {\n path: URLPath\n withQueryParams: boolean\n }\n}\n\nfunction Template({ name, generics, returnType, params, JSDoc, hook, client }: TemplateProps): ReactNode {\n if (client.withQueryParams) {\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 { query: queryOptions, client: clientOptions = {}, shouldFetch = true } = options ?? {}\n\n const url = ${client.path.template}\n const query = ${hook.name}<${hook.generics}>(\n shouldFetch ? [url, params]: null,\n {\n ...${hook.queryOptions},\n ...queryOptions\n }\n )\n\n return query\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 { query: queryOptions, client: clientOptions = {}, shouldFetch = true } = options ?? {}\n\n const url = ${client.path.template}\n const query = ${hook.name}<${hook.generics}>(\n shouldFetch ? url : null,\n {\n ...${hook.queryOptions},\n ...queryOptions\n }\n )\n\n return query\n `}\n </Function>\n </File.Source>\n )\n}\n\nconst defaultTemplates = {\n default: Template,\n} as const\n\ntype Props = {\n factory: {\n name: string\n }\n /**\n * This will make it possible to override the default behaviour.\n */\n Template?: React.ComponentType<TemplateProps>\n /**\n * This will make it possible to override the default behaviour.\n */\n QueryOptionsTemplate?: React.ComponentType<React.ComponentProps<typeof QueryOptions.templates.default>>\n}\n\nexport function Query({ factory, Template = defaultTemplates.default, QueryOptionsTemplate = QueryOptions.templates.default }: Props): ReactNode {\n const {\n pluginManager,\n plugin: {\n key: pluginKey,\n options: { dataReturnType },\n },\n } = useApp<PluginSwr>()\n\n const operation = useOperation()\n const { getSchemas, getName } = useOperationManager()\n\n const schemas = getSchemas(operation, { pluginKey: [pluginTsName], type: 'type' })\n const zodSchemas = getSchemas(operation, { pluginKey: [pluginZodName], type: 'function' })\n\n const name = getName(operation, { type: 'function' })\n\n const queryOptionsName = pluginManager.resolveName({\n name: `${factory.name}QueryOptions`,\n pluginKey,\n })\n const generics = new FunctionParams()\n const params = new FunctionParams()\n const queryParams = new FunctionParams()\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 const resultGenerics = ['TData', `${factory.name}[\"error\"]`]\n\n generics.add([{ type: 'TData', default: `${factory.name}[\"response\"]` }])\n\n const queryOptionsGenerics = ['TData']\n\n params.add([\n ...getASTParams(schemas.pathParams, { typed: true }),\n {\n name: 'params',\n type: `${factory.name}['queryParams']`,\n enabled: client.withQueryParams,\n required: false,\n },\n {\n name: 'headers',\n type: `${factory.name}['headerParams']`,\n enabled: client.withHeaders,\n required: false,\n },\n {\n name: 'options',\n required: false,\n type: `{\n query?: SWRConfiguration<${resultGenerics.join(', ')}>,\n client?: ${factory.name}['client']['parameters'],\n shouldFetch?: boolean,\n }`,\n default: '{}',\n },\n ])\n\n queryParams.add([\n ...getASTParams(schemas.pathParams, { typed: false }),\n {\n name: 'params',\n enabled: client.withQueryParams,\n required: false,\n },\n {\n name: 'headers',\n enabled: client.withHeaders,\n required: false,\n },\n {\n name: 'clientOptions',\n required: false,\n },\n ])\n\n const hook = {\n name: 'useSWR',\n generics: [...resultGenerics, client.withQueryParams ? '[typeof url, typeof params] | null' : 'typeof url | null'].join(', '),\n queryOptions: `${queryOptionsName}<${queryOptionsGenerics.join(', ')}>(${queryParams.toString()})`,\n }\n\n return (\n <>\n <QueryOptions factory={factory} Template={QueryOptionsTemplate} dataReturnType={dataReturnType} />\n <Template\n name={name}\n generics={generics.toString()}\n JSDoc={{ comments: getComments(operation) }}\n client={client}\n hook={hook}\n params={params.toString()}\n returnType={`SWRResponse<${resultGenerics.join(', ')}>`}\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 queryOptions: typeof QueryOptions.templates\n }\n}\n\nQuery.File = function ({ templates }: FileProps): ReactNode {\n const {\n pluginManager,\n plugin: {\n options: {\n extName,\n client: { importPath },\n parser,\n },\n },\n } = useApp<PluginSwr>()\n const { getSchemas, getFile, getName } = useOperationManager()\n const operation = useOperation()\n\n const file = getFile(operation)\n const schemas = getSchemas(operation, { pluginKey: [pluginTsName], type: 'type' })\n const zodSchemas = getSchemas(operation, { pluginKey: [pluginZodName], type: 'function' })\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 Template = templates?.query.default || defaultTemplates.default\n const QueryOptionsTemplate = templates?.queryOptions.default || QueryOptions.templates.default\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=\"useSWR\" path=\"swr\" />\n <File.Import name={['SWRConfiguration', 'SWRResponse']} path=\"swr\" isTypeOnly />\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.statusCodes?.map((item) => item.name) || []),\n ].filter(Boolean)}\n root={file.path}\n path={fileType.path}\n isTypeOnly\n />\n\n <SchemaType factory={factory} />\n <Query factory={factory} Template={Template} QueryOptionsTemplate={QueryOptionsTemplate} />\n </File>\n )\n}\n\nQuery.templates = defaultTemplates\n","import 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, File, useApp } from '@kubb/react'\nimport { pluginZodName } from '@kubb/plugin-zod'\n\nimport type { HttpMethod } from '@kubb/oas'\nimport type { ReactNode } from 'react'\nimport type { PluginSwr } from '../types.ts'\nimport { pluginTsName } from '@kubb/plugin-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 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<PluginSwr['options']['dataReturnType']>\n parser: string | undefined\n}\n\nfunction Template({ name, params, generics, returnType, JSDoc, client, dataReturnType, parser }: 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}, ...options.headers }` : undefined,\n '...options',\n ].filter(Boolean)\n\n const resolvedClientOptions = `${transformers.createIndent(4)}${clientOptions.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 return (\n <File.Source name={name} isExportable isIndexable>\n <Function name={name} export generics={generics} returnType={returnType} params={params} JSDoc={JSDoc}>\n {`\n return {\n fetcher: async () => {\n ${formData || ''}\n const res = await client<${client.generics}>({\n ${resolvedClientOptions}\n })\n\n ${returnRes}\n },\n }\n\n `}\n </Function>\n </File.Source>\n )\n}\n\nconst defaultTemplates = {\n default: Template,\n} as const\n\ntype Props = {\n factory: {\n name: string\n }\n dataReturnType: NonNullable<PluginSwr['options']['dataReturnType']>\n /**\n * This will make it possible to override the default behaviour.\n */\n Template?: React.ComponentType<TemplateProps>\n}\n\nexport function QueryOptions({ factory, dataReturnType, Template = defaultTemplates.default }: Props): ReactNode {\n const {\n pluginManager,\n plugin: {\n key: pluginKey,\n options: { parser },\n },\n } = useApp<PluginSwr>()\n const { getSchemas } = 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 name = pluginManager.resolveName({\n name: `${factory.name}QueryOptions`,\n pluginKey,\n })\n const contentType = operation.getContentType()\n\n const generics = new FunctionParams()\n const params = new FunctionParams()\n\n const clientGenerics = ['TData', `${factory.name}['error']`]\n const resultGenerics = ['TData', `${factory.name}['error']`]\n\n generics.add([{ type: 'TData', default: `${factory.name}['response']` }])\n\n params.add([\n ...getASTParams(schemas.pathParams, { typed: true }),\n {\n name: 'params',\n type: `${factory.name}['queryParams']`,\n enabled: !!schemas.queryParams?.name,\n required: false,\n },\n {\n name: 'headers',\n type: `${factory.name}['headerParams']`,\n enabled: !!schemas.headerParams?.name,\n required: false,\n },\n {\n name: 'options',\n type: `${factory.name}['client']['parameters']`,\n default: '{}',\n },\n ])\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.join(', '),\n contentType,\n }\n\n return (\n <Template\n name={name}\n params={params.toString()}\n generics={generics.toString()}\n returnType={`SWRConfiguration<${resultGenerics.join(', ')}>`}\n client={client}\n dataReturnType={dataReturnType}\n parser={parser === 'zod' ? `${zodSchemas.response.name}.parse` : undefined}\n />\n )\n}\n\nQueryOptions.templates = defaultTemplates\n"]}
|
|
@@ -64,7 +64,7 @@ function Template({ name, generics, returnType, params, JSDoc, client, hook, dat
|
|
|
64
64
|
const resolvedClientOptions = `${transformers.createIndent(4)}${clientOptions.join(`,
|
|
65
65
|
${transformers.createIndent(4)}`)}`;
|
|
66
66
|
if (client.withQueryParams) {
|
|
67
|
-
return /* @__PURE__ */ jsx2(File2.Source, { name, isExportable: true, children: /* @__PURE__ */ jsx2(Function, { export: true, name, generics, returnType, params, JSDoc, children: `
|
|
67
|
+
return /* @__PURE__ */ jsx2(File2.Source, { name, isExportable: true, isIndexable: true, children: /* @__PURE__ */ jsx2(Function, { export: true, name, generics, returnType, params, JSDoc, children: `
|
|
68
68
|
const { mutation: mutationOptions, client: clientOptions = {}, shouldFetch = true } = options ?? {}
|
|
69
69
|
|
|
70
70
|
const url = ${client.path.template} as const
|
|
@@ -81,7 +81,7 @@ ${transformers.createIndent(4)}`)}`;
|
|
|
81
81
|
)
|
|
82
82
|
` }) });
|
|
83
83
|
}
|
|
84
|
-
return /* @__PURE__ */ jsx2(File2.Source, { name, isExportable: true, children: /* @__PURE__ */ jsx2(Function, { export: true, name, generics, returnType, params, JSDoc, children: `
|
|
84
|
+
return /* @__PURE__ */ jsx2(File2.Source, { name, isExportable: true, isIndexable: true, children: /* @__PURE__ */ jsx2(Function, { export: true, name, generics, returnType, params, JSDoc, children: `
|
|
85
85
|
const { mutation: mutationOptions, client: clientOptions = {}, shouldFetch = true } = options ?? {}
|
|
86
86
|
|
|
87
87
|
const url = ${client.path.template} as const
|
|
@@ -259,7 +259,7 @@ ${transformers2.createIndent(4)}`)}`;
|
|
|
259
259
|
})
|
|
260
260
|
}
|
|
261
261
|
` : void 0;
|
|
262
|
-
return /* @__PURE__ */ jsx3(File3.Source, { name, isExportable: true, children: /* @__PURE__ */ jsx3(Function2, { name, export: true, generics, returnType, params, JSDoc, children: `
|
|
262
|
+
return /* @__PURE__ */ jsx3(File3.Source, { name, isExportable: true, isIndexable: true, children: /* @__PURE__ */ jsx3(Function2, { name, export: true, generics, returnType, params, JSDoc, children: `
|
|
263
263
|
return {
|
|
264
264
|
fetcher: async () => {
|
|
265
265
|
${formData || ""}
|
|
@@ -347,7 +347,7 @@ QueryOptions.templates = defaultTemplates2;
|
|
|
347
347
|
import { Fragment as Fragment2, jsx as jsx4, jsxs as jsxs3 } from "@kubb/react/jsx-runtime";
|
|
348
348
|
function Template3({ name, generics, returnType, params, JSDoc, hook, client }) {
|
|
349
349
|
if (client.withQueryParams) {
|
|
350
|
-
return /* @__PURE__ */ jsx4(File4.Source, { name, isExportable: true, children: /* @__PURE__ */ jsx4(Function3, { name, export: true, generics, returnType, params, JSDoc, children: `
|
|
350
|
+
return /* @__PURE__ */ jsx4(File4.Source, { name, isExportable: true, isIndexable: true, children: /* @__PURE__ */ jsx4(Function3, { name, export: true, generics, returnType, params, JSDoc, children: `
|
|
351
351
|
const { query: queryOptions, client: clientOptions = {}, shouldFetch = true } = options ?? {}
|
|
352
352
|
|
|
353
353
|
const url = ${client.path.template}
|
|
@@ -362,7 +362,7 @@ function Template3({ name, generics, returnType, params, JSDoc, hook, client })
|
|
|
362
362
|
return query
|
|
363
363
|
` }) });
|
|
364
364
|
}
|
|
365
|
-
return /* @__PURE__ */ jsx4(File4.Source, { name, isExportable: true, children: /* @__PURE__ */ jsx4(Function3, { name, export: true, generics, returnType, params, JSDoc, children: `
|
|
365
|
+
return /* @__PURE__ */ jsx4(File4.Source, { name, isExportable: true, isIndexable: true, children: /* @__PURE__ */ jsx4(Function3, { name, export: true, generics, returnType, params, JSDoc, children: `
|
|
366
366
|
const { query: queryOptions, client: clientOptions = {}, shouldFetch = true } = options ?? {}
|
|
367
367
|
|
|
368
368
|
const url = ${client.path.template}
|
|
@@ -533,4 +533,4 @@ export {
|
|
|
533
533
|
QueryOptions,
|
|
534
534
|
Query
|
|
535
535
|
};
|
|
536
|
-
//# sourceMappingURL=chunk-
|
|
536
|
+
//# sourceMappingURL=chunk-XWXMQJD6.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/components/Mutation.tsx","../src/components/SchemaType.tsx","../src/components/Query.tsx","../src/components/QueryOptions.tsx"],"sourcesContent":["import 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 { useOperation, useOperationManager } from '@kubb/plugin-oas/hooks'\nimport { getASTParams, getComments } from '@kubb/plugin-oas/utils'\n\nimport { SchemaType } from './SchemaType.tsx'\n\nimport type { HttpMethod } from '@kubb/oas'\nimport type { ReactNode } from 'react'\nimport type { FileMeta, PluginSwr } 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 }\n client: {\n method: HttpMethod\n generics: string\n withQueryParams: boolean\n withPathParams: boolean\n withData: boolean\n withHeaders: boolean\n path: URLPath\n }\n dataReturnType: NonNullable<PluginSwr['options']['dataReturnType']>\n}\n\nfunction Template({ name, generics, returnType, params, JSDoc, client, hook, dataReturnType }: TemplateProps): ReactNode {\n const clientOptions = [\n `method: \"${client.method}\"`,\n 'url',\n client.withQueryParams ? 'params' : undefined,\n client.withData ? 'data' : undefined,\n client.withHeaders ? 'headers: { ...headers, ...clientOptions.headers }' : undefined,\n '...clientOptions',\n ].filter(Boolean)\n\n const resolvedClientOptions = `${transformers.createIndent(4)}${clientOptions.join(`,\\n${transformers.createIndent(4)}`)}`\n if (client.withQueryParams) {\n return (\n <File.Source name={name} isExportable isIndexable>\n <Function export name={name} generics={generics} returnType={returnType} params={params} JSDoc={JSDoc}>\n {`\n const { mutation: mutationOptions, client: clientOptions = {}, shouldFetch = true } = options ?? {}\n\n const url = ${client.path.template} as const\n return ${hook.name}<${hook.generics}>(\n shouldFetch ? [url, params]: null,\n async (_url${client.withData ? ', { arg: data }' : ''}) => {\n const res = await client<${client.generics}>({\n ${resolvedClientOptions}\n })\n\n return ${dataReturnType === 'data' ? 'res.data' : 'res'}\n },\n mutationOptions\n )\n `}\n </Function>\n </File.Source>\n )\n }\n\n return (\n <File.Source name={name} isExportable isIndexable>\n <Function export name={name} generics={generics} returnType={returnType} params={params} JSDoc={JSDoc}>\n {`\n const { mutation: mutationOptions, client: clientOptions = {}, shouldFetch = true } = options ?? {}\n\n const url = ${client.path.template} as const\n return ${hook.name}<${hook.generics}>(\n shouldFetch ? url : null,\n async (_url${client.withData ? ', { arg: data }' : ''}) => {\n const res = await client<${client.generics}>({\n ${resolvedClientOptions}\n })\n\n return ${dataReturnType === 'data' ? 'res.data' : 'res'}\n },\n mutationOptions\n )\n `}\n </Function>\n </File.Source>\n )\n}\n\nconst defaultTemplates = {\n default: Template,\n} as const\n\ntype Props = {\n factory: {\n name: string\n }\n /**\n * This will make it possible to override the default behaviour.\n */\n Template?: React.ComponentType<TemplateProps>\n}\n\nexport function Mutation({ factory, Template = defaultTemplates.default }: Props): ReactNode {\n const {\n plugin: {\n options: { dataReturnType },\n },\n } = useApp<PluginSwr>()\n const { getSchemas, getName } = useOperationManager()\n const operation = useOperation()\n\n const name = getName(operation, { type: 'function' })\n const schemas = getSchemas(operation, { pluginKey: [pluginTsName], type: 'type' })\n\n const params = new FunctionParams()\n const client = {\n method: operation.method,\n path: new URLPath(operation.path),\n generics: [`${factory.name}[\"data\"]`, `${factory.name}[\"error\"]`, schemas.request?.name ? `${factory.name}[\"request\"]` : ''].filter(Boolean).join(', '),\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 = [`${factory.name}[\"response\"]`, `${factory.name}[\"error\"]`]\n\n params.add([\n ...getASTParams(schemas.pathParams, { typed: true }),\n {\n name: 'params',\n type: `${factory.name}['queryParams']`,\n enabled: client.withQueryParams,\n required: false,\n },\n {\n name: 'headers',\n type: `${factory.name}['headerParams']`,\n enabled: client.withHeaders,\n required: false,\n },\n {\n name: 'options',\n required: false,\n type: `{\n mutation?: SWRMutationConfiguration<${resultGenerics.join(', ')}>,\n client?: ${factory.name}['client']['parameters'],\n shouldFetch?: boolean,\n }`,\n default: '{}',\n },\n ])\n\n const hook = {\n name: 'useSWRMutation',\n generics: [...resultGenerics, client.withQueryParams ? '[typeof url, typeof params] | null' : 'typeof url | null'].join(', '),\n }\n\n return (\n <Template\n name={name}\n JSDoc={{ comments: getComments(operation) }}\n client={client}\n hook={hook}\n params={params.toString()}\n returnType={`SWRMutationResponse<${resultGenerics.join(', ')}>`}\n dataReturnType={dataReturnType}\n />\n )\n}\n\ntype FileProps = {\n /**\n * This will make it possible to override the default behaviour.\n */\n templates?: typeof defaultTemplates\n}\n\nMutation.File = function ({ templates = defaultTemplates }: FileProps): ReactNode {\n const {\n plugin: {\n options: {\n extName,\n client: { importPath },\n },\n },\n } = useApp<PluginSwr>()\n\n const { getSchemas, getFile, getName } = 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 const factoryName = getName(operation, { type: 'type' })\n\n const Template = templates.default\n const factory = {\n name: factoryName,\n }\n\n return (\n <File<FileMeta> baseName={file.baseName} path={file.path} meta={file.meta}>\n <File.Import name=\"useSWRMutation\" path=\"swr/mutation\" />\n <File.Import name={['SWRMutationConfiguration', 'SWRMutationResponse']} path=\"swr/mutation\" isTypeOnly />\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 <SchemaType factory={factory} />\n <Mutation Template={Template} factory={factory} />\n </File>\n )\n}\n\nMutation.templates = defaultTemplates\n","import { File, Type, useApp } from '@kubb/react'\n\nimport { useOperation, useOperationManager } from '@kubb/plugin-oas/hooks'\nimport { pluginTsName } from '@kubb/plugin-ts'\nimport type { ReactNode } from 'react'\nimport type { PluginSwr } from '../types.ts'\n\ntype Props = {\n factory: {\n name: string\n }\n}\n\nexport function SchemaType({ factory }: Props): ReactNode {\n const {\n plugin: {\n options: { dataReturnType },\n },\n } = useApp<PluginSwr>()\n const { getSchemas } = 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\n const clientType = `${factory.name}Client`\n\n return (\n <>\n <File.Source name={clientType} isTypeOnly>\n <Type name={clientType}>{`typeof client<${TResponse}, ${TError}, ${TRequest}>`}</Type>\n </File.Source>\n <File.Source name={factory.name} isTypeOnly>\n <Type name={factory.name}>\n {`\n {\n data: ${TData}\n error: ${TError}\n request: ${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 { FunctionParams, URLPath } from '@kubb/core/utils'\nimport { useOperation, useOperationManager } from '@kubb/plugin-oas/hooks'\nimport { getASTParams, getComments } from '@kubb/plugin-oas/utils'\nimport { pluginTsName } from '@kubb/plugin-ts'\nimport { pluginZodName } from '@kubb/plugin-zod'\nimport { File, Function, useApp } from '@kubb/react'\n\nimport { QueryOptions } from './QueryOptions.tsx'\nimport { SchemaType } from './SchemaType.tsx'\n\nimport type { ReactNode } from 'react'\nimport type { FileMeta, PluginSwr } 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 queryOptions: string\n }\n client: {\n path: URLPath\n withQueryParams: boolean\n }\n}\n\nfunction Template({ name, generics, returnType, params, JSDoc, hook, client }: TemplateProps): ReactNode {\n if (client.withQueryParams) {\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 { query: queryOptions, client: clientOptions = {}, shouldFetch = true } = options ?? {}\n\n const url = ${client.path.template}\n const query = ${hook.name}<${hook.generics}>(\n shouldFetch ? [url, params]: null,\n {\n ...${hook.queryOptions},\n ...queryOptions\n }\n )\n\n return query\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 { query: queryOptions, client: clientOptions = {}, shouldFetch = true } = options ?? {}\n\n const url = ${client.path.template}\n const query = ${hook.name}<${hook.generics}>(\n shouldFetch ? url : null,\n {\n ...${hook.queryOptions},\n ...queryOptions\n }\n )\n\n return query\n `}\n </Function>\n </File.Source>\n )\n}\n\nconst defaultTemplates = {\n default: Template,\n} as const\n\ntype Props = {\n factory: {\n name: string\n }\n /**\n * This will make it possible to override the default behaviour.\n */\n Template?: React.ComponentType<TemplateProps>\n /**\n * This will make it possible to override the default behaviour.\n */\n QueryOptionsTemplate?: React.ComponentType<React.ComponentProps<typeof QueryOptions.templates.default>>\n}\n\nexport function Query({ factory, Template = defaultTemplates.default, QueryOptionsTemplate = QueryOptions.templates.default }: Props): ReactNode {\n const {\n pluginManager,\n plugin: {\n key: pluginKey,\n options: { dataReturnType },\n },\n } = useApp<PluginSwr>()\n\n const operation = useOperation()\n const { getSchemas, getName } = useOperationManager()\n\n const schemas = getSchemas(operation, { pluginKey: [pluginTsName], type: 'type' })\n const zodSchemas = getSchemas(operation, { pluginKey: [pluginZodName], type: 'function' })\n\n const name = getName(operation, { type: 'function' })\n\n const queryOptionsName = pluginManager.resolveName({\n name: `${factory.name}QueryOptions`,\n pluginKey,\n })\n const generics = new FunctionParams()\n const params = new FunctionParams()\n const queryParams = new FunctionParams()\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 const resultGenerics = ['TData', `${factory.name}[\"error\"]`]\n\n generics.add([{ type: 'TData', default: `${factory.name}[\"response\"]` }])\n\n const queryOptionsGenerics = ['TData']\n\n params.add([\n ...getASTParams(schemas.pathParams, { typed: true }),\n {\n name: 'params',\n type: `${factory.name}['queryParams']`,\n enabled: client.withQueryParams,\n required: false,\n },\n {\n name: 'headers',\n type: `${factory.name}['headerParams']`,\n enabled: client.withHeaders,\n required: false,\n },\n {\n name: 'options',\n required: false,\n type: `{\n query?: SWRConfiguration<${resultGenerics.join(', ')}>,\n client?: ${factory.name}['client']['parameters'],\n shouldFetch?: boolean,\n }`,\n default: '{}',\n },\n ])\n\n queryParams.add([\n ...getASTParams(schemas.pathParams, { typed: false }),\n {\n name: 'params',\n enabled: client.withQueryParams,\n required: false,\n },\n {\n name: 'headers',\n enabled: client.withHeaders,\n required: false,\n },\n {\n name: 'clientOptions',\n required: false,\n },\n ])\n\n const hook = {\n name: 'useSWR',\n generics: [...resultGenerics, client.withQueryParams ? '[typeof url, typeof params] | null' : 'typeof url | null'].join(', '),\n queryOptions: `${queryOptionsName}<${queryOptionsGenerics.join(', ')}>(${queryParams.toString()})`,\n }\n\n return (\n <>\n <QueryOptions factory={factory} Template={QueryOptionsTemplate} dataReturnType={dataReturnType} />\n <Template\n name={name}\n generics={generics.toString()}\n JSDoc={{ comments: getComments(operation) }}\n client={client}\n hook={hook}\n params={params.toString()}\n returnType={`SWRResponse<${resultGenerics.join(', ')}>`}\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 queryOptions: typeof QueryOptions.templates\n }\n}\n\nQuery.File = function ({ templates }: FileProps): ReactNode {\n const {\n pluginManager,\n plugin: {\n options: {\n extName,\n client: { importPath },\n parser,\n },\n },\n } = useApp<PluginSwr>()\n const { getSchemas, getFile, getName } = useOperationManager()\n const operation = useOperation()\n\n const file = getFile(operation)\n const schemas = getSchemas(operation, { pluginKey: [pluginTsName], type: 'type' })\n const zodSchemas = getSchemas(operation, { pluginKey: [pluginZodName], type: 'function' })\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 Template = templates?.query.default || defaultTemplates.default\n const QueryOptionsTemplate = templates?.queryOptions.default || QueryOptions.templates.default\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=\"useSWR\" path=\"swr\" />\n <File.Import name={['SWRConfiguration', 'SWRResponse']} path=\"swr\" isTypeOnly />\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.statusCodes?.map((item) => item.name) || []),\n ].filter(Boolean)}\n root={file.path}\n path={fileType.path}\n isTypeOnly\n />\n\n <SchemaType factory={factory} />\n <Query factory={factory} Template={Template} QueryOptionsTemplate={QueryOptionsTemplate} />\n </File>\n )\n}\n\nQuery.templates = defaultTemplates\n","import 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, File, useApp } from '@kubb/react'\nimport { pluginZodName } from '@kubb/plugin-zod'\n\nimport type { HttpMethod } from '@kubb/oas'\nimport type { ReactNode } from 'react'\nimport type { PluginSwr } from '../types.ts'\nimport { pluginTsName } from '@kubb/plugin-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 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<PluginSwr['options']['dataReturnType']>\n parser: string | undefined\n}\n\nfunction Template({ name, params, generics, returnType, JSDoc, client, dataReturnType, parser }: 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}, ...options.headers }` : undefined,\n '...options',\n ].filter(Boolean)\n\n const resolvedClientOptions = `${transformers.createIndent(4)}${clientOptions.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 return (\n <File.Source name={name} isExportable isIndexable>\n <Function name={name} export generics={generics} returnType={returnType} params={params} JSDoc={JSDoc}>\n {`\n return {\n fetcher: async () => {\n ${formData || ''}\n const res = await client<${client.generics}>({\n ${resolvedClientOptions}\n })\n\n ${returnRes}\n },\n }\n\n `}\n </Function>\n </File.Source>\n )\n}\n\nconst defaultTemplates = {\n default: Template,\n} as const\n\ntype Props = {\n factory: {\n name: string\n }\n dataReturnType: NonNullable<PluginSwr['options']['dataReturnType']>\n /**\n * This will make it possible to override the default behaviour.\n */\n Template?: React.ComponentType<TemplateProps>\n}\n\nexport function QueryOptions({ factory, dataReturnType, Template = defaultTemplates.default }: Props): ReactNode {\n const {\n pluginManager,\n plugin: {\n key: pluginKey,\n options: { parser },\n },\n } = useApp<PluginSwr>()\n const { getSchemas } = 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 name = pluginManager.resolveName({\n name: `${factory.name}QueryOptions`,\n pluginKey,\n })\n const contentType = operation.getContentType()\n\n const generics = new FunctionParams()\n const params = new FunctionParams()\n\n const clientGenerics = ['TData', `${factory.name}['error']`]\n const resultGenerics = ['TData', `${factory.name}['error']`]\n\n generics.add([{ type: 'TData', default: `${factory.name}['response']` }])\n\n params.add([\n ...getASTParams(schemas.pathParams, { typed: true }),\n {\n name: 'params',\n type: `${factory.name}['queryParams']`,\n enabled: !!schemas.queryParams?.name,\n required: false,\n },\n {\n name: 'headers',\n type: `${factory.name}['headerParams']`,\n enabled: !!schemas.headerParams?.name,\n required: false,\n },\n {\n name: 'options',\n type: `${factory.name}['client']['parameters']`,\n default: '{}',\n },\n ])\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.join(', '),\n contentType,\n }\n\n return (\n <Template\n name={name}\n params={params.toString()}\n generics={generics.toString()}\n returnType={`SWRConfiguration<${resultGenerics.join(', ')}>`}\n client={client}\n dataReturnType={dataReturnType}\n parser={parser === 'zod' ? `${zodSchemas.response.name}.parse` : undefined}\n />\n )\n}\n\nQueryOptions.templates = defaultTemplates\n"],"mappings":";AAAA,OAAO,kBAAkB;AACzB,SAAS,gBAAgB,eAAe;AACxC,SAAS,QAAAA,OAAM,UAAU,UAAAC,eAAc;AACvC,SAAS,gBAAAC,qBAAoB;AAC7B,SAAS,gBAAAC,eAAc,uBAAAC,4BAA2B;AAClD,SAAS,cAAc,mBAAmB;;;ACL1C,SAAS,MAAM,MAAM,cAAc;AAEnC,SAAS,cAAc,2BAA2B;AAClD,SAAS,oBAAoB;AAkCzB,mBAEI,KAFJ;AAxBG,SAAS,WAAW,EAAE,QAAQ,GAAqB;AACxD,QAAM;AAAA,IACJ,QAAQ;AAAA,MACN,SAAS,EAAE,eAAe;AAAA,IAC5B;AAAA,EACF,IAAI,OAAkB;AACtB,QAAM,EAAE,WAAW,IAAI,oBAAoB;AAC3C,QAAM,YAAY,aAAa;AAE/B,QAAM,UAAU,WAAW,WAAW,EAAE,WAAW,CAAC,YAAY,GAAG,MAAM,OAAO,CAAC;AAEjF,QAAM,CAAC,OAAO,QAAQ,UAAU,aAAa,cAAc,eAAe,SAAS,IAAI;AAAA,IACrF,QAAQ,SAAS;AAAA,IACjB,QAAQ,QAAQ,IAAI,CAAC,SAAS,KAAK,IAAI,EAAE,KAAK,KAAK,KAAK;AAAA,IACxD,QAAQ,SAAS,QAAQ;AAAA,IACzB,QAAQ,YAAY,QAAQ;AAAA,IAC5B,QAAQ,aAAa,QAAQ;AAAA,IAC7B,QAAQ,cAAc,QAAQ;AAAA,IAC9B,QAAQ,SAAS;AAAA,EACnB;AAEA,QAAM,aAAa,GAAG,QAAQ,IAAI;AAElC,SACE,iCACE;AAAA,wBAAC,KAAK,QAAL,EAAY,MAAM,YAAY,YAAU,MACvC,8BAAC,QAAK,MAAM,YAAa,2BAAiB,SAAS,KAAK,MAAM,KAAK,QAAQ,KAAI,GACjF;AAAA,IACA,oBAAC,KAAK,QAAL,EAAY,MAAM,QAAQ,MAAM,YAAU,MACzC,8BAAC,QAAK,MAAM,QAAQ,MACjB;AAAA;AAAA,kBAEO,KAAK;AAAA,mBACJ,MAAM;AAAA,qBACJ,QAAQ;AAAA,wBACL,WAAW;AAAA,yBACV,YAAY;AAAA,0BACX,aAAa;AAAA,sBACjB,mBAAmB,SAAS,QAAQ,sBAAsB,UAAU,IAAI;AAAA;AAAA,6CAEjD,UAAU;AAAA,yCACd,UAAU;AAAA;AAAA;AAAA,WAI3C,GACF;AAAA,KACF;AAEJ;;;ADIQ,gBAAAC,MAgKJ,QAAAC,aAhKI;AAdR,SAAS,SAAS,EAAE,MAAM,UAAU,YAAY,QAAQ,OAAO,QAAQ,MAAM,eAAe,GAA6B;AACvH,QAAM,gBAAgB;AAAA,IACpB,YAAY,OAAO,MAAM;AAAA,IACzB;AAAA,IACA,OAAO,kBAAkB,WAAW;AAAA,IACpC,OAAO,WAAW,SAAS;AAAA,IAC3B,OAAO,cAAc,sDAAsD;AAAA,IAC3E;AAAA,EACF,EAAE,OAAO,OAAO;AAEhB,QAAM,wBAAwB,GAAG,aAAa,aAAa,CAAC,CAAC,GAAG,cAAc,KAAK;AAAA,EAAM,aAAa,aAAa,CAAC,CAAC,EAAE,CAAC;AACxH,MAAI,OAAO,iBAAiB;AAC1B,WACE,gBAAAD,KAACE,MAAK,QAAL,EAAY,MAAY,cAAY,MAAC,aAAW,MAC/C,0BAAAF,KAAC,YAAS,QAAM,MAAC,MAAY,UAAoB,YAAwB,QAAgB,OACtF;AAAA;AAAA;AAAA,uBAGY,OAAO,KAAK,QAAQ;AAAA,kBACzB,KAAK,IAAI,IAAI,KAAK,QAAQ;AAAA;AAAA,uBAErB,OAAO,WAAW,oBAAoB,EAAE;AAAA,uCACxB,OAAO,QAAQ;AAAA,gBACtC,qBAAqB;AAAA;AAAA;AAAA,qBAGhB,mBAAmB,SAAS,aAAa,KAAK;AAAA;AAAA;AAAA;AAAA,SAK3D,GACF;AAAA,EAEJ;AAEA,SACE,gBAAAA,KAACE,MAAK,QAAL,EAAY,MAAY,cAAY,MAAC,aAAW,MAC/C,0BAAAF,KAAC,YAAS,QAAM,MAAC,MAAY,UAAoB,YAAwB,QAAgB,OACtF;AAAA;AAAA;AAAA,qBAGY,OAAO,KAAK,QAAQ;AAAA,gBACzB,KAAK,IAAI,IAAI,KAAK,QAAQ;AAAA;AAAA,qBAErB,OAAO,WAAW,oBAAoB,EAAE;AAAA,qCACxB,OAAO,QAAQ;AAAA,cACtC,qBAAqB;AAAA;AAAA;AAAA,mBAGhB,mBAAmB,SAAS,aAAa,KAAK;AAAA;AAAA;AAAA;AAAA,OAK3D,GACF;AAEJ;AAEA,IAAM,mBAAmB;AAAA,EACvB,SAAS;AACX;AAYO,SAAS,SAAS,EAAE,SAAS,UAAAG,YAAW,iBAAiB,QAAQ,GAAqB;AAC3F,QAAM;AAAA,IACJ,QAAQ;AAAA,MACN,SAAS,EAAE,eAAe;AAAA,IAC5B;AAAA,EACF,IAAIC,QAAkB;AACtB,QAAM,EAAE,YAAY,QAAQ,IAAIC,qBAAoB;AACpD,QAAM,YAAYC,cAAa;AAE/B,QAAM,OAAO,QAAQ,WAAW,EAAE,MAAM,WAAW,CAAC;AACpD,QAAM,UAAU,WAAW,WAAW,EAAE,WAAW,CAACC,aAAY,GAAG,MAAM,OAAO,CAAC;AAEjF,QAAM,SAAS,IAAI,eAAe;AAClC,QAAM,SAAS;AAAA,IACb,QAAQ,UAAU;AAAA,IAClB,MAAM,IAAI,QAAQ,UAAU,IAAI;AAAA,IAChC,UAAU,CAAC,GAAG,QAAQ,IAAI,YAAY,GAAG,QAAQ,IAAI,aAAa,QAAQ,SAAS,OAAO,GAAG,QAAQ,IAAI,gBAAgB,EAAE,EAAE,OAAO,OAAO,EAAE,KAAK,IAAI;AAAA,IACtJ,iBAAiB,CAAC,CAAC,QAAQ,aAAa;AAAA,IACxC,UAAU,CAAC,CAAC,QAAQ,SAAS;AAAA,IAC7B,gBAAgB,CAAC,CAAC,QAAQ,YAAY;AAAA,IACtC,aAAa,CAAC,CAAC,QAAQ,cAAc;AAAA,EACvC;AAEA,QAAM,iBAAiB,CAAC,GAAG,QAAQ,IAAI,gBAAgB,GAAG,QAAQ,IAAI,WAAW;AAEjF,SAAO,IAAI;AAAA,IACT,GAAG,aAAa,QAAQ,YAAY,EAAE,OAAO,KAAK,CAAC;AAAA,IACnD;AAAA,MACE,MAAM;AAAA,MACN,MAAM,GAAG,QAAQ,IAAI;AAAA,MACrB,SAAS,OAAO;AAAA,MAChB,UAAU;AAAA,IACZ;AAAA,IACA;AAAA,MACE,MAAM;AAAA,MACN,MAAM,GAAG,QAAQ,IAAI;AAAA,MACrB,SAAS,OAAO;AAAA,MAChB,UAAU;AAAA,IACZ;AAAA,IACA;AAAA,MACE,MAAM;AAAA,MACN,UAAU;AAAA,MACV,MAAM;AAAA,8CACkC,eAAe,KAAK,IAAI,CAAC;AAAA,mBACpD,QAAQ,IAAI;AAAA;AAAA;AAAA,MAGzB,SAAS;AAAA,IACX;AAAA,EACF,CAAC;AAED,QAAM,OAAO;AAAA,IACX,MAAM;AAAA,IACN,UAAU,CAAC,GAAG,gBAAgB,OAAO,kBAAkB,uCAAuC,mBAAmB,EAAE,KAAK,IAAI;AAAA,EAC9H;AAEA,SACE,gBAAAP;AAAA,IAACG;AAAA,IAAA;AAAA,MACC;AAAA,MACA,OAAO,EAAE,UAAU,YAAY,SAAS,EAAE;AAAA,MAC1C;AAAA,MACA;AAAA,MACA,QAAQ,OAAO,SAAS;AAAA,MACxB,YAAY,uBAAuB,eAAe,KAAK,IAAI,CAAC;AAAA,MAC5D;AAAA;AAAA,EACF;AAEJ;AASA,SAAS,OAAO,SAAU,EAAE,YAAY,iBAAiB,GAAyB;AAChF,QAAM;AAAA,IACJ,QAAQ;AAAA,MACN,SAAS;AAAA,QACP;AAAA,QACA,QAAQ,EAAE,WAAW;AAAA,MACvB;AAAA,IACF;AAAA,EACF,IAAIC,QAAkB;AAEtB,QAAM,EAAE,YAAY,SAAS,QAAQ,IAAIC,qBAAoB;AAC7D,QAAM,YAAYC,cAAa;AAE/B,QAAM,UAAU,WAAW,WAAW,EAAE,WAAW,CAACC,aAAY,GAAG,MAAM,OAAO,CAAC;AACjF,QAAM,OAAO,QAAQ,SAAS;AAC9B,QAAM,WAAW,QAAQ,WAAW,EAAE,WAAW,CAACA,aAAY,EAAE,CAAC;AACjE,QAAM,cAAc,QAAQ,WAAW,EAAE,MAAM,OAAO,CAAC;AAEvD,QAAMJ,YAAW,UAAU;AAC3B,QAAM,UAAU;AAAA,IACd,MAAM;AAAA,EACR;AAEA,SACE,gBAAAF,MAACC,OAAA,EAAe,UAAU,KAAK,UAAU,MAAM,KAAK,MAAM,MAAM,KAAK,MACnE;AAAA,oBAAAF,KAACE,MAAK,QAAL,EAAY,MAAK,kBAAiB,MAAK,gBAAe;AAAA,IACvD,gBAAAF,KAACE,MAAK,QAAL,EAAY,MAAM,CAAC,4BAA4B,qBAAqB,GAAG,MAAK,gBAAe,YAAU,MAAC;AAAA,IACvG,gBAAAF,KAACE,MAAK,QAAL,EAAY,MAAM,UAAU,MAAM,YAAY;AAAA,IAC/C,gBAAAF,KAACE,MAAK,QAAL,EAAY,MAAM,CAAC,gBAAgB,GAAG,MAAM,YAAY,YAAU,MAAC;AAAA,IACpE,gBAAAF;AAAA,MAACE,MAAK;AAAA,MAAL;AAAA,QACC,MAAM;AAAA,UACJ,QAAQ,SAAS;AAAA,UACjB,QAAQ,SAAS;AAAA,UACjB,QAAQ,YAAY;AAAA,UACpB,QAAQ,aAAa;AAAA,UACrB,QAAQ,cAAc;AAAA,UACtB,GAAI,QAAQ,QAAQ,IAAI,CAAC,UAAU,MAAM,IAAI,KAAK,CAAC;AAAA,QACrD,EAAE,OAAO,OAAO;AAAA,QAChB,MAAM,KAAK;AAAA,QACX,MAAM,SAAS;AAAA,QACf,YAAU;AAAA;AAAA,IACZ;AAAA,IAEA,gBAAAF,KAAC,cAAW,SAAkB;AAAA,IAC9B,gBAAAA,KAAC,YAAS,UAAUG,WAAU,SAAkB;AAAA,KAClD;AAEJ;AAEA,SAAS,YAAY;;;AE3PrB,SAAS,kBAAAK,iBAAgB,WAAAC,gBAAe;AACxC,SAAS,gBAAAC,eAAc,uBAAAC,4BAA2B;AAClD,SAAS,gBAAAC,eAAc,eAAAC,oBAAmB;AAC1C,SAAS,gBAAAC,qBAAoB;AAC7B,SAAS,iBAAAC,sBAAqB;AAC9B,SAAS,QAAAC,OAAM,YAAAC,WAAU,UAAAC,eAAc;;;ACLvC,OAAOC,mBAAkB;AACzB,SAAS,kBAAAC,iBAAgB,WAAAC,gBAAe;AACxC,SAAS,gBAAAC,eAAc,uBAAAC,4BAA2B;AAClD,SAAS,gBAAAC,qBAAoB;AAC7B,SAAS,YAAAC,WAAU,QAAAC,OAAM,UAAAC,eAAc;AACvC,SAAS,qBAAqB;AAK9B,SAAS,gBAAAC,qBAAoB;AAkFvB,gBAAAC,YAAA;AA3CN,SAASC,UAAS,EAAE,MAAM,QAAQ,UAAU,YAAY,OAAO,QAAQ,gBAAgB,OAAO,GAA6B;AACzH,QAAM,aAAa,OAAO,gBAAgB;AAC1C,QAAM,UAAU;AAAA,IACd,OAAO,gBAAgB,qBAAqB,oBAAoB,OAAO,WAAW,MAAM;AAAA,IACxF,OAAO,cAAc,eAAe;AAAA,EACtC,EACG,OAAO,OAAO,EACd,KAAK,IAAI;AAEZ,QAAM,gBAAgB;AAAA,IACpB,YAAY,OAAO,MAAM;AAAA,IACzB,QAAQ,OAAO,KAAK,QAAQ;AAAA,IAC5B,OAAO,kBAAkB,WAAW;AAAA,IACpC,OAAO,YAAY,CAAC,aAAa,SAAS;AAAA,IAC1C,OAAO,YAAY,aAAa,mBAAmB;AAAA,IACnD,QAAQ,SAAS,cAAc,OAAO,2BAA2B;AAAA,IACjE;AAAA,EACF,EAAE,OAAO,OAAO;AAEhB,QAAM,wBAAwB,GAAGX,cAAa,aAAa,CAAC,CAAC,GAAG,cAAc,KAAK;AAAA,EAAMA,cAAa,aAAa,CAAC,CAAC,EAAE,CAAC;AAExH,MAAI,YAAY,SAAS,UAAU,MAAM,eAAe;AAExD,MAAI,mBAAmB,QAAQ;AAC7B,gBAAY,SAAS,yBAAyB,MAAM,gBAAgB;AAAA,EACtE;AAEA,QAAM,WAAW,aACb;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,MAWA;AAEJ,SACE,gBAAAU,KAACH,MAAK,QAAL,EAAY,MAAY,cAAY,MAAC,aAAW,MAC/C,0BAAAG,KAACJ,WAAA,EAAS,MAAY,QAAM,MAAC,UAAoB,YAAwB,QAAgB,OACtF;AAAA;AAAA;AAAA,YAGG,YAAY,EAAE;AAAA,qCACW,OAAO,QAAQ;AAAA,cACtC,qBAAqB;AAAA;AAAA;AAAA,WAGxB,SAAS;AAAA;AAAA;AAAA;AAAA,UAKd,GACF;AAEJ;AAEA,IAAMM,oBAAmB;AAAA,EACvB,SAASD;AACX;AAaO,SAAS,aAAa,EAAE,SAAS,gBAAgB,UAAAA,YAAWC,kBAAiB,QAAQ,GAAqB;AAC/G,QAAM;AAAA,IACJ;AAAA,IACA,QAAQ;AAAA,MACN,KAAK;AAAA,MACL,SAAS,EAAE,OAAO;AAAA,IACpB;AAAA,EACF,IAAIJ,QAAkB;AACtB,QAAM,EAAE,WAAW,IAAIJ,qBAAoB;AAC3C,QAAM,YAAYD,cAAa;AAE/B,QAAM,UAAU,WAAW,WAAW,EAAE,WAAW,CAACM,aAAY,GAAG,MAAM,OAAO,CAAC;AACjF,QAAM,aAAa,WAAW,WAAW,EAAE,WAAW,CAAC,aAAa,GAAG,MAAM,WAAW,CAAC;AACzF,QAAM,OAAO,cAAc,YAAY;AAAA,IACrC,MAAM,GAAG,QAAQ,IAAI;AAAA,IACrB;AAAA,EACF,CAAC;AACD,QAAM,cAAc,UAAU,eAAe;AAE7C,QAAM,WAAW,IAAIR,gBAAe;AACpC,QAAM,SAAS,IAAIA,gBAAe;AAElC,QAAM,iBAAiB,CAAC,SAAS,GAAG,QAAQ,IAAI,WAAW;AAC3D,QAAM,iBAAiB,CAAC,SAAS,GAAG,QAAQ,IAAI,WAAW;AAE3D,WAAS,IAAI,CAAC,EAAE,MAAM,SAAS,SAAS,GAAG,QAAQ,IAAI,eAAe,CAAC,CAAC;AAExE,SAAO,IAAI;AAAA,IACT,GAAGI,cAAa,QAAQ,YAAY,EAAE,OAAO,KAAK,CAAC;AAAA,IACnD;AAAA,MACE,MAAM;AAAA,MACN,MAAM,GAAG,QAAQ,IAAI;AAAA,MACrB,SAAS,CAAC,CAAC,QAAQ,aAAa;AAAA,MAChC,UAAU;AAAA,IACZ;AAAA,IACA;AAAA,MACE,MAAM;AAAA,MACN,MAAM,GAAG,QAAQ,IAAI;AAAA,MACrB,SAAS,CAAC,CAAC,QAAQ,cAAc;AAAA,MACjC,UAAU;AAAA,IACZ;AAAA,IACA;AAAA,MACE,MAAM;AAAA,MACN,MAAM,GAAG,QAAQ,IAAI;AAAA,MACrB,SAAS;AAAA,IACX;AAAA,EACF,CAAC;AAED,QAAM,SAAS;AAAA,IACb,iBAAiB,CAAC,CAAC,QAAQ,aAAa;AAAA,IACxC,UAAU,CAAC,CAAC,QAAQ,SAAS;AAAA,IAC7B,gBAAgB,CAAC,CAAC,QAAQ,YAAY;AAAA,IACtC,aAAa,CAAC,CAAC,QAAQ,cAAc;AAAA,IACrC,QAAQ,UAAU;AAAA,IAClB,MAAM,IAAIH,SAAQ,UAAU,IAAI;AAAA,IAChC,UAAU,eAAe,KAAK,IAAI;AAAA,IAClC;AAAA,EACF;AAEA,SACE,gBAAAQ;AAAA,IAACC;AAAA,IAAA;AAAA,MACC;AAAA,MACA,QAAQ,OAAO,SAAS;AAAA,MACxB,UAAU,SAAS,SAAS;AAAA,MAC5B,YAAY,oBAAoB,eAAe,KAAK,IAAI,CAAC;AAAA,MACzD;AAAA,MACA;AAAA,MACA,QAAQ,WAAW,QAAQ,GAAG,WAAW,SAAS,IAAI,WAAW;AAAA;AAAA,EACnE;AAEJ;AAEA,aAAa,YAAYC;;;ADnJjB,SAsJJ,YAAAC,WAtJI,OAAAC,MAsJJ,QAAAC,aAtJI;AAJR,SAASC,UAAS,EAAE,MAAM,UAAU,YAAY,QAAQ,OAAO,MAAM,OAAO,GAA6B;AACvG,MAAI,OAAO,iBAAiB;AAC1B,WACE,gBAAAF,KAACG,MAAK,QAAL,EAAY,MAAY,cAAY,MAAC,aAAW,MAC/C,0BAAAH,KAACI,WAAA,EAAS,MAAY,QAAM,MAAC,UAAoB,YAAwB,QAAgB,OACtF;AAAA;AAAA;AAAA,uBAGY,OAAO,KAAK,QAAQ;AAAA,yBAClB,KAAK,IAAI,IAAI,KAAK,QAAQ;AAAA;AAAA;AAAA,iBAGlC,KAAK,YAAY;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,YAO1B,GACF;AAAA,EAEJ;AAEA,SACE,gBAAAJ,KAACG,MAAK,QAAL,EAAY,MAAY,cAAY,MAAC,aAAW,MAC/C,0BAAAH,KAACI,WAAA,EAAS,MAAY,QAAM,MAAC,UAAoB,YAAwB,QAAgB,OACtF;AAAA;AAAA;AAAA,qBAGY,OAAO,KAAK,QAAQ;AAAA,uBAClB,KAAK,IAAI,IAAI,KAAK,QAAQ;AAAA;AAAA;AAAA,eAGlC,KAAK,YAAY;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,UAO1B,GACF;AAEJ;AAEA,IAAMC,oBAAmB;AAAA,EACvB,SAASH;AACX;AAgBO,SAAS,MAAM,EAAE,SAAS,UAAAA,YAAWG,kBAAiB,SAAS,uBAAuB,aAAa,UAAU,QAAQ,GAAqB;AAC/I,QAAM;AAAA,IACJ;AAAA,IACA,QAAQ;AAAA,MACN,KAAK;AAAA,MACL,SAAS,EAAE,eAAe;AAAA,IAC5B;AAAA,EACF,IAAIC,QAAkB;AAEtB,QAAM,YAAYC,cAAa;AAC/B,QAAM,EAAE,YAAY,QAAQ,IAAIC,qBAAoB;AAEpD,QAAM,UAAU,WAAW,WAAW,EAAE,WAAW,CAACC,aAAY,GAAG,MAAM,OAAO,CAAC;AACjF,QAAM,aAAa,WAAW,WAAW,EAAE,WAAW,CAACC,cAAa,GAAG,MAAM,WAAW,CAAC;AAEzF,QAAM,OAAO,QAAQ,WAAW,EAAE,MAAM,WAAW,CAAC;AAEpD,QAAM,mBAAmB,cAAc,YAAY;AAAA,IACjD,MAAM,GAAG,QAAQ,IAAI;AAAA,IACrB;AAAA,EACF,CAAC;AACD,QAAM,WAAW,IAAIC,gBAAe;AACpC,QAAM,SAAS,IAAIA,gBAAe;AAClC,QAAM,cAAc,IAAIA,gBAAe;AACvC,QAAM,SAAS;AAAA,IACb,QAAQ,UAAU;AAAA,IAClB,MAAM,IAAIC,SAAQ,UAAU,IAAI;AAAA,IAChC,iBAAiB,CAAC,CAAC,QAAQ,aAAa;AAAA,IACxC,UAAU,CAAC,CAAC,QAAQ,SAAS;AAAA,IAC7B,gBAAgB,CAAC,CAAC,QAAQ,YAAY;AAAA,IACtC,aAAa,CAAC,CAAC,QAAQ,cAAc;AAAA,EACvC;AAEA,QAAM,iBAAiB,CAAC,SAAS,GAAG,QAAQ,IAAI,WAAW;AAE3D,WAAS,IAAI,CAAC,EAAE,MAAM,SAAS,SAAS,GAAG,QAAQ,IAAI,eAAe,CAAC,CAAC;AAExE,QAAM,uBAAuB,CAAC,OAAO;AAErC,SAAO,IAAI;AAAA,IACT,GAAGC,cAAa,QAAQ,YAAY,EAAE,OAAO,KAAK,CAAC;AAAA,IACnD;AAAA,MACE,MAAM;AAAA,MACN,MAAM,GAAG,QAAQ,IAAI;AAAA,MACrB,SAAS,OAAO;AAAA,MAChB,UAAU;AAAA,IACZ;AAAA,IACA;AAAA,MACE,MAAM;AAAA,MACN,MAAM,GAAG,QAAQ,IAAI;AAAA,MACrB,SAAS,OAAO;AAAA,MAChB,UAAU;AAAA,IACZ;AAAA,IACA;AAAA,MACE,MAAM;AAAA,MACN,UAAU;AAAA,MACV,MAAM;AAAA,mCACuB,eAAe,KAAK,IAAI,CAAC;AAAA,mBACzC,QAAQ,IAAI;AAAA;AAAA;AAAA,MAGzB,SAAS;AAAA,IACX;AAAA,EACF,CAAC;AAED,cAAY,IAAI;AAAA,IACd,GAAGA,cAAa,QAAQ,YAAY,EAAE,OAAO,MAAM,CAAC;AAAA,IACpD;AAAA,MACE,MAAM;AAAA,MACN,SAAS,OAAO;AAAA,MAChB,UAAU;AAAA,IACZ;AAAA,IACA;AAAA,MACE,MAAM;AAAA,MACN,SAAS,OAAO;AAAA,MAChB,UAAU;AAAA,IACZ;AAAA,IACA;AAAA,MACE,MAAM;AAAA,MACN,UAAU;AAAA,IACZ;AAAA,EACF,CAAC;AAED,QAAM,OAAO;AAAA,IACX,MAAM;AAAA,IACN,UAAU,CAAC,GAAG,gBAAgB,OAAO,kBAAkB,uCAAuC,mBAAmB,EAAE,KAAK,IAAI;AAAA,IAC5H,cAAc,GAAG,gBAAgB,IAAI,qBAAqB,KAAK,IAAI,CAAC,KAAK,YAAY,SAAS,CAAC;AAAA,EACjG;AAEA,SACE,gBAAAZ,MAAAF,WAAA,EACE;AAAA,oBAAAC,KAAC,gBAAa,SAAkB,UAAU,sBAAsB,gBAAgC;AAAA,IAChG,gBAAAA;AAAA,MAACE;AAAA,MAAA;AAAA,QACC;AAAA,QACA,UAAU,SAAS,SAAS;AAAA,QAC5B,OAAO,EAAE,UAAUY,aAAY,SAAS,EAAE;AAAA,QAC1C;AAAA,QACA;AAAA,QACA,QAAQ,OAAO,SAAS;AAAA,QACxB,YAAY,eAAe,eAAe,KAAK,IAAI,CAAC;AAAA;AAAA,IACtD;AAAA,KACF;AAEJ;AAYA,MAAM,OAAO,SAAU,EAAE,UAAU,GAAyB;AAC1D,QAAM;AAAA,IACJ;AAAA,IACA,QAAQ;AAAA,MACN,SAAS;AAAA,QACP;AAAA,QACA,QAAQ,EAAE,WAAW;AAAA,QACrB;AAAA,MACF;AAAA,IACF;AAAA,EACF,IAAIR,QAAkB;AACtB,QAAM,EAAE,YAAY,SAAS,QAAQ,IAAIE,qBAAoB;AAC7D,QAAM,YAAYD,cAAa;AAE/B,QAAM,OAAO,QAAQ,SAAS;AAC9B,QAAM,UAAU,WAAW,WAAW,EAAE,WAAW,CAACE,aAAY,GAAG,MAAM,OAAO,CAAC;AACjF,QAAM,aAAa,WAAW,WAAW,EAAE,WAAW,CAACC,cAAa,GAAG,MAAM,WAAW,CAAC;AACzF,QAAM,WAAW,QAAQ,WAAW,EAAE,WAAW,CAACD,aAAY,EAAE,CAAC;AACjE,QAAM,iBAAiB,QAAQ,WAAW;AAAA,IACxC,WAAW,CAACC,cAAa;AAAA,EAC3B,CAAC;AAED,QAAM,cAAc,QAAQ,WAAW,EAAE,MAAM,OAAO,CAAC;AAEvD,QAAMR,YAAW,WAAW,MAAM,WAAWG,kBAAiB;AAC9D,QAAM,uBAAuB,WAAW,aAAa,WAAW,aAAa,UAAU;AACvF,QAAM,UAAU;AAAA,IACd,MAAM;AAAA,EACR;AAEA,SACE,gBAAAJ,MAACE,OAAA,EAAe,UAAU,KAAK,UAAU,MAAM,KAAK,MAAM,MAAM,KAAK,MAClE;AAAA,eAAW,SAAS,gBAAAH,KAACG,MAAK,QAAL,EAAY,MAAM,CAAC,WAAW,SAAS,IAAI,GAAG,MAAM,KAAK,MAAM,MAAM,eAAe,MAAM;AAAA,IAChH,gBAAAH,KAACG,MAAK,QAAL,EAAY,MAAK,UAAS,MAAK,OAAM;AAAA,IACtC,gBAAAH,KAACG,MAAK,QAAL,EAAY,MAAM,CAAC,oBAAoB,aAAa,GAAG,MAAK,OAAM,YAAU,MAAC;AAAA,IAC9E,gBAAAH,KAACG,MAAK,QAAL,EAAY,MAAM,UAAU,MAAM,YAAY;AAAA,IAC/C,gBAAAH,KAACG,MAAK,QAAL,EAAY,MAAM,CAAC,gBAAgB,GAAG,MAAM,YAAY,YAAU,MAAC;AAAA,IACpE,gBAAAH;AAAA,MAACG,MAAK;AAAA,MAAL;AAAA,QACC,MAAM;AAAA,UACJ,QAAQ,SAAS;AAAA,UACjB,QAAQ,SAAS;AAAA,UACjB,QAAQ,YAAY;AAAA,UACpB,QAAQ,aAAa;AAAA,UACrB,QAAQ,cAAc;AAAA,UACtB,GAAI,QAAQ,aAAa,IAAI,CAAC,SAAS,KAAK,IAAI,KAAK,CAAC;AAAA,QACxD,EAAE,OAAO,OAAO;AAAA,QAChB,MAAM,KAAK;AAAA,QACX,MAAM,SAAS;AAAA,QACf,YAAU;AAAA;AAAA,IACZ;AAAA,IAEA,gBAAAH,KAAC,cAAW,SAAkB;AAAA,IAC9B,gBAAAA,KAAC,SAAM,SAAkB,UAAUE,WAAU,sBAA4C;AAAA,KAC3F;AAEJ;AAEA,MAAM,YAAYG;","names":["File","useApp","pluginTsName","useOperation","useOperationManager","jsx","jsxs","File","Template","useApp","useOperationManager","useOperation","pluginTsName","FunctionParams","URLPath","useOperation","useOperationManager","getASTParams","getComments","pluginTsName","pluginZodName","File","Function","useApp","transformers","FunctionParams","URLPath","useOperation","useOperationManager","getASTParams","Function","File","useApp","pluginTsName","jsx","Template","defaultTemplates","Fragment","jsx","jsxs","Template","File","Function","defaultTemplates","useApp","useOperation","useOperationManager","pluginTsName","pluginZodName","FunctionParams","URLPath","getASTParams","getComments"]}
|
package/dist/components.cjs
CHANGED
|
@@ -2,10 +2,10 @@
|
|
|
2
2
|
|
|
3
3
|
|
|
4
4
|
|
|
5
|
-
var
|
|
5
|
+
var _chunkTGLXUPN4cjs = require('./chunk-TGLXUPN4.cjs');
|
|
6
6
|
|
|
7
7
|
|
|
8
8
|
|
|
9
9
|
|
|
10
|
-
exports.Mutation =
|
|
10
|
+
exports.Mutation = _chunkTGLXUPN4cjs.Mutation; exports.Query = _chunkTGLXUPN4cjs.Query; exports.QueryOptions = _chunkTGLXUPN4cjs.QueryOptions;
|
|
11
11
|
//# sourceMappingURL=components.cjs.map
|
package/dist/components.js
CHANGED
package/dist/index.cjs
CHANGED
|
@@ -2,7 +2,7 @@
|
|
|
2
2
|
|
|
3
3
|
|
|
4
4
|
|
|
5
|
-
var
|
|
5
|
+
var _chunkTGLXUPN4cjs = require('./chunk-TGLXUPN4.cjs');
|
|
6
6
|
|
|
7
7
|
// src/plugin.ts
|
|
8
8
|
var _path = require('path'); var _path2 = _interopRequireDefault(_path);
|
|
@@ -29,7 +29,7 @@ var OperationGenerator = class extends _pluginoas.OperationGenerator {
|
|
|
29
29
|
}
|
|
30
30
|
root.render(
|
|
31
31
|
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _react.App, { pluginManager, plugin: { ...plugin, options }, mode, children: /* @__PURE__ */ _jsxruntime.jsx.call(void 0, _components.Oas, { oas, operations: [operation], generator: this, children: /* @__PURE__ */ _jsxruntime.jsx.call(void 0, _components.Oas.Operation, { operation, children: /* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
32
|
-
|
|
32
|
+
_chunkTGLXUPN4cjs.Query.File,
|
|
33
33
|
{
|
|
34
34
|
templates: {
|
|
35
35
|
query: options.templates.query,
|
|
@@ -49,7 +49,7 @@ var OperationGenerator = class extends _pluginoas.OperationGenerator {
|
|
|
49
49
|
return [];
|
|
50
50
|
}
|
|
51
51
|
root.render(
|
|
52
|
-
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _react.App, { pluginManager, plugin: { ...plugin, options }, mode, children: /* @__PURE__ */ _jsxruntime.jsx.call(void 0, _components.Oas, { oas, operations: [operation], generator: this, children: /* @__PURE__ */ _jsxruntime.jsx.call(void 0, _components.Oas.Operation, { operation, children: /* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
52
|
+
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _react.App, { pluginManager, plugin: { ...plugin, options }, mode, children: /* @__PURE__ */ _jsxruntime.jsx.call(void 0, _components.Oas, { oas, operations: [operation], generator: this, children: /* @__PURE__ */ _jsxruntime.jsx.call(void 0, _components.Oas.Operation, { operation, children: /* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkTGLXUPN4cjs.Mutation.File, { templates: options.templates.mutation }) }) }) })
|
|
53
53
|
);
|
|
54
54
|
return root.files;
|
|
55
55
|
}
|
|
@@ -78,9 +78,9 @@ var pluginSwr = _core.createPlugin.call(void 0, (options) => {
|
|
|
78
78
|
options: {
|
|
79
79
|
extName: output.extName,
|
|
80
80
|
templates: {
|
|
81
|
-
mutation:
|
|
82
|
-
query:
|
|
83
|
-
queryOptions:
|
|
81
|
+
mutation: _chunkTGLXUPN4cjs.Mutation.templates,
|
|
82
|
+
query: _chunkTGLXUPN4cjs.Query.templates,
|
|
83
|
+
queryOptions: _chunkTGLXUPN4cjs.QueryOptions.templates,
|
|
84
84
|
...templates
|
|
85
85
|
},
|
|
86
86
|
client: {
|
package/dist/index.js
CHANGED
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@kubb/plugin-swr",
|
|
3
|
-
"version": "3.0.0-alpha.
|
|
3
|
+
"version": "3.0.0-alpha.8",
|
|
4
4
|
"description": "Generator plugin-swr",
|
|
5
5
|
"keywords": [
|
|
6
6
|
"typescript",
|
|
@@ -55,27 +55,27 @@
|
|
|
55
55
|
"!/**/__tests__/**"
|
|
56
56
|
],
|
|
57
57
|
"dependencies": {
|
|
58
|
-
"@kubb/core": "3.0.0-alpha.
|
|
59
|
-
"@kubb/fs": "3.0.0-alpha.
|
|
60
|
-
"@kubb/oas": "3.0.0-alpha.
|
|
61
|
-
"@kubb/parser-ts": "3.0.0-alpha.
|
|
62
|
-
"@kubb/plugin-client": "3.0.0-alpha.
|
|
63
|
-
"@kubb/plugin-oas": "3.0.0-alpha.
|
|
64
|
-
"@kubb/plugin-ts": "3.0.0-alpha.
|
|
65
|
-
"@kubb/plugin-zod": "3.0.0-alpha.
|
|
66
|
-
"@kubb/react": "3.0.0-alpha.
|
|
58
|
+
"@kubb/core": "3.0.0-alpha.8",
|
|
59
|
+
"@kubb/fs": "3.0.0-alpha.8",
|
|
60
|
+
"@kubb/oas": "3.0.0-alpha.8",
|
|
61
|
+
"@kubb/parser-ts": "3.0.0-alpha.8",
|
|
62
|
+
"@kubb/plugin-client": "3.0.0-alpha.8",
|
|
63
|
+
"@kubb/plugin-oas": "3.0.0-alpha.8",
|
|
64
|
+
"@kubb/plugin-ts": "3.0.0-alpha.8",
|
|
65
|
+
"@kubb/plugin-zod": "3.0.0-alpha.8",
|
|
66
|
+
"@kubb/react": "3.0.0-alpha.8"
|
|
67
67
|
},
|
|
68
68
|
"devDependencies": {
|
|
69
69
|
"@types/react": "^18.3.4",
|
|
70
70
|
"react": "^18.3.1",
|
|
71
71
|
"tsup": "^8.2.4",
|
|
72
72
|
"typescript": "^5.5.4",
|
|
73
|
-
"@kubb/config-biome": "3.0.0-alpha.
|
|
74
|
-
"@kubb/config-ts": "3.0.0-alpha.
|
|
75
|
-
"@kubb/config-tsup": "3.0.0-alpha.
|
|
73
|
+
"@kubb/config-biome": "3.0.0-alpha.8",
|
|
74
|
+
"@kubb/config-ts": "3.0.0-alpha.8",
|
|
75
|
+
"@kubb/config-tsup": "3.0.0-alpha.8"
|
|
76
76
|
},
|
|
77
77
|
"peerDependencies": {
|
|
78
|
-
"@kubb/react": "3.0.0-alpha.
|
|
78
|
+
"@kubb/react": "3.0.0-alpha.8"
|
|
79
79
|
},
|
|
80
80
|
"engines": {
|
|
81
81
|
"node": ">=20"
|
|
@@ -63,7 +63,7 @@ function Template({ name, generics, returnType, params, JSDoc, client, hook, dat
|
|
|
63
63
|
const resolvedClientOptions = `${transformers.createIndent(4)}${clientOptions.join(`,\n${transformers.createIndent(4)}`)}`
|
|
64
64
|
if (client.withQueryParams) {
|
|
65
65
|
return (
|
|
66
|
-
<File.Source name={name} isExportable>
|
|
66
|
+
<File.Source name={name} isExportable isIndexable>
|
|
67
67
|
<Function export name={name} generics={generics} returnType={returnType} params={params} JSDoc={JSDoc}>
|
|
68
68
|
{`
|
|
69
69
|
const { mutation: mutationOptions, client: clientOptions = {}, shouldFetch = true } = options ?? {}
|
|
@@ -87,7 +87,7 @@ function Template({ name, generics, returnType, params, JSDoc, client, hook, dat
|
|
|
87
87
|
}
|
|
88
88
|
|
|
89
89
|
return (
|
|
90
|
-
<File.Source name={name} isExportable>
|
|
90
|
+
<File.Source name={name} isExportable isIndexable>
|
|
91
91
|
<Function export name={name} generics={generics} returnType={returnType} params={params} JSDoc={JSDoc}>
|
|
92
92
|
{`
|
|
93
93
|
const { mutation: mutationOptions, client: clientOptions = {}, shouldFetch = true } = options ?? {}
|
package/src/components/Query.tsx
CHANGED
|
@@ -48,7 +48,7 @@ type TemplateProps = {
|
|
|
48
48
|
function Template({ name, generics, returnType, params, JSDoc, hook, client }: TemplateProps): ReactNode {
|
|
49
49
|
if (client.withQueryParams) {
|
|
50
50
|
return (
|
|
51
|
-
<File.Source name={name} isExportable>
|
|
51
|
+
<File.Source name={name} isExportable isIndexable>
|
|
52
52
|
<Function name={name} export generics={generics} returnType={returnType} params={params} JSDoc={JSDoc}>
|
|
53
53
|
{`
|
|
54
54
|
const { query: queryOptions, client: clientOptions = {}, shouldFetch = true } = options ?? {}
|
|
@@ -70,7 +70,7 @@ function Template({ name, generics, returnType, params, JSDoc, hook, client }: T
|
|
|
70
70
|
}
|
|
71
71
|
|
|
72
72
|
return (
|
|
73
|
-
<File.Source name={name} isExportable>
|
|
73
|
+
<File.Source name={name} isExportable isIndexable>
|
|
74
74
|
<Function name={name} export generics={generics} returnType={returnType} params={params} JSDoc={JSDoc}>
|
|
75
75
|
{`
|
|
76
76
|
const { query: queryOptions, client: clientOptions = {}, shouldFetch = true } = options ?? {}
|
|
@@ -89,7 +89,7 @@ function Template({ name, params, generics, returnType, JSDoc, client, dataRetur
|
|
|
89
89
|
: undefined
|
|
90
90
|
|
|
91
91
|
return (
|
|
92
|
-
<File.Source name={name} isExportable>
|
|
92
|
+
<File.Source name={name} isExportable isIndexable>
|
|
93
93
|
<Function name={name} export generics={generics} returnType={returnType} params={params} JSDoc={JSDoc}>
|
|
94
94
|
{`
|
|
95
95
|
return {
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/components/Mutation.tsx","../src/components/SchemaType.tsx","../src/components/Query.tsx","../src/components/QueryOptions.tsx"],"sourcesContent":["import 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 { useOperation, useOperationManager } from '@kubb/plugin-oas/hooks'\nimport { getASTParams, getComments } from '@kubb/plugin-oas/utils'\n\nimport { SchemaType } from './SchemaType.tsx'\n\nimport type { HttpMethod } from '@kubb/oas'\nimport type { ReactNode } from 'react'\nimport type { FileMeta, PluginSwr } 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 }\n client: {\n method: HttpMethod\n generics: string\n withQueryParams: boolean\n withPathParams: boolean\n withData: boolean\n withHeaders: boolean\n path: URLPath\n }\n dataReturnType: NonNullable<PluginSwr['options']['dataReturnType']>\n}\n\nfunction Template({ name, generics, returnType, params, JSDoc, client, hook, dataReturnType }: TemplateProps): ReactNode {\n const clientOptions = [\n `method: \"${client.method}\"`,\n 'url',\n client.withQueryParams ? 'params' : undefined,\n client.withData ? 'data' : undefined,\n client.withHeaders ? 'headers: { ...headers, ...clientOptions.headers }' : undefined,\n '...clientOptions',\n ].filter(Boolean)\n\n const resolvedClientOptions = `${transformers.createIndent(4)}${clientOptions.join(`,\\n${transformers.createIndent(4)}`)}`\n if (client.withQueryParams) {\n return (\n <File.Source name={name} isExportable>\n <Function export name={name} generics={generics} returnType={returnType} params={params} JSDoc={JSDoc}>\n {`\n const { mutation: mutationOptions, client: clientOptions = {}, shouldFetch = true } = options ?? {}\n\n const url = ${client.path.template} as const\n return ${hook.name}<${hook.generics}>(\n shouldFetch ? [url, params]: null,\n async (_url${client.withData ? ', { arg: data }' : ''}) => {\n const res = await client<${client.generics}>({\n ${resolvedClientOptions}\n })\n\n return ${dataReturnType === 'data' ? 'res.data' : 'res'}\n },\n mutationOptions\n )\n `}\n </Function>\n </File.Source>\n )\n }\n\n return (\n <File.Source name={name} isExportable>\n <Function export name={name} generics={generics} returnType={returnType} params={params} JSDoc={JSDoc}>\n {`\n const { mutation: mutationOptions, client: clientOptions = {}, shouldFetch = true } = options ?? {}\n\n const url = ${client.path.template} as const\n return ${hook.name}<${hook.generics}>(\n shouldFetch ? url : null,\n async (_url${client.withData ? ', { arg: data }' : ''}) => {\n const res = await client<${client.generics}>({\n ${resolvedClientOptions}\n })\n\n return ${dataReturnType === 'data' ? 'res.data' : 'res'}\n },\n mutationOptions\n )\n `}\n </Function>\n </File.Source>\n )\n}\n\nconst defaultTemplates = {\n default: Template,\n} as const\n\ntype Props = {\n factory: {\n name: string\n }\n /**\n * This will make it possible to override the default behaviour.\n */\n Template?: React.ComponentType<TemplateProps>\n}\n\nexport function Mutation({ factory, Template = defaultTemplates.default }: Props): ReactNode {\n const {\n plugin: {\n options: { dataReturnType },\n },\n } = useApp<PluginSwr>()\n const { getSchemas, getName } = useOperationManager()\n const operation = useOperation()\n\n const name = getName(operation, { type: 'function' })\n const schemas = getSchemas(operation, { pluginKey: [pluginTsName], type: 'type' })\n\n const params = new FunctionParams()\n const client = {\n method: operation.method,\n path: new URLPath(operation.path),\n generics: [`${factory.name}[\"data\"]`, `${factory.name}[\"error\"]`, schemas.request?.name ? `${factory.name}[\"request\"]` : ''].filter(Boolean).join(', '),\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 = [`${factory.name}[\"response\"]`, `${factory.name}[\"error\"]`]\n\n params.add([\n ...getASTParams(schemas.pathParams, { typed: true }),\n {\n name: 'params',\n type: `${factory.name}['queryParams']`,\n enabled: client.withQueryParams,\n required: false,\n },\n {\n name: 'headers',\n type: `${factory.name}['headerParams']`,\n enabled: client.withHeaders,\n required: false,\n },\n {\n name: 'options',\n required: false,\n type: `{\n mutation?: SWRMutationConfiguration<${resultGenerics.join(', ')}>,\n client?: ${factory.name}['client']['parameters'],\n shouldFetch?: boolean,\n }`,\n default: '{}',\n },\n ])\n\n const hook = {\n name: 'useSWRMutation',\n generics: [...resultGenerics, client.withQueryParams ? '[typeof url, typeof params] | null' : 'typeof url | null'].join(', '),\n }\n\n return (\n <Template\n name={name}\n JSDoc={{ comments: getComments(operation) }}\n client={client}\n hook={hook}\n params={params.toString()}\n returnType={`SWRMutationResponse<${resultGenerics.join(', ')}>`}\n dataReturnType={dataReturnType}\n />\n )\n}\n\ntype FileProps = {\n /**\n * This will make it possible to override the default behaviour.\n */\n templates?: typeof defaultTemplates\n}\n\nMutation.File = function ({ templates = defaultTemplates }: FileProps): ReactNode {\n const {\n plugin: {\n options: {\n extName,\n client: { importPath },\n },\n },\n } = useApp<PluginSwr>()\n\n const { getSchemas, getFile, getName } = 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 const factoryName = getName(operation, { type: 'type' })\n\n const Template = templates.default\n const factory = {\n name: factoryName,\n }\n\n return (\n <File<FileMeta> baseName={file.baseName} path={file.path} meta={file.meta}>\n <File.Import name=\"useSWRMutation\" path=\"swr/mutation\" />\n <File.Import name={['SWRMutationConfiguration', 'SWRMutationResponse']} path=\"swr/mutation\" isTypeOnly />\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 <SchemaType factory={factory} />\n <Mutation Template={Template} factory={factory} />\n </File>\n )\n}\n\nMutation.templates = defaultTemplates\n","import { File, Type, useApp } from '@kubb/react'\n\nimport { useOperation, useOperationManager } from '@kubb/plugin-oas/hooks'\nimport { pluginTsName } from '@kubb/plugin-ts'\nimport type { ReactNode } from 'react'\nimport type { PluginSwr } from '../types.ts'\n\ntype Props = {\n factory: {\n name: string\n }\n}\n\nexport function SchemaType({ factory }: Props): ReactNode {\n const {\n plugin: {\n options: { dataReturnType },\n },\n } = useApp<PluginSwr>()\n const { getSchemas } = 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\n const clientType = `${factory.name}Client`\n\n return (\n <>\n <File.Source name={clientType} isTypeOnly>\n <Type name={clientType}>{`typeof client<${TResponse}, ${TError}, ${TRequest}>`}</Type>\n </File.Source>\n <File.Source name={factory.name} isTypeOnly>\n <Type name={factory.name}>\n {`\n {\n data: ${TData}\n error: ${TError}\n request: ${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 { FunctionParams, URLPath } from '@kubb/core/utils'\nimport { useOperation, useOperationManager } from '@kubb/plugin-oas/hooks'\nimport { getASTParams, getComments } from '@kubb/plugin-oas/utils'\nimport { pluginTsName } from '@kubb/plugin-ts'\nimport { pluginZodName } from '@kubb/plugin-zod'\nimport { File, Function, useApp } from '@kubb/react'\n\nimport { QueryOptions } from './QueryOptions.tsx'\nimport { SchemaType } from './SchemaType.tsx'\n\nimport type { ReactNode } from 'react'\nimport type { FileMeta, PluginSwr } 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 queryOptions: string\n }\n client: {\n path: URLPath\n withQueryParams: boolean\n }\n}\n\nfunction Template({ name, generics, returnType, params, JSDoc, hook, client }: TemplateProps): ReactNode {\n if (client.withQueryParams) {\n return (\n <File.Source name={name} isExportable>\n <Function name={name} export generics={generics} returnType={returnType} params={params} JSDoc={JSDoc}>\n {`\n const { query: queryOptions, client: clientOptions = {}, shouldFetch = true } = options ?? {}\n\n const url = ${client.path.template}\n const query = ${hook.name}<${hook.generics}>(\n shouldFetch ? [url, params]: null,\n {\n ...${hook.queryOptions},\n ...queryOptions\n }\n )\n\n return query\n `}\n </Function>\n </File.Source>\n )\n }\n\n return (\n <File.Source name={name} isExportable>\n <Function name={name} export generics={generics} returnType={returnType} params={params} JSDoc={JSDoc}>\n {`\n const { query: queryOptions, client: clientOptions = {}, shouldFetch = true } = options ?? {}\n\n const url = ${client.path.template}\n const query = ${hook.name}<${hook.generics}>(\n shouldFetch ? url : null,\n {\n ...${hook.queryOptions},\n ...queryOptions\n }\n )\n\n return query\n `}\n </Function>\n </File.Source>\n )\n}\n\nconst defaultTemplates = {\n default: Template,\n} as const\n\ntype Props = {\n factory: {\n name: string\n }\n /**\n * This will make it possible to override the default behaviour.\n */\n Template?: React.ComponentType<TemplateProps>\n /**\n * This will make it possible to override the default behaviour.\n */\n QueryOptionsTemplate?: React.ComponentType<React.ComponentProps<typeof QueryOptions.templates.default>>\n}\n\nexport function Query({ factory, Template = defaultTemplates.default, QueryOptionsTemplate = QueryOptions.templates.default }: Props): ReactNode {\n const {\n pluginManager,\n plugin: {\n key: pluginKey,\n options: { dataReturnType },\n },\n } = useApp<PluginSwr>()\n\n const operation = useOperation()\n const { getSchemas, getName } = useOperationManager()\n\n const schemas = getSchemas(operation, { pluginKey: [pluginTsName], type: 'type' })\n const zodSchemas = getSchemas(operation, { pluginKey: [pluginZodName], type: 'function' })\n\n const name = getName(operation, { type: 'function' })\n\n const queryOptionsName = pluginManager.resolveName({\n name: `${factory.name}QueryOptions`,\n pluginKey,\n })\n const generics = new FunctionParams()\n const params = new FunctionParams()\n const queryParams = new FunctionParams()\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 const resultGenerics = ['TData', `${factory.name}[\"error\"]`]\n\n generics.add([{ type: 'TData', default: `${factory.name}[\"response\"]` }])\n\n const queryOptionsGenerics = ['TData']\n\n params.add([\n ...getASTParams(schemas.pathParams, { typed: true }),\n {\n name: 'params',\n type: `${factory.name}['queryParams']`,\n enabled: client.withQueryParams,\n required: false,\n },\n {\n name: 'headers',\n type: `${factory.name}['headerParams']`,\n enabled: client.withHeaders,\n required: false,\n },\n {\n name: 'options',\n required: false,\n type: `{\n query?: SWRConfiguration<${resultGenerics.join(', ')}>,\n client?: ${factory.name}['client']['parameters'],\n shouldFetch?: boolean,\n }`,\n default: '{}',\n },\n ])\n\n queryParams.add([\n ...getASTParams(schemas.pathParams, { typed: false }),\n {\n name: 'params',\n enabled: client.withQueryParams,\n required: false,\n },\n {\n name: 'headers',\n enabled: client.withHeaders,\n required: false,\n },\n {\n name: 'clientOptions',\n required: false,\n },\n ])\n\n const hook = {\n name: 'useSWR',\n generics: [...resultGenerics, client.withQueryParams ? '[typeof url, typeof params] | null' : 'typeof url | null'].join(', '),\n queryOptions: `${queryOptionsName}<${queryOptionsGenerics.join(', ')}>(${queryParams.toString()})`,\n }\n\n return (\n <>\n <QueryOptions factory={factory} Template={QueryOptionsTemplate} dataReturnType={dataReturnType} />\n <Template\n name={name}\n generics={generics.toString()}\n JSDoc={{ comments: getComments(operation) }}\n client={client}\n hook={hook}\n params={params.toString()}\n returnType={`SWRResponse<${resultGenerics.join(', ')}>`}\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 queryOptions: typeof QueryOptions.templates\n }\n}\n\nQuery.File = function ({ templates }: FileProps): ReactNode {\n const {\n pluginManager,\n plugin: {\n options: {\n extName,\n client: { importPath },\n parser,\n },\n },\n } = useApp<PluginSwr>()\n const { getSchemas, getFile, getName } = useOperationManager()\n const operation = useOperation()\n\n const file = getFile(operation)\n const schemas = getSchemas(operation, { pluginKey: [pluginTsName], type: 'type' })\n const zodSchemas = getSchemas(operation, { pluginKey: [pluginZodName], type: 'function' })\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 Template = templates?.query.default || defaultTemplates.default\n const QueryOptionsTemplate = templates?.queryOptions.default || QueryOptions.templates.default\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=\"useSWR\" path=\"swr\" />\n <File.Import name={['SWRConfiguration', 'SWRResponse']} path=\"swr\" isTypeOnly />\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.statusCodes?.map((item) => item.name) || []),\n ].filter(Boolean)}\n root={file.path}\n path={fileType.path}\n isTypeOnly\n />\n\n <SchemaType factory={factory} />\n <Query factory={factory} Template={Template} QueryOptionsTemplate={QueryOptionsTemplate} />\n </File>\n )\n}\n\nQuery.templates = defaultTemplates\n","import 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, File, useApp } from '@kubb/react'\nimport { pluginZodName } from '@kubb/plugin-zod'\n\nimport type { HttpMethod } from '@kubb/oas'\nimport type { ReactNode } from 'react'\nimport type { PluginSwr } from '../types.ts'\nimport { pluginTsName } from '@kubb/plugin-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 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<PluginSwr['options']['dataReturnType']>\n parser: string | undefined\n}\n\nfunction Template({ name, params, generics, returnType, JSDoc, client, dataReturnType, parser }: 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}, ...options.headers }` : undefined,\n '...options',\n ].filter(Boolean)\n\n const resolvedClientOptions = `${transformers.createIndent(4)}${clientOptions.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 return (\n <File.Source name={name} isExportable>\n <Function name={name} export generics={generics} returnType={returnType} params={params} JSDoc={JSDoc}>\n {`\n return {\n fetcher: async () => {\n ${formData || ''}\n const res = await client<${client.generics}>({\n ${resolvedClientOptions}\n })\n\n ${returnRes}\n },\n }\n\n `}\n </Function>\n </File.Source>\n )\n}\n\nconst defaultTemplates = {\n default: Template,\n} as const\n\ntype Props = {\n factory: {\n name: string\n }\n dataReturnType: NonNullable<PluginSwr['options']['dataReturnType']>\n /**\n * This will make it possible to override the default behaviour.\n */\n Template?: React.ComponentType<TemplateProps>\n}\n\nexport function QueryOptions({ factory, dataReturnType, Template = defaultTemplates.default }: Props): ReactNode {\n const {\n pluginManager,\n plugin: {\n key: pluginKey,\n options: { parser },\n },\n } = useApp<PluginSwr>()\n const { getSchemas } = 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 name = pluginManager.resolveName({\n name: `${factory.name}QueryOptions`,\n pluginKey,\n })\n const contentType = operation.getContentType()\n\n const generics = new FunctionParams()\n const params = new FunctionParams()\n\n const clientGenerics = ['TData', `${factory.name}['error']`]\n const resultGenerics = ['TData', `${factory.name}['error']`]\n\n generics.add([{ type: 'TData', default: `${factory.name}['response']` }])\n\n params.add([\n ...getASTParams(schemas.pathParams, { typed: true }),\n {\n name: 'params',\n type: `${factory.name}['queryParams']`,\n enabled: !!schemas.queryParams?.name,\n required: false,\n },\n {\n name: 'headers',\n type: `${factory.name}['headerParams']`,\n enabled: !!schemas.headerParams?.name,\n required: false,\n },\n {\n name: 'options',\n type: `${factory.name}['client']['parameters']`,\n default: '{}',\n },\n ])\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.join(', '),\n contentType,\n }\n\n return (\n <Template\n name={name}\n params={params.toString()}\n generics={generics.toString()}\n returnType={`SWRConfiguration<${resultGenerics.join(', ')}>`}\n client={client}\n dataReturnType={dataReturnType}\n parser={parser === 'zod' ? `${zodSchemas.response.name}.parse` : undefined}\n />\n )\n}\n\nQueryOptions.templates = defaultTemplates\n"],"mappings":"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","names":["File","useApp","pluginTsName","useOperation","useOperationManager","jsx","jsxs","File","Template","useApp","useOperationManager","useOperation","pluginTsName","FunctionParams","URLPath","useOperation","useOperationManager","getASTParams","getComments","pluginTsName","pluginZodName","File","Function","useApp","transformers","FunctionParams","URLPath","useOperation","useOperationManager","getASTParams","Function","File","useApp","pluginTsName","jsx","Template","defaultTemplates","Fragment","jsx","jsxs","Template","File","Function","defaultTemplates","useApp","useOperation","useOperationManager","pluginTsName","pluginZodName","FunctionParams","URLPath","getASTParams","getComments"]}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["/home/runner/work/kubb/kubb/packages/plugin-swr/dist/chunk-PX3AB367.cjs","../src/components/Mutation.tsx","../src/components/SchemaType.tsx","../src/components/Query.tsx","../src/components/QueryOptions.tsx"],"names":["useOperation","Template","jsx","File","transformers","Function","defaultTemplates","FunctionParams","URLPath","Fragment","pluginZodName"],"mappings":"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","file":"/home/runner/work/kubb/kubb/packages/plugin-swr/dist/chunk-PX3AB367.cjs","sourcesContent":[null,"import 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 { useOperation, useOperationManager } from '@kubb/plugin-oas/hooks'\nimport { getASTParams, getComments } from '@kubb/plugin-oas/utils'\n\nimport { SchemaType } from './SchemaType.tsx'\n\nimport type { HttpMethod } from '@kubb/oas'\nimport type { ReactNode } from 'react'\nimport type { FileMeta, PluginSwr } 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 }\n client: {\n method: HttpMethod\n generics: string\n withQueryParams: boolean\n withPathParams: boolean\n withData: boolean\n withHeaders: boolean\n path: URLPath\n }\n dataReturnType: NonNullable<PluginSwr['options']['dataReturnType']>\n}\n\nfunction Template({ name, generics, returnType, params, JSDoc, client, hook, dataReturnType }: TemplateProps): ReactNode {\n const clientOptions = [\n `method: \"${client.method}\"`,\n 'url',\n client.withQueryParams ? 'params' : undefined,\n client.withData ? 'data' : undefined,\n client.withHeaders ? 'headers: { ...headers, ...clientOptions.headers }' : undefined,\n '...clientOptions',\n ].filter(Boolean)\n\n const resolvedClientOptions = `${transformers.createIndent(4)}${clientOptions.join(`,\\n${transformers.createIndent(4)}`)}`\n if (client.withQueryParams) {\n return (\n <File.Source name={name} isExportable>\n <Function export name={name} generics={generics} returnType={returnType} params={params} JSDoc={JSDoc}>\n {`\n const { mutation: mutationOptions, client: clientOptions = {}, shouldFetch = true } = options ?? {}\n\n const url = ${client.path.template} as const\n return ${hook.name}<${hook.generics}>(\n shouldFetch ? [url, params]: null,\n async (_url${client.withData ? ', { arg: data }' : ''}) => {\n const res = await client<${client.generics}>({\n ${resolvedClientOptions}\n })\n\n return ${dataReturnType === 'data' ? 'res.data' : 'res'}\n },\n mutationOptions\n )\n `}\n </Function>\n </File.Source>\n )\n }\n\n return (\n <File.Source name={name} isExportable>\n <Function export name={name} generics={generics} returnType={returnType} params={params} JSDoc={JSDoc}>\n {`\n const { mutation: mutationOptions, client: clientOptions = {}, shouldFetch = true } = options ?? {}\n\n const url = ${client.path.template} as const\n return ${hook.name}<${hook.generics}>(\n shouldFetch ? url : null,\n async (_url${client.withData ? ', { arg: data }' : ''}) => {\n const res = await client<${client.generics}>({\n ${resolvedClientOptions}\n })\n\n return ${dataReturnType === 'data' ? 'res.data' : 'res'}\n },\n mutationOptions\n )\n `}\n </Function>\n </File.Source>\n )\n}\n\nconst defaultTemplates = {\n default: Template,\n} as const\n\ntype Props = {\n factory: {\n name: string\n }\n /**\n * This will make it possible to override the default behaviour.\n */\n Template?: React.ComponentType<TemplateProps>\n}\n\nexport function Mutation({ factory, Template = defaultTemplates.default }: Props): ReactNode {\n const {\n plugin: {\n options: { dataReturnType },\n },\n } = useApp<PluginSwr>()\n const { getSchemas, getName } = useOperationManager()\n const operation = useOperation()\n\n const name = getName(operation, { type: 'function' })\n const schemas = getSchemas(operation, { pluginKey: [pluginTsName], type: 'type' })\n\n const params = new FunctionParams()\n const client = {\n method: operation.method,\n path: new URLPath(operation.path),\n generics: [`${factory.name}[\"data\"]`, `${factory.name}[\"error\"]`, schemas.request?.name ? `${factory.name}[\"request\"]` : ''].filter(Boolean).join(', '),\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 = [`${factory.name}[\"response\"]`, `${factory.name}[\"error\"]`]\n\n params.add([\n ...getASTParams(schemas.pathParams, { typed: true }),\n {\n name: 'params',\n type: `${factory.name}['queryParams']`,\n enabled: client.withQueryParams,\n required: false,\n },\n {\n name: 'headers',\n type: `${factory.name}['headerParams']`,\n enabled: client.withHeaders,\n required: false,\n },\n {\n name: 'options',\n required: false,\n type: `{\n mutation?: SWRMutationConfiguration<${resultGenerics.join(', ')}>,\n client?: ${factory.name}['client']['parameters'],\n shouldFetch?: boolean,\n }`,\n default: '{}',\n },\n ])\n\n const hook = {\n name: 'useSWRMutation',\n generics: [...resultGenerics, client.withQueryParams ? '[typeof url, typeof params] | null' : 'typeof url | null'].join(', '),\n }\n\n return (\n <Template\n name={name}\n JSDoc={{ comments: getComments(operation) }}\n client={client}\n hook={hook}\n params={params.toString()}\n returnType={`SWRMutationResponse<${resultGenerics.join(', ')}>`}\n dataReturnType={dataReturnType}\n />\n )\n}\n\ntype FileProps = {\n /**\n * This will make it possible to override the default behaviour.\n */\n templates?: typeof defaultTemplates\n}\n\nMutation.File = function ({ templates = defaultTemplates }: FileProps): ReactNode {\n const {\n plugin: {\n options: {\n extName,\n client: { importPath },\n },\n },\n } = useApp<PluginSwr>()\n\n const { getSchemas, getFile, getName } = 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 const factoryName = getName(operation, { type: 'type' })\n\n const Template = templates.default\n const factory = {\n name: factoryName,\n }\n\n return (\n <File<FileMeta> baseName={file.baseName} path={file.path} meta={file.meta}>\n <File.Import name=\"useSWRMutation\" path=\"swr/mutation\" />\n <File.Import name={['SWRMutationConfiguration', 'SWRMutationResponse']} path=\"swr/mutation\" isTypeOnly />\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 <SchemaType factory={factory} />\n <Mutation Template={Template} factory={factory} />\n </File>\n )\n}\n\nMutation.templates = defaultTemplates\n","import { File, Type, useApp } from '@kubb/react'\n\nimport { useOperation, useOperationManager } from '@kubb/plugin-oas/hooks'\nimport { pluginTsName } from '@kubb/plugin-ts'\nimport type { ReactNode } from 'react'\nimport type { PluginSwr } from '../types.ts'\n\ntype Props = {\n factory: {\n name: string\n }\n}\n\nexport function SchemaType({ factory }: Props): ReactNode {\n const {\n plugin: {\n options: { dataReturnType },\n },\n } = useApp<PluginSwr>()\n const { getSchemas } = 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\n const clientType = `${factory.name}Client`\n\n return (\n <>\n <File.Source name={clientType} isTypeOnly>\n <Type name={clientType}>{`typeof client<${TResponse}, ${TError}, ${TRequest}>`}</Type>\n </File.Source>\n <File.Source name={factory.name} isTypeOnly>\n <Type name={factory.name}>\n {`\n {\n data: ${TData}\n error: ${TError}\n request: ${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 { FunctionParams, URLPath } from '@kubb/core/utils'\nimport { useOperation, useOperationManager } from '@kubb/plugin-oas/hooks'\nimport { getASTParams, getComments } from '@kubb/plugin-oas/utils'\nimport { pluginTsName } from '@kubb/plugin-ts'\nimport { pluginZodName } from '@kubb/plugin-zod'\nimport { File, Function, useApp } from '@kubb/react'\n\nimport { QueryOptions } from './QueryOptions.tsx'\nimport { SchemaType } from './SchemaType.tsx'\n\nimport type { ReactNode } from 'react'\nimport type { FileMeta, PluginSwr } 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 queryOptions: string\n }\n client: {\n path: URLPath\n withQueryParams: boolean\n }\n}\n\nfunction Template({ name, generics, returnType, params, JSDoc, hook, client }: TemplateProps): ReactNode {\n if (client.withQueryParams) {\n return (\n <File.Source name={name} isExportable>\n <Function name={name} export generics={generics} returnType={returnType} params={params} JSDoc={JSDoc}>\n {`\n const { query: queryOptions, client: clientOptions = {}, shouldFetch = true } = options ?? {}\n\n const url = ${client.path.template}\n const query = ${hook.name}<${hook.generics}>(\n shouldFetch ? [url, params]: null,\n {\n ...${hook.queryOptions},\n ...queryOptions\n }\n )\n\n return query\n `}\n </Function>\n </File.Source>\n )\n }\n\n return (\n <File.Source name={name} isExportable>\n <Function name={name} export generics={generics} returnType={returnType} params={params} JSDoc={JSDoc}>\n {`\n const { query: queryOptions, client: clientOptions = {}, shouldFetch = true } = options ?? {}\n\n const url = ${client.path.template}\n const query = ${hook.name}<${hook.generics}>(\n shouldFetch ? url : null,\n {\n ...${hook.queryOptions},\n ...queryOptions\n }\n )\n\n return query\n `}\n </Function>\n </File.Source>\n )\n}\n\nconst defaultTemplates = {\n default: Template,\n} as const\n\ntype Props = {\n factory: {\n name: string\n }\n /**\n * This will make it possible to override the default behaviour.\n */\n Template?: React.ComponentType<TemplateProps>\n /**\n * This will make it possible to override the default behaviour.\n */\n QueryOptionsTemplate?: React.ComponentType<React.ComponentProps<typeof QueryOptions.templates.default>>\n}\n\nexport function Query({ factory, Template = defaultTemplates.default, QueryOptionsTemplate = QueryOptions.templates.default }: Props): ReactNode {\n const {\n pluginManager,\n plugin: {\n key: pluginKey,\n options: { dataReturnType },\n },\n } = useApp<PluginSwr>()\n\n const operation = useOperation()\n const { getSchemas, getName } = useOperationManager()\n\n const schemas = getSchemas(operation, { pluginKey: [pluginTsName], type: 'type' })\n const zodSchemas = getSchemas(operation, { pluginKey: [pluginZodName], type: 'function' })\n\n const name = getName(operation, { type: 'function' })\n\n const queryOptionsName = pluginManager.resolveName({\n name: `${factory.name}QueryOptions`,\n pluginKey,\n })\n const generics = new FunctionParams()\n const params = new FunctionParams()\n const queryParams = new FunctionParams()\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 const resultGenerics = ['TData', `${factory.name}[\"error\"]`]\n\n generics.add([{ type: 'TData', default: `${factory.name}[\"response\"]` }])\n\n const queryOptionsGenerics = ['TData']\n\n params.add([\n ...getASTParams(schemas.pathParams, { typed: true }),\n {\n name: 'params',\n type: `${factory.name}['queryParams']`,\n enabled: client.withQueryParams,\n required: false,\n },\n {\n name: 'headers',\n type: `${factory.name}['headerParams']`,\n enabled: client.withHeaders,\n required: false,\n },\n {\n name: 'options',\n required: false,\n type: `{\n query?: SWRConfiguration<${resultGenerics.join(', ')}>,\n client?: ${factory.name}['client']['parameters'],\n shouldFetch?: boolean,\n }`,\n default: '{}',\n },\n ])\n\n queryParams.add([\n ...getASTParams(schemas.pathParams, { typed: false }),\n {\n name: 'params',\n enabled: client.withQueryParams,\n required: false,\n },\n {\n name: 'headers',\n enabled: client.withHeaders,\n required: false,\n },\n {\n name: 'clientOptions',\n required: false,\n },\n ])\n\n const hook = {\n name: 'useSWR',\n generics: [...resultGenerics, client.withQueryParams ? '[typeof url, typeof params] | null' : 'typeof url | null'].join(', '),\n queryOptions: `${queryOptionsName}<${queryOptionsGenerics.join(', ')}>(${queryParams.toString()})`,\n }\n\n return (\n <>\n <QueryOptions factory={factory} Template={QueryOptionsTemplate} dataReturnType={dataReturnType} />\n <Template\n name={name}\n generics={generics.toString()}\n JSDoc={{ comments: getComments(operation) }}\n client={client}\n hook={hook}\n params={params.toString()}\n returnType={`SWRResponse<${resultGenerics.join(', ')}>`}\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 queryOptions: typeof QueryOptions.templates\n }\n}\n\nQuery.File = function ({ templates }: FileProps): ReactNode {\n const {\n pluginManager,\n plugin: {\n options: {\n extName,\n client: { importPath },\n parser,\n },\n },\n } = useApp<PluginSwr>()\n const { getSchemas, getFile, getName } = useOperationManager()\n const operation = useOperation()\n\n const file = getFile(operation)\n const schemas = getSchemas(operation, { pluginKey: [pluginTsName], type: 'type' })\n const zodSchemas = getSchemas(operation, { pluginKey: [pluginZodName], type: 'function' })\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 Template = templates?.query.default || defaultTemplates.default\n const QueryOptionsTemplate = templates?.queryOptions.default || QueryOptions.templates.default\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=\"useSWR\" path=\"swr\" />\n <File.Import name={['SWRConfiguration', 'SWRResponse']} path=\"swr\" isTypeOnly />\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.statusCodes?.map((item) => item.name) || []),\n ].filter(Boolean)}\n root={file.path}\n path={fileType.path}\n isTypeOnly\n />\n\n <SchemaType factory={factory} />\n <Query factory={factory} Template={Template} QueryOptionsTemplate={QueryOptionsTemplate} />\n </File>\n )\n}\n\nQuery.templates = defaultTemplates\n","import 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, File, useApp } from '@kubb/react'\nimport { pluginZodName } from '@kubb/plugin-zod'\n\nimport type { HttpMethod } from '@kubb/oas'\nimport type { ReactNode } from 'react'\nimport type { PluginSwr } from '../types.ts'\nimport { pluginTsName } from '@kubb/plugin-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 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<PluginSwr['options']['dataReturnType']>\n parser: string | undefined\n}\n\nfunction Template({ name, params, generics, returnType, JSDoc, client, dataReturnType, parser }: 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}, ...options.headers }` : undefined,\n '...options',\n ].filter(Boolean)\n\n const resolvedClientOptions = `${transformers.createIndent(4)}${clientOptions.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 return (\n <File.Source name={name} isExportable>\n <Function name={name} export generics={generics} returnType={returnType} params={params} JSDoc={JSDoc}>\n {`\n return {\n fetcher: async () => {\n ${formData || ''}\n const res = await client<${client.generics}>({\n ${resolvedClientOptions}\n })\n\n ${returnRes}\n },\n }\n\n `}\n </Function>\n </File.Source>\n )\n}\n\nconst defaultTemplates = {\n default: Template,\n} as const\n\ntype Props = {\n factory: {\n name: string\n }\n dataReturnType: NonNullable<PluginSwr['options']['dataReturnType']>\n /**\n * This will make it possible to override the default behaviour.\n */\n Template?: React.ComponentType<TemplateProps>\n}\n\nexport function QueryOptions({ factory, dataReturnType, Template = defaultTemplates.default }: Props): ReactNode {\n const {\n pluginManager,\n plugin: {\n key: pluginKey,\n options: { parser },\n },\n } = useApp<PluginSwr>()\n const { getSchemas } = 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 name = pluginManager.resolveName({\n name: `${factory.name}QueryOptions`,\n pluginKey,\n })\n const contentType = operation.getContentType()\n\n const generics = new FunctionParams()\n const params = new FunctionParams()\n\n const clientGenerics = ['TData', `${factory.name}['error']`]\n const resultGenerics = ['TData', `${factory.name}['error']`]\n\n generics.add([{ type: 'TData', default: `${factory.name}['response']` }])\n\n params.add([\n ...getASTParams(schemas.pathParams, { typed: true }),\n {\n name: 'params',\n type: `${factory.name}['queryParams']`,\n enabled: !!schemas.queryParams?.name,\n required: false,\n },\n {\n name: 'headers',\n type: `${factory.name}['headerParams']`,\n enabled: !!schemas.headerParams?.name,\n required: false,\n },\n {\n name: 'options',\n type: `${factory.name}['client']['parameters']`,\n default: '{}',\n },\n ])\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.join(', '),\n contentType,\n }\n\n return (\n <Template\n name={name}\n params={params.toString()}\n generics={generics.toString()}\n returnType={`SWRConfiguration<${resultGenerics.join(', ')}>`}\n client={client}\n dataReturnType={dataReturnType}\n parser={parser === 'zod' ? `${zodSchemas.response.name}.parse` : undefined}\n />\n )\n}\n\nQueryOptions.templates = defaultTemplates\n"]}
|