refactor: update company registration flow and email handling; switch to zod for validation

This commit is contained in:
Danel Kungla
2025-06-17 13:45:46 +03:00
parent fe44030190
commit 291919c2d1
18 changed files with 274 additions and 87 deletions

View File

@@ -1,31 +1,26 @@
"use server";
'use server';
import * as yup from "yup";
import { companySchema } from "@/lib/validations/companySchema";
import { companySchema } from '@/lib/validations/companySchema';
export async function submitCompanyRegistration(formData: FormData) {
const data = {
companyName: formData.get("companyName")?.toString() || "",
contactPerson: formData.get("contactPerson")?.toString() || "",
email: formData.get("email")?.toString() || "",
phone: formData.get("phone")?.toString() || "",
companyName: formData.get('companyName')?.toString() || '',
contactPerson: formData.get('contactPerson')?.toString() || '',
email: formData.get('email')?.toString() || '',
phone: formData.get('phone')?.toString() || '',
};
try {
await companySchema.validate(data, { abortEarly: false });
const result = companySchema.safeParse(data);
console.log("Valid data:", data);
} catch (validationError) {
if (validationError instanceof yup.ValidationError) {
const errors = validationError.inner.map((err) => ({
path: err.path,
message: err.message,
}));
throw new Error(
"Validation failed: " +
errors.map((e) => `${e.path}: ${e.message}`).join(", ")
);
}
throw validationError;
if (!result.success) {
const errors = result.error.errors.map((err) => ({
path: err.path.join('.'),
message: err.message,
}));
throw new Error(
'Validation failed: ' +
errors.map((e) => `${e.path}: ${e.message}`).join(', '),
);
}
}