@wordpress/components 23.3.2 → 23.4.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.md +20 -5
- package/build/alignment-matrix-control/utils.js +4 -4
- package/build/alignment-matrix-control/utils.js.map +1 -1
- package/build/angle-picker-control/angle-circle.js +37 -29
- package/build/angle-picker-control/angle-circle.js.map +1 -1
- package/build/angle-picker-control/index.js +44 -9
- package/build/angle-picker-control/index.js.map +1 -1
- package/build/angle-picker-control/styles/angle-picker-control-styles.js +13 -13
- package/build/angle-picker-control/styles/angle-picker-control-styles.js.map +1 -1
- package/build/{base-field → angle-picker-control}/types.js +0 -0
- package/build/angle-picker-control/types.js.map +1 -0
- package/build/autocomplete/autocompleter-ui.native.js +1 -0
- package/build/autocomplete/autocompleter-ui.native.js.map +1 -1
- package/build/base-control/hooks.js +1 -1
- package/build/base-control/hooks.js.map +1 -1
- package/build/border-box-control/utils.js +1 -1
- package/build/border-box-control/utils.js.map +1 -1
- package/build/box-control/all-input-control.js +2 -2
- package/build/box-control/all-input-control.js.map +1 -1
- package/build/box-control/axial-input-controls.js +1 -1
- package/build/box-control/axial-input-controls.js.map +1 -1
- package/build/box-control/icon.js.map +1 -1
- package/build/box-control/index.js +32 -3
- package/build/box-control/index.js.map +1 -1
- package/build/box-control/input-controls.js +5 -5
- package/build/box-control/input-controls.js.map +1 -1
- package/build/box-control/linked-button.js.map +1 -1
- package/build/box-control/styles/box-control-icon-styles.js +28 -28
- package/build/box-control/styles/box-control-icon-styles.js.map +1 -1
- package/build/box-control/styles/box-control-styles.js +23 -23
- package/build/box-control/styles/box-control-styles.js.map +1 -1
- package/build/box-control/styles/box-control-visualizer-styles.js +19 -19
- package/build/box-control/styles/box-control-visualizer-styles.js.map +1 -1
- package/build/box-control/types.js +6 -0
- package/build/box-control/types.js.map +1 -0
- package/build/box-control/unit-control.js.map +1 -1
- package/build/box-control/utils.js +23 -23
- package/build/box-control/utils.js.map +1 -1
- package/build/color-palette/index.js +8 -3
- package/build/color-palette/index.js.map +1 -1
- package/build/combobox-control/index.js +68 -12
- package/build/combobox-control/index.js.map +1 -1
- package/build/combobox-control/styles.js +2 -2
- package/build/combobox-control/styles.js.map +1 -1
- package/build/combobox-control/types.js +6 -0
- package/build/combobox-control/types.js.map +1 -0
- package/build/custom-gradient-picker/index.js +0 -1
- package/build/custom-gradient-picker/index.js.map +1 -1
- package/build/date-time/time/index.js +1 -1
- package/build/date-time/time/index.js.map +1 -1
- package/build/date-time/utils.js +1 -1
- package/build/date-time/utils.js.map +1 -1
- package/build/draggable/index.js +2 -2
- package/build/draggable/index.js.map +1 -1
- package/build/focal-point-picker/utils.js +3 -3
- package/build/focal-point-picker/utils.js.map +1 -1
- package/build/font-size-picker/utils.js +2 -2
- package/build/font-size-picker/utils.js.map +1 -1
- package/build/gradient-picker/index.js +9 -4
- package/build/gradient-picker/index.js.map +1 -1
- package/build/input-control/reducer/reducer.js +5 -5
- package/build/input-control/reducer/reducer.js.map +1 -1
- package/build/input-control/utils.js +1 -1
- package/build/input-control/utils.js.map +1 -1
- package/build/menu-items-choice/index.js +40 -3
- package/build/menu-items-choice/index.js.map +1 -1
- package/build/menu-items-choice/types.js +6 -0
- package/build/menu-items-choice/types.js.map +1 -0
- package/build/modal/index.js +41 -3
- package/build/modal/index.js.map +1 -1
- package/build/palette-edit/index.js +4 -1
- package/build/palette-edit/index.js.map +1 -1
- package/build/panel/header.js +9 -0
- package/build/panel/header.js.map +1 -1
- package/build/panel/index.js +21 -3
- package/build/panel/index.js.map +1 -1
- package/build/panel/row.js +10 -4
- package/build/panel/row.js.map +1 -1
- package/build/panel/types.js +6 -0
- package/build/panel/types.js.map +1 -0
- package/build/popover/index.js +15 -3
- package/build/popover/index.js.map +1 -1
- package/build/popover/overlay-middlewares.js +46 -0
- package/build/popover/overlay-middlewares.js.map +1 -0
- package/build/popover/utils.js +45 -6
- package/build/popover/utils.js.map +1 -1
- package/build/query-controls/terms.js +1 -1
- package/build/query-controls/terms.js.map +1 -1
- package/build/range-control/utils.js +4 -4
- package/build/range-control/utils.js.map +1 -1
- package/build/resizable-box/resize-tooltip/styles/resize-tooltip.styles.js +12 -12
- package/build/resizable-box/resize-tooltip/styles/resize-tooltip.styles.js.map +1 -1
- package/build/resizable-box/resize-tooltip/utils.js +14 -14
- package/build/resizable-box/resize-tooltip/utils.js.map +1 -1
- package/build/snackbar/index.js +2 -2
- package/build/snackbar/index.js.map +1 -1
- package/build/toolbar/toolbar/index.js +25 -14
- package/build/toolbar/toolbar/index.js.map +1 -1
- package/build/toolbar/toolbar/toolbar-container.js +5 -4
- package/build/toolbar/toolbar/toolbar-container.js.map +1 -1
- package/build/toolbar/toolbar/types.js +6 -0
- package/build/toolbar/toolbar/types.js.map +1 -0
- package/build/toolbar/toolbar-button/index.js +2 -0
- package/build/toolbar/toolbar-button/index.js.map +1 -1
- package/build/toolbar/toolbar-button/toolbar-button-container.js +1 -0
- package/build/toolbar/toolbar-button/toolbar-button-container.js.map +1 -1
- package/build/toolbar/toolbar-context/index.js +2 -0
- package/build/toolbar/toolbar-context/index.js.map +1 -1
- package/build/toolbar/toolbar-dropdown-menu/index.js +2 -0
- package/build/toolbar/toolbar-dropdown-menu/index.js.map +1 -1
- package/build/toolbar/toolbar-group/index.js +2 -0
- package/build/toolbar/toolbar-group/index.js.map +1 -1
- package/build/toolbar/toolbar-group/toolbar-group-collapsed.js +2 -0
- package/build/toolbar/toolbar-group/toolbar-group-collapsed.js.map +1 -1
- package/build/toolbar/toolbar-group/toolbar-group-container.js +1 -0
- package/build/toolbar/toolbar-group/toolbar-group-container.js.map +1 -1
- package/build/toolbar/toolbar-item/index.js +2 -0
- package/build/toolbar/toolbar-item/index.js.map +1 -1
- package/build/tools-panel/tools-panel/component.js +61 -5
- package/build/tools-panel/tools-panel/component.js.map +1 -1
- package/build/tools-panel/tools-panel/hook.js +4 -2
- package/build/tools-panel/tools-panel/hook.js.map +1 -1
- package/build/tools-panel/tools-panel-header/component.js +2 -1
- package/build/tools-panel/tools-panel-header/component.js.map +1 -1
- package/build/tools-panel/tools-panel-header/hook.js +2 -0
- package/build/tools-panel/tools-panel-header/hook.js.map +1 -1
- package/build/tools-panel/tools-panel-item/component.js +5 -4
- package/build/tools-panel/tools-panel-item/component.js.map +1 -1
- package/build/tools-panel/tools-panel-item/hook.js +4 -2
- package/build/tools-panel/tools-panel-item/hook.js.map +1 -1
- package/build/tree-grid/cell.js +15 -4
- package/build/tree-grid/cell.js.map +1 -1
- package/build/tree-grid/index.js +81 -19
- package/build/tree-grid/index.js.map +1 -1
- package/build/tree-grid/item.js +14 -3
- package/build/tree-grid/item.js.map +1 -1
- package/build/tree-grid/roving-tab-index-context.js +1 -1
- package/build/tree-grid/roving-tab-index-context.js.map +1 -1
- package/build/tree-grid/roving-tab-index-item.js +13 -6
- package/build/tree-grid/roving-tab-index-item.js.map +1 -1
- package/build/tree-grid/roving-tab-index.js +0 -3
- package/build/tree-grid/roving-tab-index.js.map +1 -1
- package/build/tree-grid/row.js +20 -18
- package/build/tree-grid/row.js.map +1 -1
- package/build/tree-grid/types.js +6 -0
- package/build/tree-grid/types.js.map +1 -0
- package/build/ui/context/context-connect.js +7 -7
- package/build/ui/context/context-connect.js.map +1 -1
- package/build/ui/context/get-styled-class-name-from-key.js +1 -1
- package/build/ui/context/get-styled-class-name-from-key.js.map +1 -1
- package/build/ui/utils/get-valid-children.js +1 -1
- package/build/ui/utils/get-valid-children.js.map +1 -1
- package/build/ui/utils/space.js +1 -1
- package/build/ui/utils/space.js.map +1 -1
- package/build/unit-control/index.js +2 -2
- package/build/unit-control/index.js.map +1 -1
- package/build/unit-control/utils.js +20 -20
- package/build/unit-control/utils.js.map +1 -1
- package/build/utils/events.js +4 -4
- package/build/utils/events.js.map +1 -1
- package/build/utils/hooks/use-controlled-state.js +2 -2
- package/build/utils/hooks/use-controlled-state.js.map +1 -1
- package/build/utils/hooks/use-controlled-value.js +4 -4
- package/build/utils/hooks/use-controlled-value.js.map +1 -1
- package/build/utils/hooks/use-latest-ref.js +1 -1
- package/build/utils/hooks/use-latest-ref.js.map +1 -1
- package/build/utils/unit-values.js +3 -3
- package/build/utils/unit-values.js.map +1 -1
- package/build-module/alignment-matrix-control/utils.js +4 -4
- package/build-module/alignment-matrix-control/utils.js.map +1 -1
- package/build-module/angle-picker-control/angle-circle.js +37 -29
- package/build-module/angle-picker-control/angle-circle.js.map +1 -1
- package/build-module/angle-picker-control/index.js +42 -8
- package/build-module/angle-picker-control/index.js.map +1 -1
- package/build-module/angle-picker-control/styles/angle-picker-control-styles.js +13 -13
- package/build-module/angle-picker-control/styles/angle-picker-control-styles.js.map +1 -1
- package/build-module/{base-field → angle-picker-control}/types.js +0 -0
- package/build-module/{base-field → angle-picker-control}/types.js.map +0 -0
- package/build-module/autocomplete/autocompleter-ui.native.js +1 -0
- package/build-module/autocomplete/autocompleter-ui.native.js.map +1 -1
- package/build-module/base-control/hooks.js +1 -1
- package/build-module/base-control/hooks.js.map +1 -1
- package/build-module/border-box-control/utils.js +1 -1
- package/build-module/border-box-control/utils.js.map +1 -1
- package/build-module/box-control/all-input-control.js +2 -2
- package/build-module/box-control/all-input-control.js.map +1 -1
- package/build-module/box-control/axial-input-controls.js +1 -1
- package/build-module/box-control/axial-input-controls.js.map +1 -1
- package/build-module/box-control/icon.js.map +1 -1
- package/build-module/box-control/index.js +31 -3
- package/build-module/box-control/index.js.map +1 -1
- package/build-module/box-control/input-controls.js +5 -5
- package/build-module/box-control/input-controls.js.map +1 -1
- package/build-module/box-control/linked-button.js.map +1 -1
- package/build-module/box-control/styles/box-control-icon-styles.js +28 -28
- package/build-module/box-control/styles/box-control-icon-styles.js.map +1 -1
- package/build-module/box-control/styles/box-control-styles.js +23 -23
- package/build-module/box-control/styles/box-control-styles.js.map +1 -1
- package/build-module/box-control/styles/box-control-visualizer-styles.js +19 -19
- package/build-module/box-control/styles/box-control-visualizer-styles.js.map +1 -1
- package/build-module/box-control/types.js +2 -0
- package/{build/base-field → build-module/box-control}/types.js.map +0 -0
- package/build-module/box-control/unit-control.js.map +1 -1
- package/build-module/box-control/utils.js +23 -23
- package/build-module/box-control/utils.js.map +1 -1
- package/build-module/color-palette/index.js +8 -3
- package/build-module/color-palette/index.js.map +1 -1
- package/build-module/combobox-control/index.js +68 -12
- package/build-module/combobox-control/index.js.map +1 -1
- package/build-module/combobox-control/styles.js +2 -2
- package/build-module/combobox-control/styles.js.map +1 -1
- package/build-module/combobox-control/types.js +2 -0
- package/build-module/{resizable-box/styles/resizable-box.styles.js.map → combobox-control/types.js.map} +0 -0
- package/build-module/custom-gradient-picker/index.js +0 -1
- package/build-module/custom-gradient-picker/index.js.map +1 -1
- package/build-module/date-time/time/index.js +1 -1
- package/build-module/date-time/time/index.js.map +1 -1
- package/build-module/date-time/utils.js +1 -1
- package/build-module/date-time/utils.js.map +1 -1
- package/build-module/draggable/index.js +2 -2
- package/build-module/draggable/index.js.map +1 -1
- package/build-module/focal-point-picker/utils.js +3 -3
- package/build-module/focal-point-picker/utils.js.map +1 -1
- package/build-module/font-size-picker/utils.js +2 -2
- package/build-module/font-size-picker/utils.js.map +1 -1
- package/build-module/gradient-picker/index.js +9 -4
- package/build-module/gradient-picker/index.js.map +1 -1
- package/build-module/input-control/reducer/reducer.js +5 -5
- package/build-module/input-control/reducer/reducer.js.map +1 -1
- package/build-module/input-control/utils.js +1 -1
- package/build-module/input-control/utils.js.map +1 -1
- package/build-module/menu-items-choice/index.js +40 -4
- package/build-module/menu-items-choice/index.js.map +1 -1
- package/build-module/menu-items-choice/types.js +2 -0
- package/{build/resizable-box/styles/resizable-box.styles.js.map → build-module/menu-items-choice/types.js.map} +0 -0
- package/build-module/modal/index.js +41 -4
- package/build-module/modal/index.js.map +1 -1
- package/build-module/palette-edit/index.js +4 -1
- package/build-module/palette-edit/index.js.map +1 -1
- package/build-module/panel/header.js +9 -0
- package/build-module/panel/header.js.map +1 -1
- package/build-module/panel/index.js +20 -2
- package/build-module/panel/index.js.map +1 -1
- package/build-module/panel/row.js +9 -3
- package/build-module/panel/row.js.map +1 -1
- package/build-module/panel/types.js +2 -0
- package/build-module/panel/types.js.map +1 -0
- package/build-module/popover/index.js +14 -4
- package/build-module/popover/index.js.map +1 -1
- package/build-module/popover/overlay-middlewares.js +38 -0
- package/build-module/popover/overlay-middlewares.js.map +1 -0
- package/build-module/popover/utils.js +41 -5
- package/build-module/popover/utils.js.map +1 -1
- package/build-module/query-controls/terms.js +1 -1
- package/build-module/query-controls/terms.js.map +1 -1
- package/build-module/range-control/utils.js +4 -4
- package/build-module/range-control/utils.js.map +1 -1
- package/build-module/resizable-box/resize-tooltip/styles/resize-tooltip.styles.js +12 -12
- package/build-module/resizable-box/resize-tooltip/styles/resize-tooltip.styles.js.map +1 -1
- package/build-module/resizable-box/resize-tooltip/utils.js +14 -14
- package/build-module/resizable-box/resize-tooltip/utils.js.map +1 -1
- package/build-module/snackbar/index.js +2 -2
- package/build-module/snackbar/index.js.map +1 -1
- package/build-module/toolbar/toolbar/index.js +25 -13
- package/build-module/toolbar/toolbar/index.js.map +1 -1
- package/build-module/toolbar/toolbar/toolbar-container.js +4 -3
- package/build-module/toolbar/toolbar/toolbar-container.js.map +1 -1
- package/build-module/toolbar/toolbar/types.js +2 -0
- package/build-module/toolbar/toolbar/types.js.map +1 -0
- package/build-module/toolbar/toolbar-button/index.js +1 -0
- package/build-module/toolbar/toolbar-button/index.js.map +1 -1
- package/build-module/toolbar/toolbar-button/toolbar-button-container.js +1 -0
- package/build-module/toolbar/toolbar-button/toolbar-button-container.js.map +1 -1
- package/build-module/toolbar/toolbar-context/index.js +2 -0
- package/build-module/toolbar/toolbar-context/index.js.map +1 -1
- package/build-module/toolbar/toolbar-dropdown-menu/index.js +1 -0
- package/build-module/toolbar/toolbar-dropdown-menu/index.js.map +1 -1
- package/build-module/toolbar/toolbar-group/index.js +1 -0
- package/build-module/toolbar/toolbar-group/index.js.map +1 -1
- package/build-module/toolbar/toolbar-group/toolbar-group-collapsed.js +1 -0
- package/build-module/toolbar/toolbar-group/toolbar-group-collapsed.js.map +1 -1
- package/build-module/toolbar/toolbar-group/toolbar-group-container.js +1 -0
- package/build-module/toolbar/toolbar-group/toolbar-group-container.js.map +1 -1
- package/build-module/toolbar/toolbar-item/index.js +1 -0
- package/build-module/toolbar/toolbar-item/index.js.map +1 -1
- package/build-module/tools-panel/tools-panel/component.js +59 -4
- package/build-module/tools-panel/tools-panel/component.js.map +1 -1
- package/build-module/tools-panel/tools-panel/hook.js +4 -2
- package/build-module/tools-panel/tools-panel/hook.js.map +1 -1
- package/build-module/tools-panel/tools-panel-header/component.js +2 -1
- package/build-module/tools-panel/tools-panel-header/component.js.map +1 -1
- package/build-module/tools-panel/tools-panel-header/hook.js +2 -0
- package/build-module/tools-panel/tools-panel-header/hook.js.map +1 -1
- package/build-module/tools-panel/tools-panel-item/component.js +3 -3
- package/build-module/tools-panel/tools-panel-item/component.js.map +1 -1
- package/build-module/tools-panel/tools-panel-item/hook.js +5 -2
- package/build-module/tools-panel/tools-panel-item/hook.js.map +1 -1
- package/build-module/tree-grid/cell.js +16 -4
- package/build-module/tree-grid/cell.js.map +1 -1
- package/build-module/tree-grid/index.js +81 -21
- package/build-module/tree-grid/index.js.map +1 -1
- package/build-module/tree-grid/item.js +14 -2
- package/build-module/tree-grid/item.js.map +1 -1
- package/build-module/tree-grid/roving-tab-index-context.js +1 -1
- package/build-module/tree-grid/roving-tab-index-context.js.map +1 -1
- package/build-module/tree-grid/roving-tab-index-item.js +11 -4
- package/build-module/tree-grid/roving-tab-index-item.js.map +1 -1
- package/build-module/tree-grid/roving-tab-index.js +0 -3
- package/build-module/tree-grid/roving-tab-index.js.map +1 -1
- package/build-module/tree-grid/row.js +22 -17
- package/build-module/tree-grid/row.js.map +1 -1
- package/build-module/tree-grid/types.js +2 -0
- package/build-module/tree-grid/types.js.map +1 -0
- package/build-module/ui/context/context-connect.js +7 -7
- package/build-module/ui/context/context-connect.js.map +1 -1
- package/build-module/ui/context/get-styled-class-name-from-key.js +1 -1
- package/build-module/ui/context/get-styled-class-name-from-key.js.map +1 -1
- package/build-module/ui/utils/get-valid-children.js +1 -1
- package/build-module/ui/utils/get-valid-children.js.map +1 -1
- package/build-module/ui/utils/space.js +1 -1
- package/build-module/ui/utils/space.js.map +1 -1
- package/build-module/unit-control/index.js +2 -2
- package/build-module/unit-control/index.js.map +1 -1
- package/build-module/unit-control/utils.js +20 -20
- package/build-module/unit-control/utils.js.map +1 -1
- package/build-module/utils/events.js +4 -4
- package/build-module/utils/events.js.map +1 -1
- package/build-module/utils/hooks/use-controlled-state.js +2 -2
- package/build-module/utils/hooks/use-controlled-state.js.map +1 -1
- package/build-module/utils/hooks/use-controlled-value.js +4 -4
- package/build-module/utils/hooks/use-controlled-value.js.map +1 -1
- package/build-module/utils/hooks/use-latest-ref.js +1 -1
- package/build-module/utils/hooks/use-latest-ref.js.map +1 -1
- package/build-module/utils/unit-values.js +3 -3
- package/build-module/utils/unit-values.js.map +1 -1
- package/build-style/style-rtl.css +5 -0
- package/build-style/style.css +5 -0
- package/build-types/alignment-matrix-control/utils.d.ts +4 -4
- package/build-types/angle-picker-control/angle-circle.d.ts +6 -0
- package/build-types/angle-picker-control/angle-circle.d.ts.map +1 -0
- package/build-types/angle-picker-control/index.d.ts +29 -0
- package/build-types/angle-picker-control/index.d.ts.map +1 -0
- package/build-types/angle-picker-control/stories/index.d.ts +15 -0
- package/build-types/angle-picker-control/stories/index.d.ts.map +1 -0
- package/build-types/angle-picker-control/styles/angle-picker-control-styles.d.ts +20 -0
- package/build-types/angle-picker-control/styles/angle-picker-control-styles.d.ts.map +1 -0
- package/build-types/angle-picker-control/types.d.ts +26 -0
- package/build-types/angle-picker-control/types.d.ts.map +1 -0
- package/build-types/base-control/hooks.d.ts +1 -1
- package/build-types/border-box-control/border-box-control/component.d.ts +1 -1
- package/build-types/border-box-control/border-box-control/hook.d.ts +1 -1
- package/build-types/border-box-control/border-box-control-split-controls/component.d.ts +1 -1
- package/build-types/border-box-control/border-box-control-split-controls/hook.d.ts +1 -1
- package/build-types/border-box-control/stories/index.d.ts +1 -1
- package/build-types/{base-field → border-box-control}/test/index.d.ts +0 -0
- package/build-types/border-box-control/test/index.d.ts.map +1 -0
- package/build-types/border-box-control/test/utils.d.ts +2 -0
- package/build-types/border-box-control/test/utils.d.ts.map +1 -0
- package/build-types/box-control/all-input-control.d.ts +4 -0
- package/build-types/box-control/all-input-control.d.ts.map +1 -0
- package/build-types/box-control/axial-input-controls.d.ts +4 -0
- package/build-types/box-control/axial-input-controls.d.ts.map +1 -0
- package/build-types/box-control/icon.d.ts +8 -0
- package/build-types/box-control/icon.d.ts.map +1 -0
- package/build-types/box-control/index.d.ts +31 -0
- package/build-types/box-control/index.d.ts.map +1 -0
- package/build-types/box-control/input-controls.d.ts +4 -0
- package/build-types/box-control/input-controls.d.ts.map +1 -0
- package/build-types/box-control/linked-button.d.ts +9 -0
- package/build-types/box-control/linked-button.d.ts.map +1 -0
- package/build-types/box-control/styles/box-control-icon-styles.d.ts +42 -0
- package/build-types/box-control/styles/box-control-icon-styles.d.ts.map +1 -0
- package/build-types/box-control/styles/box-control-styles.d.ts +42 -0
- package/build-types/box-control/styles/box-control-styles.d.ts.map +1 -0
- package/build-types/box-control/styles/box-control-visualizer-styles.d.ts +46 -0
- package/build-types/box-control/styles/box-control-visualizer-styles.d.ts.map +1 -0
- package/build-types/box-control/test/index.d.ts +2 -0
- package/build-types/box-control/test/index.d.ts.map +1 -0
- package/build-types/box-control/types.d.ts +99 -0
- package/build-types/box-control/types.d.ts.map +1 -0
- package/build-types/box-control/unit-control.d.ts +4 -0
- package/build-types/box-control/unit-control.d.ts.map +1 -0
- package/build-types/box-control/utils.d.ts +84 -0
- package/build-types/box-control/utils.d.ts.map +1 -0
- package/build-types/color-palette/index.d.ts +3 -1
- package/build-types/color-palette/index.d.ts.map +1 -1
- package/build-types/color-palette/stories/index.d.ts +6 -2
- package/build-types/color-palette/stories/index.d.ts.map +1 -1
- package/build-types/color-palette/types.d.ts +8 -0
- package/build-types/color-palette/types.d.ts.map +1 -1
- package/build-types/combobox-control/index.d.ts +51 -0
- package/build-types/combobox-control/index.d.ts.map +1 -0
- package/build-types/combobox-control/stories/index.d.ts +18 -0
- package/build-types/combobox-control/stories/index.d.ts.map +1 -0
- package/build-types/combobox-control/styles.d.ts +8 -0
- package/build-types/combobox-control/styles.d.ts.map +1 -0
- package/build-types/combobox-control/test/index.d.ts +2 -0
- package/build-types/combobox-control/test/index.d.ts.map +1 -0
- package/build-types/combobox-control/types.d.ts +62 -0
- package/build-types/combobox-control/types.d.ts.map +1 -0
- package/build-types/date-time/utils.d.ts +1 -1
- package/build-types/focal-point-picker/styles/focal-point-picker-style.d.ts +1 -1
- package/build-types/focal-point-picker/utils.d.ts +3 -3
- package/build-types/font-size-picker/utils.d.ts +2 -2
- package/build-types/input-control/reducer/reducer.d.ts +3 -3
- package/build-types/input-control/utils.d.ts +1 -1
- package/build-types/menu-items-choice/index.d.ts +38 -0
- package/build-types/menu-items-choice/index.d.ts.map +1 -0
- package/build-types/menu-items-choice/stories/index.d.ts +12 -0
- package/build-types/menu-items-choice/stories/index.d.ts.map +1 -0
- package/build-types/menu-items-choice/types.d.ts +53 -0
- package/build-types/menu-items-choice/types.d.ts.map +1 -0
- package/build-types/modal/index.d.ts.map +1 -1
- package/build-types/modal/types.d.ts +2 -0
- package/build-types/modal/types.d.ts.map +1 -1
- package/build-types/panel/header.d.ts +13 -0
- package/build-types/panel/header.d.ts.map +1 -0
- package/build-types/panel/index.d.ts +21 -0
- package/build-types/panel/index.d.ts.map +1 -0
- package/build-types/panel/row.d.ts +12 -0
- package/build-types/panel/row.d.ts.map +1 -0
- package/build-types/panel/test/header.d.ts +2 -0
- package/build-types/panel/test/header.d.ts.map +1 -0
- package/build-types/panel/test/index.d.ts +2 -0
- package/build-types/{base-field → panel}/test/index.d.ts.map +1 -1
- package/build-types/panel/test/row.d.ts +2 -0
- package/build-types/panel/test/row.d.ts.map +1 -0
- package/build-types/panel/types.d.ts +38 -0
- package/build-types/panel/types.d.ts.map +1 -0
- package/build-types/popover/index.d.ts.map +1 -1
- package/build-types/popover/overlay-middlewares.d.ts +9 -0
- package/build-types/popover/overlay-middlewares.d.ts.map +1 -0
- package/build-types/popover/stories/index.d.ts.map +1 -1
- package/build-types/popover/types.d.ts +3 -2
- package/build-types/popover/types.d.ts.map +1 -1
- package/build-types/popover/utils.d.ts +12 -4
- package/build-types/popover/utils.d.ts.map +1 -1
- package/build-types/query-controls/terms.d.ts +1 -1
- package/build-types/range-control/utils.d.ts +4 -4
- package/build-types/resizable-box/resize-tooltip/styles/resize-tooltip.styles.d.ts +5 -4
- package/build-types/resizable-box/resize-tooltip/styles/resize-tooltip.styles.d.ts.map +1 -1
- package/build-types/resizable-box/resize-tooltip/utils.d.ts +6 -6
- package/build-types/toolbar/index.d.ts +7 -0
- package/build-types/toolbar/index.d.ts.map +1 -0
- package/build-types/toolbar/stories/index.d.ts +14 -0
- package/build-types/toolbar/stories/index.d.ts.map +1 -0
- package/build-types/toolbar/test/index.d.ts +2 -0
- package/build-types/toolbar/test/index.d.ts.map +1 -0
- package/build-types/toolbar/test/toolbar-group.d.ts +2 -0
- package/build-types/toolbar/test/toolbar-group.d.ts.map +1 -0
- package/build-types/toolbar/toolbar/index.d.ts +25 -0
- package/build-types/toolbar/toolbar/index.d.ts.map +1 -0
- package/build-types/toolbar/toolbar/toolbar-container.d.ts +5 -0
- package/build-types/toolbar/toolbar/toolbar-container.d.ts.map +1 -0
- package/build-types/toolbar/toolbar/types.d.ts +15 -0
- package/build-types/toolbar/toolbar/types.d.ts.map +1 -0
- package/build-types/toolbar/toolbar-button/index.d.ts +12 -0
- package/build-types/toolbar/toolbar-button/index.d.ts.map +1 -0
- package/build-types/toolbar/toolbar-button/toolbar-button-container.d.ts +3 -0
- package/build-types/toolbar/toolbar-button/toolbar-button-container.d.ts.map +1 -0
- package/build-types/toolbar/toolbar-context/index.d.ts +3 -0
- package/build-types/toolbar/toolbar-context/index.d.ts.map +1 -0
- package/build-types/toolbar/toolbar-dropdown-menu/index.d.ts +3 -0
- package/build-types/toolbar/toolbar-dropdown-menu/index.d.ts.map +1 -0
- package/build-types/toolbar/toolbar-group/index.d.ts +39 -0
- package/build-types/toolbar/toolbar-group/index.d.ts.map +1 -0
- package/build-types/toolbar/toolbar-group/toolbar-group-collapsed.d.ts +7 -0
- package/build-types/toolbar/toolbar-group/toolbar-group-collapsed.d.ts.map +1 -0
- package/build-types/toolbar/toolbar-group/toolbar-group-container.d.ts +7 -0
- package/build-types/toolbar/toolbar-group/toolbar-group-container.d.ts.map +1 -0
- package/build-types/toolbar/toolbar-item/index.d.ts +7 -0
- package/build-types/toolbar/toolbar-item/index.d.ts.map +1 -0
- package/build-types/tools-panel/stories/index.d.ts +17 -0
- package/build-types/tools-panel/stories/index.d.ts.map +1 -0
- package/build-types/tools-panel/tools-panel/component.d.ts +54 -2
- package/build-types/tools-panel/tools-panel/component.d.ts.map +1 -1
- package/build-types/tools-panel/tools-panel/hook.d.ts +2 -1
- package/build-types/tools-panel/tools-panel/hook.d.ts.map +1 -1
- package/build-types/tools-panel/tools-panel-header/component.d.ts.map +1 -1
- package/build-types/tools-panel/tools-panel-header/hook.d.ts +2 -1
- package/build-types/tools-panel/tools-panel-header/hook.d.ts.map +1 -1
- package/build-types/tools-panel/tools-panel-item/component.d.ts +2 -2
- package/build-types/tools-panel/tools-panel-item/component.d.ts.map +1 -1
- package/build-types/tools-panel/tools-panel-item/hook.d.ts.map +1 -1
- package/build-types/tools-panel/types.d.ts +42 -15
- package/build-types/tools-panel/types.d.ts.map +1 -1
- package/build-types/tree-grid/cell.d.ts +13 -0
- package/build-types/tree-grid/cell.d.ts.map +1 -0
- package/build-types/tree-grid/index.d.ts +70 -0
- package/build-types/tree-grid/index.d.ts.map +1 -0
- package/build-types/tree-grid/item.d.ts +12 -0
- package/build-types/tree-grid/item.d.ts.map +1 -0
- package/build-types/tree-grid/roving-tab-index-context.d.ts +10 -0
- package/build-types/tree-grid/roving-tab-index-context.d.ts.map +1 -0
- package/build-types/tree-grid/roving-tab-index-item.d.ts +5 -0
- package/build-types/tree-grid/roving-tab-index-item.d.ts.map +1 -0
- package/build-types/tree-grid/roving-tab-index.d.ts +10 -0
- package/build-types/tree-grid/roving-tab-index.d.ts.map +1 -0
- package/build-types/tree-grid/row.d.ts +12 -0
- package/build-types/tree-grid/row.d.ts.map +1 -0
- package/build-types/tree-grid/stories/index.d.ts +13 -0
- package/build-types/tree-grid/stories/index.d.ts.map +1 -0
- package/build-types/tree-grid/test/cell.d.ts +2 -0
- package/build-types/tree-grid/test/cell.d.ts.map +1 -0
- package/build-types/tree-grid/test/index.d.ts +2 -0
- package/build-types/tree-grid/test/index.d.ts.map +1 -0
- package/build-types/tree-grid/test/roving-tab-index-item.d.ts +2 -0
- package/build-types/tree-grid/test/roving-tab-index-item.d.ts.map +1 -0
- package/build-types/tree-grid/test/roving-tab-index.d.ts +2 -0
- package/build-types/tree-grid/test/roving-tab-index.d.ts.map +1 -0
- package/build-types/tree-grid/test/row.d.ts +2 -0
- package/build-types/tree-grid/test/row.d.ts.map +1 -0
- package/build-types/tree-grid/types.d.ts +109 -0
- package/build-types/tree-grid/types.d.ts.map +1 -0
- package/build-types/ui/context/context-connect.d.ts +7 -7
- package/build-types/ui/context/get-styled-class-name-from-key.d.ts +1 -1
- package/build-types/ui/utils/get-valid-children.d.ts +1 -1
- package/build-types/ui/utils/space.d.ts +1 -1
- package/build-types/unit-control/index.d.ts +1 -1
- package/build-types/unit-control/utils.d.ts +20 -20
- package/build-types/utils/events.d.ts +2 -2
- package/build-types/utils/hooks/use-controlled-state.d.ts +1 -1
- package/build-types/utils/hooks/use-controlled-state.d.ts.map +1 -1
- package/build-types/utils/hooks/use-controlled-value.d.ts +4 -4
- package/build-types/utils/hooks/use-latest-ref.d.ts +1 -1
- package/build-types/utils/unit-values.d.ts +3 -3
- package/package.json +19 -19
- package/src/alignment-matrix-control/utils.tsx +4 -4
- package/src/angle-picker-control/README.md +17 -14
- package/src/angle-picker-control/{angle-circle.js → angle-circle.tsx} +44 -12
- package/src/angle-picker-control/{index.js → index.tsx} +54 -10
- package/src/angle-picker-control/stories/index.tsx +57 -0
- package/src/angle-picker-control/styles/{angle-picker-control-styles.js → angle-picker-control-styles.tsx} +5 -1
- package/src/angle-picker-control/types.ts +29 -0
- package/src/autocomplete/autocompleter-ui.native.js +1 -0
- package/src/base-control/hooks.ts +1 -1
- package/src/border-box-control/test/{index.js → index.tsx} +76 -102
- package/src/border-box-control/test/{utils.js → utils.ts} +20 -0
- package/src/border-box-control/utils.ts +1 -1
- package/src/box-control/README.md +17 -26
- package/src/box-control/{all-input-control.js → all-input-control.tsx} +10 -6
- package/src/box-control/{axial-input-controls.js → axial-input-controls.tsx} +29 -24
- package/src/box-control/{icon.js → icon.tsx} +9 -4
- package/src/box-control/{index.js → index.tsx} +43 -8
- package/src/box-control/{input-controls.js → input-controls.tsx} +26 -16
- package/src/box-control/{linked-button.js → linked-button.tsx} +4 -1
- package/src/box-control/styles/{box-control-icon-styles.js → box-control-icon-styles.ts} +1 -1
- package/src/box-control/styles/{box-control-styles.js → box-control-styles.ts} +10 -2
- package/src/box-control/styles/{box-control-visualizer-styles.js → box-control-visualizer-styles.ts} +6 -2
- package/src/box-control/test/{index.js → index.tsx} +12 -9
- package/src/box-control/types.ts +121 -0
- package/src/box-control/{unit-control.js → unit-control.tsx} +9 -2
- package/src/box-control/{utils.js → utils.ts} +47 -38
- package/src/button/test/index.tsx +38 -30
- package/src/color-palette/README.md +7 -0
- package/src/color-palette/index.tsx +6 -1
- package/src/color-palette/types.ts +8 -0
- package/src/combobox-control/README.md +8 -15
- package/src/combobox-control/{index.js → index.tsx} +91 -19
- package/src/combobox-control/stories/index.tsx +114 -0
- package/src/combobox-control/styles.ts +4 -1
- package/src/combobox-control/test/{index.js → index.tsx} +9 -7
- package/src/combobox-control/types.ts +69 -0
- package/src/custom-gradient-picker/index.js +0 -1
- package/src/custom-select-control/stories/index.js +1 -1
- package/src/date-time/time/index.tsx +1 -1
- package/src/date-time/utils.ts +1 -1
- package/src/draggable/index.tsx +2 -2
- package/src/dropdown-menu/test/index.js +3 -11
- package/src/focal-point-picker/utils.ts +3 -3
- package/src/font-size-picker/utils.ts +2 -2
- package/src/gradient-picker/README.md +8 -0
- package/src/gradient-picker/index.js +6 -1
- package/src/input-control/reducer/reducer.ts +5 -5
- package/src/input-control/utils.ts +1 -1
- package/src/menu-items-choice/index.tsx +83 -0
- package/src/menu-items-choice/stories/index.tsx +79 -0
- package/src/menu-items-choice/types.ts +54 -0
- package/src/modal/index.tsx +45 -1
- package/src/modal/style.scss +8 -0
- package/src/modal/types.ts +2 -0
- package/src/palette-edit/index.js +4 -1
- package/src/panel/README.md +2 -2
- package/src/panel/header.tsx +20 -0
- package/src/panel/index.tsx +48 -0
- package/src/panel/row.tsx +37 -0
- package/src/panel/stories/index.js +22 -0
- package/src/panel/test/__snapshots__/{header.js.snap → header.tsx.snap} +0 -0
- package/src/panel/test/__snapshots__/{index.js.snap → index.tsx.snap} +0 -0
- package/src/panel/test/__snapshots__/{row.js.snap → row.tsx.snap} +0 -0
- package/src/panel/test/{header.js → header.tsx} +1 -1
- package/src/panel/test/{index.js → index.tsx} +6 -4
- package/src/panel/test/{row.js → row.tsx} +4 -2
- package/src/panel/types.ts +38 -0
- package/src/popover/README.md +4 -1
- package/src/popover/index.tsx +17 -1
- package/src/popover/overlay-middlewares.tsx +29 -0
- package/src/popover/stories/index.tsx +7 -1
- package/src/popover/test/index.tsx +29 -21
- package/src/popover/types.ts +4 -2
- package/src/popover/utils.ts +39 -3
- package/src/query-controls/terms.ts +1 -1
- package/src/range-control/utils.ts +4 -4
- package/src/resizable-box/resize-tooltip/styles/{resize-tooltip.styles.js → resize-tooltip.styles.ts} +0 -0
- package/src/resizable-box/resize-tooltip/utils.ts +14 -14
- package/src/snackbar/index.tsx +2 -2
- package/src/toolbar/stories/{index.js → index.tsx} +39 -26
- package/src/toolbar/test/{index.js → index.tsx} +0 -0
- package/src/toolbar/test/{toolbar-group.js → toolbar-group.tsx} +2 -2
- package/src/toolbar/toolbar/README.md +7 -2
- package/src/toolbar/toolbar/{index.js → index.tsx} +33 -12
- package/src/toolbar/toolbar/{toolbar-container.js → toolbar-container.tsx} +9 -2
- package/src/toolbar/toolbar/types.ts +15 -0
- package/src/toolbar/toolbar-button/index.js +2 -0
- package/src/toolbar/toolbar-button/toolbar-button-container.js +2 -0
- package/src/toolbar/toolbar-context/index.js +2 -0
- package/src/toolbar/toolbar-dropdown-menu/index.js +2 -0
- package/src/toolbar/toolbar-group/index.js +2 -0
- package/src/toolbar/toolbar-group/toolbar-group-collapsed.js +2 -0
- package/src/toolbar/toolbar-group/toolbar-group-container.js +2 -0
- package/src/toolbar/toolbar-item/index.js +2 -0
- package/src/tools-panel/stories/{index.js → index.tsx} +196 -95
- package/src/tools-panel/test/index.js +6 -6
- package/src/tools-panel/tools-panel/README.md +12 -4
- package/src/tools-panel/tools-panel/component.tsx +57 -3
- package/src/tools-panel/tools-panel/hook.ts +4 -2
- package/src/tools-panel/tools-panel-header/README.md +7 -0
- package/src/tools-panel/tools-panel-header/component.tsx +2 -1
- package/src/tools-panel/tools-panel-header/hook.ts +6 -4
- package/src/tools-panel/tools-panel-item/README.md +6 -4
- package/src/tools-panel/tools-panel-item/component.tsx +4 -4
- package/src/tools-panel/tools-panel-item/hook.ts +4 -2
- package/src/tools-panel/types.ts +43 -15
- package/src/tree-grid/README.md +18 -58
- package/src/tree-grid/cell.tsx +41 -0
- package/src/tree-grid/{index.js → index.tsx} +111 -35
- package/src/tree-grid/item.tsx +32 -0
- package/src/tree-grid/{roving-tab-index-context.js → roving-tab-index-context.ts} +9 -1
- package/src/tree-grid/roving-tab-index-item.tsx +50 -0
- package/src/tree-grid/{roving-tab-index.js → roving-tab-index.tsx} +7 -5
- package/src/tree-grid/row.tsx +47 -0
- package/src/tree-grid/stories/index.tsx +144 -0
- package/src/tree-grid/test/__snapshots__/{cell.js.snap → cell.tsx.snap} +0 -0
- package/src/tree-grid/test/__snapshots__/{index.js.snap → index.tsx.snap} +0 -0
- package/src/tree-grid/test/__snapshots__/{roving-tab-index-item.js.snap → roving-tab-index-item.tsx.snap} +0 -0
- package/src/tree-grid/test/__snapshots__/{roving-tab-index.js.snap → roving-tab-index.tsx.snap} +0 -0
- package/src/tree-grid/test/__snapshots__/{row.js.snap → row.tsx.snap} +0 -0
- package/src/tree-grid/test/{cell.js → cell.tsx} +7 -4
- package/src/tree-grid/test/{index.js → index.tsx} +13 -5
- package/src/tree-grid/test/{roving-tab-index-item.js → roving-tab-index-item.tsx} +7 -4
- package/src/tree-grid/test/{roving-tab-index.js → roving-tab-index.tsx} +0 -0
- package/src/tree-grid/test/{row.js → row.tsx} +4 -4
- package/src/tree-grid/types.ts +116 -0
- package/src/ui/context/context-connect.ts +7 -7
- package/src/ui/context/get-styled-class-name-from-key.ts +1 -1
- package/src/ui/utils/get-valid-children.ts +1 -1
- package/src/ui/utils/space.ts +1 -1
- package/src/unit-control/index.tsx +2 -2
- package/src/unit-control/utils.ts +20 -20
- package/src/utils/events.ts +4 -4
- package/src/utils/hooks/use-controlled-state.js +2 -2
- package/src/utils/hooks/use-controlled-value.ts +4 -4
- package/src/utils/hooks/use-latest-ref.ts +1 -1
- package/src/utils/unit-values.ts +3 -3
- package/tsconfig.json +1 -7
- package/tsconfig.tsbuildinfo +1 -1
- package/build/base-field/hook.js +0 -54
- package/build/base-field/hook.js.map +0 -1
- package/build/base-field/index.js +0 -14
- package/build/base-field/index.js.map +0 -1
- package/build/base-field/styles.js +0 -33
- package/build/base-field/styles.js.map +0 -1
- package/build/resizable-box/styles/resizable-box.styles.js +0 -2
- package/build-module/base-field/hook.js +0 -37
- package/build-module/base-field/hook.js.map +0 -1
- package/build-module/base-field/index.js +0 -2
- package/build-module/base-field/index.js.map +0 -1
- package/build-module/base-field/styles.js +0 -18
- package/build-module/base-field/styles.js.map +0 -1
- package/build-module/resizable-box/styles/resizable-box.styles.js +0 -2
- package/build-types/base-field/hook.d.ts +0 -270
- package/build-types/base-field/hook.d.ts.map +0 -1
- package/build-types/base-field/index.d.ts +0 -2
- package/build-types/base-field/index.d.ts.map +0 -1
- package/build-types/base-field/styles.d.ts +0 -6
- package/build-types/base-field/styles.d.ts.map +0 -1
- package/build-types/base-field/types.d.ts +0 -29
- package/build-types/base-field/types.d.ts.map +0 -1
- package/build-types/resizable-box/styles/resizable-box.styles.d.ts +0 -1
- package/build-types/resizable-box/styles/resizable-box.styles.d.ts.map +0 -1
- package/src/angle-picker-control/stories/index.js +0 -29
- package/src/base-field/README.md +0 -66
- package/src/base-field/hook.ts +0 -51
- package/src/base-field/index.ts +0 -1
- package/src/base-field/styles.ts +0 -86
- package/src/base-field/test/__snapshots__/index.tsx.snap +0 -141
- package/src/base-field/test/index.tsx +0 -84
- package/src/base-field/types.ts +0 -29
- package/src/combobox-control/stories/index.js +0 -339
- package/src/menu-items-choice/index.js +0 -43
- package/src/panel/header.js +0 -10
- package/src/panel/index.js +0 -26
- package/src/panel/row.js +0 -20
- package/src/resizable-box/styles/resizable-box.styles.js +0 -0
- package/src/tools-panel/stories/utils/tools-panel-with-item-group-slot.js +0 -246
- package/src/tree-grid/cell.js +0 -24
- package/src/tree-grid/item.js +0 -20
- package/src/tree-grid/roving-tab-index-item.js +0 -33
- package/src/tree-grid/row.js +0 -31
- package/src/tree-grid/stories/index.js +0 -106
|
@@ -30,82 +30,73 @@ const Example = () => {
|
|
|
30
30
|
```
|
|
31
31
|
|
|
32
32
|
## Props
|
|
33
|
-
### allowReset
|
|
33
|
+
### `allowReset`: `boolean`
|
|
34
34
|
|
|
35
35
|
If this property is true, a button to reset the box control is rendered.
|
|
36
36
|
|
|
37
|
-
- Type: `Boolean`
|
|
38
37
|
- Required: No
|
|
39
38
|
- Default: `true`
|
|
40
39
|
|
|
41
|
-
### splitOnAxis
|
|
40
|
+
### `splitOnAxis`: `boolean`
|
|
42
41
|
|
|
43
42
|
If this property is true, when the box control is unlinked, vertical and horizontal controls can be used instead of updating individual sides.
|
|
44
43
|
|
|
45
|
-
- Type: `Boolean`
|
|
46
44
|
- Required: No
|
|
47
45
|
- Default: `false`
|
|
48
46
|
|
|
49
|
-
### inputProps
|
|
47
|
+
### `inputProps`: `object`
|
|
50
48
|
|
|
51
|
-
Props for the internal [
|
|
49
|
+
Props for the internal [UnitControl](../unit-control) components.
|
|
52
50
|
|
|
53
|
-
- Type: `Object`
|
|
54
51
|
- Required: No
|
|
52
|
+
- Default: `{ min: 0 }`
|
|
55
53
|
|
|
56
|
-
### label
|
|
54
|
+
### `label`: `string`
|
|
57
55
|
|
|
58
|
-
Heading label for
|
|
56
|
+
Heading label for the control.
|
|
59
57
|
|
|
60
|
-
- Type: `String`
|
|
61
58
|
- Required: No
|
|
62
|
-
- Default: `Box Control`
|
|
59
|
+
- Default: `__( 'Box Control' )`
|
|
63
60
|
|
|
64
|
-
### onChange
|
|
61
|
+
### `onChange`: `(next: BoxControlValue) => void`
|
|
65
62
|
|
|
66
63
|
A callback function when an input value changes.
|
|
67
64
|
|
|
68
|
-
- Type: `Function`
|
|
69
65
|
- Required: Yes
|
|
70
66
|
|
|
71
|
-
### resetValues
|
|
67
|
+
### `resetValues`: `object`
|
|
72
68
|
|
|
73
69
|
The `top`, `right`, `bottom`, and `left` box dimension values to use when the control is reset.
|
|
74
70
|
|
|
75
|
-
- Type: `Object`
|
|
76
71
|
- Required: No
|
|
72
|
+
- Default: `{ top: undefined, right: undefined, bottom: undefined, left: undefined }`
|
|
77
73
|
|
|
78
|
-
### sides
|
|
74
|
+
### `sides`: `string[]`
|
|
79
75
|
|
|
80
|
-
Collection of sides to allow control of. If omitted or empty, all sides will be available.
|
|
76
|
+
Collection of sides to allow control of. If omitted or empty, all sides will be available. Allowed values are "top", "right", "bottom", "left", "vertical", and "horizontal".
|
|
81
77
|
|
|
82
|
-
- Type: `Array<Object>`
|
|
83
78
|
- Required: No
|
|
84
79
|
|
|
85
|
-
### units
|
|
80
|
+
### `units`: `WPUnitControlUnit[]`
|
|
86
81
|
|
|
87
82
|
Collection of available units which are compatible with [UnitControl](../unit-control).
|
|
88
83
|
|
|
89
|
-
- Type: `Array<Object>`
|
|
90
84
|
- Required: No
|
|
91
85
|
|
|
92
|
-
### values
|
|
86
|
+
### `values`: `object`
|
|
93
87
|
|
|
94
88
|
The `top`, `right`, `bottom`, and `left` box dimension values.
|
|
95
89
|
|
|
96
|
-
- Type: `Object`
|
|
97
90
|
- Required: No
|
|
98
91
|
|
|
99
|
-
### onMouseOver
|
|
92
|
+
### `onMouseOver`: `function`
|
|
100
93
|
|
|
101
94
|
A handler for onMouseOver events.
|
|
102
95
|
|
|
103
|
-
- Type: `Function`
|
|
104
96
|
- Required: No
|
|
105
97
|
|
|
106
|
-
### onMouseOut
|
|
98
|
+
### `onMouseOut`: `function`
|
|
107
99
|
|
|
108
100
|
A handler for onMouseOut events.
|
|
109
101
|
|
|
110
|
-
- Type: `Function`
|
|
111
102
|
- Required: No
|
|
@@ -1,6 +1,8 @@
|
|
|
1
1
|
/**
|
|
2
2
|
* Internal dependencies
|
|
3
3
|
*/
|
|
4
|
+
import type { UnitControlProps } from '../unit-control/types';
|
|
5
|
+
import type { BoxControlInputControlProps } from './types';
|
|
4
6
|
import UnitControl from './unit-control';
|
|
5
7
|
import {
|
|
6
8
|
LABELS,
|
|
@@ -22,18 +24,20 @@ export default function AllInputControl( {
|
|
|
22
24
|
selectedUnits,
|
|
23
25
|
setSelectedUnits,
|
|
24
26
|
...props
|
|
25
|
-
} ) {
|
|
27
|
+
}: BoxControlInputControlProps ) {
|
|
26
28
|
const allValue = getAllValue( values, selectedUnits, sides );
|
|
27
29
|
const hasValues = isValuesDefined( values );
|
|
28
30
|
const isMixed = hasValues && isValuesMixed( values, selectedUnits, sides );
|
|
29
|
-
const allPlaceholder = isMixed ? LABELS.mixed :
|
|
31
|
+
const allPlaceholder = isMixed ? LABELS.mixed : undefined;
|
|
30
32
|
|
|
31
|
-
const handleOnFocus
|
|
33
|
+
const handleOnFocus: React.FocusEventHandler< HTMLInputElement > = (
|
|
34
|
+
event
|
|
35
|
+
) => {
|
|
32
36
|
onFocus( event, { side: 'all' } );
|
|
33
37
|
};
|
|
34
38
|
|
|
35
|
-
const handleOnChange = ( next ) => {
|
|
36
|
-
const isNumeric = ! isNaN( parseFloat( next ) );
|
|
39
|
+
const handleOnChange: UnitControlProps[ 'onChange' ] = ( next ) => {
|
|
40
|
+
const isNumeric = next !== undefined && ! isNaN( parseFloat( next ) );
|
|
37
41
|
const nextValue = isNumeric ? next : undefined;
|
|
38
42
|
const nextValues = applyValueToSides( values, nextValue, sides );
|
|
39
43
|
|
|
@@ -42,7 +46,7 @@ export default function AllInputControl( {
|
|
|
42
46
|
|
|
43
47
|
// Set selected unit so it can be used as fallback by unlinked controls
|
|
44
48
|
// when individual sides do not have a value containing a unit.
|
|
45
|
-
const handleOnUnitChange = ( unit ) => {
|
|
49
|
+
const handleOnUnitChange: UnitControlProps[ 'onUnitChange' ] = ( unit ) => {
|
|
46
50
|
const newUnits = applyValueToSides( selectedUnits, unit, sides );
|
|
47
51
|
setSelectedUnits( newUnits );
|
|
48
52
|
};
|
|
@@ -5,8 +5,10 @@ import { parseQuantityAndUnitFromRawValue } from '../unit-control/utils';
|
|
|
5
5
|
import UnitControl from './unit-control';
|
|
6
6
|
import { LABELS } from './utils';
|
|
7
7
|
import { Layout } from './styles/box-control-styles';
|
|
8
|
+
import type { BoxControlInputControlProps } from './types';
|
|
8
9
|
|
|
9
|
-
const groupedSides = [ 'vertical', 'horizontal' ];
|
|
10
|
+
const groupedSides = [ 'vertical', 'horizontal' ] as const;
|
|
11
|
+
type GroupedSide = typeof groupedSides[ number ];
|
|
10
12
|
|
|
11
13
|
export default function AxialInputControls( {
|
|
12
14
|
onChange,
|
|
@@ -18,15 +20,17 @@ export default function AxialInputControls( {
|
|
|
18
20
|
setSelectedUnits,
|
|
19
21
|
sides,
|
|
20
22
|
...props
|
|
21
|
-
} ) {
|
|
22
|
-
const createHandleOnFocus =
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
23
|
+
}: BoxControlInputControlProps ) {
|
|
24
|
+
const createHandleOnFocus =
|
|
25
|
+
( side: GroupedSide ) =>
|
|
26
|
+
( event: React.FocusEvent< HTMLInputElement > ) => {
|
|
27
|
+
if ( ! onFocus ) {
|
|
28
|
+
return;
|
|
29
|
+
}
|
|
30
|
+
onFocus( event, { side } );
|
|
31
|
+
};
|
|
28
32
|
|
|
29
|
-
const createHandleOnHoverOn = ( side ) => () => {
|
|
33
|
+
const createHandleOnHoverOn = ( side: GroupedSide ) => () => {
|
|
30
34
|
if ( ! onHoverOn ) {
|
|
31
35
|
return;
|
|
32
36
|
}
|
|
@@ -44,7 +48,7 @@ export default function AxialInputControls( {
|
|
|
44
48
|
}
|
|
45
49
|
};
|
|
46
50
|
|
|
47
|
-
const createHandleOnHoverOff = ( side ) => () => {
|
|
51
|
+
const createHandleOnHoverOff = ( side: GroupedSide ) => () => {
|
|
48
52
|
if ( ! onHoverOff ) {
|
|
49
53
|
return;
|
|
50
54
|
}
|
|
@@ -62,12 +66,12 @@ export default function AxialInputControls( {
|
|
|
62
66
|
}
|
|
63
67
|
};
|
|
64
68
|
|
|
65
|
-
const createHandleOnChange = ( side ) => ( next ) => {
|
|
69
|
+
const createHandleOnChange = ( side: GroupedSide ) => ( next?: string ) => {
|
|
66
70
|
if ( ! onChange ) {
|
|
67
71
|
return;
|
|
68
72
|
}
|
|
69
73
|
const nextValues = { ...values };
|
|
70
|
-
const isNumeric = ! isNaN( parseFloat( next ) );
|
|
74
|
+
const isNumeric = next !== undefined && ! isNaN( parseFloat( next ) );
|
|
71
75
|
const nextValue = isNumeric ? next : undefined;
|
|
72
76
|
|
|
73
77
|
if ( side === 'vertical' ) {
|
|
@@ -83,21 +87,22 @@ export default function AxialInputControls( {
|
|
|
83
87
|
onChange( nextValues );
|
|
84
88
|
};
|
|
85
89
|
|
|
86
|
-
const createHandleOnUnitChange =
|
|
87
|
-
|
|
90
|
+
const createHandleOnUnitChange =
|
|
91
|
+
( side: GroupedSide ) => ( next?: string ) => {
|
|
92
|
+
const newUnits = { ...selectedUnits };
|
|
88
93
|
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
94
|
+
if ( side === 'vertical' ) {
|
|
95
|
+
newUnits.top = next;
|
|
96
|
+
newUnits.bottom = next;
|
|
97
|
+
}
|
|
93
98
|
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
99
|
+
if ( side === 'horizontal' ) {
|
|
100
|
+
newUnits.left = next;
|
|
101
|
+
newUnits.right = next;
|
|
102
|
+
}
|
|
98
103
|
|
|
99
|
-
|
|
100
|
-
|
|
104
|
+
setSelectedUnits( newUnits );
|
|
105
|
+
};
|
|
101
106
|
|
|
102
107
|
// Filter sides if custom configuration provided, maintaining default order.
|
|
103
108
|
const filteredSides = sides?.length
|
|
@@ -1,6 +1,7 @@
|
|
|
1
1
|
/**
|
|
2
2
|
* Internal dependencies
|
|
3
3
|
*/
|
|
4
|
+
import type { WordPressComponentProps } from '../ui/context';
|
|
4
5
|
import {
|
|
5
6
|
Root,
|
|
6
7
|
Viewbox,
|
|
@@ -9,6 +10,7 @@ import {
|
|
|
9
10
|
BottomStroke,
|
|
10
11
|
LeftStroke,
|
|
11
12
|
} from './styles/box-control-icon-styles';
|
|
13
|
+
import type { BoxControlIconProps, BoxControlProps } from './types';
|
|
12
14
|
|
|
13
15
|
const BASE_ICON_SIZE = 24;
|
|
14
16
|
|
|
@@ -17,11 +19,14 @@ export default function BoxControlIcon( {
|
|
|
17
19
|
side = 'all',
|
|
18
20
|
sides,
|
|
19
21
|
...props
|
|
20
|
-
} ) {
|
|
21
|
-
const isSideDisabled = (
|
|
22
|
-
|
|
22
|
+
}: WordPressComponentProps< BoxControlIconProps, 'span' > ) {
|
|
23
|
+
const isSideDisabled = (
|
|
24
|
+
value: NonNullable< BoxControlProps[ 'sides' ] >[ number ]
|
|
25
|
+
) => sides?.length && ! sides.includes( value );
|
|
23
26
|
|
|
24
|
-
const hasSide = (
|
|
27
|
+
const hasSide = (
|
|
28
|
+
value: NonNullable< BoxControlProps[ 'sides' ] >[ number ]
|
|
29
|
+
) => {
|
|
25
30
|
if ( isSideDisabled( value ) ) {
|
|
26
31
|
return false;
|
|
27
32
|
}
|
|
@@ -29,6 +29,11 @@ import {
|
|
|
29
29
|
isValuesDefined,
|
|
30
30
|
} from './utils';
|
|
31
31
|
import { useControlledState } from '../utils/hooks';
|
|
32
|
+
import type {
|
|
33
|
+
BoxControlIconProps,
|
|
34
|
+
BoxControlProps,
|
|
35
|
+
BoxControlValue,
|
|
36
|
+
} from './types';
|
|
32
37
|
|
|
33
38
|
const defaultInputProps = {
|
|
34
39
|
min: 0,
|
|
@@ -36,12 +41,38 @@ const defaultInputProps = {
|
|
|
36
41
|
|
|
37
42
|
const noop = () => {};
|
|
38
43
|
|
|
39
|
-
function useUniqueId( idProp ) {
|
|
44
|
+
function useUniqueId( idProp?: string ) {
|
|
40
45
|
const instanceId = useInstanceId( BoxControl, 'inspector-box-control' );
|
|
41
46
|
|
|
42
47
|
return idProp || instanceId;
|
|
43
48
|
}
|
|
44
|
-
|
|
49
|
+
|
|
50
|
+
/**
|
|
51
|
+
* BoxControl components let users set values for Top, Right, Bottom, and Left.
|
|
52
|
+
* This can be used as an input control for values like `padding` or `margin`.
|
|
53
|
+
*
|
|
54
|
+
* ```jsx
|
|
55
|
+
* import { __experimentalBoxControl as BoxControl } from '@wordpress/components';
|
|
56
|
+
* import { useState } from '@wordpress/element';
|
|
57
|
+
*
|
|
58
|
+
* const Example = () => {
|
|
59
|
+
* const [ values, setValues ] = useState( {
|
|
60
|
+
* top: '50px',
|
|
61
|
+
* left: '10%',
|
|
62
|
+
* right: '10%',
|
|
63
|
+
* bottom: '50px',
|
|
64
|
+
* } );
|
|
65
|
+
*
|
|
66
|
+
* return (
|
|
67
|
+
* <BoxControl
|
|
68
|
+
* values={ values }
|
|
69
|
+
* onChange={ ( nextValues ) => setValues( nextValues ) }
|
|
70
|
+
* />
|
|
71
|
+
* );
|
|
72
|
+
* };
|
|
73
|
+
* ```
|
|
74
|
+
*/
|
|
75
|
+
function BoxControl( {
|
|
45
76
|
id: idProp,
|
|
46
77
|
inputProps = defaultInputProps,
|
|
47
78
|
onChange = noop,
|
|
@@ -54,7 +85,7 @@ export default function BoxControl( {
|
|
|
54
85
|
resetValues = DEFAULT_VALUES,
|
|
55
86
|
onMouseOver,
|
|
56
87
|
onMouseOut,
|
|
57
|
-
} ) {
|
|
88
|
+
}: BoxControlProps ) {
|
|
58
89
|
const [ values, setValues ] = useControlledState( valuesProp, {
|
|
59
90
|
fallback: DEFAULT_VALUES,
|
|
60
91
|
} );
|
|
@@ -67,14 +98,14 @@ export default function BoxControl( {
|
|
|
67
98
|
! hasInitialValue || ! isValuesMixed( inputValues ) || hasOneSide
|
|
68
99
|
);
|
|
69
100
|
|
|
70
|
-
const [ side, setSide ] = useState(
|
|
101
|
+
const [ side, setSide ] = useState< BoxControlIconProps[ 'side' ] >(
|
|
71
102
|
getInitialSide( isLinked, splitOnAxis )
|
|
72
103
|
);
|
|
73
104
|
|
|
74
105
|
// Tracking selected units via internal state allows filtering of CSS unit
|
|
75
106
|
// only values from being saved while maintaining preexisting unit selection
|
|
76
107
|
// behaviour. Filtering CSS only values prevents invalid style values.
|
|
77
|
-
const [ selectedUnits, setSelectedUnits ] = useState( {
|
|
108
|
+
const [ selectedUnits, setSelectedUnits ] = useState< BoxControlValue >( {
|
|
78
109
|
top: parseQuantityAndUnitFromRawValue( valuesProp?.top )[ 1 ],
|
|
79
110
|
right: parseQuantityAndUnitFromRawValue( valuesProp?.right )[ 1 ],
|
|
80
111
|
bottom: parseQuantityAndUnitFromRawValue( valuesProp?.bottom )[ 1 ],
|
|
@@ -89,11 +120,14 @@ export default function BoxControl( {
|
|
|
89
120
|
setSide( getInitialSide( ! isLinked, splitOnAxis ) );
|
|
90
121
|
};
|
|
91
122
|
|
|
92
|
-
const handleOnFocus = (
|
|
123
|
+
const handleOnFocus = (
|
|
124
|
+
_event: React.FocusEvent< HTMLInputElement >,
|
|
125
|
+
{ side: nextSide }: { side: typeof side }
|
|
126
|
+
) => {
|
|
93
127
|
setSide( nextSide );
|
|
94
128
|
};
|
|
95
129
|
|
|
96
|
-
const handleOnChange = ( nextValues ) => {
|
|
130
|
+
const handleOnChange = ( nextValues: BoxControlValue ) => {
|
|
97
131
|
onChange( nextValues );
|
|
98
132
|
setValues( nextValues );
|
|
99
133
|
setIsDirty( true );
|
|
@@ -132,7 +166,7 @@ export default function BoxControl( {
|
|
|
132
166
|
<FlexItem>
|
|
133
167
|
<Button
|
|
134
168
|
className="component-box-control__reset-button"
|
|
135
|
-
|
|
169
|
+
variant="secondary"
|
|
136
170
|
isSmall
|
|
137
171
|
onClick={ handleOnReset }
|
|
138
172
|
disabled={ ! isDirty }
|
|
@@ -176,3 +210,4 @@ export default function BoxControl( {
|
|
|
176
210
|
}
|
|
177
211
|
|
|
178
212
|
export { applyValueToSides } from './utils';
|
|
213
|
+
export default BoxControl;
|
|
@@ -5,6 +5,8 @@ import UnitControl from './unit-control';
|
|
|
5
5
|
import { parseQuantityAndUnitFromRawValue } from '../unit-control/utils';
|
|
6
6
|
import { ALL_SIDES, LABELS } from './utils';
|
|
7
7
|
import { LayoutContainer, Layout } from './styles/box-control-styles';
|
|
8
|
+
import type { BoxControlInputControlProps, BoxControlValue } from './types';
|
|
9
|
+
import type { UnitControlProps } from '../unit-control/types';
|
|
8
10
|
|
|
9
11
|
const noop = () => {};
|
|
10
12
|
|
|
@@ -18,29 +20,33 @@ export default function BoxInputControls( {
|
|
|
18
20
|
setSelectedUnits,
|
|
19
21
|
sides,
|
|
20
22
|
...props
|
|
21
|
-
} ) {
|
|
22
|
-
const createHandleOnFocus =
|
|
23
|
-
|
|
24
|
-
|
|
23
|
+
}: BoxControlInputControlProps ) {
|
|
24
|
+
const createHandleOnFocus =
|
|
25
|
+
( side: keyof BoxControlValue ) =>
|
|
26
|
+
( event: React.FocusEvent< HTMLInputElement > ) => {
|
|
27
|
+
onFocus( event, { side } );
|
|
28
|
+
};
|
|
25
29
|
|
|
26
|
-
const createHandleOnHoverOn = ( side ) => () => {
|
|
30
|
+
const createHandleOnHoverOn = ( side: keyof BoxControlValue ) => () => {
|
|
27
31
|
onHoverOn( { [ side ]: true } );
|
|
28
32
|
};
|
|
29
33
|
|
|
30
|
-
const createHandleOnHoverOff = ( side ) => () => {
|
|
34
|
+
const createHandleOnHoverOff = ( side: keyof BoxControlValue ) => () => {
|
|
31
35
|
onHoverOff( { [ side ]: false } );
|
|
32
36
|
};
|
|
33
37
|
|
|
34
|
-
const handleOnChange = ( nextValues ) => {
|
|
38
|
+
const handleOnChange = ( nextValues: BoxControlValue ) => {
|
|
35
39
|
onChange( nextValues );
|
|
36
40
|
};
|
|
37
41
|
|
|
38
|
-
const createHandleOnChange
|
|
42
|
+
const createHandleOnChange: (
|
|
43
|
+
side: keyof BoxControlValue
|
|
44
|
+
) => UnitControlProps[ 'onChange' ] =
|
|
39
45
|
( side ) =>
|
|
40
46
|
( next, { event } ) => {
|
|
41
|
-
const { altKey } = event;
|
|
42
47
|
const nextValues = { ...values };
|
|
43
|
-
const isNumeric =
|
|
48
|
+
const isNumeric =
|
|
49
|
+
next !== undefined && ! isNaN( parseFloat( next ) );
|
|
44
50
|
const nextValue = isNumeric ? next : undefined;
|
|
45
51
|
|
|
46
52
|
nextValues[ side ] = nextValue;
|
|
@@ -49,7 +55,10 @@ export default function BoxInputControls( {
|
|
|
49
55
|
* Supports changing pair sides. For example, holding the ALT key
|
|
50
56
|
* when changing the TOP will also update BOTTOM.
|
|
51
57
|
*/
|
|
52
|
-
|
|
58
|
+
// @ts-expect-error - TODO: event.altKey is only present when the change event was
|
|
59
|
+
// triggered by a keyboard event. Should this feature be implemented differently so
|
|
60
|
+
// it also works with drag events?
|
|
61
|
+
if ( event.altKey ) {
|
|
53
62
|
switch ( side ) {
|
|
54
63
|
case 'top':
|
|
55
64
|
nextValues.bottom = nextValue;
|
|
@@ -69,11 +78,12 @@ export default function BoxInputControls( {
|
|
|
69
78
|
handleOnChange( nextValues );
|
|
70
79
|
};
|
|
71
80
|
|
|
72
|
-
const createHandleOnUnitChange =
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
81
|
+
const createHandleOnUnitChange =
|
|
82
|
+
( side: keyof BoxControlValue ) => ( next?: string ) => {
|
|
83
|
+
const newUnits = { ...selectedUnits };
|
|
84
|
+
newUnits[ side ] = next;
|
|
85
|
+
setSelectedUnits( newUnits );
|
|
86
|
+
};
|
|
77
87
|
|
|
78
88
|
// Filter sides if custom configuration provided, maintaining default order.
|
|
79
89
|
const filteredSides = sides?.length
|
|
@@ -10,7 +10,10 @@ import { __ } from '@wordpress/i18n';
|
|
|
10
10
|
import Button from '../button';
|
|
11
11
|
import Tooltip from '../tooltip';
|
|
12
12
|
|
|
13
|
-
export default function LinkedButton( {
|
|
13
|
+
export default function LinkedButton( {
|
|
14
|
+
isLinked,
|
|
15
|
+
...props
|
|
16
|
+
}: { isLinked?: boolean } & React.ComponentProps< typeof Button > ) {
|
|
14
17
|
const label = isLinked ? __( 'Unlink sides' ) : __( 'Link sides' );
|
|
15
18
|
|
|
16
19
|
return (
|
|
@@ -21,7 +21,7 @@ export const Viewbox = styled.span`
|
|
|
21
21
|
height: 100%;
|
|
22
22
|
`;
|
|
23
23
|
|
|
24
|
-
const strokeFocus = ( { isFocused } ) => {
|
|
24
|
+
const strokeFocus = ( { isFocused }: { isFocused: boolean } ) => {
|
|
25
25
|
return css( {
|
|
26
26
|
backgroundColor: 'currentColor',
|
|
27
27
|
opacity: isFocused ? 1 : 0.3,
|
|
@@ -9,6 +9,7 @@ import styled from '@emotion/styled';
|
|
|
9
9
|
import { Flex } from '../../flex';
|
|
10
10
|
import BaseUnitControl from '../../unit-control';
|
|
11
11
|
import { rtl } from '../../utils';
|
|
12
|
+
import type { BoxUnitControlProps } from '../types';
|
|
12
13
|
|
|
13
14
|
export const Root = styled.div`
|
|
14
15
|
box-sizing: border-box;
|
|
@@ -43,7 +44,11 @@ export const Layout = styled( Flex )`
|
|
|
43
44
|
justify-content: flex-start;
|
|
44
45
|
`;
|
|
45
46
|
|
|
46
|
-
const unitControlBorderRadiusStyles = ( {
|
|
47
|
+
const unitControlBorderRadiusStyles = ( {
|
|
48
|
+
isFirst,
|
|
49
|
+
isLast,
|
|
50
|
+
isOnly,
|
|
51
|
+
}: Pick< BoxUnitControlProps, 'isFirst' | 'isLast' | 'isOnly' > ) => {
|
|
47
52
|
if ( isFirst ) {
|
|
48
53
|
return rtl( { borderTopRightRadius: 0, borderBottomRightRadius: 0 } )();
|
|
49
54
|
}
|
|
@@ -59,7 +64,10 @@ const unitControlBorderRadiusStyles = ( { isFirst, isLast, isOnly } ) => {
|
|
|
59
64
|
} );
|
|
60
65
|
};
|
|
61
66
|
|
|
62
|
-
const unitControlMarginStyles = ( {
|
|
67
|
+
const unitControlMarginStyles = ( {
|
|
68
|
+
isFirst,
|
|
69
|
+
isOnly,
|
|
70
|
+
}: Pick< BoxUnitControlProps, 'isFirst' | 'isOnly' > ) => {
|
|
63
71
|
const marginLeft = isFirst || isOnly ? 0 : -1;
|
|
64
72
|
|
|
65
73
|
return rtl( { marginLeft } )();
|
package/src/box-control/styles/{box-control-visualizer-styles.js → box-control-visualizer-styles.ts}
RENAMED
|
@@ -9,7 +9,11 @@ import styled from '@emotion/styled';
|
|
|
9
9
|
*/
|
|
10
10
|
import { COLORS, rtl } from '../../utils';
|
|
11
11
|
|
|
12
|
-
const containerPositionStyles = ( {
|
|
12
|
+
const containerPositionStyles = ( {
|
|
13
|
+
isPositionAbsolute,
|
|
14
|
+
}: {
|
|
15
|
+
isPositionAbsolute: boolean;
|
|
16
|
+
} ) => {
|
|
13
17
|
if ( ! isPositionAbsolute ) return '';
|
|
14
18
|
|
|
15
19
|
return css`
|
|
@@ -39,7 +43,7 @@ export const Side = styled.div`
|
|
|
39
43
|
transition: opacity 120ms linear;
|
|
40
44
|
z-index: 1;
|
|
41
45
|
|
|
42
|
-
${ ( { isActive } ) =>
|
|
46
|
+
${ ( { isActive }: { isActive: boolean } ) =>
|
|
43
47
|
isActive &&
|
|
44
48
|
`
|
|
45
49
|
opacity: 0.3;
|
|
@@ -12,10 +12,11 @@ import { useState } from '@wordpress/element';
|
|
|
12
12
|
/**
|
|
13
13
|
* Internal dependencies
|
|
14
14
|
*/
|
|
15
|
-
import BoxControl from '
|
|
15
|
+
import BoxControl from '..';
|
|
16
|
+
import type { BoxControlProps, BoxControlValue } from '../types';
|
|
16
17
|
|
|
17
|
-
const Example = ( extraProps ) => {
|
|
18
|
-
const [ state, setState ] = useState();
|
|
18
|
+
const Example = ( extraProps: Omit< BoxControlProps, 'onChange' > ) => {
|
|
19
|
+
const [ state, setState ] = useState< BoxControlValue >();
|
|
19
20
|
|
|
20
21
|
return (
|
|
21
22
|
<BoxControl
|
|
@@ -29,7 +30,7 @@ const Example = ( extraProps ) => {
|
|
|
29
30
|
describe( 'BoxControl', () => {
|
|
30
31
|
describe( 'Basic rendering', () => {
|
|
31
32
|
it( 'should render a box control input', () => {
|
|
32
|
-
render( <BoxControl /> );
|
|
33
|
+
render( <BoxControl onChange={ () => {} } /> );
|
|
33
34
|
|
|
34
35
|
expect(
|
|
35
36
|
screen.getByRole( 'textbox', { name: 'Box Control' } )
|
|
@@ -39,7 +40,7 @@ describe( 'BoxControl', () => {
|
|
|
39
40
|
it( 'should update values when interacting with input', async () => {
|
|
40
41
|
const user = userEvent.setup();
|
|
41
42
|
|
|
42
|
-
render( <BoxControl /> );
|
|
43
|
+
render( <BoxControl onChange={ () => {} } /> );
|
|
43
44
|
|
|
44
45
|
const input = screen.getByRole( 'textbox', {
|
|
45
46
|
name: 'Box Control',
|
|
@@ -61,7 +62,7 @@ describe( 'BoxControl', () => {
|
|
|
61
62
|
it( 'should reset values when clicking Reset', async () => {
|
|
62
63
|
const user = userEvent.setup();
|
|
63
64
|
|
|
64
|
-
render( <BoxControl /> );
|
|
65
|
+
render( <BoxControl onChange={ () => {} } /> );
|
|
65
66
|
|
|
66
67
|
const input = screen.getByRole( 'textbox', {
|
|
67
68
|
name: 'Box Control',
|
|
@@ -238,7 +239,7 @@ describe( 'BoxControl', () => {
|
|
|
238
239
|
const user = userEvent.setup();
|
|
239
240
|
|
|
240
241
|
// Render control.
|
|
241
|
-
render( <BoxControl /> );
|
|
242
|
+
render( <BoxControl onChange={ () => {} } /> );
|
|
242
243
|
|
|
243
244
|
// Make unit selection on all input control.
|
|
244
245
|
await user.selectOptions(
|
|
@@ -270,7 +271,7 @@ describe( 'BoxControl', () => {
|
|
|
270
271
|
const user = userEvent.setup();
|
|
271
272
|
|
|
272
273
|
// Render control.
|
|
273
|
-
const { rerender } = render( <BoxControl /> );
|
|
274
|
+
const { rerender } = render( <BoxControl onChange={ () => {} } /> );
|
|
274
275
|
|
|
275
276
|
// Make unit selection on all input control.
|
|
276
277
|
await user.selectOptions(
|
|
@@ -298,7 +299,9 @@ describe( 'BoxControl', () => {
|
|
|
298
299
|
} );
|
|
299
300
|
|
|
300
301
|
// Rerender with individual side value & confirm unit is selected.
|
|
301
|
-
rerender(
|
|
302
|
+
rerender(
|
|
303
|
+
<BoxControl values={ { top: '2.5em' } } onChange={ () => {} } />
|
|
304
|
+
);
|
|
302
305
|
|
|
303
306
|
const rerenderedControls = screen.getAllByRole( 'combobox', {
|
|
304
307
|
name: 'Select unit',
|