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

show icons in the FillHugFixed dropdown! #4366

Merged
merged 7 commits into from
Oct 13, 2023
Merged
Show file tree
Hide file tree
Changes from 5 commits
Commits
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
Original file line number Diff line number Diff line change
Expand Up @@ -28,7 +28,7 @@ export interface DEPRECATEDSelectControlOptions extends DEPRECATEDGenericControl

export interface SelectOption {
value: any
icon?: IcnProps
icon?: Omit<IcnProps, 'color' | 'width' | 'height'>
label?: string
style?: React.CSSProperties
options?: SelectOption[]
Expand Down
52 changes: 41 additions & 11 deletions editor/src/components/inspector/fill-hug-fixed-control.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -56,7 +56,7 @@ import { fixedSizeDimensionHandlingText } from '../text-editor/text-handling'
import { when } from '../../utils/react-conditionals'
import type { LayoutPinnedPropIncludingCenter } from '../../core/layout/layout-helpers-new'
import { isLayoutPinnedProp, type LayoutPinnedProp } from '../../core/layout/layout-helpers-new'
import type { AllElementProps } from '../editor/store/editor-state'
import type { AllElementProps, EditorState } from '../editor/store/editor-state'
import { jsExpressionValue, emptyComments } from '../../core/shared/element-template'
import type { EditorDispatch, EditorAction } from '../editor/action-types'
import {
Expand All @@ -76,6 +76,7 @@ import {
isConversionForbidden,
} from '../canvas/canvas-strategies/strategies/group-conversion-helpers'
import { notice } from '../common/notice'
import createCachedSelector from 're-reselect'

export const FillFixedHugControlId = (segment: 'width' | 'height'): string =>
`hug-fixed-fill-${segment}`
Expand Down Expand Up @@ -106,18 +107,47 @@ export function selectOptionLabel(mode: FixedHugFillMode): string {
}
}

function selectOption(mode: FixedHugFillMode): SelectOption {
return {
value: mode,
label: selectOptionLabel(mode),
export function selectOptionIconType(
mode: FixedHugFillMode,
dimension: 'width' | 'height',
): string {
switch (mode) {
case 'fill':
return `fill-${dimension}`
case 'fixed':
return `fixed-${dimension}`
case 'hug':
return `hug-${dimension}`
case 'hug-group':
return `hug-${dimension}`
case 'computed':
return `fixed-${dimension}`
case 'detected':
return `fixed-${dimension}`
default:
assertNever(mode)
}
}

const fixedHugFillOptionsSelector = createSelector(
const selectOption =
(dimension: 'width' | 'height') =>
(mode: FixedHugFillMode): SelectOption => {
return {
value: mode,
label: selectOptionLabel(mode),
icon: {
category: 'layout/commands',
type: selectOptionIconType(mode, dimension),
},
}
}

const fixedHugFillOptionsSelector = createCachedSelector(
metadataSelector,
pathTreesSelector,
selectedViewsSelector,
(metadata, pathTrees, selectedViews) => {
(_: MetadataSubstate, dimension: 'width' | 'height') => dimension,
(metadata, pathTrees, selectedViews, dimension) => {
const applicableOptions: Array<FixedHugFillMode> = [
...intersection(
selectedViews.map((selectedView) =>
Expand All @@ -126,9 +156,9 @@ const fixedHugFillOptionsSelector = createSelector(
),
]

return applicableOptions.map(selectOption)
return applicableOptions.map(selectOption(dimension))
},
)
)((_, dimension: 'width' | 'height') => dimension)

export const FillHugFixedControlOld = React.memo(() => {
const onlyGroupChildrenSelected = useEditorState(
Expand Down Expand Up @@ -503,15 +533,15 @@ export const FixedHugDropdown = React.memo((props: { dimension: 'width' | 'heigh

const fixedHugFillOptions = useEditorState(
Substores.metadata,
fixedHugFillOptionsSelector,
(store) => fixedHugFillOptionsSelector(store, dimension),
'FixedHugDropdown fixedHugFillOptions',
)

const onSubmitFixedFillHugType = useOnSubmitFixedFillHugType(dimension)

return (
<PopupList
value={optionalMap(selectOption, currentValue.fixedHugFill?.type) ?? undefined}
value={optionalMap(selectOption(dimension), currentValue.fixedHugFill?.type) ?? undefined}
options={fixedHugFillOptions}
onSubmitValue={onSubmitFixedFillHugType}
controlStyles={getControlStyles(currentValue.controlStatus)}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -248,6 +248,7 @@ Array [
"/Symbol(react.context)/div/UtopiaSpiedFunctionComponent(ValueContainer)/Symbol(react.forward_ref)(render)",
"/div/UtopiaSpiedFunctionComponent(ValueContainer)/Symbol(react.forward_ref)(render)/UtopiaSpiedExoticType(Symbol(react.context))",
"/Symbol(react.forward_ref)(render)/UtopiaSpiedExoticType(Symbol(react.context))/Symbol(react.context)/div",
"/Symbol(react.context)/div/UtopiaSpiedFunctionComponent(SingleValue)/Symbol(react.memo)(Icon)",
"/Symbol(react.context)/div/UtopiaSpiedFunctionComponent(SingleValue)/span",
"/Symbol(react.context)/div/UtopiaSpiedFunctionComponent(SingleValue)/UtopiaSpiedFunctionComponent(SingleValue)",
"/div/UtopiaSpiedFunctionComponent(SingleValue)/UtopiaSpiedFunctionComponent(SingleValue)/Symbol(react.forward_ref)(render)",
Expand Down Expand Up @@ -291,6 +292,7 @@ Array [
"/Symbol(react.context)/div/UtopiaSpiedFunctionComponent(ValueContainer)/Symbol(react.forward_ref)(render)",
"/div/UtopiaSpiedFunctionComponent(ValueContainer)/Symbol(react.forward_ref)(render)/UtopiaSpiedExoticType(Symbol(react.context))",
"/Symbol(react.forward_ref)(render)/UtopiaSpiedExoticType(Symbol(react.context))/Symbol(react.context)/div",
"/Symbol(react.context)/div/UtopiaSpiedFunctionComponent(SingleValue)/Symbol(react.memo)(Icon)",
"/Symbol(react.context)/div/UtopiaSpiedFunctionComponent(SingleValue)/span",
"/Symbol(react.context)/div/UtopiaSpiedFunctionComponent(SingleValue)/UtopiaSpiedFunctionComponent(SingleValue)",
"/div/UtopiaSpiedFunctionComponent(SingleValue)/UtopiaSpiedFunctionComponent(SingleValue)/Symbol(react.forward_ref)(render)",
Expand Down Expand Up @@ -894,6 +896,7 @@ Array [
"/Symbol(react.context)/div/UtopiaSpiedFunctionComponent(ValueContainer)/Symbol(react.forward_ref)(render)",
"/div/UtopiaSpiedFunctionComponent(ValueContainer)/Symbol(react.forward_ref)(render)/UtopiaSpiedExoticType(Symbol(react.context))",
"/Symbol(react.forward_ref)(render)/UtopiaSpiedExoticType(Symbol(react.context))/Symbol(react.context)/div",
"/Symbol(react.context)/div/UtopiaSpiedFunctionComponent(SingleValue)/Symbol(react.memo)(Icon)",
"/Symbol(react.context)/div/UtopiaSpiedFunctionComponent(SingleValue)/span",
"/Symbol(react.context)/div/UtopiaSpiedFunctionComponent(SingleValue)/UtopiaSpiedFunctionComponent(SingleValue)",
"/div/UtopiaSpiedFunctionComponent(SingleValue)/UtopiaSpiedFunctionComponent(SingleValue)/Symbol(react.forward_ref)(render)",
Expand Down Expand Up @@ -937,6 +940,7 @@ Array [
"/Symbol(react.context)/div/UtopiaSpiedFunctionComponent(ValueContainer)/Symbol(react.forward_ref)(render)",
"/div/UtopiaSpiedFunctionComponent(ValueContainer)/Symbol(react.forward_ref)(render)/UtopiaSpiedExoticType(Symbol(react.context))",
"/Symbol(react.forward_ref)(render)/UtopiaSpiedExoticType(Symbol(react.context))/Symbol(react.context)/div",
"/Symbol(react.context)/div/UtopiaSpiedFunctionComponent(SingleValue)/Symbol(react.memo)(Icon)",
"/Symbol(react.context)/div/UtopiaSpiedFunctionComponent(SingleValue)/span",
"/Symbol(react.context)/div/UtopiaSpiedFunctionComponent(SingleValue)/UtopiaSpiedFunctionComponent(SingleValue)",
"/div/UtopiaSpiedFunctionComponent(SingleValue)/UtopiaSpiedFunctionComponent(SingleValue)/Symbol(react.forward_ref)(render)",
Expand Down Expand Up @@ -1696,6 +1700,7 @@ Array [
"/Symbol(react.context)/div/UtopiaSpiedFunctionComponent(ValueContainer)/Symbol(react.forward_ref)(render)",
"/div/UtopiaSpiedFunctionComponent(ValueContainer)/Symbol(react.forward_ref)(render)/UtopiaSpiedExoticType(Symbol(react.context))",
"/Symbol(react.forward_ref)(render)/UtopiaSpiedExoticType(Symbol(react.context))/Symbol(react.context)/div",
"/Symbol(react.context)/div/UtopiaSpiedFunctionComponent(SingleValue)/Symbol(react.memo)(Icon)",
"/Symbol(react.context)/div/UtopiaSpiedFunctionComponent(SingleValue)/span",
"/Symbol(react.context)/div/UtopiaSpiedFunctionComponent(SingleValue)/UtopiaSpiedFunctionComponent(SingleValue)",
"/div/UtopiaSpiedFunctionComponent(SingleValue)/UtopiaSpiedFunctionComponent(SingleValue)/Symbol(react.forward_ref)(render)",
Expand Down Expand Up @@ -1739,6 +1744,7 @@ Array [
"/Symbol(react.context)/div/UtopiaSpiedFunctionComponent(ValueContainer)/Symbol(react.forward_ref)(render)",
"/div/UtopiaSpiedFunctionComponent(ValueContainer)/Symbol(react.forward_ref)(render)/UtopiaSpiedExoticType(Symbol(react.context))",
"/Symbol(react.forward_ref)(render)/UtopiaSpiedExoticType(Symbol(react.context))/Symbol(react.context)/div",
"/Symbol(react.context)/div/UtopiaSpiedFunctionComponent(SingleValue)/Symbol(react.memo)(Icon)",
"/Symbol(react.context)/div/UtopiaSpiedFunctionComponent(SingleValue)/span",
"/Symbol(react.context)/div/UtopiaSpiedFunctionComponent(SingleValue)/UtopiaSpiedFunctionComponent(SingleValue)",
"/div/UtopiaSpiedFunctionComponent(SingleValue)/UtopiaSpiedFunctionComponent(SingleValue)/Symbol(react.forward_ref)(render)",
Expand Down Expand Up @@ -2435,6 +2441,7 @@ Array [
"/Symbol(react.context)/div/UtopiaSpiedFunctionComponent(ValueContainer)/Symbol(react.forward_ref)(render)",
"/div/UtopiaSpiedFunctionComponent(ValueContainer)/Symbol(react.forward_ref)(render)/UtopiaSpiedExoticType(Symbol(react.context))",
"/Symbol(react.forward_ref)(render)/UtopiaSpiedExoticType(Symbol(react.context))/Symbol(react.context)/div",
"/Symbol(react.context)/div/UtopiaSpiedFunctionComponent(SingleValue)/Symbol(react.memo)(Icon)",
"/Symbol(react.context)/div/UtopiaSpiedFunctionComponent(SingleValue)/span",
"/Symbol(react.context)/div/UtopiaSpiedFunctionComponent(SingleValue)/UtopiaSpiedFunctionComponent(SingleValue)",
"/div/UtopiaSpiedFunctionComponent(SingleValue)/UtopiaSpiedFunctionComponent(SingleValue)/Symbol(react.forward_ref)(render)",
Expand Down Expand Up @@ -2478,6 +2485,7 @@ Array [
"/Symbol(react.context)/div/UtopiaSpiedFunctionComponent(ValueContainer)/Symbol(react.forward_ref)(render)",
"/div/UtopiaSpiedFunctionComponent(ValueContainer)/Symbol(react.forward_ref)(render)/UtopiaSpiedExoticType(Symbol(react.context))",
"/Symbol(react.forward_ref)(render)/UtopiaSpiedExoticType(Symbol(react.context))/Symbol(react.context)/div",
"/Symbol(react.context)/div/UtopiaSpiedFunctionComponent(SingleValue)/Symbol(react.memo)(Icon)",
"/Symbol(react.context)/div/UtopiaSpiedFunctionComponent(SingleValue)/span",
"/Symbol(react.context)/div/UtopiaSpiedFunctionComponent(SingleValue)/UtopiaSpiedFunctionComponent(SingleValue)",
"/div/UtopiaSpiedFunctionComponent(SingleValue)/UtopiaSpiedFunctionComponent(SingleValue)/Symbol(react.forward_ref)(render)",
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -65,7 +65,7 @@ describe('React Render Count Tests -', () => {

const renderCountAfter = renderResult.getNumberOfRenders()
// if this breaks, GREAT NEWS but update the test please :)
expect(renderCountAfter - renderCountBefore).toMatchInlineSnapshot(`700`)
expect(renderCountAfter - renderCountBefore).toMatchInlineSnapshot(`702`)
expect(renderResult.getRenderInfo()).toMatchSnapshot()
})

Expand Down Expand Up @@ -127,7 +127,7 @@ describe('React Render Count Tests -', () => {

const renderCountAfter = renderResult.getNumberOfRenders()
// if this breaks, GREAT NEWS but update the test please :)
expect(renderCountAfter - renderCountBefore).toMatchInlineSnapshot(`745`)
expect(renderCountAfter - renderCountBefore).toMatchInlineSnapshot(`747`)
expect(renderResult.getRenderInfo()).toMatchSnapshot()
})

Expand Down Expand Up @@ -183,7 +183,7 @@ describe('React Render Count Tests -', () => {

const renderCountAfter = renderResult.getNumberOfRenders()
// if this breaks, GREAT NEWS but update the test please :)
expect(renderCountAfter - renderCountBefore).toMatchInlineSnapshot(`606`)
expect(renderCountAfter - renderCountBefore).toMatchInlineSnapshot(`608`)
expect(renderResult.getRenderInfo()).toMatchSnapshot()
})

Expand Down Expand Up @@ -249,7 +249,7 @@ describe('React Render Count Tests -', () => {

const renderCountAfter = renderResult.getNumberOfRenders()
// if this breaks, GREAT NEWS but update the test please :)
expect(renderCountAfter - renderCountBefore).toMatchInlineSnapshot(`678`)
expect(renderCountAfter - renderCountBefore).toMatchInlineSnapshot(`680`)
expect(renderResult.getRenderInfo()).toMatchSnapshot()
})
})
41 changes: 37 additions & 4 deletions editor/src/uuiui/widgets/popup-list/popup-list.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -98,7 +98,15 @@ const Option = (props: OptionProps<SelectOption>) => {
<FlexRow style={{ width: CheckboxWidth, padding: CheckboxPadding, flexShrink: 0 }}>
{props.isSelected ? '✓' : ''}
</FlexRow>
{props.data.icon == null ? null : <Icn {...props.data.icon} />}
{props.data.icon == null ? null : (
<Icn
{...props.data.icon}
// We override the color prop here so it can switch between dark and light depending on whether its highlighted (to always contrast the background)
color={props.isFocused ? 'on-highlight-main' : 'main'}
width={16}
height={16}
/>
)}
<span style={{ paddingLeft: 8 }}>{props.children}</span>
</FlexRow>
</Tooltip>
Expand Down Expand Up @@ -428,10 +436,35 @@ const DropdownIndicator: React.FunctionComponent<
}

const SingleValue = (props: SingleValueProps<SelectOption>) => {
const iconShown = props.data.icon != null
return (
<components.SingleValue {...props}>
{props.data.icon == null ? null : <Icn {...props.data.icon} />}
<span style={{ paddingLeft: 4 }}>{props.children}</span>
<components.SingleValue
{...props}
getStyles={(name, p) => {
return { ...props.getStyles(name, p), margin: iconShown ? -4 : 0 }
}}
>
{props.data.icon == null ? null : (
<div
style={{
position: 'absolute',
width: 20,
height: 20,
display: 'flex',
alignItems: 'center',
justifyContent: 'center',
}}
>
<Icn
{...props.data.icon}
color='secondary' // SingleValue is the "closed state" of the popupList, for these we want to show the subtle grey colored icon
width={16}
height={16}
style={{ scale: '80%' }}
/>
</div>
)}
<span style={{ paddingLeft: iconShown ? 22 : 4 }}>{props.children}</span>
</components.SingleValue>
)
}
Expand Down
Loading