@kubb/plugin-faker 3.0.0-alpha.9 → 3.0.0-beta.2

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 (55) hide show
  1. package/README.md +14 -5
  2. package/dist/chunk-HTZ2R6MK.js +305 -0
  3. package/dist/chunk-HTZ2R6MK.js.map +1 -0
  4. package/dist/chunk-KBSFZ5OP.cjs +311 -0
  5. package/dist/chunk-KBSFZ5OP.cjs.map +1 -0
  6. package/dist/chunk-QFJUM25Z.js +113 -0
  7. package/dist/chunk-QFJUM25Z.js.map +1 -0
  8. package/dist/chunk-U6LOSTOE.cjs +115 -0
  9. package/dist/chunk-U6LOSTOE.cjs.map +1 -0
  10. package/dist/components.cjs +6 -556
  11. package/dist/components.cjs.map +1 -1
  12. package/dist/components.d.cts +15 -18
  13. package/dist/components.d.ts +15 -18
  14. package/dist/components.js +2 -561
  15. package/dist/components.js.map +1 -1
  16. package/dist/generators.cjs +13 -0
  17. package/dist/generators.cjs.map +1 -0
  18. package/dist/generators.d.cts +8 -0
  19. package/dist/generators.d.ts +8 -0
  20. package/dist/generators.js +4 -0
  21. package/dist/generators.js.map +1 -0
  22. package/dist/index.cjs +52 -500
  23. package/dist/index.cjs.map +1 -1
  24. package/dist/index.d.cts +4 -125
  25. package/dist/index.d.ts +4 -125
  26. package/dist/index.js +39 -494
  27. package/dist/index.js.map +1 -1
  28. package/dist/types-C1bqlbxh.d.cts +94 -0
  29. package/dist/types-C1bqlbxh.d.ts +94 -0
  30. package/package.json +20 -16
  31. package/src/components/Faker.tsx +80 -0
  32. package/src/components/index.ts +1 -2
  33. package/src/generators/__snapshots__/createPet.ts +26 -0
  34. package/src/generators/__snapshots__/createPetSeed.ts +30 -0
  35. package/src/generators/__snapshots__/createPetUnknownTypeAny.ts +26 -0
  36. package/src/generators/__snapshots__/deletePet.ts +3 -0
  37. package/src/generators/__snapshots__/enumNames.ts +5 -0
  38. package/src/generators/__snapshots__/enumVarNames.ts +5 -0
  39. package/src/generators/__snapshots__/getPets.ts +29 -0
  40. package/src/generators/__snapshots__/pet.ts +8 -0
  41. package/src/generators/__snapshots__/petWithDateString.ts +8 -0
  42. package/src/generators/__snapshots__/petWithDayjs.ts +9 -0
  43. package/src/generators/__snapshots__/petWithMapper.ts +8 -0
  44. package/src/generators/__snapshots__/petWithRandExp.ts +9 -0
  45. package/src/generators/__snapshots__/pets.ts +8 -0
  46. package/src/generators/__snapshots__/showPetById.ts +29 -0
  47. package/src/generators/fakerGenerator.tsx +140 -0
  48. package/src/generators/index.ts +1 -0
  49. package/src/parser/index.ts +25 -14
  50. package/src/plugin.ts +29 -36
  51. package/src/types.ts +28 -67
  52. package/src/OperationGenerator.tsx +0 -31
  53. package/src/SchemaGenerator.tsx +0 -31
  54. package/src/components/OperationSchema.tsx +0 -82
  55. package/src/components/Schema.tsx +0 -144
@@ -0,0 +1,311 @@
1
+ 'use strict';
2
+
3
+ var react = require('@kubb/react');
4
+ var transformers = require('@kubb/core/transformers');
5
+ var pluginOas = require('@kubb/plugin-oas');
6
+ var jsxRuntime = require('@kubb/react/jsx-runtime');
7
+
8
+ function _interopDefault (e) { return e && e.__esModule ? e : { default: e }; }
9
+
10
+ var transformers__default = /*#__PURE__*/_interopDefault(transformers);
11
+
12
+ // src/components/Faker.tsx
13
+ var fakerKeywordMapper = {
14
+ any: () => "undefined",
15
+ unknown: () => "unknown",
16
+ number: (min, max) => {
17
+ if (max !== void 0 && min !== void 0) {
18
+ return `faker.number.float({ min: ${min}, max: ${max} })`;
19
+ }
20
+ if (min !== void 0) {
21
+ return `faker.number.float({ min: ${min} })`;
22
+ }
23
+ if (max !== void 0) {
24
+ return `faker.number.float({ max: ${max} })`;
25
+ }
26
+ return "faker.number.float()";
27
+ },
28
+ integer: (min, max) => {
29
+ if (max !== void 0 && min !== void 0) {
30
+ return `faker.number.int({ min: ${min}, max: ${max} })`;
31
+ }
32
+ if (min !== void 0) {
33
+ return `faker.number.int({ min: ${min} })`;
34
+ }
35
+ if (max !== void 0) {
36
+ return `faker.number.int({ max: ${max} })`;
37
+ }
38
+ return "faker.number.int()";
39
+ },
40
+ string: (min, max) => {
41
+ if (max !== void 0 && min !== void 0) {
42
+ return `faker.string.alpha({ length: { min: ${min}, max: ${max} } })`;
43
+ }
44
+ if (min !== void 0) {
45
+ return `faker.string.alpha({ length: { min: ${min} } })`;
46
+ }
47
+ if (max !== void 0) {
48
+ return `faker.string.alpha({ length: { max: ${max} } })`;
49
+ }
50
+ return "faker.string.alpha()";
51
+ },
52
+ boolean: () => "faker.datatype.boolean()",
53
+ undefined: () => "undefined",
54
+ null: () => "null",
55
+ array: (items = []) => `faker.helpers.arrayElements([${items.join(", ")}]) as any`,
56
+ tuple: (items = []) => `faker.helpers.arrayElements([${items.join(", ")}]) as any`,
57
+ enum: (items = []) => `faker.helpers.arrayElement<any>([${items.join(", ")}])`,
58
+ union: (items = []) => `faker.helpers.arrayElement<any>([${items.join(", ")}])`,
59
+ /**
60
+ * ISO 8601
61
+ */
62
+ datetime: () => "faker.date.anytime().toISOString()",
63
+ /**
64
+ * Type `'date'` Date
65
+ * Type `'string'` ISO date format (YYYY-MM-DD)
66
+ * @default ISO date format (YYYY-MM-DD)
67
+ */
68
+ date: (type = "string", parser = "faker") => {
69
+ if (type === "string") {
70
+ if (parser !== "faker") {
71
+ return `${parser}(faker.date.anytime()).format("YYYY-MM-DD")`;
72
+ }
73
+ return "faker.date.anytime().toString()";
74
+ }
75
+ if (parser !== "faker") {
76
+ throw new Error(`type '${type}' and parser '${parser}' can not work together`);
77
+ }
78
+ return "faker.date.anytime()";
79
+ },
80
+ /**
81
+ * Type `'date'` Date
82
+ * Type `'string'` ISO time format (HH:mm:ss[.SSSSSS])
83
+ * @default ISO time format (HH:mm:ss[.SSSSSS])
84
+ */
85
+ time: (type = "string", parser = "faker") => {
86
+ if (type === "string") {
87
+ if (parser !== "faker") {
88
+ return `${parser}(faker.date.anytime()).format("HH:mm:ss")`;
89
+ }
90
+ return "faker.date.anytime().toString()";
91
+ }
92
+ if (parser !== "faker") {
93
+ throw new Error(`type '${type}' and parser '${parser}' can not work together`);
94
+ }
95
+ return "faker.date.anytime()";
96
+ },
97
+ uuid: () => "faker.string.uuid()",
98
+ url: () => "faker.internet.url()",
99
+ and: (items = []) => `Object.assign({}, ${items.join(", ")})`,
100
+ object: () => "object",
101
+ ref: () => "ref",
102
+ matches: (value = "", regexGenerator = "faker") => {
103
+ if (regexGenerator === "randexp") {
104
+ return `${transformers__default.default.toRegExpString(value, "RandExp")}.gen()`;
105
+ }
106
+ return `faker.helpers.fromRegExp(${transformers__default.default.toRegExpString(value)})`;
107
+ },
108
+ email: () => "faker.internet.email()",
109
+ firstName: () => "faker.person.firstName()",
110
+ lastName: () => "faker.person.lastName()",
111
+ password: () => "faker.internet.password()",
112
+ phone: () => "faker.phone.number()",
113
+ blob: () => "faker.image.url() as unknown as Blob",
114
+ default: void 0,
115
+ describe: void 0,
116
+ const: (value) => value ?? "",
117
+ max: void 0,
118
+ min: void 0,
119
+ nullable: void 0,
120
+ nullish: void 0,
121
+ optional: void 0,
122
+ readOnly: void 0,
123
+ writeOnly: 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, canOverride: false })).filter(Boolean));
154
+ }
155
+ if (pluginOas.isKeyword(current, pluginOas.schemaKeywords.and)) {
156
+ return fakerKeywordMapper.and(current.args.map((schema) => parse(current, schema, { ...options, canOverride: 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, canOverride: 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.canOverride) {
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, canOverride: 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, canOverride: false })).filter(Boolean));
199
+ }
200
+ return parse(current, current.args.items, { ...options, canOverride: 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
+ function Faker({ tree, description, name, typeName, seed, regexGenerator, canOverride, mapper, dateParser }) {
258
+ const fakerText = joinItems(
259
+ tree.map(
260
+ (schema) => parse(void 0, schema, {
261
+ name,
262
+ typeName,
263
+ seed,
264
+ regexGenerator,
265
+ mapper,
266
+ canOverride,
267
+ dateParser
268
+ })
269
+ ).filter(Boolean)
270
+ );
271
+ let fakerDefaultOverride = void 0;
272
+ let fakerTextWithOverride = fakerText;
273
+ if (canOverride && fakerText.startsWith("{")) {
274
+ fakerDefaultOverride = "{}";
275
+ fakerTextWithOverride = `{
276
+ ...${fakerText},
277
+ ...data
278
+ }`;
279
+ }
280
+ if (canOverride && fakerText.startsWith("faker.helpers.arrayElements")) {
281
+ fakerDefaultOverride = "[]";
282
+ fakerTextWithOverride = `[
283
+ ...${fakerText},
284
+ ...data
285
+ ]`;
286
+ }
287
+ const params = react.FunctionParams.factory({
288
+ data: fakerDefaultOverride ? {
289
+ type: `NonNullable<Partial<${typeName}>>`,
290
+ default: fakerDefaultOverride
291
+ } : void 0
292
+ });
293
+ return /* @__PURE__ */ jsxRuntime.jsx(react.File.Source, { name, isExportable: true, isIndexable: true, children: /* @__PURE__ */ jsxRuntime.jsxs(
294
+ react.Function,
295
+ {
296
+ export: true,
297
+ name,
298
+ JSDoc: { comments: [description ? `@description ${transformers__default.default.jsStringEscape(description)}` : void 0].filter(Boolean) },
299
+ params: params.toConstructor(),
300
+ children: [
301
+ seed ? `faker.seed(${JSON.stringify(seed)})` : void 0,
302
+ /* @__PURE__ */ jsxRuntime.jsx("br", {}),
303
+ `return ${fakerTextWithOverride}`
304
+ ]
305
+ }
306
+ ) });
307
+ }
308
+
309
+ exports.Faker = Faker;
310
+ //# sourceMappingURL=chunk-KBSFZ5OP.cjs.map
311
+ //# sourceMappingURL=chunk-KBSFZ5OP.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/parser/index.ts","../src/components/Faker.tsx"],"names":["transformers","isKeyword","schemaKeywords","SchemaGenerator","value","options","FunctionParams","jsx","File","jsxs","Function"],"mappings":"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","file":"chunk-KBSFZ5OP.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\nconst 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: Options['dateParser'] = 'faker') => {\n if (type === 'string') {\n if (parser !== 'faker') {\n return `${parser}(faker.date.anytime()).format(\"YYYY-MM-DD\")`\n }\n return 'faker.date.anytime().toString()'\n }\n\n if (parser !== 'faker') {\n throw new Error(`type '${type}' and parser '${parser}' can not work together`)\n }\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: Options['dateParser'] = 'faker') => {\n if (type === 'string') {\n if (parser !== 'faker') {\n return `${parser}(faker.date.anytime()).format(\"HH:mm:ss\")`\n }\n return 'faker.date.anytime().toString()'\n }\n\n if (parser !== 'faker') {\n throw new Error(`type '${type}' and parser '${parser}' can not work together`)\n }\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.url() 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 writeOnly: 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 canOverride?: 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, canOverride: false })).filter(Boolean))\n }\n\n if (isKeyword(current, schemaKeywords.and)) {\n return fakerKeywordMapper.and(current.args.map((schema) => parse(current, schema, { ...options, canOverride: false })).filter(Boolean))\n }\n\n if (isKeyword(current, schemaKeywords.array)) {\n return fakerKeywordMapper.array(current.args.items.map((schema) => parse(current, schema, { ...options, canOverride: 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.canOverride) {\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, canOverride: 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, canOverride: false })).filter(Boolean))\n }\n\n return parse(current, current.args.items, { ...options, canOverride: 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 { File, Function, FunctionParams } from '@kubb/react'\n\nimport transformers from '@kubb/core/transformers'\nimport type { Schema } from '@kubb/plugin-oas'\nimport type { KubbNode } from '@kubb/react/types'\nimport * as parserFaker from '../parser/index.ts'\nimport type { PluginFaker } from '../types.ts'\n\ntype Props = {\n name: string\n typeName: string\n tree: Array<Schema>\n seed?: PluginFaker['options']['seed']\n description?: string\n regexGenerator?: PluginFaker['options']['regexGenerator']\n mapper?: PluginFaker['options']['mapper']\n dateParser?: PluginFaker['options']['dateParser']\n canOverride: boolean\n}\n\nexport function Faker({ tree, description, name, typeName, seed, regexGenerator, canOverride, mapper, dateParser }: Props): KubbNode {\n const fakerText = parserFaker.joinItems(\n tree\n .map((schema) =>\n parserFaker.parse(undefined, schema, {\n name,\n typeName,\n seed,\n regexGenerator,\n mapper,\n canOverride,\n dateParser,\n }),\n )\n .filter(Boolean),\n )\n\n let fakerDefaultOverride: '' | '[]' | '{}' | undefined = undefined\n let fakerTextWithOverride = fakerText\n\n if (canOverride && fakerText.startsWith('{')) {\n fakerDefaultOverride = '{}'\n fakerTextWithOverride = `{\n ...${fakerText},\n ...data\n}`\n }\n\n if (canOverride && fakerText.startsWith('faker.helpers.arrayElements')) {\n fakerDefaultOverride = '[]'\n fakerTextWithOverride = `[\n ...${fakerText},\n ...data\n ]`\n }\n\n const params = FunctionParams.factory({\n data: fakerDefaultOverride\n ? {\n type: `NonNullable<Partial<${typeName}>>`,\n default: fakerDefaultOverride,\n }\n : undefined,\n })\n\n return (\n <File.Source name={name} isExportable isIndexable>\n <Function\n export\n name={name}\n JSDoc={{ comments: [description ? `@description ${transformers.jsStringEscape(description)}` : undefined].filter(Boolean) }}\n params={params.toConstructor()}\n >\n {seed ? `faker.seed(${JSON.stringify(seed)})` : undefined}\n <br />\n {`return ${fakerTextWithOverride}`}\n </Function>\n </File.Source>\n )\n}\n"]}
@@ -0,0 +1,113 @@
1
+ import { Faker } from './chunk-HTZ2R6MK.js';
2
+ import { createReactGenerator, SchemaGenerator, schemaKeywords } from '@kubb/plugin-oas';
3
+ import { Oas } from '@kubb/plugin-oas/components';
4
+ import { useOas, useOperationManager, useSchemaManager } from '@kubb/plugin-oas/hooks';
5
+ import { pluginTsName } from '@kubb/plugin-ts';
6
+ import { useApp, File } from '@kubb/react';
7
+ import { jsxs, jsx } from '@kubb/react/jsx-runtime';
8
+
9
+ var fakerGenerator = createReactGenerator({
10
+ name: "faker",
11
+ Operation({ operation, options }) {
12
+ const { dateParser, regexGenerator, seed, mapper } = options;
13
+ const { plugin, pluginManager, mode } = useApp();
14
+ const oas = useOas();
15
+ const { getSchemas, getFile } = useOperationManager();
16
+ const schemaManager = useSchemaManager();
17
+ const file = getFile(operation);
18
+ const schemas = getSchemas(operation);
19
+ const schemaGenerator = new SchemaGenerator(options, {
20
+ oas,
21
+ plugin,
22
+ pluginManager,
23
+ mode,
24
+ override: options.override
25
+ });
26
+ const operationSchemas = [schemas.pathParams, schemas.queryParams, schemas.headerParams, schemas.statusCodes, schemas.request, schemas.response].flat().filter(Boolean);
27
+ const mapOperationSchema = ({ name, schema, description, ...options2 }, i) => {
28
+ const tree = schemaGenerator.parse({ schema, name });
29
+ const imports = schemaManager.getImports(tree);
30
+ const faker = {
31
+ name: schemaManager.getName(name, { type: "function" }),
32
+ file: schemaManager.getFile(name)
33
+ };
34
+ const type = {
35
+ name: schemaManager.getName(name, { type: "type", pluginKey: [pluginTsName] }),
36
+ file: schemaManager.getFile(options2.operationName || name, { pluginKey: [pluginTsName], tag: options2.operation?.getTags()[0]?.name })
37
+ };
38
+ const canOverride = tree.some(
39
+ ({ keyword }) => keyword === schemaKeywords.array || keyword === schemaKeywords.and || keyword === schemaKeywords.object || keyword === schemaKeywords.union || keyword === schemaKeywords.tuple
40
+ );
41
+ return /* @__PURE__ */ jsxs(Oas.Schema, { name, value: schema, tree, children: [
42
+ canOverride && /* @__PURE__ */ jsx(File.Import, { isTypeOnly: true, root: file.path, path: type.file.path, name: [type.name] }),
43
+ imports.map((imp, index) => /* @__PURE__ */ jsx(File.Import, { root: file.path, path: imp.path, name: imp.name }, index)),
44
+ /* @__PURE__ */ jsx(
45
+ Faker,
46
+ {
47
+ name: faker.name,
48
+ typeName: type.name,
49
+ description,
50
+ tree,
51
+ regexGenerator,
52
+ dateParser,
53
+ mapper,
54
+ seed,
55
+ canOverride
56
+ }
57
+ )
58
+ ] }, i);
59
+ };
60
+ return /* @__PURE__ */ jsxs(File, { baseName: file.baseName, path: file.path, meta: file.meta, banner: plugin.options.output?.banner, footer: plugin.options.output?.footer, children: [
61
+ /* @__PURE__ */ jsx(File.Import, { name: ["faker"], path: "@faker-js/faker" }),
62
+ regexGenerator === "randexp" && /* @__PURE__ */ jsx(File.Import, { name: "RandExp", path: "randexp" }),
63
+ dateParser !== "faker" && /* @__PURE__ */ jsx(File.Import, { path: dateParser, name: dateParser }),
64
+ operationSchemas.map(mapOperationSchema)
65
+ ] });
66
+ },
67
+ Schema({ schema, options }) {
68
+ const { dateParser, regexGenerator, seed, mapper } = options;
69
+ const { getName, getFile, getImports } = useSchemaManager();
70
+ const {
71
+ plugin: {
72
+ options: { output }
73
+ }
74
+ } = useApp();
75
+ const imports = getImports(schema.tree);
76
+ const faker = {
77
+ name: getName(schema.name, { type: "function" }),
78
+ file: getFile(schema.name)
79
+ };
80
+ const type = {
81
+ name: getName(schema.name, { type: "type", pluginKey: [pluginTsName] }),
82
+ file: getFile(schema.name, { pluginKey: [pluginTsName] })
83
+ };
84
+ const canOverride = schema.tree.some(
85
+ ({ keyword }) => keyword === schemaKeywords.array || keyword === schemaKeywords.and || keyword === schemaKeywords.object || keyword === schemaKeywords.union || keyword === schemaKeywords.tuple
86
+ );
87
+ return /* @__PURE__ */ jsxs(File, { baseName: faker.file.baseName, path: faker.file.path, meta: faker.file.meta, banner: output?.banner, footer: output?.footer, children: [
88
+ /* @__PURE__ */ jsx(File.Import, { name: ["faker"], path: "@faker-js/faker" }),
89
+ regexGenerator === "randexp" && /* @__PURE__ */ jsx(File.Import, { name: "RandExp", path: "randexp" }),
90
+ dateParser !== "faker" && /* @__PURE__ */ jsx(File.Import, { path: dateParser, name: dateParser }),
91
+ /* @__PURE__ */ jsx(File.Import, { isTypeOnly: true, root: faker.file.path, path: type.file.path, name: [type.name] }),
92
+ imports.map((imp, index) => /* @__PURE__ */ jsx(File.Import, { root: faker.file.path, path: imp.path, name: imp.name }, index)),
93
+ /* @__PURE__ */ jsx(
94
+ Faker,
95
+ {
96
+ name: faker.name,
97
+ typeName: type.name,
98
+ description: schema.value.description,
99
+ tree: schema.tree,
100
+ regexGenerator,
101
+ dateParser,
102
+ mapper,
103
+ seed,
104
+ canOverride
105
+ }
106
+ )
107
+ ] });
108
+ }
109
+ });
110
+
111
+ export { fakerGenerator };
112
+ //# sourceMappingURL=chunk-QFJUM25Z.js.map
113
+ //# sourceMappingURL=chunk-QFJUM25Z.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/generators/fakerGenerator.tsx"],"names":["options"],"mappings":"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","file":"chunk-QFJUM25Z.js","sourcesContent":["import { type OperationSchema as OperationSchemaType, SchemaGenerator, createReactGenerator, schemaKeywords } from '@kubb/plugin-oas'\nimport { Oas } from '@kubb/plugin-oas/components'\nimport { useOas, useOperationManager, useSchemaManager } from '@kubb/plugin-oas/hooks'\nimport { pluginTsName } from '@kubb/plugin-ts'\nimport { File, useApp } from '@kubb/react'\nimport { Faker } from '../components'\nimport type { PluginFaker } from '../types'\n\nexport const fakerGenerator = createReactGenerator<PluginFaker>({\n name: 'faker',\n Operation({ operation, options }) {\n const { dateParser, regexGenerator, seed, mapper } = options\n\n const { plugin, pluginManager, mode } = useApp<PluginFaker>()\n const oas = useOas()\n const { getSchemas, getFile } = useOperationManager()\n const schemaManager = useSchemaManager()\n\n const file = getFile(operation)\n const schemas = getSchemas(operation)\n const schemaGenerator = new SchemaGenerator(options, {\n oas,\n plugin,\n pluginManager,\n mode,\n override: options.override,\n })\n\n const operationSchemas = [schemas.pathParams, schemas.queryParams, schemas.headerParams, schemas.statusCodes, schemas.request, schemas.response]\n .flat()\n .filter(Boolean)\n\n const mapOperationSchema = ({ name, schema, description, ...options }: OperationSchemaType, i: number) => {\n const tree = schemaGenerator.parse({ schema, name })\n const imports = schemaManager.getImports(tree)\n\n const faker = {\n name: schemaManager.getName(name, { type: 'function' }),\n file: schemaManager.getFile(name),\n }\n\n const type = {\n name: schemaManager.getName(name, { type: 'type', pluginKey: [pluginTsName] }),\n file: schemaManager.getFile(options.operationName || name, { pluginKey: [pluginTsName], tag: options.operation?.getTags()[0]?.name }),\n }\n\n const canOverride = tree.some(\n ({ keyword }) =>\n keyword === schemaKeywords.array ||\n keyword === schemaKeywords.and ||\n keyword === schemaKeywords.object ||\n keyword === schemaKeywords.union ||\n keyword === schemaKeywords.tuple,\n )\n\n return (\n <Oas.Schema key={i} name={name} value={schema} tree={tree}>\n {canOverride && <File.Import isTypeOnly root={file.path} path={type.file.path} name={[type.name]} />}\n {imports.map((imp, index) => (\n <File.Import key={index} root={file.path} path={imp.path} name={imp.name} />\n ))}\n <Faker\n name={faker.name}\n typeName={type.name}\n description={description}\n tree={tree}\n regexGenerator={regexGenerator}\n dateParser={dateParser}\n mapper={mapper}\n seed={seed}\n canOverride={canOverride}\n />\n </Oas.Schema>\n )\n }\n\n return (\n <File baseName={file.baseName} path={file.path} meta={file.meta} banner={plugin.options.output?.banner} footer={plugin.options.output?.footer}>\n <File.Import name={['faker']} path=\"@faker-js/faker\" />\n {regexGenerator === 'randexp' && <File.Import name={'RandExp'} path={'randexp'} />}\n {dateParser !== 'faker' && <File.Import path={dateParser} name={dateParser} />}\n {operationSchemas.map(mapOperationSchema)}\n </File>\n )\n },\n Schema({ schema, options }) {\n const { dateParser, regexGenerator, seed, mapper } = options\n\n const { getName, getFile, getImports } = useSchemaManager()\n const {\n plugin: {\n options: { output },\n },\n } = useApp<PluginFaker>()\n const imports = getImports(schema.tree)\n\n const faker = {\n name: getName(schema.name, { type: 'function' }),\n file: getFile(schema.name),\n }\n\n const type = {\n name: getName(schema.name, { type: 'type', pluginKey: [pluginTsName] }),\n file: getFile(schema.name, { pluginKey: [pluginTsName] }),\n }\n\n const canOverride = schema.tree.some(\n ({ keyword }) =>\n keyword === schemaKeywords.array ||\n keyword === schemaKeywords.and ||\n keyword === schemaKeywords.object ||\n keyword === schemaKeywords.union ||\n keyword === schemaKeywords.tuple,\n )\n\n return (\n <File baseName={faker.file.baseName} path={faker.file.path} meta={faker.file.meta} banner={output?.banner} footer={output?.footer}>\n <File.Import name={['faker']} path=\"@faker-js/faker\" />\n {regexGenerator === 'randexp' && <File.Import name={'RandExp'} path={'randexp'} />}\n {dateParser !== 'faker' && <File.Import path={dateParser} name={dateParser} />}\n <File.Import isTypeOnly root={faker.file.path} path={type.file.path} name={[type.name]} />\n {imports.map((imp, index) => (\n <File.Import key={index} root={faker.file.path} path={imp.path} name={imp.name} />\n ))}\n\n <Faker\n name={faker.name}\n typeName={type.name}\n description={schema.value.description}\n tree={schema.tree}\n regexGenerator={regexGenerator}\n dateParser={dateParser}\n mapper={mapper}\n seed={seed}\n canOverride={canOverride}\n />\n </File>\n )\n },\n})\n"]}
@@ -0,0 +1,115 @@
1
+ 'use strict';
2
+
3
+ var chunkKBSFZ5OP_cjs = require('./chunk-KBSFZ5OP.cjs');
4
+ var pluginOas = require('@kubb/plugin-oas');
5
+ var components = require('@kubb/plugin-oas/components');
6
+ var hooks = require('@kubb/plugin-oas/hooks');
7
+ var pluginTs = require('@kubb/plugin-ts');
8
+ var react = require('@kubb/react');
9
+ var jsxRuntime = require('@kubb/react/jsx-runtime');
10
+
11
+ var fakerGenerator = pluginOas.createReactGenerator({
12
+ name: "faker",
13
+ Operation({ operation, options }) {
14
+ const { dateParser, regexGenerator, seed, mapper } = options;
15
+ const { plugin, pluginManager, mode } = react.useApp();
16
+ const oas = hooks.useOas();
17
+ const { getSchemas, getFile } = hooks.useOperationManager();
18
+ const schemaManager = hooks.useSchemaManager();
19
+ const file = getFile(operation);
20
+ const schemas = getSchemas(operation);
21
+ const schemaGenerator = new pluginOas.SchemaGenerator(options, {
22
+ oas,
23
+ plugin,
24
+ pluginManager,
25
+ mode,
26
+ override: options.override
27
+ });
28
+ const operationSchemas = [schemas.pathParams, schemas.queryParams, schemas.headerParams, schemas.statusCodes, schemas.request, schemas.response].flat().filter(Boolean);
29
+ const mapOperationSchema = ({ name, schema, description, ...options2 }, i) => {
30
+ const tree = schemaGenerator.parse({ schema, name });
31
+ const imports = schemaManager.getImports(tree);
32
+ const faker = {
33
+ name: schemaManager.getName(name, { type: "function" }),
34
+ file: schemaManager.getFile(name)
35
+ };
36
+ const type = {
37
+ name: schemaManager.getName(name, { type: "type", pluginKey: [pluginTs.pluginTsName] }),
38
+ file: schemaManager.getFile(options2.operationName || name, { pluginKey: [pluginTs.pluginTsName], tag: options2.operation?.getTags()[0]?.name })
39
+ };
40
+ const canOverride = tree.some(
41
+ ({ keyword }) => keyword === pluginOas.schemaKeywords.array || keyword === pluginOas.schemaKeywords.and || keyword === pluginOas.schemaKeywords.object || keyword === pluginOas.schemaKeywords.union || keyword === pluginOas.schemaKeywords.tuple
42
+ );
43
+ return /* @__PURE__ */ jsxRuntime.jsxs(components.Oas.Schema, { name, value: schema, tree, children: [
44
+ canOverride && /* @__PURE__ */ jsxRuntime.jsx(react.File.Import, { isTypeOnly: true, root: file.path, path: type.file.path, name: [type.name] }),
45
+ imports.map((imp, index) => /* @__PURE__ */ jsxRuntime.jsx(react.File.Import, { root: file.path, path: imp.path, name: imp.name }, index)),
46
+ /* @__PURE__ */ jsxRuntime.jsx(
47
+ chunkKBSFZ5OP_cjs.Faker,
48
+ {
49
+ name: faker.name,
50
+ typeName: type.name,
51
+ description,
52
+ tree,
53
+ regexGenerator,
54
+ dateParser,
55
+ mapper,
56
+ seed,
57
+ canOverride
58
+ }
59
+ )
60
+ ] }, i);
61
+ };
62
+ return /* @__PURE__ */ jsxRuntime.jsxs(react.File, { baseName: file.baseName, path: file.path, meta: file.meta, banner: plugin.options.output?.banner, footer: plugin.options.output?.footer, children: [
63
+ /* @__PURE__ */ jsxRuntime.jsx(react.File.Import, { name: ["faker"], path: "@faker-js/faker" }),
64
+ regexGenerator === "randexp" && /* @__PURE__ */ jsxRuntime.jsx(react.File.Import, { name: "RandExp", path: "randexp" }),
65
+ dateParser !== "faker" && /* @__PURE__ */ jsxRuntime.jsx(react.File.Import, { path: dateParser, name: dateParser }),
66
+ operationSchemas.map(mapOperationSchema)
67
+ ] });
68
+ },
69
+ Schema({ schema, options }) {
70
+ const { dateParser, regexGenerator, seed, mapper } = options;
71
+ const { getName, getFile, getImports } = hooks.useSchemaManager();
72
+ const {
73
+ plugin: {
74
+ options: { output }
75
+ }
76
+ } = react.useApp();
77
+ const imports = getImports(schema.tree);
78
+ const faker = {
79
+ name: getName(schema.name, { type: "function" }),
80
+ file: getFile(schema.name)
81
+ };
82
+ const type = {
83
+ name: getName(schema.name, { type: "type", pluginKey: [pluginTs.pluginTsName] }),
84
+ file: getFile(schema.name, { pluginKey: [pluginTs.pluginTsName] })
85
+ };
86
+ const canOverride = schema.tree.some(
87
+ ({ keyword }) => keyword === pluginOas.schemaKeywords.array || keyword === pluginOas.schemaKeywords.and || keyword === pluginOas.schemaKeywords.object || keyword === pluginOas.schemaKeywords.union || keyword === pluginOas.schemaKeywords.tuple
88
+ );
89
+ return /* @__PURE__ */ jsxRuntime.jsxs(react.File, { baseName: faker.file.baseName, path: faker.file.path, meta: faker.file.meta, banner: output?.banner, footer: output?.footer, children: [
90
+ /* @__PURE__ */ jsxRuntime.jsx(react.File.Import, { name: ["faker"], path: "@faker-js/faker" }),
91
+ regexGenerator === "randexp" && /* @__PURE__ */ jsxRuntime.jsx(react.File.Import, { name: "RandExp", path: "randexp" }),
92
+ dateParser !== "faker" && /* @__PURE__ */ jsxRuntime.jsx(react.File.Import, { path: dateParser, name: dateParser }),
93
+ /* @__PURE__ */ jsxRuntime.jsx(react.File.Import, { isTypeOnly: true, root: faker.file.path, path: type.file.path, name: [type.name] }),
94
+ imports.map((imp, index) => /* @__PURE__ */ jsxRuntime.jsx(react.File.Import, { root: faker.file.path, path: imp.path, name: imp.name }, index)),
95
+ /* @__PURE__ */ jsxRuntime.jsx(
96
+ chunkKBSFZ5OP_cjs.Faker,
97
+ {
98
+ name: faker.name,
99
+ typeName: type.name,
100
+ description: schema.value.description,
101
+ tree: schema.tree,
102
+ regexGenerator,
103
+ dateParser,
104
+ mapper,
105
+ seed,
106
+ canOverride
107
+ }
108
+ )
109
+ ] });
110
+ }
111
+ });
112
+
113
+ exports.fakerGenerator = fakerGenerator;
114
+ //# sourceMappingURL=chunk-U6LOSTOE.cjs.map
115
+ //# sourceMappingURL=chunk-U6LOSTOE.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/generators/fakerGenerator.tsx"],"names":["createReactGenerator","useApp","useOas","useOperationManager","useSchemaManager","SchemaGenerator","options","pluginTsName","schemaKeywords","Oas","File","jsx","Faker","jsxs"],"mappings":"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","file":"chunk-U6LOSTOE.cjs","sourcesContent":["import { type OperationSchema as OperationSchemaType, SchemaGenerator, createReactGenerator, schemaKeywords } from '@kubb/plugin-oas'\nimport { Oas } from '@kubb/plugin-oas/components'\nimport { useOas, useOperationManager, useSchemaManager } from '@kubb/plugin-oas/hooks'\nimport { pluginTsName } from '@kubb/plugin-ts'\nimport { File, useApp } from '@kubb/react'\nimport { Faker } from '../components'\nimport type { PluginFaker } from '../types'\n\nexport const fakerGenerator = createReactGenerator<PluginFaker>({\n name: 'faker',\n Operation({ operation, options }) {\n const { dateParser, regexGenerator, seed, mapper } = options\n\n const { plugin, pluginManager, mode } = useApp<PluginFaker>()\n const oas = useOas()\n const { getSchemas, getFile } = useOperationManager()\n const schemaManager = useSchemaManager()\n\n const file = getFile(operation)\n const schemas = getSchemas(operation)\n const schemaGenerator = new SchemaGenerator(options, {\n oas,\n plugin,\n pluginManager,\n mode,\n override: options.override,\n })\n\n const operationSchemas = [schemas.pathParams, schemas.queryParams, schemas.headerParams, schemas.statusCodes, schemas.request, schemas.response]\n .flat()\n .filter(Boolean)\n\n const mapOperationSchema = ({ name, schema, description, ...options }: OperationSchemaType, i: number) => {\n const tree = schemaGenerator.parse({ schema, name })\n const imports = schemaManager.getImports(tree)\n\n const faker = {\n name: schemaManager.getName(name, { type: 'function' }),\n file: schemaManager.getFile(name),\n }\n\n const type = {\n name: schemaManager.getName(name, { type: 'type', pluginKey: [pluginTsName] }),\n file: schemaManager.getFile(options.operationName || name, { pluginKey: [pluginTsName], tag: options.operation?.getTags()[0]?.name }),\n }\n\n const canOverride = tree.some(\n ({ keyword }) =>\n keyword === schemaKeywords.array ||\n keyword === schemaKeywords.and ||\n keyword === schemaKeywords.object ||\n keyword === schemaKeywords.union ||\n keyword === schemaKeywords.tuple,\n )\n\n return (\n <Oas.Schema key={i} name={name} value={schema} tree={tree}>\n {canOverride && <File.Import isTypeOnly root={file.path} path={type.file.path} name={[type.name]} />}\n {imports.map((imp, index) => (\n <File.Import key={index} root={file.path} path={imp.path} name={imp.name} />\n ))}\n <Faker\n name={faker.name}\n typeName={type.name}\n description={description}\n tree={tree}\n regexGenerator={regexGenerator}\n dateParser={dateParser}\n mapper={mapper}\n seed={seed}\n canOverride={canOverride}\n />\n </Oas.Schema>\n )\n }\n\n return (\n <File baseName={file.baseName} path={file.path} meta={file.meta} banner={plugin.options.output?.banner} footer={plugin.options.output?.footer}>\n <File.Import name={['faker']} path=\"@faker-js/faker\" />\n {regexGenerator === 'randexp' && <File.Import name={'RandExp'} path={'randexp'} />}\n {dateParser !== 'faker' && <File.Import path={dateParser} name={dateParser} />}\n {operationSchemas.map(mapOperationSchema)}\n </File>\n )\n },\n Schema({ schema, options }) {\n const { dateParser, regexGenerator, seed, mapper } = options\n\n const { getName, getFile, getImports } = useSchemaManager()\n const {\n plugin: {\n options: { output },\n },\n } = useApp<PluginFaker>()\n const imports = getImports(schema.tree)\n\n const faker = {\n name: getName(schema.name, { type: 'function' }),\n file: getFile(schema.name),\n }\n\n const type = {\n name: getName(schema.name, { type: 'type', pluginKey: [pluginTsName] }),\n file: getFile(schema.name, { pluginKey: [pluginTsName] }),\n }\n\n const canOverride = schema.tree.some(\n ({ keyword }) =>\n keyword === schemaKeywords.array ||\n keyword === schemaKeywords.and ||\n keyword === schemaKeywords.object ||\n keyword === schemaKeywords.union ||\n keyword === schemaKeywords.tuple,\n )\n\n return (\n <File baseName={faker.file.baseName} path={faker.file.path} meta={faker.file.meta} banner={output?.banner} footer={output?.footer}>\n <File.Import name={['faker']} path=\"@faker-js/faker\" />\n {regexGenerator === 'randexp' && <File.Import name={'RandExp'} path={'randexp'} />}\n {dateParser !== 'faker' && <File.Import path={dateParser} name={dateParser} />}\n <File.Import isTypeOnly root={faker.file.path} path={type.file.path} name={[type.name]} />\n {imports.map((imp, index) => (\n <File.Import key={index} root={faker.file.path} path={imp.path} name={imp.name} />\n ))}\n\n <Faker\n name={faker.name}\n typeName={type.name}\n description={schema.value.description}\n tree={schema.tree}\n regexGenerator={regexGenerator}\n dateParser={dateParser}\n mapper={mapper}\n seed={seed}\n canOverride={canOverride}\n />\n </File>\n )\n },\n})\n"]}