@kubb/plugin-zod 4.0.0 → 4.1.0

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/dist/{components-DtKP6doO.js → components-B1-pLa6g.js} +73 -35
  2. package/dist/components-B1-pLa6g.js.map +1 -0
  3. package/dist/{components-Bv7MaVo7.cjs → components-C6PNc1ua.cjs} +73 -35
  4. package/dist/components-C6PNc1ua.cjs.map +1 -0
  5. package/dist/components.cjs +1 -1
  6. package/dist/components.js +1 -1
  7. package/dist/{generators-CrSYV5kr.cjs → generators-8iZ6rvz2.cjs} +4 -4
  8. package/dist/generators-8iZ6rvz2.cjs.map +1 -0
  9. package/dist/{generators-BY96mD4w.js → generators-B66sl9uI.js} +4 -4
  10. package/dist/generators-B66sl9uI.js.map +1 -0
  11. package/dist/generators.cjs +2 -2
  12. package/dist/generators.js +2 -2
  13. package/dist/index.cjs +2 -2
  14. package/dist/index.js +2 -2
  15. package/package.json +8 -13
  16. package/src/components/Zod.tsx +8 -6
  17. package/src/generators/__snapshots__/coercion.ts +5 -8
  18. package/src/generators/__snapshots__/coercionDates.ts +5 -8
  19. package/src/generators/__snapshots__/coercionNumbers.ts +5 -8
  20. package/src/generators/__snapshots__/coercionStrings.ts +5 -8
  21. package/src/generators/__snapshots__/deletePet.ts +1 -1
  22. package/src/generators/__snapshots__/deletePet_wrapOutput.ts +1 -1
  23. package/src/generators/__snapshots__/example.ts +1 -1
  24. package/src/generators/__snapshots__/getPets.ts +2 -2
  25. package/src/generators/__snapshots__/getPets_wrapOutput.ts +2 -2
  26. package/src/generators/__snapshots__/nullable.ts +1 -1
  27. package/src/generators/__snapshots__/oneof.ts +2 -2
  28. package/src/generators/__snapshots__/optionalPetInfer.ts +3 -3
  29. package/src/generators/__snapshots__/optionalPetTyped.ts +3 -3
  30. package/src/generators/__snapshots__/order.ts +6 -6
  31. package/src/generators/__snapshots__/orderDateTypeFalse.ts +6 -6
  32. package/src/generators/__snapshots__/orderDateTypeString.ts +6 -6
  33. package/src/generators/__snapshots__/pet.ts +5 -8
  34. package/src/generators/__snapshots__/petCoercion.ts +5 -8
  35. package/src/generators/__snapshots__/petTupleObject.ts +1 -1
  36. package/src/generators/__snapshots__/petV4.ts +5 -8
  37. package/src/generators/__snapshots__/petWithMapper.ts +5 -8
  38. package/src/generators/__snapshots__/pets.ts +1 -1
  39. package/src/generators/__snapshots__/queryAllDefaulted.ts +2 -2
  40. package/src/generators/__snapshots__/queryAllDefaulted_wrapOutput.ts +2 -2
  41. package/src/generators/__snapshots__/toy.ts +2 -2
  42. package/src/generators/zodGenerator.tsx +1 -1
  43. package/src/parser.ts +78 -21
  44. package/dist/components-Bv7MaVo7.cjs.map +0 -1
  45. package/dist/components-DtKP6doO.js.map +0 -1
  46. package/dist/generators-BY96mD4w.js.map +0 -1
  47. package/dist/generators-CrSYV5kr.cjs.map +0 -1
  48. package/dist/utils/v4.cjs +0 -0
  49. package/dist/utils/v4.d.cts +0 -38
  50. package/dist/utils/v4.d.ts +0 -38
  51. package/dist/utils/v4.js +0 -1
  52. package/src/utils/v4/ToZod.ts +0 -61
  53. package/src/utils/v4/index.ts +0 -1
