@wordpress/block-editor 12.4.0 → 12.6.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 +4 -0
- package/README.md +1 -0
- package/build/components/block-draggable/index.js +6 -3
- package/build/components/block-draggable/index.js.map +1 -1
- package/build/components/block-draggable/index.native.js +2 -2
- package/build/components/block-draggable/index.native.js.map +1 -1
- package/build/components/block-edit/edit.js +25 -13
- package/build/components/block-edit/edit.js.map +1 -1
- package/build/components/block-heading-level-dropdown/heading-level-icon.js +10 -2
- package/build/components/block-heading-level-dropdown/heading-level-icon.js.map +1 -1
- package/build/components/block-heading-level-dropdown/index.native.js +4 -3
- package/build/components/block-heading-level-dropdown/index.native.js.map +1 -1
- package/build/components/block-list/block-outline.native.js +14 -18
- package/build/components/block-list/block-outline.native.js.map +1 -1
- package/build/components/block-list/block.native.js +21 -42
- package/build/components/block-list/block.native.js.map +1 -1
- package/build/components/block-lock/toolbar.js +25 -6
- package/build/components/block-lock/toolbar.js.map +1 -1
- package/build/components/block-mover/index.native.js +1 -1
- package/build/components/block-mover/index.native.js.map +1 -1
- package/build/components/block-parent-selector/index.js +8 -5
- package/build/components/block-parent-selector/index.js.map +1 -1
- package/build/components/block-removal-warning-modal/index.js +15 -25
- package/build/components/block-removal-warning-modal/index.js.map +1 -1
- package/build/components/block-settings/button.native.js +2 -2
- package/build/components/block-settings/button.native.js.map +1 -1
- package/build/components/{block-mobile-toolbar/block-actions-menu.native.js → block-toolbar/block-toolbar-menu.native.js} +10 -11
- package/build/components/block-toolbar/block-toolbar-menu.native.js.map +1 -0
- package/build/components/block-toolbar/index.js +12 -8
- package/build/components/block-toolbar/index.js.map +1 -1
- package/build/components/block-toolbar/index.native.js +62 -3
- package/build/components/block-toolbar/index.native.js.map +1 -1
- package/build/components/block-tools/block-contextual-toolbar.js +7 -11
- package/build/components/block-tools/block-contextual-toolbar.js.map +1 -1
- package/build/components/colors-gradients/control.js +4 -2
- package/build/components/colors-gradients/control.js.map +1 -1
- package/build/components/dimensions-tool/aspect-ratio-tool.js +99 -0
- package/build/components/dimensions-tool/aspect-ratio-tool.js.map +1 -0
- package/build/components/dimensions-tool/index.js +207 -0
- package/build/components/dimensions-tool/index.js.map +1 -0
- package/build/components/dimensions-tool/scale-tool.js +111 -0
- package/build/components/dimensions-tool/scale-tool.js.map +1 -0
- package/build/components/dimensions-tool/width-height-tool.js +125 -0
- package/build/components/dimensions-tool/width-height-tool.js.map +1 -0
- package/build/components/global-styles/color-panel.js +22 -16
- package/build/components/global-styles/color-panel.js.map +1 -1
- package/build/components/global-styles/dimensions-panel.js +13 -2
- package/build/components/global-styles/dimensions-panel.js.map +1 -1
- package/build/components/global-styles/filters-panel.js +1 -1
- package/build/components/global-styles/filters-panel.js.map +1 -1
- package/build/components/global-styles/get-block-css-selector.js +4 -8
- package/build/components/global-styles/get-block-css-selector.js.map +1 -1
- package/build/components/global-styles/hooks.js +15 -25
- package/build/components/global-styles/hooks.js.map +1 -1
- package/build/components/global-styles/typography-panel.js +52 -5
- package/build/components/global-styles/typography-panel.js.map +1 -1
- package/build/components/global-styles/use-global-styles-output.js +12 -18
- package/build/components/global-styles/use-global-styles-output.js.map +1 -1
- package/build/components/global-styles/utils.js +6 -6
- package/build/components/global-styles/utils.js.map +1 -1
- package/build/components/iframe/index.js +36 -48
- package/build/components/iframe/index.js.map +1 -1
- package/build/components/iframe/use-compatibility-styles.js +5 -0
- package/build/components/iframe/use-compatibility-styles.js.map +1 -1
- package/build/components/image-editor/aspect-ratio-dropdown.js +1 -1
- package/build/components/image-editor/aspect-ratio-dropdown.js.map +1 -1
- package/build/components/image-editor/use-save-image.js +1 -2
- package/build/components/image-editor/use-save-image.js.map +1 -1
- package/build/components/image-size-control/index.js +6 -0
- package/build/components/image-size-control/index.js.map +1 -1
- package/build/components/index.js +9 -0
- package/build/components/index.js.map +1 -1
- package/build/components/inner-blocks/index.js +3 -1
- package/build/components/inner-blocks/index.js.map +1 -1
- package/build/components/inner-blocks/index.native.js +3 -1
- package/build/components/inner-blocks/index.native.js.map +1 -1
- package/build/components/inner-blocks/use-nested-settings-update.js +33 -7
- package/build/components/inner-blocks/use-nested-settings-update.js.map +1 -1
- package/build/components/inserter/block-patterns-explorer/patterns-list.js +2 -2
- package/build/components/inserter/block-patterns-explorer/patterns-list.js.map +1 -1
- package/build/components/inserter/block-patterns-tab.js +7 -35
- package/build/components/inserter/block-patterns-tab.js.map +1 -1
- package/build/components/inserter/hooks/use-block-types-state.js +3 -4
- package/build/components/inserter/hooks/use-block-types-state.js.map +1 -1
- package/build/components/inserter/hooks/use-patterns-state.js +9 -3
- package/build/components/inserter/hooks/use-patterns-state.js.map +1 -1
- package/build/components/inserter/index.js +2 -4
- package/build/components/inserter/index.js.map +1 -1
- package/build/components/inserter/index.native.js +21 -32
- package/build/components/inserter/index.native.js.map +1 -1
- package/build/components/inserter/media-tab/hooks.js +2 -21
- package/build/components/inserter/media-tab/hooks.js.map +1 -1
- package/build/components/inserter/reusable-block-rename-hint.js +82 -0
- package/build/components/inserter/reusable-block-rename-hint.js.map +1 -0
- package/build/components/inserter/reusable-blocks-tab.js +6 -2
- package/build/components/inserter/reusable-blocks-tab.js.map +1 -1
- package/build/components/inserter/reusable-blocks-tab.native.js +2 -2
- package/build/components/inserter/reusable-blocks-tab.native.js.map +1 -1
- package/build/components/inserter/tabs.native.js +1 -1
- package/build/components/inserter/tabs.native.js.map +1 -1
- package/build/components/inserter-draggable-blocks/index.js +9 -1
- package/build/components/inserter-draggable-blocks/index.js.map +1 -1
- package/build/components/link-control/constants.js +1 -1
- package/build/components/link-control/constants.js.map +1 -1
- package/build/components/link-control/index.js +21 -16
- package/build/components/link-control/index.js.map +1 -1
- package/build/components/link-control/search-create-button.js +5 -21
- package/build/components/link-control/search-create-button.js.map +1 -1
- package/build/components/link-control/search-input.js +4 -4
- package/build/components/link-control/search-input.js.map +1 -1
- package/build/components/link-control/search-item.js +13 -30
- 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/link-control/settings-drawer.js +2 -3
- package/build/components/link-control/settings-drawer.js.map +1 -1
- package/build/components/list-view/appender.js +2 -6
- package/build/components/list-view/appender.js.map +1 -1
- package/build/components/list-view/use-list-view-client-ids.js +2 -2
- package/build/components/list-view/use-list-view-client-ids.js.map +1 -1
- package/build/components/media-placeholder/index.native.js +65 -31
- package/build/components/media-placeholder/index.native.js.map +1 -1
- package/build/components/preview-options/index.js +2 -2
- package/build/components/preview-options/index.js.map +1 -1
- package/build/components/provider/index.js +5 -2
- package/build/components/provider/index.js.map +1 -1
- package/build/components/provider/use-block-sync.js +21 -0
- package/build/components/provider/use-block-sync.js.map +1 -1
- package/build/components/resolution-tool/index.js +55 -0
- package/build/components/resolution-tool/index.js.map +1 -0
- package/build/components/rich-text/content.js +0 -36
- package/build/components/rich-text/content.js.map +1 -1
- package/build/components/rich-text/get-rich-text-values.js +118 -0
- package/build/components/rich-text/get-rich-text-values.js.map +1 -0
- package/build/components/spacing-sizes-control/hooks/use-spacing-sizes.js +1 -1
- package/build/components/spacing-sizes-control/hooks/use-spacing-sizes.js.map +1 -1
- package/build/components/spacing-sizes-control/input-controls/axial.js +6 -2
- package/build/components/spacing-sizes-control/input-controls/axial.js.map +1 -1
- package/build/components/spacing-sizes-control/input-controls/separated.js +5 -1
- package/build/components/spacing-sizes-control/input-controls/separated.js.map +1 -1
- package/build/components/spacing-sizes-control/input-controls/single.js +5 -1
- package/build/components/spacing-sizes-control/input-controls/single.js.map +1 -1
- package/build/components/spacing-sizes-control/utils.js +1 -1
- package/build/components/spacing-sizes-control/utils.js.map +1 -1
- package/build/components/url-input/index.js +4 -2
- package/build/components/url-input/index.js.map +1 -1
- package/build/components/use-block-display-information/index.js +7 -3
- package/build/components/use-block-display-information/index.js.map +1 -1
- package/build/components/use-block-drop-zone/index.native.js +49 -8
- package/build/components/use-block-drop-zone/index.native.js.map +1 -1
- package/build/components/use-setting/index.js +5 -9
- package/build/components/use-setting/index.js.map +1 -1
- package/build/components/writing-flow/use-tab-nav.js +10 -27
- package/build/components/writing-flow/use-tab-nav.js.map +1 -1
- package/build/components/writing-mode-control/index.js +70 -0
- package/build/components/writing-mode-control/index.js.map +1 -0
- package/build/hooks/behaviors.js +25 -20
- package/build/hooks/behaviors.js.map +1 -1
- package/build/hooks/margin.js +1 -1
- package/build/hooks/margin.js.map +1 -1
- package/build/hooks/padding.js +1 -1
- package/build/hooks/padding.js.map +1 -1
- package/build/hooks/supports.js +7 -1
- package/build/hooks/supports.js.map +1 -1
- package/build/hooks/typography.js +2 -1
- package/build/hooks/typography.js.map +1 -1
- package/build/hooks/utils.js +5 -9
- package/build/hooks/utils.js.map +1 -1
- package/build/private-apis.js +16 -3
- package/build/private-apis.js.map +1 -1
- package/build/private-apis.native.js +3 -0
- package/build/private-apis.native.js.map +1 -1
- package/build/store/actions.js +196 -2
- package/build/store/actions.js.map +1 -1
- package/build/store/defaults.js +1 -0
- package/build/store/defaults.js.map +1 -1
- package/build/store/index.js +10 -1
- package/build/store/index.js.map +1 -1
- package/build/store/private-actions.js +46 -40
- package/build/store/private-actions.js.map +1 -1
- package/build/store/private-selectors.js +8 -9
- package/build/store/private-selectors.js.map +1 -1
- package/build/store/reducer.js +22 -9
- package/build/store/reducer.js.map +1 -1
- package/build/store/selectors.js +52 -23
- package/build/store/selectors.js.map +1 -1
- package/build/utils/object.js +38 -2
- package/build/utils/object.js.map +1 -1
- package/build-module/components/block-draggable/index.js +6 -3
- package/build-module/components/block-draggable/index.js.map +1 -1
- package/build-module/components/block-draggable/index.native.js +2 -2
- package/build-module/components/block-draggable/index.native.js.map +1 -1
- package/build-module/components/block-edit/edit.js +27 -10
- package/build-module/components/block-edit/edit.js.map +1 -1
- package/build-module/components/block-heading-level-dropdown/heading-level-icon.js +9 -2
- package/build-module/components/block-heading-level-dropdown/heading-level-icon.js.map +1 -1
- package/build-module/components/block-heading-level-dropdown/index.native.js +4 -3
- package/build-module/components/block-heading-level-dropdown/index.native.js.map +1 -1
- package/build-module/components/block-list/block-outline.native.js +14 -18
- package/build-module/components/block-list/block-outline.native.js.map +1 -1
- package/build-module/components/block-list/block.native.js +24 -43
- package/build-module/components/block-list/block.native.js.map +1 -1
- package/build-module/components/block-lock/toolbar.js +25 -7
- package/build-module/components/block-lock/toolbar.js.map +1 -1
- package/build-module/components/block-mover/index.native.js +3 -3
- package/build-module/components/block-mover/index.native.js.map +1 -1
- package/build-module/components/block-parent-selector/index.js +7 -5
- package/build-module/components/block-parent-selector/index.js.map +1 -1
- package/build-module/components/block-removal-warning-modal/index.js +17 -24
- package/build-module/components/block-removal-warning-modal/index.js.map +1 -1
- package/build-module/components/block-settings/button.native.js +3 -3
- package/build-module/components/block-settings/button.native.js.map +1 -1
- package/build-module/components/{block-mobile-toolbar/block-actions-menu.native.js → block-toolbar/block-toolbar-menu.native.js} +13 -13
- package/build-module/components/block-toolbar/block-toolbar-menu.native.js.map +1 -0
- package/build-module/components/block-toolbar/index.js +12 -8
- package/build-module/components/block-toolbar/index.js.map +1 -1
- package/build-module/components/block-toolbar/index.native.js +60 -4
- package/build-module/components/block-toolbar/index.native.js.map +1 -1
- package/build-module/components/block-tools/block-contextual-toolbar.js +8 -11
- package/build-module/components/block-tools/block-contextual-toolbar.js.map +1 -1
- package/build-module/components/colors-gradients/control.js +3 -2
- package/build-module/components/colors-gradients/control.js.map +1 -1
- package/build-module/components/dimensions-tool/aspect-ratio-tool.js +87 -0
- package/build-module/components/dimensions-tool/aspect-ratio-tool.js.map +1 -0
- package/build-module/components/dimensions-tool/index.js +195 -0
- package/build-module/components/dimensions-tool/index.js.map +1 -0
- package/build-module/components/dimensions-tool/scale-tool.js +103 -0
- package/build-module/components/dimensions-tool/scale-tool.js.map +1 -0
- package/build-module/components/dimensions-tool/width-height-tool.js +122 -0
- package/build-module/components/dimensions-tool/width-height-tool.js.map +1 -0
- package/build-module/components/global-styles/color-panel.js +22 -16
- package/build-module/components/global-styles/color-panel.js.map +1 -1
- package/build-module/components/global-styles/dimensions-panel.js +13 -2
- 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/get-block-css-selector.js +4 -8
- package/build-module/components/global-styles/get-block-css-selector.js.map +1 -1
- package/build-module/components/global-styles/hooks.js +14 -24
- package/build-module/components/global-styles/hooks.js.map +1 -1
- package/build-module/components/global-styles/typography-panel.js +51 -5
- package/build-module/components/global-styles/typography-panel.js.map +1 -1
- package/build-module/components/global-styles/use-global-styles-output.js +13 -18
- package/build-module/components/global-styles/use-global-styles-output.js.map +1 -1
- package/build-module/components/global-styles/utils.js +5 -5
- package/build-module/components/global-styles/utils.js.map +1 -1
- package/build-module/components/iframe/index.js +37 -49
- package/build-module/components/iframe/index.js.map +1 -1
- package/build-module/components/iframe/use-compatibility-styles.js +5 -0
- package/build-module/components/iframe/use-compatibility-styles.js.map +1 -1
- package/build-module/components/image-editor/aspect-ratio-dropdown.js +1 -1
- package/build-module/components/image-editor/aspect-ratio-dropdown.js.map +1 -1
- package/build-module/components/image-editor/use-save-image.js +1 -2
- package/build-module/components/image-editor/use-save-image.js.map +1 -1
- package/build-module/components/image-size-control/index.js +5 -0
- package/build-module/components/image-size-control/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/index.js +3 -1
- package/build-module/components/inner-blocks/index.js.map +1 -1
- package/build-module/components/inner-blocks/index.native.js +3 -1
- package/build-module/components/inner-blocks/index.native.js.map +1 -1
- package/build-module/components/inner-blocks/use-nested-settings-update.js +30 -7
- package/build-module/components/inner-blocks/use-nested-settings-update.js.map +1 -1
- package/build-module/components/inserter/block-patterns-explorer/patterns-list.js +2 -2
- package/build-module/components/inserter/block-patterns-explorer/patterns-list.js.map +1 -1
- package/build-module/components/inserter/block-patterns-tab.js +7 -33
- package/build-module/components/inserter/block-patterns-tab.js.map +1 -1
- package/build-module/components/inserter/hooks/use-block-types-state.js +3 -4
- package/build-module/components/inserter/hooks/use-block-types-state.js.map +1 -1
- package/build-module/components/inserter/hooks/use-patterns-state.js +9 -3
- package/build-module/components/inserter/hooks/use-patterns-state.js.map +1 -1
- package/build-module/components/inserter/index.js +2 -4
- package/build-module/components/inserter/index.js.map +1 -1
- package/build-module/components/inserter/index.native.js +22 -33
- package/build-module/components/inserter/index.native.js.map +1 -1
- package/build-module/components/inserter/media-tab/hooks.js +2 -21
- package/build-module/components/inserter/media-tab/hooks.js.map +1 -1
- package/build-module/components/inserter/reusable-block-rename-hint.js +67 -0
- package/build-module/components/inserter/reusable-block-rename-hint.js.map +1 -0
- package/build-module/components/inserter/reusable-blocks-tab.js +5 -2
- package/build-module/components/inserter/reusable-blocks-tab.js.map +1 -1
- package/build-module/components/inserter/reusable-blocks-tab.native.js +2 -2
- package/build-module/components/inserter/reusable-blocks-tab.native.js.map +1 -1
- package/build-module/components/inserter/tabs.native.js +1 -1
- package/build-module/components/inserter/tabs.native.js.map +1 -1
- package/build-module/components/inserter-draggable-blocks/index.js +9 -2
- package/build-module/components/inserter-draggable-blocks/index.js.map +1 -1
- package/build-module/components/link-control/constants.js +1 -1
- package/build-module/components/link-control/constants.js.map +1 -1
- package/build-module/components/link-control/index.js +21 -16
- package/build-module/components/link-control/index.js.map +1 -1
- package/build-module/components/link-control/search-create-button.js +7 -20
- package/build-module/components/link-control/search-create-button.js.map +1 -1
- package/build-module/components/link-control/search-input.js +4 -4
- package/build-module/components/link-control/search-input.js.map +1 -1
- package/build-module/components/link-control/search-item.js +14 -28
- package/build-module/components/link-control/search-item.js.map +1 -1
- package/build-module/components/link-control/search-results.js +3 -3
- package/build-module/components/link-control/search-results.js.map +1 -1
- package/build-module/components/link-control/settings-drawer.js +4 -5
- package/build-module/components/link-control/settings-drawer.js.map +1 -1
- package/build-module/components/list-view/appender.js +2 -6
- package/build-module/components/list-view/appender.js.map +1 -1
- package/build-module/components/list-view/use-list-view-client-ids.js +2 -2
- package/build-module/components/list-view/use-list-view-client-ids.js.map +1 -1
- package/build-module/components/media-placeholder/index.native.js +66 -33
- package/build-module/components/media-placeholder/index.native.js.map +1 -1
- package/build-module/components/preview-options/index.js +2 -2
- package/build-module/components/preview-options/index.js.map +1 -1
- package/build-module/components/provider/index.js +5 -2
- package/build-module/components/provider/index.js.map +1 -1
- package/build-module/components/provider/use-block-sync.js +21 -0
- package/build-module/components/provider/use-block-sync.js.map +1 -1
- package/build-module/components/resolution-tool/index.js +45 -0
- package/build-module/components/resolution-tool/index.js.map +1 -0
- package/build-module/components/rich-text/content.js +1 -36
- package/build-module/components/rich-text/content.js.map +1 -1
- package/build-module/components/rich-text/get-rich-text-values.js +105 -0
- package/build-module/components/rich-text/get-rich-text-values.js.map +1 -0
- package/build-module/components/spacing-sizes-control/hooks/use-spacing-sizes.js +1 -1
- package/build-module/components/spacing-sizes-control/hooks/use-spacing-sizes.js.map +1 -1
- package/build-module/components/spacing-sizes-control/input-controls/axial.js +7 -3
- package/build-module/components/spacing-sizes-control/input-controls/axial.js.map +1 -1
- package/build-module/components/spacing-sizes-control/input-controls/separated.js +6 -2
- package/build-module/components/spacing-sizes-control/input-controls/separated.js.map +1 -1
- package/build-module/components/spacing-sizes-control/input-controls/single.js +6 -2
- package/build-module/components/spacing-sizes-control/input-controls/single.js.map +1 -1
- package/build-module/components/spacing-sizes-control/utils.js +1 -1
- package/build-module/components/spacing-sizes-control/utils.js.map +1 -1
- package/build-module/components/url-input/index.js +4 -2
- package/build-module/components/url-input/index.js.map +1 -1
- package/build-module/components/use-block-display-information/index.js +7 -3
- package/build-module/components/use-block-display-information/index.js.map +1 -1
- package/build-module/components/use-block-drop-zone/index.native.js +50 -8
- package/build-module/components/use-block-drop-zone/index.native.js.map +1 -1
- package/build-module/components/use-setting/index.js +5 -9
- package/build-module/components/use-setting/index.js.map +1 -1
- package/build-module/components/writing-flow/use-tab-nav.js +8 -26
- package/build-module/components/writing-flow/use-tab-nav.js.map +1 -1
- package/build-module/components/writing-mode-control/index.js +57 -0
- package/build-module/components/writing-mode-control/index.js.map +1 -0
- package/build-module/hooks/behaviors.js +26 -20
- package/build-module/hooks/behaviors.js.map +1 -1
- package/build-module/hooks/margin.js +1 -1
- package/build-module/hooks/margin.js.map +1 -1
- package/build-module/hooks/padding.js +1 -1
- package/build-module/hooks/padding.js.map +1 -1
- package/build-module/hooks/supports.js +7 -1
- package/build-module/hooks/supports.js.map +1 -1
- package/build-module/hooks/typography.js +2 -1
- package/build-module/hooks/typography.js.map +1 -1
- package/build-module/hooks/utils.js +6 -9
- package/build-module/hooks/utils.js.map +1 -1
- package/build-module/private-apis.js +11 -2
- package/build-module/private-apis.js.map +1 -1
- package/build-module/private-apis.native.js +2 -0
- package/build-module/private-apis.native.js.map +1 -1
- package/build-module/store/actions.js +193 -3
- package/build-module/store/actions.js.map +1 -1
- package/build-module/store/defaults.js +1 -0
- package/build-module/store/defaults.js.map +1 -1
- package/build-module/store/index.js +10 -1
- package/build-module/store/index.js.map +1 -1
- package/build-module/store/private-actions.js +45 -36
- package/build-module/store/private-actions.js.map +1 -1
- package/build-module/store/private-selectors.js +5 -5
- package/build-module/store/private-selectors.js.map +1 -1
- package/build-module/store/reducer.js +22 -9
- package/build-module/store/reducer.js.map +1 -1
- package/build-module/store/selectors.js +49 -21
- package/build-module/store/selectors.js.map +1 -1
- package/build-module/utils/object.js +34 -2
- package/build-module/utils/object.js.map +1 -1
- package/build-style/content-rtl.css +4 -0
- package/build-style/content.css +4 -0
- package/build-style/style-rtl.css +137 -129
- package/build-style/style.css +137 -129
- package/package.json +33 -32
- package/src/components/alignment-control/test/__snapshots__/index.js.snap +6 -6
- package/src/components/block-alignment-control/test/__snapshots__/index.js.snap +5 -5
- package/src/components/block-controls/README.md +89 -0
- package/src/components/block-draggable/index.js +13 -4
- package/src/components/block-draggable/index.native.js +7 -3
- package/src/components/block-draggable/style.scss +1 -0
- package/src/components/block-draggable/test/index.native.js +0 -54
- package/src/components/block-edit/edit.js +26 -9
- package/src/components/block-edit/test/edit.js +1 -1
- package/src/components/block-heading-level-dropdown/heading-level-icon.js +6 -1
- package/src/components/block-heading-level-dropdown/index.native.js +8 -4
- package/src/components/block-inspector/style.scss +2 -1
- package/src/components/block-list/block-outline.native.js +26 -25
- package/src/components/block-list/block.native.js +24 -38
- package/src/components/block-list/block.native.scss +18 -40
- package/src/components/block-list/style.native.scss +3 -3
- package/src/components/block-lock/toolbar.js +34 -6
- package/src/components/block-mover/index.native.js +3 -3
- package/src/components/block-mover/test/__snapshots__/index.native.js.snap +16 -6
- package/src/components/block-parent-selector/index.js +13 -8
- package/src/components/block-removal-warning-modal/index.js +17 -33
- package/src/components/block-settings/button.native.js +12 -6
- package/src/components/{block-mobile-toolbar/block-actions-menu.native.js → block-toolbar/block-toolbar-menu.native.js} +19 -18
- package/src/components/block-toolbar/index.js +11 -9
- package/src/components/block-toolbar/index.native.js +86 -6
- package/src/components/{block-mobile-toolbar/test/block-actions-menu.native.js → block-toolbar/test/block-toolbar-menu.native.js} +20 -54
- package/src/components/block-toolbar/test/index.native.js +42 -0
- package/src/components/block-tools/block-contextual-toolbar.js +5 -11
- package/src/components/block-tools/style.scss +73 -26
- package/src/components/button-block-appender/styles.native.scss +2 -2
- package/src/components/caption/README.md +49 -0
- package/src/components/colors-gradients/control.js +3 -2
- package/src/components/default-block-appender/content.scss +11 -0
- package/src/components/dimensions-tool/aspect-ratio-tool.js +124 -0
- package/src/components/dimensions-tool/index.js +212 -0
- package/src/components/dimensions-tool/scale-tool.js +124 -0
- package/src/components/dimensions-tool/stories/aspect-ratio-tool.js +52 -0
- package/src/components/dimensions-tool/stories/index.js +54 -0
- package/src/components/dimensions-tool/stories/scale-tool.js +48 -0
- package/src/components/dimensions-tool/stories/width-height-tool.js +54 -0
- package/src/components/dimensions-tool/test/index.js +641 -0
- package/src/components/dimensions-tool/width-height-tool.js +113 -0
- package/src/components/font-family/README.md +71 -0
- package/src/components/global-styles/color-panel.js +24 -17
- package/src/components/global-styles/dimensions-panel.js +8 -2
- package/src/components/global-styles/filters-panel.js +2 -2
- package/src/components/global-styles/get-block-css-selector.js +5 -9
- package/src/components/global-styles/hooks.js +22 -26
- package/src/components/global-styles/typography-panel.js +57 -5
- package/src/components/global-styles/use-global-styles-output.js +36 -18
- package/src/components/global-styles/utils.js +15 -6
- package/src/components/iframe/index.js +30 -56
- package/src/components/iframe/use-compatibility-styles.js +5 -0
- package/src/components/image-editor/aspect-ratio-dropdown.js +1 -1
- package/src/components/image-editor/use-save-image.js +0 -1
- package/src/components/image-size-control/index.js +6 -0
- package/src/components/index.js +1 -0
- package/src/components/inner-blocks/README.md +10 -0
- package/src/components/inner-blocks/index.js +4 -0
- package/src/components/inner-blocks/index.native.js +4 -0
- package/src/components/inner-blocks/use-nested-settings-update.js +32 -5
- package/src/components/inserter/block-patterns-explorer/patterns-list.js +8 -2
- package/src/components/inserter/block-patterns-tab.js +8 -56
- package/src/components/inserter/hooks/use-block-types-state.js +3 -4
- package/src/components/inserter/hooks/use-patterns-state.js +35 -19
- package/src/components/inserter/index.js +2 -3
- package/src/components/inserter/index.native.js +17 -36
- package/src/components/inserter/media-tab/hooks.js +2 -22
- package/src/components/inserter/reusable-block-rename-hint.js +69 -0
- package/src/components/inserter/reusable-blocks-tab.js +5 -1
- package/src/components/inserter/reusable-blocks-tab.native.js +2 -2
- package/src/components/inserter/style.native.scss +10 -15
- package/src/components/inserter/style.scss +28 -0
- package/src/components/inserter/tabs.native.js +5 -1
- package/src/components/inserter-draggable-blocks/index.js +13 -2
- package/src/components/link-control/constants.js +1 -1
- package/src/components/link-control/index.js +36 -29
- package/src/components/link-control/search-create-button.js +8 -26
- package/src/components/link-control/search-input.js +4 -3
- package/src/components/link-control/search-item.js +21 -43
- package/src/components/link-control/search-results.js +48 -46
- package/src/components/link-control/settings-drawer.js +6 -5
- package/src/components/link-control/style.scss +58 -123
- package/src/components/link-control/test/index.js +161 -123
- package/src/components/list-view/appender.js +5 -6
- package/src/components/list-view/style.scss +1 -2
- package/src/components/list-view/use-list-view-client-ids.js +2 -2
- package/src/components/media-placeholder/index.native.js +108 -59
- package/src/components/media-placeholder/styles.native.scss +59 -24
- package/src/components/media-replace-flow/test/index.js +1 -1
- package/src/components/panel-color-settings/README.md +98 -0
- package/src/components/preview-options/README.md +18 -17
- package/src/components/preview-options/index.js +2 -2
- package/src/components/provider/index.js +9 -2
- package/src/components/provider/test/use-block-sync.js +21 -6
- package/src/components/provider/use-block-sync.js +19 -0
- package/src/components/recursion-provider/README.md +101 -0
- package/src/components/resolution-tool/index.js +56 -0
- package/src/components/resolution-tool/stories/index.js +48 -0
- package/src/components/rich-text/content.js +1 -46
- package/src/components/rich-text/get-rich-text-values.js +105 -0
- package/src/components/spacing-sizes-control/hooks/use-spacing-sizes.js +1 -1
- package/src/components/spacing-sizes-control/input-controls/axial.js +17 -2
- package/src/components/spacing-sizes-control/input-controls/separated.js +17 -2
- package/src/components/spacing-sizes-control/input-controls/single.js +12 -2
- package/src/components/spacing-sizes-control/utils.js +1 -1
- package/src/components/text-transform-control/README.md +44 -0
- package/src/components/url-input/index.js +2 -0
- package/src/components/use-block-display-information/index.js +12 -5
- package/src/components/use-block-drop-zone/index.native.js +65 -28
- package/src/components/use-setting/index.js +8 -8
- package/src/components/writing-flow/use-tab-nav.js +10 -33
- package/src/components/writing-mode-control/index.js +68 -0
- package/src/components/writing-mode-control/style.scss +18 -0
- package/src/hooks/behaviors.js +25 -16
- package/src/hooks/margin.js +4 -1
- package/src/hooks/padding.js +4 -1
- package/src/hooks/supports.js +7 -0
- package/src/hooks/typography.js +2 -0
- package/src/hooks/utils.js +8 -7
- package/src/private-apis.js +13 -1
- package/src/private-apis.native.js +2 -0
- package/src/store/actions.js +195 -3
- package/src/store/defaults.js +1 -0
- package/src/store/index.js +10 -0
- package/src/store/private-actions.js +39 -39
- package/src/store/private-selectors.js +5 -8
- package/src/store/reducer.js +22 -9
- package/src/store/selectors.js +87 -25
- package/src/store/test/actions.js +114 -0
- package/src/store/test/private-actions.js +56 -0
- package/src/store/test/private-selectors.js +5 -5
- package/src/store/test/reducer.js +14 -7
- package/src/store/test/selectors.js +1 -1
- package/src/utils/object.js +32 -2
- package/src/utils/test/object.js +36 -0
- package/build/components/block-mobile-toolbar/block-actions-menu.native.js.map +0 -1
- package/build/components/block-mobile-toolbar/index.native.js +0 -135
- package/build/components/block-mobile-toolbar/index.native.js.map +0 -1
- package/build-module/components/block-mobile-toolbar/block-actions-menu.native.js.map +0 -1
- package/build-module/components/block-mobile-toolbar/index.native.js +0 -116
- package/build-module/components/block-mobile-toolbar/index.native.js.map +0 -1
- package/src/components/block-mobile-toolbar/index.native.js +0 -127
- package/src/components/block-mobile-toolbar/style.native.scss +0 -16
- /package/src/components/{block-mobile-toolbar/test/__snapshots__/block-actions-menu.native.js.snap → block-toolbar/test/__snapshots__/block-toolbar-menu.native.js.snap} +0 -0
|
@@ -3,29 +3,11 @@
|
|
|
3
3
|
}
|
|
4
4
|
|
|
5
5
|
.solidBorderColor {
|
|
6
|
-
border-color: $blue-
|
|
6
|
+
border-color: $blue-40;
|
|
7
7
|
}
|
|
8
8
|
|
|
9
9
|
.solidBorderColorDark {
|
|
10
|
-
border-color: $blue-
|
|
11
|
-
}
|
|
12
|
-
|
|
13
|
-
.dashedBorderColor {
|
|
14
|
-
border-color: $gray;
|
|
15
|
-
}
|
|
16
|
-
|
|
17
|
-
.dashedBorderColorDark {
|
|
18
|
-
border-color: $gray-70;
|
|
19
|
-
}
|
|
20
|
-
|
|
21
|
-
.borderFullWidth {
|
|
22
|
-
left: 0;
|
|
23
|
-
right: 0;
|
|
24
|
-
}
|
|
25
|
-
|
|
26
|
-
.containerBorderFullWidth {
|
|
27
|
-
left: -$solid-border-space * 0.5;
|
|
28
|
-
right: -$solid-border-space * 0.5;
|
|
10
|
+
border-color: $blue-50;
|
|
29
11
|
}
|
|
30
12
|
|
|
31
13
|
.dimmed {
|
|
@@ -51,32 +33,28 @@
|
|
|
51
33
|
min-height: 50px;
|
|
52
34
|
}
|
|
53
35
|
|
|
54
|
-
.neutralToolbar {
|
|
55
|
-
margin-left: -$block-edge-to-content;
|
|
56
|
-
margin-right: -$block-edge-to-content;
|
|
57
|
-
}
|
|
58
|
-
|
|
59
36
|
.solidBorder {
|
|
60
37
|
position: absolute;
|
|
61
|
-
top:
|
|
62
|
-
bottom:
|
|
63
|
-
left:
|
|
64
|
-
right:
|
|
65
|
-
border-width:
|
|
66
|
-
border-radius:
|
|
38
|
+
top: -6px;
|
|
39
|
+
bottom: -6px;
|
|
40
|
+
left: -6px;
|
|
41
|
+
right: -6px;
|
|
42
|
+
border-width: 2px;
|
|
43
|
+
border-radius: 2px;
|
|
67
44
|
border-style: solid;
|
|
68
45
|
z-index: 1;
|
|
69
46
|
}
|
|
70
47
|
|
|
71
|
-
.
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
48
|
+
.solidBorderCompact {
|
|
49
|
+
top: 0;
|
|
50
|
+
bottom: 0;
|
|
51
|
+
left: 0;
|
|
52
|
+
right: 0;
|
|
53
|
+
}
|
|
54
|
+
|
|
55
|
+
.solidBorderTextContent {
|
|
56
|
+
left: 0;
|
|
57
|
+
right: 0;
|
|
80
58
|
}
|
|
81
59
|
|
|
82
60
|
.fullWidthPadding {
|
|
@@ -66,12 +66,12 @@
|
|
|
66
66
|
}
|
|
67
67
|
|
|
68
68
|
.defaultBlock {
|
|
69
|
-
margin: $block-edge-to-content;
|
|
69
|
+
margin: $block-edge-to-content * 0.5 $block-edge-to-content;
|
|
70
70
|
}
|
|
71
71
|
|
|
72
72
|
.defaultAppender {
|
|
73
|
-
margin-top: $
|
|
74
|
-
margin-bottom: $
|
|
73
|
+
margin-top: $grid-unit;
|
|
74
|
+
margin-bottom: $grid-unit;
|
|
75
75
|
width: 100%;
|
|
76
76
|
}
|
|
77
77
|
|
|
@@ -3,7 +3,8 @@
|
|
|
3
3
|
*/
|
|
4
4
|
import { __ } from '@wordpress/i18n';
|
|
5
5
|
import { ToolbarButton, ToolbarGroup } from '@wordpress/components';
|
|
6
|
-
import {
|
|
6
|
+
import { focus } from '@wordpress/dom';
|
|
7
|
+
import { useReducer, useRef, useEffect } from '@wordpress/element';
|
|
7
8
|
import { lock } from '@wordpress/icons';
|
|
8
9
|
|
|
9
10
|
/**
|
|
@@ -12,7 +13,7 @@ import { lock } from '@wordpress/icons';
|
|
|
12
13
|
import BlockLockModal from './modal';
|
|
13
14
|
import useBlockLock from './use-block-lock';
|
|
14
15
|
|
|
15
|
-
export default function BlockLockToolbar( { clientId } ) {
|
|
16
|
+
export default function BlockLockToolbar( { clientId, wrapperRef } ) {
|
|
16
17
|
const { canEdit, canMove, canRemove, canLock } = useBlockLock( clientId );
|
|
17
18
|
|
|
18
19
|
const [ isModalOpen, toggleModal ] = useReducer(
|
|
@@ -20,11 +21,37 @@ export default function BlockLockToolbar( { clientId } ) {
|
|
|
20
21
|
false
|
|
21
22
|
);
|
|
22
23
|
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
24
|
+
const lockButtonRef = useRef( null );
|
|
25
|
+
const isFirstRender = useRef( true );
|
|
26
|
+
|
|
27
|
+
const shouldHideBlockLockUI =
|
|
28
|
+
! canLock || ( canEdit && canMove && canRemove );
|
|
29
|
+
|
|
30
|
+
// Restore focus manually on the first focusable element in the toolbar
|
|
31
|
+
// when the block lock modal is closed and the block is not locked anymore.
|
|
32
|
+
// See https://github.com/WordPress/gutenberg/issues/51447
|
|
33
|
+
useEffect( () => {
|
|
34
|
+
if ( isFirstRender.current ) {
|
|
35
|
+
isFirstRender.current = false;
|
|
36
|
+
return;
|
|
37
|
+
}
|
|
38
|
+
|
|
39
|
+
if ( ! isModalOpen && shouldHideBlockLockUI ) {
|
|
40
|
+
focus.focusable
|
|
41
|
+
.find( wrapperRef.current, {
|
|
42
|
+
sequential: false,
|
|
43
|
+
} )
|
|
44
|
+
.find(
|
|
45
|
+
( element ) =>
|
|
46
|
+
element.tagName === 'BUTTON' &&
|
|
47
|
+
element !== lockButtonRef.current
|
|
48
|
+
)
|
|
49
|
+
?.focus();
|
|
50
|
+
}
|
|
51
|
+
// wrapperRef is a reference object and should be stable
|
|
52
|
+
}, [ isModalOpen, shouldHideBlockLockUI, wrapperRef ] );
|
|
26
53
|
|
|
27
|
-
if (
|
|
54
|
+
if ( shouldHideBlockLockUI ) {
|
|
28
55
|
return null;
|
|
29
56
|
}
|
|
30
57
|
|
|
@@ -35,6 +62,7 @@ export default function BlockLockToolbar( { clientId } ) {
|
|
|
35
62
|
icon={ lock }
|
|
36
63
|
label={ __( 'Unlock' ) }
|
|
37
64
|
onClick={ toggleModal }
|
|
65
|
+
ref={ lockButtonRef }
|
|
38
66
|
/>
|
|
39
67
|
</ToolbarGroup>
|
|
40
68
|
{ isModalOpen && (
|
|
@@ -7,7 +7,7 @@ import { Platform } from 'react-native';
|
|
|
7
7
|
* WordPress dependencies
|
|
8
8
|
*/
|
|
9
9
|
import { __ } from '@wordpress/i18n';
|
|
10
|
-
import { Picker, ToolbarButton } from '@wordpress/components';
|
|
10
|
+
import { Picker, ToolbarButton, ToolbarGroup } from '@wordpress/components';
|
|
11
11
|
import { withInstanceId, compose } from '@wordpress/compose';
|
|
12
12
|
import { withSelect, withDispatch } from '@wordpress/data';
|
|
13
13
|
import { useCallback, useEffect, useRef, useState } from '@wordpress/element';
|
|
@@ -107,7 +107,7 @@ export const BlockMover = ( {
|
|
|
107
107
|
}
|
|
108
108
|
|
|
109
109
|
return (
|
|
110
|
-
|
|
110
|
+
<ToolbarGroup>
|
|
111
111
|
<ToolbarButton
|
|
112
112
|
title={ ! isFirst ? backwardButtonTitle : firstBlockTitle }
|
|
113
113
|
isDisabled={ isFirst }
|
|
@@ -136,7 +136,7 @@ export const BlockMover = ( {
|
|
|
136
136
|
leftAlign={ true }
|
|
137
137
|
hideCancelButton={ Platform.OS !== 'ios' }
|
|
138
138
|
/>
|
|
139
|
-
|
|
139
|
+
</ToolbarGroup>
|
|
140
140
|
);
|
|
141
141
|
};
|
|
142
142
|
|
|
@@ -43,7 +43,19 @@ exports[`Block Mover Picker moving blocks moves blocks up and down 1`] = `
|
|
|
43
43
|
`;
|
|
44
44
|
|
|
45
45
|
exports[`Block Mover Picker should render without crashing and match snapshot 1`] = `
|
|
46
|
-
|
|
46
|
+
<View
|
|
47
|
+
style={
|
|
48
|
+
[
|
|
49
|
+
{
|
|
50
|
+
"height": 44,
|
|
51
|
+
},
|
|
52
|
+
{
|
|
53
|
+
"borderLeftWidth": 0.5,
|
|
54
|
+
},
|
|
55
|
+
undefined,
|
|
56
|
+
]
|
|
57
|
+
}
|
|
58
|
+
>
|
|
47
59
|
<View>
|
|
48
60
|
<View
|
|
49
61
|
accessibilityHint="Double tap to move the block to the left"
|
|
@@ -99,7 +111,6 @@ exports[`Block Mover Picker should render without crashing and match snapshot 1`
|
|
|
99
111
|
}
|
|
100
112
|
>
|
|
101
113
|
<Svg
|
|
102
|
-
colorScheme="light"
|
|
103
114
|
height={24}
|
|
104
115
|
style={{}}
|
|
105
116
|
viewBox="0 0 24 24"
|
|
@@ -111,7 +122,7 @@ exports[`Block Mover Picker should render without crashing and match snapshot 1`
|
|
|
111
122
|
</View>
|
|
112
123
|
</View>
|
|
113
124
|
</View>
|
|
114
|
-
</View
|
|
125
|
+
</View>
|
|
115
126
|
<View>
|
|
116
127
|
<View
|
|
117
128
|
accessibilityHint="Double tap to move the block to the right"
|
|
@@ -167,7 +178,6 @@ exports[`Block Mover Picker should render without crashing and match snapshot 1`
|
|
|
167
178
|
}
|
|
168
179
|
>
|
|
169
180
|
<Svg
|
|
170
|
-
colorScheme="light"
|
|
171
181
|
height={24}
|
|
172
182
|
style={{}}
|
|
173
183
|
viewBox="0 0 24 24"
|
|
@@ -179,6 +189,6 @@ exports[`Block Mover Picker should render without crashing and match snapshot 1`
|
|
|
179
189
|
</View>
|
|
180
190
|
</View>
|
|
181
191
|
</View>
|
|
182
|
-
</View
|
|
183
|
-
|
|
192
|
+
</View>
|
|
193
|
+
</View>
|
|
184
194
|
`;
|
|
@@ -14,6 +14,7 @@ import useBlockDisplayInformation from '../use-block-display-information';
|
|
|
14
14
|
import BlockIcon from '../block-icon';
|
|
15
15
|
import { useShowMoversGestures } from '../block-toolbar/utils';
|
|
16
16
|
import { store as blockEditorStore } from '../../store';
|
|
17
|
+
import { unlock } from '../../lock-unlock';
|
|
17
18
|
|
|
18
19
|
/**
|
|
19
20
|
* Block parent selector component, displaying the hierarchy of the
|
|
@@ -24,14 +25,15 @@ import { store as blockEditorStore } from '../../store';
|
|
|
24
25
|
export default function BlockParentSelector() {
|
|
25
26
|
const { selectBlock, toggleBlockHighlight } =
|
|
26
27
|
useDispatch( blockEditorStore );
|
|
27
|
-
const { firstParentClientId,
|
|
28
|
+
const { firstParentClientId, isVisible, isDistractionFree } = useSelect(
|
|
28
29
|
( select ) => {
|
|
29
30
|
const {
|
|
30
31
|
getBlockName,
|
|
31
32
|
getBlockParents,
|
|
32
33
|
getSelectedBlockClientId,
|
|
33
34
|
getSettings,
|
|
34
|
-
|
|
35
|
+
getBlockEditingMode,
|
|
36
|
+
} = unlock( select( blockEditorStore ) );
|
|
35
37
|
const { hasBlockSupport } = select( blocksStore );
|
|
36
38
|
const selectedBlockClientId = getSelectedBlockClientId();
|
|
37
39
|
const parents = getBlockParents( selectedBlockClientId );
|
|
@@ -41,11 +43,14 @@ export default function BlockParentSelector() {
|
|
|
41
43
|
const settings = getSettings();
|
|
42
44
|
return {
|
|
43
45
|
firstParentClientId: _firstParentClientId,
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
'
|
|
47
|
-
|
|
48
|
-
|
|
46
|
+
isVisible:
|
|
47
|
+
_firstParentClientId &&
|
|
48
|
+
getBlockEditingMode( _firstParentClientId ) === 'default' &&
|
|
49
|
+
hasBlockSupport(
|
|
50
|
+
_parentBlockType,
|
|
51
|
+
'__experimentalParentSelector',
|
|
52
|
+
true
|
|
53
|
+
),
|
|
49
54
|
isDistractionFree: settings.isDistractionFree,
|
|
50
55
|
};
|
|
51
56
|
},
|
|
@@ -66,7 +71,7 @@ export default function BlockParentSelector() {
|
|
|
66
71
|
},
|
|
67
72
|
} );
|
|
68
73
|
|
|
69
|
-
if (
|
|
74
|
+
if ( ! isVisible ) {
|
|
70
75
|
return null;
|
|
71
76
|
}
|
|
72
77
|
|
|
@@ -8,7 +8,7 @@ import {
|
|
|
8
8
|
Button,
|
|
9
9
|
__experimentalHStack as HStack,
|
|
10
10
|
} from '@wordpress/components';
|
|
11
|
-
import { __
|
|
11
|
+
import { __ } from '@wordpress/i18n';
|
|
12
12
|
|
|
13
13
|
/**
|
|
14
14
|
* Internal dependencies
|
|
@@ -16,38 +16,26 @@ import { __, _n } from '@wordpress/i18n';
|
|
|
16
16
|
import { store as blockEditorStore } from '../../store';
|
|
17
17
|
import { unlock } from '../../lock-unlock';
|
|
18
18
|
|
|
19
|
-
|
|
20
|
-
// important blocks. For example, in the site editor, the Query Loop block is
|
|
21
|
-
// deemed important. In such cases, we'll ask the user for confirmation that
|
|
22
|
-
// they intended to remove such block(s).
|
|
23
|
-
//
|
|
24
|
-
// @see https://github.com/WordPress/gutenberg/pull/51145
|
|
25
|
-
export const blockTypePromptMessages = {
|
|
26
|
-
'core/query': __( 'Query Loop displays a list of posts or pages.' ),
|
|
27
|
-
'core/post-content': __(
|
|
28
|
-
'Post Content displays the content of a post or page.'
|
|
29
|
-
),
|
|
30
|
-
};
|
|
31
|
-
|
|
32
|
-
export function BlockRemovalWarningModal() {
|
|
19
|
+
export function BlockRemovalWarningModal( { rules } ) {
|
|
33
20
|
const { clientIds, selectPrevious, blockNamesForPrompt } = useSelect(
|
|
34
21
|
( select ) =>
|
|
35
22
|
unlock( select( blockEditorStore ) ).getRemovalPromptData()
|
|
36
23
|
);
|
|
37
24
|
|
|
38
25
|
const {
|
|
39
|
-
|
|
40
|
-
|
|
26
|
+
clearBlockRemovalPrompt,
|
|
27
|
+
setBlockRemovalRules,
|
|
41
28
|
privateRemoveBlocks,
|
|
42
29
|
} = unlock( useDispatch( blockEditorStore ) );
|
|
43
30
|
|
|
44
|
-
//
|
|
31
|
+
// Load block removal rules, simultaneously signalling that the block
|
|
32
|
+
// removal prompt is in place.
|
|
45
33
|
useEffect( () => {
|
|
46
|
-
|
|
34
|
+
setBlockRemovalRules( rules );
|
|
47
35
|
return () => {
|
|
48
|
-
|
|
36
|
+
setBlockRemovalRules();
|
|
49
37
|
};
|
|
50
|
-
}, [
|
|
38
|
+
}, [ rules, setBlockRemovalRules ] );
|
|
51
39
|
|
|
52
40
|
if ( ! blockNamesForPrompt ) {
|
|
53
41
|
return;
|
|
@@ -55,34 +43,30 @@ export function BlockRemovalWarningModal() {
|
|
|
55
43
|
|
|
56
44
|
const onConfirmRemoval = () => {
|
|
57
45
|
privateRemoveBlocks( clientIds, selectPrevious, /* force */ true );
|
|
58
|
-
|
|
46
|
+
clearBlockRemovalPrompt();
|
|
59
47
|
};
|
|
60
48
|
|
|
61
49
|
return (
|
|
62
50
|
<Modal
|
|
63
51
|
title={ __( 'Are you sure?' ) }
|
|
64
|
-
onRequestClose={
|
|
52
|
+
onRequestClose={ clearBlockRemovalPrompt }
|
|
65
53
|
>
|
|
66
54
|
{ blockNamesForPrompt.length === 1 ? (
|
|
67
|
-
<p>{
|
|
55
|
+
<p>{ rules[ blockNamesForPrompt[ 0 ] ] }</p>
|
|
68
56
|
) : (
|
|
69
57
|
<ul style={ { listStyleType: 'disc', paddingLeft: '1rem' } }>
|
|
70
58
|
{ blockNamesForPrompt.map( ( name ) => (
|
|
71
|
-
<li key={ name }>
|
|
72
|
-
{ blockTypePromptMessages[ name ] }
|
|
73
|
-
</li>
|
|
59
|
+
<li key={ name }>{ rules[ name ] }</li>
|
|
74
60
|
) ) }
|
|
75
61
|
</ul>
|
|
76
62
|
) }
|
|
77
63
|
<p>
|
|
78
|
-
{
|
|
79
|
-
'Removing
|
|
80
|
-
'Removing
|
|
81
|
-
blockNamesForPrompt.length
|
|
82
|
-
) }
|
|
64
|
+
{ blockNamesForPrompt.length > 1
|
|
65
|
+
? __( 'Removing these blocks is not advised.' )
|
|
66
|
+
: __( 'Removing this block is not advised.' ) }
|
|
83
67
|
</p>
|
|
84
68
|
<HStack justify="right">
|
|
85
|
-
<Button variant="tertiary" onClick={
|
|
69
|
+
<Button variant="tertiary" onClick={ clearBlockRemovalPrompt }>
|
|
86
70
|
{ __( 'Cancel' ) }
|
|
87
71
|
</Button>
|
|
88
72
|
<Button variant="primary" onClick={ onConfirmRemoval }>
|
|
@@ -1,7 +1,11 @@
|
|
|
1
1
|
/**
|
|
2
2
|
* WordPress dependencies
|
|
3
3
|
*/
|
|
4
|
-
import {
|
|
4
|
+
import {
|
|
5
|
+
createSlotFill,
|
|
6
|
+
ToolbarButton,
|
|
7
|
+
ToolbarGroup,
|
|
8
|
+
} from '@wordpress/components';
|
|
5
9
|
import { __ } from '@wordpress/i18n';
|
|
6
10
|
import { withDispatch } from '@wordpress/data';
|
|
7
11
|
import { cog } from '@wordpress/icons';
|
|
@@ -9,11 +13,13 @@ import { cog } from '@wordpress/icons';
|
|
|
9
13
|
const { Fill, Slot } = createSlotFill( 'SettingsToolbarButton' );
|
|
10
14
|
|
|
11
15
|
const SettingsButton = ( { openGeneralSidebar } ) => (
|
|
12
|
-
<
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
16
|
+
<ToolbarGroup>
|
|
17
|
+
<ToolbarButton
|
|
18
|
+
title={ __( 'Open Settings' ) }
|
|
19
|
+
icon={ cog }
|
|
20
|
+
onClick={ openGeneralSidebar }
|
|
21
|
+
/>
|
|
22
|
+
</ToolbarGroup>
|
|
17
23
|
);
|
|
18
24
|
|
|
19
25
|
const SettingsButtonFill = ( props ) => (
|
|
@@ -9,6 +9,7 @@ import { Platform, findNodeHandle } from 'react-native';
|
|
|
9
9
|
import {
|
|
10
10
|
getClipboard,
|
|
11
11
|
setClipboard,
|
|
12
|
+
ToolbarGroup,
|
|
12
13
|
ToolbarButton,
|
|
13
14
|
Picker,
|
|
14
15
|
} from '@wordpress/components';
|
|
@@ -99,9 +100,11 @@ const BlockActionsMenu = ( {
|
|
|
99
100
|
} = getMoversSetup( isStackedHorizontally, moversOptions );
|
|
100
101
|
|
|
101
102
|
// Check if selected block is Groupable and/or Ungroupable.
|
|
102
|
-
const convertToGroupButtonProps = useConvertToGroupButtonProps(
|
|
103
|
-
selectedBlockClientId
|
|
104
|
-
|
|
103
|
+
const convertToGroupButtonProps = useConvertToGroupButtonProps(
|
|
104
|
+
// `selectedBlockClientId` can be undefined in some cases where this
|
|
105
|
+
// component gets re-rendered right after the block is removed.
|
|
106
|
+
selectedBlockClientId ? [ selectedBlockClientId ] : []
|
|
107
|
+
);
|
|
105
108
|
const { isGroupable, isUngroupable } = convertToGroupButtonProps;
|
|
106
109
|
const showConvertToGroupButton =
|
|
107
110
|
( isGroupable || isUngroupable ) && canRemove;
|
|
@@ -213,16 +216,12 @@ const BlockActionsMenu = ( {
|
|
|
213
216
|
id: 'convertToRegularBlocksOption',
|
|
214
217
|
label:
|
|
215
218
|
innerBlockCount > 1
|
|
216
|
-
? __( '
|
|
217
|
-
: __( '
|
|
219
|
+
? __( 'Detach patterns' )
|
|
220
|
+
: __( 'Detach pattern' ),
|
|
218
221
|
value: 'convertToRegularBlocksOption',
|
|
219
222
|
onSelect: () => {
|
|
220
|
-
|
|
221
|
-
|
|
222
|
-
? /* translators: %s: name of the reusable block */
|
|
223
|
-
__( '%s converted to regular blocks' )
|
|
224
|
-
: /* translators: %s: name of the reusable block */
|
|
225
|
-
__( '%s converted to regular block' );
|
|
223
|
+
/* translators: %s: name of the synced block */
|
|
224
|
+
const successNotice = __( '%s detached' );
|
|
226
225
|
createSuccessNotice(
|
|
227
226
|
sprintf(
|
|
228
227
|
successNotice,
|
|
@@ -258,11 +257,13 @@ const BlockActionsMenu = ( {
|
|
|
258
257
|
// End early if there are no options to show.
|
|
259
258
|
if ( ! options.length ) {
|
|
260
259
|
return (
|
|
261
|
-
<
|
|
262
|
-
|
|
263
|
-
|
|
264
|
-
|
|
265
|
-
|
|
260
|
+
<ToolbarGroup>
|
|
261
|
+
<ToolbarButton
|
|
262
|
+
title={ __( 'Open Block Actions Menu' ) }
|
|
263
|
+
icon={ moreHorizontalMobile }
|
|
264
|
+
disabled={ true }
|
|
265
|
+
/>
|
|
266
|
+
</ToolbarGroup>
|
|
266
267
|
);
|
|
267
268
|
}
|
|
268
269
|
|
|
@@ -298,7 +299,7 @@ const BlockActionsMenu = ( {
|
|
|
298
299
|
anchorNodeRef ? findNodeHandle( anchorNodeRef ) : undefined;
|
|
299
300
|
|
|
300
301
|
return (
|
|
301
|
-
|
|
302
|
+
<ToolbarGroup>
|
|
302
303
|
<ToolbarButton
|
|
303
304
|
title={ __( 'Open Block Actions Menu' ) }
|
|
304
305
|
onClick={ onPickerPresent }
|
|
@@ -328,7 +329,7 @@ const BlockActionsMenu = ( {
|
|
|
328
329
|
selectedBlock={ getBlocksByClientId( selectedBlockClientId ) }
|
|
329
330
|
selectedBlockClientId={ selectedBlockClientId }
|
|
330
331
|
/>
|
|
331
|
-
|
|
332
|
+
</ToolbarGroup>
|
|
332
333
|
);
|
|
333
334
|
};
|
|
334
335
|
|
|
@@ -35,9 +35,9 @@ import __unstableBlockNameContext from './block-name-context';
|
|
|
35
35
|
import { unlock } from '../../lock-unlock';
|
|
36
36
|
|
|
37
37
|
const BlockToolbar = ( { hideDragHandle } ) => {
|
|
38
|
+
const { getSelectedBlockClientId } = useSelect( blockEditorStore );
|
|
38
39
|
const {
|
|
39
40
|
blockClientIds,
|
|
40
|
-
blockClientId,
|
|
41
41
|
blockType,
|
|
42
42
|
hasFixedToolbar,
|
|
43
43
|
isDistractionFree,
|
|
@@ -61,7 +61,6 @@ const BlockToolbar = ( { hideDragHandle } ) => {
|
|
|
61
61
|
|
|
62
62
|
return {
|
|
63
63
|
blockClientIds: selectedBlockClientIds,
|
|
64
|
-
blockClientId: selectedBlockClientId,
|
|
65
64
|
blockType:
|
|
66
65
|
selectedBlockClientId &&
|
|
67
66
|
getBlockType( getBlockName( selectedBlockClientId ) ),
|
|
@@ -78,6 +77,8 @@ const BlockToolbar = ( { hideDragHandle } ) => {
|
|
|
78
77
|
};
|
|
79
78
|
}, [] );
|
|
80
79
|
|
|
80
|
+
const toolbarWrapperRef = useRef( null );
|
|
81
|
+
|
|
81
82
|
// Handles highlighting the current block outline on hover or focus of the
|
|
82
83
|
// block type toolbar area.
|
|
83
84
|
const { toggleBlockHighlight } = useDispatch( blockEditorStore );
|
|
@@ -89,7 +90,7 @@ const BlockToolbar = ( { hideDragHandle } ) => {
|
|
|
89
90
|
if ( isFocused && isDistractionFree ) {
|
|
90
91
|
return;
|
|
91
92
|
}
|
|
92
|
-
toggleBlockHighlight(
|
|
93
|
+
toggleBlockHighlight( getSelectedBlockClientId(), isFocused );
|
|
93
94
|
},
|
|
94
95
|
}
|
|
95
96
|
);
|
|
@@ -123,18 +124,19 @@ const BlockToolbar = ( { hideDragHandle } ) => {
|
|
|
123
124
|
} );
|
|
124
125
|
|
|
125
126
|
return (
|
|
126
|
-
<div className={ classes }>
|
|
127
|
+
<div className={ classes } ref={ toolbarWrapperRef }>
|
|
127
128
|
{ ! isMultiToolbar &&
|
|
128
129
|
isLargeViewport &&
|
|
129
130
|
blockEditingMode === 'default' && <BlockParentSelector /> }
|
|
130
|
-
|
|
131
|
-
|
|
132
|
-
|
|
131
|
+
{ ( shouldShowVisualToolbar || isMultiToolbar ) &&
|
|
132
|
+
blockEditingMode === 'default' && (
|
|
133
|
+
<div ref={ nodeRef } { ...showMoversGestures }>
|
|
133
134
|
<ToolbarGroup className="block-editor-block-toolbar__block-controls">
|
|
134
135
|
<BlockSwitcher clientIds={ blockClientIds } />
|
|
135
136
|
{ ! isMultiToolbar && (
|
|
136
137
|
<BlockLockToolbar
|
|
137
138
|
clientId={ blockClientIds[ 0 ] }
|
|
139
|
+
wrapperRef={ toolbarWrapperRef }
|
|
138
140
|
/>
|
|
139
141
|
) }
|
|
140
142
|
<BlockMover
|
|
@@ -142,8 +144,8 @@ const BlockToolbar = ( { hideDragHandle } ) => {
|
|
|
142
144
|
hideDragHandle={ hideDragHandle }
|
|
143
145
|
/>
|
|
144
146
|
</ToolbarGroup>
|
|
145
|
-
|
|
146
|
-
|
|
147
|
+
</div>
|
|
148
|
+
) }
|
|
147
149
|
{ shouldShowVisualToolbar && isMultiToolbar && (
|
|
148
150
|
<BlockGroupToolbar />
|
|
149
151
|
) }
|