Hardcoded the platform URL due to problems with using ENV variables when deploying

This commit is contained in:
Tiago Ribeiro
2024-02-13 00:50:38 +00:00
parent 653bcf7f93
commit c31a74b835

View File

@@ -1,6 +1,6 @@
"use client"; "use client";
import React from "react"; import React from "react";
import { useForm, SubmitHandler, Controller } from "react-hook-form"; import {useForm, SubmitHandler, Controller} from "react-hook-form";
import Footer from "@/components/Footer"; import Footer from "@/components/Footer";
import Navbar from "@/components/Navbar"; import Navbar from "@/components/Navbar";
import Title from "@/components/Title"; import Title from "@/components/Title";
@@ -20,12 +20,12 @@ interface Props {
page: string; page: string;
} }
const ErrorMessage = ({ message }: { message: string }) => ( const ErrorMessage = ({message}: {message: string}) => (
<div className="w-full"> <div className="w-full">
<span className="text-mti-red">{message}</span> <span className="text-mti-red">{message}</span>
</div> </div>
); );
export default function App({ language, page }: Props) { export default function App({language, page}: Props) {
const selectOptions = [ const selectOptions = [
{ {
label: translation.feedback[language], label: translation.feedback[language],
@@ -41,7 +41,7 @@ export default function App({ language, page }: Props) {
}, },
]; ];
const { register, control, handleSubmit, formState } = useForm<FormValues>({ const {register, control, handleSubmit, formState} = useForm<FormValues>({
defaultValues: { defaultValues: {
name: "", name: "",
email: "", email: "",
@@ -51,13 +51,11 @@ export default function App({ language, page }: Props) {
}, },
}); });
const { errors, isDirty, isValid } = formState; const {errors, isDirty, isValid} = formState;
console.log("formState", formState.isSubmitSuccessful); console.log("formState", formState.isSubmitSuccessful);
const onSubmit: SubmitHandler<FormValues> = async (data) => { const onSubmit: SubmitHandler<FormValues> = async (data) => {
try { try {
const response = await fetch( const response = await fetch(`https://platform.encoach.com/api/tickets`, {
`${process.env.NEXT_PUBLIC_APP_URL}/api/tickets`,
{
method: "POST", method: "POST",
headers: { headers: {
"Content-Type": "application/json", "Content-Type": "application/json",
@@ -74,8 +72,7 @@ export default function App({ language, page }: Props) {
date: new Date().toISOString(), date: new Date().toISOString(),
description: data.description, description: data.description,
}), }),
} });
);
if (response.status === 200) { if (response.status === 200) {
const data = await response.json(); const data = await response.json();
@@ -87,7 +84,7 @@ export default function App({ language, page }: Props) {
}; };
return ( return (
<main className="text-mti-black flex h-screen w-full flex-col bg-white"> <main className="text-mti-black flex h-screen w-full flex-col bg-white" dir={language === "ar" ? "rtl" : "ltr"}>
<Navbar currentPage={page} language={language} /> <Navbar currentPage={page} language={language} />
<section className="w-full bg-mti-purple text-white text-center p-8 md:p-16"> <section className="w-full bg-mti-purple text-white text-center p-8 md:p-16">
<div className="w-full h-full flex flex-col items-center justify-center"> <div className="w-full h-full flex flex-col items-center justify-center">
@@ -95,48 +92,33 @@ export default function App({ language, page }: Props) {
</div> </div>
</section> </section>
<section className="w-full bg-white text-center p-8 md:p-16 flex justify-center items-center gap-32"> <section className="w-full bg-white text-center p-8 md:p-16 flex justify-center items-center gap-32">
<form <form onSubmit={handleSubmit(onSubmit)} className="form-control items-center gap-2 text-mti-black flex flex-col w-96">
onSubmit={handleSubmit(onSubmit)}
className="form-control items-center gap-2 text-mti-black flex flex-col w-96"
>
<input <input
id="name" id="name"
type="text" type="text"
placeholder={translation.name[language]} placeholder={translation.name[language]}
{...register("name", { required: true })} {...register("name", {required: true})}
className="input input-bordered md:w-full sm:w-1/2 max-w-md" className="input input-bordered md:w-full sm:w-1/2 max-w-md"
/> />
{errors.name && errors.name.type === "required" && ( {errors.name && errors.name.type === "required" && <ErrorMessage message={translation.fieldRequired[language]} />}
<ErrorMessage message={translation.fieldRequired[language]} />
)}
<input <input
id="email" id="email"
placeholder={translation.email[language]} placeholder={translation.email[language]}
type="text" type="text"
{...register("email", { required: true, pattern: /^\S+@\S+$/i })} {...register("email", {required: true, pattern: /^\S+@\S+$/i})}
className="input input-bordered md:w-full sm:w-1/2 max-w-md" className="input input-bordered md:w-full sm:w-1/2 max-w-md"
/> />
{errors.email && errors.email.type === "required" && ( {errors.email && errors.email.type === "required" && <ErrorMessage message={translation.fieldRequired[language]} />}
<ErrorMessage message={translation.fieldRequired[language]} /> {errors.email && errors.email.type === "pattern" && <ErrorMessage message={translation.invalidEmail[language]} />}
)}
{errors.email && errors.email.type === "pattern" && (
<ErrorMessage message={translation.invalidEmail[language]} />
)}
<input <input
id="subject" id="subject"
placeholder={translation.subject[language]} placeholder={translation.subject[language]}
type="text" type="text"
{...register("subject", { required: true })} {...register("subject", {required: true})}
className="input input-bordered md:w-full sm:w-1/2 max-w-md" className="input input-bordered md:w-full sm:w-1/2 max-w-md"
/> />
{errors.subject && errors.subject.type === "required" && ( {errors.subject && errors.subject.type === "required" && <ErrorMessage message={translation.fieldRequired[language]} />}
<ErrorMessage message={translation.fieldRequired[language]} /> <select id="type" {...register("type", {required: true})} className="select select-bordered md:w-full sm:w-1/2 max-w-md">
)}
<select
id="type"
{...register("type", { required: true })}
className="select select-bordered md:w-full sm:w-1/2 max-w-md"
>
<option value="" disabled> <option value="" disabled>
{translation.selectType[language]} {translation.selectType[language]}
</option> </option>
@@ -146,34 +128,19 @@ export default function App({ language, page }: Props) {
</option> </option>
))} ))}
</select> </select>
{errors.type && errors.type.type === "required" && ( {errors.type && errors.type.type === "required" && <ErrorMessage message={translation.fieldRequired[language]} />}
<ErrorMessage message={translation.fieldRequired[language]} />
)}
<textarea <textarea
id="description" id="description"
placeholder={translation.description[language]} placeholder={translation.description[language]}
{...register("description", { required: true })} {...register("description", {required: true})}
className="textarea textarea-bordered md:w-full sm:w-1/2 max-w-md" className="textarea textarea-bordered md:w-full sm:w-1/2 max-w-md"
rows={5} rows={5}
/> />
{errors.description && errors.description.type === "required" && ( {errors.description && errors.description.type === "required" && <ErrorMessage message={translation.fieldRequired[language]} />}
<ErrorMessage message={translation.fieldRequired[language]} /> <input type="submit" className="btn" disabled={!isDirty || !isValid} value={translation.submit[language]} />
)}
<input
type="submit"
className="btn"
disabled={!isDirty || !isValid}
value={translation.submit[language]}
/>
</form> </form>
<div className="flex flex-col"> <div className="flex flex-col">
<Image <Image src="/person_laptop_focus.jpg" alt="Contact Us" width={500} height={340} className="rounded-xl" />
src="/person_laptop_focus.jpg"
alt="Contact Us"
width={500}
height={340}
className="rounded-xl"
/>
</div> </div>
</section> </section>
<Footer language={language} /> <Footer language={language} />