diff options
author | Masaya Tojo <masaya@tojo.tokyo> | 2024-09-02 00:42:51 +0900 |
---|---|---|
committer | Masaya Tojo <masaya@tojo.tokyo> | 2024-09-02 00:42:51 +0900 |
commit | edddd70996b05c4e091b6aa0af6c7f3ef7e690ee (patch) | |
tree | c4fffdd0b0633a337e7a1593d452e8b5c45fe291 /src/signUpSchema.ts | |
parent | 71abc48fd4525b9194df848a6915ab4dfc11c354 (diff) |
react-query で取得した値でセレクトボックスを出すところまで実装
Diffstat (limited to 'src/signUpSchema.ts')
-rw-r--r-- | src/signUpSchema.ts | 28 |
1 files changed, 19 insertions, 9 deletions
diff --git a/src/signUpSchema.ts b/src/signUpSchema.ts index 4d8b71f..3b75ba1 100644 --- a/src/signUpSchema.ts +++ b/src/signUpSchema.ts @@ -11,7 +11,7 @@ const form1SchemaWithoutRefine = z.object({ tel3: z.string(), }) -const addRefine = <Form1 extends z.ZodTypeAny>(schema: Form1) => ( +const addTelRefine = <Form1Data extends z.ZodTypeAny>(schema: Form1Data) => ( schema.refine( ({ tel1, tel2, tel3 }) => (tel1.length > 0 && tel2.length > 0 && tel3.length > 0), { @@ -30,9 +30,6 @@ const addRefine = <Form1 extends z.ZodTypeAny>(schema: Form1) => ( } )) - -export type Form1 = z.infer<typeof form1SchemaWithoutRefine> - export const form2Schema = z.object({ email: z.string().min(1, { message: '必須項目です' }).email({ message: 'メールアドレスを入力してください' }), password: z.string() @@ -41,11 +38,24 @@ export const form2Schema = z.object({ .max(128, { message: '128文字以下で入力してください' }) }) -export type Form2 = z.infer<typeof form2Schema> +const favLangSchema = z.object({ + name: z.string() +}) + +export const form3Schema = z.object({ + // favLangs: z.array(favLangSchema), + hasGitHubRepo: z.boolean(), + gitHubUsername: z.string(), + repoName: z.string(), +}) -const formSchemaWithoutRefine = form1SchemaWithoutRefine.merge(form2Schema) +const formSchemaWithoutRefine = form1SchemaWithoutRefine.merge(form2Schema).merge(form3Schema) +export const form1Schema = addTelRefine(form1SchemaWithoutRefine) +export const formSchema = addTelRefine(formSchemaWithoutRefine) -export type Form = z.infer<typeof formSchemaWithoutRefine> +export type Form1Data = z.infer<typeof form1SchemaWithoutRefine> +export type Form2Data = z.infer<typeof form2Schema> +export type Form3Data = z.infer<typeof form3Schema> +export type FormData = z.infer<typeof formSchemaWithoutRefine> -export const form1Schema = addRefine(form1SchemaWithoutRefine) -export const formSchema = addRefine(formSchemaWithoutRefine) +export const displayTel = ({ tel1, tel2, tel3 }: Form1Data) => (`${tel1}-${tel2}-${tel3}`) |