Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Shattering #84

Merged
merged 118 commits into from
Oct 16, 2024
Merged
Show file tree
Hide file tree
Changes from 1 commit
Commits
Show all changes
118 commits
Select commit Hold shift + click to select a range
50dd897
refactor out tiles for now
raphaellaude Sep 9, 2024
6d81538
shattering models
raphaellaude Sep 9, 2024
d91b544
parent child procedure and management commands
raphaellaude Sep 9, 2024
e76a9e1
clean up cli
raphaellaude Sep 10, 2024
05ad503
start testing cli
raphaellaude Sep 13, 2024
507ab52
show cli coverage too
raphaellaude Sep 13, 2024
98b87ea
reorg args and allow for child layer to be null
raphaellaude Sep 13, 2024
aeb6ae3
materialize unioned gerrydb views
raphaellaude Sep 13, 2024
8cc7fc0
refactor districtmap to use only gerrydb table names rather than uuids
raphaellaude Sep 14, 2024
ae5397b
fix tests
raphaellaude Sep 14, 2024
b43b1e5
update procedures and udf api
raphaellaude Sep 15, 2024
feb30c2
fix silly issue
raphaellaude Sep 15, 2024
b6ca1d6
getting close
raphaellaude Sep 15, 2024
324266d
fix by just forcing gerrydb table name in districtrmap to be unique
raphaellaude Sep 16, 2024
23ffe27
Add event listener, context menu information in store
nofurtherinformation Sep 19, 2024
7e599df
Draft Context Menu component
nofurtherinformation Sep 19, 2024
1e44fe1
update models to match
raphaellaude Sep 20, 2024
1c7e129
partition parent child edges on districtrmap
raphaellaude Sep 20, 2024
6ce61f7
move tileset commands to pipelines
raphaellaude Sep 21, 2024
3e4036b
begin to refactor fe
raphaellaude Sep 23, 2024
e50387c
add blocks if there is a live document
raphaellaude Sep 23, 2024
4b07a6a
paint on startup
raphaellaude Sep 23, 2024
ed75eb0
use context menu from themes
raphaellaude Sep 23, 2024
d5b9f04
clean up
raphaellaude Sep 23, 2024
58335f7
progress on fixing tests
raphaellaude Sep 23, 2024
b6f8db7
passing tests
raphaellaude Sep 23, 2024
65672eb
SHATTERING ON THE FE
raphaellaude Sep 23, 2024
d6b0d39
send parents back
raphaellaude Sep 23, 2024
e5530bb
making progress
raphaellaude Sep 23, 2024
33b7692
document how to set up shatterable districtr maps
raphaellaude Sep 24, 2024
6af1bb5
Docker compose config and data load script (#88)
nofurtherinformation Sep 23, 2024
937874e
Add shatter IDs to store, subscribe and mutate map
nofurtherinformation Sep 24, 2024
d79cb20
Add parent/child layer rendering
nofurtherinformation Sep 24, 2024
fb1d9e4
Add shatter state change to context menu
nofurtherinformation Sep 24, 2024
feffb61
clean up layers
nofurtherinformation Sep 24, 2024
790fb23
Cleanup log
nofurtherinformation Sep 24, 2024
f807f1a
cleanup unused source id
nofurtherinformation Sep 24, 2024
b9a39c8
remove boolean parameter
raphaellaude Sep 25, 2024
5ce9c1d
Refactor zustand accessors
nofurtherinformation Sep 25, 2024
d9c2422
Additional zustand accessor refactor
nofurtherinformation Sep 25, 2024
3694115
refactor zustand state accessors - map
nofurtherinformation Sep 25, 2024
86209b3
Add events to child layers
nofurtherinformation Sep 25, 2024
0719df0
Refactor hover state to store
nofurtherinformation Sep 25, 2024
6a26d4a
Refactor map zone assignment rendering to mapStore
nofurtherinformation Sep 25, 2024
55deda4
Clean up hover events
nofurtherinformation Sep 25, 2024
67c09fe
Enhance set shatter Ids
nofurtherinformation Sep 25, 2024
7bfca34
Child layer interactivity and zone assignment cleanup
nofurtherinformation Sep 25, 2024
c5ded83
Update mapStore.ts
nofurtherinformation Sep 25, 2024
3a1a8b4
Performance - clean up when zone assignments run
nofurtherinformation Sep 25, 2024
96312e6
Optimize zone assignments rendering logic
nofurtherinformation Sep 26, 2024
dcd74a7
Add map lock on shatter
nofurtherinformation Sep 26, 2024
0261d28
Style fix for map container
nofurtherinformation Sep 26, 2024
d712ab0
fix layer order
nofurtherinformation Sep 26, 2024
53f781c
clean up shatter events to remove parents
nofurtherinformation Sep 26, 2024
3e92c2c
Return parent path with assignments
nofurtherinformation Sep 30, 2024
9a7c791
Load shatter IDs into state on document load
nofurtherinformation Sep 30, 2024
d32bcdf
Also return parents
nofurtherinformation Sep 30, 2024
c9f3742
Formatting
nofurtherinformation Sep 30, 2024
0aae53a
Shatter assignment bug fix
nofurtherinformation Sep 30, 2024
83da9b3
Fix remove layer order
nofurtherinformation Sep 30, 2024
e35da2e
Only allow context menu on pan
nofurtherinformation Sep 30, 2024
4dd026b
Clean up map updates
nofurtherinformation Oct 1, 2024
3993be4
Revert color while painting
nofurtherinformation Oct 2, 2024
485f25a
reorganize mutations, queries
nofurtherinformation Oct 2, 2024
e16b5f0
reorganize subscriptions
nofurtherinformation Oct 2, 2024
fc2eb90
Remove mutation logic from components
nofurtherinformation Oct 2, 2024
44e2d08
move to global query client
nofurtherinformation Oct 2, 2024
6249070
update layers and helpers to track rendering state
nofurtherinformation Oct 2, 2024
1f451fe
clean up
nofurtherinformation Oct 2, 2024
770f2b2
clean up
nofurtherinformation Oct 2, 2024
987fc85
nextjs type safety
nofurtherinformation Oct 2, 2024
367da46
Remove tracking map rendering state
nofurtherinformation Oct 2, 2024
145e78e
Revert "Remove tracking map rendering state"
nofurtherinformation Oct 2, 2024
b09e265
Add where condition for districtr map uuid
nofurtherinformation Oct 3, 2024
64be91d
materialized view should actually use column data
raphaellaude Oct 8, 2024
989919d
try using specific python version
raphaellaude Oct 8, 2024
5e6cb7d
Subscribe shatter filters to mapRenderingState
nofurtherinformation Oct 8, 2024
24801ef
clean up subscriptions and filtering
nofurtherinformation Oct 8, 2024
e43cc92
merge main backend app changes
raphaellaude Oct 9, 2024
a0832d4
sort out alembic history
raphaellaude Oct 9, 2024
746955e
Merge branch 'main' into shattering
nofurtherinformation Oct 9, 2024
a00b9d3
ruff
nofurtherinformation Oct 9, 2024
bfe6f53
update load data script
nofurtherinformation Oct 9, 2024
8bcb1db
Zone can be none after erased
nofurtherinformation Oct 9, 2024
bc8241b
erase events cleanup (on mouse move)
nofurtherinformation Oct 9, 2024
911ecbd
Add paintable IDs and bbox to state on shatter
nofurtherinformation Oct 9, 2024
b4495bd
change map fill opacity on shatter, helper
nofurtherinformation Oct 9, 2024
f6bd236
query features filtered to captive ids
nofurtherinformation Oct 9, 2024
c90cc5e
add exit shatter view
nofurtherinformation Oct 9, 2024
533952d
turf bbox
nofurtherinformation Oct 9, 2024
e742977
refactor handleShatter to features, not IDs
nofurtherinformation Oct 9, 2024
93639d5
Only paint/select parents when not shattered
nofurtherinformation Oct 9, 2024
33da1a0
wip dive back in to shattered
nofurtherinformation Oct 9, 2024
ab2e2d8
clean up
nofurtherinformation Oct 9, 2024
88b8cfe
remove children when painting
nofurtherinformation Oct 9, 2024
5b4cc31
Revert "remove children when painting"
nofurtherinformation Oct 9, 2024
18d1691
Revert "clean up"
nofurtherinformation Oct 9, 2024
248247b
Revert "wip dive back in to shattered"
nofurtherinformation Oct 9, 2024
8670d72
Revert "Only paint/select parents when not shattered"
nofurtherinformation Oct 9, 2024
d8d553b
Revert "refactor handleShatter to features, not IDs"
nofurtherinformation Oct 9, 2024
b22393d
Revert "turf bbox"
nofurtherinformation Oct 9, 2024
5467492
Revert "add exit shatter view"
nofurtherinformation Oct 9, 2024
c5b39de
Revert "query features filtered to captive ids"
nofurtherinformation Oct 9, 2024
a21a89e
Revert "change map fill opacity on shatter, helper"
nofurtherinformation Oct 9, 2024
2dac210
Revert "Add paintable IDs and bbox to state on shatter"
nofurtherinformation Oct 9, 2024
1bccead
update script
raphaellaude Oct 10, 2024
e830ef1
handle non shattering maps
raphaellaude Oct 10, 2024
9f01d14
disable shattering if no child layer
raphaellaude Oct 10, 2024
5e9ef4d
optionals
raphaellaude Oct 10, 2024
03d365d
ssr safety
nofurtherinformation Oct 10, 2024
a1302cc
Clear state on create document
nofurtherinformation Oct 10, 2024
1bc972c
swap .union for new set
nofurtherinformation Oct 10, 2024
7bbfa55
missing brackets
nofurtherinformation Oct 11, 2024
1c85564
make load data script better for future refactor
nofurtherinformation Oct 14, 2024
58a2e38
ruff
nofurtherinformation Oct 15, 2024
378da62
UDF Fix for shattering null parents
nofurtherinformation Oct 15, 2024
3ee9595
Swap onClick for onSelect
nofurtherinformation Oct 15, 2024
a1c7de2
Bump limit to 30
nofurtherinformation Oct 15, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
handle non shattering maps
  • Loading branch information
raphaellaude committed Oct 10, 2024
commit e830ef1b4aff78bd13ab7201086fef7649733730
23 changes: 14 additions & 9 deletions app/src/app/store/mapRenderSubs.ts
Original file line number Diff line number Diff line change
Expand Up @@ -9,7 +9,6 @@ import {
import {
ColorZoneAssignmentsState,
colorZoneAssignments,
getMap,
shallowCompareArray,
} from "../utils/helpers";
import { useMapStore as _useMapStore, MapStore } from "./mapStore";
Expand All @@ -26,29 +25,35 @@ export const getRenderSubscriptions = (useMapStore: typeof _useMapStore) => {
mapStore.addVisibleLayerIds([BLOCK_LAYER_ID, BLOCK_HOVER_LAYER_ID]);
}
},
{ equalityFn: shallowCompareArray }
{ equalityFn: shallowCompareArray },
);

