Skip to content

Commit

Permalink
additionalEventDetails-Form
Browse files Browse the repository at this point in the history
  • Loading branch information
mrswastik-robot committed Apr 17, 2024
1 parent 83992fa commit 10f8fd0
Show file tree
Hide file tree
Showing 8 changed files with 1,326 additions and 977 deletions.
Original file line number Diff line number Diff line change
@@ -0,0 +1,209 @@
"use client";

import React, { use, useState } from "react";
import { useRouter } from "next/navigation";

import { X } from "lucide-react";

import { db, storage } from "@/utils/firebase";
import {
addDoc,
arrayUnion,
collection,
doc,
getDoc,
getDocs,
limit,
onSnapshot,
orderBy,
query,
serverTimestamp,
setDoc,
startAfter,
updateDoc,
where,
} from "firebase/firestore";
import {
Form,
FormControl,
FormLabel,
FormField,
FormItem,
FormMessage,
FormDescription,
} from "@/components/ui/form";
import { Input } from "@/components/ui/input";
import { Button } from "@/components/ui/button";
import { useToast } from "@/components/ui/use-toast";

import { z } from "zod";
import { EventType } from "@/schemas/event";
import { useForm } from "react-hook-form";
import { zodResolver } from "@hookform/resolvers/zod";

import { useSelector } from "react-redux";
import { RootState } from "@/store/store";

type Input = z.infer<typeof EventType>;

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[];
};

const AdditionalForm = (props: Props) => {
const router = useRouter();

const { toast } = useToast();

const form = useForm<Input>({
resolver: zodResolver(EventType),
defaultValues: {
sponsors: [],
locationOfEvent: "",
},
});

const [sponsors, setSponsors] = useState<string[]>([]);
const [sponsorInput, setSponsorInput] = useState<string>("");

const [landmark, setLandmark] = useState<string>("");

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;
}

const eventRef = doc(db, "events", eventId);

try {
await updateDoc(eventRef, {
sponsors: sponsors,
locationOfEvent: data.locationOfEvent + " " + landmark,
});
console.log("Update successful");
toast({
title: "Event Updated",
description: "Event has been updated successfully.",
});
} catch (error) {
console.error("Error updating document: ", error);
}
}

return (
<div className="">
<Form {...form}>
<form
onSubmit={form.handleSubmit(onSubmit)}
className=" flex-col space-y-7"
>
{/* Location of the Event */}
<FormField
control={form.control}
name="locationOfEvent"
render={({ field }) => (
<div className=" flex-col space-y-1">
<FormItem>
<FormLabel>Landmark</FormLabel>
<FormControl>
<Input
placeholder="Any Landmark near location of the Event."
value={landmark}
onChange={(e) => setLandmark(e.target.value)}
/>
</FormControl>
{/* <div className="text-[12px] opacity-70">This is the location of the event.</div> */}
<FormMessage />
</FormItem>
</div>
)}
/>

{/* //spnosors section */}
<FormField
control={form.control}
name="sponsors"
render={({ field }) => (
<FormItem>
<FormLabel>Sponsors</FormLabel>
<FormControl>
<div className=" flex gap-2">
<Input
placeholder="Sponsors"
value={sponsorInput}
onChange={(e) => setSponsorInput(e.target.value)}
onKeyDown={(e) => {
if (e.key === "Enter") {
setSponsors((prev) => [...prev, sponsorInput]);
setSponsorInput("");
}
}}
/>
<Button
type="button"
onClick={() => {
setSponsors((prev) => [...prev, sponsorInput]);
setSponsorInput("");
}}
>
Add
</Button>
</div>
</FormControl>

<div className=" flex gap-2">
{sponsors.map((sponsor, index) => (
<div
key={index}
className=" flex gap-1 p-2 rounded-3xl bg-[#F6F6F7]"
>
<p>{sponsor}</p>
<button
type="button"
onClick={() => {
const newSponsors = [...sponsors];
newSponsors.splice(index, 1);
setSponsors(newSponsors);
}}
>
<X />
</button>
</div>
))}
</div>

<div className="text-[12px] opacity-70">
Add sponsors for the event.
</div>
<FormMessage />
</FormItem>
)}
/>
<Button className=" w-full my-4" type="submit">
Update
</Button>
</form>
</Form>
</div>
);
};

export default AdditionalForm;
19 changes: 19 additions & 0 deletions app/homepage2/createEvent/additionalInformation/page.tsx
Original file line number Diff line number Diff line change
@@ -0,0 +1,19 @@


import { Separator } from "@/components/ui/separator"
import AdditionalForm from "./additionalInfo-form"

export default function AdditionalInformationPage() {
return (
<div className="space-y-6">
<div>
<h3 className="text-lg font-medium">Additional Information</h3>
<p className="text-sm text-muted-foreground">
Fill the form to provide additional information about your event.
</p>
</div>
<Separator />
<AdditionalForm />
</div>
)
}
Loading

0 comments on commit 10f8fd0

Please sign in to comment.