@@ -0,0 +1 @@
1
+ {"version":3,"file":"generators-B66sl9uI.js","names":["options"],"sources":["../src/generators/zodGenerator.tsx","../src/generators/operationsGenerator.tsx"],"sourcesContent":["import { createReactGenerator, type OperationSchema as OperationSchemaType, SchemaGenerator, schemaKeywords } from '@kubb/plugin-oas'\nimport { Oas } from '@kubb/plugin-oas/components'\nimport { useOas, useOperationManager, useSchemaManager } from '@kubb/plugin-oas/hooks'\nimport { getBanner, getFooter } from '@kubb/plugin-oas/utils'\nimport { pluginTsName } from '@kubb/plugin-ts'\nimport { File, useApp } from '@kubb/react'\nimport { Zod } from '../components'\nimport type { PluginZod } from '../types'\n\nexport const zodGenerator = createReactGenerator<PluginZod>({\n name: 'zod',\n Operation({ operation, options }) {\n const { coercion: globalCoercion, inferred, typed, mapper, wrapOutput } = options\n\n const { plugin, pluginManager, mode } = useApp<PluginZod>()\n const oas = useOas()\n const { getSchemas, getFile, getGroup } = 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: schemaObject, description, keysToOmit, ...options }: OperationSchemaType, i: number) => {\n // hack so Params can be optional when needed\n const required = Array.isArray(schemaObject?.required) ? !!schemaObject.required.length : !!schemaObject?.required\n const someDefaults = Object.values(schemaObject.properties || {}).some((property) => Object.hasOwn(property, 'default') && property.default !== undefined)\n const optional = !required && !someDefaults && name.includes('Params')\n\n const tree = [...schemaGenerator.parse({ schemaObject, name }), optional ? { keyword: schemaKeywords.optional } : undefined].filter(Boolean)\n const imports = schemaManager.getImports(tree)\n const group = options.operation ? getGroup(options.operation) : undefined\n\n const coercion = name.includes('Params') ? { numbers: true, strings: false, dates: true } : globalCoercion\n\n const zod = {\n name: schemaManager.getName(name, { type: 'function' }),\n inferTypeName: schemaManager.getName(name, { type: 'type' }),\n file: schemaManager.getFile(name),\n }\n\n const type = {\n name: schemaManager.getName(name, {\n type: 'type',\n pluginKey: [pluginTsName],\n }),\n file: schemaManager.getFile(options.operationName || name, {\n pluginKey: [pluginTsName],\n group,\n }),\n }\n\n return (\n <Oas.Schema key={i} name={name} schemaObject={schemaObject} tree={tree}>\n {typed && <File.Import isTypeOnly root={file.path} path={type.file.path} name={[type.name]} />}\n {typed && plugin.options.version === '3' && <File.Import isTypeOnly path={'@kubb/plugin-zod/utils'} name={['ToZod']} />}\n {imports.map((imp) => (\n <File.Import key={[imp.path, imp.name, imp.isTypeOnly].join('-')} root={file.path} path={imp.path} name={imp.name} />\n ))}\n <Zod\n name={zod.name}\n typeName={typed ? type.name : undefined}\n inferTypeName={inferred ? zod.inferTypeName : undefined}\n description={description}\n tree={tree}\n rawSchema={schemaObject}\n mapper={mapper}\n coercion={coercion}\n keysToOmit={keysToOmit}\n wrapOutput={wrapOutput}\n version={plugin.options.version}\n emptySchemaType={plugin.options.emptySchemaType}\n />\n </Oas.Schema>\n )\n }\n\n return (\n <File\n baseName={file.baseName}\n path={file.path}\n meta={file.meta}\n banner={getBanner({ oas, output: plugin.options.output, config: pluginManager.config })}\n footer={getFooter({ oas, output: plugin.options.output })}\n >\n <File.Import name={['z']} path={plugin.options.importPath} />\n {operationSchemas.map(mapOperationSchema)}\n </File>\n )\n },\n Schema({ schema, options }) {\n const { coercion, inferred, typed, mapper, importPath, wrapOutput, version } = options\n\n const { getName, getFile, getImports } = useSchemaManager()\n const {\n pluginManager,\n plugin: {\n options: { output, emptySchemaType },\n },\n } = useApp<PluginZod>()\n const oas = useOas()\n\n const imports = getImports(schema.tree)\n\n const zod = {\n name: getName(schema.name, { type: 'function' }),\n inferTypeName: getName(schema.name, { type: 'type' }),\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 return (\n <File\n baseName={zod.file.baseName}\n path={zod.file.path}\n meta={zod.file.meta}\n banner={getBanner({ oas, output, config: pluginManager.config })}\n footer={getFooter({ oas, output })}\n >\n <File.Import name={['z']} path={importPath} />\n {typed && <File.Import isTypeOnly root={zod.file.path} path={type.file.path} name={[type.name]} />}\n {typed && <File.Import isTypeOnly path={options.version === '4' ? '@kubb/plugin-zod/utils/v4' : '@kubb/plugin-zod/utils'} name={['ToZod']} />}\n {imports.map((imp) => (\n <File.Import key={[imp.path, imp.name, imp.isTypeOnly].join('-')} root={zod.file.path} path={imp.path} name={imp.name} />\n ))}\n\n <Zod\n name={zod.name}\n typeName={typed ? type.name : undefined}\n inferTypeName={inferred ? zod.inferTypeName : undefined}\n description={schema.value.description}\n tree={schema.tree}\n rawSchema={schema.value}\n mapper={mapper}\n coercion={coercion}\n wrapOutput={wrapOutput}\n version={version}\n emptySchemaType={emptySchemaType}\n />\n </File>\n )\n },\n})\n","import { createReactGenerator } from '@kubb/plugin-oas'\nimport { useOas, useOperationManager } from '@kubb/plugin-oas/hooks'\nimport { getBanner, getFooter } from '@kubb/plugin-oas/utils'\nimport { File, useApp } from '@kubb/react'\nimport { Operations } from '../components/Operations'\nimport type { PluginZod } from '../types'\n\nexport const operationsGenerator = createReactGenerator<PluginZod>({\n name: 'operations',\n Operations({ operations }) {\n const {\n pluginManager,\n plugin: {\n key: pluginKey,\n options: { output },\n },\n } = useApp<PluginZod>()\n const oas = useOas()\n const { getFile, groupSchemasByName } = useOperationManager()\n\n const name = 'operations'\n const file = pluginManager.getFile({ name, extname: '.ts', pluginKey })\n\n const transformedOperations = operations.map((operation) => ({ operation, data: groupSchemasByName(operation, { type: 'function' }) }))\n\n const imports = Object.entries(transformedOperations)\n .map(([key, { data, operation }]) => {\n const names = [data.request, ...Object.values(data.responses), ...Object.values(data.parameters)].filter(Boolean)\n\n return <File.Import key={key} name={names} root={file.path} path={getFile(operation).path} />\n })\n .filter(Boolean)\n\n return (\n <File\n baseName={file.baseName}\n path={file.path}\n meta={file.meta}\n banner={getBanner({ oas, output, config: pluginManager.config })}\n footer={getFooter({ oas, output })}\n >\n {imports}\n <Operations name={name} operations={transformedOperations} />\n </File>\n )\n },\n})\n"],"mappings":"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"}
@@ -1,5 +1,5 @@
1
- require('./components-Bv7MaVo7.cjs');
2
- const require_generators = require('./generators-CrSYV5kr.cjs');
1
+ require('./components-C6PNc1ua.cjs');
2
+ const require_generators = require('./generators-8iZ6rvz2.cjs');
3
3
 
