@kubb/plugin-faker 3.0.0-alpha.2 → 3.0.0-alpha.21

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 +13 -4
  2. package/dist/chunk-4AVWJQH5.js +113 -0
  3. package/dist/chunk-4AVWJQH5.js.map +1 -0
  4. package/dist/chunk-4I5F76DK.cjs +310 -0
  5. package/dist/chunk-4I5F76DK.cjs.map +1 -0
  6. package/dist/chunk-JVUPDWN2.js +304 -0
  7. package/dist/chunk-JVUPDWN2.js.map +1 -0
  8. package/dist/chunk-WYCU2YG6.cjs +115 -0
  9. package/dist/chunk-WYCU2YG6.cjs.map +1 -0
  10. package/dist/components.cjs +6 -565
  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 -570
  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 +51 -504
  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 +34 -494
  27. package/dist/index.js.map +1 -1
  28. package/dist/types-dutOIgtG.d.cts +108 -0
  29. package/dist/types-dutOIgtG.d.ts +108 -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 +24 -14
  50. package/src/plugin.ts +20 -33
  51. package/src/types.ts +22 -47
  52. package/src/OperationGenerator.tsx +0 -30
  53. package/src/SchemaGenerator.tsx +0 -31
  54. package/src/components/OperationSchema.tsx +0 -84
  55. package/src/components/Schema.tsx +0 -146
