@wordpress/block-editor 9.1.0 → 9.4.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/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/draggable-chip.native.js +2 -1
- package/build/components/block-draggable/draggable-chip.native.js.map +1 -1
- package/build/components/block-draggable/index.js.map +1 -1
- package/build/components/block-draggable/index.native.js +7 -3
- package/build/components/block-draggable/index.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.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 +34 -32
- package/build/components/block-list/index.js.map +1 -1
- package/build/components/block-list/index.native.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-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-mobile-toolbar/block-actions-menu.native.js.map +1 -1
- package/build/components/block-mobile-toolbar/index.native.js +2 -1
- package/build/components/block-mobile-toolbar/index.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 +3 -9
- 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 +9 -6
- package/build/components/block-popover/inbetween.js.map +1 -1
- package/build/components/block-popover/index.js +2 -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 +3 -7
- package/build/components/block-settings-menu/block-mode-toggle.js.map +1 -1
- package/build/components/block-settings-menu/block-settings-dropdown.js +6 -3
- 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-switcher/block-transformations-menu.js.map +1 -1
- package/build/components/block-title/use-block-display-title.js +3 -10
- 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.map +1 -1
- package/build/components/block-tools/block-selection-button.js +1 -0
- package/build/components/block-tools/block-selection-button.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 +16 -2
- package/build/components/block-variation-transforms/index.js.map +1 -1
- package/build/components/color-style-selector/index.js.map +1 -1
- package/build/components/colors/with-colors.js.map +1 -1
- package/build/components/colors-gradients/dropdown.js +72 -95
- package/build/components/colors-gradients/dropdown.js.map +1 -1
- package/build/components/colors-gradients/panel-color-gradient-settings.js +35 -60
- package/build/components/colors-gradients/panel-color-gradient-settings.js.map +1 -1
- package/build/components/convert-to-group-buttons/toolbar.js +22 -5
- 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/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/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 +41 -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 +4 -4
- 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/branch.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 +5 -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 +23 -14
- package/build/components/media-replace-flow/index.js.map +1 -1
- package/build/components/media-upload/index.native.js +10 -4
- 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 +62 -7
- 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 +56 -0
- package/build/components/publish-date-time-picker/index.js.map +1 -0
- 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 +1 -1
- package/build/components/rich-text/index.js.map +1 -1
- package/build/components/rich-text/index.native.js +5 -1
- package/build/components/rich-text/index.native.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/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 +12 -12
- 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-input.js +15 -0
- package/build/components/writing-flow/use-input.js.map +1 -1
- 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.map +1 -1
- package/build/components/writing-flow/use-tab-nav.js.map +1 -1
- package/build/elements/index.js +17 -0
- package/build/elements/index.js.map +1 -0
- 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 +8 -88
- package/build/hooks/color.js.map +1 -1
- package/build/hooks/dimensions.js +14 -4
- package/build/hooks/dimensions.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 +3 -7
- package/build/hooks/index.js.map +1 -1
- package/build/hooks/layout.js +44 -5
- package/build/hooks/layout.js.map +1 -1
- package/build/index.js +14 -7
- package/build/index.js.map +1 -1
- package/build/layouts/flex.js +7 -4
- package/build/layouts/flex.js.map +1 -1
- package/build/store/actions.js +24 -14
- package/build/store/actions.js.map +1 -1
- package/build/store/reducer.js +35 -11
- package/build/store/reducer.js.map +1 -1
- package/build/store/selectors.js +30 -2
- 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/draggable-chip.native.js +2 -1
- package/build-module/components/block-draggable/draggable-chip.native.js.map +1 -1
- package/build-module/components/block-draggable/index.js.map +1 -1
- package/build-module/components/block-draggable/index.native.js +7 -3
- package/build-module/components/block-draggable/index.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.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 +35 -33
- package/build-module/components/block-list/index.js.map +1 -1
- package/build-module/components/block-list/index.native.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-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-mobile-toolbar/block-actions-menu.native.js.map +1 -1
- package/build-module/components/block-mobile-toolbar/index.native.js +2 -1
- package/build-module/components/block-mobile-toolbar/index.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 +3 -9
- 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 +9 -6
- package/build-module/components/block-popover/inbetween.js.map +1 -1
- package/build-module/components/block-popover/index.js +2 -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 +3 -5
- 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 +6 -2
- 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-switcher/block-transformations-menu.js.map +1 -1
- package/build-module/components/block-title/use-block-display-title.js +3 -9
- 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.map +1 -1
- package/build-module/components/block-tools/block-selection-button.js +1 -0
- package/build-module/components/block-tools/block-selection-button.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 +13 -2
- package/build-module/components/block-variation-transforms/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.map +1 -1
- package/build-module/components/colors-gradients/dropdown.js +74 -97
- package/build-module/components/colors-gradients/dropdown.js.map +1 -1
- package/build-module/components/colors-gradients/panel-color-gradient-settings.js +36 -64
- package/build-module/components/colors-gradients/panel-color-gradient-settings.js.map +1 -1
- package/build-module/components/convert-to-group-buttons/toolbar.js +23 -6
- 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/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/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 +4 -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 +2 -1
- 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/branch.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 +3 -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 +24 -14
- package/build-module/components/media-replace-flow/index.js.map +1 -1
- package/build-module/components/media-upload/index.native.js +8 -3
- 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 +63 -8
- 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 +42 -0
- package/build-module/components/publish-date-time-picker/index.js.map +1 -0
- 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 +1 -1
- package/build-module/components/rich-text/index.js.map +1 -1
- package/build-module/components/rich-text/index.native.js +5 -1
- package/build-module/components/rich-text/index.native.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/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 +12 -11
- 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-input.js +15 -0
- package/build-module/components/writing-flow/use-input.js.map +1 -1
- 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.map +1 -1
- package/build-module/components/writing-flow/use-tab-nav.js.map +1 -1
- package/build-module/elements/index.js +8 -0
- package/build-module/elements/index.js.map +1 -0
- 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 +8 -88
- package/build-module/hooks/color.js.map +1 -1
- package/build-module/hooks/dimensions.js +14 -4
- package/build-module/hooks/dimensions.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 +1 -1
- package/build-module/hooks/index.js.map +1 -1
- package/build-module/hooks/layout.js +45 -6
- package/build-module/hooks/layout.js.map +1 -1
- package/build-module/index.js +2 -1
- package/build-module/index.js.map +1 -1
- package/build-module/layouts/flex.js +6 -4
- package/build-module/layouts/flex.js.map +1 -1
- package/build-module/store/actions.js +18 -11
- package/build-module/store/actions.js.map +1 -1
- package/build-module/store/reducer.js +36 -12
- package/build-module/store/reducer.js.map +1 -1
- package/build-module/store/selectors.js +25 -2
- 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 +37 -37
- package/build-style/style.css +37 -37
- package/package.json +30 -30
- 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/draggable-chip.native.js +1 -1
- package/src/components/block-draggable/index.js +6 -13
- package/src/components/block-draggable/index.native.js +10 -14
- package/src/components/block-draggable/test/__snapshots__/index.native.js.snap +73 -0
- package/src/components/block-draggable/test/helpers.native.js +183 -0
- package/src/components/block-draggable/test/index.native.js +493 -0
- package/src/components/block-edit/test/edit.js +2 -1
- 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 +8 -10
- package/src/components/block-list/block.native.js +11 -15
- package/src/components/block-list/index.js +46 -47
- package/src/components/block-list/index.native.js +12 -21
- package/src/components/block-list/style.scss +1 -1
- 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-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-mobile-toolbar/block-actions-menu.native.js +4 -6
- package/src/components/block-mobile-toolbar/index.native.js +1 -0
- package/src/components/block-mover/button.js +2 -3
- package/src/components/block-mover/index.native.js +4 -6
- package/src/components/block-mover/test/__snapshots__/index.native.js.snap +4 -0
- package/src/components/block-parent-selector/index.js +2 -3
- package/src/components/block-pattern-setup/index.js +4 -14
- package/src/components/block-pattern-setup/setup-toolbar.js +2 -9
- package/src/components/block-popover/inbetween.js +12 -7
- package/src/components/block-popover/index.js +1 -0
- 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 +4 -8
- package/src/components/block-settings-menu/block-settings-dropdown.js +9 -8
- 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-switcher/block-transformations-menu.js +2 -4
- package/src/components/block-title/use-block-display-title.js +9 -7
- 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 +2 -5
- package/src/components/block-tools/block-selection-button.js +1 -0
- 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 +10 -8
- 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 +8 -12
- package/src/components/colors-gradients/dropdown.js +49 -69
- package/src/components/colors-gradients/panel-color-gradient-settings.js +30 -76
- package/src/components/colors-gradients/style.scss +11 -37
- package/src/components/colors-gradients/test/control.js +10 -10
- package/src/components/convert-to-group-buttons/toolbar.js +32 -19
- package/src/components/copy-handler/README.md +7 -2
- package/src/components/copy-handler/index.js +26 -6
- 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/image-editor/aspect-ratio-dropdown.js +2 -6
- package/src/components/image-size-control/index.js +4 -7
- package/src/components/index.js +4 -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/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 +4 -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 +79 -102
- 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/branch.js +22 -23
- package/src/components/list-view/index.js +4 -8
- 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 +3 -3
- package/src/components/media-placeholder/index.native.js +9 -5
- package/src/components/media-replace-flow/index.js +78 -55
- package/src/components/media-upload/README.md +8 -0
- package/src/components/media-upload/index.native.js +6 -2
- package/src/components/media-upload/test/index.native.js +31 -6
- 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 +60 -8
- 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 +52 -0
- package/src/components/publish-date-time-picker/index.js +41 -0
- 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 +9 -4
- package/src/components/rich-text/index.native.js +4 -0
- 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/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 +22 -10
- 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-input.js +12 -0
- package/src/components/writing-flow/use-multi-selection.js +2 -4
- package/src/components/writing-flow/use-select-all.js +2 -5
- package/src/components/writing-flow/use-selection-observer.js +4 -6
- package/src/components/writing-flow/use-tab-nav.js +2 -5
- package/src/elements/index.js +8 -0
- 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 +7 -76
- package/src/hooks/color.scss +9 -0
- package/src/hooks/dimensions.js +11 -3
- 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 +1 -1
- package/src/hooks/layout.js +74 -13
- 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/index.js +1 -1
- package/src/layouts/flex.js +13 -5
- package/src/store/actions.js +772 -729
- package/src/store/reducer.js +219 -183
- package/src/store/selectors.js +82 -54
- package/src/store/test/actions.js +2 -1
- package/src/store/test/reducer.js +145 -10
- package/src/store/test/selectors.js +20 -27
- package/src/style.scss +1 -0
- 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.tsbuildinfo +1 -1
- package/build/components/colors/color-panel.js +0 -82
- package/build/components/colors/color-panel.js.map +0 -1
- package/build/components/colors/color-panel.native.js +0 -11
- package/build/components/colors/color-panel.native.js.map +0 -1
- package/build-module/components/colors/color-panel.js +0 -70
- package/build-module/components/colors/color-panel.js.map +0 -1
- package/build-module/components/colors/color-panel.native.js +0 -4
- package/build-module/components/colors/color-panel.native.js.map +0 -1
- package/src/components/colors/color-panel.js +0 -91
- package/src/components/colors/color-panel.native.js +0 -3
|
@@ -1,8 +1,3 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* External dependencies
|
|
3
|
-
*/
|
|
4
|
-
import { noop, uniqueId } from 'lodash';
|
|
5
|
-
|
|
6
1
|
/**
|
|
7
2
|
* WordPress dependencies
|
|
8
3
|
*/
|
|
@@ -16,10 +11,15 @@ import {
|
|
|
16
11
|
ToolbarButton,
|
|
17
12
|
Dropdown,
|
|
18
13
|
withFilters,
|
|
14
|
+
Tooltip,
|
|
19
15
|
} from '@wordpress/components';
|
|
20
16
|
import { useSelect, withDispatch } from '@wordpress/data';
|
|
21
17
|
import { DOWN } from '@wordpress/keycodes';
|
|
22
|
-
import {
|
|
18
|
+
import {
|
|
19
|
+
postFeaturedImage,
|
|
20
|
+
upload,
|
|
21
|
+
media as mediaIcon,
|
|
22
|
+
} from '@wordpress/icons';
|
|
23
23
|
import { compose } from '@wordpress/compose';
|
|
24
24
|
import { __unstableStripHTML as stripHTML } from '@wordpress/dom';
|
|
25
25
|
import { store as noticesStore } from '@wordpress/notices';
|
|
@@ -32,6 +32,9 @@ import MediaUploadCheck from '../media-upload/check';
|
|
|
32
32
|
import LinkControl from '../link-control';
|
|
33
33
|
import { store as blockEditorStore } from '../../store';
|
|
34
34
|
|
|
35
|
+
const noop = () => {};
|
|
36
|
+
let uniqueId = 0;
|
|
37
|
+
|
|
35
38
|
const MediaReplaceFlow = ( {
|
|
36
39
|
mediaURL,
|
|
37
40
|
mediaId,
|
|
@@ -41,8 +44,9 @@ const MediaReplaceFlow = ( {
|
|
|
41
44
|
onError,
|
|
42
45
|
onSelect,
|
|
43
46
|
onSelectURL,
|
|
47
|
+
onToggleFeaturedImage,
|
|
48
|
+
useFeaturedImage,
|
|
44
49
|
onFilesUpload = noop,
|
|
45
|
-
onCloseModal = noop,
|
|
46
50
|
name = __( 'Replace' ),
|
|
47
51
|
createNotice,
|
|
48
52
|
removeNotice,
|
|
@@ -56,9 +60,7 @@ const MediaReplaceFlow = ( {
|
|
|
56
60
|
return select( blockEditorStore ).getSettings().mediaUpload;
|
|
57
61
|
}, [] );
|
|
58
62
|
const editMediaButtonRef = useRef();
|
|
59
|
-
const errorNoticeID = uniqueId
|
|
60
|
-
'block-editor/media-replace-flow/error-notice/'
|
|
61
|
-
);
|
|
63
|
+
const errorNoticeID = `block-editor/media-replace-flow/error-notice/${ ++uniqueId }`;
|
|
62
64
|
|
|
63
65
|
const onUploadError = ( message ) => {
|
|
64
66
|
const safeMessage = stripHTML( message );
|
|
@@ -82,6 +84,9 @@ const MediaReplaceFlow = ( {
|
|
|
82
84
|
};
|
|
83
85
|
|
|
84
86
|
const selectMedia = ( media, closeMenu ) => {
|
|
87
|
+
if ( useFeaturedImage && onToggleFeaturedImage ) {
|
|
88
|
+
onToggleFeaturedImage();
|
|
89
|
+
}
|
|
85
90
|
closeMenu();
|
|
86
91
|
setMediaURLValue( media?.url );
|
|
87
92
|
// Calling `onSelect` after the state update since it might unmount the component.
|
|
@@ -149,43 +154,56 @@ const MediaReplaceFlow = ( {
|
|
|
149
154
|
renderContent={ ( { onClose } ) => (
|
|
150
155
|
<>
|
|
151
156
|
<NavigableMenu className="block-editor-media-replace-flow__media-upload-menu">
|
|
152
|
-
|
|
153
|
-
|
|
154
|
-
|
|
155
|
-
|
|
156
|
-
value={ multiple ? mediaIds : mediaId }
|
|
157
|
-
onSelect={ ( media ) =>
|
|
158
|
-
selectMedia( media, onClose )
|
|
159
|
-
}
|
|
160
|
-
allowedTypes={ allowedTypes }
|
|
161
|
-
onClose={ onCloseModal }
|
|
162
|
-
render={ ( { open } ) => (
|
|
163
|
-
<MenuItem icon={ mediaIcon } onClick={ open }>
|
|
164
|
-
{ __( 'Open Media Library' ) }
|
|
165
|
-
</MenuItem>
|
|
166
|
-
) }
|
|
167
|
-
/>
|
|
168
|
-
<MediaUploadCheck>
|
|
169
|
-
<FormFileUpload
|
|
170
|
-
onChange={ ( event ) => {
|
|
171
|
-
uploadFiles( event, onClose );
|
|
172
|
-
} }
|
|
173
|
-
accept={ accept }
|
|
157
|
+
<>
|
|
158
|
+
<MediaUpload
|
|
159
|
+
gallery={ gallery }
|
|
160
|
+
addToGallery={ addToGallery }
|
|
174
161
|
multiple={ multiple }
|
|
175
|
-
|
|
176
|
-
|
|
177
|
-
|
|
178
|
-
|
|
179
|
-
|
|
180
|
-
|
|
181
|
-
|
|
182
|
-
|
|
183
|
-
|
|
184
|
-
|
|
185
|
-
|
|
186
|
-
|
|
162
|
+
value={ multiple ? mediaIds : mediaId }
|
|
163
|
+
onSelect={ ( media ) =>
|
|
164
|
+
selectMedia( media, onClose )
|
|
165
|
+
}
|
|
166
|
+
allowedTypes={ allowedTypes }
|
|
167
|
+
render={ ( { open } ) => (
|
|
168
|
+
<MenuItem
|
|
169
|
+
icon={ mediaIcon }
|
|
170
|
+
onClick={ open }
|
|
171
|
+
>
|
|
172
|
+
{ __( 'Open Media Library' ) }
|
|
173
|
+
</MenuItem>
|
|
174
|
+
) }
|
|
187
175
|
/>
|
|
188
|
-
|
|
176
|
+
<MediaUploadCheck>
|
|
177
|
+
<FormFileUpload
|
|
178
|
+
onChange={ ( event ) => {
|
|
179
|
+
uploadFiles( event, onClose );
|
|
180
|
+
} }
|
|
181
|
+
accept={ accept }
|
|
182
|
+
multiple={ multiple }
|
|
183
|
+
render={ ( { openFileDialog } ) => {
|
|
184
|
+
return (
|
|
185
|
+
<MenuItem
|
|
186
|
+
icon={ upload }
|
|
187
|
+
onClick={ () => {
|
|
188
|
+
openFileDialog();
|
|
189
|
+
} }
|
|
190
|
+
>
|
|
191
|
+
{ __( 'Upload' ) }
|
|
192
|
+
</MenuItem>
|
|
193
|
+
);
|
|
194
|
+
} }
|
|
195
|
+
/>
|
|
196
|
+
</MediaUploadCheck>
|
|
197
|
+
</>
|
|
198
|
+
{ onToggleFeaturedImage && (
|
|
199
|
+
<MenuItem
|
|
200
|
+
icon={ postFeaturedImage }
|
|
201
|
+
onClick={ onToggleFeaturedImage }
|
|
202
|
+
isPressed={ useFeaturedImage }
|
|
203
|
+
>
|
|
204
|
+
{ __( 'Use featured image' ) }
|
|
205
|
+
</MenuItem>
|
|
206
|
+
) }
|
|
189
207
|
{ children }
|
|
190
208
|
</NavigableMenu>
|
|
191
209
|
{ onSelectURL && (
|
|
@@ -194,16 +212,21 @@ const MediaReplaceFlow = ( {
|
|
|
194
212
|
<span className="block-editor-media-replace-flow__image-url-label">
|
|
195
213
|
{ __( 'Current media URL:' ) }
|
|
196
214
|
</span>
|
|
197
|
-
|
|
198
|
-
|
|
199
|
-
|
|
200
|
-
|
|
201
|
-
|
|
202
|
-
|
|
203
|
-
|
|
204
|
-
|
|
205
|
-
|
|
206
|
-
|
|
215
|
+
|
|
216
|
+
<Tooltip text={ mediaURLValue } position="bottom">
|
|
217
|
+
<div>
|
|
218
|
+
<LinkControl
|
|
219
|
+
value={ { url: mediaURLValue } }
|
|
220
|
+
settings={ [] }
|
|
221
|
+
showSuggestions={ false }
|
|
222
|
+
onChange={ ( { url } ) => {
|
|
223
|
+
setMediaURLValue( url );
|
|
224
|
+
onSelectURL( url );
|
|
225
|
+
editMediaButtonRef.current.focus();
|
|
226
|
+
} }
|
|
227
|
+
/>
|
|
228
|
+
</div>
|
|
229
|
+
</Tooltip>
|
|
207
230
|
</form>
|
|
208
231
|
) }
|
|
209
232
|
</>
|
|
@@ -64,6 +64,14 @@ If allowedTypes is unset all mime types should be allowed.
|
|
|
64
64
|
- Required: No
|
|
65
65
|
- Platform: Web | Mobile
|
|
66
66
|
|
|
67
|
+
### mode
|
|
68
|
+
|
|
69
|
+
Value of Frame content default mode like 'browse', 'upload' etc.
|
|
70
|
+
|
|
71
|
+
- Type: `String`
|
|
72
|
+
- Required: No
|
|
73
|
+
- Default: false
|
|
74
|
+
- Platform: Web
|
|
67
75
|
### multiple
|
|
68
76
|
|
|
69
77
|
Whether to allow multiple selections or not.
|
|
@@ -39,6 +39,7 @@ export const OPTION_TAKE_VIDEO = __( 'Take a Video' );
|
|
|
39
39
|
export const OPTION_TAKE_PHOTO = __( 'Take a Photo' );
|
|
40
40
|
export const OPTION_TAKE_PHOTO_OR_VIDEO = __( 'Take a Photo or Video' );
|
|
41
41
|
export const OPTION_INSERT_FROM_URL = __( 'Insert from URL' );
|
|
42
|
+
export const OPTION_WORDPRESS_MEDIA_LIBRARY = __( 'WordPress Media Library' );
|
|
42
43
|
|
|
43
44
|
const URL_MEDIA_SOURCE = 'URL';
|
|
44
45
|
|
|
@@ -78,6 +79,8 @@ export class MediaUpload extends Component {
|
|
|
78
79
|
}
|
|
79
80
|
|
|
80
81
|
getAllSources() {
|
|
82
|
+
const { onSelectURL } = this.props;
|
|
83
|
+
|
|
81
84
|
const cameraImageSource = {
|
|
82
85
|
id: mediaSources.deviceCamera, // ID is the value sent to native.
|
|
83
86
|
value: mediaSources.deviceCamera + '-IMAGE', // This is needed to diferenciate image-camera from video-camera sources.
|
|
@@ -124,16 +127,17 @@ export class MediaUpload extends Component {
|
|
|
124
127
|
id: URL_MEDIA_SOURCE,
|
|
125
128
|
value: URL_MEDIA_SOURCE,
|
|
126
129
|
label: __( 'Insert from URL' ),
|
|
127
|
-
types: [ MEDIA_TYPE_AUDIO ],
|
|
130
|
+
types: [ MEDIA_TYPE_AUDIO, MEDIA_TYPE_IMAGE, MEDIA_TYPE_VIDEO ],
|
|
128
131
|
icon: globe,
|
|
129
132
|
};
|
|
130
133
|
|
|
134
|
+
// Only include `urlSource` option if `onSelectURL` prop is present, in order to match the web behavior.
|
|
131
135
|
const internalSources = [
|
|
132
136
|
deviceLibrarySource,
|
|
133
137
|
cameraImageSource,
|
|
134
138
|
cameraVideoSource,
|
|
135
139
|
siteLibrarySource,
|
|
136
|
-
urlSource,
|
|
140
|
+
...( onSelectURL ? [ urlSource ] : [] ),
|
|
137
141
|
];
|
|
138
142
|
|
|
139
143
|
return internalSources.concat( this.state.otherMediaOptions );
|
|
@@ -20,6 +20,7 @@ import {
|
|
|
20
20
|
OPTION_TAKE_VIDEO,
|
|
21
21
|
OPTION_TAKE_PHOTO,
|
|
22
22
|
OPTION_INSERT_FROM_URL,
|
|
23
|
+
OPTION_WORDPRESS_MEDIA_LIBRARY,
|
|
23
24
|
} from '../index';
|
|
24
25
|
|
|
25
26
|
const MEDIA_URL = 'http://host.media.type';
|
|
@@ -33,8 +34,11 @@ describe( 'MediaUpload component', () => {
|
|
|
33
34
|
expect( wrapper ).toBeTruthy();
|
|
34
35
|
} );
|
|
35
36
|
|
|
36
|
-
|
|
37
|
-
const expectOptionForMediaType = (
|
|
37
|
+
describe( 'Media capture options for different media block types', () => {
|
|
38
|
+
const expectOptionForMediaType = async (
|
|
39
|
+
mediaType,
|
|
40
|
+
expectedOptions
|
|
41
|
+
) => {
|
|
38
42
|
const wrapper = render(
|
|
39
43
|
<MediaUpload
|
|
40
44
|
allowedTypes={ [ mediaType ] }
|
|
@@ -52,11 +56,32 @@ describe( 'MediaUpload component', () => {
|
|
|
52
56
|
);
|
|
53
57
|
fireEvent.press( wrapper.getByText( 'Open Picker' ) );
|
|
54
58
|
|
|
55
|
-
|
|
59
|
+
expectedOptions.forEach( ( item ) => {
|
|
60
|
+
const option = wrapper.getByText( item );
|
|
61
|
+
expect( option ).toBeVisible();
|
|
62
|
+
} );
|
|
56
63
|
};
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
64
|
+
|
|
65
|
+
it( 'shows the correct media capture options for the Image block', () => {
|
|
66
|
+
expectOptionForMediaType( MEDIA_TYPE_IMAGE, [
|
|
67
|
+
OPTION_TAKE_PHOTO,
|
|
68
|
+
OPTION_WORDPRESS_MEDIA_LIBRARY,
|
|
69
|
+
OPTION_INSERT_FROM_URL,
|
|
70
|
+
] );
|
|
71
|
+
} );
|
|
72
|
+
|
|
73
|
+
it( 'shows the correct media capture options for the Video block', () => {
|
|
74
|
+
expectOptionForMediaType( MEDIA_TYPE_VIDEO, [
|
|
75
|
+
OPTION_TAKE_VIDEO,
|
|
76
|
+
OPTION_WORDPRESS_MEDIA_LIBRARY,
|
|
77
|
+
] );
|
|
78
|
+
} );
|
|
79
|
+
|
|
80
|
+
it( 'shows the correct media capture options for the Audio block', () => {
|
|
81
|
+
expectOptionForMediaType( MEDIA_TYPE_AUDIO, [
|
|
82
|
+
OPTION_INSERT_FROM_URL,
|
|
83
|
+
] );
|
|
84
|
+
} );
|
|
60
85
|
} );
|
|
61
86
|
|
|
62
87
|
const expectMediaPickerForOption = (
|
|
@@ -69,8 +69,7 @@ function useIsAccessibleToolbar( ref ) {
|
|
|
69
69
|
since: '5.6',
|
|
70
70
|
alternative:
|
|
71
71
|
'ToolbarItem, ToolbarButton or ToolbarDropdownMenu components',
|
|
72
|
-
link:
|
|
73
|
-
'https://developer.wordpress.org/block-editor/components/toolbar-button/#inside-blockcontrols',
|
|
72
|
+
link: 'https://developer.wordpress.org/block-editor/components/toolbar-button/#inside-blockcontrols',
|
|
74
73
|
} );
|
|
75
74
|
}
|
|
76
75
|
setIsAccessibleToolbar( onlyToolbarItem );
|
|
@@ -2,13 +2,14 @@
|
|
|
2
2
|
* External dependencies
|
|
3
3
|
*/
|
|
4
4
|
import { render } from '@testing-library/react';
|
|
5
|
-
import { noop } from 'lodash';
|
|
6
5
|
|
|
7
6
|
/**
|
|
8
7
|
* Internal dependencies
|
|
9
8
|
*/
|
|
10
9
|
import PanelColorSettings from '../';
|
|
11
10
|
|
|
11
|
+
const noop = () => {};
|
|
12
|
+
|
|
12
13
|
describe( 'PanelColorSettings', () => {
|
|
13
14
|
it( 'should not render anything if there are no colors to choose', async () => {
|
|
14
15
|
const { container } = render(
|
|
@@ -7,7 +7,7 @@ import { TextInput, Platform, Dimensions } from 'react-native';
|
|
|
7
7
|
* WordPress dependencies
|
|
8
8
|
*/
|
|
9
9
|
import { Component } from '@wordpress/element';
|
|
10
|
-
import { getPxFromCssUnit } from '@wordpress/block-editor';
|
|
10
|
+
import { RichText, getPxFromCssUnit } from '@wordpress/block-editor';
|
|
11
11
|
|
|
12
12
|
/**
|
|
13
13
|
* Internal dependencies
|
|
@@ -18,6 +18,9 @@ export default class PlainText extends Component {
|
|
|
18
18
|
constructor() {
|
|
19
19
|
super( ...arguments );
|
|
20
20
|
this.isAndroid = Platform.OS === 'android';
|
|
21
|
+
|
|
22
|
+
this.onChangeTextInput = this.onChangeTextInput.bind( this );
|
|
23
|
+
this.onChangeRichText = this.onChangeRichText.bind( this );
|
|
21
24
|
}
|
|
22
25
|
|
|
23
26
|
componentDidMount() {
|
|
@@ -44,7 +47,7 @@ export default class PlainText extends Component {
|
|
|
44
47
|
|
|
45
48
|
componentDidUpdate( prevProps ) {
|
|
46
49
|
if ( ! this.props.isSelected && prevProps.isSelected ) {
|
|
47
|
-
this._input
|
|
50
|
+
this._input?.blur();
|
|
48
51
|
}
|
|
49
52
|
}
|
|
50
53
|
|
|
@@ -55,11 +58,11 @@ export default class PlainText extends Component {
|
|
|
55
58
|
}
|
|
56
59
|
|
|
57
60
|
focus() {
|
|
58
|
-
this._input
|
|
61
|
+
this._input?.focus();
|
|
59
62
|
}
|
|
60
63
|
|
|
61
64
|
blur() {
|
|
62
|
-
this._input
|
|
65
|
+
this._input?.blur();
|
|
63
66
|
}
|
|
64
67
|
|
|
65
68
|
getFontSize() {
|
|
@@ -79,20 +82,69 @@ export default class PlainText extends Component {
|
|
|
79
82
|
};
|
|
80
83
|
}
|
|
81
84
|
|
|
85
|
+
replaceLineBreakTags( value ) {
|
|
86
|
+
return value?.replace( RegExp( '<br>', 'gim' ), '\n' );
|
|
87
|
+
}
|
|
88
|
+
|
|
89
|
+
onChangeTextInput( event ) {
|
|
90
|
+
const { onChange } = this.props;
|
|
91
|
+
onChange( event.nativeEvent.text );
|
|
92
|
+
}
|
|
93
|
+
|
|
94
|
+
onChangeRichText( value ) {
|
|
95
|
+
const { onChange } = this.props;
|
|
96
|
+
// The <br> tags have to be replaced with new line characters
|
|
97
|
+
// as the content of plain text shouldn't contain HTML tags.
|
|
98
|
+
onChange( this.replaceLineBreakTags( value ) );
|
|
99
|
+
}
|
|
100
|
+
|
|
82
101
|
render() {
|
|
83
|
-
const { style } =
|
|
102
|
+
const { style, __experimentalVersion, onFocus, ...otherProps } =
|
|
103
|
+
this.props;
|
|
84
104
|
const textStyles = [
|
|
85
105
|
style || styles[ 'block-editor-plain-text' ],
|
|
86
106
|
this.getFontSize(),
|
|
87
107
|
];
|
|
88
108
|
|
|
109
|
+
if ( __experimentalVersion === 2 ) {
|
|
110
|
+
const disableFormattingProps = {
|
|
111
|
+
withoutInteractiveFormatting: true,
|
|
112
|
+
disableEditingMenu: true,
|
|
113
|
+
__unstableDisableFormats: true,
|
|
114
|
+
disableSuggestions: true,
|
|
115
|
+
};
|
|
116
|
+
|
|
117
|
+
const forcePlainTextProps = {
|
|
118
|
+
preserveWhiteSpace: true,
|
|
119
|
+
__unstablePastePlainText: true,
|
|
120
|
+
multiline: false,
|
|
121
|
+
};
|
|
122
|
+
|
|
123
|
+
const fontProps = {
|
|
124
|
+
fontFamily: style?.fontFamily,
|
|
125
|
+
fontSize: style?.fontSize,
|
|
126
|
+
fontWeight: style?.fontWeight,
|
|
127
|
+
};
|
|
128
|
+
|
|
129
|
+
return (
|
|
130
|
+
<RichText
|
|
131
|
+
{ ...otherProps }
|
|
132
|
+
{ ...disableFormattingProps }
|
|
133
|
+
{ ...forcePlainTextProps }
|
|
134
|
+
{ ...fontProps }
|
|
135
|
+
identifier="content"
|
|
136
|
+
style={ style }
|
|
137
|
+
onChange={ this.onChangeRichText }
|
|
138
|
+
unstableOnFocus={ onFocus }
|
|
139
|
+
/>
|
|
140
|
+
);
|
|
141
|
+
}
|
|
142
|
+
|
|
89
143
|
return (
|
|
90
144
|
<TextInput
|
|
91
145
|
{ ...this.props }
|
|
92
146
|
ref={ ( x ) => ( this._input = x ) }
|
|
93
|
-
onChange={
|
|
94
|
-
this.props.onChange( event.nativeEvent.text );
|
|
95
|
-
} }
|
|
147
|
+
onChange={ this.onChangeTextInput }
|
|
96
148
|
onFocus={ this.props.onFocus } // Always assign onFocus as a props.
|
|
97
149
|
onBlur={ this.props.onBlur } // Always assign onBlur as a props.
|
|
98
150
|
fontFamily={
|
|
@@ -35,11 +35,15 @@ export default function PreviewOptions( {
|
|
|
35
35
|
/* translators: button label text should, if possible, be under 16 characters. */
|
|
36
36
|
children: __( 'Preview' ),
|
|
37
37
|
};
|
|
38
|
+
const menuProps = {
|
|
39
|
+
'aria-label': __( 'Preview options' ),
|
|
40
|
+
};
|
|
38
41
|
return (
|
|
39
42
|
<DropdownMenu
|
|
40
43
|
className="block-editor-post-preview__dropdown"
|
|
41
44
|
popoverProps={ popoverProps }
|
|
42
45
|
toggleProps={ toggleProps }
|
|
46
|
+
menuProps={ menuProps }
|
|
43
47
|
icon={ null }
|
|
44
48
|
>
|
|
45
49
|
{ () => (
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
/**
|
|
2
2
|
* External dependencies
|
|
3
3
|
*/
|
|
4
|
-
import { last
|
|
4
|
+
import { last } from 'lodash';
|
|
5
5
|
|
|
6
6
|
/**
|
|
7
7
|
* WordPress dependencies
|
|
@@ -15,6 +15,8 @@ import { cloneBlock } from '@wordpress/blocks';
|
|
|
15
15
|
*/
|
|
16
16
|
import { store as blockEditorStore } from '../../store';
|
|
17
17
|
|
|
18
|
+
const noop = () => {};
|
|
19
|
+
|
|
18
20
|
/**
|
|
19
21
|
* A function to call when the block value has been updated in the block-editor
|
|
20
22
|
* store.
|
|
@@ -258,7 +260,8 @@ export default function useBlockSync( {
|
|
|
258
260
|
selection: {
|
|
259
261
|
selectionStart: getSelectionStart(),
|
|
260
262
|
selectionEnd: getSelectionEnd(),
|
|
261
|
-
initialPosition:
|
|
263
|
+
initialPosition:
|
|
264
|
+
getSelectedBlocksInitialCaretPosition(),
|
|
262
265
|
},
|
|
263
266
|
} );
|
|
264
267
|
}
|
|
@@ -0,0 +1,52 @@
|
|
|
1
|
+
# `PublishDateTimePicker`
|
|
2
|
+
|
|
3
|
+
`<PublishDateTimePicker />` is a component used to select the date and time that
|
|
4
|
+
a post will be published. It wraps the `<DateTimePicker />` component found in
|
|
5
|
+
`@wordpress/components` and adds additional post-specific controls.
|
|
6
|
+
|
|
7
|
+
See [the documentation for DateTimePicker](/packages/components/src/date-time)
|
|
8
|
+
for more information.
|
|
9
|
+
|
|
10
|
+
## Usage
|
|
11
|
+
|
|
12
|
+
```jsx
|
|
13
|
+
import { Dropdown, Button } from '@wordpress/components';
|
|
14
|
+
import { __experimentalPublishDateTimePicker as PublishDateTimePicker } from '@wordpress/block-editor';
|
|
15
|
+
import { useState } from '@wordpress/element';
|
|
16
|
+
|
|
17
|
+
const MyDateTimePicker = () => {
|
|
18
|
+
const [ date, setDate ] = useState( new Date() );
|
|
19
|
+
|
|
20
|
+
return (
|
|
21
|
+
<Dropdown
|
|
22
|
+
renderToggle={ ( { isOpen, onToggle } ) => (
|
|
23
|
+
<Button
|
|
24
|
+
onClick={ onToggle }
|
|
25
|
+
aria-expanded={ isOpen }
|
|
26
|
+
>
|
|
27
|
+
Select post date
|
|
28
|
+
</Button>
|
|
29
|
+
) }
|
|
30
|
+
renderContent={ ( { onClose } ) => (
|
|
31
|
+
<PublishDateTimePicker
|
|
32
|
+
currentDate={ date }
|
|
33
|
+
onChange={ ( newDate ) => setDate( newDate ) }
|
|
34
|
+
onClose={ onClose }
|
|
35
|
+
/>
|
|
36
|
+
) }
|
|
37
|
+
/>
|
|
38
|
+
);
|
|
39
|
+
};
|
|
40
|
+
```
|
|
41
|
+
|
|
42
|
+
## Props
|
|
43
|
+
|
|
44
|
+
`PublishDateTimePicker` supports all of the props that
|
|
45
|
+
[`DateTimePicker`](/packages/components/src/date-time#Props) supports, plus:
|
|
46
|
+
|
|
47
|
+
### onClose
|
|
48
|
+
|
|
49
|
+
Called when the user presses the close button.
|
|
50
|
+
|
|
51
|
+
- Type: `Function`
|
|
52
|
+
- Required: No
|
|
@@ -0,0 +1,41 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* WordPress dependencies
|
|
3
|
+
*/
|
|
4
|
+
import { DateTimePicker } from '@wordpress/components';
|
|
5
|
+
import { __ } from '@wordpress/i18n';
|
|
6
|
+
import { forwardRef } from '@wordpress/element';
|
|
7
|
+
import { __experimentalGetSettings as getSettings } from '@wordpress/date';
|
|
8
|
+
|
|
9
|
+
/**
|
|
10
|
+
* Internal dependencies
|
|
11
|
+
*/
|
|
12
|
+
import InspectorPopoverHeader from '../inspector-popover-header';
|
|
13
|
+
|
|
14
|
+
function PublishDateTimePicker(
|
|
15
|
+
{ onClose, onChange, ...additionalProps },
|
|
16
|
+
ref
|
|
17
|
+
) {
|
|
18
|
+
return (
|
|
19
|
+
<div ref={ ref } className="block-editor-publish-date-time-picker">
|
|
20
|
+
<InspectorPopoverHeader
|
|
21
|
+
title={ __( 'Publish' ) }
|
|
22
|
+
actions={ [
|
|
23
|
+
{
|
|
24
|
+
label: __( 'Now' ),
|
|
25
|
+
onClick: () => onChange?.( null ),
|
|
26
|
+
},
|
|
27
|
+
] }
|
|
28
|
+
onClose={ onClose }
|
|
29
|
+
/>
|
|
30
|
+
<DateTimePicker
|
|
31
|
+
startOfWeek={ getSettings().l10n.startOfWeek }
|
|
32
|
+
__nextRemoveHelpButton
|
|
33
|
+
__nextRemoveResetButton
|
|
34
|
+
onChange={ onChange }
|
|
35
|
+
{ ...additionalProps }
|
|
36
|
+
/>
|
|
37
|
+
</div>
|
|
38
|
+
);
|
|
39
|
+
}
|
|
40
|
+
|
|
41
|
+
export default forwardRef( PublishDateTimePicker );
|
|
@@ -171,8 +171,10 @@ const renderDefaultControl = ( labelComponent, viewport ) => {
|
|
|
171
171
|
An optional render function (prop) used to render the controls for the _responsive_ settings. If not provided, by default, responsive controls will be _automatically_ rendered using the component returned by the `renderDefaultControl` prop. For _complete_ control over the output of the responsive controls, you may return a component here and it will be rendered when the control group is in "responsive" mode.
|
|
172
172
|
|
|
173
173
|
```jsx
|
|
174
|
+
let uniqueId = 0;
|
|
175
|
+
|
|
174
176
|
const renderResponsiveControls = ( viewports ) => {
|
|
175
|
-
const inputId = uniqueId
|
|
177
|
+
const inputId = ++uniqueId;
|
|
176
178
|
|
|
177
179
|
return viewports.map( ( { id, label } ) => {
|
|
178
180
|
return (
|
|
@@ -3,7 +3,6 @@
|
|
|
3
3
|
*/
|
|
4
4
|
import { render, unmountComponentAtNode } from 'react-dom';
|
|
5
5
|
import { act, Simulate } from 'react-dom/test-utils';
|
|
6
|
-
import { uniqueId } from 'lodash';
|
|
7
6
|
|
|
8
7
|
/**
|
|
9
8
|
* WordPress dependencies
|
|
@@ -31,7 +30,7 @@ afterEach( () => {
|
|
|
31
30
|
container = null;
|
|
32
31
|
} );
|
|
33
32
|
|
|
34
|
-
const inputId =
|
|
33
|
+
const inputId = 'input-12345678';
|
|
35
34
|
|
|
36
35
|
const sizeOptions = [
|
|
37
36
|
{
|
|
@@ -97,8 +96,9 @@ describe( 'Basic rendering', () => {
|
|
|
97
96
|
)
|
|
98
97
|
);
|
|
99
98
|
|
|
100
|
-
const toggleState = container.querySelector(
|
|
101
|
-
|
|
99
|
+
const toggleState = container.querySelector(
|
|
100
|
+
'input[type="checkbox"]'
|
|
101
|
+
).checked;
|
|
102
102
|
|
|
103
103
|
const defaultControlGroup = container.querySelector(
|
|
104
104
|
'.block-editor-responsive-block-control__group:not(.is-responsive)'
|
|
@@ -1,8 +1,3 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* External dependencies
|
|
3
|
-
*/
|
|
4
|
-
import { noop } from 'lodash';
|
|
5
|
-
|
|
6
1
|
/**
|
|
7
2
|
* WordPress dependencies
|
|
8
3
|
*/
|
|
@@ -16,6 +11,8 @@ import {
|
|
|
16
11
|
import { Picker } from '@wordpress/components';
|
|
17
12
|
import { __ } from '@wordpress/i18n';
|
|
18
13
|
|
|
14
|
+
const noop = () => {};
|
|
15
|
+
|
|
19
16
|
const DEFAULT_PICKER_OPTIONS = [
|
|
20
17
|
{
|
|
21
18
|
id: 'createEmbed',
|
|
@@ -76,6 +76,8 @@ function removeNativeProps( props ) {
|
|
|
76
76
|
'minWidth',
|
|
77
77
|
'maxWidth',
|
|
78
78
|
'setRef',
|
|
79
|
+
'disableSuggestions',
|
|
80
|
+
'disableAutocorrection',
|
|
79
81
|
] );
|
|
80
82
|
}
|
|
81
83
|
|
|
@@ -120,9 +122,8 @@ function RichTextWrapper(
|
|
|
120
122
|
const anchorRef = useRef();
|
|
121
123
|
const { clientId } = useBlockEditContext();
|
|
122
124
|
const selector = ( select ) => {
|
|
123
|
-
const { getSelectionStart, getSelectionEnd } =
|
|
124
|
-
blockEditorStore
|
|
125
|
-
);
|
|
125
|
+
const { getSelectionStart, getSelectionEnd } =
|
|
126
|
+
select( blockEditorStore );
|
|
126
127
|
const selectionStart = getSelectionStart();
|
|
127
128
|
const selectionEnd = getSelectionEnd();
|
|
128
129
|
|
|
@@ -239,7 +240,11 @@ function RichTextWrapper(
|
|
|
239
240
|
);
|
|
240
241
|
}
|
|
241
242
|
|
|
242
|
-
const {
|
|
243
|
+
const {
|
|
244
|
+
value,
|
|
245
|
+
onChange,
|
|
246
|
+
ref: richTextRef,
|
|
247
|
+
} = useRichText( {
|
|
243
248
|
value: adjustedValue,
|
|
244
249
|
onChange( html, { __unstableFormats, __unstableText } ) {
|
|
245
250
|
adjustedOnChange( html );
|