From 2519cf30a6c8699a892d2fd76d4add9506eeb1ed Mon Sep 17 00:00:00 2001 From: jeffplays2005 Date: Thu, 17 Oct 2024 11:35:13 +1300 Subject: [PATCH 01/10] 805-frontend-display-all-events-to-admin Initial commit * Created EventService.ts for fetching all events --- client/src/services/Event/EventService.ts | 16 ++++++++++++++++ 1 file changed, 16 insertions(+) create mode 100644 client/src/services/Event/EventService.ts diff --git a/client/src/services/Event/EventService.ts b/client/src/services/Event/EventService.ts new file mode 100644 index 00000000..eeda1b46 --- /dev/null +++ b/client/src/services/Event/EventService.ts @@ -0,0 +1,16 @@ +import fetchClient from "@/services/OpenApiFetchClient" + +const EventService = { + getAllEvents: async function (limit: number, cursor: string) { + const { data } = await fetchClient.GET("/events", { + params: { + query: { + limit, + cursor + } + } + }) + return data + } +} +export default EventService From 592359471f168ecf995622b92736e0f499d39fb4 Mon Sep 17 00:00:00 2001 From: jeffplays2005 Date: Sat, 26 Oct 2024 19:03:32 +1300 Subject: [PATCH 02/10] Add all files for Admin All Events view Needs refactoring... --- .../AdminAllEvents/AdminAllEvents.story.tsx | 59 ++++ .../AdminAllEvents/AdminAllEvents.test.tsx | 0 .../AdminAllEvents/AdminAllEvents.tsx | 258 ++++++++++++++++++ .../AdminEventView/AdminEventView.story.tsx | 49 +++- .../Admin/AdminEventView/AdminEventView.tsx | 51 +++- .../composite/EventsView/EventsView.tsx | 6 +- .../Event/EventPreview/EventPreview.tsx | 16 +- .../components/generic/Event/EventUtils.ts | 6 +- 8 files changed, 430 insertions(+), 15 deletions(-) create mode 100644 client/src/components/composite/Admin/AdminEventView/AdminAllEvents/AdminAllEvents.story.tsx create mode 100644 client/src/components/composite/Admin/AdminEventView/AdminAllEvents/AdminAllEvents.test.tsx create mode 100644 client/src/components/composite/Admin/AdminEventView/AdminAllEvents/AdminAllEvents.tsx diff --git a/client/src/components/composite/Admin/AdminEventView/AdminAllEvents/AdminAllEvents.story.tsx b/client/src/components/composite/Admin/AdminEventView/AdminAllEvents/AdminAllEvents.story.tsx new file mode 100644 index 00000000..da4290cb --- /dev/null +++ b/client/src/components/composite/Admin/AdminEventView/AdminAllEvents/AdminAllEvents.story.tsx @@ -0,0 +1,59 @@ +import type { Meta, StoryObj } from "@storybook/react" +import AdminAllEvents from "./AdminAllEvents" +import { Timestamp } from "firebase/firestore" + +const meta: Meta = { + component: AdminAllEvents +} + +export default meta +type Story = StoryObj + +const earlierStartDate = Timestamp.fromDate(new Date(2023, 1, 1)) +const startDate = Timestamp.fromDate(new Date(2024, 1, 1)) + +export const DefaultEventsPage: Story = { + args: { + rawEvents: [ + { + id: "1", + title: "UASC New event 1", + location: "UASC", + physical_start_date: earlierStartDate, + sign_up_start_date: earlierStartDate, + sign_up_end_date: earlierStartDate, + google_forms_link: "https://google.com", + description: + "Lorem ipsum dolor sit amet consectetur adipisicing elit. Reprehenderit adipisci repellat perferendis. Quia ipsum laborum est, veniam accusamus voluptas praesentium, odio perspiciatis blanditiis sequi dignissimos unde. Natus delectus nihil cum." + }, + { + id: "2", + title: "UASC New event 2", + location: "UASC", + physical_start_date: earlierStartDate, + sign_up_start_date: startDate, + sign_up_end_date: earlierStartDate, + description: + "Lorem ipsum dolor sit amet consectetur adipisicing elit. Reprehenderit adipisci repellat perferendis. Quia ipsum laborum est, veniam accusamus voluptas praesentium, odio perspiciatis blanditiis sequi dignissimos unde. Natus delectus nihil cum." + }, + { + id: "3", + title: "UASC New Event 3", + location: "UASC", + physical_start_date: earlierStartDate, + sign_up_start_date: startDate, + sign_up_end_date: earlierStartDate, + description: + "Lorem ipsum dolor sit amet consectetur adipisicing elit. Reprehenderit adipisci repellat perferendis. Quia ipsum laborum est, veniam accusamus voluptas praesentium, odio perspiciatis blanditiis sequi dignissimos unde. Natus delectus nihil cum." + } + ] + }, + tags: ["autodocs"] +} + +export const EmptyEventsPage: Story = { + args: { + rawEvents: [] + }, + tags: ["autodocs"] +} diff --git a/client/src/components/composite/Admin/AdminEventView/AdminAllEvents/AdminAllEvents.test.tsx b/client/src/components/composite/Admin/AdminEventView/AdminAllEvents/AdminAllEvents.test.tsx new file mode 100644 index 00000000..e69de29b diff --git a/client/src/components/composite/Admin/AdminEventView/AdminAllEvents/AdminAllEvents.tsx b/client/src/components/composite/Admin/AdminEventView/AdminAllEvents/AdminAllEvents.tsx new file mode 100644 index 00000000..3dabbbe9 --- /dev/null +++ b/client/src/components/composite/Admin/AdminEventView/AdminAllEvents/AdminAllEvents.tsx @@ -0,0 +1,258 @@ +import EventsCardPreview, { + IEventsCardPreview +} from "@/components/generic/Event/EventPreview/EventPreview" +import EventDetailed from "@/components/generic/Event/EventDetailed/EventDetailed" +import { DateUtils } from "@/components/utils/DateUtils" +import { Event } from "@/models/Events" +import { useCallback, useMemo, useState } from "react" +import { + EventDateComparisons, + EventMessages, + EventRenderingUtils, + IMAGE_PLACEHOLDER_SRC +} from "@/components/generic/Event/EventUtils" +import Button from "@/components/generic/FigmaButtons/FigmaButton" +import Loader from "@/components/generic/SuspenseComponent/Loader" + +/** + * Interface representing the properties of the Events Page. + */ +interface IAdminAllEvents { + /** + * A list of _all_ {@link Event}s which should either be mocked + * or fetched from the backend. **NO** pre-processing should be + * performed on this list as it will be further mutated in the + * {@link EventsPage} component. + */ + rawEvents?: Event[] + + /** + * Indicates whether the events are currently being loaded. + */ + isLoading?: boolean + + /** + * Indicates whether there are more events to be fetched. + */ + hasMoreEvents?: boolean + + /** + * Function to fetch more events. + */ + fetchMoreEvents?: () => void + + /** + * The ID of the preselected event. + */ + preselectedEventId?: string + + /** + * Callback function to handle changes to the selected event ID. + * @param id - The new selected event ID. + */ + onSelectedEventIdChange?: (id?: string) => void +} + +/** + * Helper type to split the raw events into upcoming and past ones, + * this is important as they need to be sorted differently + */ +interface EventList { + upcomingAndCurrentEvents: Event[] + pastEvents: Event[] +} + +/** + * Used to handle all _presentation_ logic conerning the evnts + * + * - **Do not make any network requests in this component, the data should + * be fetched seperately and passed in as {@link rawEvents}** + * - String operations are ideally done in {@link EventMessages} + * - Complex date comparisons should also be abstracted away into {@link EventDateComparisons} + */ +const AdminAllEvents = ({ + rawEvents = [], + hasMoreEvents, + isLoading, + fetchMoreEvents, + preselectedEventId, + onSelectedEventIdChange +}: IAdminAllEvents) => { + const [selectedEventId, setSelectedEventId] = useState( + preselectedEventId + ) + + const eventSelectionHandler = useCallback( + (id?: string) => { + setSelectedEventId(id) + onSelectedEventIdChange?.(id) + }, + [setSelectedEventId, onSelectedEventIdChange] + ) + + /** + * Partitions of the array that allow us to individually process the ongoing events + */ + const eventList = useMemo(() => { + return rawEvents.reduce( + (buf: EventList, event) => { + const { physical_start_date, physical_end_date } = event + if ( + EventDateComparisons.isPastEvent( + new Date(DateUtils.timestampMilliseconds(physical_start_date)), + physical_end_date && + new Date(DateUtils.timestampMilliseconds(physical_end_date)) + ) + ) { + buf.pastEvents.push(event) + } else { + buf.upcomingAndCurrentEvents.push(event) + } + + /** + * Start dates ascending for upcoming and current events + */ + buf.upcomingAndCurrentEvents.sort( + ( + { physical_start_date: startDate1 }, + { physical_start_date: startDate2 } + ) => + DateUtils.timestampMilliseconds(startDate1) - + DateUtils.timestampMilliseconds(startDate2) + ) + + return buf + }, + { upcomingAndCurrentEvents: [], pastEvents: [] } + ) + }, [rawEvents]) + + const selectedEventObject = useMemo(() => { + if (!selectedEventId) return + + const eventInfo = rawEvents.find((event) => event.id === selectedEventId) + + /** + * See if we can find the event, otherwise give up + * Has a side-effect depending on {@link rawEvents} + */ + if (!eventInfo) { + fetchMoreEvents?.() + // We can't fetch any more, and it is still undefined, so we remove the query + !isLoading && !hasMoreEvents && eventSelectionHandler(undefined) + } + + return eventInfo + }, [ + selectedEventId, + rawEvents, + fetchMoreEvents, + hasMoreEvents, + isLoading, + eventSelectionHandler + ]) + + /** + * Detailed view of the event + */ + const SelectedEventPanel = useMemo(() => { + if (!selectedEventObject) { + return + } + + const { + sign_up_start_date, + google_forms_link, + physical_end_date, + physical_start_date, + description, + title + } = selectedEventObject + return ( + { + eventSelectionHandler(undefined) + }} + date={EventMessages.eventDateRange( + new Date(DateUtils.timestampMilliseconds(physical_start_date)), + physical_end_date && + new Date(DateUtils.timestampMilliseconds(physical_end_date)) + )} + isPastEvent={EventDateComparisons.isPastEvent( + new Date(DateUtils.timestampMilliseconds(physical_start_date)), + physical_end_date && + new Date(DateUtils.timestampMilliseconds(physical_end_date)) + )} + image={selectedEventObject.image_url || IMAGE_PLACEHOLDER_SRC} + location={selectedEventObject.location} + signUpOpenDate={ + new Date(DateUtils.timestampMilliseconds(sign_up_start_date)) + } + googleFormLink={google_forms_link} + content={

{description}

} + title={title} + /> + ) + }, [selectedEventObject, eventSelectionHandler]) + + const previewCurrentEvents: IEventsCardPreview[] = + eventList.upcomingAndCurrentEvents?.map((event) => { + return EventRenderingUtils.previewTransformer( + event, + eventSelectionHandler, + "edit event" + ) + }) || [] + + const previewPastEvents: IEventsCardPreview[] = + eventList.pastEvents?.map((event) => { + return EventRenderingUtils.previewTransformer( + event, + eventSelectionHandler, + "edit event" + ) + }) || [] + + return ( + <> +
+ {selectedEventId ? ( + SelectedEventPanel + ) : ( + <> + {isLoading ? ( + + ) : ( +
+ {rawEvents.length > 0 ? ( + <>Upcoming Events + ) : ( + <>No events found! + )} +
+ )} + {previewCurrentEvents.map((event) => ( + + ))} + + {previewPastEvents.map((event) => ( + + ))} + + )} + + {hasMoreEvents && !selectedEventId && ( + + )} +
+ + ) +} + +export default AdminAllEvents diff --git a/client/src/components/composite/Admin/AdminEventView/AdminEventView.story.tsx b/client/src/components/composite/Admin/AdminEventView/AdminEventView.story.tsx index 97e7b5e6..c33a5270 100644 --- a/client/src/components/composite/Admin/AdminEventView/AdminEventView.story.tsx +++ b/client/src/components/composite/Admin/AdminEventView/AdminEventView.story.tsx @@ -1,6 +1,7 @@ import type { Meta, StoryObj } from "@storybook/react" import AdminEventView from "./AdminEventView" +import { Timestamp } from "firebase/firestore" const meta: Meta = { component: AdminEventView @@ -9,11 +10,57 @@ const meta: Meta = { export default meta type Story = StoryObj +const earlierStartDate = Timestamp.fromDate(new Date(2023, 1, 1)) +const startDate = Timestamp.fromDate(new Date(2024, 1, 1)) + export const DefaultAdminEventView: Story = { args: { handlePostEvent: () => {}, generateImageLink: async () => { return undefined - } + }, + rawEvents: [] + } +} + +export const AdminEventViewWithEvents: Story = { + args: { + handlePostEvent: () => {}, + generateImageLink: async () => { + return undefined + }, + rawEvents: [ + { + id: "1", + title: "UASC New event 1", + location: "UASC", + physical_start_date: earlierStartDate, + sign_up_start_date: earlierStartDate, + sign_up_end_date: earlierStartDate, + google_forms_link: "https://google.com", + description: + "Lorem ipsum dolor sit amet consectetur adipisicing elit. Reprehenderit adipisci repellat perferendis. Quia ipsum laborum est, veniam accusamus voluptas praesentium, odio perspiciatis blanditiis sequi dignissimos unde. Natus delectus nihil cum." + }, + { + id: "2", + title: "UASC New event 2", + location: "UASC", + physical_start_date: earlierStartDate, + sign_up_start_date: startDate, + sign_up_end_date: earlierStartDate, + description: + "Lorem ipsum dolor sit amet consectetur adipisicing elit. Reprehenderit adipisci repellat perferendis. Quia ipsum laborum est, veniam accusamus voluptas praesentium, odio perspiciatis blanditiis sequi dignissimos unde. Natus delectus nihil cum." + }, + { + id: "3", + title: "UASC New Event 3", + location: "UASC", + physical_start_date: earlierStartDate, + sign_up_start_date: startDate, + sign_up_end_date: earlierStartDate, + description: + "Lorem ipsum dolor sit amet consectetur adipisicing elit. Reprehenderit adipisci repellat perferendis. Quia ipsum laborum est, veniam accusamus voluptas praesentium, odio perspiciatis blanditiis sequi dignissimos unde. Natus delectus nihil cum." + } + ] } } diff --git a/client/src/components/composite/Admin/AdminEventView/AdminEventView.tsx b/client/src/components/composite/Admin/AdminEventView/AdminEventView.tsx index 6b79fbcf..25d42a43 100644 --- a/client/src/components/composite/Admin/AdminEventView/AdminEventView.tsx +++ b/client/src/components/composite/Admin/AdminEventView/AdminEventView.tsx @@ -1,7 +1,8 @@ import Button from "@/components/generic/FigmaButtons/FigmaButton" -import { CreateEventBody } from "@/models/Events" +import { CreateEventBody, Event } from "@/models/Events" import { useState } from "react" import AdminEventForm from "./AdminEventForm/AdminEventForm" +import AdminAllEvents from "./AdminAllEvents/AdminAllEvents" type EventViewModes = "view-all-events" | "creating-new-event" | "editing-event" @@ -20,13 +21,40 @@ interface IAdminEventView { * @param data - The data of the event to be posted. */ handlePostEvent: (data: CreateEventBody) => void + + /** + * A list of _all_ {@link Event}s which should either be mocked + * or fetched from the backend. **NO** pre-processing should be + * performed on this list as it will be further mutated in the + * {@link EventsPage} component. + */ + rawEvents?: Event[] + + /** + * Indicates whether the events are currently being loaded. + */ + isLoading?: boolean + + /** + * Indicates whether there are more events to be fetched. + */ + hasMoreEvents?: boolean + + /** + * Function to fetch more events. + */ + fetchMoreEvents?: () => void } const AdminEventViewContent = ({ mode, setMode, handlePostEvent, - generateImageLink + generateImageLink, + rawEvents, + hasMoreEvents, + isLoading, + fetchMoreEvents // TODO: extend with the event id to allow showing an edit view }: { mode: EventViewModes @@ -34,7 +62,14 @@ const AdminEventViewContent = ({ } & IAdminEventView) => { switch (mode) { case "view-all-events": - return null + return ( + + ) case "creating-new-event": return ( { */ const AdminEventView = ({ handlePostEvent, - generateImageLink + generateImageLink, + rawEvents = [], + hasMoreEvents, + isLoading, + fetchMoreEvents }: IAdminEventView) => { const [mode, setMode] = useState("view-all-events") @@ -102,6 +141,10 @@ const AdminEventView = ({ mode={mode} handlePostEvent={handlePostEvent} generateImageLink={generateImageLink} + rawEvents={rawEvents} + hasMoreEvents={hasMoreEvents} + isLoading={isLoading} + fetchMoreEvents={fetchMoreEvents} /> ) diff --git a/client/src/components/composite/EventsView/EventsView.tsx b/client/src/components/composite/EventsView/EventsView.tsx index b2e1cc90..dc8c3ddc 100644 --- a/client/src/components/composite/EventsView/EventsView.tsx +++ b/client/src/components/composite/EventsView/EventsView.tsx @@ -199,7 +199,8 @@ const EventsPage = ({ eventList.upcomingAndCurrentEvents?.map((event) => { return EventRenderingUtils.previewTransformer( event, - eventSelectionHandler + eventSelectionHandler, + "view more" ) }) || [] @@ -207,7 +208,8 @@ const EventsPage = ({ eventList.pastEvents?.map((event) => { return EventRenderingUtils.previewTransformer( event, - eventSelectionHandler + eventSelectionHandler, + "view more" ) }) || [] diff --git a/client/src/components/generic/Event/EventPreview/EventPreview.tsx b/client/src/components/generic/Event/EventPreview/EventPreview.tsx index 4e34d731..333518f2 100644 --- a/client/src/components/generic/Event/EventPreview/EventPreview.tsx +++ b/client/src/components/generic/Event/EventPreview/EventPreview.tsx @@ -35,19 +35,22 @@ export interface IEventsCardPreview { * Headline of the preview - generally is the title of the event */ title: string + + viewButtonText?: string } type ViewButtonProps = { onClick: () => void + viewButtonText?: string } -const ViewButton = ({ onClick }: ViewButtonProps) => { +const ViewButton = ({ onClick, viewButtonText }: ViewButtonProps) => { return ( @@ -67,12 +70,13 @@ const EventsCardPreview = ({ onClick, image = "", signUpOpenDate, - isPastEvent + isPastEvent, + viewButtonText = "view more" }: IEventsCardPreview) => { return (
@@ -97,7 +101,7 @@ const EventsCardPreview = ({

{location}

- +
) diff --git a/client/src/components/generic/Event/EventUtils.ts b/client/src/components/generic/Event/EventUtils.ts index 094812da..d65fa439 100644 --- a/client/src/components/generic/Event/EventUtils.ts +++ b/client/src/components/generic/Event/EventUtils.ts @@ -78,7 +78,8 @@ export const EventRenderingUtils = { */ previewTransformer: ( event: Event, - eventSetter: (id?: string) => void + eventSetter: (id?: string) => void, + buttonText?: string ): IEventsCardPreview => { let eventStartDate @@ -114,7 +115,8 @@ export const EventRenderingUtils = { ), onClick: () => { eventSetter(event.id) - } + }, + viewButtonText: buttonText } } } From a921b2a149c142b2b660e8353f0f0caaae10143e Mon Sep 17 00:00:00 2001 From: jeffplays2005 Date: Sun, 27 Oct 2024 21:51:37 +1300 Subject: [PATCH 03/10] Fetch events in WrappedAdminEventView --- .../AdminEventView/WrappedAdminEventView.tsx | 25 +++++++++++++++++++ 1 file changed, 25 insertions(+) diff --git a/client/src/components/composite/Admin/AdminEventView/WrappedAdminEventView.tsx b/client/src/components/composite/Admin/AdminEventView/WrappedAdminEventView.tsx index 2f207634..42997a96 100644 --- a/client/src/components/composite/Admin/AdminEventView/WrappedAdminEventView.tsx +++ b/client/src/components/composite/Admin/AdminEventView/WrappedAdminEventView.tsx @@ -3,9 +3,26 @@ import { useCreateEventMutation } from "@/services/Admin/AdminMutations" import AdminEventView from "./AdminEventView" import StorageService from "@/services/Storage/StorageService" +import { useLatestEventsQuery } from "@/services/Event/EventQueries" +import { useMemo } from "react" const WrappedAdminEventView = () => { const { mutateAsync: handleEventCreation } = useCreateEventMutation() + const { + data, + isPending, + hasNextPage, + isFetching, + fetchNextPage, + isFetchingNextPage + } = useLatestEventsQuery() + const rawEvents = useMemo(() => { + const flattenedEvents = data?.pages.flatMap((page) => { + return page.data || [] + }) + return flattenedEvents + }, [data]) + return ( <> { generateImageLink={async (image) => await StorageService.uploadEventImage(image) } + rawEvents={rawEvents || []} + hasMoreEvents={hasNextPage} + isLoading={isPending} + fetchMoreEvents={() => { + if (!isFetchingNextPage && !isFetching) { + fetchNextPage() + } + }} /> ) From 08156b34b73a3821a2707d7909db97ea36c92038 Mon Sep 17 00:00:00 2001 From: jeffplays2005 Date: Sun, 27 Oct 2024 21:56:48 +1300 Subject: [PATCH 04/10] Center event items --- .../composite/Admin/AdminEventView/AdminEventView.tsx | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/client/src/components/composite/Admin/AdminEventView/AdminEventView.tsx b/client/src/components/composite/Admin/AdminEventView/AdminEventView.tsx index 25d42a43..f5975c6a 100644 --- a/client/src/components/composite/Admin/AdminEventView/AdminEventView.tsx +++ b/client/src/components/composite/Admin/AdminEventView/AdminEventView.tsx @@ -115,7 +115,7 @@ const AdminEventView = ({ const [mode, setMode] = useState("view-all-events") return ( -
+

Events

From bac618d15daa2f4a6fb121cf4b81d9febc8278b2 Mon Sep 17 00:00:00 2001 From: jeffplays2005 Date: Sun, 27 Oct 2024 22:23:26 +1300 Subject: [PATCH 05/10] Create variant for EventPreview * Both regular and admin card * Regular is a thicker padding * Admin is a smaller padding --- .../AdminEventView/AdminAllEvents/AdminAllEvents.tsx | 6 ++++-- .../generic/Event/EventPreview/EventPreview.tsx | 11 ++++++++--- client/src/components/generic/Event/EventUtils.ts | 11 ++++++++--- 3 files changed, 20 insertions(+), 8 deletions(-) diff --git a/client/src/components/composite/Admin/AdminEventView/AdminAllEvents/AdminAllEvents.tsx b/client/src/components/composite/Admin/AdminEventView/AdminAllEvents/AdminAllEvents.tsx index 3dabbbe9..a3484dfe 100644 --- a/client/src/components/composite/Admin/AdminEventView/AdminAllEvents/AdminAllEvents.tsx +++ b/client/src/components/composite/Admin/AdminEventView/AdminAllEvents/AdminAllEvents.tsx @@ -200,7 +200,8 @@ const AdminAllEvents = ({ return EventRenderingUtils.previewTransformer( event, eventSelectionHandler, - "edit event" + "edit event", + "admin" ) }) || [] @@ -209,7 +210,8 @@ const AdminAllEvents = ({ return EventRenderingUtils.previewTransformer( event, eventSelectionHandler, - "edit event" + "edit event", + "admin" ) }) || [] diff --git a/client/src/components/generic/Event/EventPreview/EventPreview.tsx b/client/src/components/generic/Event/EventPreview/EventPreview.tsx index 333518f2..33094fdb 100644 --- a/client/src/components/generic/Event/EventPreview/EventPreview.tsx +++ b/client/src/components/generic/Event/EventPreview/EventPreview.tsx @@ -1,7 +1,7 @@ // 4 props: 3 string, 1 image import Image from "next/image" import Arrow from "@/assets/icons/rightarrow.svg" - +export type EventCardPreviewVariant = "regular" | "admin" /** * The interface (props) associated with {@link EventsCardPreview} */ @@ -37,6 +37,10 @@ export interface IEventsCardPreview { title: string viewButtonText?: string + /** + * The variant of the card to render + */ + variant?: EventCardPreviewVariant } type ViewButtonProps = { @@ -71,13 +75,14 @@ const EventsCardPreview = ({ image = "", signUpOpenDate, isPastEvent, - viewButtonText = "view more" + viewButtonText = "view more", + variant = "regular" }: IEventsCardPreview) => { return (
void, - buttonText?: string + buttonText?: string, + variant?: EventCardPreviewVariant = "default" ): IEventsCardPreview => { let eventStartDate @@ -116,7 +120,8 @@ export const EventRenderingUtils = { onClick: () => { eventSetter(event.id) }, - viewButtonText: buttonText + viewButtonText: buttonText, + variant } } } From 49b7d502443948a53b77e366e658407edc611553 Mon Sep 17 00:00:00 2001 From: jeffplays2005 Date: Sun, 27 Oct 2024 22:25:34 +1300 Subject: [PATCH 06/10] Remove unneeded test file --- .../Admin/AdminEventView/AdminAllEvents/AdminAllEvents.test.tsx | 0 client/src/components/generic/Event/EventUtils.ts | 2 +- 2 files changed, 1 insertion(+), 1 deletion(-) delete mode 100644 client/src/components/composite/Admin/AdminEventView/AdminAllEvents/AdminAllEvents.test.tsx diff --git a/client/src/components/composite/Admin/AdminEventView/AdminAllEvents/AdminAllEvents.test.tsx b/client/src/components/composite/Admin/AdminEventView/AdminAllEvents/AdminAllEvents.test.tsx deleted file mode 100644 index e69de29b..00000000 diff --git a/client/src/components/generic/Event/EventUtils.ts b/client/src/components/generic/Event/EventUtils.ts index 7cdd2af0..9af98ec3 100644 --- a/client/src/components/generic/Event/EventUtils.ts +++ b/client/src/components/generic/Event/EventUtils.ts @@ -83,7 +83,7 @@ export const EventRenderingUtils = { event: Event, eventSetter: (id?: string) => void, buttonText?: string, - variant?: EventCardPreviewVariant = "default" + variant?: EventCardPreviewVariant ): IEventsCardPreview => { let eventStartDate From 213d6a2c3b6a5e35390fc187b8b82f7026f7f8d6 Mon Sep 17 00:00:00 2001 From: jeffplays2005 Date: Sun, 27 Oct 2024 22:26:59 +1300 Subject: [PATCH 07/10] Document viewButtonText in EventPreview --- .../components/generic/Event/EventPreview/EventPreview.tsx | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/client/src/components/generic/Event/EventPreview/EventPreview.tsx b/client/src/components/generic/Event/EventPreview/EventPreview.tsx index 33094fdb..9c8762dd 100644 --- a/client/src/components/generic/Event/EventPreview/EventPreview.tsx +++ b/client/src/components/generic/Event/EventPreview/EventPreview.tsx @@ -35,7 +35,9 @@ export interface IEventsCardPreview { * Headline of the preview - generally is the title of the event */ title: string - + /** + * The text to display on the view button + */ viewButtonText?: string /** * The variant of the card to render From 7a6ca90bce4e6ffa16d6a45d4885ad111c9305f7 Mon Sep 17 00:00:00 2001 From: jeffplays2005 Date: Sun, 27 Oct 2024 22:32:03 +1300 Subject: [PATCH 08/10] Update comment for AdminEventView * Also remove `relative` from ReusableButtons as already exists --- .../Admin/AdminEventView/AdminEventView.tsx | 2 +- .../generic/ReusableButtons/Button.tsx | 124 +++++++++--------- 2 files changed, 63 insertions(+), 63 deletions(-) diff --git a/client/src/components/composite/Admin/AdminEventView/AdminEventView.tsx b/client/src/components/composite/Admin/AdminEventView/AdminEventView.tsx index f5975c6a..4bbcf948 100644 --- a/client/src/components/composite/Admin/AdminEventView/AdminEventView.tsx +++ b/client/src/components/composite/Admin/AdminEventView/AdminEventView.tsx @@ -26,7 +26,7 @@ interface IAdminEventView { * A list of _all_ {@link Event}s which should either be mocked * or fetched from the backend. **NO** pre-processing should be * performed on this list as it will be further mutated in the - * {@link EventsPage} component. + * {@link AdminEventViewContent} component. */ rawEvents?: Event[] diff --git a/client/src/components/generic/ReusableButtons/Button.tsx b/client/src/components/generic/ReusableButtons/Button.tsx index 418a5328..aaf3803d 100644 --- a/client/src/components/generic/ReusableButtons/Button.tsx +++ b/client/src/components/generic/ReusableButtons/Button.tsx @@ -10,27 +10,27 @@ const V1 = ({ children, props }: props) => {