diff --git a/apps/web/src/app/admin/events/new/page.tsx b/apps/web/src/app/admin/events/new/page.tsx index 6a11aa99..0050480d 100644 --- a/apps/web/src/app/admin/events/new/page.tsx +++ b/apps/web/src/app/admin/events/new/page.tsx @@ -1,4 +1,4 @@ -import NewEventForm from "@/components/admin/events/NewEventForm"; +import NewEventForm from "@/components/events/admin/NewEventForm"; export default function Page() { const defaultDate = new Date(); diff --git a/apps/web/src/app/admin/events/page.tsx b/apps/web/src/app/admin/events/page.tsx index 2a9d0ae1..980d2fcf 100644 --- a/apps/web/src/app/admin/events/page.tsx +++ b/apps/web/src/app/admin/events/page.tsx @@ -1,12 +1,11 @@ -import { db } from "db"; -import { DataTable } from "@/components/admin/events/EventDataTable"; -import { columns } from "@/components/admin/events/EventColumns"; +import { EventDataTable } from "@/components/events/shared/EventDataTable"; +import { columns } from "@/components/events/shared/EventColumns"; import { Button } from "@/components/shadcn/ui/button"; import { PlusCircle } from "lucide-react"; import Link from "next/link"; - +import { getAllEvents } from "db/functions"; export default async function Page() { - const events = await db.query.events.findMany(); + const events = await getAllEvents(); return (
@@ -17,7 +16,7 @@ export default async function Page() { Events

- {events.length} Event{events.length != 1 ? "s" : ""} + {events.length} Event{events.length != 1 && "s"}

@@ -30,7 +29,7 @@ export default async function Page() { - + ); } diff --git a/apps/web/src/app/api/admin/events/create/route.ts b/apps/web/src/app/api/admin/events/create/route.ts index bfb68f73..372cf7de 100644 --- a/apps/web/src/app/api/admin/events/create/route.ts +++ b/apps/web/src/app/api/admin/events/create/route.ts @@ -9,6 +9,7 @@ import { z } from "zod"; import superjson from "superjson"; import c from "config"; +// Make this a server action export async function POST(req: Request) { const { userId } = auth(); @@ -25,9 +26,8 @@ export async function POST(req: Request) { return new Response("Unauthorized", { status: 401 }); } - // console.log(await req.json()); const body = superjson.parse(await req.text()); - const parsedBody = newEventValidator.safeParse(body); + const parsedBody = newEventFormSchema.safeParse(body); if (!parsedBody.success) { return new Response("Malformed request body.", { status: 400 }); diff --git a/apps/web/src/app/dash/layout.tsx b/apps/web/src/app/dash/layout.tsx index c784403d..15d16e71 100644 --- a/apps/web/src/app/dash/layout.tsx +++ b/apps/web/src/app/dash/layout.tsx @@ -45,12 +45,15 @@ export default async function DashLayout({ children }: DashLayoutProps) {
- {c.hackathonName + + {c.hackathonName + +

Dashboard

@@ -81,7 +84,9 @@ export default async function DashLayout({ children }: DashLayoutProps) {
-
+
+ +
{Object.entries(c.dashPaths.dash).map(([name, path]) => ( diff --git a/apps/web/src/app/dash/schedule/page.tsx b/apps/web/src/app/dash/schedule/page.tsx index 3650b296..1d9b20fc 100644 --- a/apps/web/src/app/dash/schedule/page.tsx +++ b/apps/web/src/app/dash/schedule/page.tsx @@ -1,21 +1,11 @@ -import c from "config"; -import Day from "@/components/schedule/Day"; -import { db } from "db"; -import { format, compareAsc } from "date-fns"; -import { type ReactNode } from "react"; -import { formatInTimeZone } from "date-fns-tz"; -import { redirect } from "next/navigation"; - -export default async function Page() { - const events = await db.query.events.findMany(); - +import { Suspense } from "react"; +import UserScheduleView from "@/components/schedule/UserScheduleView"; +import Loading from "@/components/shared/Loading"; +export default function Page() { return ( -
-

- Bug with Scheduling was found. Fix Coming soon! -

-

- Christian

-
+ }> + + ); } diff --git a/apps/web/src/app/schedule/[id]/page.tsx b/apps/web/src/app/schedule/[id]/page.tsx index dc45b9c6..c5c1ad74 100644 --- a/apps/web/src/app/schedule/[id]/page.tsx +++ b/apps/web/src/app/schedule/[id]/page.tsx @@ -2,7 +2,7 @@ import { db } from "db"; import { eq } from "db/drizzle"; import { events } from "db/schema"; import FullScreenMessage from "@/components/shared/FullScreenMessage"; -import EventFull from "@/components/schedule/EventFull"; +import EventDetails from "@/components/events/admin/EventDetails"; import Navbar from "@/components/shared/Navbar"; export default async function Page({ params }: { params: { id: string } }) { @@ -33,7 +33,7 @@ export default async function Page({ params }: { params: { id: string } }) { return ( <> - + ); } diff --git a/apps/web/src/components/schedule/EventFull.tsx b/apps/web/src/components/events/admin/EventDetails.tsx similarity index 72% rename from apps/web/src/components/schedule/EventFull.tsx rename to apps/web/src/components/events/admin/EventDetails.tsx index 922fcded..298d7a17 100644 --- a/apps/web/src/components/schedule/EventFull.tsx +++ b/apps/web/src/components/events/admin/EventDetails.tsx @@ -1,15 +1,17 @@ -import { events } from "db/schema"; -import { InferModel } from "db/drizzle"; import c from "config"; import { Badge } from "@/components/shadcn/ui/badge"; import Balancer from "react-wrap-balancer"; import { formatInTimeZone } from "date-fns-tz"; +import { getClientTimeZone } from "@/lib/utils/client/shared"; +import { EventType } from "@/lib/types/events"; +import { headers } from "next/headers"; +import { VERCEL_IP_TIMEZONE_HEADER_KEY } from "@/lib/constants"; + +export default function EventDetails({ event }: { event: EventType }) { + const userTimeZoneHeaderKey = headers().get(VERCEL_IP_TIMEZONE_HEADER_KEY); + + const userTimeZone = getClientTimeZone(userTimeZoneHeaderKey); -export default function EventFull({ - event, -}: { - event: InferModel; -}) { return (

{`${formatInTimeZone( event.startTime, - c.hackathonTimezone, + userTimeZone, "EEEE MMMM do", )}, ${formatInTimeZone( event.startTime, - c.hackathonTimezone, + userTimeZone, "h:mm a", - )} - ${formatInTimeZone(event.endTime, c.hackathonTimezone, "h:mm a")}`}

+ )} - ${formatInTimeZone(event.endTime, userTimeZone, "h:mm a")}`}

diff --git a/apps/web/src/components/admin/events/NewEventForm.tsx b/apps/web/src/components/events/admin/NewEventForm.tsx similarity index 70% rename from apps/web/src/components/admin/events/NewEventForm.tsx rename to apps/web/src/components/events/admin/NewEventForm.tsx index e20a7bed..d43ea847 100644 --- a/apps/web/src/components/admin/events/NewEventForm.tsx +++ b/apps/web/src/components/events/admin/NewEventForm.tsx @@ -25,45 +25,43 @@ import { Textarea } from "@/components/shadcn/ui/textarea"; import c from "config"; import { DateTimePicker } from "@/components/shadcn/ui/date-time-picker/date-time-picker"; import { parseAbsolute, getLocalTimeZone } from "@internationalized/date"; -import { newEventValidator } from "@/validators/shared/newEvent"; import { zpostSafe } from "@/lib/utils/client/zfetch"; import { BasicRedirValidator } from "@/validators/shared/basicRedir"; import { useState } from "react"; -import { Shell } from "lucide-react"; +import { LoaderPinwheel } from "lucide-react"; import { useRouter } from "next/navigation"; - -interface NewEventFormProps { - defaultDate: Date; -} - -const formSchema = newEventValidator.merge( - z.object({ - type: z.enum(Object.keys(c.eventTypes) as any), - }), -); +import { ONE_HOUR_IN_MILLISECONDS } from "@/lib/constants"; +import { NewEventFormProps } from "@/lib/types/events"; +import { newEventFormSchema } from "@/validators/event"; +import { useAction } from "next-safe-action/hook"; +import { eventType } from "@/lib/utils/shared/types"; +import { useEffect } from "react"; +import { ThreeCircles } from "react-loader-spinner"; export default function NewEventForm({ defaultDate }: NewEventFormProps) { const [loading, setLoading] = useState(false); const router = useRouter(); - const form = useForm>({ - resolver: zodResolver(formSchema), + const userLocalTimeZone = getLocalTimeZone(); + + const form = useForm>({ + resolver: zodResolver(newEventFormSchema), defaultValues: { title: "", description: "", type: "" as any, host: "", startTime: defaultDate, - endTime: defaultDate, + endTime: new Date(defaultDate.getTime() + ONE_HOUR_IN_MILLISECONDS), }, }); - async function onSubmit(values: z.infer) { + async function onSubmit(values: z.infer) { setLoading(true); const res = await zpostSafe({ url: "/api/admin/events/create", body: values, superReq: true, - vReq: formSchema, + vReq: newEventFormSchema, vRes: BasicRedirValidator, }); setLoading(false); @@ -91,8 +89,7 @@ export default function NewEventForm({ defaultDate }: NewEventFormProps) { - Generally its best to keep this short and - consise + Keep title short and concise @@ -105,10 +102,7 @@ export default function NewEventForm({ defaultDate }: NewEventFormProps) { Description -