From b83308ae92c313cd9fd0b4ff5c990f4806f05323 Mon Sep 17 00:00:00 2001 From: swastik Date: Fri, 19 Apr 2024 01:36:31 +0530 Subject: [PATCH] additional-info Form finally working --- .../additionalInfo-form.tsx | 104 +++++++++++++----- .../createEvent/createEvent-form.tsx | 9 +- 2 files changed, 79 insertions(+), 34 deletions(-) diff --git a/app/homepage2/createEvent/additionalInformation/additionalInfo-form.tsx b/app/homepage2/createEvent/additionalInformation/additionalInfo-form.tsx index a36d340..43ef28f 100644 --- a/app/homepage2/createEvent/additionalInformation/additionalInfo-form.tsx +++ b/app/homepage2/createEvent/additionalInformation/additionalInfo-form.tsx @@ -48,21 +48,21 @@ type Input = z.infer; type Props = {}; -type EventType = { - id: string; - title: string; - description: string; - eventImageURL: string; - dateOfEvent: string; - locationOfEvent: string; - durationOfEvent: number; - registrationLink: string; - uid: string; - createdAt: string; - name: string; - profilePic: string; - sponsors: string[]; -}; +// type EventType = { +// id: string; +// title: string; +// description: string; +// eventImageURL: string; +// dateOfEvent: string; +// locationOfEvent: string; +// durationOfEvent: number; +// registrationLink: string; +// uid: string; +// createdAt: string; +// name: string; +// profilePic: string; +// sponsors: string[]; +// }; const AdditionalForm = (props: Props) => { const router = useRouter(); @@ -70,10 +70,10 @@ const AdditionalForm = (props: Props) => { const { toast } = useToast(); const form = useForm({ - resolver: zodResolver(EventType), + // resolver: zodResolver(EventType), defaultValues: { - sponsors: [], - locationOfEvent: "", + sponsors: [], + locationOfEvent: "", }, }); @@ -85,19 +85,37 @@ const AdditionalForm = (props: Props) => { const eventId = useSelector((state: RootState) => state.eventID.event_id); console.log(eventId); - async function onSubmit(data: Input) { - if (eventId === null) { - console.log("Event ID is null"); - return; - } + async function updateEvent( eventId: string,data: Input ) + { + const eventRef = doc(db, "events", eventId); + + console.log(landmark); + console.log(sponsors); - const eventRef = doc(db, "events", eventId); + // Append the landmark to the location of the event + const locationOfEvent = data.locationOfEvent + ", " + landmark; + console.log(locationOfEvent); try { - await updateDoc(eventRef, { - sponsors: sponsors, - locationOfEvent: data.locationOfEvent + " " + landmark, - }); + // Get the current document + const docSnap = await getDoc(eventRef); + + // Check if the sponsors field exists + if (docSnap.exists() && docSnap.data().sponsors) { + // If the sponsors field exists, update it + console.log(docSnap.data().title) + await updateDoc(eventRef, { + sponsors: arrayUnion(...sponsors), + locationOfEvent: docSnap.data().locationOfEvent + ", " + landmark, + }); + } else { + // If the sponsors field doesn't exist, set it + await updateDoc(eventRef, { + sponsors: sponsors, + locationOfEvent: docSnap.data().locationOfEvent + ", " + landmark, + }); + } + console.log("Update successful"); toast({ title: "Event Updated", @@ -106,6 +124,32 @@ const AdditionalForm = (props: Props) => { } catch (error) { console.error("Error updating document: ", error); } + + } + + function onSubmit(data: Input) { + if (eventId === null) { + toast({ + title: "Event ID is null", + description: "Event ID is null. Please try again.", + }); + console.log("Event ID is null"); + return; + } + + // locationOfEvent: data.locationOfEvent + ", " + landmark; + + updateEvent(eventId, data); + + toast({ + title: "You submitted the following values:", + description: ( +
+          {JSON.stringify(data, null, 2)}
+        
+ ), + }) + } return ( @@ -120,7 +164,6 @@ const AdditionalForm = (props: Props) => { control={form.control} name="locationOfEvent" render={({ field }) => ( -
Landmark @@ -133,7 +176,6 @@ const AdditionalForm = (props: Props) => { {/*
This is the location of the event.
*/}
-
)} /> @@ -197,9 +239,11 @@ const AdditionalForm = (props: Props) => { )} /> + + diff --git a/app/homepage2/createEvent/createEvent-form.tsx b/app/homepage2/createEvent/createEvent-form.tsx index 7743839..ef2cd37 100644 --- a/app/homepage2/createEvent/createEvent-form.tsx +++ b/app/homepage2/createEvent/createEvent-form.tsx @@ -137,11 +137,11 @@ const CreatEventPage = () => { description: "", eventImageURL: "", // dateOfEvent: 0000/00/00, - // locationOfEvent: "", + locationOfEvent: "", landmarkLocationOfEvent: "", // durationOfEvent:, registrationLink: "", - // sponsors: [], + sponsors: [], }, }); @@ -900,8 +900,8 @@ const CreatEventPage = () => { )} /> - {/* //spnosors section - ( @@ -950,6 +950,7 @@ const CreatEventPage = () => { )} /> */} +