const _shatterMapSideEffectRender = useMapStore.subscribe<[MapStore['shatterIds'], MapStore['mapRef'], MapStore['mapRenderingState']]>(
const _shatterMapSideEffectRender = useMapStore.subscribe<
[MapStore["shatterIds"], MapStore["mapRef"], MapStore["mapRenderingState"]]
>(
(state) => [state.shatterIds, state.mapRef, state.mapRenderingState],
([shatterIds, mapRef, mapRenderingState]) => {
const state = useMapStore.getState();
const setMapLock = state.setMapLock;

if (!mapRef?.current || mapRenderingState !== 'loaded') {
if (!mapRef?.current || mapRenderingState !== "loaded") {
return;
}

[...PARENT_LAYERS, ...CHILD_LAYERS].forEach((layerId) =>
mapRef.current?.setFilter(layerId, getLayerFilter(layerId, shatterIds))
const layersToFilter = PARENT_LAYERS;

if (state.mapDocument?.child_layer) layersToFilter.push(...CHILD_LAYERS);

layersToFilter.forEach((layerId) =>
mapRef.current?.setFilter(layerId, getLayerFilter(layerId, shatterIds)),
);

mapRef.current.once("render", () => {
setMapLock(false);
console.log(`Unlocked at`, performance.now());
});
},
{ equalityFn: shallowCompareArray }
{ equalityFn: shallowCompareArray },
);

const _hoverMapSideEffectRender = useMapStore.subscribe(
Expand All @@ -67,7 +72,7 @@ export const getRenderSubscriptions = (useMapStore: typeof _useMapStore) => {
hoverFeatures.forEach((feature) => {
mapRef.current?.setFeatureState(feature, { hover: true });
});
}
},
);

const _zoneAssignmentMapSideEffectRender =
Expand All @@ -81,7 +86,7 @@ export const getRenderSubscriptions = (useMapStore: typeof _useMapStore) => {
state.mapRenderingState,
],
(curr, prev) => colorZoneAssignments(curr, prev),
{ equalityFn: shallowCompareArray }
{ equalityFn: shallowCompareArray },
);

return [
Expand Down
80 changes: 52 additions & 28 deletions app/src/app/utils/events/mapEvents.ts
Original file line number Diff line number Diff line change
Expand Up @@ -7,31 +7,51 @@ import type {
MapLayerMouseEvent,
MapLayerTouchEvent,
} from "maplibre-gl";
import { useMapStore } from "@/app/store/mapStore";
import { useMapStore } from "@store/mapStore";
import { MutableRefObject } from "react";
import { SelectMapFeatures, SelectZoneAssignmentFeatures } from "./handlers";
import { ResetMapSelectState } from "@/app/utils/events/handlers";
import { INTERACTIVE_LAYERS } from "@/app/constants/layers";
import { ResetMapSelectState } from "@utils/events/handlers";
import {
INTERACTIVE_LAYERS,
BLOCK_HOVER_LAYER_ID,
BLOCK_LAYER_ID,
BLOCK_LAYER_ID_CHILD,
} from "@constants/layers";

/*
MapEvent handling; these functions are called by the event listeners in the MapComponent
*/

/**

*/
function getLayerIdsToPaint(child_layer: string | undefined | null) {
return child_layer
? [BLOCK_LAYER_ID, BLOCK_LAYER_ID_CHILD]
: [BLOCK_LAYER_ID];
}

/**
* What happens when the map is clicked on; incomplete implementation
* @param e - MapLayerMouseEvent | MapLayerTouchEvent, the event object
* @param map - MutableRefObject<Map | null>, the maplibre map instance
*/
export const handleMapClick = (
e: MapLayerMouseEvent | MapLayerTouchEvent,
map: MutableRefObject<MapLibreMap | null>
map: MutableRefObject<MapLibreMap | null>,
) => {
const mapStore = useMapStore.getState();
const activeTool = mapStore.activeTool;
const sourceLayer = mapStore.mapDocument?.parent_layer;

if (activeTool === "brush" || activeTool === "eraser") {
const selectedFeatures = mapStore.paintFunction(map, e, mapStore.brushSize);
const paintLayers = getLayerIdsToPaint(mapStore.mapDocument?.child_layer);
const selectedFeatures = mapStore.paintFunction(
map,
e,
mapStore.brushSize,
paintLayers,
);

if (sourceLayer) {
// select on both the map object and the store
Expand All @@ -46,7 +66,7 @@ export const handleMapClick = (

export const handleMapMouseUp = (
e: MapLayerMouseEvent | MapLayerTouchEvent,
map: MutableRefObject<MapLibreMap | null>
map: MutableRefObject<MapLibreMap | null>,
) => {
const mapStore = useMapStore.getState();
const activeTool = mapStore.activeTool;
Expand All @@ -61,7 +81,7 @@ export const handleMapMouseUp = (

export const handleMapMouseDown = (
e: MapLayerMouseEvent | MapLayerTouchEvent,
map: MutableRefObject<MapLibreMap | null>
map: MutableRefObject<MapLibreMap | null>,
) => {
const mapStore = useMapStore.getState();
const activeTool = mapStore.activeTool;
Expand All @@ -78,17 +98,17 @@ export const handleMapMouseDown = (

export const handleMapMouseEnter = (
e: MapLayerMouseEvent | MapLayerTouchEvent,
map: MutableRefObject<MapLibreMap | null>
map: MutableRefObject<MapLibreMap | null>,
) => {};

export const handleMapMouseOver = (
e: MapLayerMouseEvent | MapLayerTouchEvent,
map: MutableRefObject<MapLibreMap | null>
map: MutableRefObject<MapLibreMap | null>,
) => {};

export const handleMapMouseLeave = (
e: MapLayerMouseEvent | MapLayerTouchEvent,
map: MutableRefObject<MapLibreMap | null>
map: MutableRefObject<MapLibreMap | null>,
) => {
const mapStore = useMapStore.getState();
const activeTool = mapStore.activeTool;
Expand All @@ -99,21 +119,27 @@ export const handleMapMouseLeave = (

export const handleMapMouseOut = (
e: MapLayerMouseEvent | MapLayerTouchEvent,
map: MutableRefObject<MapLibreMap | null>
) => {
};
map: MutableRefObject<MapLibreMap | null>,
) => {};

export const handleMapMouseMove = (
e: MapLayerMouseEvent | MapLayerTouchEvent,
map: MutableRefObject<MapLibreMap | null>
map: MutableRefObject<MapLibreMap | null>,
) => {
const mapStore = useMapStore.getState();
const activeTool = mapStore.activeTool;
const setHoverFeatures = mapStore.setHoverFeatures;
const isPainting = mapStore.isPainting;
const sourceLayer = mapStore.mapDocument?.parent_layer;
const selectedFeatures = mapStore.paintFunction(map, e, mapStore.brushSize);
const isBrushingTool = sourceLayer && ["brush", "eraser"].includes(activeTool)
const paintLayers = getLayerIdsToPaint(mapStore.mapDocument?.child_layer);
const selectedFeatures = mapStore.paintFunction(
map,
e,
mapStore.brushSize,
paintLayers,
);
const isBrushingTool =
sourceLayer && ["brush", "eraser"].includes(activeTool);
if (isBrushingTool) {
setHoverFeatures(selectedFeatures);
}
Expand All @@ -127,7 +153,7 @@ export const handleMapMouseMove = (

export const handleMapZoom = (
e: MapLayerMouseEvent | MapLayerTouchEvent,
map: MutableRefObject<MapLibreMap | null>
map: MutableRefObject<MapLibreMap | null>,
) => {};

export const handleMapIdle = () => {};
Expand All @@ -136,11 +162,11 @@ export const handleMapMoveEnd = () => {};

export const handleMapZoomEnd = (
e: MapLayerMouseEvent | MapLayerTouchEvent,
map: MutableRefObject<MapLibreMap | null>
map: MutableRefObject<MapLibreMap | null>,
) => {};

export const handleResetMapSelectState = (
map: MutableRefObject<MapLibreMap | null>
map: MutableRefObject<MapLibreMap | null>,
) => {
const mapStore = useMapStore.getState();
const sourceLayer = mapStore.mapDocument?.parent_layer;
Expand All @@ -153,23 +179,21 @@ export const handleResetMapSelectState = (

export const handleMapContextMenu = (
e: MapLayerMouseEvent | MapLayerTouchEvent,
map: MutableRefObject<MapLibreMap | null>
map: MutableRefObject<MapLibreMap | null>,
) => {
const mapStore = useMapStore.getState();
if (mapStore.activeTool !== 'pan') {
return
if (mapStore.activeTool !== "pan") {
return;
}
e.preventDefault();
const setHoverFeatures = mapStore.setHoverFeatures;
const sourceLayer = mapStore.mapDocument?.parent_layer;
// Selects from the hover layers instead of the points
// Otherwise, its hard to select precisely
const selectedFeatures = mapStore.paintFunction(
map,
e,
0,
INTERACTIVE_LAYERS
);
const paintLayers = mapStore.mapDocument?.child_layer
? INTERACTIVE_LAYERS
: [BLOCK_HOVER_LAYER_ID];
const selectedFeatures = mapStore.paintFunction(map, e, 0, paintLayers);
if (!selectedFeatures?.length || !map.current || !sourceLayer) return;

setHoverFeatures(selectedFeatures.slice(0, 1));
Expand Down
41 changes: 23 additions & 18 deletions app/src/app/utils/helpers.ts
Original file line number Diff line number Diff line change
Expand Up @@ -31,7 +31,7 @@ export type PaintEventHandler = (
map: React.MutableRefObject<Map | null>,
e: MapLayerMouseEvent | MapLayerTouchEvent,
brushSize: number,
layers?: string[]
layers?: string[],
) => MapGeoJSONFeature[] | undefined;

/**
Expand Down Expand Up @@ -60,7 +60,7 @@ export type ContextMenuState = {
*/
export const boxAroundPoint = (
e: MapLayerMouseEvent | MapLayerTouchEvent,
radius: number
radius: number,
): [PointLike, PointLike] => {
return [
[e.point.x - radius, e.point.y - radius],
Expand All @@ -80,7 +80,7 @@ export const getFeaturesInBbox = (
map: MutableRefObject<Map | null>,
e: MapLayerMouseEvent | MapLayerTouchEvent,
brushSize: number,
layers: string[] = [BLOCK_LAYER_ID, BLOCK_LAYER_ID_CHILD]
layers: string[] = [BLOCK_LAYER_ID],
): MapGeoJSONFeature[] | undefined => {
const bbox = boxAroundPoint(e, brushSize);

Expand All @@ -99,7 +99,7 @@ export const getFeaturesIntersectingCounties = (
map: MutableRefObject<Map | null>,
e: MapLayerMouseEvent | MapLayerTouchEvent,
brushSize: number,
layers: string[] = [BLOCK_LAYER_ID, BLOCK_LAYER_ID_CHILD]
layers: string[] = [BLOCK_LAYER_ID],
): MapGeoJSONFeature[] | undefined => {
if (!map.current) return;

Expand Down Expand Up @@ -142,7 +142,7 @@ export const getFeaturesIntersectingCounties = (
* @returns [PointLike, PointLike] - An array containing the SW and NE corners of the bounding box
*/
const getBoundingBoxFromFeatures = (
features: MapGeoJSONFeature[]
features: MapGeoJSONFeature[],
): [LngLatLike, LngLatLike] | null => {
if (!features || features.length === 0) {
return null;
Expand Down Expand Up @@ -178,14 +178,14 @@ const getBoundingBoxFromFeatures = (
*/
export const mousePos = (
map: MutableRefObject<Map | null>,
e: MapLayerMouseEvent | MapLayerTouchEvent
e: MapLayerMouseEvent | MapLayerTouchEvent,
) => {
const canvas = map.current?.getCanvasContainer();
if (!canvas) return new Point(0, 0);
const rect = canvas.getBoundingClientRect();
return new Point(
e.point.x - rect.left - canvas.clientLeft,
e.point.y - rect.top - canvas.clientTop
e.point.y - rect.top - canvas.clientTop,
);
};

Expand All @@ -208,7 +208,7 @@ export interface LayerVisibility {
*/
export function toggleLayerVisibility(
mapRef: MutableRefObject<maplibregl.Map | null>,
layerIds: string[]
layerIds: string[],
): LayerVisibility[] {
const activeLayerIds = getVisibleLayers(mapRef)?.map((layer) => layer.id);
if (!activeLayerIds) return [];
Expand Down Expand Up @@ -242,17 +242,22 @@ export type ColorZoneAssignmentsState = [
MapStore["mapRef"],
MapStore["shatterIds"],
MapStore["appLoadingState"],
MapStore["mapRenderingState"]
MapStore["mapRenderingState"],
];

export const getMap = (_mapRef?: MapStore['mapRef']) => {
const mapRef = _mapRef || useMapStore.getState().mapRef
if (mapRef?.current && mapRef.current?.getStyle().layers.findIndex((layer) => layer.id === BLOCK_HOVER_LAYER_ID) !== -1) {
return null
export const getMap = (_mapRef?: MapStore["mapRef"]) => {
const mapRef = _mapRef || useMapStore.getState().mapRef;
if (
mapRef?.current &&
mapRef.current
?.getStyle()
.layers.findIndex((layer) => layer.id === BLOCK_HOVER_LAYER_ID) !== -1
) {
return null;
}

return mapRef as MutableRefObject<maplibregl.Map>
}
return mapRef as MutableRefObject<maplibregl.Map>;
};

/**
* Assigns colors to zones on the map based on the current zone assignments.
Expand All @@ -275,7 +280,7 @@ export const getMap = (_mapRef?: MapStore['mapRef']) => {
*/
export const colorZoneAssignments = (
state: ColorZoneAssignmentsState,
previousState?: ColorZoneAssignmentsState
previousState?: ColorZoneAssignmentsState,
) => {
const [
zoneAssignments,
Expand Down Expand Up @@ -326,7 +331,7 @@ export const colorZoneAssignments = (
{
selected: true,
zone,
}
},
);
});
};
Expand Down Expand Up @@ -355,7 +360,7 @@ export const colorZoneAssignmentTriggers = [
export const setZones = (
zoneAssignments: MapStore["zoneAssignments"],
parent: string,
children: Set<string>
children: Set<string>,
) => {
const zone = zoneAssignments.get(parent);
if (zone) {
Expand Down