4
4
  exports.operationsGenerator = require_generators.operationsGenerator;
5
5
  exports.zodGenerator = require_generators.zodGenerator;
@@ -1,4 +1,4 @@
1
- import "./components-DtKP6doO.js";
2
- import { operationsGenerator, zodGenerator } from "./generators-BY96mD4w.js";
1
+ import "./components-B1-pLa6g.js";
2
+ import { operationsGenerator, zodGenerator } from "./generators-B66sl9uI.js";
3
3
 
4
4
  export { operationsGenerator, zodGenerator };
package/dist/index.cjs CHANGED
@@ -1,5 +1,5 @@
1
- const require_components = require('./components-Bv7MaVo7.cjs');
2
- const require_generators = require('./generators-CrSYV5kr.cjs');
1
+ const require_components = require('./components-C6PNc1ua.cjs');
2
+ const require_generators = require('./generators-8iZ6rvz2.cjs');
3
3
  let node_path = require("node:path");
4
4
  node_path = require_components.__toESM(node_path);
5
5
  let __kubb_core = require("@kubb/core");
package/dist/index.js CHANGED
@@ -1,5 +1,5 @@
1
- import "./components-DtKP6doO.js";
2
- import { operationsGenerator, zodGenerator } from "./generators-BY96mD4w.js";
1
+ import "./components-B1-pLa6g.js";
2
+ import { operationsGenerator, zodGenerator } from "./generators-B66sl9uI.js";
3
3
  import path from "node:path";
