From 4f46803f5fa65b3ab34f22642d1c094cce8171f8 Mon Sep 17 00:00:00 2001 From: Junping Luo <53324036+JacE070@users.noreply.github.com> Date: Wed, 17 Jan 2024 12:25:21 -0800 Subject: [PATCH] Add custom event to the route (#853) --- apps/antalmanac/src/components/Map/Map.tsx | 36 ++++++++++++++-------- 1 file changed, 24 insertions(+), 12 deletions(-) diff --git a/apps/antalmanac/src/components/Map/Map.tsx b/apps/antalmanac/src/components/Map/Map.tsx index 04ae2505e..e074cd133 100644 --- a/apps/antalmanac/src/components/Map/Map.tsx +++ b/apps/antalmanac/src/components/Map/Map.tsx @@ -148,7 +148,7 @@ export default function CourseMap() { const [searchParams] = useSearchParams(); const [selectedDayIndex, setSelectedDay] = useState(0); const [markers, setMarkers] = useState(getCoursesPerBuilding()); - const [customEventMarkers] = useState(getCustomEventPerBuilding()); + const [customEventMarkers, setCustomEventMarkers] = useState(getCustomEventPerBuilding()); const [calendarEvents, setCalendarEvents] = useState(AppStore.getCourseEventsInCalendar()); useEffect(() => { @@ -181,6 +181,20 @@ export default function CourseMap() { }; }, []); + useEffect(() => { + const updateCustomEventMarkers = () => { + setCustomEventMarkers(getCustomEventPerBuilding()); + }; + + AppStore.on('customEventsChange', updateCustomEventMarkers); + AppStore.on('currentScheduleIndexChange', updateCustomEventMarkers); + + return () => { + AppStore.removeListener('customEventsChange', updateCustomEventMarkers); + AppStore.removeListener('currentScheduleIndexChange', updateCustomEventMarkers); + }; + }, []); + useEffect(() => { const locationID = Number(searchParams.get('location') ?? 0); const building = locationID in buildingCatalogue ? buildingCatalogue[locationID] : undefined; @@ -274,17 +288,15 @@ export default function CourseMap() { * Every two markers grouped as [start, destination] tuples for the routes. */ const startDestPairs = useMemo(() => { - return markersToDisplay.reduce( - (acc, cur, index) => { - acc.push([cur]); - if (index > 0) { - acc[index - 1].push(cur); - } - return acc; - }, - [] as (typeof markersToDisplay)[] - ); - }, [markersToDisplay]); + const allEvents = [...markersToDisplay, ...customEventMarkersToDisplay]; + return allEvents.reduce((acc, cur, index) => { + acc.push([cur]); + if (index > 0) { + acc[index - 1].push(cur); + } + return acc; + }, [] as (typeof allEvents)[]); + }, [markersToDisplay, customEventMarkersToDisplay]); return (