diff --git a/test/utils/prohibitorySigns/withMapContext.tsx b/test/utils/prohibitorySigns/withMapContext.tsx
index 402e8038..3a92f82c 100644
--- a/test/utils/prohibitorySigns/withMapContext.tsx
+++ b/test/utils/prohibitorySigns/withMapContext.tsx
@@ -27,6 +27,7 @@ export const withMapContext = (component: ReactNode, mapContextProps?: Partial
+ {/* @ts-ignore */}
{component}
From 071d072bde9076683b11a66e862f3d073a118781 Mon Sep 17 00:00:00 2001
From: Ruben Sibon
Date: Wed, 6 Mar 2024 17:05:03 +0100
Subject: [PATCH 8/9] build(pkgs): :package: update yarn.lock
---
yarn.lock | 16 ++++++++--------
1 file changed, 8 insertions(+), 8 deletions(-)
diff --git a/yarn.lock b/yarn.lock
index fe26aaab..4c3a5aac 100644
--- a/yarn.lock
+++ b/yarn.lock
@@ -2208,7 +2208,7 @@
lz-string "^1.5.0"
pretty-format "^27.0.2"
-"@testing-library/jest-dom@^6.4.1":
+"@testing-library/jest-dom@^6.4.2":
version "6.4.2"
resolved "https://registry.yarnpkg.com/@testing-library/jest-dom/-/jest-dom-6.4.2.tgz#38949f6b63722900e2d75ba3c6d9bf8cffb3300e"
integrity sha512-CzqH0AFymEMG48CpzXFriYYkOjk6ZGPCLMhW9e9jg3KMCn5OfJecF8GtGW7yGfR/IgCe3SX8BSwjdzI6BBbZLw==
@@ -2537,7 +2537,7 @@
resolved "https://registry.yarnpkg.com/@types/node/-/node-20.5.1.tgz#178d58ee7e4834152b0e8b4d30cbfab578b9bb30"
integrity sha512-4tT2UrL5LBqDwoed9wZ6N3umC4Yhz3W3FloMmiiG4JwmUJWpie0c7lcnUNd4gtMKuDEO4wRVS8B6Xa0uMRsMKg==
-"@types/node@^18.19.12":
+"@types/node@^18.19.21":
version "18.19.21"
resolved "https://registry.yarnpkg.com/@types/node/-/node-18.19.21.tgz#f4ca1ac8ffb05ee4b89163c2d6fac9a1a59ee149"
integrity sha512-2Q2NeB6BmiTFQi4DHBzncSoq/cJMLDdhPaAoJFnFCyD9a8VPZRf7a1GAwp1Edb7ROaZc5Jz/tnZyL6EsWMRaqw==
@@ -5224,7 +5224,7 @@ eslint-webpack-plugin@^3.1.1:
normalize-path "^3.0.0"
schema-utils "^4.0.0"
-eslint@^8.3.0, eslint@^8.56.0:
+eslint@^8.3.0, eslint@^8.57.0:
version "8.57.0"
resolved "https://registry.yarnpkg.com/eslint/-/eslint-8.57.0.tgz#c786a6fd0e0b68941aaf624596fb987089195668"
integrity sha512-dZ6+mexnaTIbSBZWgou51U6OmzIhYM2VcNdtiTtI7qPNZm35Akpr0f6vtw3w1Kmn5PYo+tZVfh13WrhpS6oLqQ==
@@ -6066,7 +6066,7 @@ html-parse-stringify@^3.0.1:
dependencies:
void-elements "3.1.0"
-html-react-parser@^5.1.1:
+html-react-parser@^5.1.8:
version "5.1.8"
resolved "https://registry.yarnpkg.com/html-react-parser/-/html-react-parser-5.1.8.tgz#b8a294854845bce96627aa4f2ba738362c0ebcf8"
integrity sha512-oAXgUB4JYHFg4le3RQZtoge1TGMkwXSZPiWiexwdx3AuldgG+QEvbwMrscSViu90JNje3V4Zq5gCUSoTxa0W0A==
@@ -6197,7 +6197,7 @@ i18next-browser-languagedetector@^7.2.0:
dependencies:
"@babel/runtime" "^7.23.2"
-i18next@^23.8.2:
+i18next@^23.10.0:
version "23.10.0"
resolved "https://registry.yarnpkg.com/i18next/-/i18next-23.10.0.tgz#fb328794ae692e6fdde0564259e421f4203c4a2c"
integrity sha512-/TgHOqsa7/9abUKJjdPeydoyDc0oTi/7u9F8lMSj6ufg4cbC1Oj3f/Jja7zj7WRIhEQKB7Q4eN6y68I9RDxxGQ==
@@ -9279,7 +9279,7 @@ react-error-overlay@^6.0.11:
resolved "https://registry.yarnpkg.com/react-error-overlay/-/react-error-overlay-6.0.11.tgz#92835de5841c5cf08ba00ddd2d677b6d17ff9adb"
integrity sha512-/6UZ2qgEyH2aqzYZgQPxEnz33NJ2gNsnHA2o5+o4wW9bLM/JYQitNP9xPhsXwC08hMMovfGe/8retsdDsczPRg==
-react-hook-form@^7.49.3:
+react-hook-form@^7.50.1:
version "7.51.0"
resolved "https://registry.yarnpkg.com/react-hook-form/-/react-hook-form-7.51.0.tgz#757ae71b37c26e00590bd3788508287dcc5ecdaf"
integrity sha512-BggOy5j58RdhdMzzRUHGOYhSz1oeylFAv6jUSG86OvCIvlAvS7KvnRY7yoAf2pfEiPN7BesnR0xx73nEk3qIiw==
@@ -9317,7 +9317,7 @@ react-refresh@^0.11.0:
resolved "https://registry.yarnpkg.com/react-refresh/-/react-refresh-0.11.0.tgz#77198b944733f0f1f1a90e791de4541f9f074046"
integrity sha512-F27qZr8uUqwhWZboondsPx8tnC3Ct3SxZA3V5WyEvujRyyNv0VYPhoBg1gZ8/MV5tubQp76Trw8lTv9hzRBa+A==
-react-router-dom@^6.21.3:
+react-router-dom@^6.22.2:
version "6.22.2"
resolved "https://registry.yarnpkg.com/react-router-dom/-/react-router-dom-6.22.2.tgz#8233968a8a576f3006e5549c80f3527d2598fc9c"
integrity sha512-WgqxD2qySEIBPZ3w0sHH+PUAiamDeszls9tzqMPBDA1YYVucTBXLU7+gtRfcSnhe92A3glPnvSxK2dhNoAVOIQ==
@@ -9325,7 +9325,7 @@ react-router-dom@^6.21.3:
"@remix-run/router" "1.15.2"
react-router "6.22.2"
-react-router@6.22.2, react-router@^6.21.3:
+react-router@6.22.2, react-router@^6.22.2:
version "6.22.2"
resolved "https://registry.yarnpkg.com/react-router/-/react-router-6.22.2.tgz#27e77e4c635a5697693b922d131d773451c98a5b"
integrity sha512-YD3Dzprzpcq+tBMHBS822tCjnWD3iIZbTeSXMY9LPSG541EfoBGyZ3bS25KEnaZjLcmQpw2AVLkFyfgXY8uvcw==
From 5409664bc3a75b09d02d994a9f3f859749a102be Mon Sep 17 00:00:00 2001
From: Ruben Sibon
Date: Wed, 6 Mar 2024 17:36:34 +0100
Subject: [PATCH 9/9] fix(tour): :safety_vest: add some guards for messages
---
.../components/LocationsList/index.tsx | 1 +
.../components/MapLayers/MessagesLayer.tsx | 31 +++++++++++++------
.../components/Messages/MessagesList.tsx | 7 ++++-
3 files changed, 29 insertions(+), 10 deletions(-)
diff --git a/src/pages/Touringcar/components/LocationsList/index.tsx b/src/pages/Touringcar/components/LocationsList/index.tsx
index f48a0b87..af9cde35 100644
--- a/src/pages/Touringcar/components/LocationsList/index.tsx
+++ b/src/pages/Touringcar/components/LocationsList/index.tsx
@@ -57,6 +57,7 @@ function LocationsList({ locationItems }: { locationItems: TouringcarStop[] }) {
{
+ if (!feature?.geometry?.coordinates?.[0]) return
mapInstance.flyTo([feature.geometry.coordinates[1], feature.geometry.coordinates[0]], 20)
}}
>
diff --git a/src/pages/Touringcar/components/MapLayers/MessagesLayer.tsx b/src/pages/Touringcar/components/MapLayers/MessagesLayer.tsx
index 95a80c17..a39588f2 100644
--- a/src/pages/Touringcar/components/MapLayers/MessagesLayer.tsx
+++ b/src/pages/Touringcar/components/MapLayers/MessagesLayer.tsx
@@ -17,7 +17,13 @@ export const MessagesLayer = () => {
const { activeMapLayers, messagesDate, setCurrentMessage, setActiveTab } = useTouringcarMapContext()
const { setPositionFromSnapPoint } = useContext(MapPanelContext)
- const { isLoading, error, isError, data, refetch } = useQuery({
+ const {
+ isLoading,
+ error,
+ isError,
+ data: messages,
+ refetch,
+ } = useQuery({
enabled: true,
queryKey: ['touringcarMessages'],
queryFn: () =>
@@ -30,24 +36,31 @@ export const MessagesLayer = () => {
const findMessage = useCallback(
(title: string) => {
- if (!data) return
- const message: TouringcarMessage | undefined = data.features.find(
- msg => msg?.properties[(i18n.language || 'nl') as Language].title === title
+ if (!messages) return
+
+ console.log('Messages data:', messages)
+
+ const message: TouringcarMessage | undefined = messages.features.find(
+ msg => msg?.properties[(i18n.language ?? 'nl') as Language].title === title
)
+
+ console.log('Found message to be set:', message)
+
setCurrentMessage(message)
},
- [data, setCurrentMessage]
+ [messages, setCurrentMessage]
)
const createClusterMarkers = () => {
- return data!.features.map((message: TouringcarMessage) => {
+ // Messages should be available once createClusterMarkers is called.
+ return messages!.features.map((message: TouringcarMessage) => {
const marker = TouringcarMarker(message, MapLayerId.touringcarMessagesLayerId)
const msgParts = message.properties[(i18n.language || 'nl') as Language]
let tooltipText = `${msgParts.title}
- ${msgParts.body ?? `${msgParts.body}
`}
- ${msgParts.advice ?? `Advies: ${msgParts.advice}
`}`
+${msgParts.body ?? `${msgParts.body}
`}
+${msgParts.advice ?? `Advies: ${msgParts.advice}
`}`
marker.bindTooltip(tooltipText)
@@ -62,7 +75,7 @@ export const MessagesLayer = () => {
}
if (isError && error instanceof Error) console.error(error.message)
- if (isLoading || !data) return null
+ if (isLoading || !messages) return null
if (!activeMapLayers[MapLayerId.touringcarMessagesLayerId]) return null
return (
diff --git a/src/pages/Touringcar/components/Messages/MessagesList.tsx b/src/pages/Touringcar/components/Messages/MessagesList.tsx
index b3549a25..4dc088d8 100644
--- a/src/pages/Touringcar/components/Messages/MessagesList.tsx
+++ b/src/pages/Touringcar/components/Messages/MessagesList.tsx
@@ -62,7 +62,12 @@ function MessagesList() {
>
{
+ inlist
+ onClick={({ preventDefault }) => {
+ preventDefault()
+
+ if (!message?.geometry?.coordinates?.[0]) return
+
mapInstance.flyTo([message.geometry.coordinates[1], message.geometry.coordinates[0]], 20)
}}
>