@wordpress/edit-site 4.19.0 → 5.1.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 +17 -0
- package/build/components/add-new-template/add-custom-template-modal.js +1 -0
- package/build/components/add-new-template/add-custom-template-modal.js.map +1 -1
- package/build/components/add-new-template/index.js +8 -5
- package/build/components/add-new-template/index.js.map +1 -1
- package/build/components/add-new-template/new-template-part.js +21 -6
- package/build/components/add-new-template/new-template-part.js.map +1 -1
- package/build/components/add-new-template/new-template.js +12 -8
- package/build/components/add-new-template/new-template.js.map +1 -1
- package/build/components/app/index.js +15 -30
- package/build/components/app/index.js.map +1 -1
- package/build/components/block-editor/editor-canvas.js +64 -0
- package/build/components/block-editor/editor-canvas.js.map +1 -0
- package/build/components/block-editor/index.js +62 -59
- package/build/components/block-editor/index.js.map +1 -1
- package/build/components/block-editor/resizable-editor.js +10 -44
- package/build/components/block-editor/resizable-editor.js.map +1 -1
- package/build/components/editor/index.js +76 -135
- package/build/components/editor/index.js.map +1 -1
- package/build/components/global-styles/block-preview-panel.js +57 -0
- package/build/components/global-styles/block-preview-panel.js.map +1 -0
- package/build/components/global-styles/border-panel.js +0 -1
- package/build/components/global-styles/border-panel.js.map +1 -1
- package/build/components/global-styles/context-menu.js +6 -2
- package/build/components/global-styles/context-menu.js.map +1 -1
- package/build/components/global-styles/custom-css.js +62 -0
- package/build/components/global-styles/custom-css.js.map +1 -0
- package/build/components/global-styles/dimensions-panel.js +2 -6
- package/build/components/global-styles/dimensions-panel.js.map +1 -1
- package/build/components/global-styles/global-styles-provider.js +18 -4
- package/build/components/global-styles/global-styles-provider.js.map +1 -1
- package/build/components/global-styles/hooks.js +5 -2
- package/build/components/global-styles/hooks.js.map +1 -1
- package/build/components/global-styles/palette.js +1 -1
- package/build/components/global-styles/palette.js.map +1 -1
- package/build/components/global-styles/screen-background-color.js +0 -1
- package/build/components/global-styles/screen-background-color.js.map +1 -1
- package/build/components/global-styles/screen-block-list.js +2 -1
- package/build/components/global-styles/screen-block-list.js.map +1 -1
- package/build/components/global-styles/screen-block.js +5 -1
- package/build/components/global-styles/screen-block.js.map +1 -1
- package/build/components/global-styles/screen-border.js +47 -0
- package/build/components/global-styles/screen-border.js.map +1 -0
- package/build/components/global-styles/screen-button-color.js +0 -2
- package/build/components/global-styles/screen-button-color.js.map +1 -1
- package/build/components/global-styles/screen-colors.js +5 -1
- package/build/components/global-styles/screen-colors.js.map +1 -1
- package/build/components/global-styles/screen-css.js +42 -0
- package/build/components/global-styles/screen-css.js.map +1 -0
- package/build/components/global-styles/screen-heading-color.js +1 -3
- package/build/components/global-styles/screen-heading-color.js.map +1 -1
- package/build/components/global-styles/screen-layout.js +4 -5
- package/build/components/global-styles/screen-layout.js.map +1 -1
- package/build/components/global-styles/screen-link-color.js +0 -1
- package/build/components/global-styles/screen-link-color.js.map +1 -1
- package/build/components/global-styles/screen-root.js +20 -2
- package/build/components/global-styles/screen-root.js.map +1 -1
- package/build/components/global-styles/screen-style-variations.js +3 -3
- package/build/components/global-styles/screen-style-variations.js.map +1 -1
- package/build/components/global-styles/screen-text-color.js +0 -1
- package/build/components/global-styles/screen-text-color.js.map +1 -1
- package/build/components/global-styles/screen-typography.js +4 -0
- package/build/components/global-styles/screen-typography.js.map +1 -1
- package/build/components/global-styles/typography-utils.js +17 -5
- package/build/components/global-styles/typography-utils.js.map +1 -1
- package/build/components/global-styles/ui.js +50 -4
- package/build/components/global-styles/ui.js.map +1 -1
- package/build/components/global-styles/use-global-styles-output.js +5 -1
- package/build/components/global-styles/use-global-styles-output.js.map +1 -1
- package/build/components/global-styles/utils.js +14 -4
- package/build/components/global-styles/utils.js.map +1 -1
- package/build/components/{editor/global-styles-renderer.js → global-styles-renderer/index.js} +4 -8
- package/build/components/global-styles-renderer/index.js.map +1 -0
- package/build/components/header-edit-mode/document-actions/index.js +21 -45
- package/build/components/header-edit-mode/document-actions/index.js.map +1 -1
- package/build/components/header-edit-mode/index.js +19 -12
- package/build/components/header-edit-mode/index.js.map +1 -1
- package/build/components/keyboard-shortcuts/index.js +11 -1
- package/build/components/keyboard-shortcuts/index.js.map +1 -1
- package/build/components/layout/index.js +200 -0
- package/build/components/layout/index.js.map +1 -0
- package/build/components/list/header.js +5 -1
- package/build/components/list/header.js.map +1 -1
- package/build/components/list/index.js +4 -22
- package/build/components/list/index.js.map +1 -1
- package/build/components/navigate-to-link/index.js +1 -3
- package/build/components/navigate-to-link/index.js.map +1 -1
- package/build/components/routes/index.js +1 -1
- package/build/components/routes/index.js.map +1 -1
- package/build/components/sidebar/index.js +46 -0
- package/build/components/sidebar/index.js.map +1 -0
- package/build/components/sidebar-edit-mode/global-styles-sidebar.js +24 -4
- package/build/components/sidebar-edit-mode/global-styles-sidebar.js.map +1 -1
- package/build/components/sidebar-edit-mode/index.js +4 -2
- package/build/components/sidebar-edit-mode/index.js.map +1 -1
- package/build/components/sidebar-edit-mode/navigation-menu-sidebar/navigation-menu.js +10 -0
- package/build/components/sidebar-edit-mode/navigation-menu-sidebar/navigation-menu.js.map +1 -1
- package/build/components/sidebar-navigation-item/index.js +53 -0
- package/build/components/sidebar-navigation-item/index.js.map +1 -0
- package/build/components/sidebar-navigation-screen/index.js +49 -0
- package/build/components/sidebar-navigation-screen/index.js.map +1 -0
- package/build/components/sidebar-navigation-screen-main/index.js +46 -0
- package/build/components/sidebar-navigation-screen-main/index.js.map +1 -0
- package/build/components/sidebar-navigation-screen-templates/index.js +169 -0
- package/build/components/sidebar-navigation-screen-templates/index.js.map +1 -0
- package/build/components/site-hub/index.js +149 -0
- package/build/components/site-hub/index.js.map +1 -0
- package/build/components/site-icon/index.js +70 -0
- package/build/components/site-icon/index.js.map +1 -0
- package/build/components/style-book/index.js +173 -0
- package/build/components/style-book/index.js.map +1 -0
- package/build/components/{url-query-controller/index.js → sync-state-with-url/use-init-edited-entity-from-url.js} +5 -4
- package/build/components/sync-state-with-url/use-init-edited-entity-from-url.js.map +1 -0
- package/build/components/sync-state-with-url/use-sync-sidebar-path-with-url.js +53 -0
- package/build/components/sync-state-with-url/use-sync-sidebar-path-with-url.js.map +1 -0
- package/build/components/use-edited-entity-record/index.js +60 -0
- package/build/components/use-edited-entity-record/index.js.map +1 -0
- package/build/hooks/index.js +2 -0
- package/build/hooks/index.js.map +1 -1
- package/build/hooks/push-changes-to-global-styles/index.js +144 -0
- package/build/hooks/push-changes-to-global-styles/index.js.map +1 -0
- package/build/index.js +7 -45
- package/build/index.js.map +1 -1
- package/build/store/actions.js +93 -43
- package/build/store/actions.js.map +1 -1
- package/build/store/reducer.js +35 -107
- package/build/store/reducer.js.map +1 -1
- package/build/store/selectors.js +69 -78
- package/build/store/selectors.js.map +1 -1
- package/build-module/components/add-new-template/add-custom-template-modal.js +1 -0
- package/build-module/components/add-new-template/add-custom-template-modal.js.map +1 -1
- package/build-module/components/add-new-template/index.js +7 -5
- package/build-module/components/add-new-template/index.js.map +1 -1
- package/build-module/components/add-new-template/new-template-part.js +18 -6
- package/build-module/components/add-new-template/new-template-part.js.map +1 -1
- package/build-module/components/add-new-template/new-template.js +13 -9
- package/build-module/components/add-new-template/new-template.js.map +1 -1
- package/build-module/components/app/index.js +15 -28
- package/build-module/components/app/index.js.map +1 -1
- package/build-module/components/block-editor/editor-canvas.js +51 -0
- package/build-module/components/block-editor/editor-canvas.js.map +1 -0
- package/build-module/components/block-editor/index.js +62 -60
- package/build-module/components/block-editor/index.js.map +1 -1
- package/build-module/components/block-editor/resizable-editor.js +11 -40
- package/build-module/components/block-editor/resizable-editor.js.map +1 -1
- package/build-module/components/editor/index.js +75 -129
- package/build-module/components/editor/index.js.map +1 -1
- package/build-module/components/global-styles/block-preview-panel.js +46 -0
- package/build-module/components/global-styles/block-preview-panel.js.map +1 -0
- package/build-module/components/global-styles/border-panel.js +0 -1
- package/build-module/components/global-styles/border-panel.js.map +1 -1
- package/build-module/components/global-styles/context-menu.js +7 -3
- package/build-module/components/global-styles/context-menu.js.map +1 -1
- package/build-module/components/global-styles/custom-css.js +52 -0
- package/build-module/components/global-styles/custom-css.js.map +1 -0
- package/build-module/components/global-styles/dimensions-panel.js +3 -7
- package/build-module/components/global-styles/dimensions-panel.js.map +1 -1
- package/build-module/components/global-styles/global-styles-provider.js +18 -4
- package/build-module/components/global-styles/global-styles-provider.js.map +1 -1
- package/build-module/components/global-styles/hooks.js +5 -3
- package/build-module/components/global-styles/hooks.js.map +1 -1
- package/build-module/components/global-styles/palette.js +1 -1
- package/build-module/components/global-styles/palette.js.map +1 -1
- package/build-module/components/global-styles/screen-background-color.js +0 -1
- package/build-module/components/global-styles/screen-background-color.js.map +1 -1
- package/build-module/components/global-styles/screen-block-list.js +2 -1
- package/build-module/components/global-styles/screen-block-list.js.map +1 -1
- package/build-module/components/global-styles/screen-block.js +4 -1
- package/build-module/components/global-styles/screen-block.js.map +1 -1
- package/build-module/components/global-styles/screen-border.js +30 -0
- package/build-module/components/global-styles/screen-border.js.map +1 -0
- package/build-module/components/global-styles/screen-button-color.js +0 -2
- package/build-module/components/global-styles/screen-button-color.js.map +1 -1
- package/build-module/components/global-styles/screen-colors.js +4 -1
- package/build-module/components/global-styles/screen-colors.js.map +1 -1
- package/build-module/components/global-styles/screen-css.js +28 -0
- package/build-module/components/global-styles/screen-css.js.map +1 -0
- package/build-module/components/global-styles/screen-heading-color.js +1 -3
- package/build-module/components/global-styles/screen-heading-color.js.map +1 -1
- package/build-module/components/global-styles/screen-layout.js +3 -4
- package/build-module/components/global-styles/screen-layout.js.map +1 -1
- package/build-module/components/global-styles/screen-link-color.js +0 -1
- package/build-module/components/global-styles/screen-link-color.js.map +1 -1
- package/build-module/components/global-styles/screen-root.js +21 -3
- package/build-module/components/global-styles/screen-root.js.map +1 -1
- package/build-module/components/global-styles/screen-style-variations.js +2 -2
- package/build-module/components/global-styles/screen-style-variations.js.map +1 -1
- package/build-module/components/global-styles/screen-text-color.js +0 -1
- package/build-module/components/global-styles/screen-text-color.js.map +1 -1
- package/build-module/components/global-styles/screen-typography.js +3 -0
- package/build-module/components/global-styles/screen-typography.js.map +1 -1
- package/build-module/components/global-styles/typography-utils.js +17 -5
- package/build-module/components/global-styles/typography-utils.js.map +1 -1
- package/build-module/components/global-styles/ui.js +48 -5
- package/build-module/components/global-styles/ui.js.map +1 -1
- package/build-module/components/global-styles/use-global-styles-output.js +5 -1
- package/build-module/components/global-styles/use-global-styles-output.js.map +1 -1
- package/build-module/components/global-styles/utils.js +13 -5
- package/build-module/components/global-styles/utils.js.map +1 -1
- package/build-module/components/{editor/global-styles-renderer.js → global-styles-renderer/index.js} +4 -7
- package/build-module/components/global-styles-renderer/index.js.map +1 -0
- package/build-module/components/header-edit-mode/document-actions/index.js +22 -43
- package/build-module/components/header-edit-mode/document-actions/index.js.map +1 -1
- package/build-module/components/header-edit-mode/index.js +16 -11
- package/build-module/components/header-edit-mode/index.js.map +1 -1
- package/build-module/components/keyboard-shortcuts/index.js +10 -1
- package/build-module/components/keyboard-shortcuts/index.js.map +1 -1
- package/build-module/components/layout/index.js +173 -0
- package/build-module/components/layout/index.js.map +1 -0
- package/build-module/components/list/header.js +5 -1
- package/build-module/components/list/header.js.map +1 -1
- package/build-module/components/list/index.js +4 -19
- package/build-module/components/list/index.js.map +1 -1
- package/build-module/components/navigate-to-link/index.js +1 -3
- package/build-module/components/navigate-to-link/index.js.map +1 -1
- package/build-module/components/routes/index.js +1 -1
- package/build-module/components/routes/index.js.map +1 -1
- package/build-module/components/sidebar/index.js +33 -0
- package/build-module/components/sidebar/index.js.map +1 -0
- package/build-module/components/sidebar-edit-mode/global-styles-sidebar.js +27 -7
- package/build-module/components/sidebar-edit-mode/global-styles-sidebar.js.map +1 -1
- package/build-module/components/sidebar-edit-mode/index.js +6 -4
- package/build-module/components/sidebar-edit-mode/index.js.map +1 -1
- package/build-module/components/sidebar-edit-mode/navigation-menu-sidebar/navigation-menu.js +11 -1
- package/build-module/components/sidebar-edit-mode/navigation-menu-sidebar/navigation-menu.js.map +1 -1
- package/build-module/components/sidebar-navigation-item/index.js +40 -0
- package/build-module/components/sidebar-navigation-item/index.js.map +1 -0
- package/build-module/components/sidebar-navigation-screen/index.js +39 -0
- package/build-module/components/sidebar-navigation-screen/index.js.map +1 -0
- package/build-module/components/sidebar-navigation-screen-main/index.js +32 -0
- package/build-module/components/sidebar-navigation-screen-main/index.js.map +1 -0
- package/build-module/components/sidebar-navigation-screen-templates/index.js +147 -0
- package/build-module/components/sidebar-navigation-screen-templates/index.js.map +1 -0
- package/build-module/components/site-hub/index.js +126 -0
- package/build-module/components/site-hub/index.js.map +1 -0
- package/build-module/components/site-icon/index.js +55 -0
- package/build-module/components/site-icon/index.js.map +1 -0
- package/build-module/components/style-book/index.js +156 -0
- package/build-module/components/style-book/index.js.map +1 -0
- package/build-module/components/{url-query-controller/index.js → sync-state-with-url/use-init-edited-entity-from-url.js} +4 -3
- package/build-module/components/sync-state-with-url/use-init-edited-entity-from-url.js.map +1 -0
- package/build-module/components/sync-state-with-url/use-sync-sidebar-path-with-url.js +43 -0
- package/build-module/components/sync-state-with-url/use-sync-sidebar-path-with-url.js.map +1 -0
- package/build-module/components/use-edited-entity-record/index.js +48 -0
- package/build-module/components/use-edited-entity-record/index.js.map +1 -0
- package/build-module/hooks/index.js +1 -0
- package/build-module/hooks/index.js.map +1 -1
- package/build-module/hooks/push-changes-to-global-styles/index.js +132 -0
- package/build-module/hooks/push-changes-to-global-styles/index.js.map +1 -0
- package/build-module/index.js +9 -36
- package/build-module/index.js.map +1 -1
- package/build-module/store/actions.js +87 -42
- package/build-module/store/actions.js.map +1 -1
- package/build-module/store/reducer.js +35 -102
- package/build-module/store/reducer.js.map +1 -1
- package/build-module/store/selectors.js +60 -72
- package/build-module/store/selectors.js.map +1 -1
- package/build-style/style-rtl.css +549 -352
- package/build-style/style.css +549 -352
- package/package.json +33 -31
- package/src/components/add-new-template/add-custom-template-modal.js +1 -0
- package/src/components/add-new-template/index.js +6 -3
- package/src/components/add-new-template/new-template-part.js +15 -3
- package/src/components/add-new-template/new-template.js +14 -7
- package/src/components/add-new-template/style.scss +0 -4
- package/src/components/app/index.js +14 -43
- package/src/components/block-editor/editor-canvas.js +69 -0
- package/src/components/block-editor/index.js +100 -87
- package/src/components/block-editor/resizable-editor.js +9 -64
- package/src/components/block-editor/style.scss +25 -1
- package/src/components/code-editor/style.scss +1 -1
- package/src/components/editor/index.js +157 -238
- package/src/components/editor/style.scss +0 -22
- package/src/components/global-styles/block-preview-panel.js +44 -0
- package/src/components/global-styles/border-panel.js +0 -1
- package/src/components/global-styles/context-menu.js +11 -2
- package/src/components/global-styles/custom-css.js +74 -0
- package/src/components/global-styles/dimensions-panel.js +2 -5
- package/src/components/global-styles/global-styles-provider.js +50 -22
- package/src/components/global-styles/hooks.js +8 -3
- package/src/components/global-styles/palette.js +1 -1
- package/src/components/global-styles/screen-background-color.js +0 -1
- package/src/components/global-styles/screen-block-list.js +2 -1
- package/src/components/global-styles/screen-block.js +6 -1
- package/src/components/global-styles/screen-border.js +25 -0
- package/src/components/global-styles/screen-button-color.js +0 -2
- package/src/components/global-styles/screen-colors.js +5 -1
- package/src/components/global-styles/screen-css.js +33 -0
- package/src/components/global-styles/screen-heading-color.js +1 -3
- package/src/components/global-styles/screen-layout.js +2 -3
- package/src/components/global-styles/screen-link-color.js +0 -1
- package/src/components/global-styles/screen-root.js +37 -1
- package/src/components/global-styles/screen-style-variations.js +5 -2
- package/src/components/global-styles/screen-text-color.js +0 -1
- package/src/components/global-styles/screen-typography.js +3 -0
- package/src/components/global-styles/style.scss +31 -2
- package/src/components/global-styles/test/typography-utils.js +72 -23
- package/src/components/global-styles/typography-utils.js +24 -4
- package/src/components/global-styles/ui.js +47 -4
- package/src/components/global-styles/use-global-styles-output.js +5 -0
- package/src/components/global-styles/utils.js +18 -6
- package/src/components/{editor/global-styles-renderer.js → global-styles-renderer/index.js} +3 -9
- package/src/components/header-edit-mode/document-actions/index.js +31 -45
- package/src/components/header-edit-mode/document-actions/style.scss +8 -1
- package/src/components/header-edit-mode/index.js +96 -78
- package/src/components/header-edit-mode/style.scss +6 -33
- package/src/components/keyboard-shortcuts/index.js +13 -0
- package/src/components/layout/index.js +235 -0
- package/src/components/layout/style.scss +183 -0
- package/src/components/list/header.js +5 -1
- package/src/components/list/index.js +12 -31
- package/src/components/list/style.scss +3 -4
- package/src/components/navigate-to-link/index.js +2 -8
- package/src/components/routes/index.js +1 -1
- package/src/components/sidebar/index.js +37 -0
- package/src/components/sidebar/style.scss +8 -0
- package/src/components/sidebar-edit-mode/global-styles-sidebar.js +42 -7
- package/src/components/sidebar-edit-mode/index.js +4 -4
- package/src/components/sidebar-edit-mode/navigation-menu-sidebar/navigation-menu.js +10 -0
- package/src/components/sidebar-edit-mode/navigation-menu-sidebar/style.scss +21 -3
- package/src/components/sidebar-edit-mode/settings-header/style.scss +47 -34
- package/src/components/sidebar-edit-mode/style.scss +0 -13
- package/src/components/sidebar-navigation-item/index.js +51 -0
- package/src/components/sidebar-navigation-item/style.scss +17 -0
- package/src/components/sidebar-navigation-screen/index.js +55 -0
- package/src/components/sidebar-navigation-screen/style.scss +39 -0
- package/src/components/sidebar-navigation-screen-main/index.js +44 -0
- package/src/components/sidebar-navigation-screen-templates/index.js +163 -0
- package/src/components/sidebar-navigation-screen-templates/style.scss +9 -0
- package/src/components/site-hub/index.js +150 -0
- package/src/components/site-hub/style.scss +31 -0
- package/src/components/site-icon/index.js +56 -0
- package/src/components/site-icon/style.scss +10 -0
- package/src/components/style-book/index.js +193 -0
- package/src/components/style-book/style.scss +78 -0
- package/src/components/{url-query-controller/index.js → sync-state-with-url/use-init-edited-entity-from-url.js} +3 -3
- package/src/components/sync-state-with-url/use-sync-sidebar-path-with-url.js +36 -0
- package/src/components/template-details/style.scss +4 -0
- package/src/components/use-edited-entity-record/index.js +37 -0
- package/src/hooks/index.js +1 -0
- package/src/hooks/push-changes-to-global-styles/index.js +162 -0
- package/src/hooks/push-changes-to-global-styles/style.scss +4 -0
- package/src/index.js +5 -53
- package/src/store/actions.js +93 -48
- package/src/store/reducer.js +29 -91
- package/src/store/selectors.js +61 -101
- package/src/store/test/actions.js +3 -15
- package/src/store/test/reducer.js +8 -192
- package/src/store/test/selectors.js +3 -42
- package/src/style.scss +21 -3
- package/build/components/editor/global-styles-renderer.js.map +0 -1
- package/build/components/navigation-sidebar/index.js +0 -62
- package/build/components/navigation-sidebar/index.js.map +0 -1
- package/build/components/navigation-sidebar/navigation-panel/constants.js +0 -77
- package/build/components/navigation-sidebar/navigation-panel/constants.js.map +0 -1
- package/build/components/navigation-sidebar/navigation-panel/index.js +0 -152
- package/build/components/navigation-sidebar/navigation-panel/index.js.map +0 -1
- package/build/components/navigation-sidebar/navigation-panel/template-hierarchy.js +0 -81
- package/build/components/navigation-sidebar/navigation-panel/template-hierarchy.js.map +0 -1
- package/build/components/navigation-sidebar/navigation-toggle/index.js +0 -124
- package/build/components/navigation-sidebar/navigation-toggle/index.js.map +0 -1
- package/build/components/url-query-controller/index.js.map +0 -1
- package/build-module/components/editor/global-styles-renderer.js.map +0 -1
- package/build-module/components/navigation-sidebar/index.js +0 -45
- package/build-module/components/navigation-sidebar/index.js.map +0 -1
- package/build-module/components/navigation-sidebar/navigation-panel/constants.js +0 -49
- package/build-module/components/navigation-sidebar/navigation-panel/constants.js.map +0 -1
- package/build-module/components/navigation-sidebar/navigation-panel/index.js +0 -131
- package/build-module/components/navigation-sidebar/navigation-panel/index.js.map +0 -1
- package/build-module/components/navigation-sidebar/navigation-panel/template-hierarchy.js +0 -66
- package/build-module/components/navigation-sidebar/navigation-panel/template-hierarchy.js.map +0 -1
- package/build-module/components/navigation-sidebar/navigation-toggle/index.js +0 -108
- package/build-module/components/navigation-sidebar/navigation-toggle/index.js.map +0 -1
- package/build-module/components/url-query-controller/index.js.map +0 -1
- package/src/components/navigation-sidebar/index.js +0 -46
- package/src/components/navigation-sidebar/navigation-panel/constants.js +0 -94
- package/src/components/navigation-sidebar/navigation-panel/index.js +0 -142
- package/src/components/navigation-sidebar/navigation-panel/style.scss +0 -152
- package/src/components/navigation-sidebar/navigation-panel/template-hierarchy.js +0 -81
- package/src/components/navigation-sidebar/navigation-toggle/index.js +0 -114
- package/src/components/navigation-sidebar/navigation-toggle/style.scss +0 -71
- package/src/components/navigation-sidebar/navigation-toggle/test/index.js +0 -65
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@wordpress/edit-site",
|
|
3
|
-
"version": "
|
|
3
|
+
"version": "5.1.0",
|
|
4
4
|
"description": "Edit Site Page module for WordPress.",
|
|
5
5
|
"author": "The WordPress Contributors",
|
|
6
6
|
"license": "GPL-2.0-or-later",
|
|
@@ -27,47 +27,49 @@
|
|
|
27
27
|
"react-native": "src/index",
|
|
28
28
|
"dependencies": {
|
|
29
29
|
"@babel/runtime": "^7.16.0",
|
|
30
|
-
"@wordpress/a11y": "^3.
|
|
31
|
-
"@wordpress/api-fetch": "^6.
|
|
32
|
-
"@wordpress/block-editor": "^
|
|
33
|
-
"@wordpress/block-library": "^
|
|
34
|
-
"@wordpress/blocks": "^
|
|
35
|
-
"@wordpress/components": "^
|
|
36
|
-
"@wordpress/compose": "^
|
|
37
|
-
"@wordpress/core-data": "^
|
|
38
|
-
"@wordpress/data": "^
|
|
39
|
-
"@wordpress/deprecated": "^3.
|
|
40
|
-
"@wordpress/editor": "^
|
|
41
|
-
"@wordpress/element": "^
|
|
42
|
-
"@wordpress/hooks": "^3.
|
|
43
|
-
"@wordpress/html-entities": "^3.
|
|
44
|
-
"@wordpress/i18n": "^4.
|
|
45
|
-
"@wordpress/icons": "^9.
|
|
46
|
-
"@wordpress/interface": "^
|
|
47
|
-
"@wordpress/keyboard-shortcuts": "^
|
|
48
|
-
"@wordpress/keycodes": "^3.
|
|
49
|
-
"@wordpress/media-utils": "^4.
|
|
50
|
-
"@wordpress/notices": "^3.
|
|
51
|
-
"@wordpress/plugins": "^
|
|
52
|
-
"@wordpress/preferences": "^
|
|
53
|
-
"@wordpress/reusable-blocks": "^
|
|
54
|
-
"@wordpress/style-engine": "^1.
|
|
55
|
-
"@wordpress/url": "^3.
|
|
56
|
-
"@wordpress/viewport": "^
|
|
30
|
+
"@wordpress/a11y": "^3.24.0",
|
|
31
|
+
"@wordpress/api-fetch": "^6.21.0",
|
|
32
|
+
"@wordpress/block-editor": "^11.1.0",
|
|
33
|
+
"@wordpress/block-library": "^8.1.0",
|
|
34
|
+
"@wordpress/blocks": "^12.1.0",
|
|
35
|
+
"@wordpress/components": "^23.1.0",
|
|
36
|
+
"@wordpress/compose": "^6.1.0",
|
|
37
|
+
"@wordpress/core-data": "^6.1.0",
|
|
38
|
+
"@wordpress/data": "^8.1.0",
|
|
39
|
+
"@wordpress/deprecated": "^3.24.0",
|
|
40
|
+
"@wordpress/editor": "^13.1.0",
|
|
41
|
+
"@wordpress/element": "^5.1.0",
|
|
42
|
+
"@wordpress/hooks": "^3.24.0",
|
|
43
|
+
"@wordpress/html-entities": "^3.24.0",
|
|
44
|
+
"@wordpress/i18n": "^4.24.0",
|
|
45
|
+
"@wordpress/icons": "^9.15.0",
|
|
46
|
+
"@wordpress/interface": "^5.1.0",
|
|
47
|
+
"@wordpress/keyboard-shortcuts": "^4.1.0",
|
|
48
|
+
"@wordpress/keycodes": "^3.24.0",
|
|
49
|
+
"@wordpress/media-utils": "^4.15.0",
|
|
50
|
+
"@wordpress/notices": "^3.24.0",
|
|
51
|
+
"@wordpress/plugins": "^5.1.0",
|
|
52
|
+
"@wordpress/preferences": "^3.1.0",
|
|
53
|
+
"@wordpress/reusable-blocks": "^4.1.0",
|
|
54
|
+
"@wordpress/style-engine": "^1.7.0",
|
|
55
|
+
"@wordpress/url": "^3.25.0",
|
|
56
|
+
"@wordpress/viewport": "^5.1.0",
|
|
57
|
+
"@wordpress/widgets": "^3.1.0",
|
|
57
58
|
"classnames": "^2.3.1",
|
|
58
59
|
"colord": "^2.9.2",
|
|
59
60
|
"downloadjs": "^1.4.7",
|
|
61
|
+
"fast-deep-equal": "^3.1.3",
|
|
60
62
|
"history": "^5.1.0",
|
|
61
63
|
"lodash": "^4.17.21",
|
|
62
64
|
"react-autosize-textarea": "^7.1.0",
|
|
63
65
|
"rememo": "^4.0.0"
|
|
64
66
|
},
|
|
65
67
|
"peerDependencies": {
|
|
66
|
-
"react": "^
|
|
67
|
-
"react-dom": "^
|
|
68
|
+
"react": "^18.0.0",
|
|
69
|
+
"react-dom": "^18.0.0"
|
|
68
70
|
},
|
|
69
71
|
"publishConfig": {
|
|
70
72
|
"access": "public"
|
|
71
73
|
},
|
|
72
|
-
"gitHead": "
|
|
74
|
+
"gitHead": "200bee7b06b15f6fa655e25b6ab69cbd6b49a357"
|
|
73
75
|
}
|
|
@@ -10,7 +10,10 @@ import { store as coreStore } from '@wordpress/core-data';
|
|
|
10
10
|
import NewTemplate from './new-template';
|
|
11
11
|
import NewTemplatePart from './new-template-part';
|
|
12
12
|
|
|
13
|
-
export default function AddNewTemplate( {
|
|
13
|
+
export default function AddNewTemplate( {
|
|
14
|
+
templateType = 'wp_template',
|
|
15
|
+
...props
|
|
16
|
+
} ) {
|
|
14
17
|
const postType = useSelect(
|
|
15
18
|
( select ) => select( coreStore ).getPostType( templateType ),
|
|
16
19
|
[ templateType ]
|
|
@@ -21,9 +24,9 @@ export default function AddNewTemplate( { templateType = 'wp_template' } ) {
|
|
|
21
24
|
}
|
|
22
25
|
|
|
23
26
|
if ( templateType === 'wp_template' ) {
|
|
24
|
-
return <NewTemplate postType={ postType } />;
|
|
27
|
+
return <NewTemplate { ...props } postType={ postType } />;
|
|
25
28
|
} else if ( templateType === 'wp_template_part' ) {
|
|
26
|
-
return <NewTemplatePart postType={ postType } />;
|
|
29
|
+
return <NewTemplatePart { ...props } postType={ postType } />;
|
|
27
30
|
}
|
|
28
31
|
|
|
29
32
|
return null;
|
|
@@ -12,18 +12,25 @@ import { Button } from '@wordpress/components';
|
|
|
12
12
|
import { __ } from '@wordpress/i18n';
|
|
13
13
|
import { store as noticesStore } from '@wordpress/notices';
|
|
14
14
|
import { store as coreStore } from '@wordpress/core-data';
|
|
15
|
+
import { plus } from '@wordpress/icons';
|
|
15
16
|
|
|
16
17
|
/**
|
|
17
18
|
* Internal dependencies
|
|
18
19
|
*/
|
|
19
20
|
import { useHistory } from '../routes';
|
|
21
|
+
import { store as editSiteStore } from '../../store';
|
|
20
22
|
import CreateTemplatePartModal from '../create-template-part-modal';
|
|
21
23
|
|
|
22
|
-
export default function NewTemplatePart( {
|
|
24
|
+
export default function NewTemplatePart( {
|
|
25
|
+
postType,
|
|
26
|
+
showIcon = true,
|
|
27
|
+
toggleProps,
|
|
28
|
+
} ) {
|
|
23
29
|
const history = useHistory();
|
|
24
30
|
const [ isModalOpen, setIsModalOpen ] = useState( false );
|
|
25
31
|
const { createErrorNotice } = useDispatch( noticesStore );
|
|
26
32
|
const { saveEntityRecord } = useDispatch( coreStore );
|
|
33
|
+
const { __unstableSetCanvasMode } = useDispatch( editSiteStore );
|
|
27
34
|
|
|
28
35
|
async function createTemplatePart( { title, area } ) {
|
|
29
36
|
if ( ! title ) {
|
|
@@ -54,6 +61,9 @@ export default function NewTemplatePart( { postType } ) {
|
|
|
54
61
|
|
|
55
62
|
setIsModalOpen( false );
|
|
56
63
|
|
|
64
|
+
// Switch to edit mode.
|
|
65
|
+
__unstableSetCanvasMode( 'edit' );
|
|
66
|
+
|
|
57
67
|
// Navigate to the created template part editor.
|
|
58
68
|
history.push( {
|
|
59
69
|
postId: templatePart.id,
|
|
@@ -78,12 +88,14 @@ export default function NewTemplatePart( { postType } ) {
|
|
|
78
88
|
return (
|
|
79
89
|
<>
|
|
80
90
|
<Button
|
|
81
|
-
|
|
91
|
+
{ ...toggleProps }
|
|
82
92
|
onClick={ () => {
|
|
83
93
|
setIsModalOpen( true );
|
|
84
94
|
} }
|
|
95
|
+
icon={ showIcon ? plus : null }
|
|
96
|
+
label={ postType.labels.add_new }
|
|
85
97
|
>
|
|
86
|
-
{ postType.labels.add_new }
|
|
98
|
+
{ showIcon ? null : postType.labels.add_new }
|
|
87
99
|
</Button>
|
|
88
100
|
{ isModalOpen && (
|
|
89
101
|
<CreateTemplatePartModal
|
|
@@ -21,6 +21,7 @@ import {
|
|
|
21
21
|
media,
|
|
22
22
|
notFound,
|
|
23
23
|
page,
|
|
24
|
+
plus,
|
|
24
25
|
post,
|
|
25
26
|
postAuthor,
|
|
26
27
|
postDate,
|
|
@@ -79,7 +80,11 @@ const TEMPLATE_ICONS = {
|
|
|
79
80
|
attachment: media,
|
|
80
81
|
};
|
|
81
82
|
|
|
82
|
-
export default function NewTemplate( {
|
|
83
|
+
export default function NewTemplate( {
|
|
84
|
+
postType,
|
|
85
|
+
toggleProps,
|
|
86
|
+
showIcon = true,
|
|
87
|
+
} ) {
|
|
83
88
|
const [ showCustomTemplateModal, setShowCustomTemplateModal ] =
|
|
84
89
|
useState( false );
|
|
85
90
|
const [
|
|
@@ -93,7 +98,8 @@ export default function NewTemplate( { postType } ) {
|
|
|
93
98
|
const { saveEntityRecord } = useDispatch( coreStore );
|
|
94
99
|
const { createErrorNotice, createSuccessNotice } =
|
|
95
100
|
useDispatch( noticesStore );
|
|
96
|
-
const { setTemplate } =
|
|
101
|
+
const { setTemplate, __unstableSetCanvasMode } =
|
|
102
|
+
useDispatch( editSiteStore );
|
|
97
103
|
|
|
98
104
|
async function createTemplate( template, isWPSuggestion = true ) {
|
|
99
105
|
if ( isCreatingTemplate ) {
|
|
@@ -133,6 +139,9 @@ export default function NewTemplate( { postType } ) {
|
|
|
133
139
|
// Set template before navigating away to avoid initial stale value.
|
|
134
140
|
setTemplate( newTemplate.id, newTemplate.slug );
|
|
135
141
|
|
|
142
|
+
// Switch to edit mode.
|
|
143
|
+
__unstableSetCanvasMode( 'edit' );
|
|
144
|
+
|
|
136
145
|
// Navigate to the created template editor.
|
|
137
146
|
history.push( {
|
|
138
147
|
postId: newTemplate.id,
|
|
@@ -173,15 +182,13 @@ export default function NewTemplate( { postType } ) {
|
|
|
173
182
|
<>
|
|
174
183
|
<DropdownMenu
|
|
175
184
|
className="edit-site-new-template-dropdown"
|
|
176
|
-
icon={ null }
|
|
177
|
-
text={ postType.labels.add_new }
|
|
185
|
+
icon={ showIcon ? plus : null }
|
|
186
|
+
text={ showIcon ? null : postType.labels.add_new }
|
|
178
187
|
label={ postType.labels.add_new_item }
|
|
179
188
|
popoverProps={ {
|
|
180
189
|
noArrow: false,
|
|
181
190
|
} }
|
|
182
|
-
toggleProps={
|
|
183
|
-
variant: 'primary',
|
|
184
|
-
} }
|
|
191
|
+
toggleProps={ toggleProps }
|
|
185
192
|
>
|
|
186
193
|
{ () => (
|
|
187
194
|
<>
|
|
@@ -1,8 +1,9 @@
|
|
|
1
1
|
/**
|
|
2
2
|
* WordPress dependencies
|
|
3
3
|
*/
|
|
4
|
-
import { SlotFillProvider } from '@wordpress/components';
|
|
4
|
+
import { SlotFillProvider, Popover } from '@wordpress/components';
|
|
5
5
|
import { UnsavedChangesWarning } from '@wordpress/editor';
|
|
6
|
+
import { ShortcutProvider } from '@wordpress/keyboard-shortcuts';
|
|
6
7
|
import { store as noticesStore } from '@wordpress/notices';
|
|
7
8
|
import { useDispatch } from '@wordpress/data';
|
|
8
9
|
import { __, sprintf } from '@wordpress/i18n';
|
|
@@ -12,12 +13,9 @@ import { PluginArea } from '@wordpress/plugins';
|
|
|
12
13
|
* Internal dependencies
|
|
13
14
|
*/
|
|
14
15
|
import { Routes } from '../routes';
|
|
15
|
-
import
|
|
16
|
-
import List from '../list';
|
|
17
|
-
import NavigationSidebar from '../navigation-sidebar';
|
|
18
|
-
import getIsListPage from '../../utils/get-is-list-page';
|
|
16
|
+
import Layout from '../layout';
|
|
19
17
|
|
|
20
|
-
export default function
|
|
18
|
+
export default function App( { reboot } ) {
|
|
21
19
|
const { createErrorNotice } = useDispatch( noticesStore );
|
|
22
20
|
|
|
23
21
|
function onPluginAreaError( name ) {
|
|
@@ -33,43 +31,16 @@ export default function EditSiteApp( { reboot, homeTemplate } ) {
|
|
|
33
31
|
}
|
|
34
32
|
|
|
35
33
|
return (
|
|
36
|
-
<
|
|
37
|
-
<
|
|
34
|
+
<ShortcutProvider style={ { height: '100%' } }>
|
|
35
|
+
<SlotFillProvider>
|
|
36
|
+
<Popover.Slot />
|
|
37
|
+
<UnsavedChangesWarning />
|
|
38
38
|
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
params.postId?.includes( 'front-page' ) ||
|
|
46
|
-
params.postId === homeTemplate?.postId
|
|
47
|
-
? 'site-editor'
|
|
48
|
-
: undefined;
|
|
49
|
-
|
|
50
|
-
return (
|
|
51
|
-
<>
|
|
52
|
-
{ isListPage ? (
|
|
53
|
-
<List />
|
|
54
|
-
) : (
|
|
55
|
-
<Editor onError={ reboot } />
|
|
56
|
-
) }
|
|
57
|
-
<PluginArea onError={ onPluginAreaError } />
|
|
58
|
-
{ /* Keep the instance of the sidebar to ensure focus will not be lost
|
|
59
|
-
* when navigating to other pages. */ }
|
|
60
|
-
<NavigationSidebar
|
|
61
|
-
// Open the navigation sidebar by default when in the list page.
|
|
62
|
-
isDefaultOpen={ !! isListPage }
|
|
63
|
-
activeTemplateType={
|
|
64
|
-
isListPage
|
|
65
|
-
? params.postType
|
|
66
|
-
: homeTemplateType
|
|
67
|
-
}
|
|
68
|
-
/>
|
|
69
|
-
</>
|
|
70
|
-
);
|
|
71
|
-
} }
|
|
72
|
-
</Routes>
|
|
73
|
-
</SlotFillProvider>
|
|
39
|
+
<Routes>
|
|
40
|
+
<Layout onError={ reboot } />
|
|
41
|
+
<PluginArea onError={ onPluginAreaError } />
|
|
42
|
+
</Routes>
|
|
43
|
+
</SlotFillProvider>
|
|
44
|
+
</ShortcutProvider>
|
|
74
45
|
);
|
|
75
46
|
}
|
|
@@ -0,0 +1,69 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* WordPress dependencies
|
|
3
|
+
*/
|
|
4
|
+
import {
|
|
5
|
+
__experimentalUseResizeCanvas as useResizeCanvas,
|
|
6
|
+
__unstableEditorStyles as EditorStyles,
|
|
7
|
+
__unstableIframe as Iframe,
|
|
8
|
+
__unstableUseMouseMoveTypingReset as useMouseMoveTypingReset,
|
|
9
|
+
store as blockEditorStore,
|
|
10
|
+
} from '@wordpress/block-editor';
|
|
11
|
+
import { useSelect } from '@wordpress/data';
|
|
12
|
+
|
|
13
|
+
/**
|
|
14
|
+
* Internal dependencies
|
|
15
|
+
*/
|
|
16
|
+
import { store as editSiteStore } from '../../store';
|
|
17
|
+
|
|
18
|
+
function EditorCanvas( { enableResizing, settings, children, ...props } ) {
|
|
19
|
+
const { deviceType, isZoomOutMode } = useSelect(
|
|
20
|
+
( select ) => ( {
|
|
21
|
+
deviceType:
|
|
22
|
+
select( editSiteStore ).__experimentalGetPreviewDeviceType(),
|
|
23
|
+
isZoomOutMode:
|
|
24
|
+
select( blockEditorStore ).__unstableGetEditorMode() ===
|
|
25
|
+
'zoom-out',
|
|
26
|
+
} ),
|
|
27
|
+
[]
|
|
28
|
+
);
|
|
29
|
+
const deviceStyles = useResizeCanvas( deviceType );
|
|
30
|
+
const mouseMoveTypingRef = useMouseMoveTypingReset();
|
|
31
|
+
return (
|
|
32
|
+
<Iframe
|
|
33
|
+
scale={ ( isZoomOutMode && 0.45 ) || undefined }
|
|
34
|
+
frameSize={ isZoomOutMode ? 100 : undefined }
|
|
35
|
+
style={ enableResizing ? {} : deviceStyles }
|
|
36
|
+
head={
|
|
37
|
+
<>
|
|
38
|
+
<EditorStyles styles={ settings.styles } />
|
|
39
|
+
<style>{
|
|
40
|
+
// Forming a "block formatting context" to prevent margin collapsing.
|
|
41
|
+
// @see https://developer.mozilla.org/en-US/docs/Web/Guide/CSS/Block_formatting_context
|
|
42
|
+
`.is-root-container { display: flow-root; }
|
|
43
|
+
body { position: relative; }`
|
|
44
|
+
}</style>
|
|
45
|
+
{ enableResizing && (
|
|
46
|
+
<style>
|
|
47
|
+
{
|
|
48
|
+
// Some themes will have `min-height: 100vh` for the root container,
|
|
49
|
+
// which isn't a requirement in auto resize mode.
|
|
50
|
+
`.is-root-container { min-height: 0 !important; }`
|
|
51
|
+
}
|
|
52
|
+
</style>
|
|
53
|
+
) }
|
|
54
|
+
</>
|
|
55
|
+
}
|
|
56
|
+
assets={ settings.__unstableResolvedAssets }
|
|
57
|
+
ref={ mouseMoveTypingRef }
|
|
58
|
+
name="editor-canvas"
|
|
59
|
+
className="edit-site-visual-editor__editor-canvas"
|
|
60
|
+
{ ...props }
|
|
61
|
+
>
|
|
62
|
+
{ /* Filters need to be rendered before children to avoid Safari rendering issues. */ }
|
|
63
|
+
{ settings.svgFilters }
|
|
64
|
+
{ children }
|
|
65
|
+
</Iframe>
|
|
66
|
+
);
|
|
67
|
+
}
|
|
68
|
+
|
|
69
|
+
export default EditorCanvas;
|
|
@@ -8,7 +8,11 @@ import classnames from 'classnames';
|
|
|
8
8
|
*/
|
|
9
9
|
import { useSelect, useDispatch } from '@wordpress/data';
|
|
10
10
|
import { useCallback, useMemo, useRef, Fragment } from '@wordpress/element';
|
|
11
|
-
import {
|
|
11
|
+
import {
|
|
12
|
+
useEntityBlockEditor,
|
|
13
|
+
__experimentalFetchMedia as fetchMedia,
|
|
14
|
+
store as coreStore,
|
|
15
|
+
} from '@wordpress/core-data';
|
|
12
16
|
import {
|
|
13
17
|
BlockList,
|
|
14
18
|
BlockEditorProvider,
|
|
@@ -22,12 +26,15 @@ import {
|
|
|
22
26
|
store as blockEditorStore,
|
|
23
27
|
__unstableBlockNameContext,
|
|
24
28
|
} from '@wordpress/block-editor';
|
|
25
|
-
import {
|
|
29
|
+
import {
|
|
30
|
+
useMergeRefs,
|
|
31
|
+
useViewportMatch,
|
|
32
|
+
useResizeObserver,
|
|
33
|
+
} from '@wordpress/compose';
|
|
26
34
|
import { ReusableBlocksMenuItems } from '@wordpress/reusable-blocks';
|
|
27
35
|
import { listView } from '@wordpress/icons';
|
|
28
36
|
import { ToolbarButton, ToolbarGroup } from '@wordpress/components';
|
|
29
37
|
import { __ } from '@wordpress/i18n';
|
|
30
|
-
import { store as interfaceStore } from '@wordpress/interface';
|
|
31
38
|
|
|
32
39
|
/**
|
|
33
40
|
* Internal dependencies
|
|
@@ -39,6 +46,8 @@ import { store as editSiteStore } from '../../store';
|
|
|
39
46
|
import BlockInspectorButton from './block-inspector-button';
|
|
40
47
|
import BackButton from './back-button';
|
|
41
48
|
import ResizableEditor from './resizable-editor';
|
|
49
|
+
import EditorCanvas from './editor-canvas';
|
|
50
|
+
import StyleBook from '../style-book';
|
|
42
51
|
|
|
43
52
|
const LAYOUT = {
|
|
44
53
|
type: 'default',
|
|
@@ -46,29 +55,16 @@ const LAYOUT = {
|
|
|
46
55
|
alignments: [],
|
|
47
56
|
};
|
|
48
57
|
|
|
49
|
-
const NAVIGATION_SIDEBAR_NAME = 'edit-site/navigation-menu';
|
|
50
|
-
|
|
51
58
|
export default function BlockEditor( { setIsInserterOpen } ) {
|
|
52
|
-
const {
|
|
53
|
-
storedSettings,
|
|
54
|
-
templateType,
|
|
55
|
-
templateId,
|
|
56
|
-
page,
|
|
57
|
-
isNavigationSidebarOpen,
|
|
58
|
-
} = useSelect(
|
|
59
|
+
const { storedSettings, templateType, canvasMode } = useSelect(
|
|
59
60
|
( select ) => {
|
|
60
|
-
const { getSettings, getEditedPostType,
|
|
61
|
+
const { getSettings, getEditedPostType, __unstableGetCanvasMode } =
|
|
61
62
|
select( editSiteStore );
|
|
62
63
|
|
|
63
64
|
return {
|
|
64
65
|
storedSettings: getSettings( setIsInserterOpen ),
|
|
65
66
|
templateType: getEditedPostType(),
|
|
66
|
-
|
|
67
|
-
page: getPage(),
|
|
68
|
-
isNavigationSidebarOpen:
|
|
69
|
-
select( interfaceStore ).getActiveComplementaryArea(
|
|
70
|
-
editSiteStore.name
|
|
71
|
-
) === NAVIGATION_SIDEBAR_NAME,
|
|
67
|
+
canvasMode: __unstableGetCanvasMode(),
|
|
72
68
|
};
|
|
73
69
|
},
|
|
74
70
|
[ setIsInserterOpen ]
|
|
@@ -131,6 +127,7 @@ export default function BlockEditor( { setIsInserterOpen } ) {
|
|
|
131
127
|
|
|
132
128
|
return {
|
|
133
129
|
...restStoredSettings,
|
|
130
|
+
__unstableFetchMedia: fetchMedia,
|
|
134
131
|
__experimentalBlockPatterns: blockPatterns,
|
|
135
132
|
__experimentalBlockPatternCategories: blockPatternCategories,
|
|
136
133
|
};
|
|
@@ -141,44 +138,48 @@ export default function BlockEditor( { setIsInserterOpen } ) {
|
|
|
141
138
|
templateType
|
|
142
139
|
);
|
|
143
140
|
const { setPage } = useDispatch( editSiteStore );
|
|
144
|
-
|
|
145
|
-
useDispatch( interfaceStore );
|
|
146
|
-
const toggleNavigationSidebar = useCallback( () => {
|
|
147
|
-
const toggleComplementaryArea = isNavigationSidebarOpen
|
|
148
|
-
? disableComplementaryArea
|
|
149
|
-
: enableComplementaryArea;
|
|
150
|
-
toggleComplementaryArea( editSiteStore.name, NAVIGATION_SIDEBAR_NAME );
|
|
151
|
-
}, [ isNavigationSidebarOpen ] );
|
|
141
|
+
|
|
152
142
|
const contentRef = useRef();
|
|
153
143
|
const mergedRefs = useMergeRefs( [ contentRef, useTypingObserver() ] );
|
|
154
144
|
const isMobileViewport = useViewportMatch( 'small', '<' );
|
|
155
145
|
const { clearSelectedBlock } = useDispatch( blockEditorStore );
|
|
146
|
+
const [ resizeObserver, sizes ] = useResizeObserver();
|
|
156
147
|
|
|
157
148
|
const isTemplatePart = templateType === 'wp_template_part';
|
|
158
149
|
const hasBlocks = blocks.length !== 0;
|
|
150
|
+
const enableResizing =
|
|
151
|
+
isTemplatePart &&
|
|
152
|
+
canvasMode !== 'view' &&
|
|
153
|
+
// Disable resizing in mobile viewport.
|
|
154
|
+
! isMobileViewport;
|
|
155
|
+
const isViewMode = canvasMode === 'view';
|
|
156
|
+
const showBlockAppender =
|
|
157
|
+
( isTemplatePart && hasBlocks ) || isViewMode ? false : undefined;
|
|
158
|
+
|
|
159
|
+
// eslint-disable-next-line @wordpress/data-no-store-string-literals
|
|
160
|
+
const { enableComplementaryArea } = useDispatch( 'core/interface' );
|
|
159
161
|
|
|
160
162
|
const NavMenuSidebarToggle = () => (
|
|
161
163
|
<ToolbarGroup>
|
|
162
164
|
<ToolbarButton
|
|
163
165
|
className="components-toolbar__control"
|
|
164
|
-
label={
|
|
165
|
-
|
|
166
|
-
|
|
167
|
-
|
|
166
|
+
label={ __( 'Open navigation list view' ) }
|
|
167
|
+
onClick={ () =>
|
|
168
|
+
enableComplementaryArea(
|
|
169
|
+
'core/edit-site',
|
|
170
|
+
'edit-site/block-inspector'
|
|
171
|
+
)
|
|
168
172
|
}
|
|
169
|
-
onClick={ toggleNavigationSidebar }
|
|
170
173
|
icon={ listView }
|
|
171
|
-
isActive={ isNavigationSidebarOpen }
|
|
172
174
|
/>
|
|
173
175
|
</ToolbarGroup>
|
|
174
176
|
);
|
|
175
177
|
|
|
176
|
-
// Conditionally include NavMenu sidebar in Plugin only.
|
|
177
|
-
// Optimise for dead code elimination.
|
|
178
|
-
// See https://github.com/WordPress/gutenberg/blob/trunk/docs/how-to-guides/feature-flags.md#dead-code-elimination.
|
|
179
178
|
let MaybeNavMenuSidebarToggle = Fragment;
|
|
179
|
+
const isOffCanvasNavigationEditorEnabled =
|
|
180
|
+
window?.__experimentalEnableOffCanvasNavigationEditor === true;
|
|
180
181
|
|
|
181
|
-
if (
|
|
182
|
+
if ( isOffCanvasNavigationEditorEnabled ) {
|
|
182
183
|
MaybeNavMenuSidebarToggle = NavMenuSidebarToggle;
|
|
183
184
|
}
|
|
184
185
|
|
|
@@ -196,64 +197,76 @@ export default function BlockEditor( { setIsInserterOpen } ) {
|
|
|
196
197
|
( fillProps ) => (
|
|
197
198
|
<NavigateToLink
|
|
198
199
|
{ ...fillProps }
|
|
199
|
-
activePage={ page }
|
|
200
200
|
onActivePageChange={ setPage }
|
|
201
201
|
/>
|
|
202
202
|
),
|
|
203
|
-
[
|
|
203
|
+
[]
|
|
204
204
|
) }
|
|
205
205
|
</__experimentalLinkControl.ViewerFill>
|
|
206
206
|
<SidebarInspectorFill>
|
|
207
207
|
<BlockInspector />
|
|
208
208
|
</SidebarInspectorFill>
|
|
209
|
-
|
|
210
|
-
|
|
211
|
-
|
|
212
|
-
|
|
213
|
-
|
|
214
|
-
|
|
215
|
-
|
|
216
|
-
|
|
217
|
-
|
|
218
|
-
|
|
219
|
-
|
|
220
|
-
|
|
221
|
-
|
|
222
|
-
|
|
223
|
-
|
|
224
|
-
|
|
225
|
-
|
|
226
|
-
|
|
227
|
-
|
|
228
|
-
|
|
229
|
-
|
|
230
|
-
|
|
231
|
-
|
|
232
|
-
|
|
233
|
-
|
|
234
|
-
|
|
235
|
-
|
|
236
|
-
|
|
237
|
-
|
|
238
|
-
|
|
239
|
-
|
|
240
|
-
|
|
241
|
-
|
|
242
|
-
|
|
243
|
-
|
|
244
|
-
|
|
245
|
-
|
|
246
|
-
|
|
247
|
-
|
|
248
|
-
|
|
249
|
-
|
|
250
|
-
|
|
251
|
-
|
|
252
|
-
|
|
253
|
-
|
|
254
|
-
|
|
255
|
-
|
|
256
|
-
|
|
209
|
+
{ /* Potentially this could be a generic slot (e.g. EditorCanvas.Slot) if there are other uses for it. */ }
|
|
210
|
+
<StyleBook.Slot>
|
|
211
|
+
{ ( [ styleBook ] ) =>
|
|
212
|
+
styleBook ? (
|
|
213
|
+
<div className="edit-site-visual-editor is-focus-mode">
|
|
214
|
+
<ResizableEditor enableResizing>
|
|
215
|
+
{ styleBook }
|
|
216
|
+
</ResizableEditor>
|
|
217
|
+
</div>
|
|
218
|
+
) : (
|
|
219
|
+
<BlockTools
|
|
220
|
+
className={ classnames( 'edit-site-visual-editor', {
|
|
221
|
+
'is-focus-mode': isTemplatePart || !! styleBook,
|
|
222
|
+
'is-view-mode': isViewMode,
|
|
223
|
+
} ) }
|
|
224
|
+
__unstableContentRef={ contentRef }
|
|
225
|
+
onClick={ ( event ) => {
|
|
226
|
+
// Clear selected block when clicking on the gray background.
|
|
227
|
+
if ( event.target === event.currentTarget ) {
|
|
228
|
+
clearSelectedBlock();
|
|
229
|
+
}
|
|
230
|
+
} }
|
|
231
|
+
>
|
|
232
|
+
<BlockEditorKeyboardShortcuts.Register />
|
|
233
|
+
<BackButton />
|
|
234
|
+
<ResizableEditor
|
|
235
|
+
enableResizing={ enableResizing }
|
|
236
|
+
height={ sizes.height }
|
|
237
|
+
>
|
|
238
|
+
<EditorCanvas
|
|
239
|
+
enableResizing={ enableResizing }
|
|
240
|
+
settings={ settings }
|
|
241
|
+
contentRef={ mergedRefs }
|
|
242
|
+
readonly={ canvasMode === 'view' }
|
|
243
|
+
>
|
|
244
|
+
{ resizeObserver }
|
|
245
|
+
<BlockList
|
|
246
|
+
className="edit-site-block-editor__block-list wp-site-blocks"
|
|
247
|
+
__experimentalLayout={ LAYOUT }
|
|
248
|
+
renderAppender={ showBlockAppender }
|
|
249
|
+
/>
|
|
250
|
+
</EditorCanvas>
|
|
251
|
+
</ResizableEditor>
|
|
252
|
+
<__unstableBlockSettingsMenuFirstItem>
|
|
253
|
+
{ ( { onClose } ) => (
|
|
254
|
+
<BlockInspectorButton onClick={ onClose } />
|
|
255
|
+
) }
|
|
256
|
+
</__unstableBlockSettingsMenuFirstItem>
|
|
257
|
+
<__unstableBlockToolbarLastItem>
|
|
258
|
+
<__unstableBlockNameContext.Consumer>
|
|
259
|
+
{ ( blockName ) =>
|
|
260
|
+
blockName === 'core/navigation' && (
|
|
261
|
+
<MaybeNavMenuSidebarToggle />
|
|
262
|
+
)
|
|
263
|
+
}
|
|
264
|
+
</__unstableBlockNameContext.Consumer>
|
|
265
|
+
</__unstableBlockToolbarLastItem>
|
|
266
|
+
</BlockTools>
|
|
267
|
+
)
|
|
268
|
+
}
|
|
269
|
+
</StyleBook.Slot>
|
|
257
270
|
<ReusableBlocksMenuItems />
|
|
258
271
|
</BlockEditorProvider>
|
|
259
272
|
);
|