feat: Persist checkbox states in localStorage to retain settings after page reload
- Implemented logic to save the visibility states of POI and map layers in localStorage. - Loaded saved checkbox states on component mount to retain user preferences. - Updated `handleCheckboxChange` and `handlePoiCheckboxChange` to store changes in localStorage. - Ensured that settings persist across page reloads for a better user experience.
This commit is contained in:
@@ -18,6 +18,18 @@ function DataSheet() {
|
|||||||
const GisSystemStatic = useRecoilValue(gisSystemStaticState);
|
const GisSystemStatic = useRecoilValue(gisSystemStaticState);
|
||||||
const setZoomTrigger = useSetRecoilState(zoomTriggerState);
|
const setZoomTrigger = useSetRecoilState(zoomTriggerState);
|
||||||
|
|
||||||
|
useEffect(() => {
|
||||||
|
const storedPoiVisible = localStorage.getItem("poiVisible");
|
||||||
|
if (storedPoiVisible !== null) {
|
||||||
|
setPoiVisible(storedPoiVisible === "true");
|
||||||
|
}
|
||||||
|
|
||||||
|
const storedMapLayersVisibility = localStorage.getItem("mapLayersVisibility");
|
||||||
|
if (storedMapLayersVisibility) {
|
||||||
|
setMapLayersVisibility(JSON.parse(storedMapLayersVisibility));
|
||||||
|
}
|
||||||
|
}, [setPoiVisible, setMapLayersVisibility]);
|
||||||
|
|
||||||
const handleAreaChange = (event) => {
|
const handleAreaChange = (event) => {
|
||||||
const selectedIndex = event.target.options.selectedIndex;
|
const selectedIndex = event.target.options.selectedIndex;
|
||||||
const areaName = event.target.options[selectedIndex].text;
|
const areaName = event.target.options[selectedIndex].text;
|
||||||
@@ -69,10 +81,17 @@ function DataSheet() {
|
|||||||
...prev,
|
...prev,
|
||||||
[name]: checked,
|
[name]: checked,
|
||||||
};
|
};
|
||||||
|
localStorage.setItem("mapLayersVisibility", JSON.stringify(newState)); // Store in localStorage
|
||||||
return newState;
|
return newState;
|
||||||
});
|
});
|
||||||
};
|
};
|
||||||
|
|
||||||
|
const handlePoiCheckboxChange = (event) => {
|
||||||
|
const { checked } = event.target;
|
||||||
|
setPoiVisible(checked);
|
||||||
|
localStorage.setItem("poiVisible", checked); // Store POI visibility in localStorage
|
||||||
|
};
|
||||||
|
|
||||||
const handleIconClick = () => {
|
const handleIconClick = () => {
|
||||||
setSelectedArea("Station wählen");
|
setSelectedArea("Station wählen");
|
||||||
setZoomTrigger((current) => current + 1);
|
setZoomTrigger((current) => current + 1);
|
||||||
@@ -104,15 +123,7 @@ function DataSheet() {
|
|||||||
<br />
|
<br />
|
||||||
</React.Fragment>
|
</React.Fragment>
|
||||||
))}
|
))}
|
||||||
<input
|
<input type="checkbox" checked={poiVisible} onChange={handlePoiCheckboxChange} id="poi-checkbox" />
|
||||||
type="checkbox"
|
|
||||||
checked={poiVisible}
|
|
||||||
onChange={(e) => {
|
|
||||||
const checked = e.target.checked;
|
|
||||||
setPoiVisible(checked);
|
|
||||||
}}
|
|
||||||
id="poi-checkbox"
|
|
||||||
/>
|
|
||||||
<label htmlFor="poi-checkbox" className="text-sm ml-2">
|
<label htmlFor="poi-checkbox" className="text-sm ml-2">
|
||||||
POIs
|
POIs
|
||||||
</label>
|
</label>
|
||||||
|
|||||||
@@ -16,6 +16,8 @@ const useLineData = (webserviceGisLinesStatusUrl, setLineStatusData) => {
|
|||||||
|
|
||||||
ws.onopen = () => {
|
ws.onopen = () => {
|
||||||
console.log("WebSocket-Verbindung hergestellt");
|
console.log("WebSocket-Verbindung hergestellt");
|
||||||
|
// Testnachricht an den Server senden
|
||||||
|
ws.send(JSON.stringify({ type: "test", message: "Hallo vom Client" }));
|
||||||
};
|
};
|
||||||
|
|
||||||
ws.onmessage = (event) => {
|
ws.onmessage = (event) => {
|
||||||
|
|||||||
@@ -7,8 +7,22 @@ wss.on("connection", (ws) => {
|
|||||||
console.log("New WebSocket connection");
|
console.log("New WebSocket connection");
|
||||||
|
|
||||||
ws.on("message", (message) => {
|
ws.on("message", (message) => {
|
||||||
console.log("Received:", message);
|
// Konvertiere den Buffer in einen String
|
||||||
ws.send(JSON.stringify({ message: "Hallo vom WebSocket-Server" }));
|
const messageString = message.toString();
|
||||||
|
|
||||||
|
console.log("Received:", messageString);
|
||||||
|
|
||||||
|
// Versuche die Nachricht in JSON zu parsen
|
||||||
|
try {
|
||||||
|
const parsedMessage = JSON.parse(messageString);
|
||||||
|
|
||||||
|
// Beispielnachricht an den Client zurücksenden
|
||||||
|
if (parsedMessage.type === "test") {
|
||||||
|
ws.send(JSON.stringify({ message: `Hallo zurück, ${parsedMessage.message}` }));
|
||||||
|
}
|
||||||
|
} catch (error) {
|
||||||
|
console.error("Fehler beim Parsen der Nachricht:", error);
|
||||||
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
ws.on("close", () => {
|
ws.on("close", () => {
|
||||||
|
|||||||
Reference in New Issue
Block a user