@kubb/plugin-faker 0.0.0-canary-20241104172400

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 (53) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +53 -0
  3. package/dist/chunk-FCIZHQ4X.cjs +339 -0
  4. package/dist/chunk-FCIZHQ4X.cjs.map +1 -0
  5. package/dist/chunk-OOL6ZKDZ.cjs +115 -0
  6. package/dist/chunk-OOL6ZKDZ.cjs.map +1 -0
  7. package/dist/chunk-PLVSF3YP.js +333 -0
  8. package/dist/chunk-PLVSF3YP.js.map +1 -0
  9. package/dist/chunk-ZOJMDISS.js +113 -0
  10. package/dist/chunk-ZOJMDISS.js.map +1 -0
  11. package/dist/components.cjs +12 -0
  12. package/dist/components.cjs.map +1 -0
  13. package/dist/components.d.cts +20 -0
  14. package/dist/components.d.ts +20 -0
  15. package/dist/components.js +3 -0
  16. package/dist/components.js.map +1 -0
  17. package/dist/generators.cjs +13 -0
  18. package/dist/generators.cjs.map +1 -0
  19. package/dist/generators.d.cts +8 -0
  20. package/dist/generators.d.ts +8 -0
  21. package/dist/generators.js +4 -0
  22. package/dist/generators.js.map +1 -0
  23. package/dist/index.cjs +115 -0
  24. package/dist/index.cjs.map +1 -0
  25. package/dist/index.d.cts +9 -0
  26. package/dist/index.d.ts +9 -0
  27. package/dist/index.js +108 -0
  28. package/dist/index.js.map +1 -0
  29. package/dist/types-Cq8z4Gto.d.cts +95 -0
  30. package/dist/types-Cq8z4Gto.d.ts +95 -0
  31. package/package.json +98 -0
  32. package/src/components/Faker.tsx +82 -0
  33. package/src/components/index.ts +1 -0
  34. package/src/generators/__snapshots__/createPet.ts +26 -0
  35. package/src/generators/__snapshots__/createPetSeed.ts +30 -0
  36. package/src/generators/__snapshots__/createPetUnknownTypeAny.ts +26 -0
  37. package/src/generators/__snapshots__/deletePet.ts +3 -0
  38. package/src/generators/__snapshots__/enumNames.ts +5 -0
  39. package/src/generators/__snapshots__/enumVarNames.ts +5 -0
  40. package/src/generators/__snapshots__/getPets.ts +26 -0
  41. package/src/generators/__snapshots__/pet.ts +8 -0
  42. package/src/generators/__snapshots__/petWithDateString.ts +8 -0
  43. package/src/generators/__snapshots__/petWithDayjs.ts +9 -0
  44. package/src/generators/__snapshots__/petWithMapper.ts +8 -0
  45. package/src/generators/__snapshots__/petWithRandExp.ts +9 -0
  46. package/src/generators/__snapshots__/pets.ts +8 -0
  47. package/src/generators/__snapshots__/showPetById.ts +26 -0
  48. package/src/generators/fakerGenerator.tsx +140 -0
  49. package/src/generators/index.ts +1 -0
  50. package/src/index.ts +2 -0
  51. package/src/parser/index.ts +351 -0
  52. package/src/plugin.ts +128 -0
  53. package/src/types.ts +92 -0
