@kubb/plugin-faker 3.16.2 → 3.16.3

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 (45) hide show
  1. package/dist/components-BpyQzZAY.cjs +324 -0
  2. package/dist/components-BpyQzZAY.cjs.map +1 -0
  3. package/dist/components-BwSq4Ikw.js +290 -0
  4. package/dist/components-BwSq4Ikw.js.map +1 -0
  5. package/dist/components.cjs +2 -11
  6. package/dist/components.d.cts +24 -15
  7. package/dist/components.d.ts +24 -15
  8. package/dist/components.js +3 -3
  9. package/dist/fakerGenerator-CXR9ksYA.js +199 -0
  10. package/dist/fakerGenerator-CXR9ksYA.js.map +1 -0
  11. package/dist/fakerGenerator-S8sgrtl5.cjs +204 -0
  12. package/dist/fakerGenerator-S8sgrtl5.cjs.map +1 -0
  13. package/dist/generators.cjs +3 -12
  14. package/dist/generators.d.cts +5 -6
  15. package/dist/generators.d.ts +5 -6
  16. package/dist/generators.js +4 -4
  17. package/dist/index.cjs +96 -124
  18. package/dist/index.cjs.map +1 -1
  19. package/dist/index.d.cts +6 -7
  20. package/dist/index.d.ts +6 -7
  21. package/dist/index.js +96 -118
  22. package/dist/index.js.map +1 -1
  23. package/dist/types-Bh_6SttY.d.cts +1214 -0
  24. package/dist/types-DYUKPbgH.d.ts +1214 -0
  25. package/package.json +22 -27
  26. package/src/generators/__snapshots__/pet.ts +1 -0
  27. package/src/generators/__snapshots__/petWithDateString.ts +1 -0
  28. package/src/generators/__snapshots__/petWithDayjs.ts +1 -0
  29. package/src/generators/__snapshots__/petWithMapper.ts +1 -0
  30. package/src/generators/__snapshots__/petWithRandExp.ts +1 -0
  31. package/src/parser.ts +12 -3
  32. package/dist/chunk-BQQKSGJ4.js +0 -370
  33. package/dist/chunk-BQQKSGJ4.js.map +0 -1
  34. package/dist/chunk-DP3UK3GA.js +0 -137
  35. package/dist/chunk-DP3UK3GA.js.map +0 -1
  36. package/dist/chunk-DUV3ZLQX.cjs +0 -139
  37. package/dist/chunk-DUV3ZLQX.cjs.map +0 -1
  38. package/dist/chunk-ZA3QHI3O.cjs +0 -376
  39. package/dist/chunk-ZA3QHI3O.cjs.map +0 -1
  40. package/dist/components.cjs.map +0 -1
  41. package/dist/components.js.map +0 -1
  42. package/dist/generators.cjs.map +0 -1
  43. package/dist/generators.js.map +0 -1
  44. package/dist/types-kyHdJ8oH.d.cts +0 -107
  45. package/dist/types-kyHdJ8oH.d.ts +0 -107
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@kubb/plugin-faker",
3
- "version": "3.16.2",
3
+ "version": "3.16.3",
4
4
  "description": "Faker.js data generator plugin for Kubb, creating realistic mock data from OpenAPI specifications for development and testing.",
