@kubb/plugin-ts 5.0.0-alpha.11 → 5.0.0-alpha.13

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (57) hide show
  1. package/dist/Type-C8EHVKjc.js +663 -0
  2. package/dist/Type-C8EHVKjc.js.map +1 -0
  3. package/dist/Type-DrOq6-nh.cjs +680 -0
  4. package/dist/Type-DrOq6-nh.cjs.map +1 -0
  5. package/dist/casing-Cp-jbC_k.js +84 -0
  6. package/dist/casing-Cp-jbC_k.js.map +1 -0
  7. package/dist/casing-D2uQKLWS.cjs +144 -0
  8. package/dist/casing-D2uQKLWS.cjs.map +1 -0
  9. package/dist/components.cjs +3 -2
  10. package/dist/components.d.ts +41 -9
  11. package/dist/components.js +2 -2
  12. package/dist/generators-CX3cSSdF.cjs +551 -0
  13. package/dist/generators-CX3cSSdF.cjs.map +1 -0
  14. package/dist/generators-dCqW0ECC.js +547 -0
  15. package/dist/generators-dCqW0ECC.js.map +1 -0
  16. package/dist/generators.cjs +2 -3
  17. package/dist/generators.d.ts +3 -503
  18. package/dist/generators.js +2 -2
  19. package/dist/index.cjs +135 -4
  20. package/dist/index.cjs.map +1 -0
  21. package/dist/index.d.ts +2 -41
  22. package/dist/index.js +134 -2
  23. package/dist/index.js.map +1 -0
  24. package/dist/resolvers-CH7hINyz.js +181 -0
  25. package/dist/resolvers-CH7hINyz.js.map +1 -0
  26. package/dist/resolvers-ebHaaCyw.cjs +191 -0
  27. package/dist/resolvers-ebHaaCyw.cjs.map +1 -0
  28. package/dist/resolvers.cjs +4 -0
  29. package/dist/resolvers.d.ts +51 -0
  30. package/dist/resolvers.js +2 -0
  31. package/dist/{types-mSXmB8WU.d.ts → types-BSRhtbGl.d.ts} +80 -57
  32. package/package.json +12 -5
  33. package/src/components/{v2/Enum.tsx → Enum.tsx} +27 -11
  34. package/src/components/Type.tsx +24 -141
  35. package/src/components/index.ts +1 -0
  36. package/src/generators/index.ts +0 -1
  37. package/src/generators/typeGenerator.tsx +204 -413
  38. package/src/generators/utils.ts +300 -0
  39. package/src/index.ts +0 -1
  40. package/src/plugin.ts +81 -126
  41. package/src/printer.ts +20 -6
  42. package/src/resolvers/index.ts +2 -0
  43. package/src/{resolverTs.ts → resolvers/resolverTs.ts} +26 -2
  44. package/src/resolvers/resolverTsLegacy.ts +85 -0
  45. package/src/types.ts +75 -52
  46. package/dist/components-CRu8IKY3.js +0 -729
  47. package/dist/components-CRu8IKY3.js.map +0 -1
  48. package/dist/components-DeNDKlzf.cjs +0 -982
  49. package/dist/components-DeNDKlzf.cjs.map +0 -1
  50. package/dist/plugin-CJ29AwE2.cjs +0 -1320
  51. package/dist/plugin-CJ29AwE2.cjs.map +0 -1
  52. package/dist/plugin-D60XNJSD.js +0 -1267
  53. package/dist/plugin-D60XNJSD.js.map +0 -1
  54. package/src/components/v2/Type.tsx +0 -59
  55. package/src/generators/v2/typeGenerator.tsx +0 -167
  56. package/src/generators/v2/utils.ts +0 -140
  57. package/src/parser.ts +0 -389
