@wordpress/components 19.17.0 → 20.0.1-next.d6164808d3.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 +68 -1
- package/build/alignment-matrix-control/index.js +1 -1
- package/build/alignment-matrix-control/index.js.map +1 -1
- package/build/alignment-matrix-control/styles/alignment-matrix-control-styles.js +9 -9
- package/build/alignment-matrix-control/styles/alignment-matrix-control-styles.js.map +1 -1
- package/build/angle-picker-control/index.js +3 -0
- package/build/angle-picker-control/index.js.map +1 -1
- package/build/angle-picker-control/styles/angle-picker-control-styles.js +14 -4
- package/build/angle-picker-control/styles/angle-picker-control-styles.js.map +1 -1
- package/build/autocomplete/index.js +9 -11
- package/build/autocomplete/index.js.map +1 -1
- package/build/base-control/styles/base-control-styles.js +8 -8
- package/build/base-control/styles/base-control-styles.js.map +1 -1
- package/build/base-field/styles.js +5 -5
- package/build/base-field/styles.js.map +1 -1
- package/build/box-control/styles/box-control-visualizer-styles.js +8 -8
- package/build/box-control/styles/box-control-visualizer-styles.js.map +1 -1
- package/build/color-list-picker/index.js +16 -5
- package/build/color-list-picker/index.js.map +1 -1
- package/build/color-palette/index.js +22 -12
- package/build/color-palette/index.js.map +1 -1
- package/build/color-palette/index.native.js +3 -3
- package/build/color-palette/index.native.js.map +1 -1
- package/build/combobox-control/index.js +7 -4
- package/build/combobox-control/index.js.map +1 -1
- package/build/{custom-gradient-bar → custom-gradient-picker/gradient-bar}/constants.js +0 -0
- package/build/custom-gradient-picker/gradient-bar/constants.js.map +1 -0
- package/build/{custom-gradient-bar → custom-gradient-picker/gradient-bar}/control-points.js +34 -41
- package/build/custom-gradient-picker/gradient-bar/control-points.js.map +1 -0
- package/build/{custom-gradient-bar → custom-gradient-picker/gradient-bar}/index.js +0 -1
- package/build/custom-gradient-picker/gradient-bar/index.js.map +1 -0
- package/build/{custom-gradient-bar → custom-gradient-picker/gradient-bar}/utils.js +0 -0
- package/build/custom-gradient-picker/gradient-bar/utils.js.map +1 -0
- package/build/custom-gradient-picker/index.js +19 -4
- package/build/custom-gradient-picker/index.js.map +1 -1
- package/build/custom-select-control/index.js +21 -11
- package/build/custom-select-control/index.js.map +1 -1
- package/build/custom-select-control/styles.js +34 -0
- package/build/custom-select-control/styles.js.map +1 -0
- package/build/date-time/constants.js +9 -0
- package/build/date-time/constants.js.map +1 -0
- package/build/date-time/date/index.js +175 -186
- package/build/date-time/date/index.js.map +1 -1
- package/build/date-time/date/styles.js +59 -40
- package/build/date-time/date/styles.js.map +1 -1
- package/build/date-time/date-time/index.js +5 -2
- package/build/date-time/date-time/index.js.map +1 -1
- package/build/date-time/time/index.js +22 -17
- package/build/date-time/time/index.js.map +1 -1
- package/build/date-time/utils.js +27 -0
- package/build/date-time/utils.js.map +1 -0
- package/build/dimension-control/index.js +2 -6
- package/build/dimension-control/index.js.map +1 -1
- package/build/disabled/index.js +28 -11
- package/build/disabled/index.js.map +1 -1
- package/build/disabled/styles/disabled-styles.js +3 -3
- package/build/disabled/styles/disabled-styles.js.map +1 -1
- package/build/{swatch → disabled}/types.js +0 -0
- package/build/{swatch → disabled}/types.js.map +0 -0
- package/build/dropdown/index.js +5 -6
- package/build/dropdown/index.js.map +1 -1
- package/build/duotone-picker/custom-duotone-bar.js +2 -2
- package/build/duotone-picker/custom-duotone-bar.js.map +1 -1
- package/build/duotone-picker/duotone-picker.js +9 -1
- package/build/duotone-picker/duotone-picker.js.map +1 -1
- package/build/duotone-picker/duotone-swatch.js +13 -3
- package/build/duotone-picker/duotone-swatch.js.map +1 -1
- package/build/focal-point-picker/index.js +4 -6
- package/build/focal-point-picker/index.js.map +1 -1
- package/build/focal-point-picker/styles/focal-point-style.js +4 -4
- package/build/focal-point-picker/styles/focal-point-style.js.map +1 -1
- package/build/font-size-picker/index.js +43 -14
- package/build/font-size-picker/index.js.map +1 -1
- package/build/font-size-picker/utils.js +32 -22
- package/build/font-size-picker/utils.js.map +1 -1
- package/build/form-token-field/index.js +11 -5
- package/build/form-token-field/index.js.map +1 -1
- package/build/gradient-picker/index.js +15 -3
- package/build/gradient-picker/index.js.map +1 -1
- package/build/guide/index.js +5 -3
- package/build/guide/index.js.map +1 -1
- package/build/guide/page-control.js +3 -7
- package/build/guide/page-control.js.map +1 -1
- package/build/item-group/styles.js +10 -10
- package/build/item-group/styles.js.map +1 -1
- package/build/mobile/bottom-sheet/index.native.js +3 -6
- package/build/mobile/bottom-sheet/index.native.js.map +1 -1
- package/build/mobile/global-styles-context/utils.native.js +3 -1
- package/build/mobile/global-styles-context/utils.native.js.map +1 -1
- package/build/mobile/image/index.native.js +6 -26
- package/build/mobile/image/index.native.js.map +1 -1
- package/build/mobile/picker/index.android.js +3 -3
- package/build/mobile/picker/index.android.js.map +1 -1
- package/build/modal/index.js +1 -3
- package/build/modal/index.js.map +1 -1
- package/build/navigable-container/container.js +9 -8
- package/build/navigable-container/container.js.map +1 -1
- package/build/navigator/navigator-back-button/hook.js +0 -4
- package/build/navigator/navigator-back-button/hook.js.map +1 -1
- package/build/navigator/navigator-button/hook.js +0 -4
- package/build/navigator/navigator-button/hook.js.map +1 -1
- package/build/notice/list.js +10 -6
- package/build/notice/list.js.map +1 -1
- package/build/palette-edit/index.js +1 -0
- package/build/palette-edit/index.js.map +1 -1
- package/build/palette-edit/styles.js +10 -10
- package/build/palette-edit/styles.js.map +1 -1
- package/build/popover/index.js +100 -97
- package/build/popover/index.js.map +1 -1
- package/build/popover/utils.js +178 -0
- package/build/popover/utils.js.map +1 -0
- package/build/range-control/index.js +3 -0
- package/build/range-control/index.js.map +1 -1
- package/build/range-control/styles/range-control-styles.js +43 -37
- package/build/range-control/styles/range-control-styles.js.map +1 -1
- package/build/select-control/chevron-down.js +30 -0
- package/build/select-control/chevron-down.js.map +1 -0
- package/build/select-control/index.js +7 -7
- package/build/select-control/index.js.map +1 -1
- package/build/select-control/styles/select-control-styles.js +30 -15
- package/build/select-control/styles/select-control-styles.js.map +1 -1
- package/build/snackbar/list.js +5 -3
- package/build/snackbar/list.js.map +1 -1
- package/build/spinner/index.js +2 -0
- package/build/spinner/index.js.map +1 -1
- package/build/text/styles.js +7 -7
- package/build/text/styles.js.map +1 -1
- package/build/toggle-group-control/toggle-group-control/component.js +16 -8
- package/build/toggle-group-control/toggle-group-control/component.js.map +1 -1
- package/build/toggle-group-control/toggle-group-control/styles.js +7 -5
- package/build/toggle-group-control/toggle-group-control/styles.js.map +1 -1
- package/build/toggle-group-control/toggle-group-control-option/component.js +15 -5
- package/build/toggle-group-control/toggle-group-control-option/component.js.map +1 -1
- package/build/toggle-group-control/toggle-group-control-option-base/component.js +5 -1
- package/build/toggle-group-control/toggle-group-control-option-base/component.js.map +1 -1
- package/build/toggle-group-control/toggle-group-control-option-base/styles.js +20 -7
- package/build/toggle-group-control/toggle-group-control-option-base/styles.js.map +1 -1
- package/build/toggle-group-control/toggle-group-control-option-icon/component.js +26 -7
- package/build/toggle-group-control/toggle-group-control-option-icon/component.js.map +1 -1
- package/build/tools-panel/styles.js +11 -11
- package/build/tools-panel/styles.js.map +1 -1
- package/build/ui/context/context-connect.js +1 -3
- package/build/ui/context/context-connect.js.map +1 -1
- package/build/unit-control/index.js +2 -3
- package/build/unit-control/index.js.map +1 -1
- package/build/utils/colors-values.js +52 -142
- package/build/utils/colors-values.js.map +1 -1
- package/build/utils/config-values.js +1 -1
- package/build/utils/config-values.js.map +1 -1
- package/build/utils/input/input-control.js +1 -1
- package/build/utils/input/input-control.js.map +1 -1
- package/build/utils/rtl.js +6 -5
- package/build/utils/rtl.js.map +1 -1
- package/build/utils/strings.js +50 -0
- package/build/utils/strings.js.map +1 -0
- package/build-module/alignment-matrix-control/index.js +1 -1
- package/build-module/alignment-matrix-control/index.js.map +1 -1
- package/build-module/alignment-matrix-control/styles/alignment-matrix-control-styles.js +9 -9
- package/build-module/alignment-matrix-control/styles/alignment-matrix-control-styles.js.map +1 -1
- package/build-module/angle-picker-control/index.js +3 -0
- package/build-module/angle-picker-control/index.js.map +1 -1
- package/build-module/angle-picker-control/styles/angle-picker-control-styles.js +13 -4
- package/build-module/angle-picker-control/styles/angle-picker-control-styles.js.map +1 -1
- package/build-module/autocomplete/index.js +9 -10
- package/build-module/autocomplete/index.js.map +1 -1
- package/build-module/base-control/styles/base-control-styles.js +8 -8
- package/build-module/base-control/styles/base-control-styles.js.map +1 -1
- package/build-module/base-field/styles.js +5 -5
- package/build-module/base-field/styles.js.map +1 -1
- package/build-module/box-control/styles/box-control-visualizer-styles.js +8 -8
- package/build-module/box-control/styles/box-control-visualizer-styles.js.map +1 -1
- package/build-module/color-list-picker/index.js +13 -5
- package/build-module/color-list-picker/index.js.map +1 -1
- package/build-module/color-palette/index.js +22 -11
- package/build-module/color-palette/index.js.map +1 -1
- package/build-module/color-palette/index.native.js +4 -4
- package/build-module/color-palette/index.native.js.map +1 -1
- package/build-module/combobox-control/index.js +6 -3
- package/build-module/combobox-control/index.js.map +1 -1
- package/build-module/{custom-gradient-bar → custom-gradient-picker/gradient-bar}/constants.js +0 -0
- package/build-module/custom-gradient-picker/gradient-bar/constants.js.map +1 -0
- package/build-module/{custom-gradient-bar → custom-gradient-picker/gradient-bar}/control-points.js +34 -41
- package/build-module/custom-gradient-picker/gradient-bar/control-points.js.map +1 -0
- package/build-module/{custom-gradient-bar → custom-gradient-picker/gradient-bar}/index.js +0 -1
- package/build-module/custom-gradient-picker/gradient-bar/index.js.map +1 -0
- package/build-module/{custom-gradient-bar → custom-gradient-picker/gradient-bar}/utils.js +0 -0
- package/build-module/custom-gradient-picker/gradient-bar/utils.js.map +1 -0
- package/build-module/custom-gradient-picker/index.js +16 -3
- package/build-module/custom-gradient-picker/index.js.map +1 -1
- package/build-module/custom-select-control/index.js +20 -12
- package/build-module/custom-select-control/index.js.map +1 -1
- package/build-module/custom-select-control/styles.js +22 -0
- package/build-module/custom-select-control/styles.js.map +1 -0
- package/build-module/date-time/constants.js +2 -0
- package/build-module/date-time/constants.js.map +1 -0
- package/build-module/date-time/date/index.js +178 -184
- package/build-module/date-time/date/index.js.map +1 -1
- package/build-module/date-time/date/styles.js +47 -38
- package/build-module/date-time/date/styles.js.map +1 -1
- package/build-module/date-time/date-time/index.js +4 -2
- package/build-module/date-time/date-time/index.js.map +1 -1
- package/build-module/date-time/time/index.js +20 -16
- package/build-module/date-time/time/index.js.map +1 -1
- package/build-module/date-time/utils.js +19 -0
- package/build-module/date-time/utils.js.map +1 -0
- package/build-module/dimension-control/index.js +1 -5
- package/build-module/dimension-control/index.js.map +1 -1
- package/build-module/disabled/index.js +28 -11
- package/build-module/disabled/index.js.map +1 -1
- package/build-module/disabled/styles/disabled-styles.js +3 -3
- package/build-module/disabled/styles/disabled-styles.js.map +1 -1
- package/build-module/{swatch → disabled}/types.js +0 -0
- package/build-module/{swatch → disabled}/types.js.map +0 -0
- package/build-module/dropdown/index.js +5 -6
- package/build-module/dropdown/index.js.map +1 -1
- package/build-module/duotone-picker/custom-duotone-bar.js +1 -1
- package/build-module/duotone-picker/custom-duotone-bar.js.map +1 -1
- package/build-module/duotone-picker/duotone-picker.js +7 -1
- package/build-module/duotone-picker/duotone-picker.js.map +1 -1
- package/build-module/duotone-picker/duotone-swatch.js +11 -3
- package/build-module/duotone-picker/duotone-swatch.js.map +1 -1
- package/build-module/focal-point-picker/index.js +4 -5
- package/build-module/focal-point-picker/index.js.map +1 -1
- package/build-module/focal-point-picker/styles/focal-point-style.js +4 -4
- package/build-module/focal-point-picker/styles/focal-point-style.js.map +1 -1
- package/build-module/font-size-picker/index.js +39 -14
- package/build-module/font-size-picker/index.js.map +1 -1
- package/build-module/font-size-picker/utils.js +31 -23
- package/build-module/font-size-picker/utils.js.map +1 -1
- package/build-module/form-token-field/index.js +12 -6
- package/build-module/form-token-field/index.js.map +1 -1
- package/build-module/gradient-picker/index.js +14 -3
- package/build-module/gradient-picker/index.js.map +1 -1
- package/build-module/guide/index.js +5 -3
- package/build-module/guide/index.js.map +1 -1
- package/build-module/guide/page-control.js +3 -6
- package/build-module/guide/page-control.js.map +1 -1
- package/build-module/item-group/styles.js +10 -10
- package/build-module/item-group/styles.js.map +1 -1
- package/build-module/mobile/bottom-sheet/index.native.js +3 -5
- package/build-module/mobile/bottom-sheet/index.native.js.map +1 -1
- package/build-module/mobile/global-styles-context/utils.native.js +2 -1
- package/build-module/mobile/global-styles-context/utils.native.js.map +1 -1
- package/build-module/mobile/image/index.native.js +8 -28
- package/build-module/mobile/image/index.native.js.map +1 -1
- package/build-module/mobile/picker/index.android.js +3 -3
- package/build-module/mobile/picker/index.android.js.map +1 -1
- package/build-module/modal/index.js +1 -2
- package/build-module/modal/index.js.map +1 -1
- package/build-module/navigable-container/container.js +9 -7
- package/build-module/navigable-container/container.js.map +1 -1
- package/build-module/navigator/navigator-back-button/hook.js +0 -4
- package/build-module/navigator/navigator-back-button/hook.js.map +1 -1
- package/build-module/navigator/navigator-button/hook.js +0 -4
- package/build-module/navigator/navigator-button/hook.js.map +1 -1
- package/build-module/notice/list.js +10 -5
- package/build-module/notice/list.js.map +1 -1
- package/build-module/palette-edit/index.js +1 -0
- package/build-module/palette-edit/index.js.map +1 -1
- package/build-module/palette-edit/styles.js +10 -10
- package/build-module/palette-edit/styles.js.map +1 -1
- package/build-module/popover/index.js +100 -98
- package/build-module/popover/index.js.map +1 -1
- package/build-module/popover/utils.js +164 -0
- package/build-module/popover/utils.js.map +1 -0
- package/build-module/range-control/index.js +3 -0
- package/build-module/range-control/index.js.map +1 -1
- package/build-module/range-control/styles/range-control-styles.js +43 -37
- package/build-module/range-control/styles/range-control-styles.js.map +1 -1
- package/build-module/select-control/chevron-down.js +21 -0
- package/build-module/select-control/chevron-down.js.map +1 -0
- package/build-module/select-control/index.js +7 -7
- package/build-module/select-control/index.js.map +1 -1
- package/build-module/select-control/styles/select-control-styles.js +24 -13
- package/build-module/select-control/styles/select-control-styles.js.map +1 -1
- package/build-module/snackbar/list.js +5 -2
- package/build-module/snackbar/list.js.map +1 -1
- package/build-module/spinner/index.js +2 -0
- package/build-module/spinner/index.js.map +1 -1
- package/build-module/text/styles.js +7 -7
- package/build-module/text/styles.js.map +1 -1
- package/build-module/toggle-group-control/toggle-group-control/component.js +14 -7
- package/build-module/toggle-group-control/toggle-group-control/component.js.map +1 -1
- package/build-module/toggle-group-control/toggle-group-control/styles.js +5 -4
- package/build-module/toggle-group-control/toggle-group-control/styles.js.map +1 -1
- package/build-module/toggle-group-control/toggle-group-control-option/component.js +17 -3
- package/build-module/toggle-group-control/toggle-group-control-option/component.js.map +1 -1
- package/build-module/toggle-group-control/toggle-group-control-option-base/component.js +5 -1
- package/build-module/toggle-group-control/toggle-group-control-option-base/component.js.map +1 -1
- package/build-module/toggle-group-control/toggle-group-control-option-base/styles.js +16 -6
- package/build-module/toggle-group-control/toggle-group-control-option-base/styles.js.map +1 -1
- package/build-module/toggle-group-control/toggle-group-control-option-icon/component.js +27 -5
- package/build-module/toggle-group-control/toggle-group-control-option-icon/component.js.map +1 -1
- package/build-module/tools-panel/styles.js +11 -11
- package/build-module/tools-panel/styles.js.map +1 -1
- package/build-module/ui/context/context-connect.js +1 -2
- package/build-module/ui/context/context-connect.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/utils/colors-values.js +52 -141
- package/build-module/utils/colors-values.js.map +1 -1
- package/build-module/utils/config-values.js +1 -1
- package/build-module/utils/config-values.js.map +1 -1
- package/build-module/utils/input/input-control.js +1 -1
- package/build-module/utils/input/input-control.js.map +1 -1
- package/build-module/utils/rtl.js +6 -4
- package/build-module/utils/rtl.js.map +1 -1
- package/build-module/utils/strings.js +37 -0
- package/build-module/utils/strings.js.map +1 -0
- package/build-style/style-rtl.css +176 -1227
- package/build-style/style.css +171 -1225
- package/build-types/color-palette/index.d.ts +2 -1
- package/build-types/color-palette/index.d.ts.map +1 -1
- package/build-types/color-picker/styles.d.ts +2 -2
- package/build-types/date-time/constants.d.ts +2 -0
- package/build-types/date-time/constants.d.ts.map +1 -0
- package/build-types/date-time/date/index.d.ts +3 -1
- package/build-types/date-time/date/index.d.ts.map +1 -1
- package/build-types/date-time/date/styles.d.ts +22 -8
- package/build-types/date-time/date/styles.d.ts.map +1 -1
- package/build-types/date-time/date/test/index.d.ts +1 -1
- package/build-types/date-time/date/test/index.d.ts.map +1 -1
- package/build-types/date-time/date-time/index.d.ts.map +1 -1
- package/build-types/date-time/time/index.d.ts.map +1 -1
- package/build-types/date-time/utils.d.ts +8 -0
- package/build-types/date-time/utils.d.ts.map +1 -0
- package/build-types/disabled/index.d.ts +35 -28
- package/build-types/disabled/index.d.ts.map +1 -1
- package/build-types/disabled/stories/index.d.ts +13 -0
- package/build-types/disabled/stories/index.d.ts.map +1 -0
- package/build-types/disabled/styles/disabled-styles.d.ts +2 -1
- package/build-types/disabled/styles/disabled-styles.d.ts.map +1 -1
- package/build-types/disabled/test/index.d.ts +2 -0
- package/build-types/{flyout/flyout → disabled/test}/index.d.ts.map +1 -1
- package/build-types/disabled/types.d.ts +14 -0
- package/build-types/disabled/types.d.ts.map +1 -0
- package/build-types/dropdown/index.d.ts.map +1 -1
- package/build-types/form-token-field/index.d.ts.map +1 -1
- package/build-types/form-token-field/stories/index.d.ts +1 -0
- package/build-types/form-token-field/stories/index.d.ts.map +1 -1
- package/build-types/form-token-field/types.d.ts +7 -0
- package/build-types/form-token-field/types.d.ts.map +1 -1
- package/build-types/navigator/navigator-back-button/hook.d.ts +0 -3
- package/build-types/navigator/navigator-back-button/hook.d.ts.map +1 -1
- package/build-types/navigator/navigator-button/hook.d.ts +0 -3
- package/build-types/navigator/navigator-button/hook.d.ts.map +1 -1
- package/build-types/placeholder/test/index.d.ts +2 -0
- package/build-types/{flyout → placeholder/test}/index.d.ts.map +1 -1
- package/build-types/popover/index.d.ts +1 -1
- package/build-types/popover/index.d.ts.map +1 -1
- package/build-types/popover/utils.d.ts +26 -69
- package/build-types/popover/utils.d.ts.map +1 -1
- package/build-types/range-control/index.d.ts +2 -2
- package/build-types/range-control/index.d.ts.map +1 -1
- package/build-types/range-control/styles/range-control-styles.d.ts +5 -2
- package/build-types/range-control/styles/range-control-styles.d.ts.map +1 -1
- package/build-types/range-control/types.d.ts +2 -2
- package/build-types/range-control/types.d.ts.map +1 -1
- package/build-types/select-control/chevron-down.d.ts +4 -0
- package/build-types/select-control/chevron-down.d.ts.map +1 -0
- package/build-types/select-control/index.d.ts.map +1 -1
- package/build-types/select-control/styles/select-control-styles.d.ts +8 -0
- package/build-types/select-control/styles/select-control-styles.d.ts.map +1 -1
- package/build-types/spinner/index.d.ts.map +1 -1
- package/build-types/toggle-group-control/stories/index.d.ts +25 -0
- package/build-types/toggle-group-control/stories/index.d.ts.map +1 -0
- package/build-types/toggle-group-control/test/index.d.ts +2 -0
- package/build-types/toggle-group-control/test/index.d.ts.map +1 -0
- package/build-types/toggle-group-control/toggle-group-control/component.d.ts +6 -3
- package/build-types/toggle-group-control/toggle-group-control/component.d.ts.map +1 -1
- package/build-types/toggle-group-control/toggle-group-control/styles.d.ts +1 -0
- package/build-types/toggle-group-control/toggle-group-control/styles.d.ts.map +1 -1
- package/build-types/toggle-group-control/toggle-group-control-option/component.d.ts +6 -7
- package/build-types/toggle-group-control/toggle-group-control-option/component.d.ts.map +1 -1
- package/build-types/toggle-group-control/toggle-group-control-option-base/component.d.ts.map +1 -1
- package/build-types/toggle-group-control/toggle-group-control-option-base/styles.d.ts +4 -0
- package/build-types/toggle-group-control/toggle-group-control-option-base/styles.d.ts.map +1 -1
- package/build-types/toggle-group-control/toggle-group-control-option-icon/component.d.ts +11 -9
- package/build-types/toggle-group-control/toggle-group-control-option-icon/component.d.ts.map +1 -1
- package/build-types/toggle-group-control/types.d.ts +23 -10
- package/build-types/toggle-group-control/types.d.ts.map +1 -1
- package/build-types/ui/context/context-connect.d.ts +3 -0
- package/build-types/ui/context/context-connect.d.ts.map +1 -1
- package/build-types/ui/form-group/use-form-group.d.ts +2 -2
- package/build-types/unit-control/index.d.ts +2 -1
- package/build-types/unit-control/index.d.ts.map +1 -1
- package/build-types/unit-control/types.d.ts +5 -1
- package/build-types/unit-control/types.d.ts.map +1 -1
- package/build-types/utils/colors-values.d.ts +18 -97
- package/build-types/utils/colors-values.d.ts.map +1 -1
- package/build-types/utils/rtl.d.ts.map +1 -1
- package/build-types/utils/strings.d.ts +2 -0
- package/build-types/utils/strings.d.ts.map +1 -0
- package/package.json +22 -21
- package/src/alignment-matrix-control/index.js +1 -1
- package/src/alignment-matrix-control/stories/index.js +49 -24
- package/src/alignment-matrix-control/styles/alignment-matrix-control-styles.js +1 -3
- package/src/angle-picker-control/index.js +7 -1
- package/src/angle-picker-control/stories/index.js +8 -5
- package/src/angle-picker-control/styles/angle-picker-control-styles.js +12 -3
- package/src/autocomplete/index.js +9 -18
- package/src/base-control/styles/base-control-styles.ts +1 -1
- package/src/base-field/styles.js +1 -1
- package/src/base-field/test/__snapshots__/index.js.snap +2 -2
- package/src/box-control/styles/box-control-visualizer-styles.js +0 -1
- package/src/box-control/test/index.js +8 -8
- package/src/button/test/index.js +188 -146
- package/src/color-list-picker/index.js +15 -3
- package/src/color-list-picker/style.scss +11 -0
- package/src/color-palette/index.js +32 -16
- package/src/color-palette/index.native.js +10 -6
- package/src/color-palette/stories/index.js +1 -1
- package/src/color-palette/test/__snapshots__/index.js.snap +17 -3
- package/src/combobox-control/index.js +6 -5
- package/src/combobox-control/stories/index.js +9 -3
- package/src/combobox-control/style.scss +0 -1
- package/src/confirm-dialog/test/index.js +85 -62
- package/src/{custom-gradient-bar → custom-gradient-picker/gradient-bar}/constants.js +0 -0
- package/src/{custom-gradient-bar → custom-gradient-picker/gradient-bar}/control-points.js +54 -50
- package/src/{custom-gradient-bar → custom-gradient-picker/gradient-bar}/index.js +0 -3
- package/src/{custom-gradient-bar → custom-gradient-picker/gradient-bar}/test/utils.js +0 -0
- package/src/{custom-gradient-bar → custom-gradient-picker/gradient-bar}/utils.js +0 -0
- package/src/custom-gradient-picker/index.js +18 -3
- package/src/custom-gradient-picker/stories/index.js +4 -3
- package/src/custom-gradient-picker/style.scss +30 -27
- package/src/custom-select-control/README.md +10 -0
- package/src/custom-select-control/index.js +22 -16
- package/src/custom-select-control/stories/index.js +1 -1
- package/src/custom-select-control/style.scss +0 -12
- package/src/custom-select-control/styles.ts +28 -0
- package/src/custom-select-control/test/index.js +4 -1
- package/src/date-time/constants.ts +1 -0
- package/src/date-time/date/index.tsx +289 -184
- package/src/date-time/date/styles.ts +86 -27
- package/src/date-time/date/test/index.tsx +18 -28
- package/src/date-time/date-time/index.tsx +3 -2
- package/src/date-time/time/index.tsx +23 -19
- package/src/date-time/utils.ts +17 -0
- package/src/dimension-control/index.js +1 -5
- package/src/disabled/index.tsx +80 -0
- package/src/disabled/stories/index.tsx +87 -0
- package/src/disabled/styles/{disabled-styles.js → disabled-styles.tsx} +0 -0
- package/src/disabled/test/index.tsx +174 -0
- package/src/disabled/types.ts +13 -0
- package/src/dropdown/index.js +3 -5
- package/src/dropdown-menu/stories/index.js +13 -2
- package/src/duotone-picker/custom-duotone-bar.js +1 -1
- package/src/duotone-picker/duotone-picker.js +34 -26
- package/src/duotone-picker/duotone-swatch.js +12 -5
- package/src/duotone-picker/stories/duotone-picker.js +66 -0
- package/src/duotone-picker/stories/duotone-swatch.js +32 -0
- package/src/focal-point-picker/index.js +10 -5
- package/src/focal-point-picker/styles/focal-point-style.js +0 -1
- package/src/focal-point-picker/test/index.js +78 -45
- package/src/font-size-picker/index.js +161 -144
- package/src/font-size-picker/stories/index.js +1 -0
- package/src/font-size-picker/style.scss +8 -5
- package/src/font-size-picker/test/index.js +13 -6
- package/src/font-size-picker/test/{util.js → utils.js} +77 -1
- package/src/font-size-picker/utils.js +38 -23
- package/src/form-token-field/README.md +1 -0
- package/src/form-token-field/index.tsx +24 -10
- package/src/form-token-field/stories/index.tsx +8 -0
- package/src/form-token-field/test/index.js +31 -0
- package/src/form-token-field/types.ts +7 -0
- package/src/gradient-picker/index.js +22 -7
- package/src/gradient-picker/stories/index.js +56 -81
- package/src/guide/index.js +3 -1
- package/src/guide/page-control.js +1 -6
- package/src/guide/stories/index.js +12 -11
- package/src/guide/test/index.js +54 -37
- package/src/guide/test/page-control.js +14 -17
- package/src/higher-order/with-notices/test/index.js +4 -2
- package/src/higher-order/with-spoken-messages/test/index.js +1 -1
- package/src/item-group/styles.ts +3 -3
- package/src/menu-group/test/index.js +18 -7
- package/src/mobile/bottom-sheet/index.native.js +2 -4
- package/src/mobile/global-styles-context/utils.native.js +2 -1
- package/src/mobile/image/index.native.js +9 -30
- package/src/mobile/picker/index.android.js +10 -4
- package/src/mobile/picker/styles.native.scss +4 -4
- package/src/modal/index.js +1 -2
- package/src/modal/test/index.js +11 -9
- package/src/navigable-container/container.js +12 -18
- package/src/navigable-container/test/menu.js +14 -11
- package/src/navigator/navigator-back-button/hook.ts +0 -3
- package/src/navigator/navigator-button/hook.ts +0 -3
- package/src/notice/list.js +12 -10
- package/src/palette-edit/index.js +1 -0
- package/src/palette-edit/styles.js +6 -5
- package/src/placeholder/README.md +1 -1
- package/src/placeholder/style.scss +65 -20
- package/src/placeholder/test/index.tsx +174 -0
- package/src/popover/index.js +133 -112
- package/src/popover/stories/index.js +17 -3
- package/src/popover/test/__snapshots__/index.js.snap +6 -6
- package/src/popover/test/index.js +129 -36
- package/src/popover/utils.js +107 -0
- package/src/range-control/index.tsx +3 -0
- package/src/range-control/styles/range-control-styles.ts +9 -4
- package/src/range-control/types.ts +5 -2
- package/src/select-control/chevron-down.tsx +25 -0
- package/src/select-control/index.tsx +6 -9
- package/src/select-control/styles/select-control-styles.ts +23 -14
- package/src/slot-fill/test/slot.js +5 -5
- package/src/snackbar/list.js +3 -2
- package/src/spinner/index.tsx +2 -0
- package/src/style.scss +0 -2
- package/src/text/styles.js +1 -1
- package/src/text/test/index.tsx +1 -1
- package/src/toggle-group-control/stories/index.tsx +127 -0
- package/src/toggle-group-control/test/__snapshots__/{index.js.snap → index.tsx.snap} +28 -22
- package/src/toggle-group-control/test/{index.js → index.tsx} +2 -4
- package/src/toggle-group-control/toggle-group-control/README.md +2 -0
- package/src/toggle-group-control/toggle-group-control/component.tsx +18 -9
- package/src/toggle-group-control/toggle-group-control/styles.ts +9 -6
- package/src/toggle-group-control/toggle-group-control-option/component.tsx +19 -3
- package/src/toggle-group-control/toggle-group-control-option-base/component.tsx +3 -0
- package/src/toggle-group-control/toggle-group-control-option-base/styles.ts +18 -0
- package/src/toggle-group-control/toggle-group-control-option-icon/README.md +6 -8
- package/src/toggle-group-control/toggle-group-control-option-icon/component.tsx +30 -7
- package/src/toggle-group-control/types.ts +74 -59
- package/src/toolbar/test/index.js +4 -4
- package/src/toolbar-group/test/index.js +9 -15
- package/src/tools-panel/styles.ts +2 -2
- package/src/tools-panel/test/index.js +3 -2
- package/src/tooltip/test/index.js +188 -172
- package/src/ui/context/context-connect.ts +3 -2
- package/src/unit-control/index.tsx +2 -2
- package/src/unit-control/types.ts +10 -1
- package/src/utils/colors-values.js +42 -137
- package/src/utils/config-values.js +1 -1
- package/src/utils/input/input-control.js +6 -6
- package/src/utils/rtl.js +6 -2
- package/src/utils/strings.ts +72 -0
- package/src/utils/test/strings.js +15 -0
- package/tsconfig.json +0 -1
- package/tsconfig.tsbuildinfo +1 -1
- package/build/custom-gradient-bar/constants.js.map +0 -1
- package/build/custom-gradient-bar/control-points.js.map +0 -1
- package/build/custom-gradient-bar/index.js.map +0 -1
- package/build/custom-gradient-bar/utils.js.map +0 -1
- package/build/date-time/date/utils.js +0 -34
- package/build/date-time/date/utils.js.map +0 -1
- package/build/swatch/index.js +0 -41
- package/build/swatch/index.js.map +0 -1
- package/build-module/custom-gradient-bar/constants.js.map +0 -1
- package/build-module/custom-gradient-bar/control-points.js.map +0 -1
- package/build-module/custom-gradient-bar/index.js.map +0 -1
- package/build-module/custom-gradient-bar/utils.js.map +0 -1
- package/build-module/date-time/date/utils.js +0 -22
- package/build-module/date-time/date/utils.js.map +0 -1
- package/build-module/swatch/index.js +0 -30
- package/build-module/swatch/index.js.map +0 -1
- package/build-types/color-picker/color-display.d.ts +0 -13
- package/build-types/color-picker/color-display.d.ts.map +0 -1
- package/build-types/date-time/date/test/utils.d.ts +0 -2
- package/build-types/date-time/date/test/utils.d.ts.map +0 -1
- package/build-types/date-time/date/utils.d.ts +0 -15
- package/build-types/date-time/date/utils.d.ts.map +0 -1
- package/build-types/flyout/context.d.ts +0 -6
- package/build-types/flyout/context.d.ts.map +0 -1
- package/build-types/flyout/flyout/component.d.ts +0 -21
- package/build-types/flyout/flyout/component.d.ts.map +0 -1
- package/build-types/flyout/flyout/hook.d.ts +0 -270
- package/build-types/flyout/flyout/hook.d.ts.map +0 -1
- package/build-types/flyout/flyout/index.d.ts +0 -3
- package/build-types/flyout/flyout-content/component.d.ts +0 -3
- package/build-types/flyout/flyout-content/component.d.ts.map +0 -1
- package/build-types/flyout/flyout-content/index.d.ts +0 -2
- package/build-types/flyout/flyout-content/index.d.ts.map +0 -1
- package/build-types/flyout/index.d.ts +0 -2
- package/build-types/flyout/styles.d.ts +0 -22
- package/build-types/flyout/styles.d.ts.map +0 -1
- package/build-types/flyout/types.d.ts +0 -80
- package/build-types/flyout/types.d.ts.map +0 -1
- package/build-types/flyout/utils.d.ts +0 -8
- package/build-types/flyout/utils.d.ts.map +0 -1
- package/build-types/swatch/index.d.ts +0 -5
- package/build-types/swatch/index.d.ts.map +0 -1
- package/build-types/swatch/types.d.ts +0 -11
- package/build-types/swatch/types.d.ts.map +0 -1
- package/build-types/utils/hooks/use-combined-ref.d.ts +0 -8
- package/build-types/utils/hooks/use-combined-ref.d.ts.map +0 -1
- package/src/date-time/date/datepicker.scss +0 -863
- package/src/date-time/date/style.scss +0 -85
- package/src/date-time/date/test/utils.ts +0 -32
- package/src/date-time/date/utils.ts +0 -20
- package/src/date-time/style.scss +0 -1
- package/src/disabled/index.js +0 -55
- package/src/disabled/stories/index.js +0 -61
- package/src/disabled/test/index.js +0 -240
- package/src/menu-group/test/__snapshots__/index.js.snap +0 -23
- package/src/placeholder/test/index.js +0 -163
- package/src/swatch/index.tsx +0 -22
- package/src/swatch/style.scss +0 -21
- package/src/swatch/types.ts +0 -11
- package/src/toggle-group-control/stories/index.js +0 -203
- package/src/tools-panel/test/__snapshots__/index.js.snap +0 -210
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
/**
|
|
2
2
|
* External dependencies
|
|
3
3
|
*/
|
|
4
|
-
import { last, clone,
|
|
4
|
+
import { last, clone, map, some } from 'lodash';
|
|
5
5
|
import classnames from 'classnames';
|
|
6
6
|
import type { KeyboardEvent, MouseEvent, TouchEvent } from 'react';
|
|
7
7
|
|
|
@@ -78,6 +78,7 @@ export function FormTokenField( props: FormTokenFieldProps ) {
|
|
|
78
78
|
__experimentalValidateInput = () => true,
|
|
79
79
|
__experimentalShowHowTo = true,
|
|
80
80
|
__next36pxDefaultSize = false,
|
|
81
|
+
__experimentalAutoSelectFirstMatch = false,
|
|
81
82
|
} = props;
|
|
82
83
|
|
|
83
84
|
const instanceId = useInstanceId( FormTokenField );
|
|
@@ -409,12 +410,14 @@ export function FormTokenField( props: FormTokenFieldProps ) {
|
|
|
409
410
|
}
|
|
410
411
|
|
|
411
412
|
function addNewTokens( tokens: string[] ) {
|
|
412
|
-
const tokensToAdd =
|
|
413
|
-
|
|
414
|
-
|
|
415
|
-
|
|
416
|
-
|
|
417
|
-
|
|
413
|
+
const tokensToAdd = [
|
|
414
|
+
...new Set(
|
|
415
|
+
tokens
|
|
416
|
+
.map( saveTransform )
|
|
417
|
+
.filter( Boolean )
|
|
418
|
+
.filter( ( token ) => ! valueContainsToken( token ) )
|
|
419
|
+
),
|
|
420
|
+
];
|
|
418
421
|
|
|
419
422
|
if ( tokensToAdd.length > 0 ) {
|
|
420
423
|
const newValue = clone( value );
|
|
@@ -475,7 +478,9 @@ export function FormTokenField( props: FormTokenFieldProps ) {
|
|
|
475
478
|
} );
|
|
476
479
|
|
|
477
480
|
if ( match.length === 0 ) {
|
|
478
|
-
_suggestions =
|
|
481
|
+
_suggestions = _suggestions.filter(
|
|
482
|
+
( suggestion ) => ! normalizedValue.includes( suggestion )
|
|
483
|
+
);
|
|
479
484
|
} else {
|
|
480
485
|
match = match.toLocaleLowerCase();
|
|
481
486
|
|
|
@@ -534,8 +539,17 @@ export function FormTokenField( props: FormTokenFieldProps ) {
|
|
|
534
539
|
);
|
|
535
540
|
|
|
536
541
|
if ( resetSelectedSuggestion ) {
|
|
537
|
-
|
|
538
|
-
|
|
542
|
+
if (
|
|
543
|
+
__experimentalAutoSelectFirstMatch &&
|
|
544
|
+
inputHasMinimumChars &&
|
|
545
|
+
hasMatchingSuggestions
|
|
546
|
+
) {
|
|
547
|
+
setSelectedSuggestionIndex( 0 );
|
|
548
|
+
setSelectedSuggestionScroll( true );
|
|
549
|
+
} else {
|
|
550
|
+
setSelectedSuggestionIndex( -1 );
|
|
551
|
+
setSelectedSuggestionScroll( false );
|
|
552
|
+
}
|
|
539
553
|
}
|
|
540
554
|
|
|
541
555
|
if ( inputHasMinimumChars ) {
|
|
@@ -102,6 +102,14 @@ Async.args = {
|
|
|
102
102
|
suggestions: continents,
|
|
103
103
|
};
|
|
104
104
|
|
|
105
|
+
export const DropdownSelector: ComponentStory< typeof FormTokenField > =
|
|
106
|
+
DefaultTemplate.bind( {} );
|
|
107
|
+
DropdownSelector.args = {
|
|
108
|
+
...Default.args,
|
|
109
|
+
__experimentalExpandOnFocus: true,
|
|
110
|
+
__experimentalAutoSelectFirstMatch: true,
|
|
111
|
+
};
|
|
112
|
+
|
|
105
113
|
/**
|
|
106
114
|
* The rendered output of each suggestion can be customized by passing a
|
|
107
115
|
* render function to the `__experimentalRenderItem` prop. (This is still an experimental feature
|
|
@@ -396,6 +396,37 @@ describe( 'FormTokenField', () => {
|
|
|
396
396
|
sendKeyDown( keyCodes.enter );
|
|
397
397
|
expect( wrapper.state.tokens ).toEqual( [ 'foo', 'bar' ] );
|
|
398
398
|
} );
|
|
399
|
+
|
|
400
|
+
it( 'should automatically select the first matching suggestions when __experimentalAutoSelectFirstMatch is set to true', () => {
|
|
401
|
+
setUp( { __experimentalAutoSelectFirstMatch: true } );
|
|
402
|
+
|
|
403
|
+
wrapper.setState( {
|
|
404
|
+
isExpanded: true,
|
|
405
|
+
} );
|
|
406
|
+
|
|
407
|
+
expect( getSuggestionsText() ).toEqual( [] );
|
|
408
|
+
|
|
409
|
+
const searchText = 'so';
|
|
410
|
+
|
|
411
|
+
act( () => {
|
|
412
|
+
setText( searchText );
|
|
413
|
+
} );
|
|
414
|
+
|
|
415
|
+
const expectedFirstMatchTokens =
|
|
416
|
+
fixtures.matchingSuggestions[ searchText ][ 0 ];
|
|
417
|
+
|
|
418
|
+
expect( getSelectedSuggestion() ).toEqual(
|
|
419
|
+
expectedFirstMatchTokens
|
|
420
|
+
);
|
|
421
|
+
|
|
422
|
+
sendKeyDown( keyCodes.enter );
|
|
423
|
+
|
|
424
|
+
expect( wrapper.state.tokens ).toEqual( [
|
|
425
|
+
'foo',
|
|
426
|
+
'bar',
|
|
427
|
+
expectedFirstMatchTokens.join( '' ),
|
|
428
|
+
] );
|
|
429
|
+
} );
|
|
399
430
|
} );
|
|
400
431
|
|
|
401
432
|
describe( 'removing tokens', () => {
|
|
@@ -158,6 +158,13 @@ export interface FormTokenFieldProps
|
|
|
158
158
|
* @default false
|
|
159
159
|
*/
|
|
160
160
|
__next36pxDefaultSize?: boolean;
|
|
161
|
+
/**
|
|
162
|
+
* If true, the select the first matching suggestion when the user presses
|
|
163
|
+
* the Enter key (or space when tokenizeOnSpace is true).
|
|
164
|
+
*
|
|
165
|
+
* @default false
|
|
166
|
+
*/
|
|
167
|
+
__experimentalAutoSelectFirstMatch?: boolean;
|
|
161
168
|
/**
|
|
162
169
|
* Custom renderer for suggestions.
|
|
163
170
|
*/
|
|
@@ -16,6 +16,7 @@ import CircularOptionPicker from '../circular-option-picker';
|
|
|
16
16
|
import CustomGradientPicker from '../custom-gradient-picker';
|
|
17
17
|
import { VStack } from '../v-stack';
|
|
18
18
|
import { ColorHeading } from '../color-palette/styles';
|
|
19
|
+
import { Spacer } from '../spacer';
|
|
19
20
|
|
|
20
21
|
function SingleOrigin( {
|
|
21
22
|
className,
|
|
@@ -99,6 +100,8 @@ function MultipleOrigin( {
|
|
|
99
100
|
}
|
|
100
101
|
|
|
101
102
|
export default function GradientPicker( {
|
|
103
|
+
/** Start opting into the new margin-free styles that will become the default in a future version. */
|
|
104
|
+
__nextHasNoMargin = false,
|
|
102
105
|
className,
|
|
103
106
|
gradients,
|
|
104
107
|
onChange,
|
|
@@ -117,6 +120,11 @@ export default function GradientPicker( {
|
|
|
117
120
|
? MultipleOrigin
|
|
118
121
|
: SingleOrigin;
|
|
119
122
|
|
|
123
|
+
// Can be removed when deprecation period is over
|
|
124
|
+
const deprecatedMarginSpacerProps = ! __nextHasNoMargin
|
|
125
|
+
? { marginTop: 3 }
|
|
126
|
+
: {};
|
|
127
|
+
|
|
120
128
|
return (
|
|
121
129
|
<Component
|
|
122
130
|
className={ className }
|
|
@@ -137,13 +145,20 @@ export default function GradientPicker( {
|
|
|
137
145
|
}
|
|
138
146
|
content={
|
|
139
147
|
! disableCustomGradients && (
|
|
140
|
-
<
|
|
141
|
-
|
|
142
|
-
|
|
143
|
-
}
|
|
144
|
-
|
|
145
|
-
|
|
146
|
-
|
|
148
|
+
<Spacer
|
|
149
|
+
marginTop={ gradients?.length ? 3 : 0 }
|
|
150
|
+
marginBottom={ 0 }
|
|
151
|
+
{ ...deprecatedMarginSpacerProps }
|
|
152
|
+
>
|
|
153
|
+
<CustomGradientPicker
|
|
154
|
+
__nextHasNoMargin={ __nextHasNoMargin }
|
|
155
|
+
__experimentalIsRenderedInSidebar={
|
|
156
|
+
__experimentalIsRenderedInSidebar
|
|
157
|
+
}
|
|
158
|
+
value={ value }
|
|
159
|
+
onChange={ onChange }
|
|
160
|
+
/>
|
|
161
|
+
</Spacer>
|
|
147
162
|
)
|
|
148
163
|
}
|
|
149
164
|
/>
|
|
@@ -1,8 +1,3 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* External dependencies
|
|
3
|
-
*/
|
|
4
|
-
import { text, boolean, object } from '@storybook/addon-knobs';
|
|
5
|
-
|
|
6
1
|
/**
|
|
7
2
|
* WordPress dependencies
|
|
8
3
|
*/
|
|
@@ -16,94 +11,74 @@ import GradientPicker from '../';
|
|
|
16
11
|
export default {
|
|
17
12
|
title: 'Components/GradientPicker',
|
|
18
13
|
component: GradientPicker,
|
|
19
|
-
|
|
20
|
-
|
|
14
|
+
argTypes: {
|
|
15
|
+
__nextHasNoMargin: { control: { type: 'boolean' } },
|
|
16
|
+
clearable: { control: { type: 'boolean' } },
|
|
17
|
+
disableCustomGradients: { control: { type: 'boolean' } },
|
|
18
|
+
onChange: { action: 'onChange' },
|
|
21
19
|
},
|
|
22
20
|
};
|
|
23
21
|
|
|
24
|
-
const
|
|
22
|
+
const GRADIENTS = [
|
|
23
|
+
{
|
|
24
|
+
name: 'Vivid cyan blue to vivid purple',
|
|
25
|
+
gradient:
|
|
26
|
+
'linear-gradient(135deg,rgba(6,147,227,1) 0%,rgb(155,81,224) 100%)',
|
|
27
|
+
slug: 'vivid-cyan-blue-to-vivid-purple',
|
|
28
|
+
},
|
|
29
|
+
{
|
|
30
|
+
name: 'Light green cyan to vivid green cyan',
|
|
31
|
+
gradient:
|
|
32
|
+
'linear-gradient(135deg,rgb(122,220,180) 0%,rgb(0,208,130) 100%)',
|
|
33
|
+
slug: 'light-green-cyan-to-vivid-green-cyan',
|
|
34
|
+
},
|
|
35
|
+
{
|
|
36
|
+
name: 'Luminous vivid amber to luminous vivid orange',
|
|
37
|
+
gradient:
|
|
38
|
+
'linear-gradient(135deg,rgba(252,185,0,1) 0%,rgba(255,105,0,1) 100%)',
|
|
39
|
+
slug: 'luminous-vivid-amber-to-luminous-vivid-orange',
|
|
40
|
+
},
|
|
41
|
+
{
|
|
42
|
+
name: 'Luminous vivid orange to vivid red',
|
|
43
|
+
gradient:
|
|
44
|
+
'linear-gradient(135deg,rgba(255,105,0,1) 0%,rgb(207,46,46) 100%)',
|
|
45
|
+
slug: 'luminous-vivid-orange-to-vivid-red',
|
|
46
|
+
},
|
|
47
|
+
{
|
|
48
|
+
name: 'Very light gray to cyan bluish gray',
|
|
49
|
+
gradient:
|
|
50
|
+
'linear-gradient(135deg,rgb(238,238,238) 0%,rgb(169,184,195) 100%)',
|
|
51
|
+
slug: 'very-light-gray-to-cyan-bluish-gray',
|
|
52
|
+
},
|
|
53
|
+
{
|
|
54
|
+
name: 'Cool to warm spectrum',
|
|
55
|
+
gradient:
|
|
56
|
+
'linear-gradient(135deg,rgb(74,234,220) 0%,rgb(151,120,209) 20%,rgb(207,42,186) 40%,rgb(238,44,130) 60%,rgb(251,105,98) 80%,rgb(254,248,76) 100%)',
|
|
57
|
+
slug: 'cool-to-warm-spectrum',
|
|
58
|
+
},
|
|
59
|
+
];
|
|
60
|
+
|
|
61
|
+
const Template = ( { onChange, ...props } ) => {
|
|
25
62
|
const [ gradient, setGradient ] = useState();
|
|
26
63
|
return (
|
|
27
64
|
<GradientPicker
|
|
28
65
|
{ ...props }
|
|
29
66
|
value={ gradient }
|
|
30
|
-
onChange={
|
|
67
|
+
onChange={ ( ...changeArgs ) => {
|
|
68
|
+
setGradient( ...changeArgs );
|
|
69
|
+
onChange?.( ...changeArgs );
|
|
70
|
+
} }
|
|
31
71
|
/>
|
|
32
72
|
);
|
|
33
73
|
};
|
|
34
74
|
|
|
35
|
-
export const
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
const className = text( 'Class Name', '' );
|
|
39
|
-
const gradients = object( 'Gradients', [
|
|
40
|
-
{
|
|
41
|
-
name: 'Vivid cyan blue to vivid purple',
|
|
42
|
-
gradient:
|
|
43
|
-
'linear-gradient(135deg,rgba(6,147,227,1) 0%,rgb(155,81,224) 100%)',
|
|
44
|
-
slug: 'vivid-cyan-blue-to-vivid-purple',
|
|
45
|
-
},
|
|
46
|
-
{
|
|
47
|
-
name: 'Light green cyan to vivid green cyan',
|
|
48
|
-
gradient:
|
|
49
|
-
'linear-gradient(135deg,rgb(122,220,180) 0%,rgb(0,208,130) 100%)',
|
|
50
|
-
slug: 'light-green-cyan-to-vivid-green-cyan',
|
|
51
|
-
},
|
|
52
|
-
{
|
|
53
|
-
name: 'Luminous vivid amber to luminous vivid orange',
|
|
54
|
-
gradient:
|
|
55
|
-
'linear-gradient(135deg,rgba(252,185,0,1) 0%,rgba(255,105,0,1) 100%)',
|
|
56
|
-
slug: 'luminous-vivid-amber-to-luminous-vivid-orange',
|
|
57
|
-
},
|
|
58
|
-
{
|
|
59
|
-
name: 'Luminous vivid orange to vivid red',
|
|
60
|
-
gradient:
|
|
61
|
-
'linear-gradient(135deg,rgba(255,105,0,1) 0%,rgb(207,46,46) 100%)',
|
|
62
|
-
slug: 'luminous-vivid-orange-to-vivid-red',
|
|
63
|
-
},
|
|
64
|
-
{
|
|
65
|
-
name: 'Very light gray to cyan bluish gray',
|
|
66
|
-
gradient:
|
|
67
|
-
'linear-gradient(135deg,rgb(238,238,238) 0%,rgb(169,184,195) 100%)',
|
|
68
|
-
slug: 'very-light-gray-to-cyan-bluish-gray',
|
|
69
|
-
},
|
|
70
|
-
{
|
|
71
|
-
name: 'Cool to warm spectrum',
|
|
72
|
-
gradient:
|
|
73
|
-
'linear-gradient(135deg,rgb(74,234,220) 0%,rgb(151,120,209) 20%,rgb(207,42,186) 40%,rgb(238,44,130) 60%,rgb(251,105,98) 80%,rgb(254,248,76) 100%)',
|
|
74
|
-
slug: 'cool-to-warm-spectrum',
|
|
75
|
-
},
|
|
76
|
-
] );
|
|
77
|
-
|
|
78
|
-
return (
|
|
79
|
-
<GradientPickerWithState
|
|
80
|
-
disableCustomGradients={ disableCustomGradients }
|
|
81
|
-
gradients={ gradients }
|
|
82
|
-
clearable={ clearable }
|
|
83
|
-
className={ className }
|
|
84
|
-
/>
|
|
85
|
-
);
|
|
75
|
+
export const Default = Template.bind( {} );
|
|
76
|
+
Default.args = {
|
|
77
|
+
gradients: GRADIENTS,
|
|
86
78
|
};
|
|
87
79
|
|
|
88
|
-
export const WithNoExistingGradients = (
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
true
|
|
93
|
-
);
|
|
94
|
-
const clearable = boolean( 'Clearable', true );
|
|
95
|
-
const className = text( 'Class Name', '' );
|
|
96
|
-
const gradients = object( 'Gradients', [] );
|
|
97
|
-
|
|
98
|
-
return (
|
|
99
|
-
<GradientPickerWithState
|
|
100
|
-
__experimentalHasMultipleOrigins={
|
|
101
|
-
__experimentalHasMultipleOrigins
|
|
102
|
-
}
|
|
103
|
-
disableCustomGradients={ disableCustomGradients }
|
|
104
|
-
gradients={ gradients }
|
|
105
|
-
clearable={ clearable }
|
|
106
|
-
className={ className }
|
|
107
|
-
/>
|
|
108
|
-
);
|
|
80
|
+
export const WithNoExistingGradients = Template.bind( {} );
|
|
81
|
+
WithNoExistingGradients.args = {
|
|
82
|
+
...Default.args,
|
|
83
|
+
gradients: [],
|
|
109
84
|
};
|
package/src/guide/index.js
CHANGED
|
@@ -42,7 +42,9 @@ export default function Guide( {
|
|
|
42
42
|
useEffect( () => {
|
|
43
43
|
// Each time we change the current page, start from the first element of the page.
|
|
44
44
|
// This also solves any focus loss that can happen.
|
|
45
|
-
|
|
45
|
+
if ( guideContainer.current ) {
|
|
46
|
+
focus.tabbable.find( guideContainer.current )?.[ 0 ]?.focus();
|
|
47
|
+
}
|
|
46
48
|
}, [ currentPage ] );
|
|
47
49
|
|
|
48
50
|
if ( Children.count( children ) ) {
|
|
@@ -1,8 +1,3 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* External dependencies
|
|
3
|
-
*/
|
|
4
|
-
import { times } from 'lodash';
|
|
5
|
-
|
|
6
1
|
/**
|
|
7
2
|
* WordPress dependencies
|
|
8
3
|
*/
|
|
@@ -24,7 +19,7 @@ export default function PageControl( {
|
|
|
24
19
|
className="components-guide__page-control"
|
|
25
20
|
aria-label={ __( 'Guide controls' ) }
|
|
26
21
|
>
|
|
27
|
-
{
|
|
22
|
+
{ Array.from( { length: numberOfPages } ).map( ( _, page ) => (
|
|
28
23
|
<li
|
|
29
24
|
key={ page }
|
|
30
25
|
// Set aria-current="step" on the active page, see https://www.w3.org/TR/wai-aria-1.1/#aria-current
|
|
@@ -1,7 +1,6 @@
|
|
|
1
1
|
/**
|
|
2
2
|
* External dependencies
|
|
3
3
|
*/
|
|
4
|
-
import { times } from 'lodash';
|
|
5
4
|
import { text, number } from '@storybook/addon-knobs';
|
|
6
5
|
|
|
7
6
|
/**
|
|
@@ -41,16 +40,18 @@ const ModalExample = ( { numberOfPages, ...props } ) => {
|
|
|
41
40
|
<Guide
|
|
42
41
|
{ ...props }
|
|
43
42
|
onFinish={ closeGuide }
|
|
44
|
-
pages={
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
43
|
+
pages={ Array.from( { length: numberOfPages } ).map(
|
|
44
|
+
( _, page ) => ( {
|
|
45
|
+
content: (
|
|
46
|
+
<>
|
|
47
|
+
<h1>
|
|
48
|
+
Page { page + 1 } of { numberOfPages }
|
|
49
|
+
</h1>
|
|
50
|
+
<p>{ loremIpsum }</p>
|
|
51
|
+
</>
|
|
52
|
+
),
|
|
53
|
+
} )
|
|
54
|
+
) }
|
|
54
55
|
/>
|
|
55
56
|
) }
|
|
56
57
|
</>
|
package/src/guide/test/index.js
CHANGED
|
@@ -1,23 +1,22 @@
|
|
|
1
1
|
/**
|
|
2
2
|
* External dependencies
|
|
3
3
|
*/
|
|
4
|
-
import {
|
|
4
|
+
import { render, screen } from '@testing-library/react';
|
|
5
|
+
import userEvent from '@testing-library/user-event';
|
|
5
6
|
|
|
6
7
|
/**
|
|
7
8
|
* Internal dependencies
|
|
8
9
|
*/
|
|
9
10
|
import Guide from '../';
|
|
10
|
-
import PageControl from '../page-control';
|
|
11
|
-
import Modal from '../../modal';
|
|
12
11
|
|
|
13
12
|
describe( 'Guide', () => {
|
|
14
13
|
it( 'renders nothing when there are no pages', () => {
|
|
15
|
-
|
|
16
|
-
expect(
|
|
14
|
+
render( <Guide pages={ [] } /> );
|
|
15
|
+
expect( screen.queryByRole( 'dialog' ) ).not.toBeInTheDocument();
|
|
17
16
|
} );
|
|
18
17
|
|
|
19
18
|
it( 'renders one page at a time', () => {
|
|
20
|
-
|
|
19
|
+
render(
|
|
21
20
|
<Guide
|
|
22
21
|
pages={ [
|
|
23
22
|
{ content: <p>Page 1</p> },
|
|
@@ -25,11 +24,14 @@ describe( 'Guide', () => {
|
|
|
25
24
|
] }
|
|
26
25
|
/>
|
|
27
26
|
);
|
|
28
|
-
|
|
27
|
+
|
|
28
|
+
expect( screen.queryByRole( 'dialog' ) ).toBeVisible();
|
|
29
|
+
expect( screen.queryByText( 'Page 1' ) ).toBeVisible();
|
|
30
|
+
expect( screen.queryByText( 'Page 2' ) ).not.toBeInTheDocument();
|
|
29
31
|
} );
|
|
30
32
|
|
|
31
33
|
it( 'hides back button and shows forward button on the first page', () => {
|
|
32
|
-
|
|
34
|
+
render(
|
|
33
35
|
<Guide
|
|
34
36
|
pages={ [
|
|
35
37
|
{ content: <p>Page 1</p> },
|
|
@@ -37,20 +39,23 @@ describe( 'Guide', () => {
|
|
|
37
39
|
] }
|
|
38
40
|
/>
|
|
39
41
|
);
|
|
40
|
-
|
|
41
|
-
expect(
|
|
42
|
-
|
|
43
|
-
);
|
|
42
|
+
|
|
43
|
+
expect(
|
|
44
|
+
screen.queryByRole( 'button', { name: 'Previous' } )
|
|
45
|
+
).not.toBeInTheDocument();
|
|
44
46
|
expect(
|
|
45
|
-
|
|
46
|
-
).
|
|
47
|
+
screen.queryByRole( 'button', { name: 'Next' } )
|
|
48
|
+
).toBeVisible();
|
|
47
49
|
expect(
|
|
48
|
-
|
|
49
|
-
).
|
|
50
|
+
screen.queryByRole( 'button', { name: 'Finish' } )
|
|
51
|
+
).not.toBeInTheDocument();
|
|
50
52
|
} );
|
|
51
53
|
|
|
52
|
-
it( 'shows back button and shows finish button on the last page', () => {
|
|
53
|
-
const
|
|
54
|
+
it( 'shows back button and shows finish button on the last page', async () => {
|
|
55
|
+
const user = userEvent.setup( {
|
|
56
|
+
advanceTimers: jest.advanceTimersByTime,
|
|
57
|
+
} );
|
|
58
|
+
render(
|
|
54
59
|
<Guide
|
|
55
60
|
pages={ [
|
|
56
61
|
{ content: <p>Page 1</p> },
|
|
@@ -58,47 +63,59 @@ describe( 'Guide', () => {
|
|
|
58
63
|
] }
|
|
59
64
|
/>
|
|
60
65
|
);
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
expect(
|
|
64
|
-
|
|
65
|
-
|
|
66
|
+
await user.click( screen.getByRole( 'button', { name: 'Next' } ) );
|
|
67
|
+
|
|
68
|
+
expect( screen.queryByText( 'Page 1' ) ).not.toBeInTheDocument();
|
|
69
|
+
expect( screen.queryByText( 'Page 2' ) ).toBeVisible();
|
|
70
|
+
|
|
66
71
|
expect(
|
|
67
|
-
|
|
68
|
-
).
|
|
72
|
+
screen.queryByRole( 'button', { name: 'Previous' } )
|
|
73
|
+
).toBeVisible();
|
|
69
74
|
expect(
|
|
70
|
-
|
|
71
|
-
).
|
|
75
|
+
screen.queryByRole( 'button', { name: 'Next' } )
|
|
76
|
+
).not.toBeInTheDocument();
|
|
77
|
+
expect(
|
|
78
|
+
screen.queryByRole( 'button', { name: 'Finish' } )
|
|
79
|
+
).toBeVisible();
|
|
72
80
|
} );
|
|
73
81
|
|
|
74
82
|
it( "doesn't display the page control if there is only one page", () => {
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
83
|
+
render( <Guide pages={ [ { content: <p>Page 1</p> } ] } /> );
|
|
84
|
+
expect(
|
|
85
|
+
screen.queryByRole( 'list', { name: 'Guide controls' } )
|
|
86
|
+
).not.toBeInTheDocument();
|
|
79
87
|
} );
|
|
80
88
|
|
|
81
|
-
it( 'calls onFinish when the finish button is clicked', () => {
|
|
89
|
+
it( 'calls onFinish when the finish button is clicked', async () => {
|
|
90
|
+
const user = userEvent.setup( {
|
|
91
|
+
advanceTimers: jest.advanceTimersByTime,
|
|
92
|
+
} );
|
|
82
93
|
const onFinish = jest.fn();
|
|
83
|
-
|
|
94
|
+
render(
|
|
84
95
|
<Guide
|
|
85
96
|
onFinish={ onFinish }
|
|
86
97
|
pages={ [ { content: <p>Page 1</p> } ] }
|
|
87
98
|
/>
|
|
88
99
|
);
|
|
89
|
-
|
|
100
|
+
await user.click( screen.getByRole( 'button', { name: 'Finish' } ) );
|
|
101
|
+
|
|
90
102
|
expect( onFinish ).toHaveBeenCalled();
|
|
91
103
|
} );
|
|
92
104
|
|
|
93
|
-
it( 'calls onFinish when the modal is closed', () => {
|
|
105
|
+
it( 'calls onFinish when the modal is closed', async () => {
|
|
106
|
+
const user = userEvent.setup( {
|
|
107
|
+
advanceTimers: jest.advanceTimersByTime,
|
|
108
|
+
} );
|
|
94
109
|
const onFinish = jest.fn();
|
|
95
|
-
|
|
110
|
+
render(
|
|
96
111
|
<Guide
|
|
97
112
|
onFinish={ onFinish }
|
|
98
113
|
pages={ [ { content: <p>Page 1</p> } ] }
|
|
99
114
|
/>
|
|
100
115
|
);
|
|
101
|
-
|
|
116
|
+
|
|
117
|
+
await user.keyboard( '[Escape]' );
|
|
118
|
+
|
|
102
119
|
expect( onFinish ).toHaveBeenCalled();
|
|
103
120
|
} );
|
|
104
121
|
} );
|
|
@@ -1,12 +1,8 @@
|
|
|
1
1
|
/**
|
|
2
2
|
* External dependencies
|
|
3
3
|
*/
|
|
4
|
-
import {
|
|
5
|
-
|
|
6
|
-
/**
|
|
7
|
-
* WordPress dependencies
|
|
8
|
-
*/
|
|
9
|
-
import { Button } from '@wordpress/components';
|
|
4
|
+
import { render, screen } from '@testing-library/react';
|
|
5
|
+
import userEvent from '@testing-library/user-event';
|
|
10
6
|
|
|
11
7
|
/**
|
|
12
8
|
* Internal dependencies
|
|
@@ -15,29 +11,30 @@ import PageControl from '../page-control';
|
|
|
15
11
|
|
|
16
12
|
describe( 'PageControl', () => {
|
|
17
13
|
it( 'renders an empty list when there are no pages', () => {
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
);
|
|
21
|
-
expect( wrapper.find( Button ) ).toHaveLength( 0 );
|
|
14
|
+
render( <PageControl currentPage={ 0 } numberOfPages={ 0 } /> );
|
|
15
|
+
expect( screen.queryByRole( 'button' ) ).not.toBeInTheDocument();
|
|
22
16
|
} );
|
|
23
17
|
|
|
24
18
|
it( 'renders a button for each page', () => {
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
);
|
|
28
|
-
expect( wrapper.find( Button ) ).toHaveLength( 5 );
|
|
19
|
+
render( <PageControl currentPage={ 0 } numberOfPages={ 5 } /> );
|
|
20
|
+
expect( screen.getAllByRole( 'button' ) ).toHaveLength( 5 );
|
|
29
21
|
} );
|
|
30
22
|
|
|
31
|
-
it( 'sets the current page when a button is clicked', () => {
|
|
23
|
+
it( 'sets the current page when a button is clicked', async () => {
|
|
24
|
+
const user = userEvent.setup( {
|
|
25
|
+
advanceTimers: jest.advanceTimersByTime,
|
|
26
|
+
} );
|
|
32
27
|
const setCurrentPage = jest.fn();
|
|
33
|
-
|
|
28
|
+
render(
|
|
34
29
|
<PageControl
|
|
35
30
|
currentPage={ 0 }
|
|
36
31
|
numberOfPages={ 2 }
|
|
37
32
|
setCurrentPage={ setCurrentPage }
|
|
38
33
|
/>
|
|
39
34
|
);
|
|
40
|
-
|
|
35
|
+
|
|
36
|
+
await user.click( screen.getAllByRole( 'button' )[ 1 ] );
|
|
37
|
+
|
|
41
38
|
expect( setCurrentPage ).toHaveBeenCalledWith( 1 );
|
|
42
39
|
} );
|
|
43
40
|
} );
|
|
@@ -5,6 +5,7 @@ import {
|
|
|
5
5
|
act,
|
|
6
6
|
render,
|
|
7
7
|
fireEvent,
|
|
8
|
+
screen,
|
|
8
9
|
waitForElementToBeRemoved,
|
|
9
10
|
within,
|
|
10
11
|
} from '@testing-library/react';
|
|
@@ -145,10 +146,11 @@ describe( 'withNotices rendering', () => {
|
|
|
145
146
|
it( 'should display notices with functioning dismissal triggers', async () => {
|
|
146
147
|
const messages = [ 'Aló!', 'hu dis?', 'Otis' ];
|
|
147
148
|
const notices = noticesFrom( messages );
|
|
148
|
-
const { container
|
|
149
|
+
const { container } = render(
|
|
149
150
|
<TestComponent notifications={ notices } />
|
|
150
151
|
);
|
|
151
|
-
const [ buttonRemoveFirst ] =
|
|
152
|
+
const [ buttonRemoveFirst ] =
|
|
153
|
+
screen.getAllByLabelText( stockDismissText );
|
|
152
154
|
const getRemovalTarget = () =>
|
|
153
155
|
within( container ).getByText(
|
|
154
156
|
// The last item corresponds to the first notice in the DOM.
|