5
5
  "keywords": [
6
6
  "faker",
@@ -29,25 +29,21 @@
29
29
  "exports": {
30
30
  ".": {
31
31
  "import": "./dist/index.js",
32
- "require": "./dist/index.cjs",
33
- "default": "./dist/index.cjs"
34
- },
35
- "./generators": {
36
- "import": "./dist/generators.js",
37
- "require": "./dist/generators.cjs",
38
- "default": "./dist/generators.cjs"
32
+ "require": "./dist/index.cjs"
39
33
  },
40
34
  "./components": {
41
35
  "import": "./dist/components.js",
42
- "require": "./dist/components.cjs",
43
- "default": "./dist/components.cjs"
36
+ "require": "./dist/components.cjs"
37
+ },
38
+ "./generators": {
39
+ "import": "./dist/generators.js",
40
+ "require": "./dist/generators.cjs"
44
41
  },
45
- "./package.json": "./package.json",
46
- "./*": "./*"
42
+ "./package.json": "./package.json"
47
43
  },
48
- "main": "dist/index.cjs",
49
- "module": "dist/index.js",
50
- "types": "./dist/index.d.ts",
44
+ "main": "./dist/index.cjs",
45
+ "module": "./dist/index.js",
46
+ "types": "./dist/index.d.cts",
51
47
  "typesVersions": {
52
48
  "*": {
53
49
  "components": [
@@ -65,18 +61,17 @@
65
61
  "!/**/__tests__/**"
66
62
  ],
67
63
  "dependencies": {
68
- "@kubb/core": "3.16.2",
69
- "@kubb/plugin-oas": "3.16.2",
70
- "@kubb/plugin-ts": "3.16.2",
71
- "@kubb/react": "3.16.2",
72
- "@kubb/oas": "3.16.2"
64
+ "@kubb/core": "3.16.3",
65
+ "@kubb/oas": "3.16.3",
66
+ "@kubb/plugin-oas": "3.16.3",
67
+ "@kubb/plugin-ts": "3.16.3",
68
+ "@kubb/react": "3.16.3"
73
69
  },
74
70
  "devDependencies": {
75
- "tsup": "^8.5.0",
71
+ "tsdown": "^0.14.1",
76
72
  "typescript": "^5.9.2",
77
- "@kubb/config-tsup": "3.16.2",
78
- "@kubb/config-ts": "3.16.2",
79
- "@kubb/plugin-oas": "3.16.2"
73
+ "@kubb/config-ts": "3.16.3",
74
+ "@kubb/plugin-oas": "3.16.3"
80
75
  },
81
76
  "peerDependencies": {
82
77
  "@kubb/react": "^3.0.0"
@@ -89,13 +84,13 @@
89
84
  "registry": "https://registry.npmjs.org/"
90
85
  },
91
86
  "scripts": {
92
- "build": "tsup",
87
+ "build": "tsdown",
93
88
  "clean": "npx rimraf ./dist",
94
89
  "lint": "bun biome lint .",
95
- "lint:fix": "bun biome lint--fix --unsafe .",
90
+ "lint:fix": "bun biome lint --fix --unsafe .",
96
91
  "release": "pnpm publish --no-git-check",
97
92
  "release:canary": "bash ../../.github/canary.sh && node ../../scripts/build.js canary && pnpm publish --no-git-check",
98
- "start": "tsup --watch",
93
+ "start": "tsdown --watch",
99
94
  "test": "vitest --passWithNoTests",
100
95
  "typecheck": "tsc -p ./tsconfig.json --noEmit --emitDeclarationOnly false"
101
96
  }
@@ -13,6 +13,7 @@ export function pet(data?: Partial<Pet>): Pet {
13
13
  code: faker.helpers.fromRegExp(new RegExp('\\b[1-9]\\b')),
14
14
  shipDate: faker.date.anytime(),
15
15
  shipTime: faker.date.anytime(),
16
+ info: { animal: faker.helpers.arrayElement<NonNullable<NonNullable<Pet>['info']>['animal']>(['dog', 'cat', 'ant']) },
16
17
  },
17
18
  ...(data || {}),
18
19
  }
@@ -13,6 +13,7 @@ export function pet(data?: Partial<Pet>): Pet {
13
13
  code: faker.helpers.fromRegExp(new RegExp('\\b[1-9]\\b')),
14
14
  shipDate: faker.date.anytime().toISOString().substring(0, 10),
15
15
  shipTime: faker.date.anytime().toISOString().substring(11, 19),
16
+ info: { animal: faker.helpers.arrayElement<NonNullable<NonNullable<Pet>['info']>['animal']>(['dog', 'cat', 'ant']) },
16
17
  },
17
18
  ...(data || {}),
18
19
  }
@@ -14,6 +14,7 @@ export function pet(data?: Partial<Pet>): Pet {
14
14
  code: faker.helpers.fromRegExp(new RegExp('\\b[1-9]\\b')),
15
15
  shipDate: dayjs(faker.date.anytime()).format('YYYY-MM-DD'),
16
16
  shipTime: dayjs(faker.date.anytime()).format('HH:mm:ss'),
17
+ info: { animal: faker.helpers.arrayElement<NonNullable<NonNullable<Pet>['info']>['animal']>(['dog', 'cat', 'ant']) },
17
18
  },
18
19
  ...(data || {}),
19
20
  }
