From 6820eb51e6ecda0320dc35e51492973f8262dde7 Mon Sep 17 00:00:00 2001 From: Riad Benguella Date: Thu, 9 Nov 2023 13:32:08 +0100 Subject: [PATCH] Share the editor settings between the post and site editors (#55970) --- .../data/data-core-edit-site.md | 3 +- .../block-editor/use-site-editor-settings.js | 143 +++++++----------- .../global-styles-renderer/index.js | 2 +- .../sidebar-edit-mode/default-sidebar.js | 12 +- .../sidebar-edit-mode/plugin-sidebar/index.js | 12 +- .../index.js | 2 +- .../navigation-menu-editor.js | 2 +- packages/edit-site/src/index.js | 8 - packages/edit-site/src/store/actions.js | 13 +- packages/edit-site/src/store/selectors.js | 122 ++++----------- packages/edit-site/src/store/test/actions.js | 16 +- .../edit-site/src/store/test/selectors.js | 82 ---------- .../editor/src/components/provider/index.js | 3 +- .../provider/use-block-editor-settings.js | 81 ++++++---- .../use-block-editor-settings.native.js | 4 +- packages/editor/src/private-apis.js | 4 + 16 files changed, 177 insertions(+), 332 deletions(-) diff --git a/docs/reference-guides/data/data-core-edit-site.md b/docs/reference-guides/data/data-core-edit-site.md index 262fccaa414eb..21cd5b2beb7b6 100644 --- a/docs/reference-guides/data/data-core-edit-site.md +++ b/docs/reference-guides/data/data-core-edit-site.md @@ -120,12 +120,11 @@ _Returns_ ### getSettings -Returns the settings, taking into account active features and permissions. +Returns the site editor settings. _Parameters_ - _state_ `Object`: Global application state. -- _setIsInserterOpen_ `Function`: Setter for the open state of the global inserter. _Returns_ diff --git a/packages/edit-site/src/components/block-editor/use-site-editor-settings.js b/packages/edit-site/src/components/block-editor/use-site-editor-settings.js index 001764cbb8595..f597abee0726d 100644 --- a/packages/edit-site/src/components/block-editor/use-site-editor-settings.js +++ b/packages/edit-site/src/components/block-editor/use-site-editor-settings.js @@ -4,12 +4,16 @@ import { useDispatch, useSelect } from '@wordpress/data'; import { useMemo } from '@wordpress/element'; import { store as coreStore } from '@wordpress/core-data'; +import { privateApis as editorPrivateApis } from '@wordpress/editor'; +import { store as preferencesStore } from '@wordpress/preferences'; + /** * Internal dependencies */ import { store as editSiteStore } from '../../store'; import { unlock } from '../../lock-unlock'; -import inserterMediaCategories from './inserter-media-categories'; + +const { useBlockEditorSettings } = unlock( editorPrivateApis ); function useArchiveLabel( templateSlug ) { const taxonomyMatches = templateSlug?.match( @@ -85,40 +89,25 @@ function useArchiveLabel( templateSlug ) { export default function useSiteEditorSettings() { const { setIsInserterOpened } = useDispatch( editSiteStore ); - const { storedSettings, canvasMode, templateType, siteSettings } = - useSelect( - ( select ) => { - const { canUser, getEntityRecord } = select( coreStore ); - const { getSettings, getCanvasMode, getEditedPostType } = - unlock( select( editSiteStore ) ); - return { - storedSettings: getSettings( setIsInserterOpened ), - canvasMode: getCanvasMode(), - templateType: getEditedPostType(), - siteSettings: canUser( 'read', 'settings' ) - ? getEntityRecord( 'root', 'site' ) - : undefined, - }; - }, - [ setIsInserterOpened ] - ); - - const settingsBlockPatterns = - storedSettings.__experimentalAdditionalBlockPatterns ?? // WP 6.0 - storedSettings.__experimentalBlockPatterns; // WP 5.9 - const settingsBlockPatternCategories = - storedSettings.__experimentalAdditionalBlockPatternCategories ?? // WP 6.0 - storedSettings.__experimentalBlockPatternCategories; // WP 5.9 - const { - restBlockPatterns, - restBlockPatternCategories, templateSlug, - userPatternCategories, + focusMode, + isDistractionFree, + hasFixedToolbar, + keepCaretInsideBlock, + canvasMode, + settings, + postType, + postId, } = useSelect( ( select ) => { - const { getEditedPostType, getEditedPostId } = select( editSiteStore ); - const { getEditedEntityRecord, getUserPatternCategories } = - select( coreStore ); + const { + getEditedPostType, + getEditedPostId, + getCanvasMode, + getSettings, + } = unlock( select( editSiteStore ) ); + const { get: getPreference } = select( preferencesStore ); + const { getEditedEntityRecord } = select( coreStore ); const usedPostType = getEditedPostType(); const usedPostId = getEditedPostId(); const _record = getEditedEntityRecord( @@ -127,75 +116,53 @@ export default function useSiteEditorSettings() { usedPostId ); return { - restBlockPatterns: select( coreStore ).getBlockPatterns(), - restBlockPatternCategories: - select( coreStore ).getBlockPatternCategories(), templateSlug: _record.slug, - userPatternCategories: getUserPatternCategories(), + focusMode: !! getPreference( 'core/edit-site', 'focusMode' ), + isDistractionFree: !! getPreference( + 'core/edit-site', + 'distractionFree' + ), + hasFixedToolbar: !! getPreference( + 'core/edit-site', + 'fixedToolbar' + ), + keepCaretInsideBlock: !! getPreference( + 'core/edit-site', + 'keepCaretInsideBlock' + ), + canvasMode: getCanvasMode(), + settings: getSettings(), + postType: usedPostType, + postId: usedPostId, }; }, [] ); const archiveLabels = useArchiveLabel( templateSlug ); - const blockPatterns = useMemo( - () => - [ - ...( settingsBlockPatterns || [] ), - ...( restBlockPatterns || [] ), - ] - .filter( - ( x, index, arr ) => - index === arr.findIndex( ( y ) => x.name === y.name ) - ) - .filter( ( { postTypes } ) => { - return ( - ! postTypes || - ( Array.isArray( postTypes ) && - postTypes.includes( templateType ) ) - ); - } ), - [ settingsBlockPatterns, restBlockPatterns, templateType ] - ); - - const blockPatternCategories = useMemo( - () => - [ - ...( settingsBlockPatternCategories || [] ), - ...( restBlockPatternCategories || [] ), - ].filter( - ( x, index, arr ) => - index === arr.findIndex( ( y ) => x.name === y.name ) - ), - [ settingsBlockPatternCategories, restBlockPatternCategories ] - ); - return useMemo( () => { - const { - __experimentalAdditionalBlockPatterns, - __experimentalAdditionalBlockPatternCategories, - focusMode, - ...restStoredSettings - } = storedSettings; - + const defaultEditorSettings = useMemo( () => { return { - ...restStoredSettings, - inserterMediaCategories, - __experimentalBlockPatterns: blockPatterns, - __experimentalBlockPatternCategories: blockPatternCategories, - __experimentalUserPatternCategories: userPatternCategories, + ...settings, + + __experimentalSetIsInserterOpened: setIsInserterOpened, focusMode: canvasMode === 'view' && focusMode ? false : focusMode, + isDistractionFree, + hasFixedToolbar, + keepCaretInsideBlock, + + // I wonder if they should be set in the post editor too __experimentalArchiveTitleTypeLabel: archiveLabels.archiveTypeLabel, __experimentalArchiveTitleNameLabel: archiveLabels.archiveNameLabel, - pageOnFront: siteSettings?.page_on_front, - pageForPosts: siteSettings?.page_for_posts, }; }, [ - storedSettings, - blockPatterns, - blockPatternCategories, - userPatternCategories, + settings, + setIsInserterOpened, + focusMode, + isDistractionFree, + hasFixedToolbar, + keepCaretInsideBlock, canvasMode, archiveLabels.archiveTypeLabel, archiveLabels.archiveNameLabel, - siteSettings?.page_on_front, - siteSettings?.page_for_posts, ] ); + + return useBlockEditorSettings( defaultEditorSettings, postType, postId ); } diff --git a/packages/edit-site/src/components/global-styles-renderer/index.js b/packages/edit-site/src/components/global-styles-renderer/index.js index eca6d9b2662e8..83c7c51bbe366 100644 --- a/packages/edit-site/src/components/global-styles-renderer/index.js +++ b/packages/edit-site/src/components/global-styles-renderer/index.js @@ -32,7 +32,7 @@ function useGlobalStylesRenderer() { styles: [ ...nonGlobalStyles, ...styles ], __experimentalFeatures: settings, } ); - }, [ styles, settings ] ); + }, [ styles, settings, updateSettings, getSettings ] ); } export function GlobalStylesRenderer() { diff --git a/packages/edit-site/src/components/sidebar-edit-mode/default-sidebar.js b/packages/edit-site/src/components/sidebar-edit-mode/default-sidebar.js index a06077e30b176..48a59935bf17c 100644 --- a/packages/edit-site/src/components/sidebar-edit-mode/default-sidebar.js +++ b/packages/edit-site/src/components/sidebar-edit-mode/default-sidebar.js @@ -6,11 +6,7 @@ import { ComplementaryAreaMoreMenuItem, } from '@wordpress/interface'; import { useSelect } from '@wordpress/data'; - -/** - * Internal dependencies - */ -import { store as editSiteStore } from '../../store'; +import { store as preferencesStore } from '@wordpress/preferences'; export default function DefaultSidebar( { className, @@ -24,7 +20,11 @@ export default function DefaultSidebar( { panelClassName, } ) { const showIconLabels = useSelect( - ( select ) => select( editSiteStore ).getSettings().showIconLabels, + ( select ) => + !! select( preferencesStore ).get( + 'core/edit-site', + 'showIconLabels' + ), [] ); diff --git a/packages/edit-site/src/components/sidebar-edit-mode/plugin-sidebar/index.js b/packages/edit-site/src/components/sidebar-edit-mode/plugin-sidebar/index.js index d705d0724af9f..45a3f6d48d0b9 100644 --- a/packages/edit-site/src/components/sidebar-edit-mode/plugin-sidebar/index.js +++ b/packages/edit-site/src/components/sidebar-edit-mode/plugin-sidebar/index.js @@ -3,11 +3,7 @@ */ import { ComplementaryArea } from '@wordpress/interface'; import { useSelect } from '@wordpress/data'; - -/** - * Internal dependencies - */ -import { store as editSiteStore } from '../../../store'; +import { store as preferencesStore } from '@wordpress/preferences'; /** * Renders a sidebar when activated. The contents within the `PluginSidebar` will appear as content within the sidebar. @@ -76,7 +72,11 @@ import { store as editSiteStore } from '../../../store'; */ export default function PluginSidebarEditSite( { className, ...props } ) { const showIconLabels = useSelect( - ( select ) => select( editSiteStore ).getSettings().showIconLabels, + ( select ) => + !! select( preferencesStore ).get( + 'core/edit-site', + 'showIconLabels' + ), [] ); diff --git a/packages/edit-site/src/components/sidebar-navigation-screen-global-styles/index.js b/packages/edit-site/src/components/sidebar-navigation-screen-global-styles/index.js index aa955d5dd3378..45fa8102456a5 100644 --- a/packages/edit-site/src/components/sidebar-navigation-screen-global-styles/index.js +++ b/packages/edit-site/src/components/sidebar-navigation-screen-global-styles/index.js @@ -63,7 +63,7 @@ function SidebarNavigationScreenGlobalStylesContent() { const { getSettings } = unlock( select( editSiteStore ) ); return { - storedSettings: getSettings( false ), + storedSettings: getSettings(), }; }, [] ); diff --git a/packages/edit-site/src/components/sidebar-navigation-screen-navigation-menu/navigation-menu-editor.js b/packages/edit-site/src/components/sidebar-navigation-screen-navigation-menu/navigation-menu-editor.js index 7d3be6f631f43..3e19c7f5a29fc 100644 --- a/packages/edit-site/src/components/sidebar-navigation-screen-navigation-menu/navigation-menu-editor.js +++ b/packages/edit-site/src/components/sidebar-navigation-screen-navigation-menu/navigation-menu-editor.js @@ -20,7 +20,7 @@ export default function NavigationMenuEditor( { navigationMenuId } ) { const { getSettings } = unlock( select( editSiteStore ) ); return { - storedSettings: getSettings( false ), + storedSettings: getSettings(), }; }, [] ); diff --git a/packages/edit-site/src/index.js b/packages/edit-site/src/index.js index 18cb0d5e5db69..82014ad06eb49 100644 --- a/packages/edit-site/src/index.js +++ b/packages/edit-site/src/index.js @@ -10,10 +10,6 @@ import { import { dispatch } from '@wordpress/data'; import deprecated from '@wordpress/deprecated'; import { createRoot } from '@wordpress/element'; -import { - __experimentalFetchLinkSuggestions as fetchLinkSuggestions, - __experimentalFetchUrlData as fetchUrlData, -} from '@wordpress/core-data'; import { store as editorStore } from '@wordpress/editor'; import { store as interfaceStore } from '@wordpress/interface'; import { store as preferencesStore } from '@wordpress/preferences'; @@ -39,10 +35,6 @@ export function initializeEditor( id, settings ) { const target = document.getElementById( id ); const root = createRoot( target ); - settings.__experimentalFetchLinkSuggestions = ( search, searchOptions ) => - fetchLinkSuggestions( search, searchOptions, settings ); - settings.__experimentalFetchRichUrlData = fetchUrlData; - dispatch( blocksStore ).reapplyBlockTypeFilters(); const coreBlocks = __experimentalGetCoreBlocks().filter( ( { name } ) => name !== 'core/freeform' diff --git a/packages/edit-site/src/store/actions.js b/packages/edit-site/src/store/actions.js index 5416d4b712937..4de1f4ac2a61f 100644 --- a/packages/edit-site/src/store/actions.js +++ b/packages/edit-site/src/store/actions.js @@ -31,11 +31,14 @@ import { */ export function toggleFeature( featureName ) { return function ( { registry } ) { - deprecated( "select( 'core/edit-site' ).toggleFeature( featureName )", { - since: '6.0', - alternative: - "select( 'core/preferences').toggle( 'core/edit-site', featureName )", - } ); + deprecated( + "dispatch( 'core/edit-site' ).toggleFeature( featureName )", + { + since: '6.0', + alternative: + "dispatch( 'core/preferences').toggle( 'core/edit-site', featureName )", + } + ); registry .dispatch( preferencesStore ) diff --git a/packages/edit-site/src/store/selectors.js b/packages/edit-site/src/store/selectors.js index 9e861c7567e4a..f9c2f7d65cfaf 100644 --- a/packages/edit-site/src/store/selectors.js +++ b/packages/edit-site/src/store/selectors.js @@ -1,15 +1,9 @@ -/** - * External dependencies - */ -import createSelector from 'rememo'; - /** * WordPress dependencies */ import { store as coreDataStore } from '@wordpress/core-data'; import { createRegistrySelector } from '@wordpress/data'; import deprecated from '@wordpress/deprecated'; -import { uploadMedia } from '@wordpress/media-utils'; import { Platform } from '@wordpress/element'; import { store as preferencesStore } from '@wordpress/preferences'; import { store as blockEditorStore } from '@wordpress/block-editor'; @@ -18,28 +12,11 @@ import { store as blockEditorStore } from '@wordpress/block-editor'; * Internal dependencies */ import { getFilteredTemplatePartBlocks } from './utils'; -import { - TEMPLATE_POST_TYPE, - TEMPLATE_PART_POST_TYPE, -} from '../utils/constants'; +import { TEMPLATE_PART_POST_TYPE } from '../utils/constants'; /** * @typedef {'template'|'template_type'} TemplateType Template type. */ -/** - * Helper for getting a preference from the preferences store. - * - * This is only present so that `getSettings` doesn't need to be made a - * registry selector. - * - * It's unstable because the selector needs to be exported and so part of the - * public API to work. - */ -export const __unstableGetPreference = createRegistrySelector( - ( select ) => ( state, name ) => - select( preferencesStore ).get( 'core/edit-site', name ) -); - /** * Returns whether the given feature is enabled or not. * @@ -49,14 +26,19 @@ export const __unstableGetPreference = createRegistrySelector( * * @return {boolean} Is active. */ -export function isFeatureActive( state, featureName ) { - deprecated( `select( 'core/edit-site' ).isFeatureActive`, { - since: '6.0', - alternative: `select( 'core/preferences' ).get`, - } ); +export const isFeatureActive = createRegistrySelector( + ( select ) => ( _, featureName ) => { + deprecated( `select( 'core/edit-site' ).isFeatureActive`, { + since: '6.0', + alternative: `select( 'core/preferences' ).get`, + } ); - return !! __unstableGetPreference( state, featureName ); -} + return !! select( preferencesStore ).get( + 'core/edit-site', + featureName + ); + } +); /** * Returns the current editing canvas device type. @@ -88,6 +70,13 @@ export const getCanUserCreateMedia = createRegistrySelector( * @return {Array} The available reusable blocks. */ export const getReusableBlocks = createRegistrySelector( ( select ) => () => { + deprecated( + "select( 'core/core' ).getEntityRecords( 'postType', 'wp_block' )", + { + since: '6.5', + version: '6.8', + } + ); const isWeb = Platform.OS === 'web'; return isWeb ? select( coreDataStore ).getEntityRecords( 'postType', 'wp_block', { @@ -97,67 +86,18 @@ export const getReusableBlocks = createRegistrySelector( ( select ) => () => { } ); /** - * Returns the settings, taking into account active features and permissions. + * Returns the site editor settings. * - * @param {Object} state Global application state. - * @param {Function} setIsInserterOpen Setter for the open state of the global inserter. + * @param {Object} state Global application state. * * @return {Object} Settings. */ -export const getSettings = createSelector( - ( state, setIsInserterOpen ) => { - const settings = { - ...state.settings, - outlineMode: true, - focusMode: !! __unstableGetPreference( state, 'focusMode' ), - isDistractionFree: !! __unstableGetPreference( - state, - 'distractionFree' - ), - hasFixedToolbar: !! __unstableGetPreference( - state, - 'fixedToolbar' - ), - keepCaretInsideBlock: !! __unstableGetPreference( - state, - 'keepCaretInsideBlock' - ), - showIconLabels: !! __unstableGetPreference( - state, - 'showIconLabels' - ), - __experimentalSetIsInserterOpened: setIsInserterOpen, - __experimentalReusableBlocks: getReusableBlocks( state ), - __experimentalPreferPatternsOnRoot: - TEMPLATE_POST_TYPE === getEditedPostType( state ), - }; - - const canUserCreateMedia = getCanUserCreateMedia( state ); - if ( ! canUserCreateMedia ) { - return settings; - } - - settings.mediaUpload = ( { onError, ...rest } ) => { - uploadMedia( { - wpAllowedMimeTypes: state.settings.allowedMimeTypes, - onError: ( { message } ) => onError( message ), - ...rest, - } ); - }; - return settings; - }, - ( state ) => [ - getCanUserCreateMedia( state ), - state.settings, - __unstableGetPreference( state, 'focusMode' ), - __unstableGetPreference( state, 'distractionFree' ), - __unstableGetPreference( state, 'fixedToolbar' ), - __unstableGetPreference( state, 'keepCaretInsideBlock' ), - __unstableGetPreference( state, 'showIconLabels' ), - getReusableBlocks( state ), - getEditedPostType( state ), - ] -); +export function getSettings( state ) { + // It is important that we don't inject anything into these settings locally. + // The reason for this is that we have an effect in place that calls setSettings based on the previous value of getSettings. + // If we add computed settings here, we'll be adding these computed settings to the state which is very unexpected. + return state.settings; +} /** * @deprecated @@ -317,9 +257,9 @@ export const getCurrentTemplateTemplateParts = createRegistrySelector( * * @return {string} Editing mode. */ -export function getEditorMode( state ) { - return __unstableGetPreference( state, 'editorMode' ); -} +export const getEditorMode = createRegistrySelector( ( select ) => () => { + return select( preferencesStore ).get( 'core/edit-site', 'editorMode' ); +} ); /** * @deprecated diff --git a/packages/edit-site/src/store/test/actions.js b/packages/edit-site/src/store/test/actions.js index 538acbf233697..787809acda089 100644 --- a/packages/edit-site/src/store/test/actions.js +++ b/packages/edit-site/src/store/test/actions.js @@ -34,21 +34,27 @@ describe( 'actions', () => { it( 'should toggle a feature flag', () => { const registry = createRegistryWithStores(); - // Should default to false. + // Should start as undefined. expect( - registry.select( editSiteStore ).isFeatureActive( 'name' ) - ).toBe( false ); + registry + .select( preferencesStore ) + .get( 'core/edit-site', 'name' ) + ).toBe( undefined ); // Toggle on. registry.dispatch( editSiteStore ).toggleFeature( 'name' ); expect( - registry.select( editSiteStore ).isFeatureActive( 'name' ) + registry + .select( preferencesStore ) + .get( 'core/edit-site', 'name' ) ).toBe( true ); // Toggle off again. registry.dispatch( editSiteStore ).toggleFeature( 'name' ); expect( - registry.select( editSiteStore ).isFeatureActive( 'name' ) + registry + .select( preferencesStore ) + .get( 'core/edit-site', 'name' ) ).toBe( false ); // Expect a deprecation warning. diff --git a/packages/edit-site/src/store/test/selectors.js b/packages/edit-site/src/store/test/selectors.js index 9380f8ea4d276..7e36d2f4b75f4 100644 --- a/packages/edit-site/src/store/test/selectors.js +++ b/packages/edit-site/src/store/test/selectors.js @@ -8,30 +8,19 @@ import { store as coreDataStore } from '@wordpress/core-data'; */ import { getCanUserCreateMedia, - getSettings, getEditedPostType, getEditedPostId, - getReusableBlocks, isInserterOpened, isListViewOpened, - __unstableGetPreference, isPage, hasPageContentFocus, } from '../selectors'; describe( 'selectors', () => { const canUser = jest.fn( () => true ); - const getEntityRecords = jest.fn( () => [] ); - const get = jest.fn(); getCanUserCreateMedia.registry = { select: jest.fn( () => ( { canUser } ) ), }; - getReusableBlocks.registry = { - select: jest.fn( () => ( { getEntityRecords } ) ), - }; - __unstableGetPreference.registry = { - select: jest.fn( () => ( { get } ) ), - }; describe( 'getCanUserCreateMedia', () => { it( "selects `canUser( 'create', 'media' )` from the core store", () => { @@ -43,77 +32,6 @@ describe( 'selectors', () => { } ); } ); - describe( 'getReusableBlocks', () => { - it( "selects `getEntityRecords( 'postType', 'wp_block' )` from the core store", () => { - expect( getReusableBlocks() ).toEqual( [] ); - expect( getReusableBlocks.registry.select ).toHaveBeenCalledWith( - coreDataStore - ); - expect( getEntityRecords ).toHaveBeenCalledWith( - 'postType', - 'wp_block', - { - per_page: -1, - } - ); - } ); - } ); - - describe( 'getSettings', () => { - it( "returns the settings when the user can't create media", () => { - canUser.mockReturnValueOnce( false ); - canUser.mockReturnValueOnce( false ); - get.mockImplementation( ( scope, name ) => { - if ( name === 'focusMode' ) return false; - if ( name === 'fixedToolbar' ) return false; - } ); - const state = { - settings: {}, - preferences: {}, - editedPost: { postType: 'wp_template' }, - }; - const setInserterOpened = () => {}; - expect( getSettings( state, setInserterOpened ) ).toEqual( { - outlineMode: true, - focusMode: false, - hasFixedToolbar: false, - isDistractionFree: false, - keepCaretInsideBlock: false, - showIconLabels: false, - __experimentalSetIsInserterOpened: setInserterOpened, - __experimentalReusableBlocks: [], - __experimentalPreferPatternsOnRoot: true, - } ); - } ); - - it( 'returns the extended settings when the user can create media', () => { - get.mockImplementation( ( scope, name ) => { - if ( name === 'focusMode' ) return true; - if ( name === 'fixedToolbar' ) return true; - } ); - - const state = { - settings: { key: 'value' }, - editedPost: { postType: 'wp_template_part' }, - }; - const setInserterOpened = () => {}; - - expect( getSettings( state, setInserterOpened ) ).toEqual( { - outlineMode: true, - key: 'value', - focusMode: true, - hasFixedToolbar: true, - isDistractionFree: false, - keepCaretInsideBlock: false, - showIconLabels: false, - __experimentalSetIsInserterOpened: setInserterOpened, - __experimentalReusableBlocks: [], - mediaUpload: expect.any( Function ), - __experimentalPreferPatternsOnRoot: false, - } ); - } ); - } ); - describe( 'getEditedPostId', () => { it( 'returns the template ID', () => { const state = { editedPost: { id: 10 } }; diff --git a/packages/editor/src/components/provider/index.js b/packages/editor/src/components/provider/index.js index f2f6102a710c6..6037c6496cc0c 100644 --- a/packages/editor/src/components/provider/index.js +++ b/packages/editor/src/components/provider/index.js @@ -63,7 +63,8 @@ export const ExperimentalEditorProvider = withRegistryProvider( ); const blockEditorSettings = useBlockEditorSettings( editorSettings, - !! __unstableTemplate + type, + id ); const { updatePostLock, diff --git a/packages/editor/src/components/provider/use-block-editor-settings.js b/packages/editor/src/components/provider/use-block-editor-settings.js index 1b5e9c9466576..c0804febab0db 100644 --- a/packages/editor/src/components/provider/use-block-editor-settings.js +++ b/packages/editor/src/components/provider/use-block-editor-settings.js @@ -76,17 +76,20 @@ const BLOCK_EDITOR_SETTINGS = [ '__unstableIsPreviewMode', '__unstableResolvedAssets', '__unstableIsBlockBasedTheme', + '__experimentalArchiveTitleTypeLabel', + '__experimentalArchiveTitleNameLabel', ]; /** * React hook used to compute the block editor settings to use for the post editor. * - * @param {Object} settings EditorProvider settings prop. - * @param {boolean} hasTemplate Whether template mode is enabled. + * @param {Object} settings EditorProvider settings prop. + * @param {string} postType Editor root level post type. + * @param {string} postId Editor root level post ID. * * @return {Object} Block Editor Settings. */ -function useBlockEditorSettings( settings, hasTemplate ) { +function useBlockEditorSettings( settings, postType, postId ) { const { reusableBlocks, hasUploadPermissions, @@ -94,36 +97,42 @@ function useBlockEditorSettings( settings, hasTemplate ) { userCanCreatePages, pageOnFront, pageForPosts, - postType, userPatternCategories, - } = useSelect( ( select ) => { - const { canUserUseUnfilteredHTML, getCurrentPostType } = - select( editorStore ); - const isWeb = Platform.OS === 'web'; - const { canUser, getEntityRecord, getUserPatternCategories } = - select( coreStore ); + } = useSelect( + ( select ) => { + const isWeb = Platform.OS === 'web'; + const { + canUser, + getRawEntityRecord, + getEntityRecord, + getUserPatternCategories, + getEntityRecords, + } = select( coreStore ); - const siteSettings = canUser( 'read', 'settings' ) - ? getEntityRecord( 'root', 'site' ) - : undefined; + const siteSettings = canUser( 'read', 'settings' ) + ? getEntityRecord( 'root', 'site' ) + : undefined; - return { - canUseUnfilteredHTML: canUserUseUnfilteredHTML(), - reusableBlocks: isWeb - ? select( coreStore ).getEntityRecords( - 'postType', - 'wp_block', - { per_page: -1 } - ) - : EMPTY_BLOCKS_LIST, // Reusable blocks are fetched in the native version of this hook. - hasUploadPermissions: canUser( 'create', 'media' ) ?? true, - userCanCreatePages: canUser( 'create', 'pages' ), - pageOnFront: siteSettings?.page_on_front, - pageForPosts: siteSettings?.page_for_posts, - postType: getCurrentPostType(), - userPatternCategories: getUserPatternCategories(), - }; - }, [] ); + return { + canUseUnfilteredHTML: getRawEntityRecord( + 'postType', + postType, + postId + )?._links?.hasOwnProperty( 'wp:action-unfiltered-html' ), + reusableBlocks: isWeb + ? getEntityRecords( 'postType', 'wp_block', { + per_page: -1, + } ) + : EMPTY_BLOCKS_LIST, // Reusable blocks are fetched in the native version of this hook. + hasUploadPermissions: canUser( 'create', 'media' ) ?? true, + userCanCreatePages: canUser( 'create', 'pages' ), + pageOnFront: siteSettings?.page_on_front, + pageForPosts: siteSettings?.page_for_posts, + userPatternCategories: getUserPatternCategories(), + }; + }, + [ postType, postId ] + ); const settingsBlockPatterns = settings.__experimentalAdditionalBlockPatterns ?? // WP 6.0 @@ -214,14 +223,20 @@ function useBlockEditorSettings( settings, hasTemplate ) { fetchLinkSuggestions( search, searchOptions, settings ), inserterMediaCategories, __experimentalFetchRichUrlData: fetchUrlData, + // Todo: This only checks the top level post, not the post within a template or any other entity that can be edited. + // This might be better as a generic "canUser" selector. __experimentalCanUserUseUnfilteredHTML: canUseUnfilteredHTML, + //Todo: this is only needed for native and should probably be removed. __experimentalUndo: undo, - outlineMode: hasTemplate, + // Check whether we want all site editor frames to have outlines + // including the navigation / pattern / parts editors. + outlineMode: postType === 'wp_template', + // Check these two properties: they were not present in the site editor. __experimentalCreatePageEntity: createPageEntity, __experimentalUserCanCreatePages: userCanCreatePages, pageOnFront, pageForPosts, - __experimentalPreferPatternsOnRoot: hasTemplate, + __experimentalPreferPatternsOnRoot: postType === 'wp_template', } ), [ settings, @@ -232,11 +247,11 @@ function useBlockEditorSettings( settings, hasTemplate ) { blockPatternCategories, canUseUnfilteredHTML, undo, - hasTemplate, createPageEntity, userCanCreatePages, pageOnFront, pageForPosts, + postType, ] ); } diff --git a/packages/editor/src/components/provider/use-block-editor-settings.native.js b/packages/editor/src/components/provider/use-block-editor-settings.native.js index e0a289e2c63ba..ece088a09921d 100644 --- a/packages/editor/src/components/provider/use-block-editor-settings.native.js +++ b/packages/editor/src/components/provider/use-block-editor-settings.native.js @@ -13,8 +13,8 @@ import { store as editorStore } from '../../store'; const EMPTY_BLOCKS_LIST = []; -function useNativeBlockEditorSettings( settings, hasTemplate ) { - const editorSettings = useBlockEditorSettings( settings, hasTemplate ); +function useNativeBlockEditorSettings( settings, postType, postId ) { + const editorSettings = useBlockEditorSettings( settings, postType, postId ); const supportReusableBlock = settings.capabilities?.reusableBlock === true; const { reusableBlocks, isTitleSelected } = useSelect( diff --git a/packages/editor/src/private-apis.js b/packages/editor/src/private-apis.js index b0c2ab86c8bf2..b599278f872dd 100644 --- a/packages/editor/src/private-apis.js +++ b/packages/editor/src/private-apis.js @@ -4,9 +4,13 @@ import { ExperimentalEditorProvider } from './components/provider'; import { lock } from './lock-unlock'; import { EntitiesSavedStatesExtensible } from './components/entities-saved-states'; +import useBlockEditorSettings from './components/provider/use-block-editor-settings'; export const privateApis = {}; lock( privateApis, { ExperimentalEditorProvider, EntitiesSavedStatesExtensible, + + // This is a temporary private API while we're updating the site editor to use EditorProvider. + useBlockEditorSettings, } );