declare zod schemas that can be inverted to format from output to input
npm install zod-invertibledeclare zod schemas that can be inverted to format from output to input





zod-invertible doesn't support the following schemas, and invert will throw an error if it encounters them:
- z.preprocess(...)
- ZodType.transform(...) (outside of the transform created by invertible)
However, you may work around this by marking the schema with ignoreEffect:
``ts
import { schema, ignoreEffect } from 'zod-intervible'
const innerSchema = ...
const schema = ignoreEffect(z.preprocess((value) => ..., innerSchema))
const inverse = invert(schema) // equivalent to invert(innerSchema)
`
The inverse of ZodType.default(...) will not have a default, which should be okay, since the input to the inverse should
always be defined.
The inverse of ZodType.catch(...) will not catch. If you want to use a fallback value if errors are thrown during parsing orparse
formatting, add your own logic in the and format functions you pass to invertible.
If the output types of z.union([...]) options overlap, then invert(z.union([...])).parse(output) may format with a
different union option than the one that parsed the input.
If you have recursive schemas (using z.lazy()), the inverse z.lazy() schemas will re-invert the resolved schema each timeWeakMap
they are used. I may fix this in the future with a inverse cache.
`sh`
npm i zod-invertibleOR
pnpm i zod-invertible
`ts
import z from 'zod'
import { invertible, invert, ZodInvertible } from 'zod-intertible'
const StringToNumber = invertible(
z.string(),
(s, ctx) => {
const result = parseFloat(s)
if (isNaN(result)) {
ctx.addIssue({
code: z.ZodIssueCode.custom,
message: 'invalid float',
})
}
return result
},
z.number(),
(n) => String(n)
)
StringToNumber instanceof ZodInvertible // true
StringToNumber.parse('3.5') // 3.5
const NumberToString = invert(StringToNumber)
NumberToString.parse(3.5) // '3.5'
const obj = z.object({ foo: StringToNumber })
obj.parse({ foo: '3.5' }) // { foo: 3.5 }
// invert works deeply:
invert(obj).parse({ foo: 3.5 }) // { foo: '3.5' }
`
Creates an invertible schema that transforms from an input type to a different output type.
Returns a ZodInvertible, which is a subclass of ZodPipeline.
The ZodType for validating the input value
The function for transforming the input value into the output value. It is called with two arguments:
- value: the output of inputSchemactx
- : the zod RefinementCtx
parse may be async.
The ZodType for validating the output
The function for converting from the output value back into the input value. It is called with two arguments:
- value: the input of outputSchemactx
- : the zod RefinementCtx
format may be async.
Deeply inverts a zod schema, inverting any ZodInvertible schemas inside it, and otherwise preserving the structure of
objects, arrays, etc.
If the zod schema parses input type I into output type O, the inverted schema will parse input type O into output type I`.