You can pass the translation as an argument.
en.json:
{
"home": {
"errors": {
"Name is required": "Name is required."
}
}
}
schemas/index.ts:
import * as z from "zod";
export const BaseSchema = (t: (arg: string) => string) =>
z.object({
name: z.string().min(1, {message: t("errors.Name is required")})
});
in client code (form):
"use client";
import { useTranslations } from "next-intl";
import { BaseSchema } from "@/schemas";
import { useForm } from "react-hook-form";
import { zodResolver } from "@hookform/resolvers/zod";
export const Form = ()=> {
const t = useTranslations("home");
const formSchema = BaseSchema(t);
const form = useForm<z.infer<typeof formSchema>>({
resolver: zodResolver(formSchema),
defaultValues: {
name: ""
});
const onSubmit = async (values: z.infer<typeof formSchema>) => {
// await a server action
};
return(<Form></Form>);
};
in server action code:
"use server";
import { getTranslations } from "next-intl/server";
import * as z from "zod";
import { BaseSchema } from "@/schemas";
export const create = async (
values: z.infer<ReturnType<typeof BaseSchema>>
) => {
const t = await getTranslations("home");
const paramsSchema = BaseSchema(t);
const validatedFields = paramsSchema.safeParse(values);
if (!validatedFields.success) {
throw new Error("Invalid fields");
}
};