@@ -0,0 +1,551 @@
1
+ const require_casing = require("./casing-D2uQKLWS.cjs");
2
+ const require_Type = require("./Type-DrOq6-nh.cjs");
3
+ let _kubb_ast = require("@kubb/ast");
4
+ let _kubb_core = require("@kubb/core");
5
+ let _kubb_core_hooks = require("@kubb/core/hooks");
6
+ let _kubb_react_fabric = require("@kubb/react-fabric");
7
+ let _kubb_react_fabric_jsx_runtime = require("@kubb/react-fabric/jsx-runtime");
8
+ //#region src/generators/utils.ts
9
+ /**
10
+ * Builds an `ObjectSchemaNode` for a group of parameters (path/query/header).
11
+ * Each property is a `ref` schema pointing to the individually-resolved parameter type.
12
+ * The ref name includes the parameter location so generated type names follow
13
+ * the `<OperationId><Location><ParamName>` convention.
14
+ */
15
+ function buildParamsSchema({ params, node, resolver }) {
16
+ return (0, _kubb_ast.createSchema)({
17
+ type: "object",
18
+ properties: params.map((param) => (0, _kubb_ast.createProperty)({
19
+ name: param.name,
20
+ schema: (0, _kubb_ast.createSchema)({
21
+ type: "ref",
22
+ name: resolver.resolveParamName(node, param),
23
+ optional: !param.required
24
+ })
25
+ }))
26
+ });
27
+ }
28
+ /**
29
+ * Builds an `ObjectSchemaNode` representing the `<OperationId>RequestConfig` type:
30
+ * - `data` → request body ref (optional) or `never`
31
+ * - `pathParams` → inline object of path param refs, or `never`
32
+ * - `queryParams` → inline object of query param refs (optional), or `never`
33
+ * - `headerParams` → inline object of header param refs (optional), or `never`
34
+ * - `url` → Express-style template literal (plugin-ts extension, handled by printer)
35
+ */
36
+ function buildDataSchemaNode({ node, resolver }) {
37
+ const pathParams = node.parameters.filter((p) => p.in === "path");
38
+ const queryParams = node.parameters.filter((p) => p.in === "query");
39
+ const headerParams = node.parameters.filter((p) => p.in === "header");
40
+ return (0, _kubb_ast.createSchema)({
41
+ type: "object",
42
+ deprecated: node.deprecated,
43
+ properties: [
44
+ (0, _kubb_ast.createProperty)({
45
+ name: "data",
46
+ schema: node.requestBody?.schema ? (0, _kubb_ast.createSchema)({
47
+ type: "ref",
48
+ name: resolver.resolveDataTypedName(node),
49
+ optional: true
50
+ }) : (0, _kubb_ast.createSchema)({
51
+ type: "never",
52
+ optional: true
53
+ })
54
+ }),
55
+ (0, _kubb_ast.createProperty)({
56
+ name: "pathParams",
57
+ schema: pathParams.length > 0 ? buildParamsSchema({
58
+ params: pathParams,
59
+ node,
60
+ resolver
61
+ }) : (0, _kubb_ast.createSchema)({
62
+ type: "never",
63
+ optional: true
64
+ })
65
+ }),
66
+ (0, _kubb_ast.createProperty)({
67
+ name: "queryParams",
68
+ schema: queryParams.length > 0 ? (0, _kubb_ast.createSchema)({
69
+ ...buildParamsSchema({
70
+ params: queryParams,
71
+ node,
72
+ resolver
73
+ }),
74
+ optional: true
75
+ }) : (0, _kubb_ast.createSchema)({
76
+ type: "never",
77
+ optional: true
78
+ })
79
+ }),
80
+ (0, _kubb_ast.createProperty)({
81
+ name: "headerParams",
82
+ schema: headerParams.length > 0 ? (0, _kubb_ast.createSchema)({
83
+ ...buildParamsSchema({
84
+ params: headerParams,
85
+ node,
86
+ resolver
87
+ }),
88
+ optional: true
89
+ }) : (0, _kubb_ast.createSchema)({
90
+ type: "never",
91
+ optional: true
92
+ })
93
+ }),
94
+ (0, _kubb_ast.createProperty)({
95
+ name: "url",
96
+ schema: (0, _kubb_ast.createSchema)({
97
+ type: "url",
98
+ path: node.path
99
+ })
100
+ })
101
+ ]
102
+ });
103
+ }
104
+ /**
105
+ * Builds an `ObjectSchemaNode` representing `<OperationId>Responses` — keyed by HTTP status code.
106
+ * Numeric status codes produce unquoted numeric keys (e.g. `200:`).
107
+ * All responses are included; those without a schema are represented as a ref to a `never` type.
108
+ */
109
+ function buildResponsesSchemaNode({ node, resolver }) {
110
+ if (node.responses.length === 0) return null;
111
+ return (0, _kubb_ast.createSchema)({
112
+ type: "object",
113
+ properties: node.responses.map((res) => (0, _kubb_ast.createProperty)({
114
+ name: String(res.statusCode),
115
+ schema: (0, _kubb_ast.createSchema)({
116
+ type: "ref",
117
+ name: resolver.resolveResponseStatusTypedName(node, res.statusCode)
118
+ })
119
+ }))
120
+ });
121
+ }
122
+ /**
123
+ * Builds a `UnionSchemaNode` representing `<OperationId>Response` — all response types in union format.
124
+ * Returns `null` when the operation has no responses with schemas.
125
+ */
126
+ function buildResponseUnionSchemaNode({ node, resolver }) {
127
+ const responsesWithSchema = node.responses.filter((res) => res.schema);
128
+ if (responsesWithSchema.length === 0) return null;
129
+ return (0, _kubb_ast.createSchema)({
130
+ type: "union",
131
+ members: responsesWithSchema.map((res) => (0, _kubb_ast.createSchema)({
132
+ type: "ref",
133
+ name: resolver.resolveResponseStatusTypedName(node, res.statusCode)
134
+ }))
135
+ });
136
+ }
137
+ /**
138
+ * Builds an `ObjectSchemaNode` for a grouped parameters type (path/query/header) in legacy mode.
139
+ * Each property directly embeds the parameter's schema inline (not a ref).
140
+ * Used to generate `<OperationId>PathParams`, `<OperationId>QueryParams`, `<OperationId>HeaderParams`.
141
+ * @deprecated Legacy only — will be removed in v6.
142
+ */
143
+ function buildGroupedParamsSchema({ params, parentName }) {
144
+ return (0, _kubb_ast.createSchema)({
145
+ type: "object",
146
+ properties: params.map((param) => {
147
+ let schema = {
148
+ ...param.schema,
149
+ optional: !param.required
150
+ };
151
+ if ((0, _kubb_ast.narrowSchema)(schema, "enum") && !schema.name && parentName) schema = {
152
+ ...schema,
153
+ name: require_casing.pascalCase([
154
+ parentName,
155
+ param.name,
156
+ "enum"
157
+ ].join(" "))
158
+ };
159
+ return (0, _kubb_ast.createProperty)({
160
+ name: param.name,
161
+ schema
162
+ });
163
+ })
164
+ });
165
+ }
166
+ /**
167
+ * Builds the legacy wrapper `ObjectSchemaNode` for `<OperationId>Mutation` / `<OperationId>Query`.
168
+ * Structure: `{ Response, Request?, QueryParams?, PathParams?, HeaderParams?, Errors }`.
169
+ * Mirrors the v4 naming convention where this type acts as a namespace for the operation's shapes.
170
+ *
171
+ * @deprecated Legacy only — will be removed in v6.
172
+ */
173
+ function buildLegacyResponsesSchemaNode({ node, resolver }) {
174
+ const isGet = node.method.toLowerCase() === "get";
175
+ const successResponses = node.responses.filter((res) => {
176
+ const code = Number(res.statusCode);
177
+ return !Number.isNaN(code) && code >= 200 && code < 300;
178
+ });
179
+ const errorResponses = node.responses.filter((res) => res.statusCode === "default" || Number(res.statusCode) >= 400);
180
+ const responseSchema = successResponses.length > 0 ? successResponses.length === 1 ? (0, _kubb_ast.createSchema)({
181
+ type: "ref",
182
+ name: resolver.resolveResponseStatusTypedName(node, successResponses[0].statusCode)
183
+ }) : (0, _kubb_ast.createSchema)({
184
+ type: "union",
185
+ members: successResponses.map((res) => (0, _kubb_ast.createSchema)({
186
+ type: "ref",
187
+ name: resolver.resolveResponseStatusTypedName(node, res.statusCode)
188
+ }))
189
+ }) : (0, _kubb_ast.createSchema)({ type: "any" });
190
+ const errorsSchema = errorResponses.length > 0 ? errorResponses.length === 1 ? (0, _kubb_ast.createSchema)({
191
+ type: "ref",
192
+ name: resolver.resolveResponseStatusTypedName(node, errorResponses[0].statusCode)
193
+ }) : (0, _kubb_ast.createSchema)({
194
+ type: "union",
195
+ members: errorResponses.map((res) => (0, _kubb_ast.createSchema)({
196
+ type: "ref",
197
+ name: resolver.resolveResponseStatusTypedName(node, res.statusCode)
198
+ }))
199
+ }) : (0, _kubb_ast.createSchema)({ type: "any" });
200
+ const properties = [(0, _kubb_ast.createProperty)({
201
+ name: "Response",
202
+ schema: responseSchema
203
+ })];
204
+ if (!isGet && node.requestBody?.schema) properties.push((0, _kubb_ast.createProperty)({
205
+ name: "Request",
206
+ schema: (0, _kubb_ast.createSchema)({
207
+ type: "ref",
208
+ name: resolver.resolveDataTypedName(node)
209
+ })
210
+ }));
211
+ if (node.parameters.some((p) => p.in === "query") && resolver.resolveQueryParamsTypedName) properties.push((0, _kubb_ast.createProperty)({
212
+ name: "QueryParams",
213
+ schema: (0, _kubb_ast.createSchema)({
214
+ type: "ref",
215
+ name: resolver.resolveQueryParamsTypedName(node)
216
+ })
217
+ }));
218
+ if (node.parameters.some((p) => p.in === "path") && resolver.resolvePathParamsTypedName) properties.push((0, _kubb_ast.createProperty)({
219
+ name: "PathParams",
220
+ schema: (0, _kubb_ast.createSchema)({
221
+ type: "ref",
222
+ name: resolver.resolvePathParamsTypedName(node)
223
+ })
224
+ }));
225
+ if (node.parameters.some((p) => p.in === "header") && resolver.resolveHeaderParamsTypedName) properties.push((0, _kubb_ast.createProperty)({
226
+ name: "HeaderParams",
227
+ schema: (0, _kubb_ast.createSchema)({
228
+ type: "ref",
229
+ name: resolver.resolveHeaderParamsTypedName(node)
230
+ })
231
+ }));
232
+ properties.push((0, _kubb_ast.createProperty)({
233
+ name: "Errors",
234
+ schema: errorsSchema
235
+ }));
236
+ return (0, _kubb_ast.createSchema)({
237
+ type: "object",
238
+ properties
239
+ });
240
+ }
241
+ /**
242
+ * Builds the legacy response union for `<OperationId>MutationResponse` / `<OperationId>QueryResponse`.
243
+ * In legacy mode this is the **success** response only (not the full union including errors).
244
+ * Returns an `any` schema when there is no success response, matching v4 behavior.
245
+ * @deprecated Legacy only — will be removed in v6.
246
+ */
247
+ function buildLegacyResponseUnionSchemaNode({ node, resolver }) {
248
+ const successResponses = node.responses.filter((res) => {
249
+ const code = Number(res.statusCode);
250
+ return !Number.isNaN(code) && code >= 200 && code < 300;
251
+ });
252
+ if (successResponses.length === 0) return (0, _kubb_ast.createSchema)({ type: "any" });
253
+ if (successResponses.length === 1) return (0, _kubb_ast.createSchema)({
254
+ type: "ref",
255
+ name: resolver.resolveResponseStatusTypedName(node, successResponses[0].statusCode)
256
+ });
257
+ return (0, _kubb_ast.createSchema)({
258
+ type: "union",
259
+ members: successResponses.map((res) => (0, _kubb_ast.createSchema)({
260
+ type: "ref",
261
+ name: resolver.resolveResponseStatusTypedName(node, res.statusCode)
262
+ }))
263
+ });
264
+ }
265
+ /**
266
+ * Names unnamed enum nodes within a schema tree based on the parent type name.
267
+ * Used in legacy mode to ensure inline enums in response/request schemas get
268
+ * extracted as named enum declarations (e.g. `DeletePet200Enum`).
269
+ *
270
+ * @deprecated Legacy only — will be removed in v6.
271
+ */
272
+ function nameUnnamedEnums(node, parentName) {
273
+ return (0, _kubb_ast.transform)(node, {
274
+ schema(n) {
275
+ if (n.type === "enum" && !n.name) return {
276
+ ...n,
277
+ name: require_casing.pascalCase([parentName, "enum"].join(" "))
278
+ };
279
+ },
280
+ property(p) {
281
+ const enumNode = (0, _kubb_ast.narrowSchema)(p.schema, "enum");
282
+ if (enumNode && !enumNode.name) return {
283
+ ...p,
284
+ schema: {
285
+ ...enumNode,
286
+ name: require_casing.pascalCase([
287
+ parentName,
288
+ p.name,
289
+ "enum"
290
+ ].join(" "))
291
+ }
292
+ };
293
+ }
294
+ });
295
+ }
296
+ //#endregion
297
+ //#region src/generators/typeGenerator.tsx
298
+ const typeGenerator = (0, _kubb_core.defineGenerator)({
299
+ name: "typescript",
300
+ type: "react",
301
+ Operation({ node, adapter, options }) {
302
+ const { enumType, enumKeyCasing, optionalType, arrayType, syntaxType, paramsCasing, group, resolver, baseResolver, legacy } = options;
303
+ const { mode, getFile, resolveBanner, resolveFooter } = (0, _kubb_core_hooks.useKubb)();
304
+ const file = getFile({
305
+ name: node.operationId,
306
+ extname: ".ts",
307
+ mode,
308
+ options: { group: group ? group.type === "tag" ? { tag: node.tags[0] ?? "default" } : { path: node.path } : void 0 }
309
+ });
310
+ const params = (0, _kubb_ast.applyParamsCasing)(node.parameters, paramsCasing);
311
+ function renderSchemaType({ node: schemaNode, name, typedName, description, keysToOmit }) {
312
+ if (!schemaNode) return null;
313
+ const imports = adapter.getImports(schemaNode, (schemaName) => ({
314
+ name: resolver.default(schemaName, "type"),
315
+ path: getFile({
316
+ name: schemaName,
317
+ extname: ".ts",
318
+ mode
319
+ }).path
320
+ }));
321
+ return /* @__PURE__ */ (0, _kubb_react_fabric_jsx_runtime.jsxs)(_kubb_react_fabric_jsx_runtime.Fragment, { children: [mode === "split" && imports.map((imp) => /* @__PURE__ */ (0, _kubb_react_fabric_jsx_runtime.jsx)(_kubb_react_fabric.File.Import, {
322
+ root: file.path,
323
+ path: imp.path,
324
+ name: imp.name,
325
+ isTypeOnly: true
326
+ }, [
327
+ name,
328
+ imp.path,
329
+ imp.isTypeOnly
330
+ ].join("-"))), /* @__PURE__ */ (0, _kubb_react_fabric_jsx_runtime.jsx)(require_Type.Type, {
331
+ name,
332
+ typedName,
333
+ node: schemaNode,
334
+ description,
335
+ enumType,
336
+ enumKeyCasing,
337
+ optionalType,
338
+ arrayType,
339
+ syntaxType,
340
+ resolver,
341
+ keysToOmit,
342
+ legacy
343
+ })] });
344
+ }
345
+ const responseTypes = legacy ? node.responses.map((res) => {
346
+ const responseName = resolver.resolveResponseStatusName(node, res.statusCode);
347
+ const baseResponseName = (baseResolver ?? resolver).resolveResponseStatusName(node, res.statusCode);
348
+ return renderSchemaType({
349
+ node: res.schema ? nameUnnamedEnums(res.schema, baseResponseName) : res.schema,
350
+ name: responseName,
351
+ typedName: resolver.resolveResponseStatusTypedName(node, res.statusCode),
352
+ description: res.description,
353
+ keysToOmit: res.keysToOmit
354
+ });
355
+ }) : node.responses.map((res) => renderSchemaType({
356
+ node: res.schema,
357
+ name: resolver.resolveResponseStatusName(node, res.statusCode),
358
+ typedName: resolver.resolveResponseStatusTypedName(node, res.statusCode),
359
+ description: res.description,
360
+ keysToOmit: res.keysToOmit
361
+ }));
362
+ const requestType = node.requestBody?.schema ? renderSchemaType({
363
+ node: legacy ? nameUnnamedEnums(node.requestBody.schema, (baseResolver ?? resolver).resolveDataName(node)) : node.requestBody.schema,
364
+ name: resolver.resolveDataName(node),
365
+ typedName: resolver.resolveDataTypedName(node),
366
+ description: node.requestBody.description ?? node.requestBody.schema.description,
367
+ keysToOmit: node.requestBody.keysToOmit
368
+ }) : null;
369
+ if (legacy) {
370
+ const pathParams = params.filter((p) => p.in === "path");
371
+ const queryParams = params.filter((p) => p.in === "query");
372
+ const headerParams = params.filter((p) => p.in === "header");
373
+ const legacyParamTypes = [
374
+ pathParams.length > 0 ? renderSchemaType({
375
+ node: buildGroupedParamsSchema({
376
+ params: pathParams,
377
+ parentName: (baseResolver ?? resolver).resolvePathParamsName(node)
378
+ }),
379
+ name: resolver.resolvePathParamsName(node),
380
+ typedName: resolver.resolvePathParamsTypedName(node)
381
+ }) : null,
382
+ queryParams.length > 0 ? renderSchemaType({
383
+ node: buildGroupedParamsSchema({
384
+ params: queryParams,
385
+ parentName: (baseResolver ?? resolver).resolveQueryParamsName(node)
386
+ }),
387
+ name: resolver.resolveQueryParamsName(node),
388
+ typedName: resolver.resolveQueryParamsTypedName(node)
389
+ }) : null,
390
+ headerParams.length > 0 ? renderSchemaType({
391
+ node: buildGroupedParamsSchema({
392
+ params: headerParams,
393
+ parentName: (baseResolver ?? resolver).resolveHeaderParamsName(node)
394
+ }),
395
+ name: resolver.resolveHeaderParamsName(node),
396
+ typedName: resolver.resolveHeaderParamsTypedName(node)
397
+ }) : null
398
+ ];
399
+ const legacyResponsesType = renderSchemaType({
400
+ node: buildLegacyResponsesSchemaNode({
401
+ node,
402
+ resolver
403
+ }),
404
+ name: resolver.resolveResponsesName(node),
405
+ typedName: resolver.resolveResponsesTypedName(node)
406
+ });
407
+ const legacyResponseType = renderSchemaType({
408
+ node: buildLegacyResponseUnionSchemaNode({
409
+ node,
410
+ resolver
411
+ }),
412
+ name: resolver.resolveResponseName(node),
413
+ typedName: resolver.resolveResponseTypedName(node)
414
+ });
415
+ return /* @__PURE__ */ (0, _kubb_react_fabric_jsx_runtime.jsxs)(_kubb_react_fabric.File, {
416
+ baseName: file.baseName,
417
+ path: file.path,
418
+ meta: file.meta,
419
+ banner: resolveBanner(),
420
+ footer: resolveFooter(),
421
+ children: [
422
+ legacyParamTypes,
423
+ responseTypes,
424
+ requestType,
425
+ legacyResponseType,
426
+ legacyResponsesType
427
+ ]
428
+ });
429
+ }
430
+ const paramTypes = params.map((param) => renderSchemaType({
431
+ node: param.schema,
432
+ name: resolver.resolveParamName(node, param),
433
+ typedName: resolver.resolveParamTypedName(node, param)
434
+ }));
435
+ const queryParamsList = params.filter((p) => p.in === "query");
436
+ const queryParamsType = queryParamsList.length > 0 ? renderSchemaType({
437
+ node: buildParamsSchema({
438
+ params: queryParamsList,
439
+ node,
440
+ resolver
441
+ }),
442
+ name: resolver.resolveQueryParamsName(node),
443
+ typedName: resolver.resolveQueryParamsTypedName(node)
444
+ }) : null;
445
+ const dataType = renderSchemaType({
446
+ node: buildDataSchemaNode({
447
+ node: {
448
+ ...node,
449
+ parameters: params
450
+ },
451
+ resolver
452
+ }),
453
+ name: resolver.resolveRequestConfigName(node),
454
+ typedName: resolver.resolveRequestConfigTypedName(node)
455
+ });
456
+ const responsesType = renderSchemaType({
457
+ node: buildResponsesSchemaNode({
458
+ node,
459
+ resolver
460
+ }),
461
+ name: resolver.resolveResponsesName(node),
462
+ typedName: resolver.resolveResponsesTypedName(node)
463
+ });
464
+ const responseType = renderSchemaType({
465
+ node: buildResponseUnionSchemaNode({
466
+ node,
467
+ resolver
468
+ }),
469
+ name: resolver.resolveResponseName(node),
470
+ typedName: resolver.resolveResponseTypedName(node),
471
+ description: "Union of all possible responses"
472
+ });
473
+ return /* @__PURE__ */ (0, _kubb_react_fabric_jsx_runtime.jsxs)(_kubb_react_fabric.File, {
474
+ baseName: file.baseName,
475
+ path: file.path,
476
+ meta: file.meta,
477
+ banner: resolveBanner(),
478
+ footer: resolveFooter(),
479
+ children: [
480
+ paramTypes,
481
+ queryParamsType,
482
+ responseTypes,
483
+ requestType,
484
+ dataType,
485
+ responsesType,
486
+ responseType
487
+ ]
488
+ });
489
+ },
490
+ Schema({ node, adapter, options }) {
491
+ const { enumType, enumKeyCasing, syntaxType, optionalType, arrayType, resolver, legacy } = options;
492
+ const { mode, getFile, resolveBanner, resolveFooter } = (0, _kubb_core_hooks.useKubb)();
493
+ if (!node.name) return;
494
+ const imports = adapter.getImports(node, (schemaName) => ({
495
+ name: resolver.default(schemaName, "type"),
496
+ path: getFile({
497
+ name: schemaName,
498
+ extname: ".ts",
499
+ mode
500
+ }).path
501
+ }));
502
+ const isEnumSchema = node.type === "enum";
503
+ const typedName = require_Type.ENUM_TYPES_WITH_KEY_SUFFIX.has(enumType) && isEnumSchema ? resolver.resolveEnumKeyTypedName(node) : resolver.resolveTypedName(node.name);
504
+ const type = {
505
+ name: resolver.resolveName(node.name),
506
+ typedName,
507
+ file: getFile({
508
+ name: node.name,
509
+ extname: ".ts",
510
+ mode
511
+ })
512
+ };
513
+ return /* @__PURE__ */ (0, _kubb_react_fabric_jsx_runtime.jsxs)(_kubb_react_fabric.File, {
514
+ baseName: type.file.baseName,
515
+ path: type.file.path,
516
+ meta: type.file.meta,
517
+ banner: resolveBanner(),
518
+ footer: resolveFooter(),
519
+ children: [mode === "split" && imports.map((imp) => /* @__PURE__ */ (0, _kubb_react_fabric_jsx_runtime.jsx)(_kubb_react_fabric.File.Import, {
520
+ root: type.file.path,
521
+ path: imp.path,
522
+ name: imp.name,
523
+ isTypeOnly: true
524
+ }, [
525
+ node.name,
526
+ imp.path,
527
+ imp.isTypeOnly
528
+ ].join("-"))), /* @__PURE__ */ (0, _kubb_react_fabric_jsx_runtime.jsx)(require_Type.Type, {
529
+ name: type.name,
530
+ typedName: type.typedName,
531
+ node,
532
+ enumType,
533
+ enumKeyCasing,
534
+ optionalType,
535
+ arrayType,
536
+ syntaxType,
537
+ resolver,
538
+ legacy
539
+ })]
540
+ });
541
+ }
542
+ });
543
+ //#endregion
544
+ Object.defineProperty(exports, "typeGenerator", {
545
+ enumerable: true,
546
+ get: function() {
547
+ return typeGenerator;
548
+ }
549
+ });
550
+
551
+ //# sourceMappingURL=generators-CX3cSSdF.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"generators-CX3cSSdF.cjs","names":["pascalCase","File","Type","ENUM_TYPES_WITH_KEY_SUFFIX"],"sources":["../src/generators/utils.ts","../src/generators/typeGenerator.tsx"],"sourcesContent":["import { pascalCase } from '@internals/utils'\nimport { createProperty, createSchema, narrowSchema, transform } from '@kubb/ast'\nimport type { OperationNode, ParameterNode, SchemaNode } from '@kubb/ast/types'\nimport type { ResolverTs } from '../types.ts'\n\ntype BuildParamsSchemaOptions = {\n params: Array<ParameterNode>\n node: OperationNode\n resolver: ResolverTs\n}\n\n/**\n * Builds an `ObjectSchemaNode` for a group of parameters (path/query/header).\n * Each property is a `ref` schema pointing to the individually-resolved parameter type.\n * The ref name includes the parameter location so generated type names follow\n * the `<OperationId><Location><ParamName>` convention.\n */\nexport function buildParamsSchema({ params, node, resolver }: BuildParamsSchemaOptions): SchemaNode {\n return createSchema({\n type: 'object',\n properties: params.map((param) =>\n createProperty({\n name: param.name,\n schema: createSchema({\n type: 'ref',\n name: resolver.resolveParamName(node, param),\n optional: !param.required,\n }),\n }),\n ),\n })\n}\n\ntype BuildOperationSchemaOptions = {\n node: OperationNode\n resolver: ResolverTs\n}\n\n/**\n * Builds an `ObjectSchemaNode` representing the `<OperationId>RequestConfig` type:\n * - `data` → request body ref (optional) or `never`\n * - `pathParams` → inline object of path param refs, or `never`\n * - `queryParams` → inline object of query param refs (optional), or `never`\n * - `headerParams` → inline object of header param refs (optional), or `never`\n * - `url` → Express-style template literal (plugin-ts extension, handled by printer)\n */\nexport function buildDataSchemaNode({ node, resolver }: BuildOperationSchemaOptions): SchemaNode {\n const pathParams = node.parameters.filter((p) => p.in === 'path')\n const queryParams = node.parameters.filter((p) => p.in === 'query')\n const headerParams = node.parameters.filter((p) => p.in === 'header')\n\n return createSchema({\n type: 'object',\n deprecated: node.deprecated,\n properties: [\n createProperty({\n name: 'data',\n schema: node.requestBody?.schema\n ? createSchema({\n type: 'ref',\n name: resolver.resolveDataTypedName(node),\n optional: true,\n })\n : createSchema({ type: 'never', optional: true }),\n }),\n createProperty({\n name: 'pathParams',\n schema: pathParams.length > 0 ? buildParamsSchema({ params: pathParams, node, resolver }) : createSchema({ type: 'never', optional: true }),\n }),\n createProperty({\n name: 'queryParams',\n schema:\n queryParams.length > 0\n ? createSchema({ ...buildParamsSchema({ params: queryParams, node, resolver }), optional: true })\n : createSchema({ type: 'never', optional: true }),\n }),\n createProperty({\n name: 'headerParams',\n schema:\n headerParams.length > 0\n ? createSchema({ ...buildParamsSchema({ params: headerParams, node, resolver }), optional: true })\n : createSchema({ type: 'never', optional: true }),\n }),\n createProperty({\n name: 'url',\n schema: createSchema({ type: 'url', path: node.path }),\n }),\n ],\n })\n}\n\n/**\n * Builds an `ObjectSchemaNode` representing `<OperationId>Responses` — keyed by HTTP status code.\n * Numeric status codes produce unquoted numeric keys (e.g. `200:`).\n * All responses are included; those without a schema are represented as a ref to a `never` type.\n */\nexport function buildResponsesSchemaNode({ node, resolver }: BuildOperationSchemaOptions): SchemaNode | null {\n if (node.responses.length === 0) {\n return null\n }\n\n return createSchema({\n type: 'object',\n properties: node.responses.map((res) =>\n createProperty({\n name: String(res.statusCode),\n schema: createSchema({\n type: 'ref',\n name: resolver.resolveResponseStatusTypedName(node, res.statusCode),\n }),\n }),\n ),\n })\n}\n\n/**\n * Builds a `UnionSchemaNode` representing `<OperationId>Response` — all response types in union format.\n * Returns `null` when the operation has no responses with schemas.\n */\nexport function buildResponseUnionSchemaNode({ node, resolver }: BuildOperationSchemaOptions): SchemaNode | null {\n const responsesWithSchema = node.responses.filter((res) => res.schema)\n\n if (responsesWithSchema.length === 0) {\n return null\n }\n\n return createSchema({\n type: 'union',\n members: responsesWithSchema.map((res) =>\n createSchema({\n type: 'ref',\n name: resolver.resolveResponseStatusTypedName(node, res.statusCode),\n }),\n ),\n })\n}\n\ntype BuildGroupedParamsSchemaOptions = {\n params: Array<ParameterNode>\n /**\n * Parent type name (e.g. `FindPetsByStatusQueryParams`) used to derive enum names\n * for inline enum properties (e.g. `FindPetsByStatusQueryParamsStatusEnum`).\n */\n parentName?: string\n}\n\n/**\n * Builds an `ObjectSchemaNode` for a grouped parameters type (path/query/header) in legacy mode.\n * Each property directly embeds the parameter's schema inline (not a ref).\n * Used to generate `<OperationId>PathParams`, `<OperationId>QueryParams`, `<OperationId>HeaderParams`.\n * @deprecated Legacy only — will be removed in v6.\n */\nexport function buildGroupedParamsSchema({ params, parentName }: BuildGroupedParamsSchemaOptions): SchemaNode {\n return createSchema({\n type: 'object',\n properties: params.map((param) => {\n let schema = { ...param.schema, optional: !param.required } as SchemaNode\n // Name unnamed enum properties so they are emitted as enum declarations\n if (narrowSchema(schema, 'enum') && !schema.name && parentName) {\n schema = { ...schema, name: pascalCase([parentName, param.name, 'enum'].join(' ')) }\n }\n return createProperty({\n name: param.name,\n schema,\n })\n }),\n })\n}\n\n/**\n * Builds the legacy wrapper `ObjectSchemaNode` for `<OperationId>Mutation` / `<OperationId>Query`.\n * Structure: `{ Response, Request?, QueryParams?, PathParams?, HeaderParams?, Errors }`.\n * Mirrors the v4 naming convention where this type acts as a namespace for the operation's shapes.\n *\n * @deprecated Legacy only — will be removed in v6.\n */\nexport function buildLegacyResponsesSchemaNode({ node, resolver }: BuildOperationSchemaOptions): SchemaNode | null {\n const isGet = node.method.toLowerCase() === 'get'\n const successResponses = node.responses.filter((res) => {\n const code = Number(res.statusCode)\n return !Number.isNaN(code) && code >= 200 && code < 300\n })\n const errorResponses = node.responses.filter((res) => res.statusCode === 'default' || Number(res.statusCode) >= 400)\n\n const responseSchema =\n successResponses.length > 0\n ? successResponses.length === 1\n ? createSchema({ type: 'ref', name: resolver.resolveResponseStatusTypedName(node, successResponses[0]!.statusCode) })\n : createSchema({\n type: 'union',\n members: successResponses.map((res) => createSchema({ type: 'ref', name: resolver.resolveResponseStatusTypedName(node, res.statusCode) })),\n })\n : createSchema({ type: 'any' })\n\n const errorsSchema =\n errorResponses.length > 0\n ? errorResponses.length === 1\n ? createSchema({ type: 'ref', name: resolver.resolveResponseStatusTypedName(node, errorResponses[0]!.statusCode) })\n : createSchema({\n type: 'union',\n members: errorResponses.map((res) => createSchema({ type: 'ref', name: resolver.resolveResponseStatusTypedName(node, res.statusCode) })),\n })\n : createSchema({ type: 'any' })\n\n const properties = [createProperty({ name: 'Response', schema: responseSchema })]\n\n if (!isGet && node.requestBody?.schema) {\n properties.push(\n createProperty({\n name: 'Request',\n schema: createSchema({ type: 'ref', name: resolver.resolveDataTypedName(node) }),\n }),\n )\n }\n\n if (node.parameters.some((p) => p.in === 'query') && resolver.resolveQueryParamsTypedName) {\n properties.push(\n createProperty({\n name: 'QueryParams',\n schema: createSchema({ type: 'ref', name: resolver.resolveQueryParamsTypedName(node) }),\n }),\n )\n }\n\n if (node.parameters.some((p) => p.in === 'path') && resolver.resolvePathParamsTypedName) {\n properties.push(\n createProperty({\n name: 'PathParams',\n schema: createSchema({ type: 'ref', name: resolver.resolvePathParamsTypedName(node) }),\n }),\n )\n }\n\n if (node.parameters.some((p) => p.in === 'header') && resolver.resolveHeaderParamsTypedName) {\n properties.push(\n createProperty({\n name: 'HeaderParams',\n schema: createSchema({ type: 'ref', name: resolver.resolveHeaderParamsTypedName(node) }),\n }),\n )\n }\n\n properties.push(createProperty({ name: 'Errors', schema: errorsSchema }))\n\n return createSchema({ type: 'object', properties })\n}\n\n/**\n * Builds the legacy response union for `<OperationId>MutationResponse` / `<OperationId>QueryResponse`.\n * In legacy mode this is the **success** response only (not the full union including errors).\n * Returns an `any` schema when there is no success response, matching v4 behavior.\n * @deprecated Legacy only — will be removed in v6.\n */\nexport function buildLegacyResponseUnionSchemaNode({ node, resolver }: BuildOperationSchemaOptions): SchemaNode {\n const successResponses = node.responses.filter((res) => {\n const code = Number(res.statusCode)\n return !Number.isNaN(code) && code >= 200 && code < 300\n })\n\n if (successResponses.length === 0) {\n return createSchema({ type: 'any' })\n }\n\n if (successResponses.length === 1) {\n return createSchema({ type: 'ref', name: resolver.resolveResponseStatusTypedName(node, successResponses[0]!.statusCode) })\n }\n\n return createSchema({\n type: 'union',\n members: successResponses.map((res) => createSchema({ type: 'ref', name: resolver.resolveResponseStatusTypedName(node, res.statusCode) })),\n })\n}\n\n/**\n * Names unnamed enum nodes within a schema tree based on the parent type name.\n * Used in legacy mode to ensure inline enums in response/request schemas get\n * extracted as named enum declarations (e.g. `DeletePet200Enum`).\n *\n * @deprecated Legacy only — will be removed in v6.\n */\nexport function nameUnnamedEnums(node: SchemaNode, parentName: string): SchemaNode {\n return transform(node, {\n schema(n) {\n if (n.type === 'enum' && !n.name) {\n return { ...n, name: pascalCase([parentName, 'enum'].join(' ')) }\n }\n return undefined\n },\n property(p) {\n const enumNode = narrowSchema(p.schema, 'enum')\n if (enumNode && !enumNode.name) {\n return {\n ...p,\n schema: { ...enumNode, name: pascalCase([parentName, p.name, 'enum'].join(' ')) },\n }\n }\n return undefined\n },\n })\n}\n","import { applyParamsCasing } from '@kubb/ast'\nimport type { SchemaNode } from '@kubb/ast/types'\nimport { defineGenerator } from '@kubb/core'\nimport { useKubb } from '@kubb/core/hooks'\nimport { File } from '@kubb/react-fabric'\nimport { Type } from '../components/Type.tsx'\nimport { ENUM_TYPES_WITH_KEY_SUFFIX } from '../constants.ts'\nimport type { PluginTs } from '../types'\nimport {\n buildDataSchemaNode,\n buildGroupedParamsSchema,\n buildLegacyResponsesSchemaNode,\n buildLegacyResponseUnionSchemaNode,\n buildParamsSchema,\n buildResponsesSchemaNode,\n buildResponseUnionSchemaNode,\n nameUnnamedEnums,\n} from './utils.ts'\n\nexport const typeGenerator = defineGenerator<PluginTs>({\n name: 'typescript',\n type: 'react',\n Operation({ node, adapter, options }) {\n const { enumType, enumKeyCasing, optionalType, arrayType, syntaxType, paramsCasing, group, resolver, baseResolver, legacy } = options\n const { mode, getFile, resolveBanner, resolveFooter } = useKubb<PluginTs>()\n\n const file = getFile({\n name: node.operationId,\n extname: '.ts',\n mode,\n options: {\n group: group ? (group.type === 'tag' ? { tag: node.tags[0] ?? 'default' } : { path: node.path }) : undefined,\n },\n })\n const params = applyParamsCasing(node.parameters, paramsCasing)\n\n function renderSchemaType({\n node: schemaNode,\n name,\n typedName,\n description,\n keysToOmit,\n }: {\n node: SchemaNode | null\n name: string\n typedName: string\n description?: string\n keysToOmit?: Array<string>\n }) {\n if (!schemaNode) {\n return null\n }\n\n const imports = adapter.getImports(schemaNode, (schemaName) => ({\n name: resolver.default(schemaName, 'type'),\n path: getFile({ name: schemaName, extname: '.ts', mode }).path,\n }))\n\n return (\n <>\n {mode === 'split' &&\n imports.map((imp) => <File.Import key={[name, imp.path, imp.isTypeOnly].join('-')} root={file.path} path={imp.path} name={imp.name} isTypeOnly />)}\n <Type\n name={name}\n typedName={typedName}\n node={schemaNode}\n description={description}\n enumType={enumType}\n enumKeyCasing={enumKeyCasing}\n optionalType={optionalType}\n arrayType={arrayType}\n syntaxType={syntaxType}\n resolver={resolver}\n keysToOmit={keysToOmit}\n legacy={legacy}\n />\n </>\n )\n }\n\n const responseTypes = legacy\n ? node.responses.map((res) => {\n const responseName = resolver.resolveResponseStatusName(node, res.statusCode)\n const baseResponseName = (baseResolver ?? resolver).resolveResponseStatusName(node, res.statusCode)\n\n return renderSchemaType({\n node: res.schema ? nameUnnamedEnums(res.schema, baseResponseName) : res.schema,\n name: responseName,\n typedName: resolver.resolveResponseStatusTypedName(node, res.statusCode),\n description: res.description,\n keysToOmit: res.keysToOmit,\n })\n })\n : node.responses.map((res) =>\n renderSchemaType({\n node: res.schema,\n name: resolver.resolveResponseStatusName(node, res.statusCode),\n typedName: resolver.resolveResponseStatusTypedName(node, res.statusCode),\n description: res.description,\n keysToOmit: res.keysToOmit,\n }),\n )\n\n const requestType = node.requestBody?.schema\n ? renderSchemaType({\n node: legacy ? nameUnnamedEnums(node.requestBody.schema, (baseResolver ?? resolver).resolveDataName(node)) : node.requestBody.schema,\n name: resolver.resolveDataName(node),\n typedName: resolver.resolveDataTypedName(node),\n description: node.requestBody.description ?? node.requestBody.schema.description,\n keysToOmit: node.requestBody.keysToOmit,\n })\n : null\n\n if (legacy) {\n const pathParams = params.filter((p) => p.in === 'path')\n const queryParams = params.filter((p) => p.in === 'query')\n const headerParams = params.filter((p) => p.in === 'header')\n\n const legacyParamTypes = [\n pathParams.length > 0\n ? renderSchemaType({\n node: buildGroupedParamsSchema({ params: pathParams, parentName: (baseResolver ?? resolver).resolvePathParamsName!(node) }),\n name: resolver.resolvePathParamsName!(node),\n typedName: resolver.resolvePathParamsTypedName!(node),\n })\n : null,\n queryParams.length > 0\n ? renderSchemaType({\n node: buildGroupedParamsSchema({ params: queryParams, parentName: (baseResolver ?? resolver).resolveQueryParamsName!(node) }),\n name: resolver.resolveQueryParamsName!(node),\n typedName: resolver.resolveQueryParamsTypedName!(node),\n })\n : null,\n headerParams.length > 0\n ? renderSchemaType({\n node: buildGroupedParamsSchema({ params: headerParams, parentName: (baseResolver ?? resolver).resolveHeaderParamsName!(node) }),\n name: resolver.resolveHeaderParamsName!(node),\n typedName: resolver.resolveHeaderParamsTypedName!(node),\n })\n : null,\n ]\n\n const legacyResponsesType = renderSchemaType({\n node: buildLegacyResponsesSchemaNode({ node, resolver }),\n name: resolver.resolveResponsesName(node),\n typedName: resolver.resolveResponsesTypedName(node),\n })\n\n const legacyResponseType = renderSchemaType({\n node: buildLegacyResponseUnionSchemaNode({ node, resolver }),\n name: resolver.resolveResponseName(node),\n typedName: resolver.resolveResponseTypedName(node),\n })\n\n return (\n <File baseName={file.baseName} path={file.path} meta={file.meta} banner={resolveBanner()} footer={resolveFooter()}>\n {legacyParamTypes}\n {responseTypes}\n {requestType}\n {legacyResponseType}\n {legacyResponsesType}\n </File>\n )\n }\n\n const paramTypes = params.map((param) =>\n renderSchemaType({\n node: param.schema,\n name: resolver.resolveParamName(node, param),\n typedName: resolver.resolveParamTypedName(node, param),\n }),\n )\n\n const queryParamsList = params.filter((p) => p.in === 'query')\n const queryParamsType =\n queryParamsList.length > 0\n ? renderSchemaType({\n node: buildParamsSchema({ params: queryParamsList, node, resolver }),\n name: resolver.resolveQueryParamsName!(node),\n typedName: resolver.resolveQueryParamsTypedName!(node),\n })\n : null\n\n const dataType = renderSchemaType({\n node: buildDataSchemaNode({ node: { ...node, parameters: params }, resolver }),\n name: resolver.resolveRequestConfigName(node),\n typedName: resolver.resolveRequestConfigTypedName(node),\n })\n\n const responsesType = renderSchemaType({\n node: buildResponsesSchemaNode({ node, resolver }),\n name: resolver.resolveResponsesName(node),\n typedName: resolver.resolveResponsesTypedName(node),\n })\n\n const responseType = renderSchemaType({\n node: buildResponseUnionSchemaNode({ node, resolver }),\n name: resolver.resolveResponseName(node),\n typedName: resolver.resolveResponseTypedName(node),\n description: 'Union of all possible responses',\n })\n\n return (\n <File baseName={file.baseName} path={file.path} meta={file.meta} banner={resolveBanner()} footer={resolveFooter()}>\n {paramTypes}\n {queryParamsType}\n {responseTypes}\n {requestType}\n {dataType}\n {responsesType}\n {responseType}\n </File>\n )\n },\n Schema({ node, adapter, options }) {\n const { enumType, enumKeyCasing, syntaxType, optionalType, arrayType, resolver, legacy } = options\n const { mode, getFile, resolveBanner, resolveFooter } = useKubb<PluginTs>()\n\n if (!node.name) {\n return\n }\n\n const imports = adapter.getImports(node, (schemaName) => ({\n name: resolver.default(schemaName, 'type'),\n path: getFile({ name: schemaName, extname: '.ts', mode }).path,\n }))\n\n const isEnumSchema = node.type === 'enum'\n\n const typedName = ENUM_TYPES_WITH_KEY_SUFFIX.has(enumType) && isEnumSchema ? resolver.resolveEnumKeyTypedName(node) : resolver.resolveTypedName(node.name)\n\n const type = {\n name: resolver.resolveName(node.name),\n typedName,\n file: getFile({ name: node.name, extname: '.ts', mode }),\n } as const\n\n return (\n <File baseName={type.file.baseName} path={type.file.path} meta={type.file.meta} banner={resolveBanner()} footer={resolveFooter()}>\n {mode === 'split' &&\n imports.map((imp) => (\n <File.Import key={[node.name, imp.path, imp.isTypeOnly].join('-')} root={type.file.path} path={imp.path} name={imp.name} isTypeOnly />\n ))}\n <Type\n name={type.name}\n typedName={type.typedName}\n node={node}\n enumType={enumType}\n enumKeyCasing={enumKeyCasing}\n optionalType={optionalType}\n arrayType={arrayType}\n syntaxType={syntaxType}\n resolver={resolver}\n legacy={legacy}\n />\n </File>\n )\n },\n})\n"],"mappings":"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"}