From c6cb5a8a305cd431f90b48cfeb6760e6bc743de2 Mon Sep 17 00:00:00 2001 From: Dalton Adcock Date: Tue, 16 Jan 2024 23:28:24 -0800 Subject: [PATCH 1/2] fixed custom event initial/change map load --- apps/antalmanac/src/components/Map/Map.tsx | 18 +++++++++++++++++- 1 file changed, 17 insertions(+), 1 deletion(-) diff --git a/apps/antalmanac/src/components/Map/Map.tsx b/apps/antalmanac/src/components/Map/Map.tsx index 569a740ec..f19689575 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(() => { @@ -167,6 +167,22 @@ export default function CourseMap() { }; }, []); + useEffect(() => { + const updateCustomEventMarkers = () => { + setCustomEventMarkers(getCustomEventPerBuilding()); + }; + + AppStore.on('customEventsChange', updateCustomEventMarkers); + AppStore.on('currentScheduleIndexChange', updateCustomEventMarkers); + AppStore.on('colorChange', updateCustomEventMarkers); + + return () => { + AppStore.removeListener('customEventsChange', updateCustomEventMarkers); + AppStore.removeListener('currentScheduleIndexChange', updateCustomEventMarkers); + AppStore.removeListener('colorChange', updateCustomEventMarkers); + }; + }, []); + useEffect(() => { const updateCalendarEvents = () => { setCalendarEvents(AppStore.getCourseEventsInCalendar()); From 22163e2e9e9ffbfe533477f235b5321e20f1252a Mon Sep 17 00:00:00 2001 From: Dalton Adcock Date: Wed, 17 Jan 2024 13:39:27 -0800 Subject: [PATCH 2/2] refactored custom event map load --- apps/antalmanac/src/components/Map/Map.tsx | 31 +++++++--------------- 1 file changed, 9 insertions(+), 22 deletions(-) diff --git a/apps/antalmanac/src/components/Map/Map.tsx b/apps/antalmanac/src/components/Map/Map.tsx index f19689575..377ab1aba 100644 --- a/apps/antalmanac/src/components/Map/Map.tsx +++ b/apps/antalmanac/src/components/Map/Map.tsx @@ -152,34 +152,21 @@ export default function CourseMap() { const [calendarEvents, setCalendarEvents] = useState(AppStore.getCourseEventsInCalendar()); useEffect(() => { - const updateMarkers = () => { + const updateAllMarkers = () => { setMarkers(getCoursesPerBuilding()); - }; - - AppStore.on('addedCoursesChange', updateMarkers); - AppStore.on('currentScheduleIndexChange', updateMarkers); - AppStore.on('colorChange', updateMarkers); - - return () => { - AppStore.removeListener('addedCoursesChange', updateMarkers); - AppStore.removeListener('currentScheduleIndexChange', updateMarkers); - AppStore.removeListener('colorChange', updateMarkers); - }; - }, []); - - useEffect(() => { - const updateCustomEventMarkers = () => { setCustomEventMarkers(getCustomEventPerBuilding()); }; - AppStore.on('customEventsChange', updateCustomEventMarkers); - AppStore.on('currentScheduleIndexChange', updateCustomEventMarkers); - AppStore.on('colorChange', updateCustomEventMarkers); + AppStore.on('addedCoursesChange', updateAllMarkers); + AppStore.on('customEventsChange', updateAllMarkers); + AppStore.on('currentScheduleIndexChange', updateAllMarkers); + AppStore.on('colorChange', updateAllMarkers); return () => { - AppStore.removeListener('customEventsChange', updateCustomEventMarkers); - AppStore.removeListener('currentScheduleIndexChange', updateCustomEventMarkers); - AppStore.removeListener('colorChange', updateCustomEventMarkers); + AppStore.removeListener('addedCoursesChange', updateAllMarkers); + AppStore.removeListener('customEventsChange', updateAllMarkers); + AppStore.removeListener('currentScheduleIndexChange', updateAllMarkers); + AppStore.removeListener('colorChange', updateAllMarkers); }; }, []);