You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
I would like to add another option to the Zod plugin
exporttypeOptions={
...
coerceTypes: {// Default value would be true for all, to be backwards compatibledate: booleanstrings: booleannumber: boolean},
...
}
And then use that in conjuction with the coercion option, to enabled coercion.
I'd be down to write the PR as well, if you accept this enhancement.
The text was updated successfully, but these errors were encountered:
This was already something that was requested before so I was planning to add this as part of Kubb v3. More people needs this so happy to see some ideas here.
What if we just use one option to specify the coercion:
When true it will reuse the same logic as of today but you can then also allow an object where an user of Kubb can specify what primitive needs coercion.
This means that behind the scenes we will transform true into an object { date: true, string: true, number: true }
That was actually my original thought, but was unsure if i should propose it as such, as i was unsure if putting new logic into an existing option would be frowned upon. So i'll agree with that.
I'll give it a go, if the implementation becomes too clunky, i'll reach out 😄 and nice project you've gotten here, happy to help
@ChilloManiac Aha great to hear, with v3(which is now being used on the master branch) we will already have a major bump so I'm not seeing issues in doing it this way(can also be added to v2 if needed). coercion is already passed through so probably changing the type with some changes in plugin-zod/src/parser/index.ts will workout.
What is the problem this feature would solve?
I'm using Kubb for a serverless API, and i use to to generate Zod-schemas from my OpenApiSpec.
In this case I'm making use of the
coerce
feature of Zod. However this works better for some data-types than others.In my case i would like to coerce for numbers (
z.coerce.number()
) and not strings, since they behave pretty badly ref.Here's my current config
I would like to add another option to the Zod plugin
And then use that in conjuction with the
coercion
option, to enabled coercion.I'd be down to write the PR as well, if you accept this enhancement.
The text was updated successfully, but these errors were encountered: