From 079f3704d464710e5440e81f3dbe29fbe8836e0e Mon Sep 17 00:00:00 2001 From: Mitchell McCaffrey Date: Sun, 26 Apr 2020 19:45:36 +1000 Subject: [PATCH] Fix performance issues with settings map name change --- src/components/map/MapSettings.js | 27 ++++++++++++++++++++++++--- 1 file changed, 24 insertions(+), 3 deletions(-) diff --git a/src/components/map/MapSettings.js b/src/components/map/MapSettings.js index 77df2a6..2ad0412 100644 --- a/src/components/map/MapSettings.js +++ b/src/components/map/MapSettings.js @@ -1,8 +1,11 @@ -import React from "react"; +import React, { useEffect, useState } from "react"; import { Flex, Box, Label, Input, Checkbox, IconButton } from "theme-ui"; import ExpandMoreIcon from "../../icons/ExpandMoreIcon"; +import useDebounce from "../../helpers/useDebounce"; +import usePrevious from "../../helpers/usePrevious"; + function MapSettings({ map, mapState, @@ -21,6 +24,24 @@ function MapSettings({ ); } } + + // Create a local state for the map name to debounce calls to settings change + // and avoid performance issues with db access + const [localMapName, setLocalMapName] = useState(""); + const prevMap = usePrevious(map); + useEffect(() => { + // Check map changed + if (map && (!prevMap || map.id !== prevMap.id)) { + setLocalMapName(map.name); + } + }, [map]); + const debouncedLocalMapName = useDebounce(localMapName, 100); + useEffect(() => { + if (map) { + onSettingsChange("name", debouncedLocalMapName); + } + }, [debouncedLocalMapName]); + return ( @@ -94,8 +115,8 @@ function MapSettings({ onSettingsChange("name", e.target.value)} + value={localMapName} + onChange={(e) => setLocalMapName(e.target.value)} disabled={map === null || map.type === "default"} my={1} />