@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
|
@@ -0,0 +1,174 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* External dependencies
|
|
3
|
+
*/
|
|
4
|
+
import { render, screen, within } from '@testing-library/react';
|
|
5
|
+
|
|
6
|
+
/**
|
|
7
|
+
* WordPress dependencies
|
|
8
|
+
*/
|
|
9
|
+
import { useResizeObserver } from '@wordpress/compose';
|
|
10
|
+
import { SVG, Path } from '@wordpress/primitives';
|
|
11
|
+
|
|
12
|
+
/**
|
|
13
|
+
* Internal dependencies
|
|
14
|
+
*/
|
|
15
|
+
import BasePlaceholder from '../';
|
|
16
|
+
import type { WordPressComponentProps } from '../../ui/context';
|
|
17
|
+
import type { PlaceholderProps } from '../types';
|
|
18
|
+
|
|
19
|
+
jest.mock( '@wordpress/compose', () => {
|
|
20
|
+
return {
|
|
21
|
+
...jest.requireActual( '@wordpress/compose' ),
|
|
22
|
+
useResizeObserver: jest.fn( () => [] ),
|
|
23
|
+
};
|
|
24
|
+
} );
|
|
25
|
+
|
|
26
|
+
/**
|
|
27
|
+
* Test icon that can be queried by `getByTestId`
|
|
28
|
+
*/
|
|
29
|
+
const testIcon = (
|
|
30
|
+
<SVG data-testid="icon">
|
|
31
|
+
<Path />
|
|
32
|
+
</SVG>
|
|
33
|
+
);
|
|
34
|
+
|
|
35
|
+
const Placeholder = (
|
|
36
|
+
props: Omit<
|
|
37
|
+
WordPressComponentProps< PlaceholderProps< unknown >, 'div', false >,
|
|
38
|
+
'ref'
|
|
39
|
+
>
|
|
40
|
+
) => <BasePlaceholder data-testid="placeholder" { ...props } />;
|
|
41
|
+
|
|
42
|
+
const getPlaceholder = () => screen.getByTestId( 'placeholder' );
|
|
43
|
+
|
|
44
|
+
describe( 'Placeholder', () => {
|
|
45
|
+
beforeEach( () => {
|
|
46
|
+
// @ts-ignore
|
|
47
|
+
useResizeObserver.mockReturnValue( [
|
|
48
|
+
<div key="1" />,
|
|
49
|
+
{ width: 320 },
|
|
50
|
+
] );
|
|
51
|
+
} );
|
|
52
|
+
|
|
53
|
+
describe( 'basic rendering', () => {
|
|
54
|
+
it( 'should by default render label section and fieldset.', () => {
|
|
55
|
+
render( <Placeholder /> );
|
|
56
|
+
const placeholder = getPlaceholder();
|
|
57
|
+
|
|
58
|
+
expect( placeholder ).toHaveClass( 'components-placeholder' );
|
|
59
|
+
|
|
60
|
+
// Test for empty label. When the label is empty, the only way to
|
|
61
|
+
// query the div is with `querySelector`.
|
|
62
|
+
const label = placeholder.querySelector(
|
|
63
|
+
'.components-placeholder__label'
|
|
64
|
+
);
|
|
65
|
+
expect( label ).toBeInTheDocument();
|
|
66
|
+
expect( label ).toBeEmptyDOMElement();
|
|
67
|
+
|
|
68
|
+
// Test for non existent instructions. When the instructions is
|
|
69
|
+
// empty, the only way to query the div is with `querySelector`.
|
|
70
|
+
const placeholderInstructions = placeholder.querySelector(
|
|
71
|
+
'.components-placeholder__instructions'
|
|
72
|
+
);
|
|
73
|
+
expect( placeholderInstructions ).not.toBeInTheDocument();
|
|
74
|
+
|
|
75
|
+
// Test for empty fieldset.
|
|
76
|
+
const placeholderFieldset =
|
|
77
|
+
within( placeholder ).getByRole( 'group' );
|
|
78
|
+
expect( placeholderFieldset ).toBeInTheDocument();
|
|
79
|
+
expect( placeholderFieldset ).toBeEmptyDOMElement();
|
|
80
|
+
} );
|
|
81
|
+
|
|
82
|
+
it( 'should render an Icon in the label section', () => {
|
|
83
|
+
render( <Placeholder icon={ testIcon } /> );
|
|
84
|
+
|
|
85
|
+
const placeholder = getPlaceholder();
|
|
86
|
+
const icon = within( placeholder ).getByTestId( 'icon' );
|
|
87
|
+
expect( icon.parentNode ).toHaveClass(
|
|
88
|
+
'components-placeholder__label'
|
|
89
|
+
);
|
|
90
|
+
expect( icon ).toBeInTheDocument();
|
|
91
|
+
} );
|
|
92
|
+
|
|
93
|
+
it( 'should render a label section', () => {
|
|
94
|
+
const label = 'WordPress';
|
|
95
|
+
render( <Placeholder label={ label } /> );
|
|
96
|
+
const placeholderLabel = screen.getByText( label );
|
|
97
|
+
|
|
98
|
+
expect( placeholderLabel ).toHaveClass(
|
|
99
|
+
'components-placeholder__label'
|
|
100
|
+
);
|
|
101
|
+
expect( placeholderLabel ).toBeInTheDocument();
|
|
102
|
+
} );
|
|
103
|
+
|
|
104
|
+
it( 'should display a fieldset from the children property', () => {
|
|
105
|
+
const content = 'Fieldset';
|
|
106
|
+
render( <Placeholder>{ content }</Placeholder> );
|
|
107
|
+
const placeholderFieldset = screen.getByRole( 'group' );
|
|
108
|
+
|
|
109
|
+
expect( placeholderFieldset ).toBeInTheDocument();
|
|
110
|
+
expect( placeholderFieldset ).toHaveTextContent( content );
|
|
111
|
+
} );
|
|
112
|
+
|
|
113
|
+
it( 'should display a legend if instructions are passed', () => {
|
|
114
|
+
const instructions = 'Choose an option.';
|
|
115
|
+
render(
|
|
116
|
+
<Placeholder instructions={ instructions }>
|
|
117
|
+
<div>Fieldset</div>
|
|
118
|
+
</Placeholder>
|
|
119
|
+
);
|
|
120
|
+
const captionedFieldset = screen.getByRole( 'group', {
|
|
121
|
+
name: instructions,
|
|
122
|
+
} );
|
|
123
|
+
|
|
124
|
+
expect( captionedFieldset ).toBeInTheDocument();
|
|
125
|
+
} );
|
|
126
|
+
|
|
127
|
+
it( 'should add an additional className to the top container', () => {
|
|
128
|
+
render( <Placeholder className="wp-placeholder" /> );
|
|
129
|
+
const placeholder = getPlaceholder();
|
|
130
|
+
|
|
131
|
+
expect( placeholder ).toHaveClass( 'components-placeholder' );
|
|
132
|
+
expect( placeholder ).toHaveClass( 'wp-placeholder' );
|
|
133
|
+
} );
|
|
134
|
+
|
|
135
|
+
it( 'should add additional props to the top level container', () => {
|
|
136
|
+
render( <Placeholder data-test="test" /> );
|
|
137
|
+
const placeholder = getPlaceholder();
|
|
138
|
+
|
|
139
|
+
expect( placeholder ).toHaveAttribute( 'data-test', 'test' );
|
|
140
|
+
} );
|
|
141
|
+
} );
|
|
142
|
+
|
|
143
|
+
describe( 'resize aware', () => {
|
|
144
|
+
it( 'should not assign modifier class in first-pass `null` width from `useResizeObserver`', () => {
|
|
145
|
+
// @ts-ignore
|
|
146
|
+
useResizeObserver.mockReturnValue( [
|
|
147
|
+
<div key="1" />,
|
|
148
|
+
{ width: 480 },
|
|
149
|
+
] );
|
|
150
|
+
|
|
151
|
+
render( <Placeholder /> );
|
|
152
|
+
const placeholder = getPlaceholder();
|
|
153
|
+
|
|
154
|
+
expect( placeholder ).toHaveClass( 'is-large' );
|
|
155
|
+
expect( placeholder ).not.toHaveClass( 'is-medium' );
|
|
156
|
+
expect( placeholder ).not.toHaveClass( 'is-small' );
|
|
157
|
+
} );
|
|
158
|
+
|
|
159
|
+
it( 'should assign modifier class', () => {
|
|
160
|
+
// @ts-ignore
|
|
161
|
+
useResizeObserver.mockReturnValue( [
|
|
162
|
+
<div key="1" />,
|
|
163
|
+
{ width: null },
|
|
164
|
+
] );
|
|
165
|
+
|
|
166
|
+
render( <Placeholder /> );
|
|
167
|
+
const placeholder = getPlaceholder();
|
|
168
|
+
|
|
169
|
+
expect( placeholder ).not.toHaveClass( 'is-large' );
|
|
170
|
+
expect( placeholder ).not.toHaveClass( 'is-medium' );
|
|
171
|
+
expect( placeholder ).not.toHaveClass( 'is-small' );
|
|
172
|
+
} );
|
|
173
|
+
} );
|
|
174
|
+
} );
|
package/src/popover/index.js
CHANGED
|
@@ -13,6 +13,8 @@ import {
|
|
|
13
13
|
limitShift,
|
|
14
14
|
size,
|
|
15
15
|
} from '@floating-ui/react-dom';
|
|
16
|
+
// eslint-disable-next-line no-restricted-imports
|
|
17
|
+
import { motion, useReducedMotion } from 'framer-motion';
|
|
16
18
|
|
|
17
19
|
/**
|
|
18
20
|
* WordPress dependencies
|
|
@@ -24,6 +26,7 @@ import {
|
|
|
24
26
|
createContext,
|
|
25
27
|
useContext,
|
|
26
28
|
useMemo,
|
|
29
|
+
useEffect,
|
|
27
30
|
} from '@wordpress/element';
|
|
28
31
|
import {
|
|
29
32
|
useViewportMatch,
|
|
@@ -40,7 +43,11 @@ import { Path, SVG } from '@wordpress/primitives';
|
|
|
40
43
|
import Button from '../button';
|
|
41
44
|
import ScrollLock from '../scroll-lock';
|
|
42
45
|
import { Slot, Fill, useSlot } from '../slot-fill';
|
|
43
|
-
import {
|
|
46
|
+
import {
|
|
47
|
+
getFrameOffset,
|
|
48
|
+
positionToPlacement,
|
|
49
|
+
placementToMotionAnimationProps,
|
|
50
|
+
} from './utils';
|
|
44
51
|
|
|
45
52
|
/**
|
|
46
53
|
* Name of slot in which popover should fill.
|
|
@@ -73,50 +80,48 @@ const ArrowTriangle = ( props ) => (
|
|
|
73
80
|
</SVG>
|
|
74
81
|
);
|
|
75
82
|
|
|
76
|
-
const
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
};
|
|
83
|
+
const MaybeAnimatedWrapper = forwardRef(
|
|
84
|
+
(
|
|
85
|
+
{
|
|
86
|
+
style: receivedInlineStyles,
|
|
87
|
+
placement,
|
|
88
|
+
shouldAnimate = false,
|
|
89
|
+
...props
|
|
90
|
+
},
|
|
91
|
+
forwardedRef
|
|
92
|
+
) => {
|
|
93
|
+
const shouldReduceMotion = useReducedMotion();
|
|
94
|
+
|
|
95
|
+
const { style: motionInlineStyles, ...otherMotionProps } = useMemo(
|
|
96
|
+
() => placementToMotionAnimationProps( placement ),
|
|
97
|
+
[ placement ]
|
|
98
|
+
);
|
|
93
99
|
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
|
|
100
|
+
if ( shouldAnimate && ! shouldReduceMotion ) {
|
|
101
|
+
return (
|
|
102
|
+
<motion.div
|
|
103
|
+
style={ {
|
|
104
|
+
...motionInlineStyles,
|
|
105
|
+
...receivedInlineStyles,
|
|
106
|
+
} }
|
|
107
|
+
{ ...otherMotionProps }
|
|
108
|
+
{ ...props }
|
|
109
|
+
ref={ forwardedRef }
|
|
110
|
+
/>
|
|
111
|
+
);
|
|
105
112
|
}
|
|
106
|
-
}
|
|
107
113
|
|
|
108
|
-
|
|
109
|
-
|
|
110
|
-
|
|
111
|
-
|
|
112
|
-
|
|
113
|
-
|
|
114
|
-
|
|
115
|
-
}
|
|
114
|
+
return (
|
|
115
|
+
<div
|
|
116
|
+
style={ receivedInlineStyles }
|
|
117
|
+
{ ...props }
|
|
118
|
+
ref={ forwardedRef }
|
|
119
|
+
/>
|
|
120
|
+
);
|
|
116
121
|
}
|
|
122
|
+
);
|
|
117
123
|
|
|
118
|
-
|
|
119
|
-
};
|
|
124
|
+
const slotNameContext = createContext();
|
|
120
125
|
|
|
121
126
|
const Popover = (
|
|
122
127
|
{
|
|
@@ -130,7 +135,7 @@ const Popover = (
|
|
|
130
135
|
isAlternate,
|
|
131
136
|
position,
|
|
132
137
|
placement: placementProp = 'bottom-start',
|
|
133
|
-
offset,
|
|
138
|
+
offset: offsetProp = 0,
|
|
134
139
|
focusOnMount = 'firstElement',
|
|
135
140
|
anchorRef,
|
|
136
141
|
anchorRect,
|
|
@@ -162,7 +167,7 @@ const Popover = (
|
|
|
162
167
|
? positionToPlacement( position )
|
|
163
168
|
: placementProp;
|
|
164
169
|
|
|
165
|
-
const
|
|
170
|
+
const referenceOwnerDocument = useMemo( () => {
|
|
166
171
|
let documentToReturn;
|
|
167
172
|
|
|
168
173
|
if ( anchorRef?.top ) {
|
|
@@ -187,62 +192,57 @@ const Popover = (
|
|
|
187
192
|
|
|
188
193
|
/**
|
|
189
194
|
* Offsets the position of the popover when the anchor is inside an iframe.
|
|
195
|
+
*
|
|
196
|
+
* Store the offset in a ref, due to constraints with floating-ui:
|
|
197
|
+
* https://floating-ui.com/docs/react-dom#variables-inside-middleware-functions.
|
|
190
198
|
*/
|
|
191
|
-
const
|
|
192
|
-
|
|
193
|
-
|
|
194
|
-
|
|
195
|
-
|
|
196
|
-
|
|
197
|
-
}
|
|
198
|
-
|
|
199
|
-
const iframeRect = frameElement.getBoundingClientRect();
|
|
200
|
-
return { x: iframeRect.left, y: iframeRect.top };
|
|
201
|
-
}, [ ownerDocument ] );
|
|
199
|
+
const frameOffsetRef = useRef( getFrameOffset( referenceOwnerDocument ) );
|
|
200
|
+
/**
|
|
201
|
+
* Store the offset prop in a ref, due to constraints with floating-ui:
|
|
202
|
+
* https://floating-ui.com/docs/react-dom#variables-inside-middleware-functions.
|
|
203
|
+
*/
|
|
204
|
+
const offsetRef = useRef( offsetProp );
|
|
202
205
|
|
|
203
206
|
const middleware = [
|
|
204
|
-
|
|
205
|
-
|
|
206
|
-
|
|
207
|
-
|
|
208
|
-
|
|
209
|
-
|
|
210
|
-
|
|
211
|
-
|
|
212
|
-
|
|
213
|
-
|
|
214
|
-
|
|
215
|
-
|
|
216
|
-
|
|
217
|
-
|
|
218
|
-
|
|
219
|
-
|
|
220
|
-
|
|
221
|
-
|
|
222
|
-
|
|
223
|
-
|
|
224
|
-
|
|
225
|
-
|
|
226
|
-
|
|
227
|
-
|
|
228
|
-
|
|
229
|
-
|
|
230
|
-
|
|
231
|
-
|
|
232
|
-
|
|
233
|
-
};
|
|
234
|
-
} )
|
|
235
|
-
: undefined,
|
|
207
|
+
offsetMiddleware( ( { placement: currentPlacement } ) => {
|
|
208
|
+
if ( ! frameOffsetRef.current ) {
|
|
209
|
+
return offsetRef.current;
|
|
210
|
+
}
|
|
211
|
+
|
|
212
|
+
const isTopBottomPlacement =
|
|
213
|
+
currentPlacement.includes( 'top' ) ||
|
|
214
|
+
currentPlacement.includes( 'bottom' );
|
|
215
|
+
|
|
216
|
+
// The main axis should represent the gap between the
|
|
217
|
+
// floating element and the reference element. The cross
|
|
218
|
+
// axis is always perpendicular to the main axis.
|
|
219
|
+
const mainAxis = isTopBottomPlacement ? 'y' : 'x';
|
|
220
|
+
const crossAxis = mainAxis === 'x' ? 'y' : 'x';
|
|
221
|
+
|
|
222
|
+
// When the popover is before the reference, subtract the offset,
|
|
223
|
+
// of the main axis else add it.
|
|
224
|
+
const hasBeforePlacement =
|
|
225
|
+
currentPlacement.includes( 'top' ) ||
|
|
226
|
+
currentPlacement.includes( 'left' );
|
|
227
|
+
const mainAxisModifier = hasBeforePlacement ? -1 : 1;
|
|
228
|
+
|
|
229
|
+
return {
|
|
230
|
+
mainAxis:
|
|
231
|
+
offsetRef.current +
|
|
232
|
+
frameOffsetRef.current[ mainAxis ] * mainAxisModifier,
|
|
233
|
+
crossAxis: frameOffsetRef.current[ crossAxis ],
|
|
234
|
+
};
|
|
235
|
+
} ),
|
|
236
236
|
__unstableForcePosition ? undefined : flip(),
|
|
237
237
|
__unstableForcePosition
|
|
238
238
|
? undefined
|
|
239
239
|
: size( {
|
|
240
240
|
apply( sizeProps ) {
|
|
241
|
-
const {
|
|
241
|
+
const { availableHeight } = sizeProps;
|
|
242
242
|
if ( ! refs.floating.current ) return;
|
|
243
243
|
// Reduce the height of the popover to the available space.
|
|
244
244
|
Object.assign( refs.floating.current.firstChild.style, {
|
|
245
|
-
maxHeight: `${
|
|
245
|
+
maxHeight: `${ availableHeight }px`,
|
|
246
246
|
overflow: 'auto',
|
|
247
247
|
} );
|
|
248
248
|
},
|
|
@@ -296,6 +296,11 @@ const Popover = (
|
|
|
296
296
|
middlewareData: { arrow: arrowData = {} },
|
|
297
297
|
} = useFloating( { placement: normalizedPlacementFromProps, middleware } );
|
|
298
298
|
|
|
299
|
+
useEffect( () => {
|
|
300
|
+
offsetRef.current = offsetProp;
|
|
301
|
+
update();
|
|
302
|
+
}, [ offsetProp, update ] );
|
|
303
|
+
|
|
299
304
|
// Update the `reference`'s ref.
|
|
300
305
|
//
|
|
301
306
|
// In floating-ui's terms:
|
|
@@ -371,7 +376,10 @@ const Popover = (
|
|
|
371
376
|
refs.floating.current,
|
|
372
377
|
update
|
|
373
378
|
);
|
|
374
|
-
|
|
379
|
+
// 'reference' and 'refs.floating' are refs and don't need to be listed
|
|
380
|
+
// as dependencies (see https://github.com/WordPress/gutenberg/pull/41612)
|
|
381
|
+
// eslint-disable-next-line react-hooks/exhaustive-deps
|
|
382
|
+
}, [ anchorRef, anchorRect, getAnchorRect, update ] );
|
|
375
383
|
|
|
376
384
|
// This is only needed for a smooth transition when moving blocks.
|
|
377
385
|
useLayoutEffect( () => {
|
|
@@ -384,27 +392,43 @@ const Popover = (
|
|
|
384
392
|
return () => {
|
|
385
393
|
observer.disconnect();
|
|
386
394
|
};
|
|
387
|
-
}, [ __unstableObserveElement ] );
|
|
395
|
+
}, [ __unstableObserveElement, update ] );
|
|
388
396
|
|
|
389
397
|
// If the reference element is in a different ownerDocument (e.g. iFrame),
|
|
390
398
|
// we need to manually update the floating's position as the reference's owner
|
|
391
|
-
// document scrolls.
|
|
399
|
+
// document scrolls. Also update the frame offset if the view resizes.
|
|
392
400
|
useLayoutEffect( () => {
|
|
393
|
-
if (
|
|
401
|
+
if ( referenceOwnerDocument === document ) {
|
|
402
|
+
frameOffsetRef.current = undefined;
|
|
394
403
|
return;
|
|
395
404
|
}
|
|
396
405
|
|
|
397
|
-
|
|
398
|
-
return () => ownerDocument.removeEventListener( 'scroll', update );
|
|
399
|
-
}, [ ownerDocument ] );
|
|
406
|
+
const { defaultView } = referenceOwnerDocument;
|
|
400
407
|
|
|
401
|
-
|
|
402
|
-
|
|
403
|
-
|
|
404
|
-
|
|
405
|
-
|
|
406
|
-
|
|
407
|
-
|
|
408
|
+
referenceOwnerDocument.addEventListener( 'scroll', update );
|
|
409
|
+
|
|
410
|
+
let updateFrameOffset;
|
|
411
|
+
const hasFrameElement =
|
|
412
|
+
!! referenceOwnerDocument?.defaultView?.frameElement;
|
|
413
|
+
if ( hasFrameElement ) {
|
|
414
|
+
updateFrameOffset = () => {
|
|
415
|
+
frameOffsetRef.current = getFrameOffset(
|
|
416
|
+
referenceOwnerDocument
|
|
417
|
+
);
|
|
418
|
+
update();
|
|
419
|
+
};
|
|
420
|
+
updateFrameOffset();
|
|
421
|
+
defaultView.addEventListener( 'resize', updateFrameOffset );
|
|
422
|
+
}
|
|
423
|
+
|
|
424
|
+
return () => {
|
|
425
|
+
referenceOwnerDocument.removeEventListener( 'scroll', update );
|
|
426
|
+
|
|
427
|
+
if ( updateFrameOffset ) {
|
|
428
|
+
defaultView.removeEventListener( 'resize', updateFrameOffset );
|
|
429
|
+
}
|
|
430
|
+
};
|
|
431
|
+
}, [ referenceOwnerDocument, update ] );
|
|
408
432
|
|
|
409
433
|
const mergedFloatingRef = useMergeRefs( [
|
|
410
434
|
floating,
|
|
@@ -418,16 +442,13 @@ const Popover = (
|
|
|
418
442
|
let content = (
|
|
419
443
|
// eslint-disable-next-line jsx-a11y/no-noninteractive-element-interactions
|
|
420
444
|
// eslint-disable-next-line jsx-a11y/no-static-element-interactions
|
|
421
|
-
<
|
|
422
|
-
|
|
423
|
-
|
|
424
|
-
|
|
425
|
-
|
|
426
|
-
|
|
427
|
-
|
|
428
|
-
'is-alternate': isAlternate,
|
|
429
|
-
}
|
|
430
|
-
) }
|
|
445
|
+
<MaybeAnimatedWrapper
|
|
446
|
+
shouldAnimate={ animate && ! isExpanded }
|
|
447
|
+
placement={ computedPlacement }
|
|
448
|
+
className={ classnames( 'components-popover', className, {
|
|
449
|
+
'is-expanded': isExpanded,
|
|
450
|
+
'is-alternate': isAlternate,
|
|
451
|
+
} ) }
|
|
431
452
|
{ ...contentProps }
|
|
432
453
|
ref={ mergedFloatingRef }
|
|
433
454
|
{ ...dialogProps }
|
|
@@ -476,7 +497,7 @@ const Popover = (
|
|
|
476
497
|
<ArrowTriangle />
|
|
477
498
|
</div>
|
|
478
499
|
) }
|
|
479
|
-
</
|
|
500
|
+
</MaybeAnimatedWrapper>
|
|
480
501
|
);
|
|
481
502
|
|
|
482
503
|
if ( slot.ref ) {
|
|
@@ -126,7 +126,14 @@ export const Default = ( args ) => {
|
|
|
126
126
|
);
|
|
127
127
|
};
|
|
128
128
|
Default.args = {
|
|
129
|
-
children:
|
|
129
|
+
children: (
|
|
130
|
+
<div style={ { width: '280px', whiteSpace: 'normal' } }>
|
|
131
|
+
Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do
|
|
132
|
+
eiusmod tempor incididunt ut labore et dolore magna aliqua. Ut enim
|
|
133
|
+
ad minim veniam, quis nostrud exercitation ullamco laboris nisi ut
|
|
134
|
+
aliquip ex ea commodo consequat.
|
|
135
|
+
</div>
|
|
136
|
+
),
|
|
130
137
|
};
|
|
131
138
|
|
|
132
139
|
/**
|
|
@@ -166,8 +173,15 @@ AllPlacements.parameters = {
|
|
|
166
173
|
};
|
|
167
174
|
AllPlacements.args = {
|
|
168
175
|
...Default.args,
|
|
176
|
+
children: (
|
|
177
|
+
<div style={ { width: '280px', whiteSpace: 'normal' } }>
|
|
178
|
+
Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do
|
|
179
|
+
eiusmod tempor incididunt ut labore et dolore magna aliqua.
|
|
180
|
+
</div>
|
|
181
|
+
),
|
|
169
182
|
noArrow: false,
|
|
170
183
|
offset: 10,
|
|
184
|
+
__unstableForcePosition: true,
|
|
171
185
|
};
|
|
172
186
|
|
|
173
187
|
export const DynamicHeight = ( { children, ...args } ) => {
|
|
@@ -230,7 +244,7 @@ export const WithSlotOutsideIframe = ( args ) => {
|
|
|
230
244
|
<Iframe
|
|
231
245
|
style={ {
|
|
232
246
|
width: '100%',
|
|
233
|
-
height: '
|
|
247
|
+
height: '400px',
|
|
234
248
|
} }
|
|
235
249
|
>
|
|
236
250
|
<div
|
|
@@ -244,7 +258,7 @@ export const WithSlotOutsideIframe = ( args ) => {
|
|
|
244
258
|
padding: '8px',
|
|
245
259
|
background: 'salmon',
|
|
246
260
|
maxWidth: '200px',
|
|
247
|
-
marginTop: '
|
|
261
|
+
marginTop: '100px',
|
|
248
262
|
marginLeft: 'auto',
|
|
249
263
|
marginRight: 'auto',
|
|
250
264
|
} }
|
|
@@ -1,11 +1,11 @@
|
|
|
1
1
|
// Jest Snapshot v1, https://goo.gl/fbAQLP
|
|
2
2
|
|
|
3
|
-
exports[`Popover should pass additional props to portaled element 1`] = `
|
|
3
|
+
exports[`Popover Component should pass additional props to portaled element 1`] = `
|
|
4
4
|
<span>
|
|
5
5
|
<div
|
|
6
|
-
class="components-popover
|
|
6
|
+
class="components-popover"
|
|
7
7
|
role="tooltip"
|
|
8
|
-
style="position: absolute;"
|
|
8
|
+
style="position: absolute; opacity: 0; transform: translateY(-2em) scale(0) translateZ(0); transform-origin: 0% 0% 0;"
|
|
9
9
|
tabindex="-1"
|
|
10
10
|
>
|
|
11
11
|
<div
|
|
@@ -17,11 +17,11 @@ exports[`Popover should pass additional props to portaled element 1`] = `
|
|
|
17
17
|
</span>
|
|
18
18
|
`;
|
|
19
19
|
|
|
20
|
-
exports[`Popover should render content 1`] = `
|
|
20
|
+
exports[`Popover Component should render content 1`] = `
|
|
21
21
|
<span>
|
|
22
22
|
<div
|
|
23
|
-
class="components-popover
|
|
24
|
-
style="position: absolute;"
|
|
23
|
+
class="components-popover"
|
|
24
|
+
style="position: absolute; opacity: 0; transform: translateY(-2em) scale(0) translateZ(0); transform-origin: 0% 0% 0;"
|
|
25
25
|
tabindex="-1"
|
|
26
26
|
>
|
|
27
27
|
<div
|