@wordpress/block-editor 12.24.0 → 12.26.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 +11 -3
- package/README.md +7 -1
- package/build/components/alignment-control/ui.js +3 -1
- package/build/components/alignment-control/ui.js.map +1 -1
- package/build/components/block-actions/index.js +4 -2
- package/build/components/block-actions/index.js.map +1 -1
- package/build/components/block-alignment-control/ui.js +2 -2
- package/build/components/block-alignment-control/ui.js.map +1 -1
- package/build/components/block-card/index.js +2 -2
- package/build/components/block-card/index.js.map +1 -1
- package/build/components/block-compare/index.js +2 -2
- package/build/components/block-compare/index.js.map +1 -1
- package/build/components/block-edit/edit.js +2 -2
- package/build/components/block-edit/edit.js.map +1 -1
- package/build/components/block-icon/index.js +2 -2
- package/build/components/block-icon/index.js.map +1 -1
- package/build/components/block-list/block.js +4 -13
- package/build/components/block-list/block.js.map +1 -1
- package/build/components/block-list/block.native.js +2 -2
- package/build/components/block-list/block.native.js.map +1 -1
- package/build/components/block-list/index.js +6 -5
- package/build/components/block-list/index.js.map +1 -1
- package/build/components/block-list/index.native.js +1 -9
- package/build/components/block-list/index.native.js.map +1 -1
- package/build/components/block-list/use-block-props/index.js +11 -8
- package/build/components/block-list/use-block-props/index.js.map +1 -1
- package/build/components/block-list/use-block-props/use-block-refs.js +17 -46
- package/build/components/block-list/use-block-props/use-block-refs.js.map +1 -1
- package/build/components/block-list/use-block-props/use-is-hovered.js +10 -14
- package/build/components/block-list/use-block-props/use-is-hovered.js.map +1 -1
- package/build/components/block-list/use-block-props/use-scroll-into-view.js +44 -0
- package/build/components/block-list/use-block-props/use-scroll-into-view.js.map +1 -0
- package/build/components/block-list-appender/index.js +2 -2
- package/build/components/block-list-appender/index.js.map +1 -1
- package/build/components/block-mover/button.js +2 -2
- package/build/components/block-mover/button.js.map +1 -1
- package/build/components/block-mover/index.js +2 -2
- package/build/components/block-mover/index.js.map +1 -1
- package/build/components/block-mover/index.native.js +3 -1
- package/build/components/block-mover/index.native.js.map +1 -1
- package/build/components/block-patterns-list/index.js +26 -5
- package/build/components/block-patterns-list/index.js.map +1 -1
- package/build/components/block-popover/cover.js +9 -6
- package/build/components/block-popover/cover.js.map +1 -1
- package/build/components/block-popover/inbetween.js +2 -2
- package/build/components/block-popover/inbetween.js.map +1 -1
- package/build/components/block-popover/index.js +22 -4
- package/build/components/block-popover/index.js.map +1 -1
- package/build/components/block-preview/index.js +2 -2
- package/build/components/block-preview/index.js.map +1 -1
- package/build/components/block-settings-menu/block-settings-dropdown.js +8 -30
- package/build/components/block-settings-menu/block-settings-dropdown.js.map +1 -1
- package/build/components/block-settings-menu-controls/index.js +10 -7
- package/build/components/block-settings-menu-controls/index.js.map +1 -1
- package/build/components/block-styles/index.js +2 -2
- package/build/components/block-styles/index.js.map +1 -1
- package/build/components/block-switcher/pattern-transformations-menu.js +3 -1
- package/build/components/block-switcher/pattern-transformations-menu.js.map +1 -1
- package/build/components/block-switcher/use-transformed-patterns.js +6 -2
- package/build/components/block-switcher/use-transformed-patterns.js.map +1 -1
- package/build/components/block-switcher/utils.js +15 -5
- package/build/components/block-switcher/utils.js.map +1 -1
- package/build/components/block-toolbar/index.js +3 -3
- package/build/components/block-toolbar/index.js.map +1 -1
- package/build/components/block-toolbar/use-has-block-toolbar.js +14 -9
- package/build/components/block-toolbar/use-has-block-toolbar.js.map +1 -1
- package/build/components/block-tools/block-selection-button.js +2 -2
- package/build/components/block-tools/block-selection-button.js.map +1 -1
- package/build/components/block-tools/block-toolbar-breadcrumb.js +4 -4
- package/build/components/block-tools/block-toolbar-breadcrumb.js.map +1 -1
- package/build/components/block-tools/block-toolbar-popover.js +2 -2
- package/build/components/block-tools/block-toolbar-popover.js.map +1 -1
- package/build/components/block-tools/empty-block-inserter.js +2 -2
- package/build/components/block-tools/empty-block-inserter.js.map +1 -1
- package/build/components/block-tools/index.js +23 -2
- package/build/components/block-tools/index.js.map +1 -1
- package/build/components/block-tools/insertion-point.js +4 -4
- package/build/components/block-tools/insertion-point.js.map +1 -1
- package/build/components/block-tools/use-show-block-tools.js +2 -5
- package/build/components/block-tools/use-show-block-tools.js.map +1 -1
- package/build/components/block-tools/zoom-out-mode-inserters.js +68 -20
- package/build/components/block-tools/zoom-out-mode-inserters.js.map +1 -1
- package/build/components/block-variation-picker/index.js +5 -4
- package/build/components/block-variation-picker/index.js.map +1 -1
- package/build/components/block-variation-transforms/index.js +3 -1
- package/build/components/block-variation-transforms/index.js.map +1 -1
- package/build/components/button-block-appender/index.js +2 -2
- package/build/components/button-block-appender/index.js.map +1 -1
- package/build/components/child-layout-control/index.js +2 -2
- package/build/components/child-layout-control/index.js.map +1 -1
- package/build/components/colors-gradients/control.js +3 -3
- package/build/components/colors-gradients/control.js.map +1 -1
- package/build/components/colors-gradients/dropdown.js +2 -2
- package/build/components/colors-gradients/dropdown.js.map +1 -1
- package/build/components/colors-gradients/panel-color-gradient-settings.js +2 -2
- package/build/components/colors-gradients/panel-color-gradient-settings.js.map +1 -1
- package/build/components/convert-to-group-buttons/index.js +6 -0
- package/build/components/convert-to-group-buttons/index.js.map +1 -1
- package/build/components/default-block-appender/index.js +2 -2
- package/build/components/default-block-appender/index.js.map +1 -1
- package/build/components/dimensions-tool/aspect-ratio-tool.js +30 -36
- package/build/components/dimensions-tool/aspect-ratio-tool.js.map +1 -1
- package/build/components/floating-toolbar/index.native.js +9 -5
- package/build/components/floating-toolbar/index.native.js.map +1 -1
- package/build/components/global-styles/background-panel.js +4 -4
- package/build/components/global-styles/background-panel.js.map +1 -1
- package/build/components/global-styles/color-panel.js +6 -4
- package/build/components/global-styles/color-panel.js.map +1 -1
- package/build/components/global-styles/dimensions-panel.js +20 -4
- package/build/components/global-styles/dimensions-panel.js.map +1 -1
- package/build/components/global-styles/filters-panel.js +2 -2
- package/build/components/global-styles/filters-panel.js.map +1 -1
- package/build/components/global-styles/hooks.js +3 -2
- package/build/components/global-styles/hooks.js.map +1 -1
- package/build/components/global-styles/shadow-panel-components.js +4 -4
- package/build/components/global-styles/shadow-panel-components.js.map +1 -1
- package/build/components/global-styles/typography-panel.js +23 -23
- package/build/components/global-styles/typography-panel.js.map +1 -1
- package/build/components/global-styles/use-global-styles-output.js +149 -132
- package/build/components/global-styles/use-global-styles-output.js.map +1 -1
- package/build/components/global-styles/utils.js +45 -0
- package/build/components/global-styles/utils.js.map +1 -1
- package/build/components/grid-visualizer/grid-item-resizer.js +141 -24
- package/build/components/grid-visualizer/grid-item-resizer.js.map +1 -1
- package/build/components/grid-visualizer/grid-visualizer.js +11 -5
- package/build/components/grid-visualizer/grid-visualizer.js.map +1 -1
- package/build/components/iframe/index.js +69 -30
- package/build/components/iframe/index.js.map +1 -1
- package/build/components/image-editor/aspect-ratio-dropdown.js +53 -36
- package/build/components/image-editor/aspect-ratio-dropdown.js.map +1 -1
- package/build/components/image-editor/cropper.js +2 -2
- package/build/components/image-editor/cropper.js.map +1 -1
- package/build/components/image-editor/index.js +1 -1
- package/build/components/image-editor/index.js.map +1 -1
- package/build/components/index.js +8 -0
- package/build/components/index.js.map +1 -1
- package/build/components/inner-blocks/button-block-appender.js +2 -2
- package/build/components/inner-blocks/button-block-appender.js.map +1 -1
- package/build/components/inner-blocks/index.js +25 -10
- package/build/components/inner-blocks/index.js.map +1 -1
- package/build/components/inserter/block-patterns-explorer/pattern-list.js +1 -1
- package/build/components/inserter/block-patterns-explorer/pattern-list.js.map +1 -1
- package/build/components/inserter/block-patterns-tab/index.js +20 -30
- package/build/components/inserter/block-patterns-tab/index.js.map +1 -1
- package/build/components/inserter/block-patterns-tab/pattern-category-previews.js +1 -1
- package/build/components/inserter/block-patterns-tab/pattern-category-previews.js.map +1 -1
- package/build/components/inserter/block-types-tab.js +9 -3
- package/build/components/inserter/block-types-tab.js.map +1 -1
- package/build/components/inserter/category-tabs/index.js +56 -0
- package/build/components/inserter/category-tabs/index.js.map +1 -0
- package/build/components/inserter/hooks/use-insertion-point.js +11 -2
- package/build/components/inserter/hooks/use-insertion-point.js.map +1 -1
- package/build/components/inserter/hooks/use-patterns-state.js +12 -5
- package/build/components/inserter/hooks/use-patterns-state.js.map +1 -1
- package/build/components/inserter/index.js +2 -2
- package/build/components/inserter/index.js.map +1 -1
- package/build/components/inserter/library.js +8 -2
- package/build/components/inserter/library.js.map +1 -1
- package/build/components/inserter/media-tab/index.js +2 -2
- package/build/components/inserter/media-tab/index.js.map +1 -1
- package/build/components/inserter/media-tab/media-panel.js +0 -25
- package/build/components/inserter/media-tab/media-panel.js.map +1 -1
- package/build/components/inserter/media-tab/media-preview.js +15 -5
- package/build/components/inserter/media-tab/media-preview.js.map +1 -1
- package/build/components/inserter/media-tab/media-tab.js +15 -29
- package/build/components/inserter/media-tab/media-tab.js.map +1 -1
- package/build/components/inserter/menu.js +115 -109
- package/build/components/inserter/menu.js.map +1 -1
- package/build/components/inserter/quick-inserter.js +2 -2
- package/build/components/inserter/quick-inserter.js.map +1 -1
- package/build/components/inserter/tabs.js +23 -11
- package/build/components/inserter/tabs.js.map +1 -1
- package/build/components/inserter-list-item/index.js +3 -3
- package/build/components/inserter-list-item/index.js.map +1 -1
- package/build/components/keyboard-shortcuts/index.js +9 -0
- package/build/components/keyboard-shortcuts/index.js.map +1 -1
- package/build/components/line-height-control/index.js +6 -2
- package/build/components/line-height-control/index.js.map +1 -1
- package/build/components/link-control/index.js +2 -2
- package/build/components/link-control/index.js.map +1 -1
- package/build/components/link-control/link-preview.js +3 -3
- package/build/components/link-control/link-preview.js.map +1 -1
- package/build/components/link-control/search-item.js +9 -3
- package/build/components/link-control/search-item.js.map +1 -1
- package/build/components/link-control/search-results.js +2 -2
- package/build/components/link-control/search-results.js.map +1 -1
- package/build/components/list-view/block-contents.js +2 -2
- package/build/components/list-view/block-contents.js.map +1 -1
- package/build/components/list-view/block-select-button.js +15 -172
- package/build/components/list-view/block-select-button.js.map +1 -1
- package/build/components/list-view/block.js +196 -21
- package/build/components/list-view/block.js.map +1 -1
- package/build/components/list-view/drop-indicator.js +3 -3
- package/build/components/list-view/drop-indicator.js.map +1 -1
- package/build/components/list-view/index.js +3 -3
- package/build/components/list-view/index.js.map +1 -1
- package/build/components/list-view/leaf.js +2 -2
- package/build/components/list-view/leaf.js.map +1 -1
- package/build/components/list-view/use-list-view-drop-zone.js +1 -1
- package/build/components/list-view/use-list-view-drop-zone.js.map +1 -1
- package/build/components/list-view/utils.js +3 -1
- package/build/components/list-view/utils.js.map +1 -1
- package/build/components/media-placeholder/index.js +7 -7
- package/build/components/media-placeholder/index.js.map +1 -1
- package/build/components/media-replace-flow/index.js +2 -2
- package/build/components/media-replace-flow/index.js.map +1 -1
- package/build/components/navigable-toolbar/index.js +3 -1
- package/build/components/navigable-toolbar/index.js.map +1 -1
- package/build/components/plain-text/index.js +2 -2
- package/build/components/plain-text/index.js.map +1 -1
- package/build/components/provider/block-refs-provider.js +3 -4
- package/build/components/provider/block-refs-provider.js.map +1 -1
- package/build/components/provider/use-block-sync.js +10 -1
- package/build/components/provider/use-block-sync.js.map +1 -1
- package/build/components/responsive-block-control/index.js +2 -2
- package/build/components/responsive-block-control/index.js.map +1 -1
- package/build/components/rich-text/event-listeners/before-input-rules.js +93 -0
- package/build/components/rich-text/event-listeners/before-input-rules.js.map +1 -0
- package/build/components/rich-text/event-listeners/delete.js +58 -0
- package/build/components/rich-text/event-listeners/delete.js.map +1 -0
- package/build/components/rich-text/event-listeners/enter.js +89 -0
- package/build/components/rich-text/event-listeners/enter.js.map +1 -0
- package/build/components/rich-text/event-listeners/firefox-compat.js +36 -0
- package/build/components/rich-text/event-listeners/firefox-compat.js.map +1 -0
- package/build/components/rich-text/event-listeners/index.js +44 -0
- package/build/components/rich-text/event-listeners/index.js.map +1 -0
- package/build/components/rich-text/event-listeners/input-events.js +22 -0
- package/build/components/rich-text/event-listeners/input-events.js.map +1 -0
- package/build/components/rich-text/event-listeners/input-rules.js +135 -0
- package/build/components/rich-text/event-listeners/input-rules.js.map +1 -0
- package/build/components/rich-text/event-listeners/insert-replacement-text.js +33 -0
- package/build/components/rich-text/event-listeners/insert-replacement-text.js.map +1 -0
- package/build/components/rich-text/event-listeners/paste-handler.js +126 -0
- package/build/components/rich-text/event-listeners/paste-handler.js.map +1 -0
- package/build/components/rich-text/event-listeners/remove-browser-shortcuts.js +27 -0
- package/build/components/rich-text/event-listeners/remove-browser-shortcuts.js.map +1 -0
- package/build/components/rich-text/event-listeners/shortcuts.js +22 -0
- package/build/components/rich-text/event-listeners/shortcuts.js.map +1 -0
- package/build/components/rich-text/event-listeners/undo-automatic-change.js +51 -0
- package/build/components/rich-text/event-listeners/undo-automatic-change.js.map +1 -0
- package/build/components/rich-text/format-toolbar/index.js +2 -2
- package/build/components/rich-text/format-toolbar/index.js.map +1 -1
- package/build/components/rich-text/index.js +20 -33
- package/build/components/rich-text/index.js.map +1 -1
- package/build/components/rich-text/index.native.js +15 -5
- package/build/components/rich-text/index.native.js.map +1 -1
- package/build/components/rich-text/multiline.js +36 -4
- package/build/components/rich-text/multiline.js.map +1 -1
- package/build/components/rich-text/native/index.native.js +12 -0
- package/build/components/rich-text/native/index.native.js.map +1 -1
- package/build/components/rich-text/use-format-types.js +8 -4
- package/build/components/rich-text/use-format-types.js.map +1 -1
- package/build/components/segmented-text-control/index.js +62 -0
- package/build/components/segmented-text-control/index.js.map +1 -0
- package/build/components/spacing-sizes-control/input-controls/spacing-input-control.js +16 -2
- package/build/components/spacing-sizes-control/input-controls/spacing-input-control.js.map +1 -1
- package/build/components/text-alignment-control/index.js +76 -0
- package/build/components/text-alignment-control/index.js.map +1 -0
- package/build/components/text-decoration-control/index.js +22 -26
- package/build/components/text-decoration-control/index.js.map +1 -1
- package/build/components/text-transform-control/index.js +19 -23
- package/build/components/text-transform-control/index.js.map +1 -1
- package/build/components/url-input/index.js +4 -4
- package/build/components/url-input/index.js.map +1 -1
- package/build/components/url-popover/link-editor.js +2 -2
- package/build/components/url-popover/link-editor.js.map +1 -1
- package/build/components/url-popover/link-viewer-url.js +2 -2
- package/build/components/url-popover/link-viewer-url.js.map +1 -1
- package/build/components/url-popover/link-viewer.js +2 -2
- package/build/components/url-popover/link-viewer.js.map +1 -1
- package/build/components/use-block-display-information/index.js +9 -3
- package/build/components/use-block-display-information/index.js.map +1 -1
- package/build/components/use-on-block-drop/index.js +3 -1
- package/build/components/use-on-block-drop/index.js.map +1 -1
- package/build/components/warning/index.js +2 -2
- package/build/components/warning/index.js.map +1 -1
- package/build/components/writing-flow/index.js +2 -2
- package/build/components/writing-flow/index.js.map +1 -1
- package/build/components/writing-flow/use-clipboard-handler.js +77 -30
- package/build/components/writing-flow/use-clipboard-handler.js.map +1 -1
- package/build/components/writing-flow/use-drag-selection.js +3 -1
- package/build/components/writing-flow/use-drag-selection.js.map +1 -1
- package/build/components/writing-flow/use-input.js +44 -2
- package/build/components/writing-flow/use-input.js.map +1 -1
- package/build/components/writing-flow/use-tab-nav.js +9 -2
- package/build/components/writing-flow/use-tab-nav.js.map +1 -1
- package/build/components/writing-mode-control/index.js +17 -21
- package/build/components/writing-mode-control/index.js.map +1 -1
- package/build/hooks/align.js +2 -2
- package/build/hooks/align.js.map +1 -1
- package/build/hooks/background.js +1 -1
- package/build/hooks/background.js.map +1 -1
- package/build/hooks/border.js +3 -3
- package/build/hooks/border.js.map +1 -1
- package/build/hooks/color.js +3 -3
- package/build/hooks/color.js.map +1 -1
- package/build/hooks/content-lock-ui.js +5 -28
- package/build/hooks/content-lock-ui.js.map +1 -1
- package/build/hooks/custom-class-name.js +2 -2
- package/build/hooks/custom-class-name.js.map +1 -1
- package/build/hooks/custom-class-name.native.js +2 -2
- package/build/hooks/custom-class-name.native.js.map +1 -1
- package/build/hooks/dimensions.js +2 -2
- package/build/hooks/dimensions.js.map +1 -1
- package/build/hooks/duotone.js +3 -1
- package/build/hooks/duotone.js.map +1 -1
- package/build/hooks/layout-child.js +16 -8
- package/build/hooks/layout-child.js.map +1 -1
- package/build/hooks/layout.js +2 -2
- package/build/hooks/layout.js.map +1 -1
- package/build/hooks/position.js +2 -2
- package/build/hooks/position.js.map +1 -1
- package/build/hooks/text-align.js +3 -3
- package/build/hooks/text-align.js.map +1 -1
- package/build/hooks/use-bindings-attributes.js +39 -13
- package/build/hooks/use-bindings-attributes.js.map +1 -1
- package/build/hooks/use-color-props.js +2 -2
- package/build/hooks/use-color-props.js.map +1 -1
- package/build/hooks/use-typography-props.js +2 -2
- package/build/hooks/use-typography-props.js.map +1 -1
- package/build/hooks/utils.js +13 -8
- package/build/hooks/utils.js.map +1 -1
- package/build/layouts/grid.js +7 -6
- package/build/layouts/grid.js.map +1 -1
- package/build/private-apis.js +8 -3
- package/build/private-apis.js.map +1 -1
- package/build/store/actions.js +143 -25
- package/build/store/actions.js.map +1 -1
- package/build/store/private-actions.js +26 -1
- package/build/store/private-actions.js.map +1 -1
- package/build/store/private-keys.js +2 -1
- package/build/store/private-keys.js.map +1 -1
- package/build/store/private-selectors.js +33 -6
- package/build/store/private-selectors.js.map +1 -1
- package/build/store/reducer.js +11 -8
- package/build/store/reducer.js.map +1 -1
- package/build/store/selectors.js +25 -8
- package/build/store/selectors.js.map +1 -1
- package/build/utils/object.js +17 -0
- package/build/utils/object.js.map +1 -1
- package/build/utils/order-inserter-block-items.js +6 -2
- package/build/utils/order-inserter-block-items.js.map +1 -1
- package/build/utils/pasting.js +6 -2
- package/build/utils/pasting.js.map +1 -1
- package/build/utils/selection.js +8 -0
- package/build/utils/selection.js.map +1 -1
- package/build/utils/transform-styles/index.js +12 -7
- package/build/utils/transform-styles/index.js.map +1 -1
- package/build-module/components/alignment-control/ui.js +3 -1
- package/build-module/components/alignment-control/ui.js.map +1 -1
- package/build-module/components/block-actions/index.js +4 -2
- package/build-module/components/block-actions/index.js.map +1 -1
- package/build-module/components/block-alignment-control/ui.js +2 -2
- package/build-module/components/block-alignment-control/ui.js.map +1 -1
- package/build-module/components/block-card/index.js +2 -2
- package/build-module/components/block-card/index.js.map +1 -1
- package/build-module/components/block-compare/index.js +2 -2
- package/build-module/components/block-compare/index.js.map +1 -1
- package/build-module/components/block-edit/edit.js +2 -2
- package/build-module/components/block-edit/edit.js.map +1 -1
- package/build-module/components/block-icon/index.js +2 -2
- package/build-module/components/block-icon/index.js.map +1 -1
- package/build-module/components/block-list/block.js +4 -13
- package/build-module/components/block-list/block.js.map +1 -1
- package/build-module/components/block-list/block.native.js +2 -2
- package/build-module/components/block-list/block.native.js.map +1 -1
- package/build-module/components/block-list/index.js +6 -5
- package/build-module/components/block-list/index.js.map +1 -1
- package/build-module/components/block-list/index.native.js +1 -9
- package/build-module/components/block-list/index.native.js.map +1 -1
- package/build-module/components/block-list/use-block-props/index.js +11 -8
- package/build-module/components/block-list/use-block-props/index.js.map +1 -1
- package/build-module/components/block-list/use-block-props/use-block-refs.js +19 -48
- package/build-module/components/block-list/use-block-props/use-block-refs.js.map +1 -1
- package/build-module/components/block-list/use-block-props/use-is-hovered.js +10 -14
- package/build-module/components/block-list/use-block-props/use-is-hovered.js.map +1 -1
- package/build-module/components/block-list/use-block-props/use-scroll-into-view.js +37 -0
- package/build-module/components/block-list/use-block-props/use-scroll-into-view.js.map +1 -0
- package/build-module/components/block-list-appender/index.js +2 -2
- package/build-module/components/block-list-appender/index.js.map +1 -1
- package/build-module/components/block-mover/button.js +2 -2
- package/build-module/components/block-mover/button.js.map +1 -1
- package/build-module/components/block-mover/index.js +2 -2
- package/build-module/components/block-mover/index.js.map +1 -1
- package/build-module/components/block-mover/index.native.js +3 -1
- package/build-module/components/block-mover/index.native.js.map +1 -1
- package/build-module/components/block-patterns-list/index.js +27 -6
- package/build-module/components/block-patterns-list/index.js.map +1 -1
- package/build-module/components/block-popover/cover.js +9 -5
- package/build-module/components/block-popover/cover.js.map +1 -1
- package/build-module/components/block-popover/inbetween.js +2 -2
- package/build-module/components/block-popover/inbetween.js.map +1 -1
- package/build-module/components/block-popover/index.js +21 -3
- package/build-module/components/block-popover/index.js.map +1 -1
- package/build-module/components/block-preview/index.js +2 -2
- package/build-module/components/block-preview/index.js.map +1 -1
- package/build-module/components/block-settings-menu/block-settings-dropdown.js +9 -31
- package/build-module/components/block-settings-menu/block-settings-dropdown.js.map +1 -1
- package/build-module/components/block-settings-menu-controls/index.js +10 -7
- package/build-module/components/block-settings-menu-controls/index.js.map +1 -1
- package/build-module/components/block-styles/index.js +2 -2
- package/build-module/components/block-styles/index.js.map +1 -1
- package/build-module/components/block-switcher/pattern-transformations-menu.js +3 -1
- package/build-module/components/block-switcher/pattern-transformations-menu.js.map +1 -1
- package/build-module/components/block-switcher/use-transformed-patterns.js +6 -2
- package/build-module/components/block-switcher/use-transformed-patterns.js.map +1 -1
- package/build-module/components/block-switcher/utils.js +15 -5
- package/build-module/components/block-switcher/utils.js.map +1 -1
- package/build-module/components/block-toolbar/index.js +3 -3
- package/build-module/components/block-toolbar/index.js.map +1 -1
- package/build-module/components/block-toolbar/use-has-block-toolbar.js +14 -9
- package/build-module/components/block-toolbar/use-has-block-toolbar.js.map +1 -1
- package/build-module/components/block-tools/block-selection-button.js +2 -2
- package/build-module/components/block-tools/block-selection-button.js.map +1 -1
- package/build-module/components/block-tools/block-toolbar-breadcrumb.js +4 -4
- package/build-module/components/block-tools/block-toolbar-breadcrumb.js.map +1 -1
- package/build-module/components/block-tools/block-toolbar-popover.js +2 -2
- package/build-module/components/block-tools/block-toolbar-popover.js.map +1 -1
- package/build-module/components/block-tools/empty-block-inserter.js +2 -2
- package/build-module/components/block-tools/empty-block-inserter.js.map +1 -1
- package/build-module/components/block-tools/index.js +23 -2
- package/build-module/components/block-tools/index.js.map +1 -1
- package/build-module/components/block-tools/insertion-point.js +4 -4
- package/build-module/components/block-tools/insertion-point.js.map +1 -1
- package/build-module/components/block-tools/use-show-block-tools.js +2 -5
- package/build-module/components/block-tools/use-show-block-tools.js.map +1 -1
- package/build-module/components/block-tools/zoom-out-mode-inserters.js +69 -21
- package/build-module/components/block-tools/zoom-out-mode-inserters.js.map +1 -1
- package/build-module/components/block-variation-picker/index.js +5 -4
- package/build-module/components/block-variation-picker/index.js.map +1 -1
- package/build-module/components/block-variation-transforms/index.js +3 -1
- package/build-module/components/block-variation-transforms/index.js.map +1 -1
- package/build-module/components/button-block-appender/index.js +2 -2
- package/build-module/components/button-block-appender/index.js.map +1 -1
- package/build-module/components/child-layout-control/index.js +2 -2
- package/build-module/components/child-layout-control/index.js.map +1 -1
- package/build-module/components/colors-gradients/control.js +3 -3
- package/build-module/components/colors-gradients/control.js.map +1 -1
- package/build-module/components/colors-gradients/dropdown.js +2 -2
- package/build-module/components/colors-gradients/dropdown.js.map +1 -1
- package/build-module/components/colors-gradients/panel-color-gradient-settings.js +2 -2
- package/build-module/components/colors-gradients/panel-color-gradient-settings.js.map +1 -1
- package/build-module/components/convert-to-group-buttons/index.js +7 -1
- package/build-module/components/convert-to-group-buttons/index.js.map +1 -1
- package/build-module/components/default-block-appender/index.js +2 -2
- package/build-module/components/default-block-appender/index.js.map +1 -1
- package/build-module/components/dimensions-tool/aspect-ratio-tool.js +30 -36
- package/build-module/components/dimensions-tool/aspect-ratio-tool.js.map +1 -1
- package/build-module/components/floating-toolbar/index.native.js +9 -5
- package/build-module/components/floating-toolbar/index.native.js.map +1 -1
- package/build-module/components/global-styles/background-panel.js +4 -4
- package/build-module/components/global-styles/background-panel.js.map +1 -1
- package/build-module/components/global-styles/color-panel.js +6 -4
- package/build-module/components/global-styles/color-panel.js.map +1 -1
- package/build-module/components/global-styles/dimensions-panel.js +21 -5
- package/build-module/components/global-styles/dimensions-panel.js.map +1 -1
- package/build-module/components/global-styles/filters-panel.js +2 -2
- package/build-module/components/global-styles/filters-panel.js.map +1 -1
- package/build-module/components/global-styles/hooks.js +3 -2
- package/build-module/components/global-styles/hooks.js.map +1 -1
- package/build-module/components/global-styles/shadow-panel-components.js +4 -4
- package/build-module/components/global-styles/shadow-panel-components.js.map +1 -1
- package/build-module/components/global-styles/typography-panel.js +24 -24
- package/build-module/components/global-styles/typography-panel.js.map +1 -1
- package/build-module/components/global-styles/use-global-styles-output.js +149 -132
- package/build-module/components/global-styles/use-global-styles-output.js.map +1 -1
- package/build-module/components/global-styles/utils.js +44 -0
- package/build-module/components/global-styles/utils.js.map +1 -1
- package/build-module/components/grid-visualizer/grid-item-resizer.js +141 -24
- package/build-module/components/grid-visualizer/grid-item-resizer.js.map +1 -1
- package/build-module/components/grid-visualizer/grid-visualizer.js +12 -6
- package/build-module/components/grid-visualizer/grid-visualizer.js.map +1 -1
- package/build-module/components/iframe/index.js +70 -31
- package/build-module/components/iframe/index.js.map +1 -1
- package/build-module/components/image-editor/aspect-ratio-dropdown.js +52 -36
- package/build-module/components/image-editor/aspect-ratio-dropdown.js.map +1 -1
- package/build-module/components/image-editor/cropper.js +2 -2
- package/build-module/components/image-editor/cropper.js.map +1 -1
- package/build-module/components/image-editor/index.js +1 -1
- package/build-module/components/image-editor/index.js.map +1 -1
- package/build-module/components/index.js +1 -0
- package/build-module/components/index.js.map +1 -1
- package/build-module/components/inner-blocks/button-block-appender.js +2 -2
- package/build-module/components/inner-blocks/button-block-appender.js.map +1 -1
- package/build-module/components/inner-blocks/index.js +25 -10
- package/build-module/components/inner-blocks/index.js.map +1 -1
- package/build-module/components/inserter/block-patterns-explorer/pattern-list.js +1 -1
- package/build-module/components/inserter/block-patterns-explorer/pattern-list.js.map +1 -1
- package/build-module/components/inserter/block-patterns-tab/index.js +21 -31
- package/build-module/components/inserter/block-patterns-tab/index.js.map +1 -1
- package/build-module/components/inserter/block-patterns-tab/pattern-category-previews.js +1 -1
- package/build-module/components/inserter/block-patterns-tab/pattern-category-previews.js.map +1 -1
- package/build-module/components/inserter/block-types-tab.js +10 -4
- package/build-module/components/inserter/block-types-tab.js.map +1 -1
- package/build-module/components/inserter/category-tabs/index.js +49 -0
- package/build-module/components/inserter/category-tabs/index.js.map +1 -0
- package/build-module/components/inserter/hooks/use-insertion-point.js +11 -2
- package/build-module/components/inserter/hooks/use-insertion-point.js.map +1 -1
- package/build-module/components/inserter/hooks/use-patterns-state.js +12 -5
- package/build-module/components/inserter/hooks/use-patterns-state.js.map +1 -1
- package/build-module/components/inserter/index.js +2 -2
- package/build-module/components/inserter/index.js.map +1 -1
- package/build-module/components/inserter/library.js +8 -2
- package/build-module/components/inserter/library.js.map +1 -1
- package/build-module/components/inserter/media-tab/index.js +1 -1
- package/build-module/components/inserter/media-tab/index.js.map +1 -1
- package/build-module/components/inserter/media-tab/media-panel.js +0 -24
- package/build-module/components/inserter/media-tab/media-panel.js.map +1 -1
- package/build-module/components/inserter/media-tab/media-preview.js +15 -5
- package/build-module/components/inserter/media-tab/media-preview.js.map +1 -1
- package/build-module/components/inserter/media-tab/media-tab.js +17 -31
- package/build-module/components/inserter/media-tab/media-tab.js.map +1 -1
- package/build-module/components/inserter/menu.js +117 -111
- package/build-module/components/inserter/menu.js.map +1 -1
- package/build-module/components/inserter/quick-inserter.js +2 -2
- package/build-module/components/inserter/quick-inserter.js.map +1 -1
- package/build-module/components/inserter/tabs.js +24 -12
- package/build-module/components/inserter/tabs.js.map +1 -1
- package/build-module/components/inserter-list-item/index.js +3 -3
- package/build-module/components/inserter-list-item/index.js.map +1 -1
- package/build-module/components/keyboard-shortcuts/index.js +9 -0
- package/build-module/components/keyboard-shortcuts/index.js.map +1 -1
- package/build-module/components/line-height-control/index.js +6 -2
- package/build-module/components/line-height-control/index.js.map +1 -1
- package/build-module/components/link-control/index.js +2 -2
- package/build-module/components/link-control/index.js.map +1 -1
- package/build-module/components/link-control/link-preview.js +3 -3
- package/build-module/components/link-control/link-preview.js.map +1 -1
- package/build-module/components/link-control/search-item.js +9 -3
- package/build-module/components/link-control/search-item.js.map +1 -1
- package/build-module/components/link-control/search-results.js +2 -2
- package/build-module/components/link-control/search-results.js.map +1 -1
- package/build-module/components/list-view/block-contents.js +2 -2
- package/build-module/components/list-view/block-contents.js.map +1 -1
- package/build-module/components/list-view/block-select-button.js +17 -174
- package/build-module/components/list-view/block-select-button.js.map +1 -1
- package/build-module/components/list-view/block.js +198 -23
- package/build-module/components/list-view/block.js.map +1 -1
- package/build-module/components/list-view/drop-indicator.js +3 -3
- package/build-module/components/list-view/drop-indicator.js.map +1 -1
- package/build-module/components/list-view/index.js +3 -3
- package/build-module/components/list-view/index.js.map +1 -1
- package/build-module/components/list-view/leaf.js +2 -2
- package/build-module/components/list-view/leaf.js.map +1 -1
- package/build-module/components/list-view/use-list-view-drop-zone.js +1 -1
- package/build-module/components/list-view/use-list-view-drop-zone.js.map +1 -1
- package/build-module/components/list-view/utils.js +3 -1
- package/build-module/components/list-view/utils.js.map +1 -1
- package/build-module/components/media-placeholder/index.js +7 -7
- package/build-module/components/media-placeholder/index.js.map +1 -1
- package/build-module/components/media-replace-flow/index.js +2 -2
- package/build-module/components/media-replace-flow/index.js.map +1 -1
- package/build-module/components/navigable-toolbar/index.js +3 -1
- package/build-module/components/navigable-toolbar/index.js.map +1 -1
- package/build-module/components/plain-text/index.js +2 -2
- package/build-module/components/plain-text/index.js.map +1 -1
- package/build-module/components/provider/block-refs-provider.js +3 -4
- package/build-module/components/provider/block-refs-provider.js.map +1 -1
- package/build-module/components/provider/use-block-sync.js +10 -1
- package/build-module/components/provider/use-block-sync.js.map +1 -1
- package/build-module/components/responsive-block-control/index.js +2 -2
- package/build-module/components/responsive-block-control/index.js.map +1 -1
- package/build-module/components/rich-text/event-listeners/before-input-rules.js +86 -0
- package/build-module/components/rich-text/event-listeners/before-input-rules.js.map +1 -0
- package/build-module/components/rich-text/event-listeners/delete.js +51 -0
- package/build-module/components/rich-text/event-listeners/delete.js.map +1 -0
- package/build-module/components/rich-text/event-listeners/enter.js +82 -0
- package/build-module/components/rich-text/event-listeners/enter.js.map +1 -0
- package/build-module/components/rich-text/event-listeners/firefox-compat.js +29 -0
- package/build-module/components/rich-text/event-listeners/firefox-compat.js.map +1 -0
- package/build-module/components/rich-text/event-listeners/index.js +36 -0
- package/build-module/components/rich-text/event-listeners/index.js.map +1 -0
- package/build-module/components/rich-text/event-listeners/input-events.js +15 -0
- package/build-module/components/rich-text/event-listeners/input-events.js.map +1 -0
- package/build-module/components/rich-text/event-listeners/input-rules.js +127 -0
- package/build-module/components/rich-text/event-listeners/input-rules.js.map +1 -0
- package/build-module/components/rich-text/event-listeners/insert-replacement-text.js +27 -0
- package/build-module/components/rich-text/event-listeners/insert-replacement-text.js.map +1 -0
- package/build-module/components/rich-text/event-listeners/paste-handler.js +122 -0
- package/build-module/components/rich-text/event-listeners/paste-handler.js.map +1 -0
- package/build-module/components/rich-text/event-listeners/remove-browser-shortcuts.js +21 -0
- package/build-module/components/rich-text/event-listeners/remove-browser-shortcuts.js.map +1 -0
- package/build-module/components/rich-text/event-listeners/shortcuts.js +15 -0
- package/build-module/components/rich-text/event-listeners/shortcuts.js.map +1 -0
- package/build-module/components/rich-text/event-listeners/undo-automatic-change.js +45 -0
- package/build-module/components/rich-text/event-listeners/undo-automatic-change.js.map +1 -0
- package/build-module/components/rich-text/format-toolbar/index.js +2 -2
- package/build-module/components/rich-text/format-toolbar/index.js.map +1 -1
- package/build-module/components/rich-text/index.js +21 -34
- package/build-module/components/rich-text/index.js.map +1 -1
- package/build-module/components/rich-text/index.native.js +15 -5
- package/build-module/components/rich-text/index.native.js.map +1 -1
- package/build-module/components/rich-text/multiline.js +37 -5
- package/build-module/components/rich-text/multiline.js.map +1 -1
- package/build-module/components/rich-text/native/index.native.js +12 -0
- package/build-module/components/rich-text/native/index.native.js.map +1 -1
- package/build-module/components/rich-text/use-format-types.js +8 -4
- package/build-module/components/rich-text/use-format-types.js.map +1 -1
- package/build-module/components/segmented-text-control/index.js +55 -0
- package/build-module/components/segmented-text-control/index.js.map +1 -0
- package/build-module/components/spacing-sizes-control/input-controls/spacing-input-control.js +16 -2
- package/build-module/components/spacing-sizes-control/input-controls/spacing-input-control.js.map +1 -1
- package/build-module/components/text-alignment-control/index.js +68 -0
- package/build-module/components/text-alignment-control/index.js.map +1 -0
- package/build-module/components/text-decoration-control/index.js +22 -26
- package/build-module/components/text-decoration-control/index.js.map +1 -1
- package/build-module/components/text-transform-control/index.js +19 -23
- package/build-module/components/text-transform-control/index.js.map +1 -1
- package/build-module/components/url-input/index.js +4 -4
- package/build-module/components/url-input/index.js.map +1 -1
- package/build-module/components/url-popover/link-editor.js +2 -2
- package/build-module/components/url-popover/link-editor.js.map +1 -1
- package/build-module/components/url-popover/link-viewer-url.js +2 -2
- package/build-module/components/url-popover/link-viewer-url.js.map +1 -1
- package/build-module/components/url-popover/link-viewer.js +2 -2
- package/build-module/components/url-popover/link-viewer.js.map +1 -1
- package/build-module/components/use-block-display-information/index.js +9 -3
- package/build-module/components/use-block-display-information/index.js.map +1 -1
- package/build-module/components/use-on-block-drop/index.js +3 -1
- package/build-module/components/use-on-block-drop/index.js.map +1 -1
- package/build-module/components/warning/index.js +2 -2
- package/build-module/components/warning/index.js.map +1 -1
- package/build-module/components/writing-flow/index.js +2 -2
- package/build-module/components/writing-flow/index.js.map +1 -1
- package/build-module/components/writing-flow/use-clipboard-handler.js +78 -31
- package/build-module/components/writing-flow/use-clipboard-handler.js.map +1 -1
- package/build-module/components/writing-flow/use-drag-selection.js +3 -1
- package/build-module/components/writing-flow/use-drag-selection.js.map +1 -1
- package/build-module/components/writing-flow/use-input.js +45 -3
- package/build-module/components/writing-flow/use-input.js.map +1 -1
- package/build-module/components/writing-flow/use-tab-nav.js +9 -2
- package/build-module/components/writing-flow/use-tab-nav.js.map +1 -1
- package/build-module/components/writing-mode-control/index.js +17 -21
- package/build-module/components/writing-mode-control/index.js.map +1 -1
- package/build-module/hooks/align.js +2 -2
- package/build-module/hooks/align.js.map +1 -1
- package/build-module/hooks/background.js +1 -1
- package/build-module/hooks/background.js.map +1 -1
- package/build-module/hooks/border.js +3 -3
- package/build-module/hooks/border.js.map +1 -1
- package/build-module/hooks/color.js +3 -3
- package/build-module/hooks/color.js.map +1 -1
- package/build-module/hooks/content-lock-ui.js +5 -28
- package/build-module/hooks/content-lock-ui.js.map +1 -1
- package/build-module/hooks/custom-class-name.js +2 -2
- package/build-module/hooks/custom-class-name.js.map +1 -1
- package/build-module/hooks/custom-class-name.native.js +2 -2
- package/build-module/hooks/custom-class-name.native.js.map +1 -1
- package/build-module/hooks/dimensions.js +2 -2
- package/build-module/hooks/dimensions.js.map +1 -1
- package/build-module/hooks/duotone.js +3 -1
- package/build-module/hooks/duotone.js.map +1 -1
- package/build-module/hooks/layout-child.js +16 -8
- package/build-module/hooks/layout-child.js.map +1 -1
- package/build-module/hooks/layout.js +2 -2
- package/build-module/hooks/layout.js.map +1 -1
- package/build-module/hooks/position.js +2 -2
- package/build-module/hooks/position.js.map +1 -1
- package/build-module/hooks/text-align.js +3 -3
- package/build-module/hooks/text-align.js.map +1 -1
- package/build-module/hooks/use-bindings-attributes.js +39 -13
- package/build-module/hooks/use-bindings-attributes.js.map +1 -1
- package/build-module/hooks/use-color-props.js +2 -2
- package/build-module/hooks/use-color-props.js.map +1 -1
- package/build-module/hooks/use-typography-props.js +2 -2
- package/build-module/hooks/use-typography-props.js.map +1 -1
- package/build-module/hooks/utils.js +13 -8
- package/build-module/hooks/utils.js.map +1 -1
- package/build-module/layouts/grid.js +7 -6
- package/build-module/layouts/grid.js.map +1 -1
- package/build-module/private-apis.js +9 -4
- package/build-module/private-apis.js.map +1 -1
- package/build-module/store/actions.js +145 -27
- package/build-module/store/actions.js.map +1 -1
- package/build-module/store/private-actions.js +24 -0
- package/build-module/store/private-actions.js.map +1 -1
- package/build-module/store/private-keys.js +1 -0
- package/build-module/store/private-keys.js.map +1 -1
- package/build-module/store/private-selectors.js +32 -5
- package/build-module/store/private-selectors.js.map +1 -1
- package/build-module/store/reducer.js +11 -8
- package/build-module/store/reducer.js.map +1 -1
- package/build-module/store/selectors.js +25 -8
- package/build-module/store/selectors.js.map +1 -1
- package/build-module/utils/object.js +16 -0
- package/build-module/utils/object.js.map +1 -1
- package/build-module/utils/order-inserter-block-items.js +6 -2
- package/build-module/utils/order-inserter-block-items.js.map +1 -1
- package/build-module/utils/pasting.js +6 -2
- package/build-module/utils/pasting.js.map +1 -1
- package/build-module/utils/selection.js +7 -0
- package/build-module/utils/selection.js.map +1 -1
- package/build-module/utils/transform-styles/index.js +12 -7
- package/build-module/utils/transform-styles/index.js.map +1 -1
- package/build-style/content-rtl.css +124 -158
- package/build-style/content.css +124 -158
- package/build-style/style-rtl.css +114 -203
- package/build-style/style.css +114 -203
- package/build-types/components/block-context/index.d.ts +1 -1
- package/build-types/components/block-context/index.d.ts.map +1 -1
- package/package.json +32 -32
- package/src/components/alignment-control/ui.js +3 -1
- package/src/components/block-actions/index.js +5 -1
- package/src/components/block-alignment-control/ui.js +2 -2
- package/src/components/block-bindings-toolbar-indicator/style.scss +1 -4
- package/src/components/block-canvas/style.scss +1 -3
- package/src/components/block-card/index.js +2 -2
- package/src/components/block-compare/index.js +2 -2
- package/src/components/block-content-overlay/content.scss +4 -37
- package/src/components/block-edit/edit.js +2 -2
- package/src/components/block-icon/index.js +2 -2
- package/src/components/block-list/block.js +6 -17
- package/src/components/block-list/block.native.js +2 -2
- package/src/components/block-list/content.scss +53 -72
- package/src/components/block-list/index.js +6 -6
- package/src/components/block-list/index.native.js +1 -6
- package/src/components/block-list/use-block-props/index.js +16 -6
- package/src/components/block-list/use-block-props/use-block-refs.js +17 -57
- package/src/components/block-list/use-block-props/use-is-hovered.js +11 -16
- package/src/components/block-list/use-block-props/use-scroll-into-view.js +38 -0
- package/src/components/block-list-appender/index.js +2 -2
- package/src/components/block-mover/button.js +2 -2
- package/src/components/block-mover/index.js +2 -2
- package/src/components/block-mover/index.native.js +3 -1
- package/src/components/block-patterns-list/index.js +29 -4
- package/src/components/block-patterns-list/style.scss +1 -3
- package/src/components/block-popover/README.md +1 -1
- package/src/components/block-popover/cover.js +22 -7
- package/src/components/block-popover/inbetween.js +2 -2
- package/src/components/block-popover/index.js +24 -6
- package/src/components/block-preview/index.js +2 -2
- package/src/components/block-preview/style.scss +13 -15
- package/src/components/block-settings-menu/block-settings-dropdown.js +15 -57
- package/src/components/block-settings-menu-controls/index.js +25 -16
- package/src/components/block-styles/index.js +2 -2
- package/src/components/block-switcher/pattern-transformations-menu.js +3 -1
- package/src/components/block-switcher/use-transformed-patterns.js +6 -2
- package/src/components/block-switcher/utils.js +14 -5
- package/src/components/block-toolbar/index.js +3 -3
- package/src/components/block-toolbar/style.scss +8 -11
- package/src/components/block-toolbar/use-has-block-toolbar.js +21 -16
- package/src/components/block-tools/block-selection-button.js +2 -2
- package/src/components/block-tools/block-toolbar-breadcrumb.js +5 -5
- package/src/components/block-tools/block-toolbar-popover.js +4 -7
- package/src/components/block-tools/empty-block-inserter.js +2 -2
- package/src/components/block-tools/index.js +27 -4
- package/src/components/block-tools/insertion-point.js +4 -4
- package/src/components/block-tools/style.scss +8 -0
- package/src/components/block-tools/use-show-block-tools.js +36 -48
- package/src/components/block-tools/zoom-out-mode-inserters.js +74 -18
- package/src/components/block-variation-picker/content.scss +22 -72
- package/src/components/block-variation-picker/index.js +5 -4
- package/src/components/block-variation-transforms/index.js +3 -1
- package/src/components/button-block-appender/index.js +2 -2
- package/src/components/child-layout-control/index.js +14 -2
- package/src/components/colors-gradients/control.js +3 -3
- package/src/components/colors-gradients/dropdown.js +2 -2
- package/src/components/colors-gradients/panel-color-gradient-settings.js +2 -2
- package/src/components/colors-gradients/test/control.js +3 -3
- package/src/components/convert-to-group-buttons/index.js +10 -1
- package/src/components/default-block-appender/index.js +2 -2
- package/src/components/dimensions-tool/aspect-ratio-tool.js +40 -67
- package/src/components/dimensions-tool/test/index.js +10 -0
- package/src/components/editable-text/README.md +0 -4
- package/src/components/floating-toolbar/index.native.js +5 -2
- package/src/components/global-styles/background-panel.js +4 -6
- package/src/components/global-styles/color-panel.js +6 -4
- package/src/components/global-styles/dimensions-panel.js +22 -5
- package/src/components/global-styles/filters-panel.js +2 -2
- package/src/components/global-styles/hooks.js +2 -0
- package/src/components/global-styles/shadow-panel-components.js +6 -9
- package/src/components/global-styles/test/get-global-styles-changes.js +0 -2
- package/src/components/global-styles/test/use-global-styles-output.js +5 -5
- package/src/components/global-styles/test/utils.js +21 -0
- package/src/components/global-styles/typography-panel.js +27 -23
- package/src/components/global-styles/use-global-styles-output.js +211 -187
- package/src/components/global-styles/utils.js +55 -0
- package/src/components/grid-visualizer/grid-item-resizer.js +169 -40
- package/src/components/grid-visualizer/grid-visualizer.js +19 -6
- package/src/components/iframe/content.scss +63 -0
- package/src/components/iframe/index.js +119 -39
- package/src/components/image-editor/aspect-ratio-dropdown.js +91 -59
- package/src/components/image-editor/cropper.js +2 -2
- package/src/components/image-editor/index.js +1 -1
- package/src/components/image-editor/test/index.js +22 -0
- package/src/components/index.js +1 -0
- package/src/components/inner-blocks/button-block-appender.js +2 -2
- package/src/components/inner-blocks/index.js +24 -9
- package/src/components/inserter/block-patterns-explorer/pattern-list.js +2 -1
- package/src/components/inserter/block-patterns-tab/index.js +30 -64
- package/src/components/inserter/block-patterns-tab/pattern-category-previews.js +2 -1
- package/src/components/inserter/block-types-tab.js +12 -9
- package/src/components/inserter/category-tabs/index.js +74 -0
- package/src/components/inserter/hooks/use-insertion-point.js +15 -1
- package/src/components/inserter/hooks/use-patterns-state.js +18 -5
- package/src/components/inserter/index.js +4 -5
- package/src/components/inserter/library.js +6 -0
- package/src/components/inserter/media-tab/index.js +1 -1
- package/src/components/inserter/media-tab/media-panel.js +0 -22
- package/src/components/inserter/media-tab/media-preview.js +17 -9
- package/src/components/inserter/media-tab/media-tab.js +44 -83
- package/src/components/inserter/menu.js +168 -140
- package/src/components/inserter/quick-inserter.js +2 -2
- package/src/components/inserter/style.scss +96 -178
- package/src/components/inserter/tabs.js +33 -27
- package/src/components/inserter-list-item/index.js +3 -3
- package/src/components/keyboard-shortcuts/index.js +12 -0
- package/src/components/line-height-control/index.js +6 -2
- package/src/components/line-height-control/test/index.js +16 -14
- package/src/components/link-control/index.js +2 -2
- package/src/components/link-control/link-preview.js +3 -3
- package/src/components/link-control/search-item.js +9 -3
- package/src/components/link-control/search-results.js +2 -2
- package/src/components/list-view/block-contents.js +2 -2
- package/src/components/list-view/block-select-button.js +85 -267
- package/src/components/list-view/block.js +240 -26
- package/src/components/list-view/drop-indicator.js +3 -3
- package/src/components/list-view/index.js +3 -3
- package/src/components/list-view/leaf.js +2 -5
- package/src/components/list-view/style.scss +20 -28
- package/src/components/list-view/use-list-view-drop-zone.js +1 -1
- package/src/components/list-view/utils.js +3 -1
- package/src/components/media-placeholder/content.scss +0 -11
- package/src/components/media-placeholder/index.js +7 -7
- package/src/components/media-replace-flow/index.js +2 -2
- package/src/components/navigable-toolbar/index.js +3 -1
- package/src/components/plain-text/index.js +2 -2
- package/src/components/provider/block-refs-provider.js +3 -8
- package/src/components/provider/test/use-block-sync.js +7 -0
- package/src/components/provider/use-block-sync.js +10 -1
- package/src/components/responsive-block-control/index.js +2 -2
- package/src/components/rich-text/README.md +0 -8
- package/src/components/rich-text/event-listeners/before-input-rules.js +92 -0
- package/src/components/rich-text/event-listeners/delete.js +53 -0
- package/src/components/rich-text/event-listeners/enter.js +84 -0
- package/src/components/rich-text/event-listeners/firefox-compat.js +31 -0
- package/src/components/rich-text/event-listeners/index.js +56 -0
- package/src/components/rich-text/event-listeners/input-events.js +13 -0
- package/src/components/rich-text/event-listeners/input-rules.js +146 -0
- package/src/components/rich-text/event-listeners/insert-replacement-text.js +28 -0
- package/src/components/rich-text/event-listeners/paste-handler.js +132 -0
- package/src/components/rich-text/event-listeners/remove-browser-shortcuts.js +24 -0
- package/src/components/rich-text/event-listeners/shortcuts.js +13 -0
- package/src/components/rich-text/event-listeners/undo-automatic-change.js +45 -0
- package/src/components/rich-text/format-toolbar/index.js +2 -2
- package/src/components/rich-text/index.js +17 -37
- package/src/components/rich-text/index.native.js +13 -2
- package/src/components/rich-text/multiline.js +37 -5
- package/src/components/rich-text/native/index.native.js +11 -0
- package/src/components/rich-text/use-format-types.js +6 -2
- package/src/components/segmented-text-control/index.js +63 -0
- package/src/components/{writing-mode-control → segmented-text-control}/style.scss +2 -5
- package/src/components/spacing-sizes-control/input-controls/spacing-input-control.js +16 -1
- package/src/components/text-alignment-control/index.js +91 -0
- package/src/components/text-alignment-control/stories/index.story.js +39 -0
- package/src/components/text-decoration-control/index.js +22 -35
- package/src/components/text-transform-control/index.js +19 -32
- package/src/components/url-input/index.js +4 -4
- package/src/components/url-popover/link-editor.js +2 -2
- package/src/components/url-popover/link-viewer-url.js +2 -2
- package/src/components/url-popover/link-viewer.js +2 -2
- package/src/components/use-block-display-information/index.js +9 -3
- package/src/components/use-on-block-drop/index.js +3 -1
- package/src/components/warning/index.js +2 -2
- package/src/components/writing-flow/index.js +2 -2
- package/src/components/writing-flow/use-clipboard-handler.js +107 -47
- package/src/components/writing-flow/use-drag-selection.js +3 -1
- package/src/components/writing-flow/use-input.js +75 -1
- package/src/components/writing-flow/use-tab-nav.js +13 -2
- package/src/components/writing-mode-control/index.js +17 -33
- package/src/content.scss +1 -0
- package/src/hooks/align.js +2 -2
- package/src/hooks/background.js +1 -1
- package/src/hooks/border.js +3 -3
- package/src/hooks/color.js +12 -19
- package/src/hooks/color.scss +1 -0
- package/src/hooks/content-lock-ui.js +16 -33
- package/src/hooks/custom-class-name.js +2 -2
- package/src/hooks/custom-class-name.native.js +2 -2
- package/src/hooks/dimensions.js +2 -2
- package/src/hooks/duotone.js +3 -1
- package/src/hooks/layout-child.js +34 -20
- package/src/hooks/layout.js +2 -2
- package/src/hooks/position.js +2 -2
- package/src/hooks/text-align.js +3 -3
- package/src/hooks/use-bindings-attributes.js +48 -16
- package/src/hooks/use-color-props.js +2 -2
- package/src/hooks/use-typography-props.js +2 -2
- package/src/hooks/utils.js +18 -4
- package/src/layouts/grid.js +3 -7
- package/src/private-apis.js +8 -2
- package/src/store/actions.js +233 -54
- package/src/store/private-actions.js +24 -0
- package/src/store/private-keys.js +1 -0
- package/src/store/private-selectors.js +43 -4
- package/src/store/reducer.js +13 -23
- package/src/store/selectors.js +24 -9
- package/src/style.scss +1 -2
- package/src/utils/object.js +16 -0
- package/src/utils/order-inserter-block-items.js +6 -2
- package/src/utils/pasting.js +6 -2
- package/src/utils/selection.js +8 -0
- package/src/utils/test/__snapshots__/transform-styles.js.snap +6 -0
- package/src/utils/test/transform-styles.js +14 -0
- package/src/utils/transform-styles/index.js +12 -9
- package/tsconfig.tsbuildinfo +1 -1
- package/build/components/block-list/use-block-props/use-block-moving-mode-class-names.js +0 -54
- package/build/components/block-list/use-block-props/use-block-moving-mode-class-names.js.map +0 -1
- package/build/components/rich-text/split-value.js +0 -81
- package/build/components/rich-text/split-value.js.map +0 -1
- package/build/components/rich-text/use-before-input-rules.js +0 -98
- package/build/components/rich-text/use-before-input-rules.js.map +0 -1
- package/build/components/rich-text/use-delete.js +0 -64
- package/build/components/rich-text/use-delete.js.map +0 -1
- package/build/components/rich-text/use-enter.js +0 -109
- package/build/components/rich-text/use-enter.js.map +0 -1
- package/build/components/rich-text/use-firefox-compat.js +0 -44
- package/build/components/rich-text/use-firefox-compat.js.map +0 -1
- package/build/components/rich-text/use-input-events.js +0 -25
- package/build/components/rich-text/use-input-events.js.map +0 -1
- package/build/components/rich-text/use-input-rules.js +0 -139
- package/build/components/rich-text/use-input-rules.js.map +0 -1
- package/build/components/rich-text/use-insert-replacement-text.js +0 -38
- package/build/components/rich-text/use-insert-replacement-text.js.map +0 -1
- package/build/components/rich-text/use-paste-handler.js +0 -158
- package/build/components/rich-text/use-paste-handler.js.map +0 -1
- package/build/components/rich-text/use-remove-browser-shortcuts.js +0 -32
- package/build/components/rich-text/use-remove-browser-shortcuts.js.map +0 -1
- package/build/components/rich-text/use-shortcuts.js +0 -25
- package/build/components/rich-text/use-shortcuts.js.map +0 -1
- package/build/components/rich-text/use-undo-automatic-change.js +0 -53
- package/build/components/rich-text/use-undo-automatic-change.js.map +0 -1
- package/build-module/components/block-list/use-block-props/use-block-moving-mode-class-names.js +0 -47
- package/build-module/components/block-list/use-block-props/use-block-moving-mode-class-names.js.map +0 -1
- package/build-module/components/rich-text/split-value.js +0 -75
- package/build-module/components/rich-text/split-value.js.map +0 -1
- package/build-module/components/rich-text/use-before-input-rules.js +0 -92
- package/build-module/components/rich-text/use-before-input-rules.js.map +0 -1
- package/build-module/components/rich-text/use-delete.js +0 -57
- package/build-module/components/rich-text/use-delete.js.map +0 -1
- package/build-module/components/rich-text/use-enter.js +0 -102
- package/build-module/components/rich-text/use-enter.js.map +0 -1
- package/build-module/components/rich-text/use-firefox-compat.js +0 -37
- package/build-module/components/rich-text/use-firefox-compat.js.map +0 -1
- package/build-module/components/rich-text/use-input-events.js +0 -18
- package/build-module/components/rich-text/use-input-events.js.map +0 -1
- package/build-module/components/rich-text/use-input-rules.js +0 -132
- package/build-module/components/rich-text/use-input-rules.js.map +0 -1
- package/build-module/components/rich-text/use-insert-replacement-text.js +0 -32
- package/build-module/components/rich-text/use-insert-replacement-text.js.map +0 -1
- package/build-module/components/rich-text/use-paste-handler.js +0 -152
- package/build-module/components/rich-text/use-paste-handler.js.map +0 -1
- package/build-module/components/rich-text/use-remove-browser-shortcuts.js +0 -26
- package/build-module/components/rich-text/use-remove-browser-shortcuts.js.map +0 -1
- package/build-module/components/rich-text/use-shortcuts.js +0 -18
- package/build-module/components/rich-text/use-shortcuts.js.map +0 -1
- package/build-module/components/rich-text/use-undo-automatic-change.js +0 -46
- package/build-module/components/rich-text/use-undo-automatic-change.js.map +0 -1
- package/src/components/block-list/use-block-props/use-block-moving-mode-class-names.js +0 -55
- package/src/components/rich-text/split-value.js +0 -64
- package/src/components/rich-text/use-before-input-rules.js +0 -99
- package/src/components/rich-text/use-delete.js +0 -59
- package/src/components/rich-text/use-enter.js +0 -110
- package/src/components/rich-text/use-firefox-compat.js +0 -39
- package/src/components/rich-text/use-input-events.js +0 -19
- package/src/components/rich-text/use-input-rules.js +0 -150
- package/src/components/rich-text/use-insert-replacement-text.js +0 -31
- package/src/components/rich-text/use-paste-handler.js +0 -180
- package/src/components/rich-text/use-remove-browser-shortcuts.js +0 -29
- package/src/components/rich-text/use-shortcuts.js +0 -19
- package/src/components/rich-text/use-undo-automatic-change.js +0 -46
- package/src/components/text-decoration-control/style.scss +0 -18
- package/src/components/text-transform-control/style.scss +0 -18
|
@@ -2,6 +2,7 @@
|
|
|
2
2
|
* WordPress dependencies
|
|
3
3
|
*/
|
|
4
4
|
import { ResizableBox } from '@wordpress/components';
|
|
5
|
+
import { useState, useEffect } from '@wordpress/element';
|
|
5
6
|
|
|
6
7
|
/**
|
|
7
8
|
* Internal dependencies
|
|
@@ -10,16 +11,84 @@ import { __unstableUseBlockElement as useBlockElement } from '../block-list/use-
|
|
|
10
11
|
import BlockPopoverCover from '../block-popover/cover';
|
|
11
12
|
import { getComputedCSS } from './utils';
|
|
12
13
|
|
|
13
|
-
export function GridItemResizer( { clientId, onChange } ) {
|
|
14
|
+
export function GridItemResizer( { clientId, bounds, onChange } ) {
|
|
14
15
|
const blockElement = useBlockElement( clientId );
|
|
15
|
-
|
|
16
|
+
const rootBlockElement = blockElement?.parentElement;
|
|
17
|
+
|
|
18
|
+
if ( ! blockElement || ! rootBlockElement ) {
|
|
16
19
|
return null;
|
|
17
20
|
}
|
|
21
|
+
|
|
22
|
+
return (
|
|
23
|
+
<GridItemResizerInner
|
|
24
|
+
clientId={ clientId }
|
|
25
|
+
bounds={ bounds }
|
|
26
|
+
blockElement={ blockElement }
|
|
27
|
+
rootBlockElement={ rootBlockElement }
|
|
28
|
+
onChange={ onChange }
|
|
29
|
+
/>
|
|
30
|
+
);
|
|
31
|
+
}
|
|
32
|
+
|
|
33
|
+
function GridItemResizerInner( {
|
|
34
|
+
clientId,
|
|
35
|
+
bounds,
|
|
36
|
+
blockElement,
|
|
37
|
+
rootBlockElement,
|
|
38
|
+
onChange,
|
|
39
|
+
} ) {
|
|
40
|
+
const [ resizeDirection, setResizeDirection ] = useState( null );
|
|
41
|
+
const [ enableSide, setEnableSide ] = useState( {
|
|
42
|
+
top: false,
|
|
43
|
+
bottom: false,
|
|
44
|
+
left: false,
|
|
45
|
+
right: false,
|
|
46
|
+
} );
|
|
47
|
+
|
|
48
|
+
useEffect( () => {
|
|
49
|
+
const observer = new window.ResizeObserver( () => {
|
|
50
|
+
const blockClientRect = blockElement.getBoundingClientRect();
|
|
51
|
+
const rootBlockClientRect =
|
|
52
|
+
rootBlockElement.getBoundingClientRect();
|
|
53
|
+
setEnableSide( {
|
|
54
|
+
top: blockClientRect.top > rootBlockClientRect.top,
|
|
55
|
+
bottom: blockClientRect.bottom < rootBlockClientRect.bottom,
|
|
56
|
+
left: blockClientRect.left > rootBlockClientRect.left,
|
|
57
|
+
right: blockClientRect.right < rootBlockClientRect.right,
|
|
58
|
+
} );
|
|
59
|
+
} );
|
|
60
|
+
observer.observe( blockElement );
|
|
61
|
+
return () => observer.disconnect();
|
|
62
|
+
}, [ blockElement, rootBlockElement ] );
|
|
63
|
+
|
|
64
|
+
const justification = {
|
|
65
|
+
right: 'flex-start',
|
|
66
|
+
left: 'flex-end',
|
|
67
|
+
};
|
|
68
|
+
|
|
69
|
+
const alignment = {
|
|
70
|
+
top: 'flex-end',
|
|
71
|
+
bottom: 'flex-start',
|
|
72
|
+
};
|
|
73
|
+
|
|
74
|
+
const styles = {
|
|
75
|
+
display: 'flex',
|
|
76
|
+
justifyContent: 'center',
|
|
77
|
+
alignItems: 'center',
|
|
78
|
+
...( justification[ resizeDirection ] && {
|
|
79
|
+
justifyContent: justification[ resizeDirection ],
|
|
80
|
+
} ),
|
|
81
|
+
...( alignment[ resizeDirection ] && {
|
|
82
|
+
alignItems: alignment[ resizeDirection ],
|
|
83
|
+
} ),
|
|
84
|
+
};
|
|
85
|
+
|
|
18
86
|
return (
|
|
19
87
|
<BlockPopoverCover
|
|
20
88
|
className="block-editor-grid-item-resizer"
|
|
21
89
|
clientId={ clientId }
|
|
22
90
|
__unstablePopoverSlot="block-toolbar"
|
|
91
|
+
additionalStyles={ styles }
|
|
23
92
|
>
|
|
24
93
|
<ResizableBox
|
|
25
94
|
className="block-editor-grid-item-resizer__box"
|
|
@@ -28,50 +97,80 @@ export function GridItemResizer( { clientId, onChange } ) {
|
|
|
28
97
|
height: '100%',
|
|
29
98
|
} }
|
|
30
99
|
enable={ {
|
|
31
|
-
bottom:
|
|
100
|
+
bottom: enableSide.bottom,
|
|
32
101
|
bottomLeft: false,
|
|
33
102
|
bottomRight: false,
|
|
34
|
-
left:
|
|
35
|
-
right:
|
|
36
|
-
top:
|
|
103
|
+
left: enableSide.left,
|
|
104
|
+
right: enableSide.right,
|
|
105
|
+
top: enableSide.top,
|
|
37
106
|
topLeft: false,
|
|
38
107
|
topRight: false,
|
|
39
108
|
} }
|
|
109
|
+
bounds={ bounds }
|
|
110
|
+
boundsByDirection
|
|
111
|
+
onResizeStart={ ( event, direction ) => {
|
|
112
|
+
/*
|
|
113
|
+
* The container justification and alignment need to be set
|
|
114
|
+
* according to the direction the resizer is being dragged in,
|
|
115
|
+
* so that it resizes in the right direction.
|
|
116
|
+
*/
|
|
117
|
+
setResizeDirection( direction );
|
|
118
|
+
|
|
119
|
+
/*
|
|
120
|
+
* The mouseup event on the resize handle doesn't trigger if the mouse
|
|
121
|
+
* isn't directly above the handle, so we try to detect if it happens
|
|
122
|
+
* outside the grid and dispatch a mouseup event on the handle.
|
|
123
|
+
*/
|
|
124
|
+
blockElement.ownerDocument.addEventListener(
|
|
125
|
+
'mouseup',
|
|
126
|
+
() => {
|
|
127
|
+
event.target.dispatchEvent(
|
|
128
|
+
new Event( 'mouseup', { bubbles: true } )
|
|
129
|
+
);
|
|
130
|
+
},
|
|
131
|
+
{ once: true }
|
|
132
|
+
);
|
|
133
|
+
} }
|
|
40
134
|
onResizeStop={ ( event, direction, boxElement ) => {
|
|
41
|
-
const gridElement = blockElement.parentElement;
|
|
42
135
|
const columnGap = parseFloat(
|
|
43
|
-
getComputedCSS(
|
|
136
|
+
getComputedCSS( rootBlockElement, 'column-gap' )
|
|
44
137
|
);
|
|
45
138
|
const rowGap = parseFloat(
|
|
46
|
-
getComputedCSS(
|
|
139
|
+
getComputedCSS( rootBlockElement, 'row-gap' )
|
|
47
140
|
);
|
|
48
|
-
const
|
|
49
|
-
getComputedCSS(
|
|
141
|
+
const gridColumnTracks = getGridTracks(
|
|
142
|
+
getComputedCSS(
|
|
143
|
+
rootBlockElement,
|
|
144
|
+
'grid-template-columns'
|
|
145
|
+
),
|
|
50
146
|
columnGap
|
|
51
147
|
);
|
|
52
|
-
const
|
|
53
|
-
getComputedCSS(
|
|
148
|
+
const gridRowTracks = getGridTracks(
|
|
149
|
+
getComputedCSS(
|
|
150
|
+
rootBlockElement,
|
|
151
|
+
'grid-template-rows'
|
|
152
|
+
),
|
|
54
153
|
rowGap
|
|
55
154
|
);
|
|
56
|
-
const
|
|
57
|
-
|
|
58
|
-
blockElement.
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
gridRowLines,
|
|
62
|
-
blockElement.offsetTop
|
|
63
|
-
);
|
|
64
|
-
const columnEnd = getClosestLine(
|
|
65
|
-
gridColumnLines,
|
|
66
|
-
blockElement.offsetLeft + boxElement.offsetWidth
|
|
67
|
-
);
|
|
68
|
-
const rowEnd = getClosestLine(
|
|
69
|
-
gridRowLines,
|
|
70
|
-
blockElement.offsetTop + boxElement.offsetHeight
|
|
155
|
+
const rect = new window.DOMRect(
|
|
156
|
+
blockElement.offsetLeft + boxElement.offsetLeft,
|
|
157
|
+
blockElement.offsetTop + boxElement.offsetTop,
|
|
158
|
+
boxElement.offsetWidth,
|
|
159
|
+
boxElement.offsetHeight
|
|
71
160
|
);
|
|
161
|
+
const columnStart =
|
|
162
|
+
getClosestTrack( gridColumnTracks, rect.left ) + 1;
|
|
163
|
+
const rowStart =
|
|
164
|
+
getClosestTrack( gridRowTracks, rect.top ) + 1;
|
|
165
|
+
const columnEnd =
|
|
166
|
+
getClosestTrack( gridColumnTracks, rect.right, 'end' ) +
|
|
167
|
+
1;
|
|
168
|
+
const rowEnd =
|
|
169
|
+
getClosestTrack( gridRowTracks, rect.bottom, 'end' ) +
|
|
170
|
+
1;
|
|
72
171
|
onChange( {
|
|
73
|
-
columnSpan:
|
|
74
|
-
rowSpan:
|
|
172
|
+
columnSpan: columnEnd - columnStart + 1,
|
|
173
|
+
rowSpan: rowEnd - rowStart + 1,
|
|
75
174
|
} );
|
|
76
175
|
} }
|
|
77
176
|
/>
|
|
@@ -79,20 +178,50 @@ export function GridItemResizer( { clientId, onChange } ) {
|
|
|
79
178
|
);
|
|
80
179
|
}
|
|
81
180
|
|
|
82
|
-
|
|
83
|
-
|
|
181
|
+
/**
|
|
182
|
+
* Given a grid-template-columns or grid-template-rows CSS property value, gets the start and end
|
|
183
|
+
* position in pixels of each grid track.
|
|
184
|
+
*
|
|
185
|
+
* https://css-tricks.com/snippets/css/complete-guide-grid/#aa-grid-track
|
|
186
|
+
*
|
|
187
|
+
* @param {string} template The grid-template-columns or grid-template-rows CSS property value.
|
|
188
|
+
* Only supports fixed sizes in pixels.
|
|
189
|
+
* @param {number} gap The gap between grid tracks in pixels.
|
|
190
|
+
*
|
|
191
|
+
* @return {Array<{start: number, end: number}>} An array of objects with the start and end
|
|
192
|
+
* position in pixels of each grid track.
|
|
193
|
+
*/
|
|
194
|
+
function getGridTracks( template, gap ) {
|
|
195
|
+
const tracks = [];
|
|
84
196
|
for ( const size of template.split( ' ' ) ) {
|
|
85
|
-
const
|
|
86
|
-
|
|
197
|
+
const previousTrack = tracks[ tracks.length - 1 ];
|
|
198
|
+
const start = previousTrack ? previousTrack.end + gap : 0;
|
|
199
|
+
const end = start + parseFloat( size );
|
|
200
|
+
tracks.push( { start, end } );
|
|
87
201
|
}
|
|
88
|
-
return
|
|
202
|
+
return tracks;
|
|
89
203
|
}
|
|
90
204
|
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
205
|
+
/**
|
|
206
|
+
* Given an array of grid tracks and a position in pixels, gets the index of the closest track to
|
|
207
|
+
* that position.
|
|
208
|
+
*
|
|
209
|
+
* https://css-tricks.com/snippets/css/complete-guide-grid/#aa-grid-track
|
|
210
|
+
*
|
|
211
|
+
* @param {Array<{start: number, end: number}>} tracks An array of objects with the start and end
|
|
212
|
+
* position in pixels of each grid track.
|
|
213
|
+
* @param {number} position The position in pixels.
|
|
214
|
+
* @param {string} edge The edge of the track to compare the
|
|
215
|
+
* position to. Either 'start' or 'end'.
|
|
216
|
+
*
|
|
217
|
+
* @return {number} The index of the closest track to the position. 0-based, unlike CSS grid which
|
|
218
|
+
* is 1-based.
|
|
219
|
+
*/
|
|
220
|
+
function getClosestTrack( tracks, position, edge = 'start' ) {
|
|
221
|
+
return tracks.reduce(
|
|
222
|
+
( closest, track, index ) =>
|
|
223
|
+
Math.abs( track[ edge ] - position ) <
|
|
224
|
+
Math.abs( tracks[ closest ][ edge ] - position )
|
|
96
225
|
? index
|
|
97
226
|
: closest,
|
|
98
227
|
0
|
|
@@ -1,32 +1,44 @@
|
|
|
1
1
|
/**
|
|
2
2
|
* WordPress dependencies
|
|
3
3
|
*/
|
|
4
|
-
import { useState, useEffect } from '@wordpress/element';
|
|
4
|
+
import { useState, useEffect, forwardRef } from '@wordpress/element';
|
|
5
|
+
import { useSelect } from '@wordpress/data';
|
|
5
6
|
|
|
6
7
|
/**
|
|
7
8
|
* Internal dependencies
|
|
8
9
|
*/
|
|
9
10
|
import { __unstableUseBlockElement as useBlockElement } from '../block-list/use-block-props/use-block-refs';
|
|
10
11
|
import BlockPopoverCover from '../block-popover/cover';
|
|
12
|
+
import { store as blockEditorStore } from '../../store';
|
|
11
13
|
import { getComputedCSS } from './utils';
|
|
12
14
|
|
|
13
|
-
export function GridVisualizer( { clientId } ) {
|
|
15
|
+
export function GridVisualizer( { clientId, contentRef } ) {
|
|
16
|
+
const isDistractionFree = useSelect(
|
|
17
|
+
( select ) =>
|
|
18
|
+
select( blockEditorStore ).getSettings().isDistractionFree,
|
|
19
|
+
[]
|
|
20
|
+
);
|
|
14
21
|
const blockElement = useBlockElement( clientId );
|
|
15
|
-
|
|
22
|
+
|
|
23
|
+
if ( isDistractionFree || ! blockElement ) {
|
|
16
24
|
return null;
|
|
17
25
|
}
|
|
26
|
+
|
|
18
27
|
return (
|
|
19
28
|
<BlockPopoverCover
|
|
20
29
|
className="block-editor-grid-visualizer"
|
|
21
30
|
clientId={ clientId }
|
|
22
31
|
__unstablePopoverSlot="block-toolbar"
|
|
23
32
|
>
|
|
24
|
-
<GridVisualizerGrid
|
|
33
|
+
<GridVisualizerGrid
|
|
34
|
+
ref={ contentRef }
|
|
35
|
+
blockElement={ blockElement }
|
|
36
|
+
/>
|
|
25
37
|
</BlockPopoverCover>
|
|
26
38
|
);
|
|
27
39
|
}
|
|
28
40
|
|
|
29
|
-
|
|
41
|
+
const GridVisualizerGrid = forwardRef( ( { blockElement }, ref ) => {
|
|
30
42
|
const [ gridInfo, setGridInfo ] = useState( () =>
|
|
31
43
|
getGridInfo( blockElement )
|
|
32
44
|
);
|
|
@@ -47,6 +59,7 @@ function GridVisualizerGrid( { blockElement } ) {
|
|
|
47
59
|
}, [ blockElement ] );
|
|
48
60
|
return (
|
|
49
61
|
<div
|
|
62
|
+
ref={ ref }
|
|
50
63
|
className="block-editor-grid-visualizer__grid"
|
|
51
64
|
style={ gridInfo.style }
|
|
52
65
|
>
|
|
@@ -55,7 +68,7 @@ function GridVisualizerGrid( { blockElement } ) {
|
|
|
55
68
|
) ) }
|
|
56
69
|
</div>
|
|
57
70
|
);
|
|
58
|
-
}
|
|
71
|
+
} );
|
|
59
72
|
|
|
60
73
|
function getGridInfo( blockElement ) {
|
|
61
74
|
const gridTemplateColumns = getComputedCSS(
|
|
@@ -0,0 +1,63 @@
|
|
|
1
|
+
.block-editor-iframe__container {
|
|
2
|
+
width: 100%;
|
|
3
|
+
height: 100%;
|
|
4
|
+
overflow-x: hidden;
|
|
5
|
+
}
|
|
6
|
+
|
|
7
|
+
.block-editor-iframe__scale-container {
|
|
8
|
+
width: 100%;
|
|
9
|
+
height: 100%;
|
|
10
|
+
}
|
|
11
|
+
|
|
12
|
+
.block-editor-iframe__scale-container.is-zoomed-out {
|
|
13
|
+
$container-width: var(--wp-block-editor-iframe-zoom-out-container-width, 100vw);
|
|
14
|
+
$prev-container-width: var(--wp-block-editor-iframe-zoom-out-prev-container-width, 100vw);
|
|
15
|
+
width: $prev-container-width;
|
|
16
|
+
margin-left: calc(-1 * (#{$prev-container-width} - #{$container-width}) / 2);
|
|
17
|
+
}
|
|
18
|
+
|
|
19
|
+
.block-editor-iframe__html {
|
|
20
|
+
transform-origin: top center;
|
|
21
|
+
transition: transform 0.3s;
|
|
22
|
+
@include reduce-motion("transition");
|
|
23
|
+
}
|
|
24
|
+
|
|
25
|
+
.block-editor-iframe__html.is-zoomed-out {
|
|
26
|
+
$scale: var(--wp-block-editor-iframe-zoom-out-scale);
|
|
27
|
+
$frame-size: var(--wp-block-editor-iframe-zoom-out-frame-size);
|
|
28
|
+
$inner-height: var(--wp-block-editor-iframe-zoom-out-inner-height);
|
|
29
|
+
$content-height: var(--wp-block-editor-iframe-zoom-out-content-height);
|
|
30
|
+
$prev-container-width: var(--wp-block-editor-iframe-zoom-out-prev-container-width);
|
|
31
|
+
|
|
32
|
+
transform: scale(#{$scale});
|
|
33
|
+
|
|
34
|
+
background-color: $gray-300;
|
|
35
|
+
|
|
36
|
+
// Firefox and Safari don't render margin-bottom here and margin-bottom is needed for Chrome
|
|
37
|
+
// layout, so we use border matching the background instead of margins.
|
|
38
|
+
border: calc(#{$frame-size} / #{$scale}) solid $gray-300;
|
|
39
|
+
|
|
40
|
+
// Chrome seems to respect that transform scale shouldn't affect the layout size of the element,
|
|
41
|
+
// so we need to adjust the height of the content to match the scale by using negative margins.
|
|
42
|
+
$extra-content-height: calc(#{$content-height} * (1 - #{$scale}));
|
|
43
|
+
$total-frame-height: calc(2 * #{$frame-size});
|
|
44
|
+
$total-height: calc(#{$extra-content-height} + #{$total-frame-height} + 2px);
|
|
45
|
+
margin-bottom: calc(-1 * #{$total-height});
|
|
46
|
+
|
|
47
|
+
body {
|
|
48
|
+
min-height: calc((#{$inner-height} - #{$total-frame-height}) / #{$scale});
|
|
49
|
+
display: flex;
|
|
50
|
+
flex-direction: column;
|
|
51
|
+
|
|
52
|
+
> .is-root-container {
|
|
53
|
+
flex: 1;
|
|
54
|
+
display: flex;
|
|
55
|
+
flex-direction: column;
|
|
56
|
+
height: 100%;
|
|
57
|
+
|
|
58
|
+
> main {
|
|
59
|
+
flex: 1;
|
|
60
|
+
}
|
|
61
|
+
}
|
|
62
|
+
}
|
|
63
|
+
}
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
/**
|
|
2
2
|
* External dependencies
|
|
3
3
|
*/
|
|
4
|
-
import
|
|
4
|
+
import clsx from 'clsx';
|
|
5
5
|
|
|
6
6
|
/**
|
|
7
7
|
* WordPress dependencies
|
|
@@ -12,6 +12,7 @@ import {
|
|
|
12
12
|
forwardRef,
|
|
13
13
|
useMemo,
|
|
14
14
|
useEffect,
|
|
15
|
+
useRef,
|
|
15
16
|
} from '@wordpress/element';
|
|
16
17
|
import { __ } from '@wordpress/i18n';
|
|
17
18
|
import {
|
|
@@ -121,13 +122,14 @@ function Iframe( {
|
|
|
121
122
|
}, [] );
|
|
122
123
|
const { styles = '', scripts = '' } = resolvedAssets;
|
|
123
124
|
const [ iframeDocument, setIframeDocument ] = useState();
|
|
125
|
+
const prevContainerWidth = useRef();
|
|
124
126
|
const [ bodyClasses, setBodyClasses ] = useState( [] );
|
|
125
127
|
const clearerRef = useBlockSelectionClearer();
|
|
126
128
|
const [ before, writingFlowRef, after ] = useWritingFlow();
|
|
127
|
-
const [
|
|
128
|
-
|
|
129
|
-
|
|
130
|
-
|
|
129
|
+
const [ contentResizeListener, { height: contentHeight } ] =
|
|
130
|
+
useResizeObserver();
|
|
131
|
+
const [ containerResizeListener, { width: containerWidth } ] =
|
|
132
|
+
useResizeObserver();
|
|
131
133
|
|
|
132
134
|
const setRef = useRefEffect( ( node ) => {
|
|
133
135
|
node._load = () => {
|
|
@@ -207,9 +209,12 @@ function Iframe( {
|
|
|
207
209
|
};
|
|
208
210
|
}, [] );
|
|
209
211
|
|
|
210
|
-
const
|
|
212
|
+
const [ iframeWindowInnerHeight, setIframeWindowInnerHeight ] = useState();
|
|
213
|
+
|
|
214
|
+
const iframeResizeRef = useRefEffect( ( node ) => {
|
|
211
215
|
const nodeWindow = node.ownerDocument.defaultView;
|
|
212
216
|
|
|
217
|
+
setIframeWindowInnerHeight( nodeWindow.innerHeight );
|
|
213
218
|
const onResize = () => {
|
|
214
219
|
setIframeWindowInnerHeight( nodeWindow.innerHeight );
|
|
215
220
|
};
|
|
@@ -219,7 +224,28 @@ function Iframe( {
|
|
|
219
224
|
};
|
|
220
225
|
}, [] );
|
|
221
226
|
|
|
222
|
-
const [
|
|
227
|
+
const [ windowInnerWidth, setWindowInnerWidth ] = useState();
|
|
228
|
+
|
|
229
|
+
const windowResizeRef = useRefEffect( ( node ) => {
|
|
230
|
+
const nodeWindow = node.ownerDocument.defaultView;
|
|
231
|
+
|
|
232
|
+
setWindowInnerWidth( nodeWindow.innerWidth );
|
|
233
|
+
const onResize = () => {
|
|
234
|
+
setWindowInnerWidth( nodeWindow.innerWidth );
|
|
235
|
+
};
|
|
236
|
+
nodeWindow.addEventListener( 'resize', onResize );
|
|
237
|
+
return () => {
|
|
238
|
+
nodeWindow.removeEventListener( 'resize', onResize );
|
|
239
|
+
};
|
|
240
|
+
}, [] );
|
|
241
|
+
|
|
242
|
+
const isZoomedOut = scale !== 1;
|
|
243
|
+
|
|
244
|
+
useEffect( () => {
|
|
245
|
+
if ( ! isZoomedOut ) {
|
|
246
|
+
prevContainerWidth.current = containerWidth;
|
|
247
|
+
}
|
|
248
|
+
}, [ containerWidth, isZoomedOut ] );
|
|
223
249
|
|
|
224
250
|
const disabledRef = useDisabled( { isDisabled: ! readonly } );
|
|
225
251
|
const bodyRef = useMergeRefs( [
|
|
@@ -231,7 +257,7 @@ function Iframe( {
|
|
|
231
257
|
// Avoid resize listeners when not needed, these will trigger
|
|
232
258
|
// unnecessary re-renders when animating the iframe width, or when
|
|
233
259
|
// expanding preview iframes.
|
|
234
|
-
|
|
260
|
+
isZoomedOut ? iframeResizeRef : null,
|
|
235
261
|
] );
|
|
236
262
|
|
|
237
263
|
// Correct doctype is required to enable rendering in standards
|
|
@@ -272,54 +298,80 @@ function Iframe( {
|
|
|
272
298
|
|
|
273
299
|
useEffect( () => cleanup, [ cleanup ] );
|
|
274
300
|
|
|
275
|
-
scale =
|
|
276
|
-
typeof scale === 'function'
|
|
277
|
-
? scale( contentWidth, contentHeight )
|
|
278
|
-
: scale;
|
|
279
|
-
|
|
280
301
|
useEffect( () => {
|
|
281
|
-
if ( ! iframeDocument ) {
|
|
302
|
+
if ( ! iframeDocument || ! isZoomedOut ) {
|
|
282
303
|
return;
|
|
283
304
|
}
|
|
284
305
|
|
|
285
|
-
|
|
286
|
-
// Hack to get proper margins when scaling the iframe document.
|
|
287
|
-
const bottomFrameSize = frameSize - contentHeight * ( 1 - scale );
|
|
306
|
+
iframeDocument.documentElement.classList.add( 'is-zoomed-out' );
|
|
288
307
|
|
|
289
|
-
|
|
308
|
+
const maxWidth = 800;
|
|
309
|
+
iframeDocument.documentElement.style.setProperty(
|
|
310
|
+
'--wp-block-editor-iframe-zoom-out-scale',
|
|
311
|
+
scale === 'default'
|
|
312
|
+
? Math.min( containerWidth, maxWidth ) /
|
|
313
|
+
prevContainerWidth.current
|
|
314
|
+
: scale
|
|
315
|
+
);
|
|
316
|
+
iframeDocument.documentElement.style.setProperty(
|
|
317
|
+
'--wp-block-editor-iframe-zoom-out-frame-size',
|
|
318
|
+
typeof frameSize === 'number' ? `${ frameSize }px` : frameSize
|
|
319
|
+
);
|
|
320
|
+
iframeDocument.documentElement.style.setProperty(
|
|
321
|
+
'--wp-block-editor-iframe-zoom-out-content-height',
|
|
322
|
+
`${ contentHeight }px`
|
|
323
|
+
);
|
|
324
|
+
iframeDocument.documentElement.style.setProperty(
|
|
325
|
+
'--wp-block-editor-iframe-zoom-out-inner-height',
|
|
326
|
+
`${ iframeWindowInnerHeight }px`
|
|
327
|
+
);
|
|
328
|
+
iframeDocument.documentElement.style.setProperty(
|
|
329
|
+
'--wp-block-editor-iframe-zoom-out-container-width',
|
|
330
|
+
`${ containerWidth }px`
|
|
331
|
+
);
|
|
332
|
+
iframeDocument.documentElement.style.setProperty(
|
|
333
|
+
'--wp-block-editor-iframe-zoom-out-prev-container-width',
|
|
334
|
+
`${ prevContainerWidth.current }px`
|
|
335
|
+
);
|
|
290
336
|
|
|
291
|
-
|
|
292
|
-
iframeDocument.documentElement.
|
|
293
|
-
// TODO: `marginBottom` doesn't work in Firefox. We need another way to do this.
|
|
294
|
-
iframeDocument.documentElement.style.marginBottom = `${ bottomFrameSize }px`;
|
|
295
|
-
if ( iframeWindowInnerHeight > contentHeight * scale ) {
|
|
296
|
-
iframeDocument.body.style.minHeight = `${ Math.floor(
|
|
297
|
-
( iframeWindowInnerHeight - 2 * frameSize ) / scale
|
|
298
|
-
) }px`;
|
|
299
|
-
}
|
|
337
|
+
return () => {
|
|
338
|
+
iframeDocument.documentElement.classList.remove( 'is-zoomed-out' );
|
|
300
339
|
|
|
301
|
-
|
|
302
|
-
|
|
303
|
-
|
|
304
|
-
|
|
305
|
-
|
|
306
|
-
|
|
307
|
-
|
|
308
|
-
|
|
340
|
+
iframeDocument.documentElement.style.removeProperty(
|
|
341
|
+
'--wp-block-editor-iframe-zoom-out-scale'
|
|
342
|
+
);
|
|
343
|
+
iframeDocument.documentElement.style.removeProperty(
|
|
344
|
+
'--wp-block-editor-iframe-zoom-out-frame-size'
|
|
345
|
+
);
|
|
346
|
+
iframeDocument.documentElement.style.removeProperty(
|
|
347
|
+
'--wp-block-editor-iframe-zoom-out-content-height'
|
|
348
|
+
);
|
|
349
|
+
iframeDocument.documentElement.style.removeProperty(
|
|
350
|
+
'--wp-block-editor-iframe-zoom-out-inner-height'
|
|
351
|
+
);
|
|
352
|
+
iframeDocument.documentElement.style.removeProperty(
|
|
353
|
+
'--wp-block-editor-iframe-zoom-out-container-width'
|
|
354
|
+
);
|
|
355
|
+
iframeDocument.documentElement.style.removeProperty(
|
|
356
|
+
'--wp-block-editor-iframe-zoom-out-prev-container-width'
|
|
357
|
+
);
|
|
358
|
+
};
|
|
309
359
|
}, [
|
|
310
360
|
scale,
|
|
311
361
|
frameSize,
|
|
312
362
|
iframeDocument,
|
|
313
|
-
contentHeight,
|
|
314
363
|
iframeWindowInnerHeight,
|
|
315
|
-
|
|
364
|
+
contentHeight,
|
|
365
|
+
containerWidth,
|
|
366
|
+
windowInnerWidth,
|
|
367
|
+
isZoomedOut,
|
|
316
368
|
] );
|
|
317
369
|
|
|
318
370
|
// Make sure to not render the before and after focusable div elements in view
|
|
319
371
|
// mode. They're only needed to capture focus in edit mode.
|
|
320
372
|
const shouldRenderFocusCaptureElements = tabIndex >= 0 && ! isPreviewMode;
|
|
321
373
|
|
|
322
|
-
|
|
374
|
+
const iframe = (
|
|
323
375
|
<>
|
|
324
376
|
{ shouldRenderFocusCaptureElements && before }
|
|
325
377
|
{ /* eslint-disable-next-line jsx-a11y/no-noninteractive-element-interactions */ }
|
|
@@ -352,7 +404,15 @@ function Iframe( {
|
|
|
352
404
|
event.currentTarget.ownerDocument !==
|
|
353
405
|
event.target.ownerDocument
|
|
354
406
|
) {
|
|
407
|
+
// We should only stop propagation of the React event,
|
|
408
|
+
// the native event should further bubble inside the
|
|
409
|
+
// iframe to the document and window.
|
|
410
|
+
// Alternatively, we could consider redispatching the
|
|
411
|
+
// native event in the iframe.
|
|
412
|
+
const { stopPropagation } = event.nativeEvent;
|
|
413
|
+
event.nativeEvent.stopPropagation = () => {};
|
|
355
414
|
event.stopPropagation();
|
|
415
|
+
event.nativeEvent.stopPropagation = stopPropagation;
|
|
356
416
|
bubbleEvent(
|
|
357
417
|
event,
|
|
358
418
|
window.KeyboardEvent,
|
|
@@ -368,7 +428,7 @@ function Iframe( {
|
|
|
368
428
|
/* eslint-disable-next-line jsx-a11y/no-noninteractive-element-interactions */
|
|
369
429
|
<body
|
|
370
430
|
ref={ bodyRef }
|
|
371
|
-
className={
|
|
431
|
+
className={ clsx(
|
|
372
432
|
'block-editor-iframe__body',
|
|
373
433
|
'editor-styles-wrapper',
|
|
374
434
|
...bodyClasses
|
|
@@ -385,6 +445,26 @@ function Iframe( {
|
|
|
385
445
|
{ shouldRenderFocusCaptureElements && after }
|
|
386
446
|
</>
|
|
387
447
|
);
|
|
448
|
+
|
|
449
|
+
return (
|
|
450
|
+
<div className="block-editor-iframe__container" ref={ windowResizeRef }>
|
|
451
|
+
{ containerResizeListener }
|
|
452
|
+
<div
|
|
453
|
+
className={ clsx(
|
|
454
|
+
'block-editor-iframe__scale-container',
|
|
455
|
+
isZoomedOut && 'is-zoomed-out'
|
|
456
|
+
) }
|
|
457
|
+
style={ {
|
|
458
|
+
'--wp-block-editor-iframe-zoom-out-container-width':
|
|
459
|
+
isZoomedOut && `${ containerWidth }px`,
|
|
460
|
+
'--wp-block-editor-iframe-zoom-out-prev-container-width':
|
|
461
|
+
isZoomedOut && `${ prevContainerWidth.current }px`,
|
|
462
|
+
} }
|
|
463
|
+
>
|
|
464
|
+
{ iframe }
|
|
465
|
+
</div>
|
|
466
|
+
</div>
|
|
467
|
+
);
|
|
388
468
|
}
|
|
389
469
|
|
|
390
470
|
function IframeIfReady( props, ref ) {
|