@kubb/plugin-faker 3.0.0-alpha.15 → 3.0.0-alpha.16

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 (54) hide show
  1. package/dist/chunk-7JKM5LCT.cjs +310 -0
  2. package/dist/chunk-7JKM5LCT.cjs.map +1 -0
  3. package/dist/chunk-CJMJFFHG.cjs +110 -0
  4. package/dist/chunk-CJMJFFHG.cjs.map +1 -0
  5. package/dist/chunk-JE7K2NAC.js +108 -0
  6. package/dist/chunk-JE7K2NAC.js.map +1 -0
  7. package/dist/chunk-Q5K4KJXX.js +304 -0
  8. package/dist/chunk-Q5K4KJXX.js.map +1 -0
  9. package/dist/components.cjs +4 -530
  10. package/dist/components.cjs.map +1 -1
  11. package/dist/components.d.cts +16 -18
  12. package/dist/components.d.ts +16 -18
  13. package/dist/components.js +1 -528
  14. package/dist/components.js.map +1 -1
  15. package/dist/generators.cjs +13 -0
  16. package/dist/generators.cjs.map +1 -0
  17. package/dist/generators.d.cts +9 -0
  18. package/dist/generators.d.ts +9 -0
  19. package/dist/generators.js +4 -0
  20. package/dist/generators.js.map +1 -0
  21. package/dist/index.cjs +12 -430
  22. package/dist/index.cjs.map +1 -1
  23. package/dist/index.d.cts +5 -125
  24. package/dist/index.d.ts +5 -125
  25. package/dist/index.js +13 -430
  26. package/dist/index.js.map +1 -1
  27. package/dist/types-DrJPCRvZ.d.cts +125 -0
  28. package/dist/types-DrJPCRvZ.d.ts +125 -0
  29. package/package.json +21 -13
  30. package/src/components/Faker.tsx +80 -0
  31. package/src/components/index.ts +1 -2
  32. package/src/generators/__snapshots__/createPet.ts +26 -0
  33. package/src/generators/__snapshots__/createPetSeed.ts +30 -0
  34. package/src/generators/__snapshots__/createPetUnknownTypeAny.ts +26 -0
  35. package/src/generators/__snapshots__/deletePet.ts +3 -0
  36. package/src/generators/__snapshots__/enumNames.ts +5 -0
  37. package/src/generators/__snapshots__/enumVarNames.ts +5 -0
  38. package/src/generators/__snapshots__/getPets.ts +29 -0
  39. package/src/generators/__snapshots__/pet.ts +15 -0
  40. package/src/generators/__snapshots__/petWithDateString.ts +15 -0
  41. package/src/generators/__snapshots__/petWithDayjs.ts +16 -0
  42. package/src/generators/__snapshots__/petWithMapper.ts +15 -0
  43. package/src/generators/__snapshots__/petWithRandExp.ts +16 -0
  44. package/src/generators/__snapshots__/pets.ts +5 -0
  45. package/src/generators/__snapshots__/showPetById.ts +29 -0
  46. package/src/generators/fakerGenerator.tsx +135 -0
  47. package/src/generators/index.ts +1 -0
  48. package/src/parser/index.ts +22 -12
  49. package/src/plugin.ts +7 -10
  50. package/src/types.ts +17 -17
  51. package/src/OperationGenerator.tsx +0 -31
  52. package/src/SchemaGenerator.tsx +0 -31
  53. package/src/components/OperationSchema.tsx +0 -81
  54. package/src/components/Schema.tsx +0 -148
@@ -1,538 +1,12 @@
1
1
  'use strict';
2
2
 
3
- var components = require('@kubb/plugin-oas/components');
4
- var hooks = require('@kubb/plugin-oas/hooks');
5
- var pluginTs = require('@kubb/plugin-ts');
6
- var react = require('@kubb/react');
7
- var pluginOas = require('@kubb/plugin-oas');
8
- var transformers = require('@kubb/core/transformers');
9
- var path = require('path');
10
- var core = require('@kubb/core');
11
- var utils = require('@kubb/core/utils');
12
- var jsxRuntime = require('@kubb/react/jsx-runtime');
3
+ var chunk7JKM5LCT_cjs = require('./chunk-7JKM5LCT.cjs');
13
4
 
14
- function _interopDefault (e) { return e && e.__esModule ? e : { default: e }; }
15
5
 
16
- var transformers__default = /*#__PURE__*/_interopDefault(transformers);
17
- var path__default = /*#__PURE__*/_interopDefault(path);
18
6
 
