@kubb/plugin-swr 3.0.0-alpha.1 → 3.0.0-alpha.11

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.
@@ -0,0 +1,514 @@
1
+ 'use strict';
2
+
3
+ var transformers = require('@kubb/core/transformers');
4
+ var utils = require('@kubb/core/utils');
5
+ var react = require('@kubb/react');
6
+ var pluginTs = require('@kubb/plugin-ts');
7
+ var hooks = require('@kubb/plugin-oas/hooks');
8
+ var utils$1 = require('@kubb/plugin-oas/utils');
9
+ var jsxRuntime = require('@kubb/react/jsx-runtime');
10
+ var pluginZod = require('@kubb/plugin-zod');
11
+
12
+ function _interopDefault (e) { return e && e.__esModule ? e : { default: e }; }
13
+
14
+ var transformers__default = /*#__PURE__*/_interopDefault(transformers);
15
+
16
+ // src/components/Mutation.tsx
17
+ function SchemaType({ factory }) {
18
+ const {
19
+ plugin: {
20
+ options: { dataReturnType }
21
+ }
22
+ } = react.useApp();
23
+ const { getSchemas } = hooks.useOperationManager();
24
+ const operation = hooks.useOperation();
25
+ const schemas = getSchemas(operation, { pluginKey: [pluginTs.pluginTsName], type: "type" });
26
+ const [TData, TError, TRequest, TPathParams, TQueryParams, THeaderParams, TResponse] = [
27
+ schemas.response.name,
28
+ schemas.errors?.map((item) => item.name).join(" | ") || "never",
29
+ schemas.request?.name || "never",
30
+ schemas.pathParams?.name || "never",
31
+ schemas.queryParams?.name || "never",
32
+ schemas.headerParams?.name || "never",
33
+ schemas.response.name
34
+ ];
35
+ const clientType = `${factory.name}Client`;
36
+ return /* @__PURE__ */ jsxRuntime.jsxs(jsxRuntime.Fragment, { children: [
37
+ /* @__PURE__ */ jsxRuntime.jsx(react.File.Source, { name: clientType, isTypeOnly: true, children: /* @__PURE__ */ jsxRuntime.jsx(react.Type, { name: clientType, children: `typeof client<${TResponse}, ${TError}, ${TRequest}>` }) }),
38
+ /* @__PURE__ */ jsxRuntime.jsx(react.File.Source, { name: factory.name, isTypeOnly: true, children: /* @__PURE__ */ jsxRuntime.jsx(react.Type, { name: factory.name, children: `
39
+ {
40
+ data: ${TData}
41
+ error: ${TError}
42
+ request: ${TRequest}
43
+ pathParams: ${TPathParams}
44
+ queryParams: ${TQueryParams}
45
+ headerParams: ${THeaderParams}
46
+ response: ${dataReturnType === "data" ? TData : `Awaited<ReturnType<${clientType}>>`}
47
+ client: {
48
+ parameters: Partial<Parameters<${clientType}>[0]>
49
+ return: Awaited<ReturnType<${clientType}>>
50
+ }
51
+ }
52
+ ` }) })
53
+ ] });
54
+ }
55
+ function Template({ name, generics, returnType, params, JSDoc, client, hook, dataReturnType }) {
56
+ const clientOptions = [
57
+ `method: "${client.method}"`,
58
+ "url",
59
+ client.withQueryParams ? "params" : void 0,
60
+ client.withData ? "data" : void 0,
61
+ client.withHeaders ? "headers: { ...headers, ...clientOptions.headers }" : void 0,
62
+ "...clientOptions"
63
+ ].filter(Boolean);
64
+ const resolvedClientOptions = `${transformers__default.default.createIndent(4)}${clientOptions.join(`,
65
+ ${transformers__default.default.createIndent(4)}`)}`;
66
+ if (client.withQueryParams) {
67
+ return /* @__PURE__ */ jsxRuntime.jsx(react.File.Source, { name, isExportable: true, isIndexable: true, children: /* @__PURE__ */ jsxRuntime.jsx(react.Function, { export: true, name, generics, returnType, params, JSDoc, children: `
68
+ const { mutation: mutationOptions, client: clientOptions = {}, shouldFetch = true } = options ?? {}
69
+
70
+ const url = ${client.path.template} as const
71
+ return ${hook.name}<${hook.generics}>(
72
+ shouldFetch ? [url, params]: null,
73
+ async (_url${client.withData ? ", { arg: data }" : ""}) => {
74
+ const res = await client<${client.generics}>({
75
+ ${resolvedClientOptions}
76
+ })
77
+
78
+ return ${dataReturnType === "data" ? "res.data" : "res"}
79
+ },
80
+ mutationOptions
81
+ )
82
+ ` }) });
83
+ }
84
+ return /* @__PURE__ */ jsxRuntime.jsx(react.File.Source, { name, isExportable: true, isIndexable: true, children: /* @__PURE__ */ jsxRuntime.jsx(react.Function, { export: true, name, generics, returnType, params, JSDoc, children: `
85
+ const { mutation: mutationOptions, client: clientOptions = {}, shouldFetch = true } = options ?? {}
86
+
87
+ const url = ${client.path.template} as const
88
+ return ${hook.name}<${hook.generics}>(
89
+ shouldFetch ? url : null,
90
+ async (_url${client.withData ? ", { arg: data }" : ""}) => {
91
+ const res = await client<${client.generics}>({
92
+ ${resolvedClientOptions}
93
+ })
94
+
95
+ return ${dataReturnType === "data" ? "res.data" : "res"}
96
+ },
97
+ mutationOptions
98
+ )
99
+ ` }) });
100
+ }
101
+ var defaultTemplates = {
102
+ default: Template
103
+ };
104
+ function Mutation({ factory, Template: Template4 = defaultTemplates.default }) {
105
+ const {
106
+ plugin: {
107
+ options: { dataReturnType }
108
+ }
109
+ } = react.useApp();
110
+ const { getSchemas, getName } = hooks.useOperationManager();
111
+ const operation = hooks.useOperation();
112
+ const name = getName(operation, { type: "function" });
113
+ const schemas = getSchemas(operation, { pluginKey: [pluginTs.pluginTsName], type: "type" });
114
+ const params = new utils.FunctionParams();
115
+ const client = {
116
+ method: operation.method,
117
+ path: new utils.URLPath(operation.path),
118
+ generics: [`${factory.name}["data"]`, `${factory.name}["error"]`, schemas.request?.name ? `${factory.name}["request"]` : ""].filter(Boolean).join(", "),
119
+ withQueryParams: !!schemas.queryParams?.name,
120
+ withData: !!schemas.request?.name,
121
+ withPathParams: !!schemas.pathParams?.name,
122
+ withHeaders: !!schemas.headerParams?.name
123
+ };
124
+ const resultGenerics = [`${factory.name}["response"]`, `${factory.name}["error"]`];
125
+ params.add([
126
+ ...utils$1.getASTParams(schemas.pathParams, { typed: true }),
127
+ {
128
+ name: "params",
129
+ type: `${factory.name}['queryParams']`,
130
+ enabled: client.withQueryParams,
131
+ required: false
132
+ },
133
+ {
134
+ name: "headers",
135
+ type: `${factory.name}['headerParams']`,
136
+ enabled: client.withHeaders,
137
+ required: false
138
+ },
139
+ {
140
+ name: "options",
141
+ required: false,
142
+ type: `{
143
+ mutation?: SWRMutationConfiguration<${resultGenerics.join(", ")}>,
144
+ client?: ${factory.name}['client']['parameters'],
145
+ shouldFetch?: boolean,
146
+ }`,
147
+ default: "{}"
148
+ }
149
+ ]);
150
+ const hook = {
151
+ name: "useSWRMutation",
152
+ generics: [...resultGenerics, client.withQueryParams ? "[typeof url, typeof params] | null" : "typeof url | null"].join(", ")
153
+ };
154
+ return /* @__PURE__ */ jsxRuntime.jsx(
155
+ Template4,
156
+ {
157
+ name,
158
+ JSDoc: { comments: utils$1.getComments(operation) },
159
+ client,
160
+ hook,
161
+ params: params.toString(),
162
+ returnType: `SWRMutationResponse<${resultGenerics.join(", ")}>`,
163
+ dataReturnType
164
+ }
165
+ );
166
+ }
167
+ Mutation.File = function({ templates = defaultTemplates }) {
168
+ const {
169
+ plugin: {
170
+ options: {
171
+ extName,
172
+ client: { importPath }
173
+ }
174
+ }
175
+ } = react.useApp();
176
+ const { getSchemas, getFile, getName } = hooks.useOperationManager();
177
+ const operation = hooks.useOperation();
178
+ const schemas = getSchemas(operation, { pluginKey: [pluginTs.pluginTsName], type: "type" });
179
+ const file = getFile(operation);
180
+ const fileType = getFile(operation, { pluginKey: [pluginTs.pluginTsName] });
181
+ const factoryName = getName(operation, { type: "type" });
182
+ const Template4 = templates.default;
183
+ const factory = {
184
+ name: factoryName
185
+ };
186
+ return /* @__PURE__ */ jsxRuntime.jsxs(react.File, { baseName: file.baseName, path: file.path, meta: file.meta, children: [
187
+ /* @__PURE__ */ jsxRuntime.jsx(react.File.Import, { name: "useSWRMutation", path: "swr/mutation" }),
188
+ /* @__PURE__ */ jsxRuntime.jsx(react.File.Import, { name: ["SWRMutationConfiguration", "SWRMutationResponse"], path: "swr/mutation", isTypeOnly: true }),
189
+ /* @__PURE__ */ jsxRuntime.jsx(react.File.Import, { name: "client", path: importPath }),
190
+ /* @__PURE__ */ jsxRuntime.jsx(react.File.Import, { name: ["ResponseConfig"], path: importPath, isTypeOnly: true }),
191
+ /* @__PURE__ */ jsxRuntime.jsx(
192
+ react.File.Import,
193
+ {
194
+ name: [
195
+ schemas.request?.name,
196
+ schemas.response.name,
197
+ schemas.pathParams?.name,
198
+ schemas.queryParams?.name,
199
+ schemas.headerParams?.name,
200
+ ...schemas.errors?.map((error) => error.name) || []
201
+ ].filter(Boolean),
202
+ root: file.path,
203
+ path: fileType.path,
204
+ isTypeOnly: true
205
+ }
206
+ ),
207
+ /* @__PURE__ */ jsxRuntime.jsx(SchemaType, { factory }),
208
+ /* @__PURE__ */ jsxRuntime.jsx(Mutation, { Template: Template4, factory })
209
+ ] });
210
+ };
211
+ Mutation.templates = defaultTemplates;
212
+ function Template2({ name, params, generics, returnType, JSDoc, client, dataReturnType, parser }) {
213
+ const isFormData = client.contentType === "multipart/form-data";
214
+ const headers = [
215
+ client.contentType !== "application/json" ? `'Content-Type': '${client.contentType}'` : void 0,
216
+ client.withHeaders ? "...headers" : void 0
217
+ ].filter(Boolean).join(", ");
218
+ const clientOptions = [
219
+ `method: "${client.method}"`,
220
+ `url: ${client.path.template}`,
221
+ client.withQueryParams ? "params" : void 0,
222
+ client.withData && !isFormData ? "data" : void 0,
223
+ client.withData && isFormData ? "data: formData" : void 0,
224
+ headers.length ? `headers: { ${headers}, ...options.headers }` : void 0,
225
+ "...options"
226
+ ].filter(Boolean);
227
+ const resolvedClientOptions = `${transformers__default.default.createIndent(4)}${clientOptions.join(`,
228
+ ${transformers__default.default.createIndent(4)}`)}`;
229
+ let returnRes = parser ? `return ${parser}(res.data)` : "return res.data";
230
+ if (dataReturnType === "full") {
231
+ returnRes = parser ? `return {...res, data: ${parser}(res.data)}` : "return res";
232
+ }
233
+ const formData = isFormData ? `
234
+ const formData = new FormData()
235
+ if(data) {
236
+ Object.keys(data).forEach((key) => {
237
+ const value = data[key];
238
+ if (typeof key === "string" && (typeof value === "string" || value instanceof Blob)) {
239
+ formData.append(key, value);
240
+ }
241
+ })
242
+ }
243
+ ` : void 0;
244
+ return /* @__PURE__ */ jsxRuntime.jsx(react.File.Source, { name, isExportable: true, isIndexable: true, children: /* @__PURE__ */ jsxRuntime.jsx(react.Function, { name, export: true, generics, returnType, params, JSDoc, children: `
245
+ return {
246
+ fetcher: async () => {
247
+ ${formData || ""}
248
+ const res = await client<${client.generics}>({
249
+ ${resolvedClientOptions}
250
+ })
251
+
252
+ ${returnRes}
253
+ },
254
+ }
255
+
256
+ ` }) });
257
+ }
258
+ var defaultTemplates2 = {
259
+ default: Template2
260
+ };
261
+ function QueryOptions({ factory, dataReturnType, Template: Template4 = defaultTemplates2.default }) {
262
+ const {
263
+ pluginManager,
264
+ plugin: {
265
+ key: pluginKey,
266
+ options: { parser }
267
+ }
268
+ } = react.useApp();
269
+ const { getSchemas } = hooks.useOperationManager();
270
+ const operation = hooks.useOperation();
271
+ const schemas = getSchemas(operation, { pluginKey: [pluginTs.pluginTsName], type: "type" });
272
+ const zodSchemas = getSchemas(operation, { pluginKey: [pluginZod.pluginZodName], type: "function" });
273
+ const name = pluginManager.resolveName({
274
+ name: `${factory.name}QueryOptions`,
275
+ pluginKey
276
+ });
277
+ const contentType = operation.getContentType();
278
+ const generics = new utils.FunctionParams();
279
+ const params = new utils.FunctionParams();
280
+ const clientGenerics = ["TData", `${factory.name}['error']`];
281
+ const resultGenerics = ["TData", `${factory.name}['error']`];
282
+ generics.add([{ type: "TData", default: `${factory.name}['response']` }]);
283
+ params.add([
284
+ ...utils$1.getASTParams(schemas.pathParams, { typed: true }),
285
+ {
286
+ name: "params",
287
+ type: `${factory.name}['queryParams']`,
288
+ enabled: !!schemas.queryParams?.name,
289
+ required: false
290
+ },
291
+ {
292
+ name: "headers",
293
+ type: `${factory.name}['headerParams']`,
294
+ enabled: !!schemas.headerParams?.name,
295
+ required: false
296
+ },
297
+ {
298
+ name: "options",
299
+ type: `${factory.name}['client']['parameters']`,
300
+ default: "{}"
301
+ }
302
+ ]);
303
+ const client = {
304
+ withQueryParams: !!schemas.queryParams?.name,
305
+ withData: !!schemas.request?.name,
306
+ withPathParams: !!schemas.pathParams?.name,
307
+ withHeaders: !!schemas.headerParams?.name,
308
+ method: operation.method,
309
+ path: new utils.URLPath(operation.path),
310
+ generics: clientGenerics.join(", "),
311
+ contentType
312
+ };
313
+ return /* @__PURE__ */ jsxRuntime.jsx(
314
+ Template4,
315
+ {
316
+ name,
317
+ params: params.toString(),
318
+ generics: generics.toString(),
319
+ returnType: `SWRConfiguration<${resultGenerics.join(", ")}>`,
320
+ client,
321
+ dataReturnType,
322
+ parser: parser === "zod" ? `${zodSchemas.response.name}.parse` : void 0
323
+ }
324
+ );
325
+ }
326
+ QueryOptions.templates = defaultTemplates2;
327
+ function Template3({ name, generics, returnType, params, JSDoc, hook, client }) {
328
+ if (client.withQueryParams) {
329
+ return /* @__PURE__ */ jsxRuntime.jsx(react.File.Source, { name, isExportable: true, isIndexable: true, children: /* @__PURE__ */ jsxRuntime.jsx(react.Function, { name, export: true, generics, returnType, params, JSDoc, children: `
330
+ const { query: queryOptions, client: clientOptions = {}, shouldFetch = true } = options ?? {}
331
+
332
+ const url = ${client.path.template}
333
+ const query = ${hook.name}<${hook.generics}>(
334
+ shouldFetch ? [url, params]: null,
335
+ {
336
+ ...${hook.queryOptions},
337
+ ...queryOptions
338
+ }
339
+ )
340
+
341
+ return query
342
+ ` }) });
343
+ }
344
+ return /* @__PURE__ */ jsxRuntime.jsx(react.File.Source, { name, isExportable: true, isIndexable: true, children: /* @__PURE__ */ jsxRuntime.jsx(react.Function, { name, export: true, generics, returnType, params, JSDoc, children: `
345
+ const { query: queryOptions, client: clientOptions = {}, shouldFetch = true } = options ?? {}
346
+
347
+ const url = ${client.path.template}
348
+ const query = ${hook.name}<${hook.generics}>(
349
+ shouldFetch ? url : null,
350
+ {
351
+ ...${hook.queryOptions},
352
+ ...queryOptions
353
+ }
354
+ )
355
+
356
+ return query
357
+ ` }) });
358
+ }
359
+ var defaultTemplates3 = {
360
+ default: Template3
361
+ };
362
+ function Query({ factory, Template: Template4 = defaultTemplates3.default, QueryOptionsTemplate = QueryOptions.templates.default }) {
363
+ const {
364
+ pluginManager,
365
+ plugin: {
366
+ key: pluginKey,
367
+ options: { dataReturnType }
368
+ }
369
+ } = react.useApp();
370
+ const operation = hooks.useOperation();
371
+ const { getSchemas, getName } = hooks.useOperationManager();
372
+ const schemas = getSchemas(operation, { pluginKey: [pluginTs.pluginTsName], type: "type" });
373
+ getSchemas(operation, { pluginKey: [pluginZod.pluginZodName], type: "function" });
374
+ const name = getName(operation, { type: "function" });
375
+ const queryOptionsName = pluginManager.resolveName({
376
+ name: `${factory.name}QueryOptions`,
377
+ pluginKey
378
+ });
379
+ const generics = new utils.FunctionParams();
380
+ const params = new utils.FunctionParams();
381
+ const queryParams = new utils.FunctionParams();
382
+ const client = {
383
+ method: operation.method,
384
+ path: new utils.URLPath(operation.path),
385
+ withQueryParams: !!schemas.queryParams?.name,
386
+ withData: !!schemas.request?.name,
387
+ withPathParams: !!schemas.pathParams?.name,
388
+ withHeaders: !!schemas.headerParams?.name
389
+ };
390
+ const resultGenerics = ["TData", `${factory.name}["error"]`];
391
+ generics.add([{ type: "TData", default: `${factory.name}["response"]` }]);
392
+ const queryOptionsGenerics = ["TData"];
393
+ params.add([
394
+ ...utils$1.getASTParams(schemas.pathParams, { typed: true }),
395
+ {
396
+ name: "params",
397
+ type: `${factory.name}['queryParams']`,
398
+ enabled: client.withQueryParams,
399
+ required: false
400
+ },
401
+ {
402
+ name: "headers",
403
+ type: `${factory.name}['headerParams']`,
404
+ enabled: client.withHeaders,
405
+ required: false
406
+ },
407
+ {
408
+ name: "options",
409
+ required: false,
410
+ type: `{
411
+ query?: SWRConfiguration<${resultGenerics.join(", ")}>,
412
+ client?: ${factory.name}['client']['parameters'],
413
+ shouldFetch?: boolean,
414
+ }`,
415
+ default: "{}"
416
+ }
417
+ ]);
418
+ queryParams.add([
419
+ ...utils$1.getASTParams(schemas.pathParams, { typed: false }),
420
+ {
421
+ name: "params",
422
+ enabled: client.withQueryParams,
423
+ required: false
424
+ },
425
+ {
426
+ name: "headers",
427
+ enabled: client.withHeaders,
428
+ required: false
429
+ },
430
+ {
431
+ name: "clientOptions",
432
+ required: false
433
+ }
434
+ ]);
435
+ const hook = {
436
+ name: "useSWR",
437
+ generics: [...resultGenerics, client.withQueryParams ? "[typeof url, typeof params] | null" : "typeof url | null"].join(", "),
438
+ queryOptions: `${queryOptionsName}<${queryOptionsGenerics.join(", ")}>(${queryParams.toString()})`
439
+ };
440
+ return /* @__PURE__ */ jsxRuntime.jsxs(jsxRuntime.Fragment, { children: [
441
+ /* @__PURE__ */ jsxRuntime.jsx(QueryOptions, { factory, Template: QueryOptionsTemplate, dataReturnType }),
442
+ /* @__PURE__ */ jsxRuntime.jsx(
443
+ Template4,
444
+ {
445
+ name,
446
+ generics: generics.toString(),
447
+ JSDoc: { comments: utils$1.getComments(operation) },
448
+ client,
449
+ hook,
450
+ params: params.toString(),
451
+ returnType: `SWRResponse<${resultGenerics.join(", ")}>`
452
+ }
453
+ )
454
+ ] });
455
+ }
456
+ Query.File = function({ templates }) {
457
+ const {
458
+ pluginManager,
459
+ plugin: {
460
+ options: {
461
+ extName,
462
+ client: { importPath },
463
+ parser
464
+ }
465
+ }
466
+ } = react.useApp();
467
+ const { getSchemas, getFile, getName } = hooks.useOperationManager();
468
+ const operation = hooks.useOperation();
469
+ const file = getFile(operation);
470
+ const schemas = getSchemas(operation, { pluginKey: [pluginTs.pluginTsName], type: "type" });
471
+ const zodSchemas = getSchemas(operation, { pluginKey: [pluginZod.pluginZodName], type: "function" });
472
+ const fileType = getFile(operation, { pluginKey: [pluginTs.pluginTsName] });
473
+ const fileZodSchemas = getFile(operation, {
474
+ pluginKey: [pluginZod.pluginZodName]
475
+ });
476
+ const factoryName = getName(operation, { type: "type" });
477
+ const Template4 = templates?.query.default || defaultTemplates3.default;
478
+ const QueryOptionsTemplate = templates?.queryOptions.default || QueryOptions.templates.default;
479
+ const factory = {
480
+ name: factoryName
481
+ };
482
+ return /* @__PURE__ */ jsxRuntime.jsxs(react.File, { baseName: file.baseName, path: file.path, meta: file.meta, children: [
483
+ parser === "zod" && /* @__PURE__ */ jsxRuntime.jsx(react.File.Import, { name: [zodSchemas.response.name], root: file.path, path: fileZodSchemas.path }),
484
+ /* @__PURE__ */ jsxRuntime.jsx(react.File.Import, { name: "useSWR", path: "swr" }),
485
+ /* @__PURE__ */ jsxRuntime.jsx(react.File.Import, { name: ["SWRConfiguration", "SWRResponse"], path: "swr", isTypeOnly: true }),
486
+ /* @__PURE__ */ jsxRuntime.jsx(react.File.Import, { name: "client", path: importPath }),
487
+ /* @__PURE__ */ jsxRuntime.jsx(react.File.Import, { name: ["ResponseConfig"], path: importPath, isTypeOnly: true }),
488
+ /* @__PURE__ */ jsxRuntime.jsx(
489
+ react.File.Import,
490
+ {
491
+ name: [
492
+ schemas.request?.name,
493
+ schemas.response.name,
494
+ schemas.pathParams?.name,
495
+ schemas.queryParams?.name,
496
+ schemas.headerParams?.name,
497
+ ...schemas.statusCodes?.map((item) => item.name) || []
498
+ ].filter(Boolean),
499
+ root: file.path,
500
+ path: fileType.path,
501
+ isTypeOnly: true
502
+ }
503
+ ),
504
+ /* @__PURE__ */ jsxRuntime.jsx(SchemaType, { factory }),
505
+ /* @__PURE__ */ jsxRuntime.jsx(Query, { factory, Template: Template4, QueryOptionsTemplate })
506
+ ] });
507
+ };
508
+ Query.templates = defaultTemplates3;
509
+
510
+ exports.Mutation = Mutation;
511
+ exports.Query = Query;
512
+ exports.QueryOptions = QueryOptions;
513
+ //# sourceMappingURL=chunk-TGLXUPN4.cjs.map
514
+ //# sourceMappingURL=chunk-TGLXUPN4.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/components/SchemaType.tsx","../src/components/Mutation.tsx","../src/components/QueryOptions.tsx","../src/components/Query.tsx"],"names":["useApp","useOperationManager","useOperation","pluginTsName","jsxs","Fragment","jsx","File","Type","transformers","Function","Template","FunctionParams","URLPath","getASTParams","getComments","defaultTemplates","pluginZodName"],"mappings":"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","file":"chunk-TGLXUPN4.cjs","sourcesContent":["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 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 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","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"]}