'use client'; import React from 'react'; import { useRouter } from 'next/navigation'; import { MedReportLogo } from '@/components/med-report-logo'; import { SubmitButton } from '@/components/ui/submit-button'; import { sendCompanyOfferEmail } from '@/lib/services/mailer.service'; import { CompanySubmitData } from '@/lib/types/company'; import { companyOfferSchema } from '@/lib/validations/company-offer.schema'; import { zodResolver } from '@hookform/resolvers/zod'; import { useForm } from 'react-hook-form'; import { useTranslation } from 'react-i18next'; import { FormItem } from '@kit/ui/form'; import { Input } from '@kit/ui/input'; import { Label } from '@kit/ui/label'; import { Trans } from '@kit/ui/trans'; export default function CompanyOffer() { const router = useRouter(); const { register, handleSubmit, formState: { isValid, isSubmitting }, } = useForm({ resolver: zodResolver(companyOfferSchema), mode: 'onChange', }); const language = useTranslation().i18n.language; const onSubmit = async (data: CompanySubmitData) => { const formData = new FormData(); Object.entries(data).forEach(([key, value]) => { if (value !== undefined) formData.append(key, value); }); try { sendCompanyOfferEmail(data, language) .then(() => router.push('/company-offer/success')) .catch((error) => alert('error: ' + error)); } catch (err: unknown) { if (err instanceof Error) { console.warn('Server validation error: ' + err.message); } console.warn('Server validation error: ', err); } }; return (

); }