@wordpress/components 23.2.0 → 23.3.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 +35 -1
- package/CONTRIBUTING.md +1 -1
- package/build/alignment-matrix-control/utils.js +2 -2
- package/build/alignment-matrix-control/utils.js.map +1 -1
- package/build/autocomplete/autocompleter-ui.js +1 -3
- package/build/autocomplete/autocompleter-ui.js.map +1 -1
- package/build/border-box-control/border-box-control-linked-button/component.js.map +1 -1
- package/build/border-box-control/border-box-control-linked-button/hook.js.map +1 -1
- package/build/border-control/border-control-dropdown/component.js +8 -4
- package/build/border-control/border-control-dropdown/component.js.map +1 -1
- package/build/button/deprecated.js +8 -6
- package/build/button/deprecated.js.map +1 -1
- package/build/button/index.js +52 -23
- package/build/button/index.js.map +1 -1
- package/build/button/types.js +6 -0
- package/build/button/types.js.map +1 -0
- package/build/color-list-picker/index.js.map +1 -1
- package/build/color-list-picker/types.js +6 -0
- package/build/color-list-picker/types.js.map +1 -0
- package/build/color-palette/index.js +9 -61
- package/build/color-palette/index.js.map +1 -1
- package/build/color-palette/index.native.js +24 -9
- package/build/color-palette/index.native.js.map +1 -1
- package/build/color-palette/utils.js +103 -0
- package/build/color-palette/utils.js.map +1 -0
- package/build/custom-gradient-picker/gradient-bar/utils.js +1 -1
- package/build/custom-gradient-picker/gradient-bar/utils.js.map +1 -1
- package/build/date-time/date/index.js.map +1 -1
- package/build/dropdown/index.js +20 -8
- package/build/dropdown/index.js.map +1 -1
- package/build/form-token-field/token.js +1 -1
- package/build/form-token-field/token.js.map +1 -1
- package/build/gradient-picker/index.js +9 -1
- package/build/gradient-picker/index.js.map +1 -1
- package/build/h-stack/component.js +0 -1
- package/build/h-stack/component.js.map +1 -1
- package/build/input-control/input-field.js +4 -2
- package/build/input-control/input-field.js.map +1 -1
- package/build/keyboard-shortcuts/index.js +44 -16
- package/build/keyboard-shortcuts/index.js.map +1 -1
- package/build/keyboard-shortcuts/types.js +6 -0
- package/build/keyboard-shortcuts/types.js.map +1 -0
- package/build/modal/index.js +1 -1
- package/build/modal/index.js.map +1 -1
- package/build/notice/index.js +16 -18
- package/build/notice/index.js.map +1 -1
- package/build/notice/list.js +23 -8
- package/build/notice/list.js.map +1 -1
- package/build/notice/types.js +6 -0
- package/build/notice/types.js.map +1 -0
- package/build/number-control/index.js +1 -1
- package/build/number-control/index.js.map +1 -1
- package/build/query-controls/author-select.js +7 -3
- package/build/query-controls/author-select.js.map +1 -1
- package/build/query-controls/category-select.js +7 -3
- package/build/query-controls/category-select.js.map +1 -1
- package/build/query-controls/index.js +68 -20
- package/build/query-controls/index.js.map +1 -1
- package/build/query-controls/terms.js +4 -3
- package/build/query-controls/terms.js.map +1 -1
- package/build/query-controls/types.js +6 -0
- package/build/query-controls/types.js.map +1 -0
- package/build/slot-fill/bubbles-virtually/fill.js +1 -0
- package/build/slot-fill/bubbles-virtually/fill.js.map +1 -1
- package/build/slot-fill/slot.js +1 -0
- package/build/slot-fill/slot.js.map +1 -1
- package/build/slot-fill/use-slot.js +1 -11
- package/build/slot-fill/use-slot.js.map +1 -1
- package/build/snackbar/index.js.map +1 -1
- package/build/snackbar/list.js.map +1 -1
- package/build/tab-panel/index.js +36 -8
- package/build/tab-panel/index.js.map +1 -1
- package/build/tree-grid/index.js +1 -1
- package/build/tree-grid/index.js.map +1 -1
- package/build/tree-select/index.js +2 -6
- package/build/tree-select/index.js.map +1 -1
- package/build-module/alignment-matrix-control/utils.js +2 -2
- package/build-module/alignment-matrix-control/utils.js.map +1 -1
- package/build-module/autocomplete/autocompleter-ui.js +1 -2
- package/build-module/autocomplete/autocompleter-ui.js.map +1 -1
- 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-linked-button/hook.js.map +1 -1
- package/build-module/border-control/border-control-dropdown/component.js +7 -4
- package/build-module/border-control/border-control-dropdown/component.js.map +1 -1
- package/build-module/button/deprecated.js +8 -5
- package/build-module/button/deprecated.js.map +1 -1
- package/build-module/button/index.js +51 -22
- package/build-module/button/index.js.map +1 -1
- package/build-module/button/types.js +2 -0
- package/build-module/button/types.js.map +1 -0
- package/build-module/color-list-picker/index.js.map +1 -1
- package/build-module/color-list-picker/types.js +2 -0
- package/build-module/color-list-picker/types.js.map +1 -0
- package/build-module/color-palette/index.js +7 -54
- package/build-module/color-palette/index.js.map +1 -1
- package/build-module/color-palette/index.native.js +24 -8
- package/build-module/color-palette/index.native.js.map +1 -1
- package/build-module/color-palette/utils.js +79 -0
- package/build-module/color-palette/utils.js.map +1 -0
- package/build-module/custom-gradient-picker/gradient-bar/utils.js +1 -1
- package/build-module/custom-gradient-picker/gradient-bar/utils.js.map +1 -1
- package/build-module/date-time/date/index.js +1 -1
- package/build-module/date-time/date/index.js.map +1 -1
- package/build-module/dropdown/index.js +19 -8
- package/build-module/dropdown/index.js.map +1 -1
- package/build-module/form-token-field/token.js +1 -1
- package/build-module/form-token-field/token.js.map +1 -1
- package/build-module/gradient-picker/index.js +9 -2
- package/build-module/gradient-picker/index.js.map +1 -1
- package/build-module/h-stack/component.js +0 -1
- package/build-module/h-stack/component.js.map +1 -1
- package/build-module/input-control/input-field.js +4 -2
- package/build-module/input-control/input-field.js.map +1 -1
- package/build-module/keyboard-shortcuts/index.js +48 -16
- package/build-module/keyboard-shortcuts/index.js.map +1 -1
- package/build-module/keyboard-shortcuts/types.js +2 -0
- package/build-module/keyboard-shortcuts/types.js.map +1 -0
- package/build-module/modal/index.js +1 -1
- package/build-module/modal/index.js.map +1 -1
- package/build-module/notice/index.js +14 -15
- package/build-module/notice/index.js.map +1 -1
- package/build-module/notice/list.js +23 -8
- package/build-module/notice/list.js.map +1 -1
- package/build-module/notice/types.js +2 -0
- package/build-module/notice/types.js.map +1 -0
- package/build-module/number-control/index.js +1 -1
- package/build-module/number-control/index.js.map +1 -1
- package/build-module/query-controls/author-select.js +7 -3
- package/build-module/query-controls/author-select.js.map +1 -1
- package/build-module/query-controls/category-select.js +8 -4
- package/build-module/query-controls/category-select.js.map +1 -1
- package/build-module/query-controls/index.js +64 -20
- package/build-module/query-controls/index.js.map +1 -1
- package/build-module/query-controls/terms.js +8 -4
- package/build-module/query-controls/terms.js.map +1 -1
- package/build-module/query-controls/types.js +2 -0
- package/build-module/query-controls/types.js.map +1 -0
- package/build-module/slot-fill/bubbles-virtually/fill.js +1 -0
- package/build-module/slot-fill/bubbles-virtually/fill.js.map +1 -1
- package/build-module/slot-fill/slot.js +1 -0
- package/build-module/slot-fill/slot.js.map +1 -1
- package/build-module/slot-fill/use-slot.js +2 -12
- package/build-module/slot-fill/use-slot.js.map +1 -1
- package/build-module/snackbar/index.js.map +1 -1
- package/build-module/snackbar/list.js.map +1 -1
- package/build-module/tab-panel/index.js +36 -8
- package/build-module/tab-panel/index.js.map +1 -1
- package/build-module/tree-grid/index.js +1 -1
- package/build-module/tree-grid/index.js.map +1 -1
- package/build-module/tree-select/index.js +2 -6
- package/build-module/tree-select/index.js.map +1 -1
- package/build-style/style-rtl.css +5 -0
- package/build-style/style.css +5 -0
- package/build-types/border-box-control/border-box-control/hook.d.ts +1 -1
- package/build-types/border-box-control/border-box-control-linked-button/component.d.ts +1 -1
- package/build-types/border-box-control/border-box-control-linked-button/hook.d.ts +171 -160
- 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/hook.d.ts +1 -1
- package/build-types/border-control/border-control/hook.d.ts +1 -1
- 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 +1 -1
- package/build-types/button/deprecated.d.ts +143 -7
- package/build-types/button/deprecated.d.ts.map +1 -1
- package/build-types/button/index.d.ts +20 -3
- package/build-types/button/index.d.ts.map +1 -1
- package/build-types/button/stories/index.d.ts +20 -0
- package/build-types/button/stories/index.d.ts.map +1 -0
- package/build-types/button/test/index.d.ts +2 -0
- package/build-types/button/test/index.d.ts.map +1 -0
- package/build-types/button/types.d.ts +134 -0
- package/build-types/button/types.d.ts.map +1 -0
- package/build-types/color-list-picker/index.d.ts +5 -0
- package/build-types/color-list-picker/index.d.ts.map +1 -0
- package/build-types/color-list-picker/types.d.ts +42 -0
- package/build-types/color-list-picker/types.d.ts.map +1 -0
- package/build-types/color-palette/index.d.ts +2 -4
- package/build-types/color-palette/index.d.ts.map +1 -1
- package/build-types/color-palette/stories/index.d.ts +2 -2
- package/build-types/color-palette/styles.d.ts +1 -1
- package/build-types/color-palette/types.d.ts +1 -1
- package/build-types/color-palette/types.d.ts.map +1 -1
- package/build-types/color-palette/utils.d.ts +14 -0
- package/build-types/color-palette/utils.d.ts.map +1 -0
- package/build-types/color-picker/styles.d.ts +2 -2
- package/build-types/date-time/date/index.d.ts.map +1 -1
- package/build-types/date-time/date/styles.d.ts +3 -3
- package/build-types/dropdown/index.d.ts +4 -4
- package/build-types/dropdown/index.d.ts.map +1 -1
- package/build-types/dropdown/stories/index.d.ts.map +1 -1
- package/build-types/dropdown/types.d.ts +9 -10
- package/build-types/dropdown/types.d.ts.map +1 -1
- package/build-types/font-size-picker/styles.d.ts +2 -2
- package/build-types/h-stack/component.d.ts +0 -1
- package/build-types/h-stack/component.d.ts.map +1 -1
- package/build-types/input-control/input-field.d.ts.map +1 -1
- package/build-types/keyboard-shortcuts/index.d.ts +38 -0
- package/build-types/keyboard-shortcuts/index.d.ts.map +1 -0
- package/build-types/keyboard-shortcuts/stories/index.d.ts +12 -0
- package/build-types/keyboard-shortcuts/stories/index.d.ts.map +1 -0
- package/build-types/keyboard-shortcuts/test/index.d.ts +2 -0
- package/build-types/keyboard-shortcuts/test/index.d.ts.map +1 -0
- package/build-types/keyboard-shortcuts/types.d.ts +48 -0
- package/build-types/keyboard-shortcuts/types.d.ts.map +1 -0
- package/build-types/modal/index.d.ts.map +1 -1
- package/build-types/navigator/navigator-back-button/component.d.ts +1 -1
- package/build-types/navigator/navigator-back-button/hook.d.ts +2 -2
- package/build-types/navigator/navigator-button/component.d.ts +1 -1
- package/build-types/navigator/navigator-button/hook.d.ts +2 -2
- package/build-types/notice/index.d.ts +16 -0
- package/build-types/notice/index.d.ts.map +1 -0
- package/build-types/notice/list.d.ts +32 -0
- package/build-types/notice/list.d.ts.map +1 -0
- package/build-types/notice/stories/index.d.ts +17 -0
- package/build-types/notice/stories/index.d.ts.map +1 -0
- package/build-types/notice/test/index.d.ts +2 -0
- package/build-types/notice/test/index.d.ts.map +1 -0
- package/build-types/notice/test/list.d.ts +2 -0
- package/build-types/notice/test/list.d.ts.map +1 -0
- package/build-types/notice/types.d.ts +128 -0
- package/build-types/notice/types.d.ts.map +1 -0
- package/build-types/number-control/styles/number-control-styles.d.ts +2 -2
- package/build-types/number-control/styles/number-control-styles.d.ts.map +1 -1
- package/build-types/placeholder/stories/index.d.ts.map +1 -1
- package/build-types/query-controls/author-select.d.ts +4 -0
- package/build-types/query-controls/author-select.d.ts.map +1 -0
- package/build-types/query-controls/category-select.d.ts +4 -0
- package/build-types/query-controls/category-select.d.ts.map +1 -0
- package/build-types/query-controls/index.d.ts +30 -0
- package/build-types/query-controls/index.d.ts.map +1 -0
- package/build-types/query-controls/stories/index.d.ts +13 -0
- package/build-types/query-controls/stories/index.d.ts.map +1 -0
- package/build-types/query-controls/terms.d.ts +13 -0
- package/build-types/query-controls/terms.d.ts.map +1 -0
- package/build-types/query-controls/test/terms.d.ts +2 -0
- package/build-types/query-controls/test/terms.d.ts.map +1 -0
- package/build-types/query-controls/types.d.ts +131 -0
- package/build-types/query-controls/types.d.ts.map +1 -0
- package/build-types/range-control/index.d.ts +1 -1
- package/build-types/slot-fill/bubbles-virtually/fill.d.ts.map +1 -1
- package/build-types/slot-fill/use-slot.d.ts.map +1 -1
- package/build-types/snackbar/index.d.ts +9 -2
- package/build-types/snackbar/index.d.ts.map +1 -1
- package/build-types/snackbar/list.d.ts.map +1 -1
- package/build-types/snackbar/types.d.ts +15 -88
- package/build-types/snackbar/types.d.ts.map +1 -1
- package/build-types/tab-panel/index.d.ts.map +1 -1
- package/build-types/tab-panel/types.d.ts +1 -1
- package/build-types/tab-panel/types.d.ts.map +1 -1
- package/build-types/toggle-group-control/stories/index.d.ts.map +1 -1
- package/build-types/tree-select/index.d.ts.map +1 -1
- package/build-types/ui/form-group/form-group.d.ts +2 -2
- package/package.json +18 -17
- package/src/alignment-matrix-control/utils.tsx +2 -2
- package/src/autocomplete/autocompleter-ui.js +1 -2
- package/src/autocomplete/test/index.js +1 -5
- package/src/border-box-control/border-box-control-linked-button/component.tsx +1 -1
- package/src/border-box-control/border-box-control-linked-button/hook.ts +1 -1
- package/src/border-control/border-control-dropdown/component.tsx +9 -8
- package/src/box-control/test/index.js +11 -35
- package/src/button/README.md +49 -55
- package/src/button/{deprecated.js → deprecated.tsx} +19 -4
- package/src/button/{index.js → index.tsx} +95 -34
- package/src/button/stories/index.tsx +106 -0
- package/src/button/style.scss +3 -2
- package/src/button/test/{index.js → index.tsx} +30 -7
- package/src/button/types.ts +138 -0
- package/src/checkbox-control/test/index.tsx +1 -5
- package/src/color-list-picker/{index.js → index.tsx} +3 -2
- package/src/color-list-picker/types.ts +46 -0
- package/src/color-palette/README.md +1 -1
- package/src/color-palette/index.native.js +11 -4
- package/src/color-palette/index.tsx +11 -67
- package/src/color-palette/test/index.tsx +4 -14
- package/src/color-palette/test/utils.ts +1 -1
- package/src/color-palette/types.ts +1 -1
- package/src/color-palette/utils.ts +98 -0
- package/src/color-picker/test/index.js +6 -15
- package/src/combobox-control/test/index.js +1 -6
- package/src/confirm-dialog/test/index.js +9 -29
- package/src/custom-gradient-picker/gradient-bar/utils.js +1 -1
- package/src/date-time/date/index.tsx +2 -1
- package/src/date-time/date/test/index.tsx +2 -8
- package/src/date-time/time/test/index.tsx +9 -29
- package/src/dimension-control/test/index.test.js +2 -8
- package/src/disabled/test/index.tsx +1 -5
- package/src/draggable/test/index.native.js +4 -4
- package/src/dropdown/README.md +1 -8
- package/src/dropdown/index.tsx +17 -6
- package/src/dropdown/stories/index.tsx +3 -3
- package/src/dropdown/test/index.tsx +2 -8
- package/src/dropdown/types.ts +9 -10
- package/src/dropdown-menu/README.md +1 -1
- package/src/dropdown-menu/stories/index.js +96 -27
- package/src/dropdown-menu/test/index.js +2 -8
- package/src/external-link/test/index.tsx +1 -6
- package/src/focal-point-picker/test/index.js +3 -11
- package/src/font-size-picker/test/index.tsx +14 -44
- package/src/form-file-upload/test/index.tsx +2 -17
- package/src/form-toggle/test/index.tsx +1 -5
- package/src/form-token-field/test/index.tsx +80 -163
- package/src/form-token-field/token.tsx +1 -1
- package/src/gradient-picker/index.js +15 -4
- package/src/guide/test/index.js +5 -17
- package/src/h-stack/component.tsx +0 -1
- package/src/higher-order/with-filters/test/index.js +24 -24
- package/src/higher-order/with-focus-outside/test/index.js +11 -25
- package/src/higher-order/with-focus-return/test/index.js +1 -5
- package/src/input-control/input-field.tsx +3 -1
- package/src/input-control/test/index.js +1 -6
- package/src/isolated-event-container/test/index.js +2 -8
- package/src/keyboard-shortcuts/README.md +1 -1
- package/src/keyboard-shortcuts/index.tsx +93 -0
- package/src/keyboard-shortcuts/stories/index.tsx +60 -0
- package/src/keyboard-shortcuts/test/{index.js → index.tsx} +16 -6
- package/src/keyboard-shortcuts/types.ts +51 -0
- package/src/modal/index.tsx +1 -2
- package/src/navigable-container/test/navigable-menu.js +5 -17
- package/src/navigable-container/test/tababble-container.js +3 -11
- package/src/navigation/test/index.js +3 -11
- package/src/navigator/test/index.tsx +6 -20
- package/src/notice/README.md +89 -42
- package/src/notice/{index.js → index.tsx} +28 -20
- package/src/notice/list.tsx +72 -0
- package/src/notice/stories/index.tsx +119 -0
- package/src/notice/test/__snapshots__/{index.js.snap → index.tsx.snap} +0 -0
- package/src/notice/test/{index.js → index.tsx} +7 -4
- package/src/notice/test/{list.js → list.tsx} +0 -0
- package/src/notice/types.ts +136 -0
- package/src/number-control/index.tsx +1 -1
- package/src/number-control/test/index.tsx +28 -86
- package/src/panel/test/body.js +2 -8
- package/src/placeholder/stories/index.tsx +1 -0
- package/src/query-controls/README.md +56 -56
- package/src/query-controls/author-select.tsx +37 -0
- package/src/query-controls/category-select.tsx +46 -0
- package/src/query-controls/index.tsx +192 -0
- package/src/query-controls/stories/index.tsx +205 -0
- package/src/query-controls/terms.ts +57 -0
- package/src/query-controls/test/{terms.js → terms.ts} +36 -20
- package/src/query-controls/types.ts +150 -0
- package/src/select-control/test/select-control.tsx +1 -6
- package/src/slot-fill/bubbles-virtually/fill.js +1 -0
- package/src/slot-fill/slot.js +1 -1
- package/src/slot-fill/use-slot.js +6 -16
- package/src/snackbar/index.tsx +6 -5
- package/src/snackbar/list.tsx +4 -2
- package/src/snackbar/types.ts +18 -92
- package/src/tab-panel/index.tsx +38 -16
- package/src/tab-panel/style.scss +8 -0
- package/src/tab-panel/test/index.tsx +35 -7
- package/src/tab-panel/types.ts +1 -1
- package/src/theme/test/index.tsx +4 -4
- package/src/toggle-group-control/stories/index.tsx +1 -0
- package/src/toggle-group-control/test/index.tsx +7 -23
- package/src/toolbar/stories/index.js +75 -72
- package/src/tools-panel/stories/index.js +3 -0
- package/src/tools-panel/test/index.js +1 -1
- package/src/tree-grid/index.js +1 -1
- package/src/tree-select/index.tsx +3 -6
- package/src/ui/context/test/context-connect.tsx +2 -0
- package/src/ui/context/test/wordpress-component.tsx +2 -0
- package/src/unit-control/test/index.tsx +21 -74
- package/src/utils/hooks/test/use-latest-ref.js +15 -18
- package/tsconfig.json +1 -4
- package/tsconfig.tsbuildinfo +1 -1
- package/build-types/radio-context/index.d.ts +0 -6
- package/build-types/radio-context/index.d.ts.map +0 -1
- package/src/button/stories/index.js +0 -179
- package/src/keyboard-shortcuts/index.js +0 -56
- package/src/notice/list.js +0 -48
- package/src/notice/stories/index.js +0 -46
- package/src/query-controls/author-select.js +0 -23
- package/src/query-controls/category-select.js +0 -31
- package/src/query-controls/index.js +0 -122
- package/src/query-controls/terms.js +0 -40
- package/src/toolbar/stories/toolbar-button.js +0 -32
- package/src/toolbar/stories/toolbar-group.js +0 -33
|
@@ -16,8 +16,6 @@ import UnitControl from '..';
|
|
|
16
16
|
import { parseQuantityAndUnitFromRawValue } from '../utils';
|
|
17
17
|
import type { UnitControlOnChangeCallback } from '../types';
|
|
18
18
|
|
|
19
|
-
jest.useFakeTimers();
|
|
20
|
-
|
|
21
19
|
const getInput = ( {
|
|
22
20
|
isInputTypeText = false,
|
|
23
21
|
}: {
|
|
@@ -87,15 +85,6 @@ const ControlledSyncUnits = () => {
|
|
|
87
85
|
};
|
|
88
86
|
|
|
89
87
|
describe( 'UnitControl', () => {
|
|
90
|
-
beforeEach( () => {
|
|
91
|
-
jest.useFakeTimers();
|
|
92
|
-
} );
|
|
93
|
-
|
|
94
|
-
afterEach( () => {
|
|
95
|
-
jest.runOnlyPendingTimers();
|
|
96
|
-
jest.useRealTimers();
|
|
97
|
-
} );
|
|
98
|
-
|
|
99
88
|
describe( 'Basic rendering', () => {
|
|
100
89
|
it( 'should render', () => {
|
|
101
90
|
render( <UnitControl /> );
|
|
@@ -147,9 +136,7 @@ describe( 'UnitControl', () => {
|
|
|
147
136
|
|
|
148
137
|
describe( 'Value', () => {
|
|
149
138
|
it( 'should update value on change', async () => {
|
|
150
|
-
const user = userEvent.setup(
|
|
151
|
-
advanceTimers: jest.advanceTimersByTime,
|
|
152
|
-
} );
|
|
139
|
+
const user = userEvent.setup();
|
|
153
140
|
|
|
154
141
|
let state = '50px';
|
|
155
142
|
const setState = jest.fn( ( value ) => ( state = value ) );
|
|
@@ -169,9 +156,7 @@ describe( 'UnitControl', () => {
|
|
|
169
156
|
} );
|
|
170
157
|
|
|
171
158
|
it( 'should increment value on UP press', async () => {
|
|
172
|
-
const user = userEvent.setup(
|
|
173
|
-
advanceTimers: jest.advanceTimersByTime,
|
|
174
|
-
} );
|
|
159
|
+
const user = userEvent.setup();
|
|
175
160
|
|
|
176
161
|
let state: string | undefined = '50px';
|
|
177
162
|
const setState: UnitControlOnChangeCallback = ( nextState ) =>
|
|
@@ -186,9 +171,7 @@ describe( 'UnitControl', () => {
|
|
|
186
171
|
} );
|
|
187
172
|
|
|
188
173
|
it( 'should increment value on UP + SHIFT press, with step', async () => {
|
|
189
|
-
const user = userEvent.setup(
|
|
190
|
-
advanceTimers: jest.advanceTimersByTime,
|
|
191
|
-
} );
|
|
174
|
+
const user = userEvent.setup();
|
|
192
175
|
|
|
193
176
|
let state: string | undefined = '50px';
|
|
194
177
|
const setState: UnitControlOnChangeCallback = ( nextState ) =>
|
|
@@ -203,9 +186,7 @@ describe( 'UnitControl', () => {
|
|
|
203
186
|
} );
|
|
204
187
|
|
|
205
188
|
it( 'should decrement value on DOWN press', async () => {
|
|
206
|
-
const user = userEvent.setup(
|
|
207
|
-
advanceTimers: jest.advanceTimersByTime,
|
|
208
|
-
} );
|
|
189
|
+
const user = userEvent.setup();
|
|
209
190
|
|
|
210
191
|
let state: string | number | undefined = 50;
|
|
211
192
|
const setState: UnitControlOnChangeCallback = ( nextState ) =>
|
|
@@ -220,9 +201,7 @@ describe( 'UnitControl', () => {
|
|
|
220
201
|
} );
|
|
221
202
|
|
|
222
203
|
it( 'should decrement value on DOWN + SHIFT press, with step', async () => {
|
|
223
|
-
const user = userEvent.setup(
|
|
224
|
-
advanceTimers: jest.advanceTimersByTime,
|
|
225
|
-
} );
|
|
204
|
+
const user = userEvent.setup();
|
|
226
205
|
|
|
227
206
|
let state: string | number | undefined = 50;
|
|
228
207
|
const setState: UnitControlOnChangeCallback = ( nextState ) =>
|
|
@@ -237,9 +216,7 @@ describe( 'UnitControl', () => {
|
|
|
237
216
|
} );
|
|
238
217
|
|
|
239
218
|
it( 'should cancel change when ESCAPE key is pressed', async () => {
|
|
240
|
-
const user = userEvent.setup(
|
|
241
|
-
advanceTimers: jest.advanceTimersByTime,
|
|
242
|
-
} );
|
|
219
|
+
const user = userEvent.setup();
|
|
243
220
|
|
|
244
221
|
let state: string | number | undefined = 50;
|
|
245
222
|
const setState: UnitControlOnChangeCallback = ( nextState ) =>
|
|
@@ -268,9 +245,7 @@ describe( 'UnitControl', () => {
|
|
|
268
245
|
} );
|
|
269
246
|
|
|
270
247
|
it( 'should run onBlur callback when quantity input is blurred', async () => {
|
|
271
|
-
const user = userEvent.setup(
|
|
272
|
-
advanceTimers: jest.advanceTimersByTime,
|
|
273
|
-
} );
|
|
248
|
+
const user = userEvent.setup();
|
|
274
249
|
|
|
275
250
|
const onChangeSpy = jest.fn();
|
|
276
251
|
const onBlurSpy = jest.fn();
|
|
@@ -303,9 +278,7 @@ describe( 'UnitControl', () => {
|
|
|
303
278
|
} );
|
|
304
279
|
|
|
305
280
|
it( 'should invoke onChange and onUnitChange callbacks when isPressEnterToChange is true and the component is blurred with an uncommitted value', async () => {
|
|
306
|
-
const user = userEvent.setup(
|
|
307
|
-
advanceTimers: jest.advanceTimersByTime,
|
|
308
|
-
} );
|
|
281
|
+
const user = userEvent.setup();
|
|
309
282
|
|
|
310
283
|
const onUnitChangeSpy = jest.fn();
|
|
311
284
|
const onChangeSpy = jest.fn();
|
|
@@ -348,9 +321,7 @@ describe( 'UnitControl', () => {
|
|
|
348
321
|
} );
|
|
349
322
|
|
|
350
323
|
it( 'should update value correctly when typed and blurred when a single unit is passed', async () => {
|
|
351
|
-
const user = userEvent.setup(
|
|
352
|
-
advanceTimers: jest.advanceTimersByTime,
|
|
353
|
-
} );
|
|
324
|
+
const user = userEvent.setup();
|
|
354
325
|
|
|
355
326
|
const onChangeSpy = jest.fn();
|
|
356
327
|
render(
|
|
@@ -384,9 +355,7 @@ describe( 'UnitControl', () => {
|
|
|
384
355
|
|
|
385
356
|
describe( 'Unit', () => {
|
|
386
357
|
it( 'should update unit value on change', async () => {
|
|
387
|
-
const user = userEvent.setup(
|
|
388
|
-
advanceTimers: jest.advanceTimersByTime,
|
|
389
|
-
} );
|
|
358
|
+
const user = userEvent.setup();
|
|
390
359
|
|
|
391
360
|
let state: string | undefined = '14rem';
|
|
392
361
|
const setState: UnitControlOnChangeCallback = ( nextState ) =>
|
|
@@ -428,9 +397,7 @@ describe( 'UnitControl', () => {
|
|
|
428
397
|
} );
|
|
429
398
|
|
|
430
399
|
it( 'should reset value on unit change, if unit has default value', async () => {
|
|
431
|
-
const user = userEvent.setup(
|
|
432
|
-
advanceTimers: jest.advanceTimersByTime,
|
|
433
|
-
} );
|
|
400
|
+
const user = userEvent.setup();
|
|
434
401
|
|
|
435
402
|
let state: string | number | undefined = 50;
|
|
436
403
|
const setState: UnitControlOnChangeCallback = ( nextState ) =>
|
|
@@ -461,9 +428,7 @@ describe( 'UnitControl', () => {
|
|
|
461
428
|
} );
|
|
462
429
|
|
|
463
430
|
it( 'should not reset value on unit change, if disabled', async () => {
|
|
464
|
-
const user = userEvent.setup(
|
|
465
|
-
advanceTimers: jest.advanceTimersByTime,
|
|
466
|
-
} );
|
|
431
|
+
const user = userEvent.setup();
|
|
467
432
|
|
|
468
433
|
let state: string | number | undefined = 50;
|
|
469
434
|
const setState: UnitControlOnChangeCallback = ( nextState ) =>
|
|
@@ -494,9 +459,7 @@ describe( 'UnitControl', () => {
|
|
|
494
459
|
} );
|
|
495
460
|
|
|
496
461
|
it( 'should set correct unit if single units', async () => {
|
|
497
|
-
const user = userEvent.setup(
|
|
498
|
-
advanceTimers: jest.advanceTimersByTime,
|
|
499
|
-
} );
|
|
462
|
+
const user = userEvent.setup();
|
|
500
463
|
|
|
501
464
|
let state: string | undefined = '50%';
|
|
502
465
|
const setState: UnitControlOnChangeCallback = ( value ) =>
|
|
@@ -518,9 +481,7 @@ describe( 'UnitControl', () => {
|
|
|
518
481
|
} );
|
|
519
482
|
|
|
520
483
|
it( 'should update unit value when a new raw value is passed', async () => {
|
|
521
|
-
const user = userEvent.setup(
|
|
522
|
-
advanceTimers: jest.advanceTimersByTime,
|
|
523
|
-
} );
|
|
484
|
+
const user = userEvent.setup();
|
|
524
485
|
|
|
525
486
|
render( <ControlledSyncUnits /> );
|
|
526
487
|
|
|
@@ -550,9 +511,7 @@ describe( 'UnitControl', () => {
|
|
|
550
511
|
} );
|
|
551
512
|
|
|
552
513
|
it( 'should maintain the chosen non-default unit when value is cleared', async () => {
|
|
553
|
-
const user = userEvent.setup(
|
|
554
|
-
advanceTimers: jest.advanceTimersByTime,
|
|
555
|
-
} );
|
|
514
|
+
const user = userEvent.setup();
|
|
556
515
|
|
|
557
516
|
const units = [
|
|
558
517
|
{ value: 'pt', label: 'pt' },
|
|
@@ -571,9 +530,7 @@ describe( 'UnitControl', () => {
|
|
|
571
530
|
} );
|
|
572
531
|
|
|
573
532
|
it( 'should run onBlur callback when the unit select is blurred', async () => {
|
|
574
|
-
const user = userEvent.setup(
|
|
575
|
-
advanceTimers: jest.advanceTimersByTime,
|
|
576
|
-
} );
|
|
533
|
+
const user = userEvent.setup();
|
|
577
534
|
|
|
578
535
|
const onUnitChangeSpy = jest.fn();
|
|
579
536
|
const onBlurSpy = jest.fn();
|
|
@@ -604,9 +561,7 @@ describe( 'UnitControl', () => {
|
|
|
604
561
|
|
|
605
562
|
describe( 'Unit Parser', () => {
|
|
606
563
|
it( 'should parse unit from input', async () => {
|
|
607
|
-
const user = userEvent.setup(
|
|
608
|
-
advanceTimers: jest.advanceTimersByTime,
|
|
609
|
-
} );
|
|
564
|
+
const user = userEvent.setup();
|
|
610
565
|
|
|
611
566
|
let state = '10px';
|
|
612
567
|
const setState = jest.fn( ( nextState ) => ( state = nextState ) );
|
|
@@ -629,9 +584,7 @@ describe( 'UnitControl', () => {
|
|
|
629
584
|
} );
|
|
630
585
|
|
|
631
586
|
it( 'should parse PX unit from input', async () => {
|
|
632
|
-
const user = userEvent.setup(
|
|
633
|
-
advanceTimers: jest.advanceTimersByTime,
|
|
634
|
-
} );
|
|
587
|
+
const user = userEvent.setup();
|
|
635
588
|
|
|
636
589
|
let state = '10px';
|
|
637
590
|
const setState = jest.fn( ( nextState ) => ( state = nextState ) );
|
|
@@ -654,9 +607,7 @@ describe( 'UnitControl', () => {
|
|
|
654
607
|
} );
|
|
655
608
|
|
|
656
609
|
it( 'should parse EM unit from input', async () => {
|
|
657
|
-
const user = userEvent.setup(
|
|
658
|
-
advanceTimers: jest.advanceTimersByTime,
|
|
659
|
-
} );
|
|
610
|
+
const user = userEvent.setup();
|
|
660
611
|
|
|
661
612
|
let state = '10px';
|
|
662
613
|
const setState = jest.fn( ( nextState ) => ( state = nextState ) );
|
|
@@ -679,9 +630,7 @@ describe( 'UnitControl', () => {
|
|
|
679
630
|
} );
|
|
680
631
|
|
|
681
632
|
it( 'should parse % unit from input', async () => {
|
|
682
|
-
const user = userEvent.setup(
|
|
683
|
-
advanceTimers: jest.advanceTimersByTime,
|
|
684
|
-
} );
|
|
633
|
+
const user = userEvent.setup();
|
|
685
634
|
|
|
686
635
|
let state = '10px';
|
|
687
636
|
const setState = jest.fn( ( nextState ) => ( state = nextState ) );
|
|
@@ -704,9 +653,7 @@ describe( 'UnitControl', () => {
|
|
|
704
653
|
} );
|
|
705
654
|
|
|
706
655
|
it( 'should parse REM unit from input', async () => {
|
|
707
|
-
const user = userEvent.setup(
|
|
708
|
-
advanceTimers: jest.advanceTimersByTime,
|
|
709
|
-
} );
|
|
656
|
+
const user = userEvent.setup();
|
|
710
657
|
|
|
711
658
|
let state = '10px';
|
|
712
659
|
const setState = jest.fn( ( nextState ) => ( state = nextState ) );
|
|
@@ -13,8 +13,6 @@ import { useState } from '@wordpress/element';
|
|
|
13
13
|
*/
|
|
14
14
|
import { useLatestRef } from '..';
|
|
15
15
|
|
|
16
|
-
jest.useFakeTimers();
|
|
17
|
-
|
|
18
16
|
function debounce( callback, timeout = 0 ) {
|
|
19
17
|
let timeoutId = 0;
|
|
20
18
|
return ( ...args ) => {
|
|
@@ -47,12 +45,6 @@ function Example() {
|
|
|
47
45
|
);
|
|
48
46
|
}
|
|
49
47
|
|
|
50
|
-
function sleep( milliseconds ) {
|
|
51
|
-
return new Promise( ( resolve ) =>
|
|
52
|
-
window.setTimeout( resolve, milliseconds )
|
|
53
|
-
);
|
|
54
|
-
}
|
|
55
|
-
|
|
56
48
|
function getCount() {
|
|
57
49
|
return screen.getByText( /Count:/ ).innerHTML;
|
|
58
50
|
}
|
|
@@ -76,47 +68,52 @@ describe( 'useLatestRef', () => {
|
|
|
76
68
|
// Prove the example works as expected.
|
|
77
69
|
it( 'should start at 0', () => {
|
|
78
70
|
render( <Example /> );
|
|
71
|
+
|
|
79
72
|
expect( getCount() ).toEqual( 'Count: 0' );
|
|
80
73
|
} );
|
|
81
74
|
|
|
82
75
|
it( 'should increment immediately', () => {
|
|
83
76
|
render( <Example /> );
|
|
77
|
+
|
|
84
78
|
incrementCount();
|
|
79
|
+
|
|
85
80
|
expect( getCount() ).toEqual( 'Count: 1' );
|
|
86
81
|
} );
|
|
87
82
|
|
|
88
83
|
it( 'should increment after debouncing', async () => {
|
|
89
84
|
render( <Example /> );
|
|
85
|
+
|
|
90
86
|
incrementCountDebounced();
|
|
91
|
-
expect( getCount() ).toEqual( 'Count: 0' );
|
|
92
87
|
|
|
93
|
-
|
|
94
|
-
expect( getCount() ).toEqual( 'Count: 1' );
|
|
88
|
+
expect( getCount() ).toEqual( 'Count: 0' );
|
|
89
|
+
await waitFor( () => expect( getCount() ).toEqual( 'Count: 1' ) );
|
|
95
90
|
} );
|
|
96
91
|
|
|
97
92
|
it( 'should increment after debouncing with latest ref', async () => {
|
|
98
93
|
render( <Example /> );
|
|
94
|
+
|
|
99
95
|
incrementCountDebouncedRef();
|
|
100
|
-
expect( getCount() ).toEqual( 'Count: 0' );
|
|
101
96
|
|
|
102
|
-
|
|
103
|
-
expect( getCount() ).toEqual( 'Count: 1' );
|
|
97
|
+
expect( getCount() ).toEqual( 'Count: 0' );
|
|
98
|
+
await waitFor( () => expect( getCount() ).toEqual( 'Count: 1' ) );
|
|
104
99
|
} );
|
|
105
100
|
} );
|
|
106
101
|
|
|
107
102
|
it( 'should increment to one', async () => {
|
|
108
103
|
render( <Example /> );
|
|
104
|
+
|
|
109
105
|
incrementCountDebounced();
|
|
110
106
|
incrementCount();
|
|
111
|
-
|
|
112
|
-
expect( getCount() ).toEqual( 'Count: 1' );
|
|
107
|
+
|
|
108
|
+
await waitFor( () => expect( getCount() ).toEqual( 'Count: 1' ) );
|
|
113
109
|
} );
|
|
114
110
|
|
|
115
111
|
it( 'should increment to two', async () => {
|
|
116
112
|
render( <Example /> );
|
|
113
|
+
|
|
117
114
|
incrementCountDebouncedRef();
|
|
118
115
|
incrementCount();
|
|
119
|
-
|
|
120
|
-
expect( getCount() ).toEqual( 'Count: 2' );
|
|
116
|
+
|
|
117
|
+
await waitFor( () => expect( getCount() ).toEqual( 'Count: 2' ) );
|
|
121
118
|
} );
|
|
122
119
|
} );
|
package/tsconfig.json
CHANGED
|
@@ -24,6 +24,7 @@
|
|
|
24
24
|
{ "path": "../deprecated" },
|
|
25
25
|
{ "path": "../dom" },
|
|
26
26
|
{ "path": "../element" },
|
|
27
|
+
{ "path": "../html-entities" },
|
|
27
28
|
{ "path": "../hooks" },
|
|
28
29
|
{ "path": "../icons" },
|
|
29
30
|
{ "path": "../is-shallow-equal" },
|
|
@@ -43,7 +44,6 @@
|
|
|
43
44
|
"src/angle-picker-control",
|
|
44
45
|
"src/autocomplete",
|
|
45
46
|
"src/box-control",
|
|
46
|
-
"src/color-list-picker",
|
|
47
47
|
"src/combobox-control",
|
|
48
48
|
"src/custom-gradient-picker",
|
|
49
49
|
"src/dimension-control",
|
|
@@ -55,13 +55,10 @@
|
|
|
55
55
|
"src/higher-order/with-filters",
|
|
56
56
|
"src/higher-order/with-focus-return",
|
|
57
57
|
"src/higher-order/with-notices",
|
|
58
|
-
"src/keyboard-shortcuts",
|
|
59
58
|
"src/menu-items-choice",
|
|
60
59
|
"src/navigation",
|
|
61
|
-
"src/notice",
|
|
62
60
|
"src/palette-edit",
|
|
63
61
|
"src/panel",
|
|
64
|
-
"src/query-controls",
|
|
65
62
|
"src/toolbar",
|
|
66
63
|
"src/tree-grid"
|
|
67
64
|
]
|