4
4
  import { FileManager, PackageManager, PluginManager, createPlugin } from "@kubb/core";
5
5
  import { camelCase, pascalCase } from "@kubb/core/transformers";
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@kubb/plugin-zod",
3
- "version": "4.0.0",
3
+ "version": "4.1.0",
4
4
  "description": "Zod schema generator plugin for Kubb, creating type-safe validation schemas from OpenAPI specifications for runtime data validation.",
5
5
  "keywords": [
6
6
  "zod",
@@ -41,10 +41,6 @@
41
41
  "import": "./dist/utils.js",
42
42
  "require": "./dist/utils.cjs"
43
43
  },
44
- "./utils/v4": {
45
- "import": "./dist/utils/v4.js",
46
- "require": "./dist/utils/v4.cjs"
47
- },
48
44
  "./package.json": "./package.json"
49
45
  },
50
46
  "main": "./dist/index.cjs",
@@ -73,20 +69,19 @@
73
69
  "!/**/__tests__/**"
74
70
  ],
75
71
  "dependencies": {
76
- "@kubb/core": "4.0.0",
77
- "@kubb/oas": "4.0.0",
78
- "@kubb/parser-ts": "4.0.0",
79
- "@kubb/plugin-oas": "4.0.0",
80
- "@kubb/plugin-ts": "4.0.0",
81
- "@kubb/react": "4.0.0"
72
+ "@kubb/core": "4.1.0",
73
+ "@kubb/parser-ts": "4.1.0",
74
+ "@kubb/plugin-oas": "4.1.0",
75
+ "@kubb/plugin-ts": "4.1.0",
76
+ "@kubb/react": "4.1.0",
77
+ "@kubb/oas": "4.1.0"
82
78
  },
83
79
  "devDependencies": {
84
80
  "@asteasolutions/zod-to-openapi": "^7.3.4",
85
81
  "@hono/zod-openapi": "0.19.2",
86
82
  "tsdown": "^0.14.2",
87
83
  "zod": "^3.25.76",
88
- "@kubb/config-ts": "4.0.0",
89
- "@kubb/plugin-oas": "4.0.0"
84
+ "@kubb/plugin-oas": "4.1.0"
90
85
  },
