From 9cc1134a1023b8fa6a1659f2a5ca44aedd8c2343 Mon Sep 17 00:00:00 2001 From: Federico Ruggi <1081051+ruggi@users.noreply.github.com> Date: Tue, 8 Oct 2024 13:49:42 +0200 Subject: [PATCH 1/2] trim dynamic empty grid dimensions --- editor/src/components/canvas/dom-walker.ts | 68 ++++++++++++++++++---- 1 file changed, 56 insertions(+), 12 deletions(-) diff --git a/editor/src/components/canvas/dom-walker.ts b/editor/src/components/canvas/dom-walker.ts index 3a0e979335fe..21505b10bd1b 100644 --- a/editor/src/components/canvas/dom-walker.ts +++ b/editor/src/components/canvas/dom-walker.ts @@ -9,6 +9,7 @@ import type { GridContainerProperties, GridElementProperties, DomElementMetadata, + GridAutoOrTemplateBase, } from '../../core/shared/element-template' import { specialSizeMeasurements, @@ -16,6 +17,7 @@ import { gridElementProperties, gridAutoOrTemplateFallback, domElementMetadata, + gridAutoOrTemplateDimensions, } from '../../core/shared/element-template' import type { ElementPath } from '../../core/shared/project-file-types' import type { ElementCanvasRectangleCache } from '../../core/shared/dom-utils' @@ -52,6 +54,7 @@ import { parseGridAutoOrTemplateBase, parseGridAutoFlow, isCSSKeyword, + isDynamicGridRepeat, } from '../inspector/common/css-utils' import type { UtopiaStoreAPI } from '../editor/store/store-hook' import { @@ -555,6 +558,10 @@ export function collectDomElementMetadataForElement( function getGridContainerProperties( elementStyle: CSSStyleDeclaration | null, + options?: { + dynamicCols: boolean + dynamicRows: boolean + }, ): GridContainerProperties { if (elementStyle == null) { return { @@ -565,14 +572,23 @@ function getGridContainerProperties( gridAutoFlow: null, } } - const gridTemplateColumns = defaultEither( - gridAutoOrTemplateFallback(elementStyle.gridTemplateColumns), - parseGridAutoOrTemplateBase(elementStyle.gridTemplateColumns), + + const gridTemplateColumns = trimDynamicEmptyDimensions( + defaultEither( + gridAutoOrTemplateFallback(elementStyle.gridTemplateColumns), + parseGridAutoOrTemplateBase(elementStyle.gridTemplateColumns), + ), + options?.dynamicCols === true, ) - const gridTemplateRows = defaultEither( - gridAutoOrTemplateFallback(elementStyle.gridTemplateRows), - parseGridAutoOrTemplateBase(elementStyle.gridTemplateRows), + + const gridTemplateRows = trimDynamicEmptyDimensions( + defaultEither( + gridAutoOrTemplateFallback(elementStyle.gridTemplateRows), + parseGridAutoOrTemplateBase(elementStyle.gridTemplateRows), + ), + options?.dynamicRows === true, ) + const gridAutoColumns = defaultEither( gridAutoOrTemplateFallback(elementStyle.gridAutoColumns), parseGridAutoOrTemplateBase(elementStyle.gridAutoColumns), @@ -590,6 +606,23 @@ function getGridContainerProperties( ) } +function trimDynamicEmptyDimensions( + template: GridAutoOrTemplateBase, + isDynamic: boolean, +): GridAutoOrTemplateBase { + if (!isDynamic) { + return template + } + if (template.type !== 'DIMENSIONS') { + return template + } + + const lastNonEmptyColumn = template.dimensions.findLastIndex( + (d) => d.type === 'KEYWORD' || (d.type === 'NUMBER' && d.value.value !== 0), + ) + return gridAutoOrTemplateDimensions(template.dimensions.slice(0, lastNonEmptyColumn + 1)) +} + function getGridElementProperties( container: GridContainerProperties, elementStyle: CSSStyleDeclaration, @@ -882,8 +915,6 @@ function getSpecialMeasurements( const parentContainerGridProperties = getGridContainerProperties(parentElementStyle) - const containerGridProperties = getGridContainerProperties(elementStyle) - const paddingValue = isRight(padding) ? padding.value : sides(undefined, undefined, undefined, undefined) @@ -898,15 +929,28 @@ function getSpecialMeasurements( ) : null - const containerElementProperties = getGridElementProperties( - parentContainerGridProperties, - elementStyle, - ) const containerGridPropertiesFromProps = getGridContainerProperties(element.style) + const containerGridProperties = getGridContainerProperties(elementStyle, { + dynamicCols: + containerGridPropertiesFromProps.gridTemplateColumns?.type === 'DIMENSIONS' && + containerGridPropertiesFromProps.gridTemplateColumns.dimensions.some((d) => + isDynamicGridRepeat(d), + ), + dynamicRows: + containerGridPropertiesFromProps.gridTemplateRows?.type === 'DIMENSIONS' && + containerGridPropertiesFromProps.gridTemplateRows.dimensions.some((d) => + isDynamicGridRepeat(d), + ), + }) + const containerElementPropertiesFromProps = getGridElementProperties( parentContainerGridProperties, element.style, ) + const containerElementProperties = getGridElementProperties( + parentContainerGridProperties, + elementStyle, + ) return specialSizeMeasurements( offset, From bee49233a7499ababb9fff7ee8799fb727fe9a8d Mon Sep 17 00:00:00 2001 From: Federico Ruggi <1081051+ruggi@users.noreply.github.com> Date: Tue, 8 Oct 2024 14:24:48 +0200 Subject: [PATCH 2/2] factor out isDynamicGridTemplate --- editor/src/components/canvas/dom-walker.ts | 16 ++++++---------- 1 file changed, 6 insertions(+), 10 deletions(-) diff --git a/editor/src/components/canvas/dom-walker.ts b/editor/src/components/canvas/dom-walker.ts index 21505b10bd1b..912d3515f34b 100644 --- a/editor/src/components/canvas/dom-walker.ts +++ b/editor/src/components/canvas/dom-walker.ts @@ -931,16 +931,8 @@ function getSpecialMeasurements( const containerGridPropertiesFromProps = getGridContainerProperties(element.style) const containerGridProperties = getGridContainerProperties(elementStyle, { - dynamicCols: - containerGridPropertiesFromProps.gridTemplateColumns?.type === 'DIMENSIONS' && - containerGridPropertiesFromProps.gridTemplateColumns.dimensions.some((d) => - isDynamicGridRepeat(d), - ), - dynamicRows: - containerGridPropertiesFromProps.gridTemplateRows?.type === 'DIMENSIONS' && - containerGridPropertiesFromProps.gridTemplateRows.dimensions.some((d) => - isDynamicGridRepeat(d), - ), + dynamicCols: isDynamicGridTemplate(containerGridPropertiesFromProps.gridTemplateColumns), + dynamicRows: isDynamicGridTemplate(containerGridPropertiesFromProps.gridTemplateRows), }) const containerElementPropertiesFromProps = getGridElementProperties( @@ -1009,6 +1001,10 @@ function getSpecialMeasurements( ) } +function isDynamicGridTemplate(template: GridAutoOrTemplateBase | null) { + return template?.type === 'DIMENSIONS' && template.dimensions.some((d) => isDynamicGridRepeat(d)) +} + function elementContainsOnlyText(element: HTMLElement): boolean { if (element.childNodes.length === 0) { return false