19
- // src/components/OperationSchema.tsx
20
- var fakerKeywordMapper = {
21
- any: () => "undefined",
22
- unknown: () => "unknown",
23
- number: (min, max) => {
24
- if (max !== void 0 && min !== void 0) {
25
- return `faker.number.float({ min: ${min}, max: ${max} })`;
26
- }
27
- if (min !== void 0) {
28
- return `faker.number.float({ min: ${min} })`;
29
- }
30
- if (max !== void 0) {
31
- return `faker.number.float({ max: ${max} })`;
32
- }
33
- return "faker.number.float()";
34
- },
35
- integer: (min, max) => {
36
- if (max !== void 0 && min !== void 0) {
37
- return `faker.number.int({ min: ${min}, max: ${max} })`;
38
- }
39
- if (min !== void 0) {
40
- return `faker.number.int({ min: ${min} })`;
41
- }
42
- if (max !== void 0) {
43
- return `faker.number.int({ max: ${max} })`;
44
- }
45
- return "faker.number.int()";
46
- },
47
- string: (min, max) => {
48
- if (max !== void 0 && min !== void 0) {
49
- return `faker.string.alpha({ length: { min: ${min}, max: ${max} } })`;
50
- }
51
- if (min !== void 0) {
52
- return `faker.string.alpha({ length: { min: ${min} } })`;
53
- }
54
- if (max !== void 0) {
55
- return `faker.string.alpha({ length: { max: ${max} } })`;
56
- }
57
- return "faker.string.alpha()";
58
- },
59
- boolean: () => "faker.datatype.boolean()",
60
- undefined: () => "undefined",
61
- null: () => "null",
62
- array: (items = []) => `faker.helpers.arrayElements([${items.join(", ")}]) as any`,
63
- tuple: (items = []) => `faker.helpers.arrayElements([${items.join(", ")}]) as any`,
64
- enum: (items = []) => `faker.helpers.arrayElement<any>([${items.join(", ")}])`,
65
- union: (items = []) => `faker.helpers.arrayElement<any>([${items.join(", ")}])`,
66
- /**
67
- * ISO 8601
68
- */
69
- datetime: () => "faker.date.anytime().toISOString()",
70
- /**
71
- * Type `'date'` Date
72
- * Type `'string'` ISO date format (YYYY-MM-DD)
73
- * @default ISO date format (YYYY-MM-DD)
74
- */
75
- date: (type = "string", parser) => {
76
- if (type === "string") {
77
- if (parser) {
78
- return `${parser}(faker.date.anytime()).format("YYYY-MM-DD")`;
79
- }
80
- return "faker.date.anytime().toString()";
81
- }
82
- return "faker.date.anytime()";
83
- },
84
- /**
85
- * Type `'date'` Date
86
- * Type `'string'` ISO time format (HH:mm:ss[.SSSSSS])
87
- * @default ISO time format (HH:mm:ss[.SSSSSS])
88
- */
89
- time: (type = "string", parser) => {
90
- if (type === "string") {
91
- if (parser) {
92
- return `${parser}(faker.date.anytime()).format("HH:mm:ss")`;
93
- }
94
- return "faker.date.anytime().toString()";
95
- }
96
- return "faker.date.anytime()";
97
- },
98
- uuid: () => "faker.string.uuid()",
99
- url: () => "faker.internet.url()",
100
- and: (items = []) => `Object.assign({}, ${items.join(", ")})`,
101
- object: () => "object",
102
- ref: () => "ref",
103
- matches: (value = "", regexGenerator = "faker") => {
104
- if (regexGenerator === "randexp") {
105
- return `${transformers__default.default.toRegExpString(value, "RandExp")}.gen()`;
106
- }
107
- return `faker.helpers.fromRegExp(${transformers__default.default.toRegExpString(value)})`;
108
- },
109
- email: () => "faker.internet.email()",
110
- firstName: () => "faker.person.firstName()",
111
- lastName: () => "faker.person.lastName()",
112
- password: () => "faker.internet.password()",
113
- phone: () => "faker.phone.number()",
114
- blob: () => "faker.image.imageUrl() as unknown as Blob",
115
- default: void 0,
116
- describe: void 0,
117
- const: (value) => value ?? "",
118
- max: void 0,
119
- min: void 0,
120
- nullable: void 0,
121
- nullish: void 0,
122
- optional: void 0,
123
- readOnly: void 0,
124
- strict: void 0,
125
- deprecated: void 0,
126
- example: void 0,
127
- schema: void 0,
128
- catchall: void 0,
129
- name: void 0
130
- };
131
- function schemaKeywordsorter(a, b) {
132
- if (b.keyword === "null") {
133
- return -1;
134
- }
135
- return 0;
136
- }
137
- function joinItems(items) {
138
- switch (items.length) {
139
- case 0:
140
- return "undefined";
141
- case 1:
142
- return items[0];
143
- default:
144
- return fakerKeywordMapper.union(items);
145
- }
146
- }
147
- function parse(parent, current, options) {
148
- const value = fakerKeywordMapper[current.keyword];
149
- if (!value) {
150
- return void 0;
151
- }
152
- if (pluginOas.isKeyword(current, pluginOas.schemaKeywords.union)) {
153
- return fakerKeywordMapper.union(current.args.map((schema) => parse(current, schema, { ...options, withData: false })).filter(Boolean));
154
- }
155
- if (pluginOas.isKeyword(current, pluginOas.schemaKeywords.and)) {
156
- return fakerKeywordMapper.and(current.args.map((schema) => parse(current, schema, { ...options, withData: false })).filter(Boolean));
157
- }
158
- if (pluginOas.isKeyword(current, pluginOas.schemaKeywords.array)) {
159
- return fakerKeywordMapper.array(current.args.items.map((schema) => parse(current, schema, { ...options, withData: false })).filter(Boolean));
160
- }
161
- if (pluginOas.isKeyword(current, pluginOas.schemaKeywords.enum)) {
162
- return fakerKeywordMapper.enum(
163
- current.args.items.map((schema) => {
164
- if (schema.format === "number") {
165
- return schema.name;
166
- }
167
- return transformers__default.default.stringify(schema.name);
168
- })
169
- );
170
- }
171
- if (pluginOas.isKeyword(current, pluginOas.schemaKeywords.ref)) {
172
- if (!current.args?.name) {
173
- throw new Error(`Name not defined for keyword ${current.keyword}`);
174
- }
175
- if (options.withData) {
176
- return `${current.args.name}(data)`;
177
- }
178
- return `${current.args.name}()`;
179
- }
180
- if (pluginOas.isKeyword(current, pluginOas.schemaKeywords.object)) {
181
- const argsObject = Object.entries(current.args?.properties || {}).filter((item) => {
182
- const schema = item[1];
183
- return schema && typeof schema.map === "function";
184
- }).map(([name, schemas]) => {
185
- const nameSchema = schemas.find((schema) => schema.keyword === pluginOas.schemaKeywords.name);
186
- const mappedName = nameSchema?.args || name;
187
- if (options.mapper?.[mappedName]) {
188
- return `"${name}": ${options.mapper?.[mappedName]}`;
189
- }
190
- return `"${name}": ${joinItems(
191
- schemas.sort(schemaKeywordsorter).map((schema) => parse(current, schema, { ...options, withData: false })).filter(Boolean)
192
- )}`;
193
- }).join(",");
194
- return `{${argsObject}}`;
195
- }
196
- if (pluginOas.isKeyword(current, pluginOas.schemaKeywords.tuple)) {
197
- if (Array.isArray(current.args.items)) {
198
- return fakerKeywordMapper.tuple(current.args.items.map((schema) => parse(current, schema, { ...options, withData: false })).filter(Boolean));
199
- }
200
- return parse(current, current.args.items, { ...options, withData: false });
201
- }
202
- if (pluginOas.isKeyword(current, pluginOas.schemaKeywords.const)) {
203
- if (current.args.format === "number" && current.args.name !== void 0) {
204
- return fakerKeywordMapper.const(current.args.name?.toString());
205
- }
206
- return fakerKeywordMapper.const(transformers__default.default.stringify(current.args.value));
207
- }
208
- if (pluginOas.isKeyword(current, pluginOas.schemaKeywords.matches) && current.args) {
209
- return fakerKeywordMapper.matches(current.args, options.regexGenerator);
210
- }
211
- if (pluginOas.isKeyword(current, pluginOas.schemaKeywords.null) || pluginOas.isKeyword(current, pluginOas.schemaKeywords.undefined) || pluginOas.isKeyword(current, pluginOas.schemaKeywords.any)) {
212
- return value() || "";
213
- }
214
- if (pluginOas.isKeyword(current, pluginOas.schemaKeywords.string)) {
215
- if (parent) {
216
- const minSchema = pluginOas.SchemaGenerator.find([parent], pluginOas.schemaKeywords.min);
217
- const maxSchema = pluginOas.SchemaGenerator.find([parent], pluginOas.schemaKeywords.max);
218
- return fakerKeywordMapper.string(minSchema?.args, maxSchema?.args);
219
- }
220
- return fakerKeywordMapper.string();
221
- }
222
- if (pluginOas.isKeyword(current, pluginOas.schemaKeywords.number)) {
223
- if (parent) {
224
- const minSchema = pluginOas.SchemaGenerator.find([parent], pluginOas.schemaKeywords.min);
225
- const maxSchema = pluginOas.SchemaGenerator.find([parent], pluginOas.schemaKeywords.max);
226
- return fakerKeywordMapper.number(minSchema?.args, maxSchema?.args);
227
- }
228
- return fakerKeywordMapper.number();
229
- }
230
- if (pluginOas.isKeyword(current, pluginOas.schemaKeywords.integer)) {
231
- if (parent) {
232
- const minSchema = pluginOas.SchemaGenerator.find([parent], pluginOas.schemaKeywords.min);
233
- const maxSchema = pluginOas.SchemaGenerator.find([parent], pluginOas.schemaKeywords.max);
234
- return fakerKeywordMapper.integer(minSchema?.args, maxSchema?.args);
235
- }
236
- return fakerKeywordMapper.integer();
237
- }
238
- if (pluginOas.isKeyword(current, pluginOas.schemaKeywords.datetime)) {
239
- return fakerKeywordMapper.datetime();
240
- }
241
- if (pluginOas.isKeyword(current, pluginOas.schemaKeywords.date)) {
242
- return fakerKeywordMapper.date(current.args.type, options.dateParser);
243
- }
244
- if (pluginOas.isKeyword(current, pluginOas.schemaKeywords.time)) {
245
- return fakerKeywordMapper.time(current.args.type, options.dateParser);
246
- }
247
- if (current.keyword in fakerKeywordMapper && "args" in current) {
248
- const value2 = fakerKeywordMapper[current.keyword];
249
- const options2 = JSON.stringify(current.args);
250
- return value2(options2);
251
- }
252
- if (current.keyword in fakerKeywordMapper) {
253
- return value();
254
- }
255
- return void 0;
256
- }
257
- var OperationGenerator = class extends pluginOas.OperationGenerator {
258
- async operation(operation, options) {
259
- const { oas, pluginManager, plugin, mode } = this.context;
260
- const root = react.createRoot({
261
- logger: pluginManager.logger
262
- });
263
- root.render(
264
- /* @__PURE__ */ jsxRuntime.jsx(react.App, { pluginManager, plugin: { ...plugin, options }, mode, children: /* @__PURE__ */ jsxRuntime.jsx(components.Oas, { oas, operations: [operation], generator: this, children: /* @__PURE__ */ jsxRuntime.jsx(components.Oas.Operation, { operation, children: /* @__PURE__ */ jsxRuntime.jsx(OperationSchema.File, {}) }) }) })
265
- );
266
- return root.files;
267
- }
268
- };
269
-
270
- // src/plugin.ts
271
- var pluginFakerName = "plugin-faker";
272
- core.createPlugin((options) => {
273
- const {
274
- output = { path: "mocks" },
275
- seed,
276
- group,
277
- exclude = [],
278
- include,
279
- override = [],
280
- transformers: transformers3 = {},
281
- mapper = {},
282
- dateType = "string",
283
- unknownType = "any",
284
- dateParser,
285
- regexGenerator = "faker"
286
- } = options;
287
- const template = group?.output ? group.output : `${output.path}/{{tag}}Controller`;
288
- return {
289
- name: pluginFakerName,
290
- output: {
291
- exportType: "barrelNamed",
292
- ...output
293
- },
294
- options: {
295
- extName: output.extName,
296
- transformers: transformers3,
297
- dateType,
298
- seed,
299
- unknownType,
300
- dateParser,
301
- mapper,
302
- override,
303
- regexGenerator
304
- },
305
- pre: [pluginOas.pluginOasName, pluginTs.pluginTsName],
306
- resolvePath(baseName, pathMode, options2) {
307
- const root = path__default.default.resolve(this.config.root, this.config.output.path);
308
- const mode = pathMode ?? core.FileManager.getMode(path__default.default.resolve(root, output.path));
309
- if (mode === "single") {
310
- return path__default.default.resolve(root, output.path);
311
- }
312
- if (options2?.tag && group?.type === "tag") {
313
- const tag = transformers.camelCase(options2.tag);
314
- return path__default.default.resolve(root, utils.renderTemplate(template, { tag }), baseName);
315
- }
316
- return path__default.default.resolve(root, output.path, baseName);
317
- },
318
- resolveName(name, type) {
319
- const resolvedName = transformers.camelCase(name, {
320
- prefix: type ? "create" : void 0,
321
- isFile: type === "file"
322
- });
323
- if (type) {
324
- return transformers3?.name?.(resolvedName, type) || resolvedName;
325
- }
326
- return resolvedName;
327
- },
328
- async buildStart() {
329
- const [swaggerPlugin] = core.PluginManager.getDependedPlugins(this.plugins, [pluginOas.pluginOasName]);
330
- const oas = await swaggerPlugin.context.getOas();
331
- const root = path__default.default.resolve(this.config.root, this.config.output.path);
332
- const mode = core.FileManager.getMode(path__default.default.resolve(root, output.path));
333
- const schemaGenerator = new SchemaGenerator2(this.plugin.options, {
334
- oas,
335
- pluginManager: this.pluginManager,
336
- plugin: this.plugin,
337
- contentType: swaggerPlugin.context.contentType,
338
- include: void 0,
339
- override,
340
- mode,
341
- output: output.path
342
- });
343
- const schemaFiles = await schemaGenerator.build();
344
- await this.addFile(...schemaFiles);
345
- const operationGenerator = new OperationGenerator(this.plugin.options, {
346
- oas,
347
- pluginManager: this.pluginManager,
348
- plugin: this.plugin,
349
- contentType: swaggerPlugin.context.contentType,
350
- exclude,
351
- include,
352
- override,
353
- mode
354
- });
355
- const operationFiles = await operationGenerator.build();
356
- await this.addFile(...operationFiles);
357
- if (this.config.output.exportType) {
358
- const barrelFiles = await this.fileManager.getBarrelFiles({
359
- root,
360
- output,
361
- files: this.fileManager.files,
362
- meta: {
363
- pluginKey: this.plugin.key
364
- },
365
- logger: this.logger
366
- });
367
- await this.addFile(...barrelFiles);
368
- }
369
- }
370
- };
7
+ Object.defineProperty(exports, "Faker", {
8
+ enumerable: true,
9
+ get: function () { return chunk7JKM5LCT_cjs.Faker; }
371
10
  });
372
- function Schema(props) {
373
- const { withData, description } = props;
374
- const { tree, name } = hooks.useSchema();
375
- const {
376
- pluginManager,
377
- plugin: {
378
- options: { dateParser, regexGenerator, mapper, seed }
379
- }
380
- } = react.useApp();
381
- const resolvedName = pluginManager.resolveName({
382
- name,
383
- pluginKey: [pluginFakerName],
384
- type: "function"
385
- });
386
- const typeName = pluginManager.resolveName({
387
- name,
388
- pluginKey: [pluginTs.pluginTsName],
389
- type: "type"
390
- });
391
- const fakerText = joinItems(
392
- tree.map((schema) => parse(void 0, schema, { name: resolvedName, typeName, seed, regexGenerator, mapper, withData, dateParser })).filter(Boolean)
393
- );
394
- let fakerDefaultOverride = void 0;
395
- let fakerTextWithOverride = fakerText;
396
- if (withData && fakerText.startsWith("{")) {
397
- fakerDefaultOverride = "{}";
398
- fakerTextWithOverride = `{
399
- ...${fakerText},
400
- ...data
401
- }`;
402
- }
403
- if (withData && fakerText.startsWith("faker.helpers.arrayElements")) {
404
- fakerDefaultOverride = "[]";
405
- fakerTextWithOverride = `[
406
- ...${fakerText},
407
- ...data
408
- ]`;
409
- }
410
- const params = fakerDefaultOverride ? `data: NonNullable<Partial<${typeName}>> = ${fakerDefaultOverride}` : `data?: NonNullable<Partial<${typeName}>>`;
411
- const containsFaker = !!fakerTextWithOverride.match(/faker/) || !!seed;
412
- return /* @__PURE__ */ jsxRuntime.jsxs(jsxRuntime.Fragment, { children: [
413
- containsFaker && /* @__PURE__ */ jsxRuntime.jsx(react.File.Import, { name: ["faker"], path: "@faker-js/faker" }),
414
- /* @__PURE__ */ jsxRuntime.jsxs(react.File.Source, { name: resolvedName, isExportable: true, isIndexable: true, children: [
415
- /* @__PURE__ */ jsxRuntime.jsxs(
416
- react.Function,
417
- {
418
- export: true,
419
- name: resolvedName,
420
- JSDoc: { comments: [description ? `@description ${transformers__default.default.jsStringEscape(description)}` : void 0].filter(Boolean) },
421
- params: withData ? params : "",
422
- returnType: typeName ? `NonNullable<${typeName}>` : "",
423
- children: [
424
- seed ? `faker.seed(${JSON.stringify(seed)})` : "",
425
- /* @__PURE__ */ jsxRuntime.jsx("br", {}),
426
- /* @__PURE__ */ jsxRuntime.jsx(react.Function.Return, { children: fakerTextWithOverride })
427
- ]
428
- }
429
- ),
430
- /* @__PURE__ */ jsxRuntime.jsx("br", {})
431
- ] })
432
- ] });
433
- }
434
- Schema.File = function({}) {
435
- const { pluginManager } = react.useApp();
436
- const { tree, schema } = hooks.useSchema();
437
- const withData = tree.some(
438
- (schema2) => schema2.keyword === pluginOas.schemaKeywords.array || schema2.keyword === pluginOas.schemaKeywords.and || schema2.keyword === pluginOas.schemaKeywords.object || schema2.keyword === pluginOas.schemaKeywords.union || schema2.keyword === pluginOas.schemaKeywords.tuple
439
- );
440
- return /* @__PURE__ */ jsxRuntime.jsxs(components.Oas.Schema.File, { output: pluginManager.config.output.path, children: [
441
- /* @__PURE__ */ jsxRuntime.jsx(Schema.Imports, {}),
442
- /* @__PURE__ */ jsxRuntime.jsx(Schema, { description: schema?.description, withData })
443
- ] });
444
- };
445
- Schema.Imports = () => {
446
- const {
447
- pluginManager,
448
- plugin: {
449
- options: { extName, dateParser, regexGenerator }
450
- }
451
- } = react.useApp();
452
- const { path: root } = react.useFile();
453
- const { name, tree, schema } = hooks.useSchema();
454
- const typeName = pluginManager.resolveName({
455
- name,
456
- pluginKey: [pluginTs.pluginTsName],
457
- type: "type"
458
- });
459
- const typeFileName = pluginManager.resolveName({
460
- name,
461
- pluginKey: [pluginTs.pluginTsName],
462
- type: "file"
463
- });
464
- const typePath = pluginManager.resolvePath({
465
- baseName: typeFileName,
466
- pluginKey: [pluginTs.pluginTsName]
467
- });
468
- return /* @__PURE__ */ jsxRuntime.jsxs(jsxRuntime.Fragment, { children: [
469
- regexGenerator === "randexp" && /* @__PURE__ */ jsxRuntime.jsx(react.File.Import, { name: "RandExp", path: "randexp" }),
470
- dateParser && /* @__PURE__ */ jsxRuntime.jsx(react.File.Import, { path: dateParser, name: dateParser }),
471
- typeName && typePath && /* @__PURE__ */ jsxRuntime.jsx(react.File.Import, { isTypeOnly: true, root, path: typePath, name: [typeName] })
472
- ] });
473
- };
474
- var SchemaGenerator2 = class extends pluginOas.SchemaGenerator {
475
- async schema(name, schema, options) {
476
- const { oas, pluginManager, plugin, mode, output } = this.context;
477
- const root = react.createRoot({
478
- logger: pluginManager.logger
479
- });
480
- const tree = this.parse({ schema, name });
481
- root.render(
482
- /* @__PURE__ */ jsxRuntime.jsx(react.App, { pluginManager, plugin: { ...plugin, options }, mode, children: /* @__PURE__ */ jsxRuntime.jsx(components.Oas, { oas, children: /* @__PURE__ */ jsxRuntime.jsx(components.Oas.Schema, { name, value: schema, tree, children: /* @__PURE__ */ jsxRuntime.jsx(Schema.File, {}) }) }) })
483
- );
484
- return root.files;
485
- }
486
- };
487
- function OperationSchema({ description }) {
488
- return /* @__PURE__ */ jsxRuntime.jsx(Schema, { withData: false, description });
489
- }
490
- OperationSchema.File = function({}) {
491
- const { plugin, pluginManager, mode } = react.useApp();
492
- const oas = hooks.useOas();
493
- const { getSchemas, getFile } = hooks.useOperationManager();
494
- const operation = hooks.useOperation();
495
- const file = getFile(operation);
496
- const schemas = getSchemas(operation);
497
- const generator = new SchemaGenerator2(plugin.options, {
498
- oas,
499
- plugin,
500
- pluginManager,
501
- mode,
502
- override: plugin.options.override
503
- });
504
- const items = [schemas.pathParams, schemas.queryParams, schemas.headerParams, schemas.statusCodes, schemas.request, schemas.response].flat().filter(Boolean);
505
- const mapItem = ({ name, schema, description, ...options }, i) => {
506
- const typeName = pluginManager.resolveName({
507
- name,
508
- pluginKey: [pluginTs.pluginTsName],
509
- type: "type"
510
- });
511
- const typeFileName = pluginManager.resolveName({
512
- name: options.operationName || name,
513
- pluginKey: [pluginTs.pluginTsName],
514
- type: "file"
515
- });
516
- const typePath = pluginManager.resolvePath({
517
- baseName: typeFileName,
518
- pluginKey: [pluginTs.pluginTsName],
519
- options: { tag: options.operation?.getTags()[0]?.name }
520
- });
521
- const tree = generator.parse({ schema, name });
522
- return /* @__PURE__ */ jsxRuntime.jsxs(components.Oas.Schema, { name, value: schema, tree, children: [
523
- typeName && typePath && /* @__PURE__ */ jsxRuntime.jsx(react.File.Import, { isTypeOnly: true, root: file.path, path: typePath, name: [typeName] }),
524
- plugin.options.dateParser && /* @__PURE__ */ jsxRuntime.jsx(react.File.Import, { path: plugin.options.dateParser, name: plugin.options.dateParser }),
525
- mode === "split" && /* @__PURE__ */ jsxRuntime.jsx(components.Oas.Schema.Imports, {}),
526
- /* @__PURE__ */ jsxRuntime.jsx(OperationSchema, { description })
527
- ] }, i);
528
- };
529
- return /* @__PURE__ */ jsxRuntime.jsxs(react.File, { baseName: file.baseName, path: file.path, meta: file.meta, children: [
530
- plugin.options.regexGenerator === "randexp" && /* @__PURE__ */ jsxRuntime.jsx(react.File.Import, { name: "RandExp", path: "randexp" }),
531
- items.map(mapItem)
532
- ] });
533
- };
534
-
535
- exports.OperationSchema = OperationSchema;
536
- exports.Schema = Schema;
537
11
  //# sourceMappingURL=components.cjs.map
538
12
  //# sourceMappingURL=components.cjs.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/parser/index.ts","../src/OperationGenerator.tsx","../src/plugin.ts","../src/components/Schema.tsx","../src/SchemaGenerator.tsx","../src/components/OperationSchema.tsx"],"names":["transformers","isKeyword","schemaKeywords","SchemaGenerator","value","options","Generator","createRoot","jsx","App","Oas","createPlugin","pluginOasName","pluginTsName","path","FileManager","camelCase","renderTemplate","PluginManager","useSchema","useApp","jsxs","Fragment","File","Function","schema","useFile","useOas","useOperationManager","useOperation"],"mappings":"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","file":"components.cjs","sourcesContent":["import transformers from '@kubb/core/transformers'\nimport { SchemaGenerator, isKeyword, schemaKeywords } from '@kubb/plugin-oas'\n\nimport type { Schema, SchemaKeywordBase, SchemaKeywordMapper, SchemaMapper } from '@kubb/plugin-oas'\nimport type { Options } from '../types.ts'\n\nexport const fakerKeywordMapper = {\n any: () => 'undefined',\n unknown: () => 'unknown',\n number: (min?: number, max?: number) => {\n if (max !== undefined && min !== undefined) {\n return `faker.number.float({ min: ${min}, max: ${max} })`\n }\n\n if (min !== undefined) {\n return `faker.number.float({ min: ${min} })`\n }\n\n if (max !== undefined) {\n return `faker.number.float({ max: ${max} })`\n }\n\n return 'faker.number.float()'\n },\n integer: (min?: number, max?: number) => {\n if (max !== undefined && min !== undefined) {\n return `faker.number.int({ min: ${min}, max: ${max} })`\n }\n\n if (min !== undefined) {\n return `faker.number.int({ min: ${min} })`\n }\n\n if (max !== undefined) {\n return `faker.number.int({ max: ${max} })`\n }\n\n return 'faker.number.int()'\n },\n string: (min?: number, max?: number) => {\n if (max !== undefined && min !== undefined) {\n return `faker.string.alpha({ length: { min: ${min}, max: ${max} } })`\n }\n\n if (min !== undefined) {\n return `faker.string.alpha({ length: { min: ${min} } })`\n }\n\n if (max !== undefined) {\n return `faker.string.alpha({ length: { max: ${max} } })`\n }\n\n return 'faker.string.alpha()'\n },\n boolean: () => 'faker.datatype.boolean()',\n undefined: () => 'undefined',\n null: () => 'null',\n array: (items: string[] = []) => `faker.helpers.arrayElements([${items.join(', ')}]) as any`,\n tuple: (items: string[] = []) => `faker.helpers.arrayElements([${items.join(', ')}]) as any`,\n enum: (items: Array<string | number> = []) => `faker.helpers.arrayElement<any>([${items.join(', ')}])`,\n union: (items: string[] = []) => `faker.helpers.arrayElement<any>([${items.join(', ')}])`,\n /**\n * ISO 8601\n */\n datetime: () => 'faker.date.anytime().toISOString()',\n /**\n * Type `'date'` Date\n * Type `'string'` ISO date format (YYYY-MM-DD)\n * @default ISO date format (YYYY-MM-DD)\n */\n date: (type: 'date' | 'string' = 'string', parser?: string) => {\n if (type === 'string') {\n if (parser) {\n return `${parser}(faker.date.anytime()).format(\"YYYY-MM-DD\")`\n }\n return 'faker.date.anytime().toString()'\n }\n return 'faker.date.anytime()'\n },\n /**\n * Type `'date'` Date\n * Type `'string'` ISO time format (HH:mm:ss[.SSSSSS])\n * @default ISO time format (HH:mm:ss[.SSSSSS])\n */\n time: (type: 'date' | 'string' = 'string', parser?: string) => {\n if (type === 'string') {\n if (parser) {\n return `${parser}(faker.date.anytime()).format(\"HH:mm:ss\")`\n }\n return 'faker.date.anytime().toString()'\n }\n return 'faker.date.anytime()'\n },\n uuid: () => 'faker.string.uuid()',\n url: () => 'faker.internet.url()',\n and: (items: string[] = []) => `Object.assign({}, ${items.join(', ')})`,\n object: () => 'object',\n ref: () => 'ref',\n matches: (value = '', regexGenerator: 'faker' | 'randexp' = 'faker') => {\n if (regexGenerator === 'randexp') {\n return `${transformers.toRegExpString(value, 'RandExp')}.gen()`\n }\n return `faker.helpers.fromRegExp(${transformers.toRegExpString(value)})`\n },\n email: () => 'faker.internet.email()',\n firstName: () => 'faker.person.firstName()',\n lastName: () => 'faker.person.lastName()',\n password: () => 'faker.internet.password()',\n phone: () => 'faker.phone.number()',\n blob: () => 'faker.image.imageUrl() as unknown as Blob',\n default: undefined,\n describe: undefined,\n const: (value?: string | number) => (value as string) ?? '',\n max: undefined,\n min: undefined,\n nullable: undefined,\n nullish: undefined,\n optional: undefined,\n readOnly: undefined,\n strict: undefined,\n deprecated: undefined,\n example: undefined,\n schema: undefined,\n catchall: undefined,\n name: undefined,\n} satisfies SchemaMapper<string | null | undefined>\n\n/**\n * @link based on https://github.com/cellular/oazapfts/blob/7ba226ebb15374e8483cc53e7532f1663179a22c/src/codegen/generate.ts#L398\n */\n\nfunction schemaKeywordsorter(a: Schema, b: Schema) {\n if (b.keyword === 'null') {\n return -1\n }\n\n return 0\n}\n\nexport function joinItems(items: string[]): string {\n switch (items.length) {\n case 0:\n return 'undefined'\n case 1:\n return items[0]!\n default:\n return fakerKeywordMapper.union(items)\n }\n}\n\ntype ParserOptions = {\n name: string\n typeName?: string\n description?: string\n\n seed?: number | number[]\n regexGenerator?: 'faker' | 'randexp'\n withData?: boolean\n dateParser?: Options['dateParser']\n mapper?: Record<string, string>\n}\n\nexport function parse(parent: Schema | undefined, current: Schema, options: ParserOptions): string | null | undefined {\n const value = fakerKeywordMapper[current.keyword as keyof typeof fakerKeywordMapper]\n\n if (!value) {\n return undefined\n }\n\n if (isKeyword(current, schemaKeywords.union)) {\n return fakerKeywordMapper.union(current.args.map((schema) => parse(current, schema, { ...options, withData: false })).filter(Boolean))\n }\n\n if (isKeyword(current, schemaKeywords.and)) {\n return fakerKeywordMapper.and(current.args.map((schema) => parse(current, schema, { ...options, withData: false })).filter(Boolean))\n }\n\n if (isKeyword(current, schemaKeywords.array)) {\n return fakerKeywordMapper.array(current.args.items.map((schema) => parse(current, schema, { ...options, withData: false })).filter(Boolean))\n }\n\n if (isKeyword(current, schemaKeywords.enum)) {\n return fakerKeywordMapper.enum(\n current.args.items.map((schema) => {\n if (schema.format === 'number') {\n return schema.name\n }\n return transformers.stringify(schema.name)\n }),\n )\n }\n\n if (isKeyword(current, schemaKeywords.ref)) {\n if (!current.args?.name) {\n throw new Error(`Name not defined for keyword ${current.keyword}`)\n }\n\n if (options.withData) {\n return `${current.args.name}(data)`\n }\n\n return `${current.args.name}()`\n }\n\n if (isKeyword(current, schemaKeywords.object)) {\n const argsObject = Object.entries(current.args?.properties || {})\n .filter((item) => {\n const schema = item[1]\n return schema && typeof schema.map === 'function'\n })\n .map(([name, schemas]) => {\n const nameSchema = schemas.find((schema) => schema.keyword === schemaKeywords.name) as SchemaKeywordMapper['name']\n const mappedName = nameSchema?.args || name\n\n // custom mapper(pluginOptions)\n if (options.mapper?.[mappedName]) {\n return `\"${name}\": ${options.mapper?.[mappedName]}`\n }\n\n return `\"${name}\": ${joinItems(\n schemas\n .sort(schemaKeywordsorter)\n .map((schema) => parse(current, schema, { ...options, withData: false }))\n .filter(Boolean),\n )}`\n })\n .join(',')\n\n return `{${argsObject}}`\n }\n\n if (isKeyword(current, schemaKeywords.tuple)) {\n if (Array.isArray(current.args.items)) {\n return fakerKeywordMapper.tuple(current.args.items.map((schema) => parse(current, schema, { ...options, withData: false })).filter(Boolean))\n }\n\n return parse(current, current.args.items, { ...options, withData: false })\n }\n\n if (isKeyword(current, schemaKeywords.const)) {\n if (current.args.format === 'number' && current.args.name !== undefined) {\n return fakerKeywordMapper.const(current.args.name?.toString())\n }\n return fakerKeywordMapper.const(transformers.stringify(current.args.value))\n }\n\n if (isKeyword(current, schemaKeywords.matches) && current.args) {\n return fakerKeywordMapper.matches(current.args, options.regexGenerator)\n }\n\n if (isKeyword(current, schemaKeywords.null) || isKeyword(current, schemaKeywords.undefined) || isKeyword(current, schemaKeywords.any)) {\n return value() || ''\n }\n\n if (isKeyword(current, schemaKeywords.string)) {\n if (parent) {\n const minSchema = SchemaGenerator.find([parent], schemaKeywords.min)\n const maxSchema = SchemaGenerator.find([parent], schemaKeywords.max)\n\n return fakerKeywordMapper.string(minSchema?.args, maxSchema?.args)\n }\n\n return fakerKeywordMapper.string()\n }\n\n if (isKeyword(current, schemaKeywords.number)) {\n if (parent) {\n const minSchema = SchemaGenerator.find([parent], schemaKeywords.min)\n const maxSchema = SchemaGenerator.find([parent], schemaKeywords.max)\n\n return fakerKeywordMapper.number(minSchema?.args, maxSchema?.args)\n }\n\n return fakerKeywordMapper.number()\n }\n\n if (isKeyword(current, schemaKeywords.integer)) {\n if (parent) {\n const minSchema = SchemaGenerator.find([parent], schemaKeywords.min)\n const maxSchema = SchemaGenerator.find([parent], schemaKeywords.max)\n\n return fakerKeywordMapper.integer(minSchema?.args, maxSchema?.args)\n }\n\n return fakerKeywordMapper.integer()\n }\n\n if (isKeyword(current, schemaKeywords.datetime)) {\n return fakerKeywordMapper.datetime()\n }\n\n if (isKeyword(current, schemaKeywords.date)) {\n return fakerKeywordMapper.date(current.args.type, options.dateParser)\n }\n\n if (isKeyword(current, schemaKeywords.time)) {\n return fakerKeywordMapper.time(current.args.type, options.dateParser)\n }\n\n if (current.keyword in fakerKeywordMapper && 'args' in current) {\n const value = fakerKeywordMapper[current.keyword as keyof typeof fakerKeywordMapper] as (typeof fakerKeywordMapper)['const']\n\n const options = JSON.stringify((current as SchemaKeywordBase<unknown>).args)\n\n return value(options)\n }\n\n if (current.keyword in fakerKeywordMapper) {\n return value()\n }\n\n return undefined\n}\n","import { OperationGenerator as Generator } from '@kubb/plugin-oas'\nimport { Oas } from '@kubb/plugin-oas/components'\nimport { App, createRoot } from '@kubb/react'\n\nimport { OperationSchema } from './components/OperationSchema.tsx'\n\nimport type { Operation } from '@kubb/oas'\nimport type { OperationMethodResult } from '@kubb/plugin-oas'\nimport type { FileMeta, PluginFaker } from './types.ts'\n\nexport class OperationGenerator extends Generator<PluginFaker['resolvedOptions'], PluginFaker> {\n async operation(operation: Operation, options: PluginFaker['resolvedOptions']): OperationMethodResult<FileMeta> {\n const { oas, pluginManager, plugin, mode } = this.context\n\n const root = createRoot({\n logger: pluginManager.logger,\n })\n\n root.render(\n <App pluginManager={pluginManager} plugin={{ ...plugin, options }} mode={mode}>\n <Oas oas={oas} operations={[operation]} generator={this}>\n <Oas.Operation operation={operation}>\n <OperationSchema.File />\n </Oas.Operation>\n </Oas>\n </App>,\n )\n\n return root.files\n }\n}\n","import path from 'node:path'\n\nimport { FileManager, PluginManager, createPlugin } from '@kubb/core'\nimport { camelCase } from '@kubb/core/transformers'\nimport { renderTemplate } from '@kubb/core/utils'\nimport { pluginOasName } from '@kubb/plugin-oas'\n\nimport { pluginTsName } from '@kubb/plugin-ts'\n\nimport { OperationGenerator } from './OperationGenerator.tsx'\nimport { SchemaGenerator } from './SchemaGenerator.tsx'\n\nimport type { Plugin } from '@kubb/core'\nimport type { PluginOas } from '@kubb/plugin-oas'\nimport type { PluginFaker } from './types.ts'\n\nexport const pluginFakerName = 'plugin-faker' satisfies PluginFaker['name']\n\nexport const pluginFaker = createPlugin<PluginFaker>((options) => {\n const {\n output = { path: 'mocks' },\n seed,\n group,\n exclude = [],\n include,\n override = [],\n transformers = {},\n mapper = {},\n dateType = 'string',\n unknownType = 'any',\n dateParser,\n regexGenerator = 'faker',\n } = options\n const template = group?.output ? group.output : `${output.path}/{{tag}}Controller`\n\n return {\n name: pluginFakerName,\n output: {\n exportType: 'barrelNamed',\n ...output,\n },\n options: {\n extName: output.extName,\n transformers,\n dateType,\n seed,\n unknownType,\n dateParser,\n mapper,\n override,\n regexGenerator,\n },\n pre: [pluginOasName, pluginTsName],\n resolvePath(baseName, pathMode, options) {\n const root = path.resolve(this.config.root, this.config.output.path)\n const mode = pathMode ?? FileManager.getMode(path.resolve(root, output.path))\n\n if (mode === 'single') {\n /**\n * when output is a file then we will always append to the same file(output file), see fileManager.addOrAppend\n * Other plugins then need to call addOrAppend instead of just add from the fileManager class\n */\n return path.resolve(root, output.path)\n }\n\n if (options?.tag && group?.type === 'tag') {\n const tag = camelCase(options.tag)\n\n return path.resolve(root, renderTemplate(template, { tag }), baseName)\n }\n\n return path.resolve(root, output.path, baseName)\n },\n resolveName(name, type) {\n const resolvedName = camelCase(name, {\n prefix: type ? 'create' : undefined,\n isFile: type === 'file',\n })\n\n if (type) {\n return transformers?.name?.(resolvedName, type) || resolvedName\n }\n\n return resolvedName\n },\n async buildStart() {\n const [swaggerPlugin]: [Plugin<PluginOas>] = PluginManager.getDependedPlugins<PluginOas>(this.plugins, [pluginOasName])\n\n const oas = await swaggerPlugin.context.getOas()\n const root = path.resolve(this.config.root, this.config.output.path)\n const mode = FileManager.getMode(path.resolve(root, output.path))\n\n const schemaGenerator = new SchemaGenerator(this.plugin.options, {\n oas,\n pluginManager: this.pluginManager,\n plugin: this.plugin,\n contentType: swaggerPlugin.context.contentType,\n include: undefined,\n override,\n mode,\n output: output.path,\n })\n\n const schemaFiles = await schemaGenerator.build()\n await this.addFile(...schemaFiles)\n\n const operationGenerator = new OperationGenerator(this.plugin.options, {\n oas,\n pluginManager: this.pluginManager,\n plugin: this.plugin,\n contentType: swaggerPlugin.context.contentType,\n exclude,\n include,\n override,\n mode,\n })\n\n const operationFiles = await operationGenerator.build()\n await this.addFile(...operationFiles)\n\n if (this.config.output.exportType) {\n const barrelFiles = await this.fileManager.getBarrelFiles({\n root,\n output,\n files: this.fileManager.files,\n meta: {\n pluginKey: this.plugin.key,\n },\n logger: this.logger,\n })\n\n await this.addFile(...barrelFiles)\n }\n },\n }\n})\n","import { Oas } from '@kubb/plugin-oas/components'\nimport { pluginTsName } from '@kubb/plugin-ts'\nimport { File, Function, useApp, useFile } from '@kubb/react'\n\nimport transformers from '@kubb/core/transformers'\nimport { schemaKeywords } from '@kubb/plugin-oas'\nimport { useSchema } from '@kubb/plugin-oas/hooks'\nimport type { ReactNode } from 'react'\nimport * as parserFaker from '../parser/index.ts'\nimport { pluginFakerName } from '../plugin.ts'\nimport type { PluginFaker } from '../types.ts'\n\ntype Props = {\n description?: string\n withData?: boolean\n}\n\nexport function Schema(props: Props): ReactNode {\n const { withData, description } = props\n const { tree, name } = useSchema()\n const {\n pluginManager,\n plugin: {\n options: { dateParser, regexGenerator, mapper, seed },\n },\n } = useApp<PluginFaker>()\n\n // all checks are also inside this.schema(React)\n const resolvedName = pluginManager.resolveName({\n name,\n pluginKey: [pluginFakerName],\n type: 'function',\n })\n\n const typeName = pluginManager.resolveName({\n name,\n pluginKey: [pluginTsName],\n type: 'type',\n })\n\n const fakerText = parserFaker.joinItems(\n tree\n .map((schema) => parserFaker.parse(undefined, schema, { name: resolvedName, typeName, seed, regexGenerator, mapper, withData, dateParser }))\n .filter(Boolean),\n )\n\n let fakerDefaultOverride: '' | '[]' | '{}' | undefined = undefined\n let fakerTextWithOverride = fakerText\n\n if (withData && fakerText.startsWith('{')) {\n fakerDefaultOverride = '{}'\n fakerTextWithOverride = `{\n ...${fakerText},\n ...data\n}`\n }\n\n if (withData && fakerText.startsWith('faker.helpers.arrayElements')) {\n fakerDefaultOverride = '[]'\n fakerTextWithOverride = `[\n ...${fakerText},\n ...data\n ]`\n }\n\n const params = fakerDefaultOverride ? `data: NonNullable<Partial<${typeName}>> = ${fakerDefaultOverride}` : `data?: NonNullable<Partial<${typeName}>>`\n\n const containsFaker = !!fakerTextWithOverride.match(/faker/) || !!seed\n\n return (\n <>\n {containsFaker && <File.Import name={['faker']} path=\"@faker-js/faker\" />}\n <File.Source name={resolvedName} isExportable isIndexable>\n <Function\n export\n name={resolvedName}\n JSDoc={{ comments: [description ? `@description ${transformers.jsStringEscape(description)}` : undefined].filter(Boolean) }}\n params={withData ? params : ''}\n returnType={typeName ? `NonNullable<${typeName}>` : ''}\n >\n {seed ? `faker.seed(${JSON.stringify(seed)})` : ''}\n <br />\n <Function.Return>{fakerTextWithOverride}</Function.Return>\n </Function>\n <br />\n </File.Source>\n </>\n )\n}\n\ntype FileProps = {}\n\nSchema.File = function ({}: FileProps): ReactNode {\n const { pluginManager } = useApp<PluginFaker>()\n const { tree, schema } = useSchema()\n\n const withData = tree.some(\n (schema) =>\n schema.keyword === schemaKeywords.array ||\n schema.keyword === schemaKeywords.and ||\n schema.keyword === schemaKeywords.object ||\n schema.keyword === schemaKeywords.union ||\n schema.keyword === schemaKeywords.tuple,\n )\n\n return (\n <Oas.Schema.File output={pluginManager.config.output.path}>\n <Schema.Imports />\n <Schema description={schema?.description} withData={withData} />\n </Oas.Schema.File>\n )\n}\nSchema.Imports = (): ReactNode => {\n const {\n pluginManager,\n plugin: {\n options: { extName, dateParser, regexGenerator },\n },\n } = useApp<PluginFaker>()\n const { path: root } = useFile()\n const { name, tree, schema } = useSchema()\n\n // used for this.options.typed\n const typeName = pluginManager.resolveName({\n name,\n pluginKey: [pluginTsName],\n type: 'type',\n })\n\n const typeFileName = pluginManager.resolveName({\n name: name,\n pluginKey: [pluginTsName],\n type: 'file',\n })\n\n const typePath = pluginManager.resolvePath({\n baseName: typeFileName,\n pluginKey: [pluginTsName],\n })\n\n return (\n <>\n {regexGenerator === 'randexp' && <File.Import name={'RandExp'} path={'randexp'} />}\n {dateParser && <File.Import path={dateParser} name={dateParser} />}\n {typeName && typePath && <File.Import isTypeOnly root={root} path={typePath} name={[typeName]} />}\n </>\n )\n}\n","import type { SchemaObject } from '@kubb/oas'\nimport { SchemaGenerator as Generator } from '@kubb/plugin-oas'\nimport type { SchemaMethodResult } from '@kubb/plugin-oas'\nimport { Oas } from '@kubb/plugin-oas/components'\nimport { App, createRoot } from '@kubb/react'\nimport { Schema } from './components/Schema.tsx'\nimport type { FileMeta, PluginFaker } from './types.ts'\n\nexport class SchemaGenerator extends Generator<PluginFaker['resolvedOptions'], PluginFaker> {\n async schema(name: string, schema: SchemaObject, options: PluginFaker['resolvedOptions']): SchemaMethodResult<FileMeta> {\n const { oas, pluginManager, plugin, mode, output } = this.context\n\n const root = createRoot({\n logger: pluginManager.logger,\n })\n\n const tree = this.parse({ schema, name })\n\n root.render(\n <App pluginManager={pluginManager} plugin={{ ...plugin, options }} mode={mode}>\n <Oas oas={oas}>\n <Oas.Schema name={name} value={schema} tree={tree}>\n <Schema.File />\n </Oas.Schema>\n </Oas>\n </App>,\n )\n\n return root.files\n }\n}\n","import { Oas } from '@kubb/plugin-oas/components'\nimport { useOas, useOperation, useOperationManager } from '@kubb/plugin-oas/hooks'\nimport { pluginTsName } from '@kubb/plugin-ts'\nimport { File, useApp } from '@kubb/react'\n\nimport { SchemaGenerator } from '../SchemaGenerator.tsx'\n\nimport type { OperationSchema as OperationSchemaType } from '@kubb/plugin-oas'\nimport type { ReactNode } from 'react'\nimport type { FileMeta, PluginFaker } from '../types.ts'\nimport { Schema } from './Schema.tsx'\n\ntype Props = {\n description?: string\n}\n\nexport function OperationSchema({ description }: Props): ReactNode {\n return <Schema withData={false} description={description} />\n}\n\ntype FileProps = {}\n\nOperationSchema.File = function ({}: FileProps): ReactNode {\n const { plugin, pluginManager, mode } = useApp<PluginFaker>()\n\n const oas = useOas()\n const { getSchemas, getFile } = useOperationManager()\n const operation = useOperation()\n\n const file = getFile(operation)\n const schemas = getSchemas(operation)\n const generator = new SchemaGenerator(plugin.options, {\n oas,\n plugin,\n pluginManager,\n mode,\n override: plugin.options.override,\n })\n\n const items = [schemas.pathParams, schemas.queryParams, schemas.headerParams, schemas.statusCodes, schemas.request, schemas.response].flat().filter(Boolean)\n\n const mapItem = ({ name, schema, description, ...options }: OperationSchemaType, i: number) => {\n // used for this.options.typed\n const typeName = pluginManager.resolveName({\n name,\n pluginKey: [pluginTsName],\n type: 'type',\n })\n const typeFileName = pluginManager.resolveName({\n name: options.operationName || name,\n pluginKey: [pluginTsName],\n type: 'file',\n })\n\n // todo replace by getFile\n const typePath = pluginManager.resolvePath({\n baseName: typeFileName,\n pluginKey: [pluginTsName],\n options: { tag: options.operation?.getTags()[0]?.name },\n })\n\n const tree = generator.parse({ schema, name })\n\n return (\n <Oas.Schema key={i} name={name} value={schema} tree={tree}>\n {typeName && typePath && <File.Import isTypeOnly root={file.path} path={typePath} name={[typeName]} />}\n {plugin.options.dateParser && <File.Import path={plugin.options.dateParser} name={plugin.options.dateParser} />}\n\n {mode === 'split' && <Oas.Schema.Imports />}\n <OperationSchema description={description} />\n </Oas.Schema>\n )\n }\n\n return (\n <File<FileMeta> baseName={file.baseName} path={file.path} meta={file.meta}>\n {plugin.options.regexGenerator === 'randexp' && <File.Import name={'RandExp'} path={'randexp'} />}\n {items.map(mapItem)}\n </File>\n )\n}\n"]}
1
+ {"version":3,"sources":[],"names":[],"mappings":"","file":"components.cjs"}