91
86
  "peerDependencies": {
92
87
  "@kubb/react": "^4.0.0"
@@ -45,12 +45,14 @@ export function Zod({
45
45
  })
46
46
 
47
47
  const output = schemas
48
- .map((schema, _index, siblings) =>
49
- parserZod.parse(
48
+ .map((schema, index) => {
49
+ const siblings = schemas.filter((_, i) => i !== index)
50
+
51
+ return parserZod.parse(
50
52
  { parent: undefined, current: schema, siblings },
51
53
  { name, keysToOmit, typeName, description, mapper, coercion, wrapOutput, rawSchema, version },
52
- ),
53
- )
54
+ )
55
+ })
54
56
  .filter(Boolean)
55
57
  .join('')
56
58
 
@@ -86,11 +88,11 @@ export function Zod({
86
88
  )
87
89
 
88
90
  const baseSchemaOutput =
89
- [output, keysToOmit?.length ? `${suffix}.omit({ ${keysToOmit.map((key) => `${key}: true`).join(',')} })` : undefined].filter(Boolean).join('') ||
91
+ [output, keysToOmit?.length ? `${suffix}.omit({ ${keysToOmit.map((key) => `'${key}': true`).join(',')} })` : undefined].filter(Boolean).join('') ||
90
92
  emptyValue ||
91
93
  ''
92
94
  const wrappedSchemaOutput = wrapOutput ? wrapOutput({ output: baseSchemaOutput, schema: rawSchema }) || baseSchemaOutput : baseSchemaOutput
93
- const finalOutput = typeName ? `${wrappedSchemaOutput} as unknown as ToZod<${typeName}>` : wrappedSchemaOutput
95
+ const finalOutput = typeName ? `${wrappedSchemaOutput} as unknown as ${version === '4' ? 'z.ZodType' : 'ToZod'}<${typeName}>` : wrappedSchemaOutput
94
96
 
95
97
  return (
96
98
  <>
@@ -7,12 +7,9 @@ import { z } from 'zod'
7
7
  export const pet = z.object({
8
8
  id: z.coerce.number().int(),
9
9
  name: z.coerce.string(),
10
- date: z.coerce.date().optional(),
11
- uuid: z.coerce.string().uuid().optional(),
12
- email: z.coerce.string().email().optional(),
13
- pattern: z.coerce
14
- .string()
15
- .regex(/^[a-zA-Z0-9]{3}$/)
16
- .optional(),
17
- tag: z.coerce.string().min(5).max(100).optional(),
10
+ date: z.optional(z.coerce.date()),
11
+ uuid: z.optional(z.coerce.string().uuid()),
12
+ email: z.optional(z.coerce.string().email()),
13
+ pattern: z.optional(z.coerce.string().regex(/^[a-zA-Z0-9]{3}$/)),
14
+ tag: z.optional(z.coerce.string().min(5).max(100)),
18
15
  })
@@ -7,12 +7,9 @@ import { z } from 'zod'
7
7
  export const pet = z.object({
8
8
  id: z.number().int(),
9
9
  name: z.string(),
10
- date: z.coerce.date().optional(),
11
- uuid: z.string().uuid().optional(),
12
- email: z.string().email().optional(),
13
- pattern: z
14
- .string()
15
- .regex(/^[a-zA-Z0-9]{3}$/)
16
- .optional(),
17
- tag: z.string().min(5).max(100).optional(),
10
+ date: z.optional(z.coerce.date()),
11
+ uuid: z.optional(z.string().uuid()),
12
+ email: z.optional(z.string().email()),
13
+ pattern: z.optional(z.string().regex(/^[a-zA-Z0-9]{3}$/)),
14
+ tag: z.optional(z.string().min(5).max(100)),
18
15
  })
@@ -7,12 +7,9 @@ import { z } from 'zod'
7
7
  export const pet = z.object({
8
8
  id: z.coerce.number().int(),
9
9
  name: z.string(),
10
- date: z.date().optional(),
11
- uuid: z.string().uuid().optional(),
12
- email: z.string().email().optional(),
13
- pattern: z
14
- .string()
15
- .regex(/^[a-zA-Z0-9]{3}$/)
16
- .optional(),
17
- tag: z.string().min(5).max(100).optional(),
10
+ date: z.optional(z.date()),
11
+ uuid: z.optional(z.string().uuid()),
12
+ email: z.optional(z.string().email()),
13
+ pattern: z.optional(z.string().regex(/^[a-zA-Z0-9]{3}$/)),
14
+ tag: z.optional(z.string().min(5).max(100)),
18
15
  })
@@ -7,12 +7,9 @@ import { z } from 'zod'
7
7
  export const pet = z.object({
8
8
  id: z.number().int(),
9
9
  name: z.coerce.string(),
10
- date: z.date().optional(),
11
- uuid: z.coerce.string().uuid().optional(),
12
- email: z.coerce.string().email().optional(),
13
- pattern: z.coerce
14
- .string()
15
- .regex(/^[a-zA-Z0-9]{3}$/)
16
- .optional(),
17
- tag: z.coerce.string().min(5).max(100).optional(),
10
+ date: z.optional(z.date()),
11
+ uuid: z.optional(z.coerce.string().uuid()),
12
+ email: z.optional(z.coerce.string().email()),
13
+ pattern: z.optional(z.coerce.string().regex(/^[a-zA-Z0-9]{3}$/)),
14
+ tag: z.optional(z.coerce.string().min(5).max(100)),
18
15
  })
@@ -10,7 +10,7 @@ export const deletePetPathParams = z.object({
10
10
 
11
11
  export const deletePetHeaderParams = z
12
12
  .object({
13
- api_key: z.string().optional(),
13
+ api_key: z.optional(z.string()),
14
14
  })
15
15
  .optional()
16
16
 
@@ -10,7 +10,7 @@ export const deletePetPathParams = z.object({
10
10
 
11
11
  export const deletePetHeaderParams = z
12
12
  .object({
13
- api_key: z.string().optional(),
13
+ api_key: z.optional(z.string()),
14
14
  })
15
15
  .optional()
16
16
 
@@ -5,5 +5,5 @@
5
5
  import { z } from 'zod'
6
6
 
7
7
  export const example = z.object({
8
- nestedExamples: z.lazy(() => example).optional(),
8
+ nestedExamples: z.optional(z.lazy(() => example)),
9
9
  })
@@ -5,8 +5,8 @@
5
5
  import { z } from 'zod'
6
6
 
7
7
  export const listPetsQueryParams = z.object({
8
- limit: z.string().describe('How many items to return at one time (max 100)').optional(),
9
- offset: z.coerce.number().int().default(0),
8
+ limit: z.optional(z.string().describe('How many items to return at one time (max 100)')),
9
+ offset: z.optional(z.coerce.number().int().default(0)),
10
10
  })
11
11
 
12
12
  /**
@@ -5,8 +5,8 @@
5
5
  import { z } from '@hono/zod-openapi'
6
6
 
7
7
  export const listPetsQueryParams = z.object({
8
- limit: z.string().describe('How many items to return at one time (max 100)').optional(),
9
- offset: z.coerce.number().int().default(0),
8
+ limit: z.optional(z.string().describe('How many items to return at one time (max 100)')),
9
+ offset: z.optional(z.coerce.number().int().default(0)),
10
10
  })
11
11
 
12
12
  /**
@@ -6,6 +6,6 @@ import { z } from 'zod'
6
6
 
7
7
  export const nullable = z
8
8
  .object({
9
- foo: z.string().nullable().nullish(),
9
+ foo: z.string().nullish(),
10
10
  })
11
11
  .nullable()
@@ -6,9 +6,9 @@ import { z } from 'zod'
6
6
 
7
7
  export const test = z.union([
8
8
  z.object({
9
- propertyA: z.string().optional(),
9
+ propertyA: z.optional(z.string()),
10
10
  }),
11
11
  z.object({
12
- propertyA: z.string().optional(),
12
+ propertyA: z.optional(z.string()),
13
13
  }),
14
14
  ])
@@ -5,9 +5,9 @@
5
5
  import { z } from 'zod'
6
6
 
7
7
  export const optionalPet = z.object({
8
- id: z.number().int().optional(),
9
- name: z.string().optional(),
10
- tag: z.string().optional(),
8
+ id: z.optional(z.number().int()),
9
+ name: z.optional(z.string()),
10
+ tag: z.optional(z.string()),
11
11
  })
12
12
 
13
13
  export type OptionalPet = z.infer<typeof optionalPet>
@@ -6,7 +6,7 @@ import type { ToZod } from '@kubb/plugin-zod/utils'
6
6
  import { z } from 'zod'
7
7
 
8
8
  export const optionalPet = z.object({
9
- id: z.number().int().optional(),
10
- name: z.string().optional(),
11
- tag: z.string().optional(),
9
+ id: z.optional(z.number().int()),
10
+ name: z.optional(z.string()),
11
+ tag: z.optional(z.string()),
12
12
  }) as unknown as ToZod<OptionalPet>
@@ -5,10 +5,10 @@
5
5
  import { z } from 'zod'
6
6
 
7
7
  export const order = z.object({
8
- id: z.number().int().optional(),
9
- petId: z.number().int().optional(),
10
- quantity: z.number().int().optional(),
11
- shipDate: z.date().optional(),
12
- status: z.enum(['placed', 'approved', 'delivered']).describe('Order Status').optional(),
13
- complete: z.boolean().optional(),
8
+ id: z.optional(z.number().int()),
9
+ petId: z.optional(z.number().int()),
10
+ quantity: z.optional(z.number().int()),
11
+ shipDate: z.optional(z.date()),
12
+ status: z.optional(z.enum(['placed', 'approved', 'delivered']).describe('Order Status')),
13
+ complete: z.optional(z.boolean()),
14
14
  })
@@ -5,10 +5,10 @@
5
5
  import { z } from 'zod'
6
6
 
7
7
  export const order = z.object({
8
- id: z.number().int().optional(),
9
- petId: z.number().int().optional(),
10
- quantity: z.number().int().optional(),
11
- shipDate: z.string().optional(),
12
- status: z.enum(['placed', 'approved', 'delivered']).describe('Order Status').optional(),
13
- complete: z.boolean().optional(),
8
+ id: z.optional(z.number().int()),
9
+ petId: z.optional(z.number().int()),
10
+ quantity: z.optional(z.number().int()),
11
+ shipDate: z.optional(z.string()),
12
+ status: z.optional(z.enum(['placed', 'approved', 'delivered']).describe('Order Status')),
13
+ complete: z.optional(z.boolean()),
14
14
  })
@@ -5,10 +5,10 @@
5
5
  import { z } from 'zod'
6
6
 
7
7
  export const order = z.object({
8
- id: z.number().int().optional(),
9
- petId: z.number().int().optional(),
10
- quantity: z.number().int().optional(),
11
- shipDate: z.string().datetime().optional(),
12
- status: z.enum(['placed', 'approved', 'delivered']).describe('Order Status').optional(),
13
- complete: z.boolean().optional(),
8
+ id: z.optional(z.number().int()),
9
+ petId: z.optional(z.number().int()),
10
+ quantity: z.optional(z.number().int()),
11
+ shipDate: z.optional(z.string().datetime()),
12
+ status: z.optional(z.enum(['placed', 'approved', 'delivered']).describe('Order Status')),
13
+ complete: z.optional(z.boolean()),
14
14
  })
@@ -7,12 +7,9 @@ import { z } from 'zod'
7
7
  export const pet = z.object({
8
8
  id: z.number().int(),
9
9
  name: z.string(),
10
- date: z.date().optional(),
11
- uuid: z.string().uuid().optional(),
12
- email: z.string().email().optional(),
13
- pattern: z
14
- .string()
15
- .regex(/^[a-zA-Z0-9]{3}$/)
16
- .optional(),
17
- tag: z.string().min(5).max(100).optional(),
10
+ date: z.optional(z.date()),
11
+ uuid: z.optional(z.string().uuid()),
12
+ email: z.optional(z.string().email()),
13
+ pattern: z.optional(z.string().regex(/^[a-zA-Z0-9]{3}$/)),
14
+ tag: z.optional(z.string().min(5).max(100)),
18
15
  })
@@ -7,12 +7,9 @@ import { z } from 'zod'
7
7
  export const pet = z.object({
8
8
  id: z.coerce.number().int(),
9
9
  name: z.coerce.string(),
10
- date: z.coerce.date().optional(),
11
- uuid: z.coerce.string().uuid().optional(),
12
- email: z.coerce.string().email().optional(),
13
- pattern: z.coerce
14
- .string()
15
- .regex(/^[a-zA-Z0-9]{3}$/)
16
- .optional(),
17
- tag: z.coerce.string().min(5).max(100).optional(),
10
+ date: z.optional(z.coerce.date()),
11
+ uuid: z.optional(z.coerce.string().uuid()),
12
+ email: z.optional(z.coerce.string().email()),
13
+ pattern: z.optional(z.coerce.string().regex(/^[a-zA-Z0-9]{3}$/)),
14
+ tag: z.optional(z.coerce.string().min(5).max(100)),
18
15
  })
@@ -9,6 +9,6 @@ import { z } from 'zod'
9
9
  */
10
10
  export const petTupleObject = z
11
11
  .object({
12
- tupleProperty: z.tuple([z.string(), z.string()]).optional(),
12
+ tupleProperty: z.optional(z.tuple([z.string(), z.string()])),
13
13
  })
14
14
  .describe('Tuple of exact length 2 nested in an object')
@@ -7,12 +7,9 @@ import { z } from 'zod'
7
7
  export const pet = z.object({
8
8
  id: z.int(),
9
9
  name: z.string(),
10
- date: z.date().optional(),
11
- uuid: z.uuid().optional(),
12
- email: z.email().optional(),
13
- pattern: z
14
- .string()
15
- .regex(/^[a-zA-Z0-9]{3}$/)
16
- .optional(),
17
- tag: z.string().min(5).max(100).optional(),
10
+ date: z.optional(z.date()),
11
+ uuid: z.optional(z.uuid()),
12
+ email: z.optional(z.email()),
13
+ pattern: z.optional(z.string().regex(/^[a-zA-Z0-9]{3}$/)),
14
+ tag: z.optional(z.string().min(5).max(100)),
18
15
  })
@@ -7,12 +7,9 @@ import { z } from 'zod'
7
7
  export const pet = z.object({
8
8
  id: z.number().int(),
9
9
  name: z.string().email(),
10
- date: z.date().optional(),
11
- uuid: z.string().uuid().optional(),
12
- email: z.string().email().optional(),
13
- pattern: z
14
- .string()
15
- .regex(/^[a-zA-Z0-9]{3}$/)
16
- .optional(),
17
- tag: z.string().min(5).max(100).optional(),
10
+ date: z.optional(z.date()),
11
+ uuid: z.optional(z.string().uuid()),
12
+ email: z.optional(z.string().email()),
13
+ pattern: z.optional(z.string().regex(/^[a-zA-Z0-9]{3}$/)),
14
+ tag: z.optional(z.string().min(5).max(100)),
18
15
  })
@@ -9,6 +9,6 @@ export const pets = z.array(
9
9
  z.object({
10
10
  id: z.number().int(),
11
11
  name: z.string(),
12
- tag: z.string().optional(),
12
+ tag: z.optional(z.string()),
13
13
  }),
14
14
  ) as unknown as ToZod<Pets>
@@ -5,8 +5,8 @@
5
5
  import { z } from 'zod'
6
6
 
7
7
  export const getThingsQueryParams = z.object({
8
- limit: z.coerce.number().int().min(1).max(100).default(100).describe('Maximum number of things to return'),
9
- skip: z.coerce.number().int().min(0).default(0).describe('Number of things to skip'),
8
+ limit: z.optional(z.coerce.number().int().min(1).max(100).default(100).describe('Maximum number of things to return')),
9
+ skip: z.optional(z.coerce.number().int().min(0).default(0).describe('Number of things to skip')),
10
10
  })
11
11
 
12
12
  /**
@@ -5,8 +5,8 @@
5
5
  import { z } from '@hono/zod-openapi'
6
6
 
7
7
  export const getThingsQueryParams = z.object({
8
- limit: z.coerce.number().int().min(1).max(100).default(100).describe('Maximum number of things to return'),
9
- skip: z.coerce.number().int().min(0).default(0).describe('Number of things to skip'),
8
+ limit: z.optional(z.coerce.number().int().min(1).max(100).default(100).describe('Maximum number of things to return')),
9
+ skip: z.optional(z.coerce.number().int().min(0).default(0).describe('Number of things to skip')),
10
10
  })
11
11
 
12
12
  /**
@@ -7,7 +7,7 @@ import { z } from 'zod'
7
7
  export const toy = z
8
8
  .object({
9
9
  id: z.string().uuid(),
10
- name: z.string().optional(),
11
- description: z.string().nullable().nullish(),
10
+ name: z.optional(z.string()),
11
+ description: z.string().nullish(),
12
12
  })
13
13
  .nullable()
@@ -63,7 +63,7 @@ export const zodGenerator = createReactGenerator<PluginZod>({
63
63
  return (
64
64
  <Oas.Schema key={i} name={name} schemaObject={schemaObject} tree={tree}>
65
65
  {typed && <File.Import isTypeOnly root={file.path} path={type.file.path} name={[type.name]} />}
66
- {typed && <File.Import isTypeOnly path={plugin.options.version === '4' ? '@kubb/plugin-zod/utils/v4' : '@kubb/plugin-zod/utils'} name={['ToZod']} />}
66
+ {typed && plugin.options.version === '3' && <File.Import isTypeOnly path={'@kubb/plugin-zod/utils'} name={['ToZod']} />}
67
67
  {imports.map((imp) => (
68
68
  <File.Import key={[imp.path, imp.name, imp.isTypeOnly].join('-')} root={file.path} path={imp.path} name={imp.name} />
69
69
  ))}