From af52c22c093527ec94861de7887319b512311cef Mon Sep 17 00:00:00 2001
From: Sean Parsons <217400+seanparsons@users.noreply.github.com>
Date: Thu, 26 Oct 2023 14:42:17 +0100
Subject: [PATCH] fix(inspector) Only show one set of padding controls. (#4430)
- Exported `areElementsFlexContainersSelector`.
- In `ContainerSubsection` don't show `PaddingRow` if `allElementsInFlexLayout`
is true.
---
.../src/components/inspector/flex-section.tsx | 5 +-
.../inspector/inspector.spec.browser2.tsx | 91 ++++++++++++++++++-
2 files changed, 91 insertions(+), 5 deletions(-)
diff --git a/editor/src/components/inspector/flex-section.tsx b/editor/src/components/inspector/flex-section.tsx
index 8e8849af509b..00bc1e1fd8f0 100644
--- a/editor/src/components/inspector/flex-section.tsx
+++ b/editor/src/components/inspector/flex-section.tsx
@@ -18,7 +18,7 @@ import { FlexGapControl } from './sections/layout-section/flex-container-subsect
import { FlexContainerControls } from './sections/layout-section/flex-container-subsection/flex-container-subsection'
import { FlexCol } from 'utopia-api'
-const areElementsFlexContainersSelector = createSelector(
+export const areElementsFlexContainersSelector = createSelector(
metadataSelector,
selectedViewsSelector,
detectAreElementsFlexContainers,
@@ -57,9 +57,6 @@ export const FlexSection = React.memo(() => {
-
-
-
,
)}
diff --git a/editor/src/components/inspector/inspector.spec.browser2.tsx b/editor/src/components/inspector/inspector.spec.browser2.tsx
index 168dd2abf430..e1b26fe4c331 100644
--- a/editor/src/components/inspector/inspector.spec.browser2.tsx
+++ b/editor/src/components/inspector/inspector.spec.browser2.tsx
@@ -4,7 +4,7 @@ import { assertNever } from '../../core/shared/utils'
import { CanvasControlsContainerID } from '../canvas/controls/new-canvas-controls'
import { mouseClickAtPoint, mouseMoveToPoint } from '../canvas/event-helpers.test-utils'
import { getPrintedUiJsCode, renderTestEditorWithCode } from '../canvas/ui-jsx.test-utils'
-import { selectComponents } from '../editor/actions/action-creators'
+import { clearSelection, selectComponents } from '../editor/actions/action-creators'
import { AspectRatioLockButtonTestId } from './sections/layout-section/self-layout-subsection/gigantic-size-pins-subsection'
import { cmdModifier } from '../../utils/modifiers'
import { wait } from '../../utils/utils.test-utils'
@@ -80,6 +80,65 @@ export var storyboard = (
`
}
+function exampleProjectToCheckPaddingControls(): string {
+ return `import * as React from "react";
+import { Scene, Storyboard, jsx } from "utopia-api";
+
+export var App = (props) => {
+ return (
+
+ );
+};
+
+export var storyboard = (
+
+
+
+
+
+);
+`
+}
+
function exampleProjectForSectionRemoval(): string {
return `import * as React from 'react'
import { Storyboard, jsx } from 'utopia-api'
@@ -195,6 +254,36 @@ export var storyboard = (
// Click on the blue div.
await clickOnElementCheckTop('div-blue', '270')
})
+ it('check that only one pair of padding controls shows up at a time', async () => {
+ const editor = await renderTestEditorWithCode(
+ exampleProjectToCheckPaddingControls(),
+ 'await-first-dom-report',
+ )
+
+ function validatePaddingControlCount(): void {
+ const paddingHControls = editor.renderedDOM.queryAllByTestId('padding-H')
+ const paddingVControls = editor.renderedDOM.queryAllByTestId('padding-V')
+ expect(paddingHControls).toHaveLength(1)
+ expect(paddingVControls).toHaveLength(1)
+ }
+
+ await editor.dispatch([clearSelection()], true)
+ await editor.getDispatchFollowUpActionsFinished()
+ validatePaddingControlCount()
+
+ const appRootPath = elementPath([['storyboard', 'scene-1', 'app'], ['app-root']])
+ await editor.dispatch([selectComponents([appRootPath], false)], true)
+ await editor.getDispatchFollowUpActionsFinished()
+ validatePaddingControlCount()
+
+ const divPath = elementPath([
+ ['storyboard', 'scene-1', 'app'],
+ ['app-root', 'div-green'],
+ ])
+ await editor.dispatch([selectComponents([divPath], false)], true)
+ await editor.getDispatchFollowUpActionsFinished()
+ validatePaddingControlCount()
+ })
it('removes the transform property when clicking the cross on that section', async () => {
const resultCode = await setupRemovalTest('inspector-transform-remove-all')
expect(resultCode).toEqual(`import * as React from 'react'