how to pass zod object from server component to client components as props
Answered
Giant panda posted this in #help-forum
data:image/s3,"s3://crabby-images/275c3/275c333dd9c41bfcb60b2ce71c8cd83abb8eb125" alt="Avatar"
Giant pandaOP
how to pass zod object from server component to client components as props
Answered by alfonsus
zod arent serializable; this means not only that it wouldn't work passing server to client, but storing it to a database. I think its better you change to a library that supports serializable schema like [superstruct](https://docs.superstructjs.org/)
10 Replies
data:image/s3,"s3://crabby-images/275c3/275c333dd9c41bfcb60b2ce71c8cd83abb8eb125" alt="Avatar"
@Giant panda how to pass zod object from server component to client components as props
data:image/s3,"s3://crabby-images/93fe2/93fe2e3635c48b56e0d3be1ca90fbb4c21ddde31" alt="Avatar"
why do you want to do that? zod schemas are static so can be imported to the client components directly
data:image/s3,"s3://crabby-images/93fe2/93fe2e3635c48b56e0d3be1ca90fbb4c21ddde31" alt="Avatar"
@joulev why do you want to do that? zod schemas are static so can be imported to the client components directly
data:image/s3,"s3://crabby-images/275c3/275c333dd9c41bfcb60b2ce71c8cd83abb8eb125" alt="Avatar"
Giant pandaOP
to create some basic fields based on schema
data:image/s3,"s3://crabby-images/275c3/275c333dd9c41bfcb60b2ce71c8cd83abb8eb125" alt="Avatar"
@Giant panda to create some basic fields based on schema
data:image/s3,"s3://crabby-images/e289f/e289f0ab781a1cb108105326ee790703fc125881" alt="Avatar"
you meant to create dynamic schema based on user input?
data:image/s3,"s3://crabby-images/275c3/275c333dd9c41bfcb60b2ce71c8cd83abb8eb125" alt="Avatar"
Giant pandaOP
yes
want to store schema in db and fetch and give to a client component
data:image/s3,"s3://crabby-images/e289f/e289f0ab781a1cb108105326ee790703fc125881" alt="Avatar"
why do you need to store the schema in the db again?
data:image/s3,"s3://crabby-images/275c3/275c333dd9c41bfcb60b2ce71c8cd83abb8eb125" alt="Avatar"
Giant pandaOP
to create some basic fields based on schema,
schema that can be changed by the users -> so want to, also store it in db
schema that can be changed by the users -> so want to, also store it in db
data:image/s3,"s3://crabby-images/275c3/275c333dd9c41bfcb60b2ce71c8cd83abb8eb125" alt="Avatar"
@Giant panda to create some basic fields based on schema,
schema that can be changed by the users -> so want to, also store it in db
data:image/s3,"s3://crabby-images/e289f/e289f0ab781a1cb108105326ee790703fc125881" alt="Avatar"
zod arent serializable; this means not only that it wouldn't work passing server to client, but storing it to a database. I think its better you change to a library that supports serializable schema like [superstruct](https://docs.superstructjs.org/)
Answer
data:image/s3,"s3://crabby-images/e289f/e289f0ab781a1cb108105326ee790703fc125881" alt="Avatar"
or you know, you can make your own schema parser, you know, keep the scope small
data:image/s3,"s3://crabby-images/e289f/e289f0ab781a1cb108105326ee790703fc125881" alt="Avatar"
@alfonsus or you know, you can make your own schema parser, you know, keep the scope small
data:image/s3,"s3://crabby-images/275c3/275c333dd9c41bfcb60b2ce71c8cd83abb8eb125" alt="Avatar"
Giant pandaOP
ok, thanks