@@ -13,6 +13,7 @@ export function pet(data?: Partial<Pet>): Pet {
13
13
  code: faker.helpers.fromRegExp(new RegExp('\\b[1-9]\\b')),
14
14
  shipDate: faker.date.anytime(),
15
15
  shipTime: faker.date.anytime(),
16
+ info: { animal: faker.helpers.arrayElement<NonNullable<NonNullable<Pet>['info']>['animal']>(['dog', 'cat', 'ant']) },
16
17
  },
17
18
  ...(data || {}),
18
19
  }
@@ -14,6 +14,7 @@ export function pet(data?: Partial<Pet>): Pet {
14
14
  code: new RandExp('\\b[1-9]\\b').gen(),
15
15
  shipDate: faker.date.anytime(),
16
16
  shipTime: faker.date.anytime(),
17
+ info: { animal: faker.helpers.arrayElement<NonNullable<NonNullable<Pet>['info']>['animal']>(['dog', 'cat', 'ant']) },
17
18
  },
18
19
  ...(data || {}),
19
20
  }
package/src/parser.ts CHANGED
@@ -219,7 +219,7 @@ export function parse({ current, parent, name, siblings }: SchemaTree, options:
219
219
  { parent: current, current: schema, siblings },
220
220
  {
221
221
  ...options,
222
- typeName: `${options.typeName}["${name}"][number]`,
222
+ typeName: `NonNullable<${options.typeName}>[number]`,
223
223
  canOverride: false,
224
224
  },
225
225
  ),
@@ -259,7 +259,7 @@ export function parse({ current, parent, name, siblings }: SchemaTree, options:
259
259
  return transformers.stringify(schema.value)
260
260
  }),
261
261
  // TODO replace this with getEnumNameFromSchema
262
- name ? `NonNullable<${options.typeName}>['${name}']` : undefined,
262
+ name ? options.typeName : undefined,
263
263
  )
264
264
  }
265
265
 
@@ -293,7 +293,16 @@ export function parse({ current, parent, name, siblings }: SchemaTree, options:
293
293
  return `"${name}": ${joinItems(
294
294
  schemas
295
295
  .sort(schemaKeywordSorter)
296
- .map((schema) => parse({ name, parent: current, current: schema, siblings: schemas }, { ...options, canOverride: false }))
296
+ .map((schema) =>
297
+ parse(
298
+ { name, parent: current, current: schema, siblings: schemas },
299
+ {
300
+ ...options,
301
+ typeName: `NonNullable<${options.typeName}>[${JSON.stringify(name)}]`,
302
+ canOverride: false,
303
+ },
304
+ ),
305
+ )
297
306
  .filter(Boolean),
298
307
  )}`
299
308
  })
@@ -1,370 +0,0 @@
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: () => "undefined",
10
- void: () => "undefined",
11
- number: (min, max) => {
12
- if (max !== void 0 && min !== void 0) {
13
- return `faker.number.float({ min: ${min}, max: ${max} })`;
14
- }
15
- if (max !== void 0) {
16
- return `faker.number.float({ max: ${max} })`;
17
- }
18
- if (min !== void 0) {
19
- return `faker.number.float({ min: ${min} })`;
20
- }
21
- return "faker.number.float()";
22
- },
23
- integer: (min, max) => {
24
- if (max !== void 0 && min !== void 0) {
25
- return `faker.number.int({ min: ${min}, max: ${max} })`;
26
- }
27
- if (max !== void 0) {
28
- return `faker.number.int({ max: ${max} })`;
29
- }
30
- if (min !== void 0) {
31
- return `faker.number.int({ min: ${min} })`;
32
- }
33
- return "faker.number.int()";
34
- },
35
- string: (min, max) => {
36
- if (max !== void 0 && min !== void 0) {
37
- return `faker.string.alpha({ length: { min: ${min}, max: ${max} } })`;
38
- }
39
- if (max !== void 0) {
40
- return `faker.string.alpha({ length: ${max} })`;
41
- }
42
- if (min !== void 0) {
43
- return `faker.string.alpha({ length: ${min} })`;
44
- }
45
- return "faker.string.alpha()";
46
- },
47
- boolean: () => "faker.datatype.boolean()",
48
- undefined: () => "undefined",
49
- null: () => "null",
50
- array: (items = [], min, max) => {
51
- if (items.length > 1) {
52
- return `faker.helpers.arrayElements([${items.join(", ")}])`;
53
- }
54
- const item = items.at(0);
55
- if (min !== void 0 && max !== void 0) {
56
- return `faker.helpers.multiple(() => (${item}), { count: { min: ${min}, max: ${max} }})`;
57
- }
58
- if (min !== void 0) {
59
- return `faker.helpers.multiple(() => (${item}), { count: ${min} })`;
60
- }
61
- if (max !== void 0) {
62
- return `faker.helpers.multiple(() => (${item}), { count: { min: 0, max: ${max} }})`;
63
- }
64
- return `faker.helpers.multiple(() => (${item}))`;
65
- },
66
- tuple: (items = []) => `[${items.join(", ")}]`,
67
- enum: (items = [], type = "any") => `faker.helpers.arrayElement<${type}>([${items.join(", ")}])`,
68
- union: (items = []) => `faker.helpers.arrayElement<any>([${items.join(", ")}])`,
69
- /**
70
- * ISO 8601
71
- */
72
- datetime: () => "faker.date.anytime().toISOString()",
73
- /**
74
- * Type `'date'` Date
75
- * Type `'string'` ISO date format (YYYY-MM-DD)
76
- * @default ISO date format (YYYY-MM-DD)
77
- */
78
- date: (type = "string", parser = "faker") => {
79
- if (type === "string") {
80
- if (parser !== "faker") {
81
- return `${parser}(faker.date.anytime()).format("YYYY-MM-DD")`;
82
- }
83
- return "faker.date.anytime().toISOString().substring(0, 10)";
84
- }
85
- if (parser !== "faker") {
86
- throw new Error(`type '${type}' and parser '${parser}' can not work together`);
87
- }
88
- return "faker.date.anytime()";
89
- },
90
- /**
91
- * Type `'date'` Date
92
- * Type `'string'` ISO time format (HH:mm:ss[.SSSSSS])
93
- * @default ISO time format (HH:mm:ss[.SSSSSS])
94
- */
95
- time: (type = "string", parser = "faker") => {
96
- if (type === "string") {
97
- if (parser !== "faker") {
98
- return `${parser}(faker.date.anytime()).format("HH:mm:ss")`;
99
- }
100
- return "faker.date.anytime().toISOString().substring(11, 19)";
101
- }
102
- if (parser !== "faker") {
103
- throw new Error(`type '${type}' and parser '${parser}' can not work together`);
104
- }
105
- return "faker.date.anytime()";
106
- },
107
- uuid: () => "faker.string.uuid()",
108
- url: () => "faker.internet.url()",
109
- and: (items = []) => `Object.assign({}, ${items.join(", ")})`,
110
- object: () => "object",
111
- ref: () => "ref",
112
- matches: (value = "", regexGenerator = "faker") => {
113
- if (regexGenerator === "randexp") {
114
- return `${transformers.toRegExpString(value, "RandExp")}.gen()`;
115
- }
116
- return `faker.helpers.fromRegExp(${transformers.toRegExpString(value)})`;
117
- },
118
- email: () => "faker.internet.email()",
119
- firstName: () => "faker.person.firstName()",
120
- lastName: () => "faker.person.lastName()",
121
- password: () => "faker.internet.password()",
122
- phone: () => "faker.phone.number()",
123
- blob: () => "faker.image.url() as unknown as Blob",
124
- default: void 0,
125
- describe: void 0,
126
- const: (value) => value ?? "",
127
- max: void 0,
128
- min: void 0,
129
- nullable: void 0,
130
- nullish: void 0,
131
- optional: void 0,
132
- readOnly: void 0,
133
- writeOnly: void 0,
134
- deprecated: void 0,
135
- example: void 0,
136
- schema: void 0,
137
- catchall: void 0,
138
- name: void 0,
139
- interface: void 0
140
- };
141
- function schemaKeywordSorter(_a, b) {
142
- if (b.keyword === "null") {
143
- return -1;
144
- }
145
- return 0;
146
- }
147
- function joinItems(items) {
148
- switch (items.length) {
149
- case 0:
150
- return "undefined";
151
- case 1:
152
- return items[0];
153
- default:
154
- return fakerKeywordMapper.union(items);
155
- }
156
- }
157
- function parse({ current, parent, name, siblings }, options) {
158
- const value = fakerKeywordMapper[current.keyword];
159
- if (!value) {
160
- return void 0;
161
- }
162
- if (isKeyword(current, schemaKeywords.union)) {
163
- if (Array.isArray(current.args) && !current.args.length) {
164
- return "";
165
- }
166
- return fakerKeywordMapper.union(
167
- current.args.map((schema) => parse({ parent: current, current: schema, siblings }, { ...options, canOverride: false })).filter(Boolean)
168
- );
169
- }
170
- if (isKeyword(current, schemaKeywords.and)) {
171
- return fakerKeywordMapper.and(
172
- current.args.map((schema) => parse({ parent: current, current: schema, siblings }, { ...options, canOverride: false })).filter(Boolean)
173
- );
174
- }
175
- if (isKeyword(current, schemaKeywords.array)) {
176
- return fakerKeywordMapper.array(
177
- current.args.items.map(
178
- (schema) => parse(
179
- { parent: current, current: schema, siblings },
180
- {
181
- ...options,
182
- typeName: `${options.typeName}["${name}"][number]`,
183
- canOverride: false
184
- }
185
- )
186
- ).filter(Boolean),
187
- current.args.min,
188
- current.args.max
189
- );
190
- }
191
- if (isKeyword(current, schemaKeywords.enum)) {
192
- const isParentTuple = parent ? isKeyword(parent, schemaKeywords.tuple) : false;
193
- if (isParentTuple) {
194
- return fakerKeywordMapper.enum(
195
- current.args.items.map((schema) => {
196
- if (schema.format === "number") {
197
- return schema.value;
198
- }
199
- if (schema.format === "boolean") {
200
- return schema.value;
201
- }
202
- return transformers.stringify(schema.value);
203
- })
204
- );
205
- }
206
- return fakerKeywordMapper.enum(
207
- current.args.items.map((schema) => {
208
- if (schema.format === "number") {
209
- return schema.value;
210
- }
211
- if (schema.format === "boolean") {
212
- return schema.value;
213
- }
214
- return transformers.stringify(schema.value);
215
- }),
216
- // TODO replace this with getEnumNameFromSchema
217
- name ? `NonNullable<${options.typeName}>['${name}']` : void 0
218
- );
219
- }
220
- if (isKeyword(current, schemaKeywords.ref)) {
221
- if (!current.args?.name) {
222
- throw new Error(`Name not defined for keyword ${current.keyword}`);
223
- }
224
- if (options.canOverride) {
225
- return `${current.args.name}(data)`;
226
- }
227
- return `${current.args.name}()`;
228
- }
229
- if (isKeyword(current, schemaKeywords.object)) {
230
- const argsObject = Object.entries(current.args?.properties || {}).filter((item) => {
231
- const schema = item[1];
232
- return schema && typeof schema.map === "function";
233
- }).map(([name2, schemas]) => {
234
- const nameSchema = schemas.find((schema) => schema.keyword === schemaKeywords.name);
235
- const mappedName = nameSchema?.args || name2;
236
- if (options.mapper?.[mappedName]) {
237
- return `"${name2}": ${options.mapper?.[mappedName]}`;
238
- }
239
- return `"${name2}": ${joinItems(
240
- schemas.sort(schemaKeywordSorter).map((schema) => parse({ name: name2, parent: current, current: schema, siblings: schemas }, { ...options, canOverride: false })).filter(Boolean)
241
- )}`;
242
- }).join(",");
243
- return `{${argsObject}}`;
244
- }
245
- if (isKeyword(current, schemaKeywords.tuple)) {
246
- if (Array.isArray(current.args.items)) {
247
- return fakerKeywordMapper.tuple(
248
- current.args.items.map((schema) => parse({ parent: current, current: schema, siblings }, { ...options, canOverride: false })).filter(Boolean)
249
- );
250
- }
251
- return parse({ parent: current, current: current.args.items, siblings }, { ...options, canOverride: false });
252
- }
253
- if (isKeyword(current, schemaKeywords.const)) {
254
- if (current.args.format === "number" && current.args.name !== void 0) {
255
- return fakerKeywordMapper.const(current.args.name?.toString());
256
- }
257
- return fakerKeywordMapper.const(transformers.stringify(current.args.value));
258
- }
259
- if (isKeyword(current, schemaKeywords.matches) && current.args) {
260
- return fakerKeywordMapper.matches(current.args, options.regexGenerator);
261
- }
262
- if (isKeyword(current, schemaKeywords.null) || isKeyword(current, schemaKeywords.undefined) || isKeyword(current, schemaKeywords.any)) {
263
- return value() || "";
264
- }
265
- if (isKeyword(current, schemaKeywords.string)) {
266
- if (siblings) {
267
- const minSchema = SchemaGenerator.find(siblings, schemaKeywords.min);
268
- const maxSchema = SchemaGenerator.find(siblings, schemaKeywords.max);
269
- return fakerKeywordMapper.string(minSchema?.args, maxSchema?.args);
270
- }
271
- return fakerKeywordMapper.string();
272
- }
273
- if (isKeyword(current, schemaKeywords.number)) {
274
- if (siblings) {
275
- const minSchema = SchemaGenerator.find(siblings, schemaKeywords.min);
276
- const maxSchema = SchemaGenerator.find(siblings, schemaKeywords.max);
277
- return fakerKeywordMapper.number(minSchema?.args, maxSchema?.args);
278
- }
279
- return fakerKeywordMapper.number();
280
- }
281
- if (isKeyword(current, schemaKeywords.integer)) {
282
- if (siblings) {
283
- const minSchema = SchemaGenerator.find(siblings, schemaKeywords.min);
284
- const maxSchema = SchemaGenerator.find(siblings, schemaKeywords.max);
285
- return fakerKeywordMapper.integer(minSchema?.args, maxSchema?.args);
286
- }
287
- return fakerKeywordMapper.integer();
288
- }
289
- if (isKeyword(current, schemaKeywords.datetime)) {
290
- return fakerKeywordMapper.datetime();
291
- }
292
- if (isKeyword(current, schemaKeywords.date)) {
293
- return fakerKeywordMapper.date(current.args.type, options.dateParser);
294
- }
295
- if (isKeyword(current, schemaKeywords.time)) {
296
- return fakerKeywordMapper.time(current.args.type, options.dateParser);
297
- }
298
- if (current.keyword in fakerKeywordMapper && "args" in current) {
299
- const value2 = fakerKeywordMapper[current.keyword];
300
- const options2 = JSON.stringify(current.args);
301
- return value2(options2);
302
- }
303
- if (current.keyword in fakerKeywordMapper) {
304
- return value();
305
- }
306
- return void 0;
307
- }
308
- function Faker({ tree, description, name, typeName, seed, regexGenerator, canOverride, mapper, dateParser }) {
309
- const fakerText = joinItems(
310
- tree.map(
311
- (schema, _index, siblings) => parse(
312
- { parent: void 0, current: schema, siblings },
313
- {
314
- name,
315
- typeName,
316
- seed,
317
- regexGenerator,
318
- mapper,
319
- canOverride,
320
- dateParser
321
- }
322
- )
323
- ).filter(Boolean)
324
- );
325
- const isArray = fakerText.startsWith("faker.helpers.arrayElements") || fakerText.startsWith("faker.helpers.multiple");
326
- const isObject = fakerText.startsWith("{");
327
- const isTuple = fakerText.startsWith("faker.helpers.arrayElement");
328
- let fakerTextWithOverride = fakerText;
329
- if (canOverride && isObject) {
330
- fakerTextWithOverride = `{
331
- ...${fakerText},
332
- ...data || {}
333
- }`;
334
- }
335
- if (canOverride && isTuple) {
336
- fakerTextWithOverride = `data || ${fakerText}`;
337
- }
338
- if (canOverride && isArray) {
339
- fakerTextWithOverride = `[
340
- ...${fakerText},
341
- ...data || []
342
- ]`;
343
- }
344
- const params = FunctionParams.factory({
345
- data: {
346
- // making a partial out of an array does not make sense
347
- type: isArray ? typeName : `Partial<${typeName}>`,
348
- optional: true
349
- }
350
- });
351
- return /* @__PURE__ */ jsx(File.Source, { name, isExportable: true, isIndexable: true, children: /* @__PURE__ */ jsxs(
352
- Function,
353
- {
354
- export: true,
355
- name,
356
- JSDoc: { comments: [description ? `@description ${transformers.jsStringEscape(description)}` : void 0].filter(Boolean) },
357
- params: canOverride ? params.toConstructor() : void 0,
358
- returnType: canOverride ? typeName : void 0,
359
- children: [
360
- seed ? `faker.seed(${JSON.stringify(seed)})` : void 0,
361
- /* @__PURE__ */ jsx("br", {}),
362
- `return ${fakerTextWithOverride}`
363
- ]
364
- }
365
- ) });
366
- }
367
-
368
- export { Faker };
369
- //# sourceMappingURL=chunk-BQQKSGJ4.js.map
370
- //# sourceMappingURL=chunk-BQQKSGJ4.js.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../src/parser.ts","../src/components/Faker.tsx"],"names":["name","value","options","transformers"],"mappings":"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","file":"chunk-BQQKSGJ4.js","sourcesContent":["import transformers from '@kubb/core/transformers'\nimport type { Schema, SchemaKeywordBase, SchemaKeywordMapper, SchemaMapper } from '@kubb/plugin-oas'\nimport { isKeyword, SchemaGenerator, type SchemaTree, schemaKeywords } from '@kubb/plugin-oas'\nimport type { Options } from './types.ts'\n\nconst fakerKeywordMapper = {\n any: () => 'undefined',\n unknown: () => 'undefined',\n void: () => 'undefined',\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 (max !== undefined) {\n return `faker.number.float({ max: ${max} })`\n }\n\n if (min !== undefined) {\n return `faker.number.float({ min: ${min} })`\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 (max !== undefined) {\n return `faker.number.int({ max: ${max} })`\n }\n\n if (min !== undefined) {\n return `faker.number.int({ min: ${min} })`\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 (max !== undefined) {\n return `faker.string.alpha({ length: ${max} })`\n }\n\n if (min !== undefined) {\n return `faker.string.alpha({ length: ${min} })`\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(', ')}])`\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} }})`\n }\n if (min !== undefined) {\n return `faker.helpers.multiple(() => (${item}), { count: ${min} })`\n }\n if (max !== undefined) {\n return `faker.helpers.multiple(() => (${item}), { count: { min: 0, max: ${max} }})`\n }\n\n return `faker.helpers.multiple(() => (${item}))`\n },\n tuple: (items: string[] = []) => `[${items.join(', ')}]`,\n enum: (items: Array<string | number | boolean | undefined> = [], type = 'any') => `faker.helpers.arrayElement<${type}>([${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().toISOString().substring(0, 10)'\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().toISOString().substring(11, 19)'\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 deprecated: undefined,\n example: undefined,\n schema: undefined,\n catchall: undefined,\n name: undefined,\n interface: 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({ current, parent, name, 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 if (Array.isArray(current.args) && !current.args.length) {\n return ''\n }\n\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\n .map((schema) =>\n parse(\n { parent: current, current: schema, siblings },\n {\n ...options,\n typeName: `${options.typeName}[\"${name}\"][number]`,\n canOverride: false,\n },\n ),\n )\n .filter(Boolean),\n current.args.min,\n current.args.max,\n )\n }\n\n if (isKeyword(current, schemaKeywords.enum)) {\n const isParentTuple = parent ? isKeyword(parent, schemaKeywords.tuple) : false\n\n if (isParentTuple) {\n return fakerKeywordMapper.enum(\n current.args.items.map((schema) => {\n if (schema.format === 'number') {\n return schema.value\n }\n\n if (schema.format === 'boolean') {\n return schema.value\n }\n return transformers.stringify(schema.value)\n }),\n )\n }\n\n return fakerKeywordMapper.enum(\n current.args.items.map((schema) => {\n if (schema.format === 'number') {\n return schema.value\n }\n if (schema.format === 'boolean') {\n return schema.value\n }\n return transformers.stringify(schema.value)\n }),\n // TODO replace this with getEnumNameFromSchema\n name ? `NonNullable<${options.typeName}>['${name}']` : undefined,\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({ name, parent: current, current: schema, siblings: schemas }, { ...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 (siblings) {\n const minSchema = SchemaGenerator.find(siblings, schemaKeywords.min)\n const maxSchema = SchemaGenerator.find(siblings, 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 (siblings) {\n const minSchema = SchemaGenerator.find(siblings, schemaKeywords.min)\n const maxSchema = SchemaGenerator.find(siblings, 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 (siblings) {\n const minSchema = SchemaGenerator.find(siblings, schemaKeywords.min)\n const maxSchema = SchemaGenerator.find(siblings, 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 * as parserFaker from '../parser.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) {\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 const isArray = fakerText.startsWith('faker.helpers.arrayElements') || fakerText.startsWith('faker.helpers.multiple')\n const isObject = fakerText.startsWith('{')\n const isTuple = fakerText.startsWith('faker.helpers.arrayElement')\n\n let fakerTextWithOverride = fakerText\n\n if (canOverride && isObject) {\n fakerTextWithOverride = `{\n ...${fakerText},\n ...data || {}\n}`\n }\n\n if (canOverride && isTuple) {\n fakerTextWithOverride = `data || ${fakerText}`\n }\n\n if (canOverride && isArray) {\n fakerTextWithOverride = `[\n ...${fakerText},\n ...data || []\n ]`\n }\n\n const params = FunctionParams.factory({\n data: {\n // making a partial out of an array does not make sense\n type: isArray ? typeName : `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 returnType={canOverride ? typeName : undefined}\n >\n {seed ? `faker.seed(${JSON.stringify(seed)})` : undefined}\n <br />\n {`return ${fakerTextWithOverride}`}\n </Function>\n </File.Source>\n )\n}\n"]}