@@ -0,0 +1,304 @@
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 = []) => `faker.helpers.arrayElements([${items.join(", ")}]) as any`,
50
+ tuple: (items = []) => `faker.helpers.arrayElements([${items.join(", ")}]) as any`,
51
+ enum: (items = []) => `faker.helpers.arrayElement<any>([${items.join(", ")}])`,
52
+ union: (items = []) => `faker.helpers.arrayElement<any>([${items.join(", ")}])`,
53
+ /**
54
+ * ISO 8601
55
+ */
56
+ datetime: () => "faker.date.anytime().toISOString()",
57
+ /**
58
+ * Type `'date'` Date
59
+ * Type `'string'` ISO date format (YYYY-MM-DD)
60
+ * @default ISO date format (YYYY-MM-DD)
61
+ */
62
+ date: (type = "string", parser = "faker") => {
63
+ if (type === "string") {
64
+ if (parser !== "faker") {
65
+ return `${parser}(faker.date.anytime()).format("YYYY-MM-DD")`;
66
+ }
67
+ return "faker.date.anytime().toString()";
68
+ }
69
+ if (parser !== "faker") {
70
+ throw new Error(`type '${type}' and parser '${parser}' can not work together`);
71
+ }
72
+ return "faker.date.anytime()";
73
+ },
74
+ /**
75
+ * Type `'date'` Date
76
+ * Type `'string'` ISO time format (HH:mm:ss[.SSSSSS])
77
+ * @default ISO time format (HH:mm:ss[.SSSSSS])
78
+ */
79
+ time: (type = "string", parser = "faker") => {
80
+ if (type === "string") {
81
+ if (parser !== "faker") {
82
+ return `${parser}(faker.date.anytime()).format("HH:mm:ss")`;
83
+ }
84
+ return "faker.date.anytime().toString()";
85
+ }
86
+ if (parser !== "faker") {
87
+ throw new Error(`type '${type}' and parser '${parser}' can not work together`);
88
+ }
89
+ return "faker.date.anytime()";
90
+ },
91
+ uuid: () => "faker.string.uuid()",
92
+ url: () => "faker.internet.url()",
93
+ and: (items = []) => `Object.assign({}, ${items.join(", ")})`,
94
+ object: () => "object",
95
+ ref: () => "ref",
96
+ matches: (value = "", regexGenerator = "faker") => {
97
+ if (regexGenerator === "randexp") {
98
+ return `${transformers.toRegExpString(value, "RandExp")}.gen()`;
99
+ }
100
+ return `faker.helpers.fromRegExp(${transformers.toRegExpString(value)})`;
101
+ },
102
+ email: () => "faker.internet.email()",
103
+ firstName: () => "faker.person.firstName()",
104
+ lastName: () => "faker.person.lastName()",
105
+ password: () => "faker.internet.password()",
106
+ phone: () => "faker.phone.number()",
107
+ blob: () => "faker.image.url() as unknown as Blob",
108
+ default: void 0,
109
+ describe: void 0,
110
+ const: (value) => value ?? "",
111
+ max: void 0,
112
+ min: void 0,
113
+ nullable: void 0,
114
+ nullish: void 0,
115
+ optional: void 0,
116
+ readOnly: void 0,
117
+ strict: void 0,
118
+ deprecated: void 0,
119
+ example: void 0,
120
+ schema: void 0,
121
+ catchall: void 0,
122
+ name: void 0
123
+ };
124
+ function schemaKeywordsorter(a, b) {
125
+ if (b.keyword === "null") {
126
+ return -1;
127
+ }
128
+ return 0;
129
+ }
130
+ function joinItems(items) {
131
+ switch (items.length) {
132
+ case 0:
133
+ return "undefined";
134
+ case 1:
135
+ return items[0];
136
+ default:
137
+ return fakerKeywordMapper.union(items);
138
+ }
139
+ }
140
+ function parse(parent, current, options) {
141
+ const value = fakerKeywordMapper[current.keyword];
142
+ if (!value) {
143
+ return void 0;
144
+ }
145
+ if (isKeyword(current, schemaKeywords.union)) {
146
+ return fakerKeywordMapper.union(current.args.map((schema) => parse(current, schema, { ...options, canOverride: false })).filter(Boolean));
147
+ }
148
+ if (isKeyword(current, schemaKeywords.and)) {
149
+ return fakerKeywordMapper.and(current.args.map((schema) => parse(current, schema, { ...options, canOverride: false })).filter(Boolean));
150
+ }
151
+ if (isKeyword(current, schemaKeywords.array)) {
152
+ return fakerKeywordMapper.array(current.args.items.map((schema) => parse(current, schema, { ...options, canOverride: false })).filter(Boolean));
153
+ }
154
+ if (isKeyword(current, schemaKeywords.enum)) {
155
+ return fakerKeywordMapper.enum(
156
+ current.args.items.map((schema) => {
157
+ if (schema.format === "number") {
158
+ return schema.name;
159
+ }
160
+ return transformers.stringify(schema.name);
161
+ })
162
+ );
163
+ }
164
+ if (isKeyword(current, schemaKeywords.ref)) {
165
+ if (!current.args?.name) {
166
+ throw new Error(`Name not defined for keyword ${current.keyword}`);
167
+ }
168
+ if (options.canOverride) {
169
+ return `${current.args.name}(data)`;
170
+ }
171
+ return `${current.args.name}()`;
172
+ }
173
+ if (isKeyword(current, schemaKeywords.object)) {
174
+ const argsObject = Object.entries(current.args?.properties || {}).filter((item) => {
175
+ const schema = item[1];
176
+ return schema && typeof schema.map === "function";
177
+ }).map(([name, schemas]) => {
178
+ const nameSchema = schemas.find((schema) => schema.keyword === schemaKeywords.name);
179
+ const mappedName = nameSchema?.args || name;
180
+ if (options.mapper?.[mappedName]) {
181
+ return `"${name}": ${options.mapper?.[mappedName]}`;
182
+ }
183
+ return `"${name}": ${joinItems(
184
+ schemas.sort(schemaKeywordsorter).map((schema) => parse(current, schema, { ...options, canOverride: false })).filter(Boolean)
185
+ )}`;
186
+ }).join(",");
187
+ return `{${argsObject}}`;
188
+ }
189
+ if (isKeyword(current, schemaKeywords.tuple)) {
190
+ if (Array.isArray(current.args.items)) {
191
+ return fakerKeywordMapper.tuple(current.args.items.map((schema) => parse(current, schema, { ...options, canOverride: false })).filter(Boolean));
192
+ }
193
+ return parse(current, current.args.items, { ...options, canOverride: false });
194
+ }
195
+ if (isKeyword(current, schemaKeywords.const)) {
196
+ if (current.args.format === "number" && current.args.name !== void 0) {
197
+ return fakerKeywordMapper.const(current.args.name?.toString());
198
+ }
199
+ return fakerKeywordMapper.const(transformers.stringify(current.args.value));
200
+ }
201
+ if (isKeyword(current, schemaKeywords.matches) && current.args) {
202
+ return fakerKeywordMapper.matches(current.args, options.regexGenerator);
203
+ }
204
+ if (isKeyword(current, schemaKeywords.null) || isKeyword(current, schemaKeywords.undefined) || isKeyword(current, schemaKeywords.any)) {
205
+ return value() || "";
206
+ }
207
+ if (isKeyword(current, schemaKeywords.string)) {
208
+ if (parent) {
209
+ const minSchema = SchemaGenerator.find([parent], schemaKeywords.min);
210
+ const maxSchema = SchemaGenerator.find([parent], schemaKeywords.max);
211
+ return fakerKeywordMapper.string(minSchema?.args, maxSchema?.args);
212
+ }
213
+ return fakerKeywordMapper.string();
214
+ }
215
+ if (isKeyword(current, schemaKeywords.number)) {
216
+ if (parent) {
217
+ const minSchema = SchemaGenerator.find([parent], schemaKeywords.min);
218
+ const maxSchema = SchemaGenerator.find([parent], schemaKeywords.max);
219
+ return fakerKeywordMapper.number(minSchema?.args, maxSchema?.args);
220
+ }
221
+ return fakerKeywordMapper.number();
222
+ }
223
+ if (isKeyword(current, schemaKeywords.integer)) {
224
+ if (parent) {
225
+ const minSchema = SchemaGenerator.find([parent], schemaKeywords.min);
226
+ const maxSchema = SchemaGenerator.find([parent], schemaKeywords.max);
227
+ return fakerKeywordMapper.integer(minSchema?.args, maxSchema?.args);
228
+ }
229
+ return fakerKeywordMapper.integer();
230
+ }
231
+ if (isKeyword(current, schemaKeywords.datetime)) {
232
+ return fakerKeywordMapper.datetime();
233
+ }
234
+ if (isKeyword(current, schemaKeywords.date)) {
235
+ return fakerKeywordMapper.date(current.args.type, options.dateParser);
236
+ }
237
+ if (isKeyword(current, schemaKeywords.time)) {
238
+ return fakerKeywordMapper.time(current.args.type, options.dateParser);
239
+ }
240
+ if (current.keyword in fakerKeywordMapper && "args" in current) {
241
+ const value2 = fakerKeywordMapper[current.keyword];
242
+ const options2 = JSON.stringify(current.args);
243
+ return value2(options2);
244
+ }
245
+ if (current.keyword in fakerKeywordMapper) {
246
+ return value();
247
+ }
248
+ return void 0;
249
+ }
250
+ function Faker({ tree, description, name, typeName, seed, regexGenerator, canOverride, mapper, dateParser }) {
251
+ const fakerText = joinItems(
252
+ tree.map(
253
+ (schema) => parse(void 0, schema, {
254
+ name,
255
+ typeName,
256
+ seed,
257
+ regexGenerator,
258
+ mapper,
259
+ canOverride,
260
+ dateParser
261
+ })
262
+ ).filter(Boolean)
263
+ );
264
+ let fakerDefaultOverride = void 0;
265
+ let fakerTextWithOverride = fakerText;
266
+ if (canOverride && fakerText.startsWith("{")) {
267
+ fakerDefaultOverride = "{}";
268
+ fakerTextWithOverride = `{
269
+ ...${fakerText},
270
+ ...data
271
+ }`;
272
+ }
273
+ if (canOverride && fakerText.startsWith("faker.helpers.arrayElements")) {
274
+ fakerDefaultOverride = "[]";
275
+ fakerTextWithOverride = `[
276
+ ...${fakerText},
277
+ ...data
278
+ ]`;
279
+ }
280
+ const params = FunctionParams.factory({
281
+ data: fakerDefaultOverride ? {
282
+ type: `NonNullable<Partial<${typeName}>>`,
283
+ default: fakerDefaultOverride
284
+ } : void 0
285
+ });
286
+ return /* @__PURE__ */ jsx(File.Source, { name, isExportable: true, isIndexable: true, children: /* @__PURE__ */ jsxs(
287
+ Function,
288
+ {
289
+ export: true,
290
+ name,
291
+ JSDoc: { comments: [description ? `@description ${transformers.jsStringEscape(description)}` : void 0].filter(Boolean) },
292
+ params: params.toConstructor(),
293
+ children: [
294
+ seed ? `faker.seed(${JSON.stringify(seed)})` : void 0,
295
+ /* @__PURE__ */ jsx("br", {}),
296
+ `return ${fakerTextWithOverride}`
297
+ ]
298
+ }
299
+ ) });
300
+ }
301
+
302
+ export { Faker };
303
+ //# sourceMappingURL=chunk-JVUPDWN2.js.map
304
+ //# sourceMappingURL=chunk-JVUPDWN2.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-JVUPDWN2.js","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 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,115 @@
1
+ 'use strict';
2
+
3
+ var chunk4I5F76DK_cjs = require('./chunk-4I5F76DK.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
+ chunk4I5F76DK_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
+ chunk4I5F76DK_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-WYCU2YG6.cjs.map
115
+ //# sourceMappingURL=chunk-WYCU2YG6.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-WYCU2YG6.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"]}