@@ -0,0 +1,333 @@
1
+ import { FunctionParams, File, Function } from '@kubb/react';
2
+ import transformers from '@kubb/core/transformers';
3
+ import { isKeyword, schemaKeywords, SchemaGenerator } from '@kubb/plugin-oas';
4
+ import { jsx, jsxs } from '@kubb/react/jsx-runtime';
5
+
6
+ // src/components/Faker.tsx
7
+ var fakerKeywordMapper = {
8
+ any: () => "undefined",
9
+ unknown: () => "unknown",
10
+ number: (min, max) => {
11
+ if (max !== void 0 && min !== void 0) {
12
+ return `faker.number.float({ min: ${min}, max: ${max} })`;
13
+ }
14
+ if (min !== void 0) {
15
+ return `faker.number.float({ min: ${min} })`;
16
+ }
17
+ if (max !== void 0) {
18
+ return `faker.number.float({ max: ${max} })`;
19
+ }
20
+ return "faker.number.float()";
21
+ },
22
+ integer: (min, max) => {
23
+ if (max !== void 0 && min !== void 0) {
24
+ return `faker.number.int({ min: ${min}, max: ${max} })`;
25
+ }
26
+ if (min !== void 0) {
27
+ return `faker.number.int({ min: ${min} })`;
28
+ }
29
+ if (max !== void 0) {
30
+ return `faker.number.int({ max: ${max} })`;
31
+ }
32
+ return "faker.number.int()";
33
+ },
34
+ string: (min, max) => {
35
+ if (max !== void 0 && min !== void 0) {
36
+ return `faker.string.alpha({ length: { min: ${min}, max: ${max} } })`;
37
+ }
38
+ if (min !== void 0) {
39
+ return `faker.string.alpha({ length: { min: ${min} } })`;
40
+ }
41
+ if (max !== void 0) {
42
+ return `faker.string.alpha({ length: { max: ${max} } })`;
43
+ }
44
+ return "faker.string.alpha()";
45
+ },
46
+ boolean: () => "faker.datatype.boolean()",
47
+ undefined: () => "undefined",
48
+ null: () => "null",
49
+ array: (items = [], min, max) => {
50
+ if (items.length > 1) {
51
+ return `faker.helpers.arrayElements([${items.join(", ")}]) as any`;
52
+ }
53
+ const item = items.at(0);
54
+ if (min !== void 0 && max !== void 0) {
55
+ return `faker.helpers.multiple(() => (${item}), { count: { min: ${min}, max: ${max} }}) as any`;
56
+ }
57
+ if (min !== void 0) {
58
+ return `faker.helpers.multiple(() => (${item}), { count: ${min} }) as any`;
59
+ }
60
+ if (max !== void 0) {
61
+ return `faker.helpers.multiple(() => (${item}), { count: { min: 0, max: ${max} }}) as any`;
62
+ }
63
+ return `faker.helpers.multiple(() => (${item})) as any`;
64
+ },
65
+ tuple: (items = []) => `faker.helpers.arrayElements([${items.join(", ")}]) as any`,
66
+ enum: (items = []) => `faker.helpers.arrayElement<any>([${items.join(", ")}])`,
67
+ union: (items = []) => `faker.helpers.arrayElement<any>([${items.join(", ")}])`,
68
+ /**
69
+ * ISO 8601
70
+ */
71
+ datetime: () => "faker.date.anytime().toISOString()",
72
+ /**
73
+ * Type `'date'` Date
74
+ * Type `'string'` ISO date format (YYYY-MM-DD)
75
+ * @default ISO date format (YYYY-MM-DD)
76
+ */
77
+ date: (type = "string", parser = "faker") => {
78
+ if (type === "string") {
79
+ if (parser !== "faker") {
80
+ return `${parser}(faker.date.anytime()).format("YYYY-MM-DD")`;
81
+ }
82
+ return "faker.date.anytime().toString()";
83
+ }
84
+ if (parser !== "faker") {
85
+ throw new Error(`type '${type}' and parser '${parser}' can not work together`);
86
+ }
87
+ return "faker.date.anytime()";
88
+ },
89
+ /**
90
+ * Type `'date'` Date
91
+ * Type `'string'` ISO time format (HH:mm:ss[.SSSSSS])
92
+ * @default ISO time format (HH:mm:ss[.SSSSSS])
93
+ */
94
+ time: (type = "string", parser = "faker") => {
95
+ if (type === "string") {
96
+ if (parser !== "faker") {
97
+ return `${parser}(faker.date.anytime()).format("HH:mm:ss")`;
98
+ }
99
+ return "faker.date.anytime().toString()";
100
+ }
101
+ if (parser !== "faker") {
102
+ throw new Error(`type '${type}' and parser '${parser}' can not work together`);
103
+ }
104
+ return "faker.date.anytime()";
105
+ },
106
+ uuid: () => "faker.string.uuid()",
107
+ url: () => "faker.internet.url()",
108
+ and: (items = []) => `Object.assign({}, ${items.join(", ")})`,
109
+ object: () => "object",
110
+ ref: () => "ref",
111
+ matches: (value = "", regexGenerator = "faker") => {
112
+ if (regexGenerator === "randexp") {
113
+ return `${transformers.toRegExpString(value, "RandExp")}.gen()`;
114
+ }
115
+ return `faker.helpers.fromRegExp(${transformers.toRegExpString(value)})`;
116
+ },
117
+ email: () => "faker.internet.email()",
118
+ firstName: () => "faker.person.firstName()",
119
+ lastName: () => "faker.person.lastName()",
120
+ password: () => "faker.internet.password()",
121
+ phone: () => "faker.phone.number()",
122
+ blob: () => "faker.image.url() as unknown as Blob",
123
+ default: void 0,
124
+ describe: void 0,
125
+ const: (value) => value ?? "",
126
+ max: void 0,
127
+ min: void 0,
128
+ nullable: void 0,
129
+ nullish: void 0,
130
+ optional: void 0,
131
+ readOnly: void 0,
132
+ writeOnly: void 0,
133
+ strict: void 0,
134
+ deprecated: void 0,
135
+ example: void 0,
136
+ schema: void 0,
137
+ catchall: void 0,
138
+ name: void 0
139
+ };
140
+ function schemaKeywordsorter(a, b) {
141
+ if (b.keyword === "null") {
142
+ return -1;
143
+ }
144
+ return 0;
145
+ }
146
+ function joinItems(items) {
147
+ switch (items.length) {
148
+ case 0:
149
+ return "undefined";
150
+ case 1:
151
+ return items[0];
152
+ default:
153
+ return fakerKeywordMapper.union(items);
154
+ }
155
+ }
156
+ function parse({ parent, current, siblings }, options) {
157
+ const value = fakerKeywordMapper[current.keyword];
158
+ if (!value) {
159
+ return void 0;
160
+ }
161
+ if (isKeyword(current, schemaKeywords.union)) {
162
+ return fakerKeywordMapper.union(
163
+ current.args.map((schema) => parse({ parent: current, current: schema, siblings }, { ...options, canOverride: false })).filter(Boolean)
164
+ );
165
+ }
166
+ if (isKeyword(current, schemaKeywords.and)) {
167
+ return fakerKeywordMapper.and(
168
+ current.args.map((schema) => parse({ parent: current, current: schema, siblings }, { ...options, canOverride: false })).filter(Boolean)
169
+ );
170
+ }
171
+ if (isKeyword(current, schemaKeywords.array)) {
172
+ return fakerKeywordMapper.array(
173
+ current.args.items.map((schema) => parse({ parent: current, current: schema, siblings }, { ...options, canOverride: false })).filter(Boolean),
174
+ current.args.min,
175
+ current.args.max
176
+ );
177
+ }
178
+ if (isKeyword(current, schemaKeywords.enum)) {
179
+ return fakerKeywordMapper.enum(
180
+ current.args.items.map((schema) => {
181
+ if (schema.format === "number") {
182
+ return schema.name;
183
+ }
184
+ return transformers.stringify(schema.name);
185
+ })
186
+ );
187
+ }
188
+ if (isKeyword(current, schemaKeywords.ref)) {
189
+ if (!current.args?.name) {
190
+ throw new Error(`Name not defined for keyword ${current.keyword}`);
191
+ }
192
+ if (options.canOverride) {
193
+ return `${current.args.name}(data)`;
194
+ }
195
+ return `${current.args.name}()`;
196
+ }
197
+ if (isKeyword(current, schemaKeywords.object)) {
198
+ const argsObject = Object.entries(current.args?.properties || {}).filter((item) => {
199
+ const schema = item[1];
200
+ return schema && typeof schema.map === "function";
201
+ }).map(([name, schemas]) => {
202
+ const nameSchema = schemas.find((schema) => schema.keyword === schemaKeywords.name);
203
+ const mappedName = nameSchema?.args || name;
204
+ if (options.mapper?.[mappedName]) {
205
+ return `"${name}": ${options.mapper?.[mappedName]}`;
206
+ }
207
+ return `"${name}": ${joinItems(
208
+ schemas.sort(schemaKeywordsorter).map((schema) => parse({ parent: current, current: schema, siblings }, { ...options, canOverride: false })).filter(Boolean)
209
+ )}`;
210
+ }).join(",");
211
+ return `{${argsObject}}`;
212
+ }
213
+ if (isKeyword(current, schemaKeywords.tuple)) {
214
+ if (Array.isArray(current.args.items)) {
215
+ return fakerKeywordMapper.tuple(
216
+ current.args.items.map((schema) => parse({ parent: current, current: schema, siblings }, { ...options, canOverride: false })).filter(Boolean)
217
+ );
218
+ }
219
+ return parse({ parent: current, current: current.args.items, siblings }, { ...options, canOverride: false });
220
+ }
221
+ if (isKeyword(current, schemaKeywords.const)) {
222
+ if (current.args.format === "number" && current.args.name !== void 0) {
223
+ return fakerKeywordMapper.const(current.args.name?.toString());
224
+ }
225
+ return fakerKeywordMapper.const(transformers.stringify(current.args.value));
226
+ }
227
+ if (isKeyword(current, schemaKeywords.matches) && current.args) {
228
+ return fakerKeywordMapper.matches(current.args, options.regexGenerator);
229
+ }
230
+ if (isKeyword(current, schemaKeywords.null) || isKeyword(current, schemaKeywords.undefined) || isKeyword(current, schemaKeywords.any)) {
231
+ return value() || "";
232
+ }
233
+ if (isKeyword(current, schemaKeywords.string)) {
234
+ if (parent) {
235
+ const minSchema = SchemaGenerator.find([parent], schemaKeywords.min);
236
+ const maxSchema = SchemaGenerator.find([parent], schemaKeywords.max);
237
+ return fakerKeywordMapper.string(minSchema?.args, maxSchema?.args);
238
+ }
239
+ return fakerKeywordMapper.string();
240
+ }
241
+ if (isKeyword(current, schemaKeywords.number)) {
242
+ if (parent) {
243
+ const minSchema = SchemaGenerator.find([parent], schemaKeywords.min);
244
+ const maxSchema = SchemaGenerator.find([parent], schemaKeywords.max);
245
+ return fakerKeywordMapper.number(minSchema?.args, maxSchema?.args);
246
+ }
247
+ return fakerKeywordMapper.number();
248
+ }
249
+ if (isKeyword(current, schemaKeywords.integer)) {
250
+ if (parent) {
251
+ const minSchema = SchemaGenerator.find([parent], schemaKeywords.min);
252
+ const maxSchema = SchemaGenerator.find([parent], schemaKeywords.max);
253
+ return fakerKeywordMapper.integer(minSchema?.args, maxSchema?.args);
254
+ }
255
+ return fakerKeywordMapper.integer();
256
+ }
257
+ if (isKeyword(current, schemaKeywords.datetime)) {
258
+ return fakerKeywordMapper.datetime();
259
+ }
260
+ if (isKeyword(current, schemaKeywords.date)) {
261
+ return fakerKeywordMapper.date(current.args.type, options.dateParser);
262
+ }
263
+ if (isKeyword(current, schemaKeywords.time)) {
264
+ return fakerKeywordMapper.time(current.args.type, options.dateParser);
265
+ }
266
+ if (current.keyword in fakerKeywordMapper && "args" in current) {
267
+ const value2 = fakerKeywordMapper[current.keyword];
268
+ const options2 = JSON.stringify(current.args);
269
+ return value2(options2);
270
+ }
271
+ if (current.keyword in fakerKeywordMapper) {
272
+ return value();
273
+ }
274
+ return void 0;
275
+ }
276
+ function Faker({ tree, description, name, typeName, seed, regexGenerator, canOverride, mapper, dateParser }) {
277
+ const fakerText = joinItems(
278
+ tree.map(
279
+ (schema, _index, siblings) => parse(
280
+ { parent: void 0, current: schema, siblings },
281
+ {
282
+ name,
283
+ typeName,
284
+ seed,
285
+ regexGenerator,
286
+ mapper,
287
+ canOverride,
288
+ dateParser
289
+ }
290
+ )
291
+ ).filter(Boolean)
292
+ );
293
+ let fakerTextWithOverride = fakerText;
294
+ if (canOverride && fakerText.startsWith("{")) {
295
+ fakerTextWithOverride = `{
296
+ ...${fakerText},
297
+ ...data || {}
298
+ }`;
299
+ }
300
+ if (canOverride && fakerText.startsWith("faker.helpers.arrayElement")) {
301
+ fakerTextWithOverride = `${fakerText} || data`;
302
+ }
303
+ if (canOverride && fakerText.startsWith("faker.helpers.arrayElements") || fakerText.startsWith("faker.helpers.multiple")) {
304
+ fakerTextWithOverride = `[
305
+ ...${fakerText},
306
+ ...data || []
307
+ ]`;
308
+ }
309
+ const params = FunctionParams.factory({
310
+ data: {
311
+ type: `Partial<${typeName}>`,
312
+ optional: true
313
+ }
314
+ });
315
+ return /* @__PURE__ */ jsx(File.Source, { name, isExportable: true, isIndexable: true, children: /* @__PURE__ */ jsxs(
316
+ Function,
317
+ {
318
+ export: true,
319
+ name,
320
+ JSDoc: { comments: [description ? `@description ${transformers.jsStringEscape(description)}` : void 0].filter(Boolean) },
321
+ params: canOverride ? params.toConstructor() : void 0,
322
+ children: [
323
+ seed ? `faker.seed(${JSON.stringify(seed)})` : void 0,
324
+ /* @__PURE__ */ jsx("br", {}),
325
+ `return ${fakerTextWithOverride}`
326
+ ]
327
+ }
328
+ ) });
329
+ }
330
+
331
+ export { Faker };
332
+ //# sourceMappingURL=chunk-PLVSF3YP.js.map
333
+ //# sourceMappingURL=chunk-PLVSF3YP.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/parser/index.ts","../src/components/Faker.tsx"],"names":["value","options","transformers"],"mappings":"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","file":"chunk-PLVSF3YP.js","sourcesContent":["import transformers from '@kubb/core/transformers'\nimport { SchemaGenerator, type SchemaTree, 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[] = [], min?: number, max?: number) => {\n if (items.length > 1) {\n return `faker.helpers.arrayElements([${items.join(', ')}]) as any`\n }\n const item = items.at(0)\n\n if (min !== undefined && max !== undefined) {\n return `faker.helpers.multiple(() => (${item}), { count: { min: ${min}, max: ${max} }}) as any`\n }\n if (min !== undefined) {\n return `faker.helpers.multiple(() => (${item}), { count: ${min} }) as any`\n }\n if (max !== undefined) {\n return `faker.helpers.multiple(() => (${item}), { count: { min: 0, max: ${max} }}) as any`\n }\n\n return `faker.helpers.multiple(() => (${item})) as any`\n },\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, current, siblings }: SchemaTree, 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(\n current.args.map((schema) => parse({ parent: current, current: schema, siblings }, { ...options, canOverride: false })).filter(Boolean),\n )\n }\n\n if (isKeyword(current, schemaKeywords.and)) {\n return fakerKeywordMapper.and(\n current.args.map((schema) => parse({ parent: current, current: schema, siblings }, { ...options, canOverride: false })).filter(Boolean),\n )\n }\n\n if (isKeyword(current, schemaKeywords.array)) {\n return fakerKeywordMapper.array(\n current.args.items.map((schema) => parse({ parent: current, current: schema, siblings }, { ...options, canOverride: false })).filter(Boolean),\n current.args.min,\n current.args.max,\n )\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({ parent: current, current: schema, siblings }, { ...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(\n current.args.items.map((schema) => parse({ parent: current, current: schema, siblings }, { ...options, canOverride: false })).filter(Boolean),\n )\n }\n\n return parse({ parent: current, current: current.args.items, siblings }, { ...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, _index, siblings) =>\n parserFaker.parse(\n { parent: undefined, current: schema, siblings },\n {\n name,\n typeName,\n seed,\n regexGenerator,\n mapper,\n canOverride,\n dateParser,\n },\n ),\n )\n .filter(Boolean),\n )\n\n let fakerTextWithOverride = fakerText\n\n if (canOverride && fakerText.startsWith('{')) {\n fakerTextWithOverride = `{\n ...${fakerText},\n ...data || {}\n}`\n }\n\n if (canOverride && fakerText.startsWith('faker.helpers.arrayElement')) {\n fakerTextWithOverride = `${fakerText} || data`\n }\n\n if ((canOverride && fakerText.startsWith('faker.helpers.arrayElements')) || fakerText.startsWith('faker.helpers.multiple')) {\n fakerTextWithOverride = `[\n ...${fakerText},\n ...data || []\n ]`\n }\n\n const params = FunctionParams.factory({\n data: {\n type: `Partial<${typeName}>`,\n optional: true,\n },\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={canOverride ? params.toConstructor() : undefined}\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-PLVSF3YP.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-ZOJMDISS.js.map
113
+ //# sourceMappingURL=chunk-ZOJMDISS.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/generators/fakerGenerator.tsx"],"names":["options"],"mappings":"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","file":"chunk-ZOJMDISS.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,12 @@
1
+ 'use strict';
2
+
3
+ var chunkFCIZHQ4X_cjs = require('./chunk-FCIZHQ4X.cjs');
4
+
5
+
6
+
7
+ Object.defineProperty(exports, "Faker", {
8
+ enumerable: true,
9
+ get: function () { return chunkFCIZHQ4X_cjs.Faker; }
10
+ });
11
+ //# sourceMappingURL=components.cjs.map
12
+ //# sourceMappingURL=components.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":[],"names":[],"mappings":"","file":"components.cjs"}
@@ -0,0 +1,20 @@
1
+ import { Schema } from '@kubb/plugin-oas';
2
+ import { KubbNode } from '@kubb/react/types';
3
+ import { P as PluginFaker } from './types-Cq8z4Gto.cjs';
4
+ import '@kubb/core';
5
+ import '@kubb/oas';
6
+
7
+ type Props = {
8
+ name: string;
9
+ typeName: string;
10
+ tree: Array<Schema>;
11
+ seed?: PluginFaker['options']['seed'];
12
+ description?: string;
13
+ regexGenerator?: PluginFaker['options']['regexGenerator'];
14
+ mapper?: PluginFaker['options']['mapper'];
15
+ dateParser?: PluginFaker['options']['dateParser'];
16
+ canOverride: boolean;
17
+ };
18
+ declare function Faker({ tree, description, name, typeName, seed, regexGenerator, canOverride, mapper, dateParser }: Props): KubbNode;
19
+
20
+ export { Faker };
@@ -0,0 +1,20 @@
1
+ import { Schema } from '@kubb/plugin-oas';
2
+ import { KubbNode } from '@kubb/react/types';
3
+ import { P as PluginFaker } from './types-Cq8z4Gto.js';
4
+ import '@kubb/core';
5
+ import '@kubb/oas';
6
+
7
+ type Props = {
8
+ name: string;
9
+ typeName: string;
10
+ tree: Array<Schema>;
11
+ seed?: PluginFaker['options']['seed'];
12
+ description?: string;
13
+ regexGenerator?: PluginFaker['options']['regexGenerator'];
14
+ mapper?: PluginFaker['options']['mapper'];
15
+ dateParser?: PluginFaker['options']['dateParser'];
16
+ canOverride: boolean;
17
+ };
18
+ declare function Faker({ tree, description, name, typeName, seed, regexGenerator, canOverride, mapper, dateParser }: Props): KubbNode;
19
+
20
+ export { Faker };
@@ -0,0 +1,3 @@
1
+ export { Faker } from './chunk-PLVSF3YP.js';
2
+ //# sourceMappingURL=components.js.map
3
+ //# sourceMappingURL=components.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":[],"names":[],"mappings":"","file":"components.js"}
@@ -0,0 +1,13 @@
1
+ 'use strict';
2
+
3
+ var chunkOOL6ZKDZ_cjs = require('./chunk-OOL6ZKDZ.cjs');
4
+ require('./chunk-FCIZHQ4X.cjs');
5
+
6
+
7
+
8
+ Object.defineProperty(exports, "fakerGenerator", {
9
+ enumerable: true,
10
+ get: function () { return chunkOOL6ZKDZ_cjs.fakerGenerator; }
11
+ });
12
+ //# sourceMappingURL=generators.cjs.map
13
+ //# sourceMappingURL=generators.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":[],"names":[],"mappings":"","file":"generators.cjs"}
@@ -0,0 +1,8 @@
1
+ import * as _kubb_plugin_oas from '@kubb/plugin-oas';
2
+ import { P as PluginFaker } from './types-Cq8z4Gto.cjs';
3
+ import '@kubb/core';
4
+ import '@kubb/oas';
5
+
6
+ declare const fakerGenerator: _kubb_plugin_oas.Generator<PluginFaker>;
7
+
8
+ export { fakerGenerator };
@@ -0,0 +1,8 @@
1
+ import * as _kubb_plugin_oas from '@kubb/plugin-oas';
2
+ import { P as PluginFaker } from './types-Cq8z4Gto.js';
3
+ import '@kubb/core';
4
+ import '@kubb/oas';
5
+
6
+ declare const fakerGenerator: _kubb_plugin_oas.Generator<PluginFaker>;
7
+
8
+ export { fakerGenerator };
@@ -0,0 +1,4 @@
1
+ export { fakerGenerator } from './chunk-ZOJMDISS.js';
2
+ import './chunk-PLVSF3YP.js';
3
+ //# sourceMappingURL=generators.js.map
4
+ //# sourceMappingURL=generators.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":[],"names":[],"mappings":"","file":"generators.js"}