@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.
- package/dist/chunk-TGLXUPN4.cjs +514 -0
- package/dist/chunk-TGLXUPN4.cjs.map +1 -0
- package/dist/{chunk-ECJ346AA.js → chunk-XWXMQJD6.js} +86 -122
- package/dist/chunk-XWXMQJD6.js.map +1 -0
- package/dist/components.cjs +15 -6
- package/dist/components.cjs.map +1 -1
- package/dist/components.js +2 -10
- package/dist/components.js.map +1 -1
- package/dist/index.cjs +61 -78
- package/dist/index.cjs.map +1 -1
- package/dist/index.js +30 -54
- package/dist/index.js.map +1 -1
- package/package.json +15 -15
- package/src/components/Mutation.tsx +34 -34
- package/src/components/Query.tsx +28 -34
- package/src/components/QueryOptions.tsx +6 -4
- package/src/components/SchemaType.tsx +10 -6
- package/src/components/__snapshots__/Mutation/Pets.ts +37 -33
- package/src/components/__snapshots__/Query/showPetById.ts +51 -47
- package/src/plugin.ts +15 -32
- package/dist/chunk-ECJ346AA.js.map +0 -1
- package/dist/chunk-H4LHXYRJ.cjs +0 -542
- package/dist/chunk-H4LHXYRJ.cjs.map +0 -1
|
@@ -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"]}
|