@wordpress/block-editor 9.2.0 → 9.5.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 +10 -0
- package/README.md +1 -8
- package/build/autocompleters/block.js +3 -1
- package/build/autocompleters/block.js.map +1 -1
- package/build/components/block-actions/index.js.map +1 -1
- package/build/components/block-alignment-control/ui.js.map +1 -1
- package/build/components/block-alignment-matrix-control/index.js +3 -7
- package/build/components/block-alignment-matrix-control/index.js.map +1 -1
- package/build/components/block-breadcrumb/index.js.map +1 -1
- package/build/components/block-content-overlay/index.js.map +1 -1
- package/build/components/block-context/index.js.map +1 -1
- package/build/components/block-controls/hook.js.map +1 -1
- package/build/components/block-draggable/index.js.map +1 -1
- package/build/components/block-draggable/index.native.js.map +1 -1
- package/build/components/block-list/block-invalid-warning.native.js +54 -6
- package/build/components/block-list/block-invalid-warning.native.js.map +1 -1
- package/build/components/block-list/block-list-item.native.js.map +1 -1
- package/build/components/block-list/block-selection-button.native.js.map +1 -1
- package/build/components/block-list/block.js +2 -2
- package/build/components/block-list/block.js.map +1 -1
- package/build/components/block-list/block.native.js +2 -1
- package/build/components/block-list/block.native.js.map +1 -1
- package/build/components/block-list/index.js.map +1 -1
- package/build/components/block-list/index.native.js +4 -3
- package/build/components/block-list/index.native.js.map +1 -1
- package/build/components/block-list/layout.js +20 -5
- package/build/components/block-list/layout.js.map +1 -1
- package/build/components/block-list/use-block-props/index.js.map +1 -1
- package/build/components/block-list/use-block-props/use-block-class-names.js +5 -2
- package/build/components/block-list/use-block-props/use-block-class-names.js.map +1 -1
- package/build/components/block-list/use-block-props/use-block-custom-class-name.js.map +1 -1
- package/build/components/block-list/use-block-props/use-selected-block-event-handlers.js.map +1 -1
- package/build/components/block-list/use-in-between-inserter.js.map +1 -1
- package/build/components/block-list-appender/index.js.map +1 -1
- package/build/components/block-list-appender/index.native.js.map +1 -1
- package/build/components/block-lock/modal.js +35 -5
- package/build/components/block-lock/modal.js.map +1 -1
- package/build/components/block-mobile-toolbar/block-actions-menu.native.js.map +1 -1
- package/build/components/block-mover/button.js.map +1 -1
- package/build/components/block-mover/index.native.js.map +1 -1
- package/build/components/block-parent-selector/index.js.map +1 -1
- package/build/components/block-pattern-setup/index.js +8 -26
- package/build/components/block-pattern-setup/index.js.map +1 -1
- package/build/components/block-pattern-setup/setup-toolbar.js +3 -8
- package/build/components/block-pattern-setup/setup-toolbar.js.map +1 -1
- package/build/components/block-popover/inbetween.js +1 -1
- package/build/components/block-popover/inbetween.js.map +1 -1
- package/build/components/block-popover/index.js +1 -1
- package/build/components/block-popover/index.js.map +1 -1
- package/build/components/block-preview/auto.js +21 -5
- package/build/components/block-preview/auto.js.map +1 -1
- package/build/components/block-selection-clearer/index.js.map +1 -1
- package/build/components/block-settings-menu/block-edit-visually-button.js +70 -0
- package/build/components/block-settings-menu/block-edit-visually-button.js.map +1 -0
- package/build/components/block-settings-menu/block-mode-toggle.js +4 -8
- package/build/components/block-settings-menu/block-mode-toggle.js.map +1 -1
- package/build/components/block-settings-menu/block-settings-dropdown.js +10 -4
- package/build/components/block-settings-menu/block-settings-dropdown.js.map +1 -1
- package/build/components/block-settings-menu/index.js +6 -2
- package/build/components/block-settings-menu/index.js.map +1 -1
- package/build/components/block-settings-menu-controls/index.js +4 -1
- package/build/components/block-settings-menu-controls/index.js.map +1 -1
- package/build/components/block-styles/index.js +6 -3
- package/build/components/block-styles/index.js.map +1 -1
- package/build/components/block-styles/menu-items.js +3 -7
- package/build/components/block-styles/menu-items.js.map +1 -1
- package/build/components/block-styles/preview.native.js +3 -1
- package/build/components/block-styles/preview.native.js.map +1 -1
- package/build/components/block-switcher/block-transformations-menu.js.map +1 -1
- package/build/components/block-switcher/index.js +7 -1
- package/build/components/block-switcher/index.js.map +1 -1
- package/build/components/block-title/index.js +8 -2
- package/build/components/block-title/index.js.map +1 -1
- package/build/components/block-title/use-block-display-title.js +15 -15
- package/build/components/block-title/use-block-display-title.js.map +1 -1
- package/build/components/block-toolbar/index.native.js.map +1 -1
- package/build/components/block-toolbar/utils.js +5 -8
- package/build/components/block-toolbar/utils.js.map +1 -1
- package/build/components/block-tools/block-contextual-toolbar.js +1 -1
- package/build/components/block-tools/block-contextual-toolbar.js.map +1 -1
- package/build/components/block-tools/index.js.map +1 -1
- package/build/components/block-types-list/index.native.js.map +1 -1
- package/build/components/block-variation-transforms/index.js.map +1 -1
- package/build/components/border-radius-control/index.js +2 -0
- package/build/components/border-radius-control/index.js.map +1 -1
- package/build/components/color-style-selector/index.js.map +1 -1
- package/build/components/colors/with-colors.js +1 -1
- package/build/components/colors/with-colors.js.map +1 -1
- package/build/components/colors-gradients/control.js +45 -39
- package/build/components/colors-gradients/control.js.map +1 -1
- package/build/components/colors-gradients/dropdown.js +2 -1
- package/build/components/colors-gradients/dropdown.js.map +1 -1
- package/build/components/convert-to-group-buttons/toolbar.js.map +1 -1
- package/build/components/copy-handler/index.js +17 -1
- package/build/components/copy-handler/index.js.map +1 -1
- package/build/components/date-format-picker/index.js +1 -1
- package/build/components/date-format-picker/index.js.map +1 -1
- package/build/components/default-block-appender/index.js.map +1 -1
- package/build/components/default-block-appender/index.native.js.map +1 -1
- package/build/components/default-style-picker/index.js.map +1 -1
- package/build/components/duotone/components.js +145 -0
- package/build/components/duotone/components.js.map +1 -0
- package/build/components/duotone/index.js +40 -0
- package/build/components/duotone/index.js.map +1 -0
- package/build/components/duotone/utils.js +38 -0
- package/build/components/duotone/utils.js.map +1 -0
- package/build/components/duotone-control/index.js +17 -5
- package/build/components/duotone-control/index.js.map +1 -1
- package/build/components/font-sizes/with-font-sizes.js.map +1 -1
- package/build/components/iframe/index.js +19 -6
- package/build/components/iframe/index.js.map +1 -1
- package/build/components/image-editor/aspect-ratio-dropdown.js.map +1 -1
- package/build/components/image-size-control/index.js +3 -1
- package/build/components/image-size-control/index.js.map +1 -1
- package/build/components/index.js +32 -0
- package/build/components/index.js.map +1 -1
- package/build/components/inner-blocks/use-inner-block-template-sync.js.map +1 -1
- package/build/components/inner-blocks/use-nested-settings-update.js.map +1 -1
- package/build/components/inserter/block-types-tab.native.js.map +1 -1
- package/build/components/inserter/hooks/use-block-type-impressions.native.js.map +1 -1
- package/build/components/inserter/hooks/use-insertion-point.js.map +1 -1
- package/build/components/inserter/hooks/use-patterns-state.js.map +1 -1
- package/build/components/inserter/index.js +3 -3
- package/build/components/inserter/index.js.map +1 -1
- package/build/components/inserter/index.native.js.map +1 -1
- package/build/components/inserter/library.js +3 -7
- package/build/components/inserter/library.js.map +1 -1
- package/build/components/inserter/menu.js.map +1 -1
- package/build/components/inserter/menu.native.js.map +1 -1
- package/build/components/inserter/no-results.native.js.map +1 -1
- package/build/components/inserter/quick-inserter.js.map +1 -1
- package/build/components/inserter/search-items.js +1 -1
- package/build/components/inserter/search-items.js.map +1 -1
- package/build/components/inserter/search-results.native.js.map +1 -1
- package/build/components/inspector-popover-header/index.js +56 -0
- package/build/components/inspector-popover-header/index.js.map +1 -0
- package/build/components/line-height-control/index.js.map +1 -1
- package/build/components/link-control/index.js +5 -5
- package/build/components/link-control/index.js.map +1 -1
- package/build/components/link-control/search-create-button.js +1 -3
- package/build/components/link-control/search-create-button.js.map +1 -1
- package/build/components/link-control/search-input.js +5 -3
- package/build/components/link-control/search-input.js.map +1 -1
- package/build/components/link-control/settings-drawer.js +3 -7
- package/build/components/link-control/settings-drawer.js.map +1 -1
- package/build/components/link-control/use-search-handler.js.map +1 -1
- package/build/components/list-view/block-contents.js.map +1 -1
- package/build/components/list-view/block-select-button.js +15 -7
- package/build/components/list-view/block-select-button.js.map +1 -1
- package/build/components/list-view/branch.js.map +1 -1
- package/build/components/list-view/drop-indicator.js +1 -1
- package/build/components/list-view/drop-indicator.js.map +1 -1
- package/build/components/list-view/index.js.map +1 -1
- package/build/components/list-view/use-block-selection.js.map +1 -1
- package/build/components/list-view/use-list-view-drop-zone.js.map +1 -1
- package/build/components/list-view/utils.js +1 -7
- package/build/components/list-view/utils.js.map +1 -1
- package/build/components/media-placeholder/index.js +18 -6
- package/build/components/media-placeholder/index.js.map +1 -1
- package/build/components/media-placeholder/index.native.js +4 -4
- package/build/components/media-placeholder/index.native.js.map +1 -1
- package/build/components/media-replace-flow/index.js +25 -17
- package/build/components/media-replace-flow/index.js.map +1 -1
- package/build/components/media-upload/index.native.js +1 -1
- package/build/components/media-upload/index.native.js.map +1 -1
- package/build/components/navigable-toolbar/index.js.map +1 -1
- package/build/components/plain-text/index.native.js.map +1 -1
- package/build/components/preview-options/index.js +4 -0
- package/build/components/preview-options/index.js.map +1 -1
- package/build/components/provider/use-block-sync.js +5 -3
- package/build/components/provider/use-block-sync.js.map +1 -1
- package/build/components/publish-date-time-picker/index.js +17 -16
- package/build/components/publish-date-time-picker/index.js.map +1 -1
- package/build/components/rich-text/embed-handler-picker.native.js +4 -8
- package/build/components/rich-text/embed-handler-picker.native.js.map +1 -1
- package/build/components/rich-text/index.js.map +1 -1
- package/build/components/rich-text/use-format-types.js.map +1 -1
- package/build/components/rich-text/use-input-rules.js +4 -13
- package/build/components/rich-text/use-input-rules.js.map +1 -1
- package/build/components/rich-text/use-mark-persistent.js.map +1 -1
- package/build/components/rich-text/use-paste-handler.js +20 -5
- package/build/components/rich-text/use-paste-handler.js.map +1 -1
- package/build/components/skip-to-selected-block/index.js.map +1 -1
- package/build/components/ungroup-button/index.native.js +3 -7
- package/build/components/ungroup-button/index.native.js.map +1 -1
- package/build/components/url-input/index.js +14 -3
- package/build/components/url-input/index.js.map +1 -1
- package/build/components/url-popover/index.js +2 -1
- package/build/components/url-popover/index.js.map +1 -1
- package/build/components/use-block-display-information/index.js.map +1 -1
- package/build/components/use-block-drop-zone/index.js.map +1 -1
- package/build/components/use-block-drop-zone/index.native.js.map +1 -1
- package/build/components/use-display-block-controls/index.native.js.map +1 -1
- package/build/components/use-on-block-drop/index.js.map +1 -1
- package/build/components/use-on-block-drop/index.native.js.map +1 -1
- package/build/components/use-setting/index.js.map +1 -1
- package/build/components/writing-flow/use-arrow-nav.js +46 -14
- package/build/components/writing-flow/use-arrow-nav.js.map +1 -1
- package/build/components/writing-flow/use-click-selection.js.map +1 -1
- package/build/components/writing-flow/use-drag-selection.js.map +1 -1
- package/build/components/writing-flow/use-multi-selection.js +3 -47
- package/build/components/writing-flow/use-multi-selection.js.map +1 -1
- package/build/components/writing-flow/use-select-all.js.map +1 -1
- package/build/components/writing-flow/use-selection-observer.js +1 -3
- package/build/components/writing-flow/use-selection-observer.js.map +1 -1
- package/build/components/writing-flow/use-tab-nav.js.map +1 -1
- package/build/elements/index.js +11 -3
- package/build/elements/index.js.map +1 -1
- package/build/hooks/aria-label.js +71 -0
- package/build/hooks/aria-label.js.map +1 -0
- package/build/hooks/color-panel.js.map +1 -1
- package/build/hooks/color-panel.native.js.map +1 -1
- package/build/hooks/color.js +2 -4
- package/build/hooks/color.js.map +1 -1
- package/build/hooks/duotone.js +33 -160
- package/build/hooks/duotone.js.map +1 -1
- package/build/hooks/font-family.js.map +1 -1
- package/build/hooks/gap.js.map +1 -1
- package/build/hooks/index.js +11 -7
- package/build/hooks/index.js.map +1 -1
- package/build/hooks/layout.js +74 -8
- package/build/hooks/layout.js.map +1 -1
- package/build/hooks/utils.js +5 -3
- package/build/hooks/utils.js.map +1 -1
- package/build/index.js +7 -7
- package/build/index.js.map +1 -1
- package/build/layouts/flex.js +42 -38
- package/build/layouts/flex.js.map +1 -1
- package/build/layouts/flow.js +10 -35
- package/build/layouts/flow.js.map +1 -1
- package/build/layouts/utils.js +35 -3
- package/build/layouts/utils.js.map +1 -1
- package/build/store/actions.js +24 -31
- package/build/store/actions.js.map +1 -1
- package/build/store/index.js +0 -4
- package/build/store/index.js.map +1 -1
- package/build/store/reducer.js +23 -12
- package/build/store/reducer.js.map +1 -1
- package/build/store/selectors.js +4 -4
- package/build/store/selectors.js.map +1 -1
- package/build/utils/pasting.js.map +1 -1
- package/build/utils/selection.js +34 -0
- package/build/utils/selection.js.map +1 -0
- package/build/utils/transform-styles/transforms/wrap.js.map +1 -1
- package/build-module/autocompleters/block.js +4 -1
- package/build-module/autocompleters/block.js.map +1 -1
- package/build-module/components/block-actions/index.js.map +1 -1
- package/build-module/components/block-alignment-control/ui.js.map +1 -1
- package/build-module/components/block-alignment-matrix-control/index.js +2 -5
- package/build-module/components/block-alignment-matrix-control/index.js.map +1 -1
- package/build-module/components/block-breadcrumb/index.js.map +1 -1
- package/build-module/components/block-content-overlay/index.js.map +1 -1
- package/build-module/components/block-context/index.js.map +1 -1
- package/build-module/components/block-controls/hook.js.map +1 -1
- package/build-module/components/block-draggable/index.js.map +1 -1
- package/build-module/components/block-draggable/index.native.js.map +1 -1
- package/build-module/components/block-list/block-invalid-warning.native.js +50 -6
- package/build-module/components/block-list/block-invalid-warning.native.js.map +1 -1
- package/build-module/components/block-list/block-list-item.native.js.map +1 -1
- package/build-module/components/block-list/block-selection-button.native.js.map +1 -1
- package/build-module/components/block-list/block.js +2 -2
- package/build-module/components/block-list/block.js.map +1 -1
- package/build-module/components/block-list/block.native.js +2 -1
- package/build-module/components/block-list/block.native.js.map +1 -1
- package/build-module/components/block-list/index.js.map +1 -1
- package/build-module/components/block-list/index.native.js +3 -1
- package/build-module/components/block-list/index.native.js.map +1 -1
- package/build-module/components/block-list/layout.js +19 -4
- package/build-module/components/block-list/layout.js.map +1 -1
- 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-class-names.js +5 -2
- package/build-module/components/block-list/use-block-props/use-block-class-names.js.map +1 -1
- package/build-module/components/block-list/use-block-props/use-block-custom-class-name.js.map +1 -1
- package/build-module/components/block-list/use-block-props/use-selected-block-event-handlers.js.map +1 -1
- package/build-module/components/block-list/use-in-between-inserter.js.map +1 -1
- package/build-module/components/block-list-appender/index.js.map +1 -1
- package/build-module/components/block-list-appender/index.native.js.map +1 -1
- package/build-module/components/block-lock/modal.js +37 -6
- package/build-module/components/block-lock/modal.js.map +1 -1
- package/build-module/components/block-mobile-toolbar/block-actions-menu.native.js.map +1 -1
- package/build-module/components/block-mover/button.js.map +1 -1
- package/build-module/components/block-mover/index.native.js.map +1 -1
- package/build-module/components/block-parent-selector/index.js.map +1 -1
- package/build-module/components/block-pattern-setup/index.js +9 -27
- package/build-module/components/block-pattern-setup/index.js.map +1 -1
- package/build-module/components/block-pattern-setup/setup-toolbar.js +3 -8
- package/build-module/components/block-pattern-setup/setup-toolbar.js.map +1 -1
- package/build-module/components/block-popover/inbetween.js +1 -1
- package/build-module/components/block-popover/inbetween.js.map +1 -1
- package/build-module/components/block-popover/index.js +1 -1
- package/build-module/components/block-popover/index.js.map +1 -1
- package/build-module/components/block-preview/auto.js +20 -5
- package/build-module/components/block-preview/auto.js.map +1 -1
- package/build-module/components/block-selection-clearer/index.js.map +1 -1
- package/build-module/components/block-settings-menu/block-edit-visually-button.js +56 -0
- package/build-module/components/block-settings-menu/block-edit-visually-button.js.map +1 -0
- package/build-module/components/block-settings-menu/block-mode-toggle.js +4 -6
- package/build-module/components/block-settings-menu/block-mode-toggle.js.map +1 -1
- package/build-module/components/block-settings-menu/block-settings-dropdown.js +10 -3
- package/build-module/components/block-settings-menu/block-settings-dropdown.js.map +1 -1
- package/build-module/components/block-settings-menu/index.js +6 -3
- package/build-module/components/block-settings-menu/index.js.map +1 -1
- package/build-module/components/block-settings-menu-controls/index.js +5 -2
- package/build-module/components/block-settings-menu-controls/index.js.map +1 -1
- package/build-module/components/block-styles/index.js +5 -2
- package/build-module/components/block-styles/index.js.map +1 -1
- package/build-module/components/block-styles/menu-items.js +3 -5
- package/build-module/components/block-styles/menu-items.js.map +1 -1
- package/build-module/components/block-styles/preview.native.js +3 -2
- package/build-module/components/block-styles/preview.native.js.map +1 -1
- package/build-module/components/block-switcher/block-transformations-menu.js.map +1 -1
- package/build-module/components/block-switcher/index.js +7 -1
- package/build-module/components/block-switcher/index.js.map +1 -1
- package/build-module/components/block-title/index.js +8 -2
- package/build-module/components/block-title/index.js.map +1 -1
- package/build-module/components/block-title/use-block-display-title.js +15 -14
- package/build-module/components/block-title/use-block-display-title.js.map +1 -1
- package/build-module/components/block-toolbar/index.native.js.map +1 -1
- package/build-module/components/block-toolbar/utils.js +3 -5
- package/build-module/components/block-toolbar/utils.js.map +1 -1
- package/build-module/components/block-tools/block-contextual-toolbar.js +1 -1
- package/build-module/components/block-tools/block-contextual-toolbar.js.map +1 -1
- package/build-module/components/block-tools/index.js.map +1 -1
- package/build-module/components/block-types-list/index.native.js.map +1 -1
- package/build-module/components/block-variation-transforms/index.js.map +1 -1
- package/build-module/components/border-radius-control/index.js +2 -0
- package/build-module/components/border-radius-control/index.js.map +1 -1
- package/build-module/components/color-style-selector/index.js.map +1 -1
- package/build-module/components/colors/with-colors.js +2 -2
- package/build-module/components/colors/with-colors.js.map +1 -1
- package/build-module/components/colors-gradients/control.js +46 -40
- package/build-module/components/colors-gradients/control.js.map +1 -1
- package/build-module/components/colors-gradients/dropdown.js +2 -1
- package/build-module/components/colors-gradients/dropdown.js.map +1 -1
- package/build-module/components/convert-to-group-buttons/toolbar.js.map +1 -1
- package/build-module/components/copy-handler/index.js +18 -2
- package/build-module/components/copy-handler/index.js.map +1 -1
- package/build-module/components/date-format-picker/index.js +1 -1
- package/build-module/components/date-format-picker/index.js.map +1 -1
- package/build-module/components/default-block-appender/index.js.map +1 -1
- package/build-module/components/default-block-appender/index.native.js.map +1 -1
- package/build-module/components/default-style-picker/index.js.map +1 -1
- package/build-module/components/duotone/components.js +130 -0
- package/build-module/components/duotone/components.js.map +1 -0
- package/build-module/components/duotone/index.js +3 -0
- package/build-module/components/duotone/index.js.map +1 -0
- package/build-module/components/duotone/utils.js +30 -0
- package/build-module/components/duotone/utils.js.map +1 -0
- package/build-module/components/duotone-control/index.js +18 -6
- package/build-module/components/duotone-control/index.js.map +1 -1
- package/build-module/components/font-sizes/with-font-sizes.js.map +1 -1
- package/build-module/components/iframe/index.js +19 -6
- package/build-module/components/iframe/index.js.map +1 -1
- package/build-module/components/image-editor/aspect-ratio-dropdown.js.map +1 -1
- package/build-module/components/image-size-control/index.js +4 -1
- package/build-module/components/image-size-control/index.js.map +1 -1
- package/build-module/components/index.js +3 -0
- package/build-module/components/index.js.map +1 -1
- package/build-module/components/inner-blocks/use-inner-block-template-sync.js.map +1 -1
- package/build-module/components/inner-blocks/use-nested-settings-update.js.map +1 -1
- package/build-module/components/inserter/block-types-tab.native.js.map +1 -1
- package/build-module/components/inserter/hooks/use-block-type-impressions.native.js.map +1 -1
- package/build-module/components/inserter/hooks/use-insertion-point.js.map +1 -1
- package/build-module/components/inserter/hooks/use-patterns-state.js.map +1 -1
- package/build-module/components/inserter/index.js +3 -2
- package/build-module/components/inserter/index.js.map +1 -1
- package/build-module/components/inserter/index.native.js.map +1 -1
- package/build-module/components/inserter/library.js +2 -5
- package/build-module/components/inserter/library.js.map +1 -1
- package/build-module/components/inserter/menu.js.map +1 -1
- package/build-module/components/inserter/menu.native.js.map +1 -1
- package/build-module/components/inserter/no-results.native.js.map +1 -1
- package/build-module/components/inserter/quick-inserter.js.map +1 -1
- package/build-module/components/inserter/search-items.js +2 -2
- package/build-module/components/inserter/search-items.js.map +1 -1
- package/build-module/components/inserter/search-results.native.js.map +1 -1
- package/build-module/components/inspector-popover-header/index.js +46 -0
- package/build-module/components/inspector-popover-header/index.js.map +1 -0
- package/build-module/components/line-height-control/index.js.map +1 -1
- package/build-module/components/link-control/index.js +3 -2
- package/build-module/components/link-control/index.js.map +1 -1
- package/build-module/components/link-control/search-create-button.js +1 -2
- package/build-module/components/link-control/search-create-button.js.map +1 -1
- package/build-module/components/link-control/search-input.js +3 -1
- package/build-module/components/link-control/search-input.js.map +1 -1
- package/build-module/components/link-control/settings-drawer.js +2 -5
- package/build-module/components/link-control/settings-drawer.js.map +1 -1
- package/build-module/components/link-control/use-search-handler.js.map +1 -1
- package/build-module/components/list-view/block-contents.js.map +1 -1
- package/build-module/components/list-view/block-select-button.js +16 -8
- package/build-module/components/list-view/block-select-button.js.map +1 -1
- package/build-module/components/list-view/branch.js.map +1 -1
- package/build-module/components/list-view/drop-indicator.js +1 -1
- package/build-module/components/list-view/drop-indicator.js.map +1 -1
- package/build-module/components/list-view/index.js.map +1 -1
- package/build-module/components/list-view/use-block-selection.js.map +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 +1 -6
- package/build-module/components/list-view/utils.js.map +1 -1
- package/build-module/components/media-placeholder/index.js +16 -3
- package/build-module/components/media-placeholder/index.js.map +1 -1
- package/build-module/components/media-placeholder/index.native.js +5 -3
- package/build-module/components/media-placeholder/index.native.js.map +1 -1
- package/build-module/components/media-replace-flow/index.js +27 -18
- package/build-module/components/media-replace-flow/index.js.map +1 -1
- package/build-module/components/media-upload/index.native.js +1 -1
- package/build-module/components/media-upload/index.native.js.map +1 -1
- package/build-module/components/navigable-toolbar/index.js.map +1 -1
- package/build-module/components/plain-text/index.native.js.map +1 -1
- package/build-module/components/preview-options/index.js +4 -0
- package/build-module/components/preview-options/index.js.map +1 -1
- package/build-module/components/provider/use-block-sync.js +4 -1
- package/build-module/components/provider/use-block-sync.js.map +1 -1
- package/build-module/components/publish-date-time-picker/index.js +16 -16
- package/build-module/components/publish-date-time-picker/index.js.map +1 -1
- package/build-module/components/rich-text/embed-handler-picker.native.js +3 -5
- package/build-module/components/rich-text/embed-handler-picker.native.js.map +1 -1
- package/build-module/components/rich-text/index.js.map +1 -1
- package/build-module/components/rich-text/use-format-types.js.map +1 -1
- package/build-module/components/rich-text/use-input-rules.js +3 -11
- package/build-module/components/rich-text/use-input-rules.js.map +1 -1
- package/build-module/components/rich-text/use-mark-persistent.js.map +1 -1
- package/build-module/components/rich-text/use-paste-handler.js +20 -5
- package/build-module/components/rich-text/use-paste-handler.js.map +1 -1
- package/build-module/components/skip-to-selected-block/index.js.map +1 -1
- package/build-module/components/ungroup-button/index.native.js +3 -5
- package/build-module/components/ungroup-button/index.native.js.map +1 -1
- package/build-module/components/url-input/index.js +11 -1
- package/build-module/components/url-input/index.js.map +1 -1
- package/build-module/components/url-popover/index.js +2 -1
- package/build-module/components/url-popover/index.js.map +1 -1
- package/build-module/components/use-block-display-information/index.js.map +1 -1
- package/build-module/components/use-block-drop-zone/index.js.map +1 -1
- package/build-module/components/use-block-drop-zone/index.native.js.map +1 -1
- package/build-module/components/use-display-block-controls/index.native.js.map +1 -1
- package/build-module/components/use-on-block-drop/index.js.map +1 -1
- package/build-module/components/use-on-block-drop/index.native.js.map +1 -1
- package/build-module/components/use-setting/index.js.map +1 -1
- package/build-module/components/writing-flow/use-arrow-nav.js +47 -14
- package/build-module/components/writing-flow/use-arrow-nav.js.map +1 -1
- package/build-module/components/writing-flow/use-click-selection.js.map +1 -1
- package/build-module/components/writing-flow/use-drag-selection.js.map +1 -1
- package/build-module/components/writing-flow/use-multi-selection.js +3 -45
- package/build-module/components/writing-flow/use-multi-selection.js.map +1 -1
- package/build-module/components/writing-flow/use-select-all.js.map +1 -1
- package/build-module/components/writing-flow/use-selection-observer.js +1 -3
- package/build-module/components/writing-flow/use-selection-observer.js.map +1 -1
- package/build-module/components/writing-flow/use-tab-nav.js.map +1 -1
- package/build-module/elements/index.js +7 -1
- package/build-module/elements/index.js.map +1 -1
- package/build-module/hooks/aria-label.js +59 -0
- package/build-module/hooks/aria-label.js.map +1 -0
- package/build-module/hooks/color-panel.js.map +1 -1
- package/build-module/hooks/color-panel.native.js.map +1 -1
- package/build-module/hooks/color.js +2 -3
- package/build-module/hooks/color.js.map +1 -1
- package/build-module/hooks/duotone.js +22 -140
- package/build-module/hooks/duotone.js.map +1 -1
- package/build-module/hooks/font-family.js.map +1 -1
- package/build-module/hooks/gap.js.map +1 -1
- package/build-module/hooks/index.js +2 -1
- package/build-module/hooks/index.js.map +1 -1
- package/build-module/hooks/layout.js +76 -10
- package/build-module/hooks/layout.js.map +1 -1
- package/build-module/hooks/utils.js +5 -2
- package/build-module/hooks/utils.js.map +1 -1
- package/build-module/index.js +1 -1
- package/build-module/index.js.map +1 -1
- package/build-module/layouts/flex.js +43 -35
- package/build-module/layouts/flex.js.map +1 -1
- package/build-module/layouts/flow.js +11 -36
- package/build-module/layouts/flow.js.map +1 -1
- package/build-module/layouts/utils.js +33 -3
- package/build-module/layouts/utils.js.map +1 -1
- package/build-module/store/actions.js +14 -20
- package/build-module/store/actions.js.map +1 -1
- package/build-module/store/index.js +0 -4
- package/build-module/store/index.js.map +1 -1
- package/build-module/store/reducer.js +23 -11
- package/build-module/store/reducer.js.map +1 -1
- package/build-module/store/selectors.js +5 -5
- package/build-module/store/selectors.js.map +1 -1
- package/build-module/utils/pasting.js.map +1 -1
- package/build-module/utils/selection.js +24 -0
- package/build-module/utils/selection.js.map +1 -0
- package/build-module/utils/transform-styles/transforms/wrap.js.map +1 -1
- package/build-style/style-rtl.css +57 -34
- package/build-style/style.css +57 -34
- package/package.json +28 -28
- package/src/autocompleters/block.js +2 -1
- package/src/components/block-actions/index.js +2 -3
- package/src/components/block-alignment-control/ui.js +4 -6
- package/src/components/block-alignment-matrix-control/index.js +2 -4
- package/src/components/block-breadcrumb/index.js +2 -5
- package/src/components/block-compare/test/block-view.js +2 -1
- package/src/components/block-content-overlay/index.js +2 -5
- package/src/components/block-context/index.js +4 -4
- package/src/components/block-controls/hook.js +2 -3
- package/src/components/block-draggable/index.js +6 -13
- package/src/components/block-draggable/index.native.js +6 -14
- package/src/components/block-draggable/test/helpers.native.js +3 -3
- package/src/components/block-draggable/test/index.native.js +12 -15
- package/src/components/block-edit/test/edit.js +2 -1
- package/src/components/block-list/block-invalid-warning.native.js +42 -7
- package/src/components/block-list/block-list-item.native.js +4 -12
- package/src/components/block-list/block-selection-button.native.js +2 -3
- package/src/components/block-list/block.js +10 -12
- package/src/components/block-list/block.native.js +11 -15
- package/src/components/block-list/index.js +2 -3
- package/src/components/block-list/index.native.js +13 -22
- package/src/components/block-list/layout.js +15 -3
- package/src/components/block-list/style.scss +2 -2
- package/src/components/block-list/test/block-list-context.native.js +8 -16
- package/src/components/block-list/use-block-props/index.js +6 -3
- package/src/components/block-list/use-block-props/use-block-class-names.js +5 -1
- package/src/components/block-list/use-block-props/use-block-custom-class-name.js +2 -3
- package/src/components/block-list/use-block-props/use-selected-block-event-handlers.js +2 -3
- package/src/components/block-list/use-in-between-inserter.js +2 -3
- package/src/components/block-list-appender/index.js +2 -5
- package/src/components/block-list-appender/index.native.js +2 -3
- package/src/components/block-lock/modal.js +42 -4
- package/src/components/block-lock/style.scss +10 -0
- package/src/components/block-mobile-toolbar/block-actions-menu.native.js +4 -6
- package/src/components/block-mover/button.js +2 -3
- package/src/components/block-mover/index.native.js +4 -6
- package/src/components/block-parent-selector/index.js +2 -3
- package/src/components/block-pattern-setup/index.js +5 -27
- package/src/components/block-pattern-setup/setup-toolbar.js +2 -9
- package/src/components/block-pattern-setup/style.scss +4 -2
- package/src/components/block-popover/inbetween.js +1 -1
- package/src/components/block-popover/index.js +1 -1
- package/src/components/block-preview/auto.js +21 -11
- package/src/components/block-selection-clearer/index.js +2 -3
- package/src/components/block-settings-menu/block-edit-visually-button.js +52 -0
- package/src/components/block-settings-menu/block-mode-toggle.js +5 -8
- package/src/components/block-settings-menu/block-settings-dropdown.js +13 -9
- package/src/components/block-settings-menu/index.js +15 -11
- package/src/components/block-settings-menu-controls/index.js +3 -2
- package/src/components/block-styles/index.js +3 -1
- package/src/components/block-styles/menu-items.js +2 -5
- package/src/components/block-styles/preview.native.js +3 -2
- package/src/components/block-switcher/block-transformations-menu.js +2 -4
- package/src/components/block-switcher/index.js +7 -1
- package/src/components/block-title/index.js +3 -2
- package/src/components/block-title/use-block-display-title.js +20 -12
- package/src/components/block-toolbar/index.native.js +2 -5
- package/src/components/block-toolbar/utils.js +3 -11
- package/src/components/block-tools/block-contextual-toolbar.js +5 -6
- package/src/components/block-tools/index.js +2 -3
- package/src/components/block-types-list/index.native.js +2 -4
- package/src/components/block-variation-transforms/index.js +4 -6
- package/src/components/border-radius-control/index.js +2 -0
- package/src/components/color-palette/test/control.js +2 -1
- package/src/components/color-style-selector/index.js +27 -28
- package/src/components/colors/test/with-colors.js +14 -14
- package/src/components/colors/with-colors.js +10 -14
- package/src/components/colors-gradients/control.js +77 -65
- package/src/components/colors-gradients/dropdown.js +22 -16
- package/src/components/colors-gradients/style.scss +4 -0
- package/src/components/colors-gradients/test/control.js +25 -32
- package/src/components/convert-to-group-buttons/toolbar.js +2 -6
- package/src/components/copy-handler/README.md +7 -2
- package/src/components/copy-handler/index.js +26 -6
- package/src/components/date-format-picker/index.js +1 -0
- package/src/components/default-block-appender/index.js +4 -6
- package/src/components/default-block-appender/index.native.js +4 -9
- package/src/components/default-style-picker/index.js +20 -21
- package/src/components/duotone/components.js +133 -0
- package/src/components/duotone/index.js +7 -0
- package/src/components/duotone/utils.js +25 -0
- package/src/components/duotone-control/index.js +12 -7
- package/src/components/duotone-control/style.scss +5 -0
- package/src/components/font-sizes/with-font-sizes.js +2 -3
- package/src/components/iframe/index.js +25 -6
- package/src/components/image-editor/aspect-ratio-dropdown.js +2 -6
- package/src/components/image-size-control/index.js +4 -7
- package/src/components/index.js +3 -0
- package/src/components/inner-blocks/use-inner-block-template-sync.js +2 -3
- package/src/components/inner-blocks/use-nested-settings-update.js +6 -9
- package/src/components/inserter/block-types-tab.native.js +2 -3
- package/src/components/inserter/hooks/use-block-type-impressions.native.js +2 -3
- package/src/components/inserter/hooks/use-insertion-point.js +3 -2
- package/src/components/inserter/hooks/use-patterns-state.js +4 -5
- package/src/components/inserter/index.js +7 -11
- package/src/components/inserter/index.native.js +6 -11
- package/src/components/inserter/library.js +2 -5
- package/src/components/inserter/menu.js +14 -19
- package/src/components/inserter/menu.native.js +8 -6
- package/src/components/inserter/no-results.native.js +2 -1
- package/src/components/inserter/quick-inserter.js +2 -3
- package/src/components/inserter/search-items.js +6 -6
- package/src/components/inserter/search-results.native.js +4 -6
- package/src/components/inserter/style.scss +1 -1
- package/src/components/inspector-popover-header/README.md +76 -0
- package/src/components/inspector-popover-header/index.js +56 -0
- package/src/components/inspector-popover-header/style.scss +16 -0
- package/src/components/line-height-control/index.js +1 -2
- package/src/components/link-control/index.js +5 -4
- package/src/components/link-control/search-create-button.js +4 -2
- package/src/components/link-control/search-input.js +3 -1
- package/src/components/link-control/settings-drawer.js +2 -5
- package/src/components/link-control/test/fixtures/index.js +5 -7
- package/src/components/link-control/test/index.js +85 -106
- package/src/components/link-control/use-search-handler.js +2 -2
- package/src/components/list-view/block-contents.js +2 -4
- package/src/components/list-view/block-select-button.js +29 -14
- package/src/components/list-view/branch.js +22 -23
- package/src/components/list-view/drop-indicator.js +1 -1
- package/src/components/list-view/index.js +4 -8
- package/src/components/list-view/style.scss +18 -4
- package/src/components/list-view/use-block-selection.js +5 -5
- package/src/components/list-view/use-list-view-drop-zone.js +2 -1
- package/src/components/list-view/utils.js +1 -6
- package/src/components/media-placeholder/index.js +22 -1
- package/src/components/media-placeholder/index.native.js +9 -5
- package/src/components/media-replace-flow/index.js +78 -56
- package/src/components/media-replace-flow/test/index.js +14 -4
- package/src/components/media-upload/README.md +8 -0
- package/src/components/media-upload/index.native.js +1 -1
- package/src/components/navigable-toolbar/index.js +1 -2
- package/src/components/panel-color-settings/test/index.js +2 -1
- package/src/components/plain-text/index.native.js +2 -6
- package/src/components/preview-options/index.js +4 -0
- package/src/components/provider/use-block-sync.js +5 -2
- package/src/components/publish-date-time-picker/README.md +1 -1
- package/src/components/publish-date-time-picker/index.js +18 -27
- package/src/components/responsive-block-control/README.md +3 -1
- package/src/components/responsive-block-control/test/index.js +4 -4
- package/src/components/rich-text/embed-handler-picker.native.js +2 -5
- package/src/components/rich-text/index.js +7 -4
- package/src/components/rich-text/use-format-types.js +16 -16
- package/src/components/rich-text/use-input-rules.js +6 -15
- package/src/components/rich-text/use-mark-persistent.js +2 -3
- package/src/components/rich-text/use-paste-handler.js +17 -5
- package/src/components/skip-to-selected-block/index.js +2 -3
- package/src/components/ungroup-button/index.native.js +4 -8
- package/src/components/url-input/index.js +21 -20
- package/src/components/url-popover/index.js +1 -0
- package/src/components/url-popover/test/__snapshots__/index.js.snap +3 -0
- package/src/components/use-block-display-information/index.js +4 -6
- package/src/components/use-block-drop-zone/index.js +2 -3
- package/src/components/use-block-drop-zone/index.native.js +2 -4
- package/src/components/use-block-drop-zone/test/index.js +22 -23
- package/src/components/use-display-block-controls/index.native.js +2 -3
- package/src/components/use-no-recursive-renders/test/use-no-recursive-renders.js +2 -3
- package/src/components/use-on-block-drop/index.js +2 -5
- package/src/components/use-on-block-drop/index.native.js +4 -8
- package/src/components/use-setting/index.js +8 -6
- package/src/components/writing-flow/test/index.js +22 -4
- package/src/components/writing-flow/use-arrow-nav.js +54 -11
- package/src/components/writing-flow/use-click-selection.js +2 -5
- package/src/components/writing-flow/use-drag-selection.js +6 -9
- package/src/components/writing-flow/use-multi-selection.js +1 -50
- package/src/components/writing-flow/use-select-all.js +2 -5
- package/src/components/writing-flow/use-selection-observer.js +6 -9
- package/src/components/writing-flow/use-tab-nav.js +2 -5
- package/src/elements/index.js +8 -1
- package/src/elements/test/index.js +18 -0
- package/src/hooks/aria-label.js +67 -0
- package/src/hooks/color-panel.js +4 -4
- package/src/hooks/color-panel.native.js +2 -2
- package/src/hooks/color.js +12 -5
- package/src/hooks/duotone.js +18 -139
- package/src/hooks/font-family.js +4 -2
- package/src/hooks/gap.js +2 -3
- package/src/hooks/index.js +2 -1
- package/src/hooks/layout.js +102 -15
- package/src/hooks/test/align.js +2 -1
- package/src/hooks/test/generated-class-name.js +2 -5
- package/src/hooks/test/utils.js +2 -5
- package/src/hooks/utils.js +7 -3
- package/src/index.js +1 -1
- package/src/layouts/flex.js +49 -43
- package/src/layouts/flow.js +14 -35
- package/src/layouts/test/flex.js +21 -0
- package/src/layouts/test/flow.js +21 -0
- package/src/layouts/test/utils.js +138 -0
- package/src/layouts/utils.js +44 -3
- package/src/store/actions.js +763 -733
- package/src/store/index.js +0 -4
- package/src/store/reducer.js +208 -184
- package/src/store/selectors.js +57 -58
- package/src/store/test/actions.js +2 -1
- package/src/store/test/reducer.js +140 -10
- package/src/store/test/selectors.js +20 -27
- package/src/style.scss +1 -1
- package/src/utils/pasting.js +3 -3
- package/src/utils/selection.js +26 -0
- package/src/utils/test/selection.js +39 -0
- package/src/utils/transform-styles/transforms/wrap.js +30 -28
- package/tsconfig.json +2 -1
- package/tsconfig.tsbuildinfo +1 -1
- package/src/components/publish-date-time-picker/style.scss +0 -20
|
@@ -22,9 +22,8 @@ export function useBlockCustomClassName( clientId ) {
|
|
|
22
22
|
// as much.
|
|
23
23
|
return useSelect(
|
|
24
24
|
( select ) => {
|
|
25
|
-
const { getBlockName, getBlockAttributes } =
|
|
26
|
-
blockEditorStore
|
|
27
|
-
);
|
|
25
|
+
const { getBlockName, getBlockAttributes } =
|
|
26
|
+
select( blockEditorStore );
|
|
28
27
|
const attributes = getBlockAttributes( clientId );
|
|
29
28
|
|
|
30
29
|
if ( ! attributes?.className ) {
|
|
@@ -24,9 +24,8 @@ export function useEventHandlers( clientId ) {
|
|
|
24
24
|
( select ) => select( blockEditorStore ).isBlockSelected( clientId ),
|
|
25
25
|
[ clientId ]
|
|
26
26
|
);
|
|
27
|
-
const { getBlockRootClientId, getBlockIndex } =
|
|
28
|
-
blockEditorStore
|
|
29
|
-
);
|
|
27
|
+
const { getBlockRootClientId, getBlockIndex } =
|
|
28
|
+
useSelect( blockEditorStore );
|
|
30
29
|
const { insertDefaultBlock, removeBlock } = useDispatch( blockEditorStore );
|
|
31
30
|
|
|
32
31
|
return useRefEffect(
|
|
@@ -27,9 +27,8 @@ export function useInBetweenInserter() {
|
|
|
27
27
|
getSelectedBlockClientIds,
|
|
28
28
|
getTemplateLock,
|
|
29
29
|
} = useSelect( blockEditorStore );
|
|
30
|
-
const { showInsertionPoint, hideInsertionPoint } =
|
|
31
|
-
blockEditorStore
|
|
32
|
-
);
|
|
30
|
+
const { showInsertionPoint, hideInsertionPoint } =
|
|
31
|
+
useDispatch( blockEditorStore );
|
|
33
32
|
|
|
34
33
|
return useRefEffect(
|
|
35
34
|
( node ) => {
|
|
@@ -93,11 +93,8 @@ function BlockListAppender( {
|
|
|
93
93
|
}
|
|
94
94
|
|
|
95
95
|
export default withSelect( ( select, { rootClientId } ) => {
|
|
96
|
-
const {
|
|
97
|
-
|
|
98
|
-
getTemplateLock,
|
|
99
|
-
getSelectedBlockClientId,
|
|
100
|
-
} = select( blockEditorStore );
|
|
96
|
+
const { canInsertBlockType, getTemplateLock, getSelectedBlockClientId } =
|
|
97
|
+
select( blockEditorStore );
|
|
101
98
|
|
|
102
99
|
return {
|
|
103
100
|
isLocked: !! getTemplateLock( rootClientId ),
|
|
@@ -48,9 +48,8 @@ function BlockListAppender( {
|
|
|
48
48
|
}
|
|
49
49
|
|
|
50
50
|
export default withSelect( ( select, { rootClientId } ) => {
|
|
51
|
-
const { getBlockOrder, canInsertBlockType, getTemplateLock } =
|
|
52
|
-
blockEditorStore
|
|
53
|
-
);
|
|
51
|
+
const { getBlockOrder, canInsertBlockType, getTemplateLock } =
|
|
52
|
+
select( blockEditorStore );
|
|
54
53
|
|
|
55
54
|
return {
|
|
56
55
|
isLocked: !! getTemplateLock( rootClientId ),
|
|
@@ -10,6 +10,7 @@ import {
|
|
|
10
10
|
FlexItem,
|
|
11
11
|
Icon,
|
|
12
12
|
Modal,
|
|
13
|
+
ToggleControl,
|
|
13
14
|
} from '@wordpress/components';
|
|
14
15
|
import { lock as lockIcon, unlock as unlockIcon } from '@wordpress/icons';
|
|
15
16
|
import { useInstanceId } from '@wordpress/compose';
|
|
@@ -23,20 +24,41 @@ import useBlockLock from './use-block-lock';
|
|
|
23
24
|
import useBlockDisplayInformation from '../use-block-display-information';
|
|
24
25
|
import { store as blockEditorStore } from '../../store';
|
|
25
26
|
|
|
27
|
+
function getTemplateLockValue( lock ) {
|
|
28
|
+
// Prevents all operations.
|
|
29
|
+
if ( lock.remove && lock.move ) {
|
|
30
|
+
return 'all';
|
|
31
|
+
}
|
|
32
|
+
|
|
33
|
+
// Prevents inserting or removing blocks, but allows moving existing blocks.
|
|
34
|
+
if ( lock.remove && ! lock.move ) {
|
|
35
|
+
return 'insert';
|
|
36
|
+
}
|
|
37
|
+
|
|
38
|
+
return false;
|
|
39
|
+
}
|
|
40
|
+
|
|
26
41
|
export default function BlockLockModal( { clientId, onClose } ) {
|
|
27
42
|
const [ lock, setLock ] = useState( { move: false, remove: false } );
|
|
28
43
|
const { canEdit, canMove, canRemove } = useBlockLock( clientId );
|
|
29
|
-
const { isReusable } = useSelect(
|
|
44
|
+
const { isReusable, templateLock, hasTemplateLock } = useSelect(
|
|
30
45
|
( select ) => {
|
|
31
|
-
const { getBlockName } =
|
|
46
|
+
const { getBlockName, getBlockAttributes } =
|
|
47
|
+
select( blockEditorStore );
|
|
32
48
|
const blockName = getBlockName( clientId );
|
|
49
|
+
const blockType = getBlockType( blockName );
|
|
33
50
|
|
|
34
51
|
return {
|
|
35
|
-
isReusable: isReusableBlock(
|
|
52
|
+
isReusable: isReusableBlock( blockType ),
|
|
53
|
+
templateLock: getBlockAttributes( clientId )?.templateLock,
|
|
54
|
+
hasTemplateLock: !! blockType?.attributes?.templateLock,
|
|
36
55
|
};
|
|
37
56
|
},
|
|
38
57
|
[ clientId ]
|
|
39
58
|
);
|
|
59
|
+
const [ applyTemplateLock, setApplyTemplateLock ] = useState(
|
|
60
|
+
!! templateLock
|
|
61
|
+
);
|
|
40
62
|
const { updateBlockAttributes } = useDispatch( blockEditorStore );
|
|
41
63
|
const blockInformation = useBlockDisplayInformation( clientId );
|
|
42
64
|
const instanceId = useInstanceId(
|
|
@@ -69,7 +91,12 @@ export default function BlockLockModal( { clientId, onClose } ) {
|
|
|
69
91
|
<form
|
|
70
92
|
onSubmit={ ( event ) => {
|
|
71
93
|
event.preventDefault();
|
|
72
|
-
updateBlockAttributes( [ clientId ], {
|
|
94
|
+
updateBlockAttributes( [ clientId ], {
|
|
95
|
+
lock,
|
|
96
|
+
templateLock: applyTemplateLock
|
|
97
|
+
? getTemplateLockValue( lock )
|
|
98
|
+
: undefined,
|
|
99
|
+
} );
|
|
73
100
|
onClose();
|
|
74
101
|
} }
|
|
75
102
|
>
|
|
@@ -171,6 +198,17 @@ export default function BlockLockModal( { clientId, onClose } ) {
|
|
|
171
198
|
/>
|
|
172
199
|
</li>
|
|
173
200
|
</ul>
|
|
201
|
+
{ hasTemplateLock && (
|
|
202
|
+
<ToggleControl
|
|
203
|
+
className="block-editor-block-lock-modal__template-lock"
|
|
204
|
+
label={ __( 'Apply to all blocks inside' ) }
|
|
205
|
+
checked={ applyTemplateLock }
|
|
206
|
+
disabled={ lock.move && ! lock.remove }
|
|
207
|
+
onChange={ () =>
|
|
208
|
+
setApplyTemplateLock( ! applyTemplateLock )
|
|
209
|
+
}
|
|
210
|
+
/>
|
|
211
|
+
) }
|
|
174
212
|
</div>
|
|
175
213
|
<Flex
|
|
176
214
|
className="block-editor-block-lock-modal__actions"
|
|
@@ -53,6 +53,16 @@
|
|
|
53
53
|
}
|
|
54
54
|
}
|
|
55
55
|
|
|
56
|
+
.block-editor-block-lock-modal__template-lock {
|
|
57
|
+
border-top: $border-width solid $gray-300;
|
|
58
|
+
margin-top: $grid-unit-20;
|
|
59
|
+
padding: $grid-unit-15 0;
|
|
60
|
+
|
|
61
|
+
.components-base-control__field {
|
|
62
|
+
margin: 0;
|
|
63
|
+
}
|
|
64
|
+
}
|
|
65
|
+
|
|
56
66
|
.block-editor-block-lock-modal__actions {
|
|
57
67
|
margin-top: $grid-unit-30;
|
|
58
68
|
}
|
|
@@ -386,14 +386,12 @@ export default compose(
|
|
|
386
386
|
clearSelectedBlock,
|
|
387
387
|
} = dispatch( blockEditorStore );
|
|
388
388
|
const { openGeneralSidebar } = dispatch( 'core/edit-post' );
|
|
389
|
-
const { getBlockSelectionEnd, getBlock } =
|
|
390
|
-
blockEditorStore
|
|
391
|
-
);
|
|
389
|
+
const { getBlockSelectionEnd, getBlock } =
|
|
390
|
+
select( blockEditorStore );
|
|
392
391
|
const { createSuccessNotice } = dispatch( noticesStore );
|
|
393
392
|
|
|
394
|
-
const {
|
|
395
|
-
|
|
396
|
-
} = dispatch( reusableBlocksStore );
|
|
393
|
+
const { __experimentalConvertBlockToStatic: convertBlockToStatic } =
|
|
394
|
+
dispatch( reusableBlocksStore );
|
|
397
395
|
|
|
398
396
|
return {
|
|
399
397
|
createSuccessNotice,
|
|
@@ -108,9 +108,8 @@ const BlockMoverButton = forwardRef(
|
|
|
108
108
|
[ clientIds, direction ]
|
|
109
109
|
);
|
|
110
110
|
|
|
111
|
-
const { moveBlocksDown, moveBlocksUp } =
|
|
112
|
-
blockEditorStore
|
|
113
|
-
);
|
|
111
|
+
const { moveBlocksDown, moveBlocksUp } =
|
|
112
|
+
useDispatch( blockEditorStore );
|
|
114
113
|
const moverFunction =
|
|
115
114
|
direction === 'up' ? moveBlocksUp : moveBlocksDown;
|
|
116
115
|
|
|
@@ -37,9 +37,8 @@ export const BlockMover = ( {
|
|
|
37
37
|
} ) => {
|
|
38
38
|
const pickerRef = useRef();
|
|
39
39
|
const [ shouldPresentPicker, setShouldPresentPicker ] = useState( false );
|
|
40
|
-
const [ blockPageMoverState, setBlockPageMoverState ] =
|
|
41
|
-
undefined
|
|
42
|
-
);
|
|
40
|
+
const [ blockPageMoverState, setBlockPageMoverState ] =
|
|
41
|
+
useState( undefined );
|
|
43
42
|
const showBlockPageMover = ( direction ) => () => {
|
|
44
43
|
if ( ! pickerRef.current ) {
|
|
45
44
|
setBlockPageMoverState( undefined );
|
|
@@ -167,9 +166,8 @@ export default compose(
|
|
|
167
166
|
};
|
|
168
167
|
} ),
|
|
169
168
|
withDispatch( ( dispatch, { clientIds, rootClientId } ) => {
|
|
170
|
-
const { moveBlocksDown, moveBlocksUp, moveBlocksToPosition } =
|
|
171
|
-
blockEditorStore
|
|
172
|
-
);
|
|
169
|
+
const { moveBlocksDown, moveBlocksUp, moveBlocksToPosition } =
|
|
170
|
+
dispatch( blockEditorStore );
|
|
173
171
|
return {
|
|
174
172
|
onMoveDown: partial( moveBlocksDown, clientIds, rootClientId ),
|
|
175
173
|
onMoveUp: partial( moveBlocksUp, clientIds, rootClientId ),
|
|
@@ -22,9 +22,8 @@ import { store as blockEditorStore } from '../../store';
|
|
|
22
22
|
* @return {WPComponent} Parent block selector.
|
|
23
23
|
*/
|
|
24
24
|
export default function BlockParentSelector() {
|
|
25
|
-
const { selectBlock, toggleBlockHighlight } =
|
|
26
|
-
blockEditorStore
|
|
27
|
-
);
|
|
25
|
+
const { selectBlock, toggleBlockHighlight } =
|
|
26
|
+
useDispatch( blockEditorStore );
|
|
28
27
|
const { firstParentClientId, shouldHide, hasReducedUI } = useSelect(
|
|
29
28
|
( select ) => {
|
|
30
29
|
const {
|
|
@@ -11,7 +11,7 @@ import {
|
|
|
11
11
|
} from '@wordpress/components';
|
|
12
12
|
|
|
13
13
|
import { useState } from '@wordpress/element';
|
|
14
|
-
import { useInstanceId
|
|
14
|
+
import { useInstanceId } from '@wordpress/compose';
|
|
15
15
|
import { __ } from '@wordpress/i18n';
|
|
16
16
|
|
|
17
17
|
/**
|
|
@@ -28,7 +28,6 @@ const SetupContent = ( {
|
|
|
28
28
|
activeSlide,
|
|
29
29
|
patterns,
|
|
30
30
|
onBlockPatternSelect,
|
|
31
|
-
height,
|
|
32
31
|
} ) => {
|
|
33
32
|
const composite = useCompositeState();
|
|
34
33
|
const containerClass = 'block-editor-block-pattern-setup__container';
|
|
@@ -39,10 +38,7 @@ const SetupContent = ( {
|
|
|
39
38
|
[ activeSlide + 1, 'next-slide' ],
|
|
40
39
|
] );
|
|
41
40
|
return (
|
|
42
|
-
<div
|
|
43
|
-
className="block-editor-block-pattern-setup__carousel"
|
|
44
|
-
style={ { height } }
|
|
45
|
-
>
|
|
41
|
+
<div className="block-editor-block-pattern-setup__carousel">
|
|
46
42
|
<div className={ containerClass }>
|
|
47
43
|
<ul className="carousel-container">
|
|
48
44
|
{ patterns.map( ( pattern, index ) => (
|
|
@@ -50,7 +46,6 @@ const SetupContent = ( {
|
|
|
50
46
|
className={ slideClass.get( index ) || '' }
|
|
51
47
|
key={ pattern.name }
|
|
52
48
|
pattern={ pattern }
|
|
53
|
-
minHeight={ height }
|
|
54
49
|
/>
|
|
55
50
|
) ) }
|
|
56
51
|
</ul>
|
|
@@ -59,10 +54,7 @@ const SetupContent = ( {
|
|
|
59
54
|
);
|
|
60
55
|
}
|
|
61
56
|
return (
|
|
62
|
-
<div
|
|
63
|
-
style={ { height } }
|
|
64
|
-
className="block-editor-block-pattern-setup__grid"
|
|
65
|
-
>
|
|
57
|
+
<div className="block-editor-block-pattern-setup__grid">
|
|
66
58
|
<Composite
|
|
67
59
|
{ ...composite }
|
|
68
60
|
role="listbox"
|
|
@@ -145,21 +137,15 @@ const BlockPatternSetup = ( {
|
|
|
145
137
|
clientId,
|
|
146
138
|
blockName,
|
|
147
139
|
filterPatternsFn,
|
|
148
|
-
startBlankComponent,
|
|
149
140
|
onBlockPatternSelect,
|
|
150
141
|
} ) => {
|
|
151
142
|
const [ viewMode, setViewMode ] = useState( VIEWMODES.carousel );
|
|
152
143
|
const [ activeSlide, setActiveSlide ] = useState( 0 );
|
|
153
|
-
const [ showBlank, setShowBlank ] = useState( false );
|
|
154
144
|
const { replaceBlock } = useDispatch( blockEditorStore );
|
|
155
145
|
const patterns = usePatternsSetup( clientId, blockName, filterPatternsFn );
|
|
156
|
-
const [
|
|
157
|
-
contentResizeListener,
|
|
158
|
-
{ height: contentHeight },
|
|
159
|
-
] = useResizeObserver();
|
|
160
146
|
|
|
161
|
-
if ( ! patterns?.length
|
|
162
|
-
return
|
|
147
|
+
if ( ! patterns?.length ) {
|
|
148
|
+
return null;
|
|
163
149
|
}
|
|
164
150
|
|
|
165
151
|
const onBlockPatternSelectDefault = ( blocks ) => {
|
|
@@ -168,14 +154,8 @@ const BlockPatternSetup = ( {
|
|
|
168
154
|
};
|
|
169
155
|
const onPatternSelectCallback =
|
|
170
156
|
onBlockPatternSelect || onBlockPatternSelectDefault;
|
|
171
|
-
const onStartBlank = startBlankComponent
|
|
172
|
-
? () => {
|
|
173
|
-
setShowBlank( true );
|
|
174
|
-
}
|
|
175
|
-
: undefined;
|
|
176
157
|
return (
|
|
177
158
|
<>
|
|
178
|
-
{ contentResizeListener }
|
|
179
159
|
<div
|
|
180
160
|
className={ `block-editor-block-pattern-setup view-mode-${ viewMode }` }
|
|
181
161
|
>
|
|
@@ -184,7 +164,6 @@ const BlockPatternSetup = ( {
|
|
|
184
164
|
activeSlide={ activeSlide }
|
|
185
165
|
patterns={ patterns }
|
|
186
166
|
onBlockPatternSelect={ onPatternSelectCallback }
|
|
187
|
-
height={ contentHeight - 2 * 60 }
|
|
188
167
|
/>
|
|
189
168
|
<SetupToolbar
|
|
190
169
|
viewMode={ viewMode }
|
|
@@ -202,7 +181,6 @@ const BlockPatternSetup = ( {
|
|
|
202
181
|
patterns[ activeSlide ].blocks
|
|
203
182
|
);
|
|
204
183
|
} }
|
|
205
|
-
onStartBlank={ onStartBlank }
|
|
206
184
|
/>
|
|
207
185
|
</div>
|
|
208
186
|
</>
|
|
@@ -15,11 +15,8 @@ import {
|
|
|
15
15
|
*/
|
|
16
16
|
import { VIEWMODES } from './constants';
|
|
17
17
|
|
|
18
|
-
const Actions = ( {
|
|
18
|
+
const Actions = ( { onBlockPatternSelect } ) => (
|
|
19
19
|
<div className="block-editor-block-pattern-setup__actions">
|
|
20
|
-
{ onStartBlank && (
|
|
21
|
-
<Button onClick={ onStartBlank }>{ __( 'Start blank' ) }</Button>
|
|
22
|
-
) }
|
|
23
20
|
<Button variant="primary" onClick={ onBlockPatternSelect }>
|
|
24
21
|
{ __( 'Choose' ) }
|
|
25
22
|
</Button>
|
|
@@ -56,7 +53,6 @@ const SetupToolbar = ( {
|
|
|
56
53
|
activeSlide,
|
|
57
54
|
totalSlides,
|
|
58
55
|
onBlockPatternSelect,
|
|
59
|
-
onStartBlank,
|
|
60
56
|
} ) => {
|
|
61
57
|
const isCarouselView = viewMode === VIEWMODES.carousel;
|
|
62
58
|
const displayControls = (
|
|
@@ -87,10 +83,7 @@ const SetupToolbar = ( {
|
|
|
87
83
|
) }
|
|
88
84
|
{ displayControls }
|
|
89
85
|
{ isCarouselView && (
|
|
90
|
-
<Actions
|
|
91
|
-
onBlockPatternSelect={ onBlockPatternSelect }
|
|
92
|
-
onStartBlank={ onStartBlank }
|
|
93
|
-
/>
|
|
86
|
+
<Actions onBlockPatternSelect={ onBlockPatternSelect } />
|
|
94
87
|
) }
|
|
95
88
|
</div>
|
|
96
89
|
);
|
|
@@ -17,6 +17,8 @@
|
|
|
17
17
|
display: block;
|
|
18
18
|
width: 100%;
|
|
19
19
|
padding: $grid-unit-40;
|
|
20
|
+
padding-bottom: 0;
|
|
21
|
+
padding-top: 0;
|
|
20
22
|
column-count: 2;
|
|
21
23
|
|
|
22
24
|
@include break-huge() {
|
|
@@ -53,8 +55,9 @@
|
|
|
53
55
|
text-align: left;
|
|
54
56
|
margin: 0;
|
|
55
57
|
color: $gray-900;
|
|
58
|
+
position: absolute;
|
|
59
|
+
bottom: 0;
|
|
56
60
|
// Block UI appearance.
|
|
57
|
-
border-radius: $radius-block-ui $radius-block-ui 0 0;
|
|
58
61
|
background-color: $white;
|
|
59
62
|
display: flex;
|
|
60
63
|
flex-direction: row;
|
|
@@ -129,5 +132,4 @@
|
|
|
129
132
|
.block-editor-block-pattern-setup__carousel,
|
|
130
133
|
.block-editor-block-pattern-setup__grid {
|
|
131
134
|
width: 100%;
|
|
132
|
-
overflow-y: auto;
|
|
133
135
|
}
|
|
@@ -172,7 +172,7 @@ function BlockPopoverInbetween( {
|
|
|
172
172
|
getAnchorRect={ getAnchorRect }
|
|
173
173
|
focusOnMount={ false }
|
|
174
174
|
// Render in the old slot if needed for backward compatibility,
|
|
175
|
-
// otherwise render in place (not in the
|
|
175
|
+
// otherwise render in place (not in the default popover slot).
|
|
176
176
|
__unstableSlotName={ __unstablePopoverSlot || null }
|
|
177
177
|
// Forces a remount of the popover when its position changes
|
|
178
178
|
// This makes sure the popover doesn't animate from its previous position.
|
|
@@ -57,7 +57,7 @@ export default function BlockPopover( {
|
|
|
57
57
|
focusOnMount={ false }
|
|
58
58
|
anchorRef={ anchorRef }
|
|
59
59
|
// Render in the old slot if needed for backward compatibility,
|
|
60
|
-
// otherwise render in place (not in the
|
|
60
|
+
// otherwise render in place (not in the default popover slot).
|
|
61
61
|
__unstableSlotName={ __unstablePopoverSlot || null }
|
|
62
62
|
// Observe movement for block animations (especially horizontal).
|
|
63
63
|
__unstableObserveElement={ selectedElement }
|
|
@@ -12,6 +12,7 @@ import { useMemo } from '@wordpress/element';
|
|
|
12
12
|
import BlockList from '../block-list';
|
|
13
13
|
import Iframe from '../iframe';
|
|
14
14
|
import EditorStyles from '../editor-styles';
|
|
15
|
+
import { __unstablePresetDuotoneFilter as PresetDuotoneFilter } from '../../components/duotone';
|
|
15
16
|
import { store } from '../../store';
|
|
16
17
|
|
|
17
18
|
// This is used to avoid rendering the block list if the sizes change.
|
|
@@ -24,19 +25,16 @@ function AutoBlockPreview( {
|
|
|
24
25
|
__experimentalPadding,
|
|
25
26
|
__experimentalMinHeight,
|
|
26
27
|
} ) {
|
|
27
|
-
const [
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
const
|
|
32
|
-
contentResizeListener,
|
|
33
|
-
{ height: contentHeight },
|
|
34
|
-
] = useResizeObserver();
|
|
35
|
-
const { styles, assets } = useSelect( ( select ) => {
|
|
28
|
+
const [ containerResizeListener, { width: containerWidth } ] =
|
|
29
|
+
useResizeObserver();
|
|
30
|
+
const [ contentResizeListener, { height: contentHeight } ] =
|
|
31
|
+
useResizeObserver();
|
|
32
|
+
const { styles, assets, duotone } = useSelect( ( select ) => {
|
|
36
33
|
const settings = select( store ).getSettings();
|
|
37
34
|
return {
|
|
38
35
|
styles: settings.styles,
|
|
39
36
|
assets: settings.__unstableResolvedAssets,
|
|
37
|
+
duotone: settings.__experimentalFeatures?.color?.duotone,
|
|
40
38
|
};
|
|
41
39
|
}, [] );
|
|
42
40
|
|
|
@@ -55,11 +53,14 @@ function AutoBlockPreview( {
|
|
|
55
53
|
return styles;
|
|
56
54
|
}, [ styles ] );
|
|
57
55
|
|
|
56
|
+
const svgFilters = useMemo( () => {
|
|
57
|
+
return [ ...( duotone?.default ?? [] ), ...( duotone?.theme ?? [] ) ];
|
|
58
|
+
}, [ duotone ] );
|
|
59
|
+
|
|
58
60
|
// Initialize on render instead of module top level, to avoid circular dependency issues.
|
|
59
61
|
MemoizedBlockList = MemoizedBlockList || pure( BlockList );
|
|
60
62
|
|
|
61
63
|
const scale = containerWidth / viewportWidth;
|
|
62
|
-
|
|
63
64
|
return (
|
|
64
65
|
<div className="block-editor-block-preview__container">
|
|
65
66
|
{ containerResizeListener }
|
|
@@ -104,12 +105,21 @@ function AutoBlockPreview( {
|
|
|
104
105
|
// See: https://github.com/WordPress/gutenberg/pull/38175.
|
|
105
106
|
maxHeight: MAX_HEIGHT,
|
|
106
107
|
minHeight:
|
|
107
|
-
scale < 1 && __experimentalMinHeight
|
|
108
|
+
scale !== 0 && scale < 1 && __experimentalMinHeight
|
|
108
109
|
? __experimentalMinHeight / scale
|
|
109
110
|
: __experimentalMinHeight,
|
|
110
111
|
} }
|
|
111
112
|
>
|
|
112
113
|
{ contentResizeListener }
|
|
114
|
+
{
|
|
115
|
+
/* Filters need to be rendered before children to avoid Safari rendering issues. */
|
|
116
|
+
svgFilters.map( ( preset ) => (
|
|
117
|
+
<PresetDuotoneFilter
|
|
118
|
+
preset={ preset }
|
|
119
|
+
key={ preset.slug }
|
|
120
|
+
/>
|
|
121
|
+
) )
|
|
122
|
+
}
|
|
113
123
|
<MemoizedBlockList renderAppender={ false } />
|
|
114
124
|
</Iframe>
|
|
115
125
|
</Disabled>
|
|
@@ -17,9 +17,8 @@ import { store as blockEditorStore } from '../../store';
|
|
|
17
17
|
* @return {import('react').RefCallback} Ref callback.
|
|
18
18
|
*/
|
|
19
19
|
export function useBlockSelectionClearer() {
|
|
20
|
-
const { hasSelectedBlock, hasMultiSelection } =
|
|
21
|
-
blockEditorStore
|
|
22
|
-
);
|
|
20
|
+
const { hasSelectedBlock, hasMultiSelection } =
|
|
21
|
+
useSelect( blockEditorStore );
|
|
23
22
|
const { clearSelectedBlock } = useDispatch( blockEditorStore );
|
|
24
23
|
|
|
25
24
|
return useRefEffect(
|
|
@@ -0,0 +1,52 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* WordPress dependencies
|
|
3
|
+
*/
|
|
4
|
+
import { rawHandler, getBlockContent } from '@wordpress/blocks';
|
|
5
|
+
import { ToolbarButton, ToolbarGroup } from '@wordpress/components';
|
|
6
|
+
import { __ } from '@wordpress/i18n';
|
|
7
|
+
import { useSelect, useDispatch } from '@wordpress/data';
|
|
8
|
+
import { useCallback } from '@wordpress/element';
|
|
9
|
+
|
|
10
|
+
/**
|
|
11
|
+
* Internal dependencies
|
|
12
|
+
*/
|
|
13
|
+
import { store as blockEditorStore } from '../../store';
|
|
14
|
+
|
|
15
|
+
export default function BlockEditVisuallyButton( { clientIds, ...props } ) {
|
|
16
|
+
const { block, shouldRender } = useSelect(
|
|
17
|
+
( select ) => {
|
|
18
|
+
const firstBlockClientId = clientIds[ 0 ];
|
|
19
|
+
const { isBlockMultiSelected, getBlockMode, getBlock } =
|
|
20
|
+
select( blockEditorStore );
|
|
21
|
+
const isSingleSelected =
|
|
22
|
+
! isBlockMultiSelected( firstBlockClientId );
|
|
23
|
+
const isHtmlMode = getBlockMode( firstBlockClientId ) === 'html';
|
|
24
|
+
|
|
25
|
+
return {
|
|
26
|
+
block: getBlock( firstBlockClientId ),
|
|
27
|
+
shouldRender: isSingleSelected && isHtmlMode,
|
|
28
|
+
};
|
|
29
|
+
},
|
|
30
|
+
[ clientIds[ 0 ] ]
|
|
31
|
+
);
|
|
32
|
+
|
|
33
|
+
const { replaceBlocks } = useDispatch( blockEditorStore );
|
|
34
|
+
const onClick = useCallback( () => {
|
|
35
|
+
replaceBlocks(
|
|
36
|
+
block.clientId,
|
|
37
|
+
rawHandler( { HTML: getBlockContent( block ) } )
|
|
38
|
+
);
|
|
39
|
+
}, [ block ] );
|
|
40
|
+
|
|
41
|
+
if ( ! shouldRender ) {
|
|
42
|
+
return null;
|
|
43
|
+
}
|
|
44
|
+
|
|
45
|
+
return (
|
|
46
|
+
<ToolbarGroup>
|
|
47
|
+
<ToolbarButton onClick={ onClick } { ...props }>
|
|
48
|
+
{ __( 'Edit visually' ) }
|
|
49
|
+
</ToolbarButton>
|
|
50
|
+
</ToolbarGroup>
|
|
51
|
+
);
|
|
52
|
+
}
|
|
@@ -1,8 +1,3 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* External dependencies
|
|
3
|
-
*/
|
|
4
|
-
import { noop } from 'lodash';
|
|
5
|
-
|
|
6
1
|
/**
|
|
7
2
|
* WordPress dependencies
|
|
8
3
|
*/
|
|
@@ -17,6 +12,8 @@ import { compose } from '@wordpress/compose';
|
|
|
17
12
|
*/
|
|
18
13
|
import { store as blockEditorStore } from '../../store';
|
|
19
14
|
|
|
15
|
+
const noop = () => {};
|
|
16
|
+
|
|
20
17
|
export function BlockModeToggle( {
|
|
21
18
|
blockType,
|
|
22
19
|
mode,
|
|
@@ -25,6 +22,7 @@ export function BlockModeToggle( {
|
|
|
25
22
|
isCodeEditingEnabled = true,
|
|
26
23
|
} ) {
|
|
27
24
|
if (
|
|
25
|
+
! blockType ||
|
|
28
26
|
! hasBlockSupport( blockType, 'html', true ) ||
|
|
29
27
|
! isCodeEditingEnabled
|
|
30
28
|
) {
|
|
@@ -39,9 +37,8 @@ export function BlockModeToggle( {
|
|
|
39
37
|
|
|
40
38
|
export default compose( [
|
|
41
39
|
withSelect( ( select, { clientId } ) => {
|
|
42
|
-
const { getBlock, getBlockMode, getSettings } =
|
|
43
|
-
blockEditorStore
|
|
44
|
-
);
|
|
40
|
+
const { getBlock, getBlockMode, getSettings } =
|
|
41
|
+
select( blockEditorStore );
|
|
45
42
|
const block = getBlock( clientId );
|
|
46
43
|
const isCodeEditingEnabled = getSettings().codeEditingEnabled;
|
|
47
44
|
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
/**
|
|
2
2
|
* External dependencies
|
|
3
3
|
*/
|
|
4
|
-
import { castArray, flow
|
|
4
|
+
import { castArray, flow } from 'lodash';
|
|
5
5
|
|
|
6
6
|
/**
|
|
7
7
|
* WordPress dependencies
|
|
@@ -33,6 +33,7 @@ import { store as blockEditorStore } from '../../store';
|
|
|
33
33
|
import useBlockDisplayTitle from '../block-title/use-block-display-title';
|
|
34
34
|
import { useShowMoversGestures } from '../block-toolbar/utils';
|
|
35
35
|
|
|
36
|
+
const noop = () => {};
|
|
36
37
|
const POPOVER_PROPS = {
|
|
37
38
|
className: 'block-editor-block-settings-menu__popover',
|
|
38
39
|
position: 'bottom right',
|
|
@@ -41,7 +42,9 @@ const POPOVER_PROPS = {
|
|
|
41
42
|
|
|
42
43
|
function CopyMenuItem( { blocks, onCopy } ) {
|
|
43
44
|
const ref = useCopyToClipboard( () => serialize( blocks ), onCopy );
|
|
44
|
-
|
|
45
|
+
const copyMenuItemLabel =
|
|
46
|
+
blocks.length > 1 ? __( 'Copy blocks' ) : __( 'Copy block' );
|
|
47
|
+
return <MenuItem ref={ ref }>{ copyMenuItemLabel }</MenuItem>;
|
|
45
48
|
}
|
|
46
49
|
|
|
47
50
|
export function BlockSettingsDropdown( {
|
|
@@ -82,9 +85,8 @@ export function BlockSettingsDropdown( {
|
|
|
82
85
|
hasReducedUI: getSettings().hasReducedUI,
|
|
83
86
|
onlyBlock: 1 === getBlockCount(),
|
|
84
87
|
parentBlockType: getBlockType( parentBlockName ),
|
|
85
|
-
previousBlockClientId:
|
|
86
|
-
firstBlockClientId
|
|
87
|
-
),
|
|
88
|
+
previousBlockClientId:
|
|
89
|
+
getPreviousBlockClientId( firstBlockClientId ),
|
|
88
90
|
nextBlockClientId: getNextBlockClientId( firstBlockClientId ),
|
|
89
91
|
selectedBlockClientIds: getSelectedBlockClientIds(),
|
|
90
92
|
};
|
|
@@ -108,9 +110,8 @@ export function BlockSettingsDropdown( {
|
|
|
108
110
|
};
|
|
109
111
|
}, [] );
|
|
110
112
|
|
|
111
|
-
const { selectBlock, toggleBlockHighlight } =
|
|
112
|
-
blockEditorStore
|
|
113
|
-
);
|
|
113
|
+
const { selectBlock, toggleBlockHighlight } =
|
|
114
|
+
useDispatch( blockEditorStore );
|
|
114
115
|
|
|
115
116
|
const updateSelectionAfterDuplicate = useCallback(
|
|
116
117
|
__experimentalSelectBlock
|
|
@@ -124,7 +125,10 @@ export function BlockSettingsDropdown( {
|
|
|
124
125
|
[ __experimentalSelectBlock ]
|
|
125
126
|
);
|
|
126
127
|
|
|
127
|
-
const blockTitle = useBlockDisplayTitle(
|
|
128
|
+
const blockTitle = useBlockDisplayTitle( {
|
|
129
|
+
clientId: firstBlockClientId,
|
|
130
|
+
maximumLength: 25,
|
|
131
|
+
} );
|
|
128
132
|
|
|
129
133
|
const updateSelectionAfterRemove = useCallback(
|
|
130
134
|
__experimentalSelectBlock
|