@wordpress/components 20.0.2-next.957ca95e4c.0 → 21.0.1
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/CONTRIBUTING.md +3 -54
- 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 +10 -0
- package/build/angle-picker-control/index.js.map +1 -1
- package/build/autocomplete/autocompleter-ui.js +3 -3
- package/build/autocomplete/autocompleter-ui.js.map +1 -1
- package/build/border-box-control/border-box-control/component.js +10 -7
- package/build/border-box-control/border-box-control/component.js.map +1 -1
- package/build/border-box-control/border-box-control-linked-button/component.js +1 -2
- package/build/border-box-control/border-box-control-linked-button/component.js.map +1 -1
- package/build/border-box-control/border-box-control-split-controls/component.js +10 -7
- package/build/border-box-control/border-box-control-split-controls/component.js.map +1 -1
- package/build/border-box-control/styles.js +7 -7
- package/build/border-box-control/styles.js.map +1 -1
- package/build/border-control/border-control-dropdown/component.js +2 -1
- package/build/border-control/border-control-dropdown/component.js.map +1 -1
- package/build/box-control/linked-button.js +3 -3
- package/build/box-control/linked-button.js.map +1 -1
- package/build/card/styles.js +17 -17
- package/build/card/styles.js.map +1 -1
- package/build/checkbox-control/index.js +3 -3
- package/build/checkbox-control/index.js.map +1 -1
- package/build/color-palette/index.js +1 -1
- package/build/color-palette/index.js.map +1 -1
- package/build/color-picker/input-with-slider.js +2 -1
- package/build/color-picker/input-with-slider.js.map +1 -1
- package/build/combobox-control/index.js +1 -1
- package/build/combobox-control/index.js.map +1 -1
- package/build/custom-gradient-picker/index.js +1 -1
- package/build/custom-gradient-picker/index.js.map +1 -1
- package/build/date-time/date/index.js +1 -1
- package/build/date-time/date/index.js.map +1 -1
- package/build/date-time/time/timezone.js +1 -1
- package/build/date-time/time/timezone.js.map +1 -1
- package/build/disabled/index.js +14 -6
- package/build/disabled/index.js.map +1 -1
- package/build/disabled/styles/disabled-styles.js +8 -18
- package/build/disabled/styles/disabled-styles.js.map +1 -1
- package/build/drop-zone/index.js +44 -9
- package/build/drop-zone/index.js.map +1 -1
- package/build/drop-zone/provider.js.map +1 -1
- package/build/drop-zone/types.js +6 -0
- package/build/drop-zone/types.js.map +1 -0
- package/build/dropdown/index.js +11 -4
- package/build/dropdown/index.js.map +1 -1
- package/build/flex/flex/hook.js +6 -30
- package/build/flex/flex/hook.js.map +1 -1
- package/build/focal-point-picker/controls.js +10 -5
- package/build/focal-point-picker/controls.js.map +1 -1
- package/build/focal-point-picker/focal-point.js.map +1 -1
- package/build/focal-point-picker/grid.js.map +1 -1
- package/build/focal-point-picker/index.js +83 -16
- package/build/focal-point-picker/index.js.map +1 -1
- package/build/focal-point-picker/media.js +4 -0
- package/build/focal-point-picker/media.js.map +1 -1
- package/build/focal-point-picker/styles/focal-point-picker-style.js +70 -41
- package/build/focal-point-picker/styles/focal-point-picker-style.js.map +1 -1
- package/build/focal-point-picker/styles/focal-point-style.js +12 -12
- package/build/focal-point-picker/styles/focal-point-style.js.map +1 -1
- package/build/focal-point-picker/types.js +6 -0
- package/build/focal-point-picker/types.js.map +1 -0
- package/build/focal-point-picker/utils.js +6 -6
- package/build/focal-point-picker/utils.js.map +1 -1
- package/build/font-size-picker/index.js +11 -0
- package/build/font-size-picker/index.js.map +1 -1
- package/build/font-size-picker/utils.js +1 -1
- package/build/font-size-picker/utils.js.map +1 -1
- package/build/form-file-upload/index.js +22 -2
- package/build/form-file-upload/index.js.map +1 -1
- package/build/form-file-upload/types.js +6 -0
- package/build/form-file-upload/types.js.map +1 -0
- package/build/form-toggle/index.js +1 -3
- package/build/form-toggle/index.js.map +1 -1
- package/build/form-token-field/index.js +4 -6
- package/build/form-token-field/index.js.map +1 -1
- package/build/form-token-field/suggestions-list.js +1 -3
- package/build/form-token-field/suggestions-list.js.map +1 -1
- package/build/gradient-picker/index.js +25 -26
- package/build/gradient-picker/index.js.map +1 -1
- package/build/icon/index.js +1 -2
- package/build/icon/index.js.map +1 -1
- package/build/input-control/input-base.js +3 -2
- package/build/input-control/input-base.js.map +1 -1
- package/build/input-control/label.js +2 -2
- package/build/input-control/label.js.map +1 -1
- package/build/input-control/styles/input-control-styles.js +41 -128
- package/build/input-control/styles/input-control-styles.js.map +1 -1
- package/build/modal/aria-helper.js +3 -10
- package/build/modal/aria-helper.js.map +1 -1
- package/build/navigable-container/container.js +5 -1
- package/build/navigable-container/container.js.map +1 -1
- package/build/navigable-container/menu.js +10 -12
- package/build/navigable-container/menu.js.map +1 -1
- package/build/navigable-container/tabbable.js +2 -4
- package/build/navigable-container/tabbable.js.map +1 -1
- package/build/navigation/menu/menu-title-search.js +2 -1
- package/build/navigation/menu/menu-title-search.js.map +1 -1
- package/build/navigation/menu/use-navigation-tree-menu.js +2 -1
- package/build/navigation/menu/use-navigation-tree-menu.js.map +1 -1
- package/build/navigator/navigator-button/hook.js +1 -1
- package/build/navigator/navigator-button/hook.js.map +1 -1
- package/build/navigator/navigator-screen/component.js +2 -2
- package/build/navigator/navigator-screen/component.js.map +1 -1
- package/build/number-control/index.js +29 -25
- package/build/number-control/index.js.map +1 -1
- package/build/number-control/types.js +6 -0
- package/build/number-control/types.js.map +1 -0
- package/build/placeholder/index.js +1 -3
- package/build/placeholder/index.js.map +1 -1
- package/build/popover/index.js +190 -160
- package/build/popover/index.js.map +1 -1
- package/build/popover/types.js +6 -0
- package/build/popover/types.js.map +1 -0
- package/build/popover/utils.js +125 -24
- package/build/popover/utils.js.map +1 -1
- package/build/radio-control/index.js +7 -4
- package/build/radio-control/index.js.map +1 -1
- package/build/range-control/index.js +4 -1
- package/build/range-control/index.js.map +1 -1
- package/build/range-control/styles/range-control-styles.js +33 -33
- package/build/range-control/styles/range-control-styles.js.map +1 -1
- package/build/sandbox/index.js +2 -2
- package/build/sandbox/index.js.map +1 -1
- package/build/search-control/index.js +38 -10
- package/build/search-control/index.js.map +1 -1
- package/build/search-control/types.js +6 -0
- package/build/search-control/types.js.map +1 -0
- package/build/select-control/index.native.js +2 -1
- package/build/select-control/index.native.js.map +1 -1
- package/build/tab-panel/index.js +48 -9
- package/build/tab-panel/index.js.map +1 -1
- package/build/tab-panel/types.js +6 -0
- package/build/tab-panel/types.js.map +1 -0
- package/build/text-control/index.js +2 -0
- package/build/text-control/index.js.map +1 -1
- package/build/textarea-control/index.js +3 -3
- package/build/textarea-control/index.js.map +1 -1
- package/build/toggle-control/index.js +44 -4
- package/build/toggle-control/index.js.map +1 -1
- package/build/toggle-control/types.js +6 -0
- package/build/toggle-control/types.js.map +1 -0
- package/build/toggle-group-control/toggle-group-control/component.js +2 -2
- package/build/toggle-group-control/toggle-group-control/component.js.map +1 -1
- package/build/toggle-group-control/toggle-group-control-option-icon/component.js +1 -1
- package/build/toggle-group-control/toggle-group-control-option-icon/component.js.map +1 -1
- package/build/tooltip/index.js +9 -7
- package/build/tooltip/index.js.map +1 -1
- package/build/ui/context/context-connect.js +31 -22
- package/build/ui/context/context-connect.js.map +1 -1
- package/build/ui/context/context-system-provider.js +4 -3
- package/build/ui/context/context-system-provider.js.map +1 -1
- package/build/unit-control/index.js +1 -1
- package/build/unit-control/index.js.map +1 -1
- package/build/unit-control/styles/unit-control-styles.js +9 -9
- package/build/unit-control/styles/unit-control-styles.js.map +1 -1
- package/build/utils/colors-values.js +2 -30
- package/build/utils/colors-values.js.map +1 -1
- package/build/utils/math.js +4 -4
- package/build/utils/math.js.map +1 -1
- package/build/utils/values.js +62 -6
- package/build/utils/values.js.map +1 -1
- package/build/view/component.js +6 -7
- package/build/view/component.js.map +1 -1
- package/build/view/types.js +6 -0
- package/build/view/types.js.map +1 -0
- 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 +9 -0
- package/build-module/angle-picker-control/index.js.map +1 -1
- package/build-module/autocomplete/autocompleter-ui.js +4 -4
- package/build-module/autocomplete/autocompleter-ui.js.map +1 -1
- package/build-module/border-box-control/border-box-control/component.js +11 -8
- package/build-module/border-box-control/border-box-control/component.js.map +1 -1
- package/build-module/border-box-control/border-box-control-linked-button/component.js +1 -2
- package/build-module/border-box-control/border-box-control-linked-button/component.js.map +1 -1
- package/build-module/border-box-control/border-box-control-split-controls/component.js +11 -8
- package/build-module/border-box-control/border-box-control-split-controls/component.js.map +1 -1
- package/build-module/border-box-control/styles.js +7 -7
- package/build-module/border-box-control/styles.js.map +1 -1
- package/build-module/border-control/border-control-dropdown/component.js +2 -1
- package/build-module/border-control/border-control-dropdown/component.js.map +1 -1
- package/build-module/box-control/linked-button.js +3 -3
- package/build-module/box-control/linked-button.js.map +1 -1
- package/build-module/card/styles.js +17 -17
- package/build-module/card/styles.js.map +1 -1
- package/build-module/checkbox-control/index.js +3 -3
- package/build-module/checkbox-control/index.js.map +1 -1
- package/build-module/color-palette/index.js +1 -1
- package/build-module/color-palette/index.js.map +1 -1
- package/build-module/color-picker/input-with-slider.js +2 -1
- package/build-module/color-picker/input-with-slider.js.map +1 -1
- package/build-module/combobox-control/index.js +1 -1
- package/build-module/combobox-control/index.js.map +1 -1
- package/build-module/custom-gradient-picker/index.js +1 -1
- package/build-module/custom-gradient-picker/index.js.map +1 -1
- package/build-module/date-time/date/index.js +2 -3
- package/build-module/date-time/date/index.js.map +1 -1
- package/build-module/date-time/time/timezone.js +1 -1
- package/build-module/date-time/time/timezone.js.map +1 -1
- package/build-module/disabled/index.js +16 -8
- package/build-module/disabled/index.js.map +1 -1
- package/build-module/disabled/styles/disabled-styles.js +6 -12
- package/build-module/disabled/styles/disabled-styles.js.map +1 -1
- package/build-module/drop-zone/index.js +40 -9
- package/build-module/drop-zone/index.js.map +1 -1
- package/build-module/drop-zone/provider.js.map +1 -1
- package/build-module/drop-zone/types.js +2 -0
- package/build-module/drop-zone/types.js.map +1 -0
- package/build-module/dropdown/index.js +10 -4
- package/build-module/dropdown/index.js.map +1 -1
- package/build-module/flex/flex/hook.js +7 -29
- package/build-module/flex/flex/hook.js.map +1 -1
- package/build-module/focal-point-picker/controls.js +11 -6
- package/build-module/focal-point-picker/controls.js.map +1 -1
- package/build-module/focal-point-picker/focal-point.js.map +1 -1
- package/build-module/focal-point-picker/grid.js.map +1 -1
- package/build-module/focal-point-picker/index.js +81 -16
- package/build-module/focal-point-picker/index.js.map +1 -1
- package/build-module/focal-point-picker/media.js +4 -0
- package/build-module/focal-point-picker/media.js.map +1 -1
- package/build-module/focal-point-picker/styles/focal-point-picker-style.js +68 -40
- package/build-module/focal-point-picker/styles/focal-point-picker-style.js.map +1 -1
- package/build-module/focal-point-picker/styles/focal-point-style.js +12 -12
- package/build-module/focal-point-picker/styles/focal-point-style.js.map +1 -1
- package/build-module/focal-point-picker/types.js +2 -0
- package/build-module/focal-point-picker/types.js.map +1 -0
- package/build-module/focal-point-picker/utils.js +6 -6
- package/build-module/focal-point-picker/utils.js.map +1 -1
- package/build-module/font-size-picker/index.js +10 -0
- package/build-module/font-size-picker/index.js.map +1 -1
- package/build-module/font-size-picker/utils.js +1 -1
- package/build-module/font-size-picker/utils.js.map +1 -1
- package/build-module/form-file-upload/index.js +21 -4
- package/build-module/form-file-upload/index.js.map +1 -1
- package/build-module/form-file-upload/types.js +2 -0
- package/build-module/form-file-upload/types.js.map +1 -0
- package/build-module/form-toggle/index.js +1 -3
- package/build-module/form-toggle/index.js.map +1 -1
- package/build-module/form-token-field/index.js +4 -5
- package/build-module/form-token-field/index.js.map +1 -1
- package/build-module/form-token-field/suggestions-list.js +1 -2
- package/build-module/form-token-field/suggestions-list.js.map +1 -1
- package/build-module/gradient-picker/index.js +25 -26
- package/build-module/gradient-picker/index.js.map +1 -1
- package/build-module/icon/index.js +1 -2
- package/build-module/icon/index.js.map +1 -1
- package/build-module/input-control/input-base.js +4 -3
- package/build-module/input-control/input-base.js.map +1 -1
- package/build-module/input-control/label.js +3 -3
- package/build-module/input-control/label.js.map +1 -1
- package/build-module/input-control/styles/input-control-styles.js +41 -127
- package/build-module/input-control/styles/input-control-styles.js.map +1 -1
- package/build-module/modal/aria-helper.js +3 -8
- package/build-module/modal/aria-helper.js.map +1 -1
- package/build-module/navigable-container/container.js +5 -1
- package/build-module/navigable-container/container.js.map +1 -1
- package/build-module/navigable-container/menu.js +10 -11
- package/build-module/navigable-container/menu.js.map +1 -1
- package/build-module/navigable-container/tabbable.js +2 -3
- package/build-module/navigable-container/tabbable.js.map +1 -1
- package/build-module/navigation/menu/menu-title-search.js +2 -1
- package/build-module/navigation/menu/menu-title-search.js.map +1 -1
- package/build-module/navigation/menu/use-navigation-tree-menu.js +2 -1
- package/build-module/navigation/menu/use-navigation-tree-menu.js.map +1 -1
- package/build-module/navigator/navigator-button/hook.js +1 -1
- package/build-module/navigator/navigator-button/hook.js.map +1 -1
- package/build-module/navigator/navigator-screen/component.js +2 -2
- package/build-module/navigator/navigator-screen/component.js.map +1 -1
- package/build-module/number-control/index.js +31 -23
- package/build-module/number-control/index.js.map +1 -1
- package/build-module/number-control/types.js +2 -0
- package/build-module/number-control/types.js.map +1 -0
- package/build-module/placeholder/index.js +1 -3
- package/build-module/placeholder/index.js.map +1 -1
- package/build-module/popover/index.js +192 -162
- package/build-module/popover/index.js.map +1 -1
- package/build-module/popover/types.js +2 -0
- package/build-module/popover/types.js.map +1 -0
- package/build-module/popover/utils.js +118 -23
- package/build-module/popover/utils.js.map +1 -1
- package/build-module/radio-control/index.js +7 -5
- package/build-module/radio-control/index.js.map +1 -1
- package/build-module/range-control/index.js +4 -1
- package/build-module/range-control/index.js.map +1 -1
- package/build-module/range-control/styles/range-control-styles.js +33 -33
- package/build-module/range-control/styles/range-control-styles.js.map +1 -1
- package/build-module/sandbox/index.js +2 -2
- package/build-module/sandbox/index.js.map +1 -1
- package/build-module/search-control/index.js +34 -7
- package/build-module/search-control/index.js.map +1 -1
- package/build-module/search-control/types.js +2 -0
- package/build-module/search-control/types.js.map +1 -0
- package/build-module/select-control/index.native.js +1 -1
- package/build-module/select-control/index.native.js.map +1 -1
- package/build-module/tab-panel/index.js +46 -10
- package/build-module/tab-panel/index.js.map +1 -1
- package/build-module/tab-panel/types.js +2 -0
- package/build-module/tab-panel/types.js.map +1 -0
- package/build-module/text-control/index.js +2 -0
- package/build-module/text-control/index.js.map +1 -1
- package/build-module/textarea-control/index.js +3 -3
- package/build-module/textarea-control/index.js.map +1 -1
- package/build-module/toggle-control/index.js +38 -4
- package/build-module/toggle-control/index.js.map +1 -1
- package/build-module/toggle-control/types.js +2 -0
- package/build-module/toggle-control/types.js.map +1 -0
- package/build-module/toggle-group-control/toggle-group-control/component.js +2 -2
- package/build-module/toggle-group-control/toggle-group-control/component.js.map +1 -1
- package/build-module/toggle-group-control/toggle-group-control-option-icon/component.js +1 -1
- package/build-module/toggle-group-control/toggle-group-control-option-icon/component.js.map +1 -1
- package/build-module/tooltip/index.js +10 -8
- package/build-module/tooltip/index.js.map +1 -1
- package/build-module/ui/context/context-connect.js +30 -23
- package/build-module/ui/context/context-connect.js.map +1 -1
- package/build-module/ui/context/context-system-provider.js +5 -4
- package/build-module/ui/context/context-system-provider.js.map +1 -1
- package/build-module/unit-control/index.js +1 -1
- package/build-module/unit-control/index.js.map +1 -1
- package/build-module/unit-control/styles/unit-control-styles.js +9 -9
- package/build-module/unit-control/styles/unit-control-styles.js.map +1 -1
- package/build-module/utils/colors-values.js +2 -30
- package/build-module/utils/colors-values.js.map +1 -1
- package/build-module/utils/math.js +4 -4
- package/build-module/utils/math.js.map +1 -1
- package/build-module/utils/values.js +48 -6
- package/build-module/utils/values.js.map +1 -1
- package/build-module/view/component.js +5 -8
- package/build-module/view/component.js.map +1 -1
- package/build-module/view/types.js +2 -0
- package/build-module/view/types.js.map +1 -0
- package/build-style/style-rtl.css +4 -31
- package/build-style/style.css +4 -31
- package/build-types/base-field/hook.d.ts +54 -55
- package/build-types/base-field/hook.d.ts.map +1 -1
- package/build-types/border-box-control/border-box-control/component.d.ts +10 -2
- package/build-types/border-box-control/border-box-control/component.d.ts.map +1 -1
- package/build-types/border-box-control/border-box-control/hook.d.ts +56 -57
- package/build-types/border-box-control/border-box-control/hook.d.ts.map +1 -1
- package/build-types/border-box-control/border-box-control-linked-button/component.d.ts +2 -1
- package/build-types/border-box-control/border-box-control-linked-button/component.d.ts.map +1 -1
- package/build-types/border-box-control/border-box-control-linked-button/hook.d.ts +55 -56
- package/build-types/border-box-control/border-box-control-linked-button/hook.d.ts.map +1 -1
- package/build-types/border-box-control/border-box-control-split-controls/component.d.ts +9 -2
- package/build-types/border-box-control/border-box-control-split-controls/component.d.ts.map +1 -1
- package/build-types/border-box-control/border-box-control-split-controls/hook.d.ts +56 -57
- package/build-types/border-box-control/border-box-control-split-controls/hook.d.ts.map +1 -1
- package/build-types/border-box-control/border-box-control-visualizer/component.d.ts +2 -1
- package/build-types/border-box-control/border-box-control-visualizer/component.d.ts.map +1 -1
- package/build-types/border-box-control/border-box-control-visualizer/hook.d.ts +55 -56
- package/build-types/border-box-control/border-box-control-visualizer/hook.d.ts.map +1 -1
- package/build-types/border-box-control/styles.d.ts.map +1 -1
- package/build-types/border-box-control/types.d.ts +5 -4
- package/build-types/border-box-control/types.d.ts.map +1 -1
- package/build-types/border-control/border-control/component.d.ts +14 -2
- package/build-types/border-control/border-control/component.d.ts.map +1 -1
- package/build-types/border-control/border-control/hook.d.ts +56 -57
- package/build-types/border-control/border-control/hook.d.ts.map +1 -1
- package/build-types/border-control/border-control-dropdown/component.d.ts +10 -2
- package/build-types/border-control/border-control-dropdown/component.d.ts.map +1 -1
- package/build-types/border-control/border-control-dropdown/hook.d.ts +56 -57
- package/build-types/border-control/border-control-dropdown/hook.d.ts.map +1 -1
- package/build-types/border-control/border-control-style-picker/component.d.ts +6 -2
- package/build-types/border-control/border-control-style-picker/component.d.ts.map +1 -1
- package/build-types/border-control/border-control-style-picker/hook.d.ts +55 -56
- package/build-types/border-control/border-control-style-picker/hook.d.ts.map +1 -1
- package/build-types/border-control/stories/index.d.ts +74 -6
- package/build-types/border-control/stories/index.d.ts.map +1 -1
- package/build-types/border-control/types.d.ts +6 -8
- package/build-types/border-control/types.d.ts.map +1 -1
- package/build-types/button-group/index.d.ts +1 -3
- package/build-types/button-group/index.d.ts.map +1 -1
- package/build-types/card/card/component.d.ts +9 -2
- package/build-types/card/card/component.d.ts.map +1 -1
- package/build-types/card/card/hook.d.ts +55 -56
- package/build-types/card/card/hook.d.ts.map +1 -1
- package/build-types/card/card-body/component.d.ts +9 -2
- package/build-types/card/card-body/component.d.ts.map +1 -1
- package/build-types/card/card-body/hook.d.ts +55 -56
- package/build-types/card/card-body/hook.d.ts.map +1 -1
- package/build-types/card/card-divider/component.d.ts +7 -2
- package/build-types/card/card-divider/component.d.ts.map +1 -1
- package/build-types/card/card-divider/hook.d.ts +55 -55
- package/build-types/card/card-footer/component.d.ts +11 -2
- package/build-types/card/card-footer/component.d.ts.map +1 -1
- package/build-types/card/card-footer/hook.d.ts +55 -56
- package/build-types/card/card-footer/hook.d.ts.map +1 -1
- package/build-types/card/card-header/component.d.ts +1 -1
- package/build-types/card/card-header/component.d.ts.map +1 -1
- package/build-types/card/card-header/hook.d.ts +55 -56
- package/build-types/card/card-header/hook.d.ts.map +1 -1
- package/build-types/card/card-media/component.d.ts +2 -1
- package/build-types/card/card-media/component.d.ts.map +1 -1
- package/build-types/card/card-media/hook.d.ts +55 -56
- package/build-types/card/card-media/hook.d.ts.map +1 -1
- package/build-types/checkbox-control/index.d.ts +1 -1
- package/build-types/checkbox-control/index.d.ts.map +1 -1
- package/build-types/checkbox-control/stories/index.d.ts.map +1 -1
- package/build-types/checkbox-control/types.d.ts +1 -1
- package/build-types/checkbox-control/types.d.ts.map +1 -1
- package/build-types/color-indicator/index.d.ts +1 -3
- package/build-types/color-indicator/index.d.ts.map +1 -1
- package/build-types/color-palette/styles.d.ts +1 -3
- package/build-types/color-palette/styles.d.ts.map +1 -1
- package/build-types/color-picker/component.d.ts +2 -1
- package/build-types/color-picker/component.d.ts.map +1 -1
- package/build-types/color-picker/input-with-slider.d.ts.map +1 -1
- package/build-types/color-picker/styles.d.ts +12 -25
- package/build-types/color-picker/styles.d.ts.map +1 -1
- package/build-types/confirm-dialog/component.d.ts +4 -8
- package/build-types/confirm-dialog/component.d.ts.map +1 -1
- package/build-types/date-time/date/styles.d.ts +4 -8
- package/build-types/date-time/date/styles.d.ts.map +1 -1
- package/build-types/date-time/date-time/styles.d.ts +4 -6
- package/build-types/date-time/date-time/styles.d.ts.map +1 -1
- package/build-types/date-time/time/styles.d.ts +21 -43
- package/build-types/date-time/time/styles.d.ts.map +1 -1
- package/build-types/disabled/index.d.ts +1 -1
- package/build-types/disabled/index.d.ts.map +1 -1
- package/build-types/disabled/styles/disabled-styles.d.ts +1 -5
- package/build-types/disabled/styles/disabled-styles.d.ts.map +1 -1
- package/build-types/divider/component.d.ts +7 -2
- package/build-types/divider/component.d.ts.map +1 -1
- package/build-types/drop-zone/index.d.ts +29 -0
- package/build-types/drop-zone/index.d.ts.map +1 -0
- package/build-types/drop-zone/provider.d.ts +5 -0
- package/build-types/drop-zone/provider.d.ts.map +1 -0
- package/build-types/drop-zone/stories/index.d.ts +12 -0
- package/build-types/drop-zone/stories/index.d.ts.map +1 -0
- package/build-types/drop-zone/types.d.ts +29 -0
- package/build-types/drop-zone/types.d.ts.map +1 -0
- package/build-types/dropdown/dropdown-content-wrapper.d.ts +2 -1
- package/build-types/dropdown/dropdown-content-wrapper.d.ts.map +1 -1
- package/build-types/dropdown/index.d.ts.map +1 -1
- package/build-types/elevation/component.d.ts +2 -1
- package/build-types/elevation/component.d.ts.map +1 -1
- package/build-types/elevation/hook.d.ts +54 -55
- package/build-types/elevation/hook.d.ts.map +1 -1
- package/build-types/external-link/index.d.ts +1 -1
- package/build-types/external-link/index.d.ts.map +1 -1
- package/build-types/external-link/styles/external-link-styles.d.ts +1 -1
- package/build-types/flex/flex/component.d.ts +2 -1
- package/build-types/flex/flex/component.d.ts.map +1 -1
- package/build-types/flex/flex/hook.d.ts +55 -56
- package/build-types/flex/flex/hook.d.ts.map +1 -1
- package/build-types/flex/flex-block/component.d.ts +2 -1
- package/build-types/flex/flex-block/component.d.ts.map +1 -1
- package/build-types/flex/flex-block/hook.d.ts +55 -56
- package/build-types/flex/flex-block/hook.d.ts.map +1 -1
- package/build-types/flex/flex-item/component.d.ts +2 -1
- package/build-types/flex/flex-item/component.d.ts.map +1 -1
- package/build-types/flex/flex-item/hook.d.ts +55 -56
- package/build-types/flex/flex-item/hook.d.ts.map +1 -1
- package/build-types/focal-point-picker/controls.d.ts +4 -0
- package/build-types/focal-point-picker/controls.d.ts.map +1 -0
- package/build-types/focal-point-picker/focal-point.d.ts +5 -0
- package/build-types/focal-point-picker/focal-point.d.ts.map +1 -0
- package/build-types/focal-point-picker/grid.d.ts +5 -0
- package/build-types/focal-point-picker/grid.d.ts.map +1 -0
- package/build-types/focal-point-picker/index.d.ts +51 -0
- package/build-types/focal-point-picker/index.d.ts.map +1 -0
- package/build-types/focal-point-picker/media.d.ts +4 -0
- package/build-types/focal-point-picker/media.d.ts.map +1 -0
- package/build-types/focal-point-picker/stories/index.d.ts +15 -0
- package/build-types/focal-point-picker/stories/index.d.ts.map +1 -0
- package/build-types/focal-point-picker/styles/focal-point-picker-style.d.ts +56 -0
- package/build-types/focal-point-picker/styles/focal-point-picker-style.d.ts.map +1 -0
- package/build-types/focal-point-picker/styles/focal-point-style.d.ts +19 -0
- package/build-types/focal-point-picker/styles/focal-point-style.d.ts.map +1 -0
- package/build-types/focal-point-picker/types.d.ts +79 -0
- package/build-types/focal-point-picker/types.d.ts.map +1 -0
- package/build-types/focal-point-picker/utils.d.ts +26 -0
- package/build-types/focal-point-picker/utils.d.ts.map +1 -0
- package/build-types/form-file-upload/index.d.ts +22 -0
- package/build-types/form-file-upload/index.d.ts.map +1 -0
- package/build-types/form-file-upload/stories/index.d.ts +23 -0
- package/build-types/form-file-upload/stories/index.d.ts.map +1 -0
- package/build-types/form-file-upload/test/index.d.ts +2 -0
- package/build-types/form-file-upload/test/index.d.ts.map +1 -0
- package/build-types/form-file-upload/types.d.ts +63 -0
- package/build-types/form-file-upload/types.d.ts.map +1 -0
- package/build-types/form-toggle/index.d.ts +1 -1
- package/build-types/form-toggle/index.d.ts.map +1 -1
- package/build-types/form-token-field/index.d.ts.map +1 -1
- package/build-types/form-token-field/styles.d.ts +1 -3
- package/build-types/form-token-field/styles.d.ts.map +1 -1
- package/build-types/form-token-field/suggestions-list.d.ts.map +1 -1
- package/build-types/form-token-field/token-input.d.ts +1 -3
- package/build-types/form-token-field/token-input.d.ts.map +1 -1
- package/build-types/grid/component.d.ts +2 -1
- package/build-types/grid/component.d.ts.map +1 -1
- package/build-types/grid/hook.d.ts +55 -56
- package/build-types/grid/hook.d.ts.map +1 -1
- package/build-types/h-stack/component.d.ts +5 -2
- package/build-types/h-stack/component.d.ts.map +1 -1
- package/build-types/h-stack/hook.d.ts +55 -56
- package/build-types/h-stack/hook.d.ts.map +1 -1
- package/build-types/heading/component.d.ts +4 -2
- package/build-types/heading/component.d.ts.map +1 -1
- package/build-types/heading/hook.d.ts +54 -55
- package/build-types/heading/hook.d.ts.map +1 -1
- package/build-types/input-control/index.d.ts +1 -1
- package/build-types/input-control/index.d.ts.map +1 -1
- package/build-types/input-control/input-base.d.ts.map +1 -1
- package/build-types/input-control/input-field.d.ts +1 -3
- package/build-types/input-control/input-field.d.ts.map +1 -1
- package/build-types/input-control/input-prefix-wrapper.d.ts +2 -1
- package/build-types/input-control/input-prefix-wrapper.d.ts.map +1 -1
- package/build-types/input-control/input-suffix-wrapper.d.ts +2 -1
- package/build-types/input-control/input-suffix-wrapper.d.ts.map +1 -1
- package/build-types/input-control/label.d.ts.map +1 -1
- package/build-types/input-control/stories/index.d.ts +5 -5
- package/build-types/input-control/stories/index.d.ts.map +1 -1
- package/build-types/input-control/styles/input-control-styles.d.ts +2 -6
- package/build-types/input-control/styles/input-control-styles.d.ts.map +1 -1
- package/build-types/input-control/types.d.ts +3 -0
- package/build-types/input-control/types.d.ts.map +1 -1
- package/build-types/item-group/item/component.d.ts +2 -1
- package/build-types/item-group/item/component.d.ts.map +1 -1
- package/build-types/item-group/item/hook.d.ts +54 -55
- package/build-types/item-group/item/hook.d.ts.map +1 -1
- package/build-types/item-group/item-group/component.d.ts +2 -1
- package/build-types/item-group/item-group/component.d.ts.map +1 -1
- package/build-types/item-group/item-group/hook.d.ts +54 -55
- package/build-types/item-group/item-group/hook.d.ts.map +1 -1
- package/build-types/modal/aria-helper.d.ts.map +1 -1
- package/build-types/navigable-container/menu.d.ts.map +1 -1
- package/build-types/navigable-container/tabbable.d.ts.map +1 -1
- package/build-types/navigator/navigator-back-button/component.d.ts +4 -2
- package/build-types/navigator/navigator-back-button/component.d.ts.map +1 -1
- package/build-types/navigator/navigator-back-button/hook.d.ts +59 -60
- package/build-types/navigator/navigator-back-button/hook.d.ts.map +1 -1
- package/build-types/navigator/navigator-button/component.d.ts +7 -2
- package/build-types/navigator/navigator-button/component.d.ts.map +1 -1
- package/build-types/navigator/navigator-button/hook.d.ts +59 -60
- package/build-types/navigator/navigator-button/hook.d.ts.map +1 -1
- package/build-types/navigator/navigator-provider/component.d.ts +2 -1
- package/build-types/navigator/navigator-provider/component.d.ts.map +1 -1
- package/build-types/navigator/navigator-screen/component.d.ts +1 -1
- package/build-types/navigator/navigator-screen/component.d.ts.map +1 -1
- package/build-types/number-control/index.d.ts +10 -28
- package/build-types/number-control/index.d.ts.map +1 -1
- package/build-types/number-control/styles/number-control-styles.d.ts +1 -1
- package/build-types/number-control/types.d.ts +72 -0
- package/build-types/number-control/types.d.ts.map +1 -0
- package/build-types/placeholder/index.d.ts +1 -1
- package/build-types/placeholder/index.d.ts.map +1 -1
- package/build-types/popover/index.d.ts +28 -24
- package/build-types/popover/index.d.ts.map +1 -1
- package/build-types/popover/stories/index.d.ts +12 -0
- package/build-types/popover/stories/index.d.ts.map +1 -0
- package/build-types/popover/types.d.ts +179 -0
- package/build-types/popover/types.d.ts.map +1 -0
- package/build-types/popover/utils.d.ts +42 -24
- package/build-types/popover/utils.d.ts.map +1 -1
- package/build-types/radio-control/index.d.ts +1 -1
- package/build-types/radio-control/index.d.ts.map +1 -1
- package/build-types/range-control/index.d.ts +2 -4
- package/build-types/range-control/index.d.ts.map +1 -1
- package/build-types/range-control/input-range.d.ts +2 -4
- package/build-types/range-control/input-range.d.ts.map +1 -1
- package/build-types/range-control/styles/range-control-styles.d.ts +5 -10
- package/build-types/range-control/styles/range-control-styles.d.ts.map +1 -1
- package/build-types/resizable-box/index.d.ts +1 -1
- package/build-types/resizable-box/resize-tooltip/index.d.ts +1 -1
- package/build-types/resizable-box/resize-tooltip/label.d.ts +1 -1
- package/build-types/resizable-box/resize-tooltip/styles/resize-tooltip.styles.d.ts +1 -3
- package/build-types/resizable-box/resize-tooltip/styles/resize-tooltip.styles.d.ts.map +1 -1
- package/build-types/scrollable/component.d.ts +2 -1
- package/build-types/scrollable/component.d.ts.map +1 -1
- package/build-types/scrollable/hook.d.ts +55 -56
- package/build-types/scrollable/hook.d.ts.map +1 -1
- package/build-types/search-control/index.d.ts +29 -0
- package/build-types/search-control/index.d.ts.map +1 -0
- package/build-types/search-control/stories/index.d.ts +47 -0
- package/build-types/search-control/stories/index.d.ts.map +1 -0
- package/build-types/search-control/types.d.ts +39 -0
- package/build-types/search-control/types.d.ts.map +1 -0
- package/build-types/select-control/index.d.ts +1 -3
- package/build-types/select-control/index.d.ts.map +1 -1
- package/build-types/select-control/stories/index.d.ts +2 -6
- package/build-types/select-control/stories/index.d.ts.map +1 -1
- package/build-types/select-control/styles/select-control-styles.d.ts +1 -3
- package/build-types/select-control/styles/select-control-styles.d.ts.map +1 -1
- package/build-types/spacer/component.d.ts +2 -1
- package/build-types/spacer/component.d.ts.map +1 -1
- package/build-types/spacer/hook.d.ts +55 -56
- package/build-types/spacer/hook.d.ts.map +1 -1
- package/build-types/spinner/index.d.ts +1 -3
- package/build-types/spinner/index.d.ts.map +1 -1
- package/build-types/surface/component.d.ts +2 -1
- package/build-types/surface/component.d.ts.map +1 -1
- package/build-types/surface/hook.d.ts +55 -56
- package/build-types/surface/hook.d.ts.map +1 -1
- package/build-types/tab-panel/index.d.ts +42 -0
- package/build-types/tab-panel/index.d.ts.map +1 -0
- package/build-types/tab-panel/stories/index.d.ts +12 -0
- package/build-types/tab-panel/stories/index.d.ts.map +1 -0
- package/build-types/tab-panel/test/index.d.ts +2 -0
- package/build-types/tab-panel/test/index.d.ts.map +1 -0
- package/build-types/tab-panel/types.d.ts +64 -0
- package/build-types/tab-panel/types.d.ts.map +1 -0
- package/build-types/text/component.d.ts +1 -1
- package/build-types/text/component.d.ts.map +1 -1
- package/build-types/text/hook.d.ts +55 -56
- package/build-types/text/hook.d.ts.map +1 -1
- package/build-types/text-control/index.d.ts +2 -4
- package/build-types/text-control/index.d.ts.map +1 -1
- package/build-types/text-control/types.d.ts +1 -1
- package/build-types/text-control/types.d.ts.map +1 -1
- package/build-types/textarea-control/index.d.ts +1 -1
- package/build-types/textarea-control/index.d.ts.map +1 -1
- package/build-types/textarea-control/types.d.ts +1 -1
- package/build-types/textarea-control/types.d.ts.map +1 -1
- package/build-types/toggle-control/index.d.ts +26 -0
- package/build-types/toggle-control/index.d.ts.map +1 -0
- package/build-types/toggle-control/stories/index.d.ts +13 -0
- package/build-types/toggle-control/stories/index.d.ts.map +1 -0
- package/build-types/toggle-control/test/index.d.ts +2 -0
- package/build-types/toggle-control/test/index.d.ts.map +1 -0
- package/build-types/toggle-control/types.d.ts +20 -0
- package/build-types/toggle-control/types.d.ts.map +1 -0
- package/build-types/toggle-group-control/stories/index.d.ts +4 -2
- package/build-types/toggle-group-control/stories/index.d.ts.map +1 -1
- package/build-types/toggle-group-control/toggle-group-control/component.d.ts +12 -2
- package/build-types/toggle-group-control/toggle-group-control/component.d.ts.map +1 -1
- package/build-types/toggle-group-control/toggle-group-control-option/component.d.ts +2 -4
- 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 +2 -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-icon/component.d.ts +3 -5
- 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 +2 -2
- package/build-types/toggle-group-control/types.d.ts.map +1 -1
- package/build-types/tools-panel/tools-panel/component.d.ts +2 -1
- package/build-types/tools-panel/tools-panel/component.d.ts.map +1 -1
- package/build-types/tools-panel/tools-panel/hook.d.ts +55 -56
- package/build-types/tools-panel/tools-panel/hook.d.ts.map +1 -1
- package/build-types/tools-panel/tools-panel-header/component.d.ts +2 -1
- package/build-types/tools-panel/tools-panel-header/component.d.ts.map +1 -1
- package/build-types/tools-panel/tools-panel-header/hook.d.ts +55 -56
- package/build-types/tools-panel/tools-panel-header/hook.d.ts.map +1 -1
- package/build-types/tools-panel/tools-panel-item/component.d.ts +6 -2
- package/build-types/tools-panel/tools-panel-item/component.d.ts.map +1 -1
- package/build-types/tools-panel/tools-panel-item/hook.d.ts +55 -56
- package/build-types/tools-panel/tools-panel-item/hook.d.ts.map +1 -1
- package/build-types/tooltip/index.d.ts.map +1 -1
- package/build-types/truncate/component.d.ts +2 -1
- package/build-types/truncate/component.d.ts.map +1 -1
- package/build-types/truncate/hook.d.ts +55 -56
- package/build-types/truncate/hook.d.ts.map +1 -1
- package/build-types/ui/context/context-connect.d.ts +10 -9
- package/build-types/ui/context/context-connect.d.ts.map +1 -1
- package/build-types/ui/context/context-system-provider.d.ts.map +1 -1
- package/build-types/ui/context/test/context-connect.d.ts +2 -0
- package/build-types/ui/context/test/context-connect.d.ts.map +1 -0
- package/build-types/ui/context/test/wordpress-component.d.ts +2 -0
- package/build-types/ui/context/test/wordpress-component.d.ts.map +1 -0
- package/build-types/ui/context/wordpress-component.d.ts +8 -9
- package/build-types/ui/context/wordpress-component.d.ts.map +1 -1
- package/build-types/ui/control-group/component.d.ts +4 -1
- package/build-types/ui/control-group/component.d.ts.map +1 -1
- package/build-types/ui/control-group/hook.d.ts +55 -56
- package/build-types/ui/control-group/hook.d.ts.map +1 -1
- package/build-types/ui/control-label/component.d.ts +4 -1
- package/build-types/ui/control-label/component.d.ts.map +1 -1
- package/build-types/ui/control-label/hook.d.ts +55 -56
- package/build-types/ui/control-label/hook.d.ts.map +1 -1
- package/build-types/ui/form-group/form-group.d.ts +4 -8
- package/build-types/ui/form-group/form-group.d.ts.map +1 -1
- package/build-types/ui/form-group/use-form-group.d.ts +112 -114
- package/build-types/ui/form-group/use-form-group.d.ts.map +1 -1
- package/build-types/ui/shortcut/component.d.ts +2 -1
- package/build-types/ui/shortcut/component.d.ts.map +1 -1
- package/build-types/ui/spinner/component.d.ts +1 -1
- package/build-types/ui/tooltip/component.d.ts +11 -1
- package/build-types/ui/tooltip/component.d.ts.map +1 -1
- package/build-types/ui/tooltip/content.d.ts +7 -1
- package/build-types/ui/tooltip/styles.d.ts +1 -3
- package/build-types/ui/tooltip/styles.d.ts.map +1 -1
- package/build-types/unit-control/index.d.ts +2 -12
- package/build-types/unit-control/index.d.ts.map +1 -1
- package/build-types/unit-control/stories/index.d.ts.map +1 -1
- package/build-types/unit-control/styles/unit-control-styles.d.ts +5 -10
- package/build-types/unit-control/styles/unit-control-styles.d.ts.map +1 -1
- package/build-types/unit-control/types.d.ts +3 -35
- package/build-types/unit-control/types.d.ts.map +1 -1
- package/build-types/utils/colors-values.d.ts +0 -18
- package/build-types/utils/colors-values.d.ts.map +1 -1
- package/build-types/utils/math.d.ts +6 -6
- package/build-types/utils/math.d.ts.map +1 -1
- package/build-types/utils/values.d.ts +10 -8
- package/build-types/utils/values.d.ts.map +1 -1
- package/build-types/v-stack/component.d.ts +8 -2
- package/build-types/v-stack/component.d.ts.map +1 -1
- package/build-types/v-stack/hook.d.ts +55 -56
- package/build-types/v-stack/hook.d.ts.map +1 -1
- package/build-types/v-stack/stories/index.d.ts +8 -1
- package/build-types/v-stack/stories/index.d.ts.map +1 -1
- package/build-types/view/component.d.ts +8 -6
- package/build-types/view/component.d.ts.map +1 -1
- package/build-types/view/stories/index.d.ts +12 -0
- package/build-types/view/stories/index.d.ts.map +1 -0
- package/build-types/view/types.d.ts +8 -0
- package/build-types/view/types.d.ts.map +1 -0
- package/build-types/visually-hidden/component.d.ts +2 -1
- package/build-types/visually-hidden/component.d.ts.map +1 -1
- package/build-types/z-stack/component.d.ts +2 -1
- package/build-types/z-stack/component.d.ts.map +1 -1
- package/package.json +17 -17
- package/src/alignment-matrix-control/styles/alignment-matrix-control-styles.js +1 -1
- package/src/angle-picker-control/README.md +9 -1
- package/src/angle-picker-control/index.js +12 -0
- package/src/angle-picker-control/stories/index.js +3 -3
- package/src/autocomplete/autocompleter-ui.js +6 -3
- package/src/base-field/test/__snapshots__/index.js.snap +3 -5
- package/src/border-box-control/border-box-control/component.tsx +28 -12
- package/src/border-box-control/border-box-control-linked-button/component.tsx +1 -2
- package/src/border-box-control/border-box-control-split-controls/component.tsx +25 -11
- package/src/border-box-control/stories/index.js +1 -0
- package/src/border-box-control/styles.ts +2 -1
- package/src/border-box-control/types.ts +5 -4
- package/src/border-control/border-control-dropdown/component.tsx +3 -8
- package/src/border-control/types.ts +7 -9
- package/src/box-control/linked-button.js +3 -3
- package/src/box-control/test/index.js +5 -5
- package/src/button/style.scss +4 -3
- package/src/card/styles.ts +1 -1
- package/src/card/test/__snapshots__/index.tsx.snap +39 -51
- package/src/checkbox-control/index.tsx +3 -6
- package/src/checkbox-control/stories/index.tsx +6 -2
- package/src/checkbox-control/types.ts +4 -1
- package/src/color-palette/index.js +1 -1
- package/src/color-palette/test/__snapshots__/index.js.snap +67 -91
- package/src/color-picker/input-with-slider.tsx +1 -0
- package/src/combobox-control/index.js +1 -1
- package/src/combobox-control/test/index.js +311 -0
- package/src/custom-gradient-picker/index.js +1 -1
- package/src/date-time/date/index.tsx +2 -2
- package/src/date-time/time/timezone.tsx +1 -1
- package/src/dimension-control/test/__snapshots__/index.test.js.snap +1122 -164
- package/src/dimension-control/test/index.test.js +29 -38
- package/src/disabled/index.tsx +27 -9
- package/src/disabled/styles/disabled-styles.tsx +2 -2
- package/src/disabled/test/index.tsx +38 -0
- package/src/drop-zone/README.md +3 -3
- package/src/drop-zone/{index.js → index.tsx} +48 -13
- package/src/drop-zone/{provider.js → provider.ts} +5 -1
- package/src/drop-zone/stories/index.tsx +30 -0
- package/src/drop-zone/types.ts +29 -0
- package/src/dropdown/README.md +6 -4
- package/src/dropdown/index.js +15 -3
- package/src/dropdown/stories/index.js +1 -1
- package/src/flex/flex/hook.ts +5 -54
- package/src/flex/test/__snapshots__/index.tsx.snap +7 -15
- package/src/focal-point-picker/README.md +2 -2
- package/src/focal-point-picker/{controls.js → controls.tsx} +38 -10
- package/src/focal-point-picker/{focal-point.js → focal-point.tsx} +7 -1
- package/src/focal-point-picker/{grid.js → grid.tsx} +6 -1
- package/src/focal-point-picker/{index.js → index.tsx} +99 -15
- package/src/focal-point-picker/{media.js → media.tsx} +10 -4
- package/src/focal-point-picker/stories/index.tsx +93 -0
- package/src/focal-point-picker/styles/{focal-point-picker-style.js → focal-point-picker-style.ts} +31 -5
- package/src/focal-point-picker/styles/{focal-point-style.js → focal-point-style.ts} +2 -1
- package/src/focal-point-picker/test/index.js +27 -7
- package/src/focal-point-picker/types.ts +93 -0
- package/src/focal-point-picker/{utils.js → utils.ts} +9 -9
- package/src/font-size-picker/README.md +9 -0
- package/src/font-size-picker/index.js +9 -0
- package/src/font-size-picker/stories/index.js +3 -5
- package/src/font-size-picker/test/index.js +15 -2
- package/src/font-size-picker/test/utils.js +1 -2
- package/src/font-size-picker/utils.js +1 -1
- package/src/form-file-upload/README.md +6 -1
- package/src/form-file-upload/{index.js → index.tsx} +22 -4
- package/src/form-file-upload/stories/index.tsx +74 -0
- package/src/form-file-upload/test/{index.js → index.tsx} +7 -3
- package/src/form-file-upload/types.ts +63 -0
- package/src/form-toggle/index.tsx +1 -6
- package/src/form-token-field/index.tsx +4 -5
- package/src/form-token-field/suggestions-list.tsx +1 -2
- package/src/gradient-picker/index.js +41 -47
- package/src/gradient-picker/stories/index.js +10 -0
- package/src/h-stack/test/__snapshots__/index.tsx.snap +3 -12
- package/src/higher-order/with-filters/test/__snapshots__/index.js.snap +87 -0
- package/src/higher-order/with-filters/test/index.js +20 -74
- package/src/icon/index.tsx +1 -1
- package/src/icon/stories/index.js +18 -0
- package/src/icon/test/index.js +32 -83
- package/src/input-control/input-base.tsx +9 -11
- package/src/input-control/label.tsx +9 -4
- package/src/input-control/styles/input-control-styles.tsx +0 -43
- package/src/input-control/types.ts +3 -0
- package/src/isolated-event-container/test/index.js +53 -11
- package/src/item-group/test/__snapshots__/index.js.snap +16 -16
- package/src/keyboard-shortcuts/test/index.js +16 -31
- package/src/menu-item/test/__snapshots__/index.js.snap +60 -62
- package/src/menu-item/test/index.js +30 -22
- package/src/modal/aria-helper.js +3 -8
- package/src/modal/style.scss +3 -4
- package/src/navigable-container/README.md +2 -0
- package/src/navigable-container/container.js +8 -1
- package/src/navigable-container/menu.js +14 -11
- package/src/navigable-container/stories/navigable-menu.js +49 -0
- package/src/navigable-container/stories/tabbable-container.js +40 -0
- package/src/navigable-container/tabbable.js +2 -3
- package/src/navigable-container/test/navigable-menu.js +277 -0
- package/src/navigable-container/test/tababble-container.js +175 -0
- package/src/navigation/menu/menu-title-search.js +2 -0
- package/src/navigation/menu/use-navigation-tree-menu.js +2 -0
- package/src/navigator/navigator-button/hook.ts +1 -1
- package/src/navigator/navigator-screen/component.tsx +6 -1
- package/src/number-control/index.tsx +209 -0
- package/src/number-control/stories/index.js +6 -18
- package/src/number-control/types.ts +75 -0
- package/src/panel/README.md +1 -1
- package/src/panel/test/__snapshots__/header.js.snap +9 -0
- package/src/panel/test/__snapshots__/index.js.snap +17 -0
- package/src/panel/test/__snapshots__/row.js.snap +17 -0
- package/src/panel/test/header.js +30 -23
- package/src/panel/test/index.js +33 -25
- package/src/panel/test/row.js +18 -11
- package/src/placeholder/index.tsx +4 -5
- package/src/placeholder/style.scss +4 -0
- package/src/popover/README.md +128 -48
- package/src/popover/{index.js → index.tsx} +284 -182
- package/src/popover/stories/{index.js → index.tsx} +52 -54
- package/src/popover/test/index.js +7 -5
- package/src/popover/types.ts +192 -0
- package/src/popover/utils.ts +242 -0
- package/src/radio-control/index.tsx +28 -29
- package/src/radio-control/style.scss +0 -17
- package/src/range-control/index.tsx +4 -1
- package/src/range-control/styles/range-control-styles.ts +8 -8
- package/src/sandbox/index.js +2 -2
- package/src/search-control/README.md +5 -3
- package/src/search-control/{index.js → index.tsx} +35 -7
- package/src/search-control/stories/index.tsx +66 -0
- package/src/search-control/types.ts +43 -0
- package/src/select-control/index.native.js +1 -1
- package/src/slot-fill/test/index.js +69 -12
- package/src/style.scss +0 -1
- package/src/surface/test/__snapshots__/index.tsx.snap +10 -10
- package/src/tab-panel/README.md +1 -2
- package/src/tab-panel/{index.js → index.tsx} +58 -13
- package/src/tab-panel/stories/index.tsx +37 -0
- package/src/tab-panel/test/index.tsx +120 -0
- package/src/tab-panel/types.ts +65 -0
- package/src/text-control/index.tsx +2 -0
- package/src/text-control/types.ts +5 -1
- package/src/textarea-control/index.tsx +3 -6
- package/src/textarea-control/types.ts +1 -1
- package/src/toggle-control/index.tsx +97 -0
- package/src/toggle-control/stories/index.tsx +58 -0
- package/src/toggle-control/test/index.tsx +53 -0
- package/src/toggle-control/types.ts +28 -0
- package/src/toggle-group-control/stories/index.tsx +10 -3
- package/src/toggle-group-control/toggle-group-control/component.tsx +3 -3
- package/src/toggle-group-control/toggle-group-control-option-icon/README.md +1 -1
- package/src/toggle-group-control/toggle-group-control-option-icon/component.tsx +1 -1
- package/src/toggle-group-control/types.ts +2 -2
- package/src/tooltip/index.js +11 -7
- package/src/ui/context/context-connect.ts +58 -31
- package/src/ui/context/context-system-provider.js +5 -4
- package/src/ui/context/test/context-connect.tsx +55 -0
- package/src/ui/context/test/wordpress-component.tsx +36 -0
- package/src/ui/context/wordpress-component.ts +18 -12
- package/src/ui/control-group/test/__snapshots__/index.js.snap +1 -4
- package/src/unit-control/index.tsx +1 -1
- package/src/unit-control/stories/index.tsx +7 -16
- package/src/unit-control/styles/unit-control-styles.ts +2 -2
- package/src/unit-control/test/__snapshots__/index.tsx.snap +4 -6
- package/src/unit-control/types.ts +3 -44
- package/src/utils/colors-values.js +2 -24
- package/src/utils/math.js +4 -4
- package/src/utils/values.js +48 -6
- package/src/v-stack/test/__snapshots__/index.tsx.snap +3 -12
- package/src/view/{component.js → component.tsx} +13 -4
- package/src/view/stories/index.tsx +32 -0
- package/src/view/types.ts +6 -0
- package/tsconfig.json +1 -6
- package/tsconfig.tsbuildinfo +1 -1
- package/src/focal-point-picker/stories/index.js +0 -76
- package/src/navigable-container/test/menu.js +0 -310
- package/src/navigable-container/test/tabbable.js +0 -158
- package/src/number-control/index.js +0 -192
- package/src/popover/utils.js +0 -107
- package/src/search-control/stories/index.js +0 -39
- package/src/tab-panel/stories/index.js +0 -39
- package/src/tab-panel/test/index.js +0 -179
- package/src/toggle-control/index.js +0 -55
- package/src/toggle-control/stories/index.js +0 -64
- package/src/toggle-control/style.scss +0 -14
- package/src/toggle-control/test/index.js +0 -52
|
@@ -1,20 +1,26 @@
|
|
|
1
|
-
// @ts-nocheck
|
|
2
1
|
/**
|
|
3
2
|
* External dependencies
|
|
4
3
|
*/
|
|
4
|
+
import type { ForwardedRef, SyntheticEvent, RefCallback } from 'react';
|
|
5
5
|
import classnames from 'classnames';
|
|
6
6
|
import {
|
|
7
7
|
useFloating,
|
|
8
|
-
flip,
|
|
9
|
-
shift,
|
|
8
|
+
flip as flipMiddleware,
|
|
9
|
+
shift as shiftMiddleware,
|
|
10
10
|
autoUpdate,
|
|
11
11
|
arrow,
|
|
12
12
|
offset as offsetMiddleware,
|
|
13
13
|
limitShift,
|
|
14
14
|
size,
|
|
15
|
+
Middleware,
|
|
15
16
|
} from '@floating-ui/react-dom';
|
|
16
17
|
// eslint-disable-next-line no-restricted-imports
|
|
17
|
-
import {
|
|
18
|
+
import {
|
|
19
|
+
motion,
|
|
20
|
+
useReducedMotion,
|
|
21
|
+
HTMLMotionProps,
|
|
22
|
+
MotionProps,
|
|
23
|
+
} from 'framer-motion';
|
|
18
24
|
|
|
19
25
|
/**
|
|
20
26
|
* WordPress dependencies
|
|
@@ -26,6 +32,8 @@ import {
|
|
|
26
32
|
createContext,
|
|
27
33
|
useContext,
|
|
28
34
|
useMemo,
|
|
35
|
+
useState,
|
|
36
|
+
useCallback,
|
|
29
37
|
useEffect,
|
|
30
38
|
} from '@wordpress/element';
|
|
31
39
|
import {
|
|
@@ -47,7 +55,16 @@ import {
|
|
|
47
55
|
getFrameOffset,
|
|
48
56
|
positionToPlacement,
|
|
49
57
|
placementToMotionAnimationProps,
|
|
58
|
+
getReferenceOwnerDocument,
|
|
59
|
+
getReferenceElement,
|
|
50
60
|
} from './utils';
|
|
61
|
+
import type { WordPressComponentProps } from '../ui/context';
|
|
62
|
+
import type {
|
|
63
|
+
PopoverProps,
|
|
64
|
+
AnimatedWrapperProps,
|
|
65
|
+
PopoverAnchorRefReference,
|
|
66
|
+
PopoverAnchorRefTopBottom,
|
|
67
|
+
} from './types';
|
|
51
68
|
|
|
52
69
|
/**
|
|
53
70
|
* Name of slot in which popover should fill.
|
|
@@ -60,9 +77,8 @@ const SLOT_NAME = 'Popover';
|
|
|
60
77
|
// color and bordered in such a way to create an arrow-like effect.
|
|
61
78
|
// Keeping the SVG's viewbox squared simplify the arrow positioning
|
|
62
79
|
// calculations.
|
|
63
|
-
const ArrowTriangle = (
|
|
80
|
+
const ArrowTriangle = () => (
|
|
64
81
|
<SVG
|
|
65
|
-
{ ...props }
|
|
66
82
|
xmlns="http://www.w3.org/2000/svg"
|
|
67
83
|
viewBox={ `0 0 100 100` }
|
|
68
84
|
className="components-popover__triangle"
|
|
@@ -80,16 +96,20 @@ const ArrowTriangle = ( props ) => (
|
|
|
80
96
|
</SVG>
|
|
81
97
|
);
|
|
82
98
|
|
|
83
|
-
const
|
|
99
|
+
const AnimatedWrapper = forwardRef(
|
|
84
100
|
(
|
|
85
101
|
{
|
|
86
102
|
style: receivedInlineStyles,
|
|
87
103
|
placement,
|
|
88
104
|
shouldAnimate = false,
|
|
89
105
|
...props
|
|
90
|
-
},
|
|
91
|
-
forwardedRef
|
|
106
|
+
}: HTMLMotionProps< 'div' > & AnimatedWrapperProps,
|
|
107
|
+
forwardedRef: ForwardedRef< any >
|
|
92
108
|
) => {
|
|
109
|
+
// When animating, animate only once (i.e. when the popover is opened), and
|
|
110
|
+
// do not animate on subsequent prop changes (as it conflicts with
|
|
111
|
+
// floating-ui's positioning updates).
|
|
112
|
+
const [ hasAnimatedOnce, setHasAnimatedOnce ] = useState( false );
|
|
93
113
|
const shouldReduceMotion = useReducedMotion();
|
|
94
114
|
|
|
95
115
|
const { style: motionInlineStyles, ...otherMotionProps } = useMemo(
|
|
@@ -97,23 +117,32 @@ const MaybeAnimatedWrapper = forwardRef(
|
|
|
97
117
|
[ placement ]
|
|
98
118
|
);
|
|
99
119
|
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
|
|
109
|
-
|
|
110
|
-
|
|
111
|
-
|
|
112
|
-
|
|
120
|
+
const onAnimationComplete = useCallback(
|
|
121
|
+
() => setHasAnimatedOnce( true ),
|
|
122
|
+
[]
|
|
123
|
+
);
|
|
124
|
+
|
|
125
|
+
const computedAnimationProps: HTMLMotionProps< 'div' > =
|
|
126
|
+
shouldAnimate && ! shouldReduceMotion
|
|
127
|
+
? {
|
|
128
|
+
style: {
|
|
129
|
+
...motionInlineStyles,
|
|
130
|
+
...receivedInlineStyles,
|
|
131
|
+
},
|
|
132
|
+
...otherMotionProps,
|
|
133
|
+
onAnimationComplete,
|
|
134
|
+
animate: hasAnimatedOnce
|
|
135
|
+
? false
|
|
136
|
+
: otherMotionProps.animate,
|
|
137
|
+
}
|
|
138
|
+
: {
|
|
139
|
+
animate: false,
|
|
140
|
+
style: receivedInlineStyles,
|
|
141
|
+
};
|
|
113
142
|
|
|
114
143
|
return (
|
|
115
|
-
<div
|
|
116
|
-
|
|
144
|
+
<motion.div
|
|
145
|
+
{ ...computedAnimationProps }
|
|
117
146
|
{ ...props }
|
|
118
147
|
ref={ forwardedRef }
|
|
119
148
|
/>
|
|
@@ -121,11 +150,19 @@ const MaybeAnimatedWrapper = forwardRef(
|
|
|
121
150
|
}
|
|
122
151
|
);
|
|
123
152
|
|
|
124
|
-
const slotNameContext = createContext();
|
|
125
|
-
|
|
126
|
-
const
|
|
127
|
-
|
|
128
|
-
|
|
153
|
+
const slotNameContext = createContext< string | undefined >( undefined );
|
|
154
|
+
|
|
155
|
+
const UnforwardedPopover = (
|
|
156
|
+
props: Omit<
|
|
157
|
+
WordPressComponentProps< PopoverProps, 'div', false >,
|
|
158
|
+
// To avoid overlaps between the standard HTML attributes and the props
|
|
159
|
+
// expected by `framer-motion`, omit all framer motion props from popover
|
|
160
|
+
// props (except for `animate`, which is re-defined in `PopoverProps`).
|
|
161
|
+
keyof Omit< MotionProps, 'animate' >
|
|
162
|
+
>,
|
|
163
|
+
forwardedRef: ForwardedRef< any >
|
|
164
|
+
) => {
|
|
165
|
+
const {
|
|
129
166
|
animate = true,
|
|
130
167
|
headerTitle,
|
|
131
168
|
onClose,
|
|
@@ -137,27 +174,98 @@ const Popover = (
|
|
|
137
174
|
placement: placementProp = 'bottom-start',
|
|
138
175
|
offset: offsetProp = 0,
|
|
139
176
|
focusOnMount = 'firstElement',
|
|
140
|
-
|
|
141
|
-
anchorRect,
|
|
142
|
-
getAnchorRect,
|
|
177
|
+
anchor,
|
|
143
178
|
expandOnMobile,
|
|
144
179
|
onFocusOutside,
|
|
145
180
|
__unstableSlotName = SLOT_NAME,
|
|
146
|
-
|
|
147
|
-
|
|
181
|
+
flip = true,
|
|
182
|
+
resize = true,
|
|
183
|
+
shift = false,
|
|
184
|
+
|
|
185
|
+
// Deprecated props
|
|
186
|
+
__unstableForcePosition,
|
|
187
|
+
__unstableShift,
|
|
188
|
+
anchorRef,
|
|
189
|
+
anchorRect,
|
|
190
|
+
getAnchorRect,
|
|
191
|
+
range,
|
|
192
|
+
|
|
193
|
+
// Rest
|
|
148
194
|
...contentProps
|
|
149
|
-
}
|
|
150
|
-
|
|
151
|
-
) => {
|
|
195
|
+
} = props;
|
|
196
|
+
|
|
152
197
|
if ( range ) {
|
|
153
|
-
deprecated( 'range prop in Popover
|
|
198
|
+
deprecated( '`range` prop in wp.components.Popover', {
|
|
199
|
+
since: '6.1',
|
|
200
|
+
version: '6.3',
|
|
201
|
+
} );
|
|
202
|
+
}
|
|
203
|
+
|
|
204
|
+
let computedFlipProp = flip;
|
|
205
|
+
let computedResizeProp = resize;
|
|
206
|
+
if ( __unstableForcePosition !== undefined ) {
|
|
207
|
+
deprecated( '`__unstableForcePosition` prop wp.components.Popover', {
|
|
208
|
+
since: '6.1',
|
|
209
|
+
version: '6.3',
|
|
210
|
+
alternative: '`flip={ false }` and `resize={ false }`',
|
|
211
|
+
} );
|
|
212
|
+
|
|
213
|
+
// Back-compat, set the `flip` and `resize` props
|
|
214
|
+
// to `false` to replicate `__unstableForcePosition`.
|
|
215
|
+
computedFlipProp = ! __unstableForcePosition;
|
|
216
|
+
computedResizeProp = ! __unstableForcePosition;
|
|
217
|
+
}
|
|
218
|
+
|
|
219
|
+
let shouldShift = shift;
|
|
220
|
+
if ( __unstableShift !== undefined ) {
|
|
221
|
+
deprecated( '`__unstableShift` prop in wp.components.Popover', {
|
|
222
|
+
since: '6.1',
|
|
223
|
+
version: '6.3',
|
|
224
|
+
alternative: '`shift` prop`',
|
|
225
|
+
} );
|
|
226
|
+
|
|
227
|
+
// Back-compat.
|
|
228
|
+
shouldShift = __unstableShift;
|
|
229
|
+
}
|
|
230
|
+
|
|
231
|
+
if ( anchorRef !== undefined ) {
|
|
232
|
+
deprecated( '`anchorRef` prop in wp.components.Popover', {
|
|
233
|
+
since: '6.1',
|
|
234
|
+
version: '6.3',
|
|
235
|
+
alternative: '`anchor` prop',
|
|
236
|
+
} );
|
|
237
|
+
}
|
|
238
|
+
|
|
239
|
+
if ( anchorRect !== undefined ) {
|
|
240
|
+
deprecated( '`anchorRect` prop in wp.components.Popover', {
|
|
241
|
+
since: '6.1',
|
|
242
|
+
version: '6.3',
|
|
243
|
+
alternative: '`anchor` prop',
|
|
244
|
+
} );
|
|
245
|
+
}
|
|
246
|
+
|
|
247
|
+
if ( getAnchorRect !== undefined ) {
|
|
248
|
+
deprecated( '`getAnchorRect` prop in wp.components.Popover', {
|
|
154
249
|
since: '6.1',
|
|
155
250
|
version: '6.3',
|
|
251
|
+
alternative: '`anchor` prop',
|
|
156
252
|
} );
|
|
157
253
|
}
|
|
158
254
|
|
|
159
255
|
const arrowRef = useRef( null );
|
|
160
|
-
|
|
256
|
+
|
|
257
|
+
const [ fallbackReferenceElement, setFallbackReferenceElement ] =
|
|
258
|
+
useState< HTMLSpanElement | null >( null );
|
|
259
|
+
const [ referenceOwnerDocument, setReferenceOwnerDocument ] = useState<
|
|
260
|
+
Document | undefined
|
|
261
|
+
>();
|
|
262
|
+
|
|
263
|
+
const anchorRefFallback: RefCallback< HTMLSpanElement > = useCallback(
|
|
264
|
+
( node ) => {
|
|
265
|
+
setFallbackReferenceElement( node );
|
|
266
|
+
},
|
|
267
|
+
[]
|
|
268
|
+
);
|
|
161
269
|
|
|
162
270
|
const isMobileViewport = useViewportMatch( 'medium', '<' );
|
|
163
271
|
const isExpanded = expandOnMobile && isMobileViewport;
|
|
@@ -166,29 +274,6 @@ const Popover = (
|
|
|
166
274
|
? positionToPlacement( position )
|
|
167
275
|
: placementProp;
|
|
168
276
|
|
|
169
|
-
const referenceOwnerDocument = useMemo( () => {
|
|
170
|
-
let documentToReturn;
|
|
171
|
-
|
|
172
|
-
if ( anchorRef?.top ) {
|
|
173
|
-
documentToReturn = anchorRef?.top.ownerDocument;
|
|
174
|
-
} else if ( anchorRef?.startContainer ) {
|
|
175
|
-
documentToReturn = anchorRef.startContainer.ownerDocument;
|
|
176
|
-
} else if ( anchorRef?.current ) {
|
|
177
|
-
documentToReturn = anchorRef.current.ownerDocument;
|
|
178
|
-
} else if ( anchorRef ) {
|
|
179
|
-
// This one should be deprecated.
|
|
180
|
-
documentToReturn = anchorRef.ownerDocument;
|
|
181
|
-
} else if ( anchorRect && anchorRect?.ownerDocument ) {
|
|
182
|
-
documentToReturn = anchorRect.ownerDocument;
|
|
183
|
-
} else if ( getAnchorRect ) {
|
|
184
|
-
documentToReturn = getAnchorRect(
|
|
185
|
-
anchorRefFallback.current
|
|
186
|
-
)?.ownerDocument;
|
|
187
|
-
}
|
|
188
|
-
|
|
189
|
-
return documentToReturn ?? document;
|
|
190
|
-
}, [ anchorRef, anchorRect, getAnchorRect ] );
|
|
191
|
-
|
|
192
277
|
/**
|
|
193
278
|
* Offsets the position of the popover when the anchor is inside an iframe.
|
|
194
279
|
*
|
|
@@ -232,36 +317,43 @@ const Popover = (
|
|
|
232
317
|
crossAxis: frameOffsetRef.current[ crossAxis ],
|
|
233
318
|
};
|
|
234
319
|
} ),
|
|
235
|
-
|
|
236
|
-
|
|
237
|
-
?
|
|
238
|
-
: size( {
|
|
320
|
+
computedFlipProp ? flipMiddleware() : undefined,
|
|
321
|
+
computedResizeProp
|
|
322
|
+
? size( {
|
|
239
323
|
apply( sizeProps ) {
|
|
240
|
-
const {
|
|
241
|
-
|
|
324
|
+
const { firstElementChild } =
|
|
325
|
+
refs.floating.current ?? {};
|
|
326
|
+
|
|
327
|
+
// Only HTMLElement instances have the `style` property.
|
|
328
|
+
if ( ! ( firstElementChild instanceof HTMLElement ) )
|
|
329
|
+
return;
|
|
330
|
+
|
|
242
331
|
// Reduce the height of the popover to the available space.
|
|
243
|
-
Object.assign(
|
|
244
|
-
maxHeight: `${ availableHeight }px`,
|
|
332
|
+
Object.assign( firstElementChild.style, {
|
|
333
|
+
maxHeight: `${ sizeProps.availableHeight }px`,
|
|
245
334
|
overflow: 'auto',
|
|
246
335
|
} );
|
|
247
336
|
},
|
|
248
|
-
} )
|
|
249
|
-
|
|
250
|
-
|
|
337
|
+
} )
|
|
338
|
+
: undefined,
|
|
339
|
+
shouldShift
|
|
340
|
+
? shiftMiddleware( {
|
|
251
341
|
crossAxis: true,
|
|
252
342
|
limiter: limitShift(),
|
|
253
343
|
padding: 1, // Necessary to avoid flickering at the edge of the viewport.
|
|
254
344
|
} )
|
|
255
345
|
: undefined,
|
|
256
|
-
|
|
257
|
-
].filter(
|
|
346
|
+
arrow( { element: arrowRef } ),
|
|
347
|
+
].filter(
|
|
348
|
+
( m: Middleware | undefined ): m is Middleware => m !== undefined
|
|
349
|
+
);
|
|
258
350
|
const slotName = useContext( slotNameContext ) || __unstableSlotName;
|
|
259
351
|
const slot = useSlot( slotName );
|
|
260
352
|
|
|
261
353
|
let onDialogClose;
|
|
262
354
|
|
|
263
355
|
if ( onClose || onFocusOutside ) {
|
|
264
|
-
onDialogClose = ( type, event ) => {
|
|
356
|
+
onDialogClose = ( type: string | undefined, event: SyntheticEvent ) => {
|
|
265
357
|
// Ideally the popover should have just a single onClose prop and
|
|
266
358
|
// not three props that potentially do the same thing.
|
|
267
359
|
if ( type === 'focus-outside' && onFocusOutside ) {
|
|
@@ -275,6 +367,7 @@ const Popover = (
|
|
|
275
367
|
const [ dialogRef, dialogProps ] = useDialog( {
|
|
276
368
|
focusOnMount,
|
|
277
369
|
__unstableOnClose: onDialogClose,
|
|
370
|
+
// @ts-expect-error The __unstableOnClose property needs to be deprecated first (see https://github.com/WordPress/gutenberg/pull/27675)
|
|
278
371
|
onClose: onDialogClose,
|
|
279
372
|
} );
|
|
280
373
|
|
|
@@ -284,7 +377,7 @@ const Popover = (
|
|
|
284
377
|
y,
|
|
285
378
|
// Callback refs (not regular refs). This allows the position to be updated.
|
|
286
379
|
// when either elements change.
|
|
287
|
-
reference,
|
|
380
|
+
reference: referenceCallbackRef,
|
|
288
381
|
floating,
|
|
289
382
|
// Object with "regular" refs to both "reference" and "floating"
|
|
290
383
|
refs,
|
|
@@ -292,107 +385,77 @@ const Popover = (
|
|
|
292
385
|
strategy,
|
|
293
386
|
update,
|
|
294
387
|
placement: computedPlacement,
|
|
295
|
-
middlewareData: { arrow: arrowData
|
|
296
|
-
} = useFloating( {
|
|
388
|
+
middlewareData: { arrow: arrowData },
|
|
389
|
+
} = useFloating( {
|
|
390
|
+
placement: normalizedPlacementFromProps,
|
|
391
|
+
middleware,
|
|
392
|
+
whileElementsMounted: ( referenceParam, floatingParam, updateParam ) =>
|
|
393
|
+
autoUpdate( referenceParam, floatingParam, updateParam, {
|
|
394
|
+
animationFrame: true,
|
|
395
|
+
} ),
|
|
396
|
+
} );
|
|
297
397
|
|
|
298
398
|
useEffect( () => {
|
|
299
399
|
offsetRef.current = offsetProp;
|
|
300
400
|
update();
|
|
301
401
|
}, [ offsetProp, update ] );
|
|
302
402
|
|
|
303
|
-
|
|
304
|
-
|
|
305
|
-
|
|
306
|
-
|
|
307
|
-
|
|
308
|
-
|
|
309
|
-
|
|
310
|
-
// with the `getBoundingClientRect()` function (like real elements).
|
|
311
|
-
// See https://floating-ui.com/docs/virtual-elements for more info.
|
|
312
|
-
useLayoutEffect( () => {
|
|
313
|
-
let resultingReferenceRef;
|
|
314
|
-
|
|
315
|
-
if ( anchorRef?.top ) {
|
|
316
|
-
// Create a virtual element for the ref. The expectation is that
|
|
317
|
-
// if anchorRef.top is defined, then anchorRef.bottom is defined too.
|
|
318
|
-
resultingReferenceRef = {
|
|
319
|
-
getBoundingClientRect() {
|
|
320
|
-
const topRect = anchorRef.top.getBoundingClientRect();
|
|
321
|
-
const bottomRect = anchorRef.bottom.getBoundingClientRect();
|
|
322
|
-
return new window.DOMRect(
|
|
323
|
-
topRect.x,
|
|
324
|
-
topRect.y,
|
|
325
|
-
topRect.width,
|
|
326
|
-
bottomRect.bottom - topRect.top
|
|
327
|
-
);
|
|
328
|
-
},
|
|
329
|
-
};
|
|
330
|
-
} else if ( anchorRef?.current ) {
|
|
331
|
-
// Standard React ref.
|
|
332
|
-
resultingReferenceRef = anchorRef.current;
|
|
333
|
-
} else if ( anchorRef ) {
|
|
334
|
-
// If `anchorRef` holds directly the element's value (no `current` key)
|
|
335
|
-
// This is a weird scenario and should be deprecated.
|
|
336
|
-
resultingReferenceRef = anchorRef;
|
|
337
|
-
} else if ( anchorRect ) {
|
|
338
|
-
// Create a virtual element for the ref.
|
|
339
|
-
resultingReferenceRef = {
|
|
340
|
-
getBoundingClientRect() {
|
|
341
|
-
return anchorRect;
|
|
342
|
-
},
|
|
343
|
-
};
|
|
344
|
-
} else if ( getAnchorRect ) {
|
|
345
|
-
// Create a virtual element for the ref.
|
|
346
|
-
resultingReferenceRef = {
|
|
347
|
-
getBoundingClientRect() {
|
|
348
|
-
const rect = getAnchorRect( anchorRefFallback.current );
|
|
349
|
-
return new window.DOMRect(
|
|
350
|
-
rect.x ?? rect.left,
|
|
351
|
-
rect.y ?? rect.top,
|
|
352
|
-
rect.width ?? rect.right - rect.left,
|
|
353
|
-
rect.height ?? rect.bottom - rect.top
|
|
354
|
-
);
|
|
355
|
-
},
|
|
356
|
-
};
|
|
357
|
-
} else if ( anchorRefFallback.current ) {
|
|
358
|
-
// If no explicit ref is passed via props, fall back to
|
|
359
|
-
// anchoring to the popover's parent node.
|
|
360
|
-
resultingReferenceRef = anchorRefFallback.current.parentNode;
|
|
361
|
-
}
|
|
362
|
-
|
|
363
|
-
if ( ! resultingReferenceRef ) {
|
|
364
|
-
return;
|
|
365
|
-
}
|
|
403
|
+
const arrowCallbackRef = useCallback(
|
|
404
|
+
( node ) => {
|
|
405
|
+
arrowRef.current = node;
|
|
406
|
+
update();
|
|
407
|
+
},
|
|
408
|
+
[ update ]
|
|
409
|
+
);
|
|
366
410
|
|
|
367
|
-
|
|
411
|
+
// When any of the possible anchor "sources" change,
|
|
412
|
+
// recompute the reference element (real or virtual) and its owner document.
|
|
413
|
+
useLayoutEffect( () => {
|
|
414
|
+
const resultingReferenceOwnerDoc = getReferenceOwnerDocument( {
|
|
415
|
+
anchor,
|
|
416
|
+
anchorRef,
|
|
417
|
+
anchorRect,
|
|
418
|
+
getAnchorRect,
|
|
419
|
+
fallbackReferenceElement,
|
|
420
|
+
fallbackDocument: document,
|
|
421
|
+
} );
|
|
422
|
+
const resultingReferenceElement = getReferenceElement( {
|
|
423
|
+
anchor,
|
|
424
|
+
anchorRef,
|
|
425
|
+
anchorRect,
|
|
426
|
+
getAnchorRect,
|
|
427
|
+
fallbackReferenceElement,
|
|
428
|
+
} );
|
|
368
429
|
|
|
369
|
-
|
|
370
|
-
return;
|
|
371
|
-
}
|
|
430
|
+
referenceCallbackRef( resultingReferenceElement );
|
|
372
431
|
|
|
373
|
-
|
|
374
|
-
|
|
375
|
-
|
|
376
|
-
|
|
377
|
-
|
|
378
|
-
|
|
379
|
-
|
|
380
|
-
)
|
|
381
|
-
|
|
382
|
-
|
|
383
|
-
|
|
384
|
-
|
|
432
|
+
setReferenceOwnerDocument( resultingReferenceOwnerDoc );
|
|
433
|
+
}, [
|
|
434
|
+
anchor,
|
|
435
|
+
anchorRef as Element | undefined,
|
|
436
|
+
( anchorRef as PopoverAnchorRefTopBottom | undefined )?.top,
|
|
437
|
+
( anchorRef as PopoverAnchorRefTopBottom | undefined )?.bottom,
|
|
438
|
+
( anchorRef as Range | undefined )?.startContainer,
|
|
439
|
+
( anchorRef as PopoverAnchorRefReference )?.current,
|
|
440
|
+
anchorRect,
|
|
441
|
+
getAnchorRect,
|
|
442
|
+
fallbackReferenceElement,
|
|
443
|
+
referenceCallbackRef,
|
|
444
|
+
] );
|
|
385
445
|
|
|
386
446
|
// If the reference element is in a different ownerDocument (e.g. iFrame),
|
|
387
447
|
// we need to manually update the floating's position as the reference's owner
|
|
388
448
|
// document scrolls. Also update the frame offset if the view resizes.
|
|
389
449
|
useLayoutEffect( () => {
|
|
390
|
-
|
|
391
|
-
|
|
392
|
-
|
|
393
|
-
|
|
394
|
-
|
|
395
|
-
|
|
450
|
+
if (
|
|
451
|
+
// Reference and root documents are the same.
|
|
452
|
+
referenceOwnerDocument === document ||
|
|
453
|
+
// Reference and floating are in the same document.
|
|
454
|
+
referenceOwnerDocument === refs?.floating?.current?.ownerDocument ||
|
|
455
|
+
// The reference's document has no view (i.e. window)
|
|
456
|
+
// or frame element (ie. it's not an iframe).
|
|
457
|
+
! referenceOwnerDocument?.defaultView?.frameElement
|
|
458
|
+
) {
|
|
396
459
|
frameOffsetRef.current = undefined;
|
|
397
460
|
return;
|
|
398
461
|
}
|
|
@@ -424,7 +487,7 @@ const Popover = (
|
|
|
424
487
|
let content = (
|
|
425
488
|
// eslint-disable-next-line jsx-a11y/no-noninteractive-element-interactions
|
|
426
489
|
// eslint-disable-next-line jsx-a11y/no-static-element-interactions
|
|
427
|
-
<
|
|
490
|
+
<AnimatedWrapper
|
|
428
491
|
shouldAnimate={ animate && ! isExpanded }
|
|
429
492
|
placement={ computedPlacement }
|
|
430
493
|
className={ classnames( 'components-popover', className, {
|
|
@@ -434,14 +497,14 @@ const Popover = (
|
|
|
434
497
|
{ ...contentProps }
|
|
435
498
|
ref={ mergedFloatingRef }
|
|
436
499
|
{ ...dialogProps }
|
|
437
|
-
tabIndex=
|
|
500
|
+
tabIndex={ -1 }
|
|
438
501
|
style={
|
|
439
502
|
isExpanded
|
|
440
503
|
? undefined
|
|
441
504
|
: {
|
|
442
505
|
position: strategy,
|
|
443
|
-
left: Number.isNaN( x ) ? 0 : x,
|
|
444
|
-
top: Number.isNaN( y ) ? 0 : y,
|
|
506
|
+
left: Number.isNaN( x ) ? 0 : x ?? undefined,
|
|
507
|
+
top: Number.isNaN( y ) ? 0 : y ?? undefined,
|
|
445
508
|
}
|
|
446
509
|
}
|
|
447
510
|
>
|
|
@@ -462,42 +525,79 @@ const Popover = (
|
|
|
462
525
|
<div className="components-popover__content">{ children }</div>
|
|
463
526
|
{ hasArrow && (
|
|
464
527
|
<div
|
|
465
|
-
ref={
|
|
528
|
+
ref={ arrowCallbackRef }
|
|
466
529
|
className={ [
|
|
467
530
|
'components-popover__arrow',
|
|
468
531
|
`is-${ computedPlacement.split( '-' )[ 0 ] }`,
|
|
469
532
|
].join( ' ' ) }
|
|
470
533
|
style={ {
|
|
471
|
-
left:
|
|
472
|
-
|
|
473
|
-
|
|
474
|
-
|
|
475
|
-
|
|
476
|
-
|
|
534
|
+
left:
|
|
535
|
+
typeof arrowData?.x !== 'undefined' &&
|
|
536
|
+
Number.isFinite( arrowData.x )
|
|
537
|
+
? `${
|
|
538
|
+
arrowData.x +
|
|
539
|
+
( frameOffsetRef.current?.x ?? 0 )
|
|
540
|
+
}px`
|
|
541
|
+
: '',
|
|
542
|
+
top:
|
|
543
|
+
typeof arrowData?.y !== 'undefined' &&
|
|
544
|
+
Number.isFinite( arrowData.y )
|
|
545
|
+
? `${
|
|
546
|
+
arrowData.y +
|
|
547
|
+
( frameOffsetRef.current?.y ?? 0 )
|
|
548
|
+
}px`
|
|
549
|
+
: '',
|
|
477
550
|
} }
|
|
478
551
|
>
|
|
479
552
|
<ArrowTriangle />
|
|
480
553
|
</div>
|
|
481
554
|
) }
|
|
482
|
-
</
|
|
555
|
+
</AnimatedWrapper>
|
|
483
556
|
);
|
|
484
557
|
|
|
485
558
|
if ( slot.ref ) {
|
|
486
559
|
content = <Fill name={ slotName }>{ content }</Fill>;
|
|
487
560
|
}
|
|
488
561
|
|
|
489
|
-
if ( anchorRef || anchorRect ) {
|
|
562
|
+
if ( anchorRef || anchorRect || anchor ) {
|
|
490
563
|
return content;
|
|
491
564
|
}
|
|
492
565
|
|
|
493
566
|
return <span ref={ anchorRefFallback }>{ content }</span>;
|
|
494
567
|
};
|
|
495
568
|
|
|
496
|
-
|
|
569
|
+
/**
|
|
570
|
+
* `Popover` renders its content in a floating modal. If no explicit anchor is passed via props, it anchors to its parent element by default.
|
|
571
|
+
*
|
|
572
|
+
* ```jsx
|
|
573
|
+
* import { Button, Popover } from '@wordpress/components';
|
|
574
|
+
* import { useState } from '@wordpress/element';
|
|
575
|
+
*
|
|
576
|
+
* const MyPopover = () => {
|
|
577
|
+
* const [ isVisible, setIsVisible ] = useState( false );
|
|
578
|
+
* const toggleVisible = () => {
|
|
579
|
+
* setIsVisible( ( state ) => ! state );
|
|
580
|
+
* };
|
|
581
|
+
*
|
|
582
|
+
* return (
|
|
583
|
+
* <Button variant="secondary" onClick={ toggleVisible }>
|
|
584
|
+
* Toggle Popover!
|
|
585
|
+
* { isVisible && <Popover>Popover is toggled!</Popover> }
|
|
586
|
+
* </Button>
|
|
587
|
+
* );
|
|
588
|
+
* };
|
|
589
|
+
* ```
|
|
590
|
+
*
|
|
591
|
+
*/
|
|
592
|
+
export const Popover = forwardRef( UnforwardedPopover );
|
|
497
593
|
|
|
498
|
-
function PopoverSlot(
|
|
594
|
+
function PopoverSlot(
|
|
595
|
+
{ name = SLOT_NAME }: { name?: string },
|
|
596
|
+
ref: ForwardedRef< any >
|
|
597
|
+
) {
|
|
499
598
|
return (
|
|
500
599
|
<Slot
|
|
600
|
+
// @ts-expect-error Need to type `SlotFill`
|
|
501
601
|
bubblesVirtually
|
|
502
602
|
name={ name }
|
|
503
603
|
className="popover-slot"
|
|
@@ -506,7 +606,9 @@ function PopoverSlot( { name = SLOT_NAME }, ref ) {
|
|
|
506
606
|
);
|
|
507
607
|
}
|
|
508
608
|
|
|
509
|
-
|
|
510
|
-
|
|
609
|
+
// @ts-expect-error For Legacy Reasons
|
|
610
|
+
Popover.Slot = forwardRef( PopoverSlot );
|
|
611
|
+
// @ts-expect-error For Legacy Reasons
|
|
612
|
+
Popover.__unstableSlotNameProvider = slotNameContext.Provider;
|
|
511
613
|
|
|
512
|
-
export default
|
|
614
|
+
export default Popover;
|