From f91cc26fe181447f4be6cd635ff4e444c46eb401 Mon Sep 17 00:00:00 2001 From: Andrew Kingston Date: Mon, 29 Jul 2024 16:36:56 +0100 Subject: [PATCH] Sanity check grid size limits and improve logic around min/max column/row dimensions --- packages/client/manifest.json | 2 + .../app/container/GridContainer.svelte | 16 +++----- .../components/preview/GridDNDHandler.svelte | 41 ++++++------------- 3 files changed, 20 insertions(+), 39 deletions(-) diff --git a/packages/client/manifest.json b/packages/client/manifest.json index 2559671bab..f282cf17a4 100644 --- a/packages/client/manifest.json +++ b/packages/client/manifest.json @@ -146,6 +146,7 @@ "label": "Columns", "key": "cols", "placeholder": 12, + "min": 1, "dependsOn": { "setting": "layout", "value": "grid" @@ -156,6 +157,7 @@ "label": "Rows", "key": "rows", "placeholder": 12, + "min": 1, "dependsOn": { "setting": "layout", "value": "grid" diff --git a/packages/client/src/components/app/container/GridContainer.svelte b/packages/client/src/components/app/container/GridContainer.svelte index 2d7bf109d2..498b19b25b 100644 --- a/packages/client/src/components/app/container/GridContainer.svelte +++ b/packages/client/src/components/app/container/GridContainer.svelte @@ -9,11 +9,6 @@ $: cols = cols || 12 $: rows = rows || 12 - - // Deliberately non-reactive as we want this fixed whenever the grid renders - const defaultColSpan = Math.ceil((cols + 1) / 2) - const defaultRowSpan = Math.ceil((rows + 1) / 2) - $: coords = generateCoords(rows, cols) const generateCoords = (rows, cols) => { @@ -35,8 +30,6 @@ ...$component.styles?.normal, "--cols": cols, "--rows": rows, - "--default-col-span": defaultColSpan, - "--default-row-span": defaultRowSpan, gap: "0 !important", }, }} @@ -73,11 +66,14 @@ var(--cols) ) !important; grid-column-end: min( - max(1, var(--grid-column-end)), - var(--cols) + max(2, var(--grid-column-end)), + calc(var(--cols) + 1) ) !important; grid-row-start: min(max(1, var(--grid-row-start)), var(--rows)) !important; - grid-row-end: min(max(1, var(--grid-row-end)), var(--rows)) !important; + grid-row-end: min( + max(2, var(--grid-row-end)), + calc(var(--rows) + 1) + ) !important; max-height: 100%; max-width: 100%; } diff --git a/packages/client/src/components/preview/GridDNDHandler.svelte b/packages/client/src/components/preview/GridDNDHandler.svelte index 924631bc78..878a8a7feb 100644 --- a/packages/client/src/components/preview/GridDNDHandler.svelte +++ b/packages/client/src/components/preview/GridDNDHandler.svelte @@ -17,6 +17,9 @@ ...($gridStyles ? { "z-index": 999 } : null), }) + // Sugar for a combination of both min and max + const minMax = (value, min, max) => Math.min(max, Math.max(min, value)) + // Util to check if a DND event originates from a grid (or inside a grid). // This is important as we do not handle grid DND in this handler. const isGridEvent = e => { @@ -41,18 +44,7 @@ } const { mode, side, gridId, grid } = dragInfo - const { - startX, - startY, - rowStart, - rowEnd, - colStart, - colEnd, - rowDeltaMin, - rowDeltaMax, - colDeltaMin, - colDeltaMax, - } = grid + const { startX, startY, rowStart, rowEnd, colStart, colEnd } = grid const domGrid = getDOMNode(gridId) const cols = parseInt(domGrid.dataset.cols) @@ -67,13 +59,11 @@ let deltaY = Math.round(diffY / rowHeight) if (mode === "move") { - deltaY = Math.min(Math.max(deltaY, rowDeltaMin), rowDeltaMax) - deltaX = Math.min(Math.max(deltaX, colDeltaMin), colDeltaMax) const newStyles = { - "--grid-row-start": rowStart + deltaY, - "--grid-row-end": rowEnd + deltaY, - "--grid-column-start": colStart + deltaX, - "--grid-column-end": colEnd + deltaX, + "--grid-row-start": minMax(rowStart + deltaY, 1, rows), + "--grid-row-end": minMax(rowEnd + deltaY, 2, rows + 1), + "--grid-column-start": minMax(colStart + deltaX, 1, cols), + "--grid-column-end": minMax(colEnd + deltaX, 2, cols + 1), } gridStyles.set(newStyles) } else if (mode === "resize") { @@ -174,21 +164,14 @@ const domNode = getDOMNode(dragInfo.id) const styles = window.getComputedStyle(domNode) if (domGrid) { - const minMax = (value, min, max) => Math.min(max, Math.max(min, value)) const getStyle = x => parseInt(styles?.getPropertyValue(x) || "0") - const getColStyle = x => minMax(getStyle(x), 1, gridCols + 1) - const getRowStyle = x => minMax(getStyle(x), 1, gridRows + 1) dragInfo.grid = { startX: e.clientX, startY: e.clientY, - rowStart: getRowStyle("--grid-row-start"), - rowEnd: getRowStyle("--grid-row-end"), - colStart: getColStyle("--grid-column-start"), - colEnd: getColStyle("--grid-column-end"), - rowDeltaMin: 1 - getRowStyle("--grid-row-start"), - rowDeltaMax: gridRows + 1 - getRowStyle("--grid-row-end"), - colDeltaMin: 1 - getColStyle("--grid-column-start"), - colDeltaMax: gridCols + 1 - getColStyle("--grid-column-end"), + rowStart: minMax(getStyle("--grid-row-start"), 1, gridRows), + rowEnd: minMax(getStyle("--grid-row-end"), 2, gridRows + 1), + colStart: minMax(getStyle("--grid-column-start"), 1, gridCols), + colEnd: minMax(getStyle("--grid-column-end"), 2, gridCols + 1), } handleEvent(e) }