From ac58a6c76d6c38ad6cd599730af227f41cf446f2 Mon Sep 17 00:00:00 2001 From: Riad Benguella Date: Mon, 4 Mar 2019 07:42:58 +0100 Subject: [PATCH] Clarify the block editor settings from the post editor settings (#14082) --- .../developers/data/data-core-block-editor.md | 6 ++-- .../developers/data/data-core-editor.md | 22 +++++++++++++- .../src/components/provider/index.js | 10 +++---- packages/block-editor/src/index.js | 2 ++ packages/block-editor/src/store/actions.js | 6 ++-- packages/block-editor/src/store/defaults.js | 28 +++++++++--------- packages/block-editor/src/store/reducer.js | 6 ++-- packages/block-editor/src/store/selectors.js | 4 +-- .../block-editor/src/store/test/effects.js | 8 ++--- packages/block-library/src/html/edit.js | 4 +-- packages/block-library/src/image/edit.js | 4 +-- packages/block-library/src/paragraph/edit.js | 4 +-- packages/block-library/src/pullquote/index.js | 2 +- .../components/header/header-toolbar/index.js | 2 +- .../components/header/mode-switcher/index.js | 2 +- .../components/keyboard-shortcuts/index.js | 2 +- .../edit-post/src/components/layout/index.js | 2 +- .../options-modal/meta-boxes-section.js | 2 +- .../options/enable-custom-fields.js | 2 +- .../src/components/text-editor/index.js | 2 +- .../src/components/alignment-toolbar/index.js | 4 +-- .../src/components/autosave-monitor/index.js | 3 +- .../block-alignment-toolbar/index.js | 7 +++-- .../editor/src/components/block-list/block.js | 8 ++--- .../src/components/block-list/hover-area.js | 2 +- .../color-palette/with-color-context.js | 2 +- .../src/components/colors/with-colors.js | 2 +- .../default-block-appender/index.js | 4 +-- .../default-block-appender/index.native.js | 4 +-- .../components/font-sizes/font-size-picker.js | 2 +- .../components/font-sizes/with-font-sizes.js | 2 +- .../src/components/media-placeholder/index.js | 4 +-- .../src/components/page-attributes/check.js | 5 +--- .../components/page-attributes/template.js | 3 +- .../src/components/post-format/check.js | 3 +- .../src/components/post-locked-modal/index.js | 5 +--- .../editor/src/components/post-title/index.js | 4 +-- .../editor/src/components/provider/index.js | 29 +++++++++++++++++-- packages/editor/src/hooks/align.js | 4 +-- packages/editor/src/store/actions.js | 15 +++++++++- packages/editor/src/store/defaults.js | 24 +++++++++++++++ packages/editor/src/store/reducer.js | 22 ++++++++++++++ packages/editor/src/store/selectors.js | 12 +++++++- .../editor/src/utils/media-upload/index.js | 5 +--- 44 files changed, 201 insertions(+), 94 deletions(-) diff --git a/docs/designers-developers/developers/data/data-core-block-editor.md b/docs/designers-developers/developers/data/data-core-block-editor.md index 3166400bd3fbf..03929e3671685 100644 --- a/docs/designers-developers/developers/data/data-core-block-editor.md +++ b/docs/designers-developers/developers/data/data-core-block-editor.md @@ -737,7 +737,7 @@ Returns the Block List settings of a block, if any exist. Block settings of the block if set. -### getEditorSettings +### getSettings Returns the editor settings. @@ -1027,9 +1027,9 @@ Returns an action object that changes the nested settings of a given block. being received. * settings: Object with the new settings for the nested block. -### updateEditorSettings +### updateSettings -Returns an action object used in signalling that the editor settings have been updated. +Returns an action object used in signalling that the block editor settings have been updated. *Parameters* diff --git a/docs/designers-developers/developers/data/data-core-editor.md b/docs/designers-developers/developers/data/data-core-editor.md index 3a22e11c90121..cd251dc92d678 100644 --- a/docs/designers-developers/developers/data/data-core-editor.md +++ b/docs/designers-developers/developers/data/data-core-editor.md @@ -718,6 +718,18 @@ Is the editor ready is Ready. +### getEditorSettings + +Returns the post editor settings. + +*Parameters* + + * state: Editor state. + +*Returns* + +The editor settings object. + ## Actions ### setupEditor @@ -967,4 +979,12 @@ Returns an action object used to signal that the blocks have been updated. *Parameters* * blocks: Block Array. - * options: Optional options. \ No newline at end of file + * options: Optional options. + +### updateEditorSettings + +Returns an action object used in signalling that the post editor settings have been updated. + +*Parameters* + + * settings: Updated settings \ No newline at end of file diff --git a/packages/block-editor/src/components/provider/index.js b/packages/block-editor/src/components/provider/index.js index a1d3063962b5d..a8073ace46c5d 100644 --- a/packages/block-editor/src/components/provider/index.js +++ b/packages/block-editor/src/components/provider/index.js @@ -30,7 +30,7 @@ const withRegistry = createHigherOrderComponent( class BlockEditorProvider extends Component { componentDidMount() { - this.props.updateEditorSettings( this.props.settings ); + this.props.updateSettings( this.props.settings ); this.props.resetBlocks( this.props.value ); this.attachChangeObserver( this.props.registry ); } @@ -38,14 +38,14 @@ class BlockEditorProvider extends Component { componentDidUpdate( prevProps ) { const { settings, - updateEditorSettings, + updateSettings, value, resetBlocks, registry, } = this.props; if ( settings !== prevProps.settings ) { - updateEditorSettings( settings ); + updateSettings( settings ); } if ( registry !== prevProps.registry ) { @@ -139,12 +139,12 @@ class BlockEditorProvider extends Component { export default compose( [ withDispatch( ( dispatch ) => { const { - updateEditorSettings, + updateSettings, resetBlocks, } = dispatch( 'core/block-editor' ); return { - updateEditorSettings, + updateSettings, resetBlocks, }; } ), diff --git a/packages/block-editor/src/index.js b/packages/block-editor/src/index.js index 9421db61f16e9..58e920befd5ea 100644 --- a/packages/block-editor/src/index.js +++ b/packages/block-editor/src/index.js @@ -9,3 +9,5 @@ import '@wordpress/blocks'; import './store'; export * from './components'; + +export { SETTINGS_DEFAULTS } from './store/defaults'; diff --git a/packages/block-editor/src/store/actions.js b/packages/block-editor/src/store/actions.js index 07f150f53d21a..a2a1bc6e6e628 100644 --- a/packages/block-editor/src/store/actions.js +++ b/packages/block-editor/src/store/actions.js @@ -514,15 +514,15 @@ export function updateBlockListSettings( clientId, settings ) { } /* - * Returns an action object used in signalling that the editor settings have been updated. + * Returns an action object used in signalling that the block editor settings have been updated. * * @param {Object} settings Updated settings * * @return {Object} Action object */ -export function updateEditorSettings( settings ) { +export function updateSettings( settings ) { return { - type: 'UPDATE_EDITOR_SETTINGS', + type: 'UPDATE_SETTINGS', settings, }; } diff --git a/packages/block-editor/src/store/defaults.js b/packages/block-editor/src/store/defaults.js index 31d1574d6283a..3e61e459c53f6 100644 --- a/packages/block-editor/src/store/defaults.js +++ b/packages/block-editor/src/store/defaults.js @@ -10,17 +10,22 @@ export const PREFERENCES_DEFAULTS = { /** * The default editor settings * - * alignWide boolean Enable/Disable Wide/Full Alignments - * colors Array Palette colors - * fontSizes Array Available font sizes - * imageSizes Array Available image sizes - * maxWidth number Max width to constraint resizing - * blockTypes boolean|Array Allowed block types - * hasFixedToolbar boolean Whether or not the editor toolbar is fixed - * focusMode boolean Whether the focus mode is enabled or not - * richEditingEnabled boolean Whether rich editing is enabled or not + * alignWide boolean Enable/Disable Wide/Full Alignments + * colors Array Palette colors + * disableCustomColors boolean Whether or not the custom colors are disabled + * fontSizes Array Available font sizes + * disableCustomFontSizes boolean Whether or not the custom font sizes are disabled + * imageSizes Array Available image sizes + * maxWidth number Max width to constraint resizing + * blockTypes boolean|Array Allowed block types + * hasFixedToolbar boolean Whether or not the editor toolbar is fixed + * focusMode boolean Whether the focus mode is enabled or not + * styles Array Editor Styles + * isRTL boolean Whether the editor is in RTL mode + * bodyPlaceholder string Empty post placeholder + * titlePlaceholder string Empty title placeholder */ -export const EDITOR_SETTINGS_DEFAULTS = { +export const SETTINGS_DEFAULTS = { alignWide: false, colors: [ { @@ -126,8 +131,5 @@ export const EDITOR_SETTINGS_DEFAULTS = { // List of allowed mime types and file extensions. allowedMimeTypes: null, - - // Whether richs editing is enabled or not. - richEditingEnabled: true, }; diff --git a/packages/block-editor/src/store/reducer.js b/packages/block-editor/src/store/reducer.js index bcd8b3295c4bc..007c5f4a8f6d4 100644 --- a/packages/block-editor/src/store/reducer.js +++ b/packages/block-editor/src/store/reducer.js @@ -26,7 +26,7 @@ import { isReusableBlock } from '@wordpress/blocks'; */ import { PREFERENCES_DEFAULTS, - EDITOR_SETTINGS_DEFAULTS, + SETTINGS_DEFAULTS, } from './defaults'; import { insertAt, moveTo } from './array'; @@ -830,9 +830,9 @@ export function template( state = { isValid: true }, action ) { * * @return {Object} Updated state. */ -export function settings( state = EDITOR_SETTINGS_DEFAULTS, action ) { +export function settings( state = SETTINGS_DEFAULTS, action ) { switch ( action.type ) { - case 'UPDATE_EDITOR_SETTINGS': + case 'UPDATE_SETTINGS': return { ...state, ...action.settings, diff --git a/packages/block-editor/src/store/selectors.js b/packages/block-editor/src/store/selectors.js index efadb31bf0ff2..d1b142530cff6 100644 --- a/packages/block-editor/src/store/selectors.js +++ b/packages/block-editor/src/store/selectors.js @@ -1034,7 +1034,7 @@ const canInsertBlockTypeUnmemoized = ( state, blockName, rootClientId = null ) = return false; } - const { allowedBlockTypes } = getEditorSettings( state ); + const { allowedBlockTypes } = getSettings( state ); const isBlockAllowedInEditor = checkAllowList( allowedBlockTypes, blockName, true ); if ( ! isBlockAllowedInEditor ) { @@ -1350,7 +1350,7 @@ export function getBlockListSettings( state, clientId ) { * * @return {Object} The editor settings object. */ -export function getEditorSettings( state ) { +export function getSettings( state ) { return state.settings; } diff --git a/packages/block-editor/src/store/test/effects.js b/packages/block-editor/src/store/test/effects.js index 090779cbad0d9..34300ed6d42ff 100644 --- a/packages/block-editor/src/store/test/effects.js +++ b/packages/block-editor/src/store/test/effects.js @@ -18,7 +18,7 @@ import { createRegistry } from '@wordpress/data'; * Internal dependencies */ import actions, { - updateEditorSettings, + updateSettings, mergeBlocks, replaceBlocks, resetBlocks, @@ -234,7 +234,7 @@ describe( 'effects', () => { } ); it( 'should return undefined if invalid but unlocked', () => { - store.dispatch( updateEditorSettings( { + store.dispatch( updateSettings( { template: [ [ 'core/foo', {} ], ], @@ -248,7 +248,7 @@ describe( 'effects', () => { } ); it( 'should return undefined if locked and valid', () => { - store.dispatch( updateEditorSettings( { + store.dispatch( updateSettings( { template: [ [ 'core/test-block' ], ], @@ -263,7 +263,7 @@ describe( 'effects', () => { } ); it( 'should return validity set action if invalid on default state', () => { - store.dispatch( updateEditorSettings( { + store.dispatch( updateSettings( { template: [ [ 'core/foo' ], ], diff --git a/packages/block-library/src/html/edit.js b/packages/block-library/src/html/edit.js index 6dd2bb6f1fd92..0000654785a43 100644 --- a/packages/block-library/src/html/edit.js +++ b/packages/block-library/src/html/edit.js @@ -87,8 +87,8 @@ class HTMLEdit extends Component { } } export default withSelect( ( select ) => { - const { getEditorSettings } = select( 'core/block-editor' ); + const { getSettings } = select( 'core/block-editor' ); return { - styles: getEditorSettings().styles, + styles: getSettings().styles, }; } )( HTMLEdit ); diff --git a/packages/block-library/src/image/edit.js b/packages/block-library/src/image/edit.js index deaeaf79766dc..f8308165923f1 100644 --- a/packages/block-library/src/image/edit.js +++ b/packages/block-library/src/image/edit.js @@ -705,9 +705,9 @@ class ImageEdit extends Component { export default compose( [ withSelect( ( select, props ) => { const { getMedia } = select( 'core' ); - const { getEditorSettings } = select( 'core/block-editor' ); + const { getSettings } = select( 'core/block-editor' ); const { id } = props.attributes; - const { maxWidth, isRTL, imageSizes } = getEditorSettings(); + const { maxWidth, isRTL, imageSizes } = getSettings(); return { image: id ? getMedia( id ) : null, diff --git a/packages/block-library/src/paragraph/edit.js b/packages/block-library/src/paragraph/edit.js index 2aaad4c8060ff..060080b971e59 100644 --- a/packages/block-library/src/paragraph/edit.js +++ b/packages/block-library/src/paragraph/edit.js @@ -259,10 +259,10 @@ const ParagraphEdit = compose( [ withFontSizes( 'fontSize' ), applyFallbackStyles, withSelect( ( select ) => { - const { getEditorSettings } = select( 'core/block-editor' ); + const { getSettings } = select( 'core/block-editor' ); return { - isRTL: getEditorSettings().isRTL, + isRTL: getSettings().isRTL, }; } ), ] )( ParagraphBlock ); diff --git a/packages/block-library/src/pullquote/index.js b/packages/block-library/src/pullquote/index.js index beaf1d9549aaa..766cb78861158 100644 --- a/packages/block-library/src/pullquote/index.js +++ b/packages/block-library/src/pullquote/index.js @@ -100,7 +100,7 @@ export const settings = { // Is normal style and a named color is being used, we need to retrieve the color value to set the style, // as there is no expectation that themes create classes that set border colors. } else if ( mainColor ) { - const colors = get( select( 'core/block-editor' ).getEditorSettings(), [ 'colors' ], [] ); + const colors = get( select( 'core/block-editor' ).getSettings(), [ 'colors' ], [] ); const colorObject = getColorObjectByAttributeValues( colors, mainColor ); figureStyles = { borderColor: colorObject.color, diff --git a/packages/edit-post/src/components/header/header-toolbar/index.js b/packages/edit-post/src/components/header/header-toolbar/index.js index 7740b3b157a99..7d99c1f889e04 100644 --- a/packages/edit-post/src/components/header/header-toolbar/index.js +++ b/packages/edit-post/src/components/header/header-toolbar/index.js @@ -57,7 +57,7 @@ export default compose( [ withSelect( ( select ) => ( { hasFixedToolbar: select( 'core/edit-post' ).isFeatureActive( 'fixedToolbar' ), // This setting (richEditingEnabled) should not live in the block editor's setting. - showInserter: select( 'core/edit-post' ).getEditorMode() === 'visual' && select( 'core/block-editor' ).getEditorSettings().richEditingEnabled, + showInserter: select( 'core/edit-post' ).getEditorMode() === 'visual' && select( 'core/editor' ).getEditorSettings().richEditingEnabled, isTextModeEnabled: select( 'core/edit-post' ).getEditorMode() === 'text', } ) ), withViewportMatch( { isLargeViewport: 'medium' } ), diff --git a/packages/edit-post/src/components/header/mode-switcher/index.js b/packages/edit-post/src/components/header/mode-switcher/index.js index 058d9c74eeb8c..52ca0b78cfc94 100644 --- a/packages/edit-post/src/components/header/mode-switcher/index.js +++ b/packages/edit-post/src/components/header/mode-switcher/index.js @@ -49,7 +49,7 @@ function ModeSwitcher( { onSwitch, mode } ) { export default compose( [ withSelect( ( select ) => ( { - isRichEditingEnabled: select( 'core/block-editor' ).getEditorSettings().richEditingEnabled, + isRichEditingEnabled: select( 'core/editor' ).getEditorSettings().richEditingEnabled, mode: select( 'core/edit-post' ).getEditorMode(), } ) ), ifCondition( ( { isRichEditingEnabled } ) => isRichEditingEnabled ), diff --git a/packages/edit-post/src/components/keyboard-shortcuts/index.js b/packages/edit-post/src/components/keyboard-shortcuts/index.js index b5c09178efd68..bde16d7431106 100644 --- a/packages/edit-post/src/components/keyboard-shortcuts/index.js +++ b/packages/edit-post/src/components/keyboard-shortcuts/index.js @@ -55,7 +55,7 @@ class EditorModeKeyboardShortcuts extends Component { export default compose( [ withSelect( ( select ) => ( { - isRichEditingEnabled: select( 'core/block-editor' ).getEditorSettings().richEditingEnabled, + isRichEditingEnabled: select( 'core/editor' ).getEditorSettings().richEditingEnabled, mode: select( 'core/edit-post' ).getEditorMode(), isEditorSidebarOpen: select( 'core/edit-post' ).isEditorSidebarOpened(), } ) ), diff --git a/packages/edit-post/src/components/layout/index.js b/packages/edit-post/src/components/layout/index.js index 76c10e8a78032..f0876f4672287 100644 --- a/packages/edit-post/src/components/layout/index.js +++ b/packages/edit-post/src/components/layout/index.js @@ -137,7 +137,7 @@ export default compose( hasFixedToolbar: select( 'core/edit-post' ).isFeatureActive( 'fixedToolbar' ), hasActiveMetaboxes: select( 'core/edit-post' ).hasMetaBoxes(), isSaving: select( 'core/edit-post' ).isSavingMetaBoxes(), - isRichEditingEnabled: select( 'core/block-editor' ).getEditorSettings().richEditingEnabled, + isRichEditingEnabled: select( 'core/editor' ).getEditorSettings().richEditingEnabled, } ) ), withDispatch( ( dispatch ) => { const { closePublishSidebar, togglePublishSidebar } = dispatch( 'core/edit-post' ); diff --git a/packages/edit-post/src/components/options-modal/meta-boxes-section.js b/packages/edit-post/src/components/options-modal/meta-boxes-section.js index a5b8e0e85ad50..e4ab459a0e41a 100644 --- a/packages/edit-post/src/components/options-modal/meta-boxes-section.js +++ b/packages/edit-post/src/components/options-modal/meta-boxes-section.js @@ -34,7 +34,7 @@ export function MetaBoxesSection( { areCustomFieldsRegistered, metaBoxes, ...sec } export default withSelect( ( select ) => { - const { getEditorSettings } = select( 'core/block-editor' ); + const { getEditorSettings } = select( 'core/editor' ); const { getAllMetaBoxes } = select( 'core/edit-post' ); return { diff --git a/packages/edit-post/src/components/options-modal/options/enable-custom-fields.js b/packages/edit-post/src/components/options-modal/options/enable-custom-fields.js index e9a319efbebfe..140c6f1c46d2d 100644 --- a/packages/edit-post/src/components/options-modal/options/enable-custom-fields.js +++ b/packages/edit-post/src/components/options-modal/options/enable-custom-fields.js @@ -43,5 +43,5 @@ export class EnableCustomFieldsOption extends Component { } export default withSelect( ( select ) => ( { - isChecked: !! select( 'core/block-editor' ).getEditorSettings().enableCustomFields, + isChecked: !! select( 'core/editor' ).getEditorSettings().enableCustomFields, } ) )( EnableCustomFieldsOption ); diff --git a/packages/edit-post/src/components/text-editor/index.js b/packages/edit-post/src/components/text-editor/index.js index 0cebd6e7396ad..882e97dd7e83c 100644 --- a/packages/edit-post/src/components/text-editor/index.js +++ b/packages/edit-post/src/components/text-editor/index.js @@ -38,7 +38,7 @@ function TextEditor( { onExit, isRichEditingEnabled } ) { export default compose( withSelect( ( select ) => ( { - isRichEditingEnabled: select( 'core/block-editor' ).getEditorSettings().richEditingEnabled, + isRichEditingEnabled: select( 'core/editor' ).getEditorSettings().richEditingEnabled, } ) ), withDispatch( ( dispatch ) => { return { diff --git a/packages/editor/src/components/alignment-toolbar/index.js b/packages/editor/src/components/alignment-toolbar/index.js index bf5fe27650e2a..1124f44f033e1 100644 --- a/packages/editor/src/components/alignment-toolbar/index.js +++ b/packages/editor/src/components/alignment-toolbar/index.js @@ -69,10 +69,10 @@ export default compose( } ), withViewportMatch( { isLargeViewport: 'medium' } ), withSelect( ( select, { clientId, isLargeViewport, isCollapsed } ) => { - const { getBlockRootClientId, getEditorSettings } = select( 'core/block-editor' ); + const { getBlockRootClientId, getSettings } = select( 'core/block-editor' ); return { isCollapsed: isCollapsed || ! isLargeViewport || ( - ! getEditorSettings().hasFixedToolbar && + ! getSettings().hasFixedToolbar && getBlockRootClientId( clientId ) ), }; diff --git a/packages/editor/src/components/autosave-monitor/index.js b/packages/editor/src/components/autosave-monitor/index.js index 23cff18b19411..73f15c285cbff 100644 --- a/packages/editor/src/components/autosave-monitor/index.js +++ b/packages/editor/src/components/autosave-monitor/index.js @@ -66,8 +66,7 @@ export default compose( [ isAutosavingPost, } = select( 'core/editor' ); - // This settings should not live in the block editor. - const { autosaveInterval } = select( 'core/block-editor' ).getEditorSettings(); + const { autosaveInterval } = select( 'core/editor' ).getEditorSettings(); return { isDirty: isEditedPostDirty(), diff --git a/packages/editor/src/components/block-alignment-toolbar/index.js b/packages/editor/src/components/block-alignment-toolbar/index.js index 0dcc4bda1412f..adf02cd90b08b 100644 --- a/packages/editor/src/components/block-alignment-toolbar/index.js +++ b/packages/editor/src/components/block-alignment-toolbar/index.js @@ -75,11 +75,12 @@ export default compose( } ), withViewportMatch( { isLargeViewport: 'medium' } ), withSelect( ( select, { clientId, isLargeViewport, isCollapsed } ) => { - const { getBlockRootClientId, getEditorSettings } = select( 'core/block-editor' ); + const { getBlockRootClientId, getSettings } = select( 'core/block-editor' ); + const settings = getSettings(); return { - wideControlsEnabled: select( 'core/block-editor' ).getEditorSettings().alignWide, + wideControlsEnabled: settings.alignWide, isCollapsed: isCollapsed || ! isLargeViewport || ( - ! getEditorSettings().hasFixedToolbar && + ! settings.hasFixedToolbar && getBlockRootClientId( clientId ) ), }; diff --git a/packages/editor/src/components/block-list/block.js b/packages/editor/src/components/block-list/block.js index 4a977903e44c7..2b828a34cdd93 100644 --- a/packages/editor/src/components/block-list/block.js +++ b/packages/editor/src/components/block-list/block.js @@ -633,14 +633,14 @@ const applyWithSelect = withSelect( getBlockMode, isSelectionEnabled, getSelectedBlocksInitialCaretPosition, - getEditorSettings, + getSettings, hasSelectedInnerBlock, getTemplateLock, __unstableGetBlockWithoutInnerBlocks, } = select( 'core/block-editor' ); const block = __unstableGetBlockWithoutInnerBlocks( clientId ); const isSelected = isBlockSelected( clientId ); - const { hasFixedToolbar, focusMode } = getEditorSettings(); + const { hasFixedToolbar, focusMode } = getSettings(); const templateLock = getTemplateLock( rootClientId ); const isParentOfSelectedBlock = hasSelectedInnerBlock( clientId, true ); @@ -748,8 +748,8 @@ const applyWithDispatch = withDispatch( ( dispatch, ownProps, { select } ) => { replaceBlocks( [ ownProps.clientId ], blocks ); }, onMetaChange( updatedMeta ) { - const { getEditorSettings } = select( 'core/block-editor' ); - const onChangeMeta = getEditorSettings().__experimentalMetaSource.onChange; + const { getSettings } = select( 'core/block-editor' ); + const onChangeMeta = getSettings().__experimentalMetaSource.onChange; onChangeMeta( updatedMeta ); }, onShiftSelection() { diff --git a/packages/editor/src/components/block-list/hover-area.js b/packages/editor/src/components/block-list/hover-area.js index d7091552b4885..a79b0bcd9b088 100644 --- a/packages/editor/src/components/block-list/hover-area.js +++ b/packages/editor/src/components/block-list/hover-area.js @@ -76,7 +76,7 @@ class HoverArea extends Component { export default withSelect( ( select ) => { return { - isRTL: select( 'core/block-editor' ).getEditorSettings().isRTL, + isRTL: select( 'core/block-editor' ).getSettings().isRTL, }; } )( HoverArea ); diff --git a/packages/editor/src/components/color-palette/with-color-context.js b/packages/editor/src/components/color-palette/with-color-context.js index 48eaa8085fca9..1c32141f2a3f1 100644 --- a/packages/editor/src/components/color-palette/with-color-context.js +++ b/packages/editor/src/components/color-palette/with-color-context.js @@ -13,7 +13,7 @@ import { withSelect } from '@wordpress/data'; export default createHigherOrderComponent( withSelect( ( select, ownProps ) => { - const settings = select( 'core/block-editor' ).getEditorSettings(); + const settings = select( 'core/block-editor' ).getSettings(); const colors = ownProps.colors === undefined ? settings.colors : ownProps.colors; diff --git a/packages/editor/src/components/colors/with-colors.js b/packages/editor/src/components/colors/with-colors.js index 11524408b4a29..516a5a023414f 100644 --- a/packages/editor/src/components/colors/with-colors.js +++ b/packages/editor/src/components/colors/with-colors.js @@ -36,7 +36,7 @@ const withCustomColorPalette = ( colorsArray ) => createHigherOrderComponent( ( * @return {function} The higher order component. */ const withEditorColorPalette = () => withSelect( ( select ) => { - const settings = select( 'core/block-editor' ).getEditorSettings(); + const settings = select( 'core/block-editor' ).getSettings(); return { colors: get( settings, [ 'colors' ], DEFAULT_COLORS ), }; diff --git a/packages/editor/src/components/default-block-appender/index.js b/packages/editor/src/components/default-block-appender/index.js index 5a320ba4c105d..183da30afd8b1 100644 --- a/packages/editor/src/components/default-block-appender/index.js +++ b/packages/editor/src/components/default-block-appender/index.js @@ -74,12 +74,12 @@ export function DefaultBlockAppender( { export default compose( withState( { hovered: false } ), withSelect( ( select, ownProps ) => { - const { getBlockCount, getBlockName, isBlockValid, getEditorSettings, getTemplateLock } = select( 'core/block-editor' ); + const { getBlockCount, getBlockName, isBlockValid, getSettings, getTemplateLock } = select( 'core/block-editor' ); const isEmpty = ! getBlockCount( ownProps.rootClientId ); const isLastBlockDefault = getBlockName( ownProps.lastBlockClientId ) === getDefaultBlockName(); const isLastBlockValid = isBlockValid( ownProps.lastBlockClientId ); - const { bodyPlaceholder } = getEditorSettings(); + const { bodyPlaceholder } = getSettings(); return { isVisible: isEmpty || ! isLastBlockDefault || ! isLastBlockValid, diff --git a/packages/editor/src/components/default-block-appender/index.native.js b/packages/editor/src/components/default-block-appender/index.native.js index ab34b5ebbde21..eae900cc70362 100644 --- a/packages/editor/src/components/default-block-appender/index.native.js +++ b/packages/editor/src/components/default-block-appender/index.native.js @@ -49,10 +49,10 @@ export function DefaultBlockAppender( { export default compose( withSelect( ( select, ownProps ) => { - const { getBlockCount, getEditorSettings, getTemplateLock } = select( 'core/block-editor' ); + const { getBlockCount, getSettings, getTemplateLock } = select( 'core/block-editor' ); const isEmpty = ! getBlockCount( ownProps.rootClientId ); - const { bodyPlaceholder } = getEditorSettings(); + const { bodyPlaceholder } = getSettings(); return { isVisible: isEmpty, diff --git a/packages/editor/src/components/font-sizes/font-size-picker.js b/packages/editor/src/components/font-sizes/font-size-picker.js index 6989bb2233669..e2dbe3dba8134 100644 --- a/packages/editor/src/components/font-sizes/font-size-picker.js +++ b/packages/editor/src/components/font-sizes/font-size-picker.js @@ -9,7 +9,7 @@ export default withSelect( const { disableCustomFontSizes, fontSizes, - } = select( 'core/block-editor' ).getEditorSettings(); + } = select( 'core/block-editor' ).getSettings(); return { disableCustomFontSizes, diff --git a/packages/editor/src/components/font-sizes/with-font-sizes.js b/packages/editor/src/components/font-sizes/with-font-sizes.js index 39953baf801f2..23a8c76a11d25 100644 --- a/packages/editor/src/components/font-sizes/with-font-sizes.js +++ b/packages/editor/src/components/font-sizes/with-font-sizes.js @@ -38,7 +38,7 @@ export default ( ...fontSizeNames ) => { return createHigherOrderComponent( compose( [ withSelect( ( select ) => { - const { fontSizes } = select( 'core/block-editor' ).getEditorSettings(); + const { fontSizes } = select( 'core/block-editor' ).getSettings(); return { fontSizes, }; diff --git a/packages/editor/src/components/media-placeholder/index.js b/packages/editor/src/components/media-placeholder/index.js index 33b2792beb65d..2270b87762ea3 100644 --- a/packages/editor/src/components/media-placeholder/index.js +++ b/packages/editor/src/components/media-placeholder/index.js @@ -263,11 +263,11 @@ export class MediaPlaceholder extends Component { const applyWithSelect = withSelect( ( select ) => { const { canUser } = select( 'core' ); - const { getEditorSettings } = select( 'core/block-editor' ); + const { getSettings } = select( 'core/block-editor' ); return { hasUploadPermissions: defaultTo( canUser( 'create', 'media' ), true ), - mediaUpload: getEditorSettings().__experimentalMediaUpload, + mediaUpload: getSettings().__experimentalMediaUpload, }; } ); diff --git a/packages/editor/src/components/page-attributes/check.js b/packages/editor/src/components/page-attributes/check.js index 014b2aa29136a..56be444a04985 100644 --- a/packages/editor/src/components/page-attributes/check.js +++ b/packages/editor/src/components/page-attributes/check.js @@ -20,11 +20,8 @@ export function PageAttributesCheck( { availableTemplates, postType, children } } export default withSelect( ( select ) => { - const { getEditedPostAttribute } = select( 'core/editor' ); - const { getEditorSettings } = select( 'core/block-editor' ); + const { getEditedPostAttribute, getEditorSettings } = select( 'core/editor' ); const { getPostType } = select( 'core' ); - - // This setting should not live in the block-editor module. const { availableTemplates } = getEditorSettings(); return { postType: getPostType( getEditedPostAttribute( 'type' ) ), diff --git a/packages/editor/src/components/page-attributes/template.js b/packages/editor/src/components/page-attributes/template.js index 8e6d9cef689cd..3646a05e3206f 100644 --- a/packages/editor/src/components/page-attributes/template.js +++ b/packages/editor/src/components/page-attributes/template.js @@ -33,8 +33,7 @@ export function PageTemplate( { availableTemplates, selectedTemplate, onUpdate } export default compose( withSelect( ( select ) => { - const { getEditedPostAttribute } = select( 'core/editor' ); - const { getEditorSettings } = select( 'core/block-editor' ); + const { getEditedPostAttribute, getEditorSettings } = select( 'core/editor' ); const { availableTemplates } = getEditorSettings(); return { selectedTemplate: getEditedPostAttribute( 'template' ), diff --git a/packages/editor/src/components/post-format/check.js b/packages/editor/src/components/post-format/check.js index d13e354655e9d..cd124553a7cf1 100644 --- a/packages/editor/src/components/post-format/check.js +++ b/packages/editor/src/components/post-format/check.js @@ -15,8 +15,7 @@ function PostFormatCheck( { disablePostFormats, ...props } ) { export default withSelect( ( select ) => { - // This setting should not live in the block-editor's store. - const editorSettings = select( 'core/block-editor' ).getEditorSettings(); + const editorSettings = select( 'core/editor' ).getEditorSettings(); return { disablePostFormats: editorSettings.disablePostFormats, }; diff --git a/packages/editor/src/components/post-locked-modal/index.js b/packages/editor/src/components/post-locked-modal/index.js index 8a9b88cbc2109..dd681f1f80980 100644 --- a/packages/editor/src/components/post-locked-modal/index.js +++ b/packages/editor/src/components/post-locked-modal/index.js @@ -220,17 +220,14 @@ export default compose( getCurrentPostId, getActivePostLock, getEditedPostAttribute, - } = select( 'core/editor' ); - const { getEditorSettings, - } = select( 'core/block-editor' ); + } = select( 'core/editor' ); const { getPostType } = select( 'core' ); return { isLocked: isPostLocked(), isTakeover: isPostLockTakeover(), user: getPostLockUser(), postId: getCurrentPostId(), - // This setting should not live in the block-editor's store. postLockUtils: getEditorSettings().postLockUtils, activePostLock: getActivePostLock(), postType: getPostType( getEditedPostAttribute( 'type' ) ), diff --git a/packages/editor/src/components/post-title/index.js b/packages/editor/src/components/post-title/index.js index 761fcff095df4..e992e25bae11a 100644 --- a/packages/editor/src/components/post-title/index.js +++ b/packages/editor/src/components/post-title/index.js @@ -150,10 +150,10 @@ class PostTitle extends Component { const applyWithSelect = withSelect( ( select ) => { const { getEditedPostAttribute, isCleanNewPost } = select( 'core/editor' ); - const { getEditorSettings } = select( 'core/block-editor' ); + const { getSettings } = select( 'core/block-editor' ); const { getPostType } = select( 'core' ); const postType = getPostType( getEditedPostAttribute( 'type' ) ); - const { titlePlaceholder, focusMode, hasFixedToolbar } = getEditorSettings(); + const { titlePlaceholder, focusMode, hasFixedToolbar } = getSettings(); return { isCleanNewPost: isCleanNewPost(), diff --git a/packages/editor/src/components/provider/index.js b/packages/editor/src/components/provider/index.js index fa85e1b1abadd..92e13d137ce54 100644 --- a/packages/editor/src/components/provider/index.js +++ b/packages/editor/src/components/provider/index.js @@ -1,7 +1,7 @@ /** * External dependencies */ -import { map } from 'lodash'; +import { map, pick } from 'lodash'; import memize from 'memize'; /** @@ -53,7 +53,22 @@ class EditorProvider extends Component { getBlockEditorSettings( settings, meta, onMetaChange, reusableBlocks ) { return { - ...settings, + ...pick( settings, [ + 'alignWide', + 'colors', + 'disableCustomColors', + 'fontSizes', + 'disableCustomFontSizes', + 'imageSizes', + 'maxWidth', + 'blockTypes', + 'hasFixedToolbar', + 'focusMode', + 'styles', + 'isRTL', + 'bodyPlaceholder', + 'titlePlaceholder', + ] ), __experimentalMetaSource: { value: meta, onChange: onMetaChange, @@ -64,6 +79,8 @@ class EditorProvider extends Component { } componentDidMount() { + this.props.updateEditorSettings( this.props.settings ); + if ( ! this.props.settings.styles ) { return; } @@ -79,6 +96,12 @@ class EditorProvider extends Component { } ); } + componentDidUpdate( prevProps ) { + if ( this.props.settings !== prevProps.settings ) { + this.props.updateEditorSettings( this.props.settings ); + } + } + render() { const { children, @@ -134,6 +157,7 @@ export default compose( [ updatePostLock, resetEditorBlocks, editPost, + updateEditorSettings, } = dispatch( 'core/editor' ); const { createWarningNotice } = dispatch( 'core/notices' ); @@ -142,6 +166,7 @@ export default compose( [ updatePostLock, createWarningNotice, resetEditorBlocks, + updateEditorSettings, resetEditorBlocksWithoutUndoLevel( blocks ) { resetEditorBlocks( blocks, { __unstableShouldCreateUndoLevel: false, diff --git a/packages/editor/src/hooks/align.js b/packages/editor/src/hooks/align.js index b9d2b842cef1d..ca0a019d5cc9e 100644 --- a/packages/editor/src/hooks/align.js +++ b/packages/editor/src/hooks/align.js @@ -168,9 +168,9 @@ export const withDataAlign = createHigherOrderComponent( compose( [ withSelect( ( select ) => { - const { getEditorSettings } = select( 'core/block-editor' ); + const { getSettings } = select( 'core/block-editor' ); return { - hasWideEnabled: !! getEditorSettings().alignWide, + hasWideEnabled: !! getSettings().alignWide, }; } ), diff --git a/packages/editor/src/store/actions.js b/packages/editor/src/store/actions.js index f1271ed3d96d1..c0c88d1072fe9 100644 --- a/packages/editor/src/store/actions.js +++ b/packages/editor/src/store/actions.js @@ -699,6 +699,20 @@ export function resetEditorBlocks( blocks, options = {} ) { }; } +/* + * Returns an action object used in signalling that the post editor settings have been updated. + * + * @param {Object} settings Updated settings + * + * @return {Object} Action object + */ +export function updateEditorSettings( settings ) { + return { + type: 'UPDATE_EDITOR_SETTINGS', + settings, + }; +} + /** * Backward compatibility */ @@ -737,4 +751,3 @@ export const enterFormattedText = getBlockEditorAction( 'enterFormattedText' ); export const exitFormattedText = getBlockEditorAction( 'exitFormattedText' ); export const insertDefaultBlock = getBlockEditorAction( 'insertDefaultBlock' ); export const updateBlockListSettings = getBlockEditorAction( 'updateBlockListSettings' ); -export const updateEditorSettings = getBlockEditorAction( 'updateEditorSettings' ); diff --git a/packages/editor/src/store/defaults.js b/packages/editor/src/store/defaults.js index 32fd438302c69..53178b43cb5aa 100644 --- a/packages/editor/src/store/defaults.js +++ b/packages/editor/src/store/defaults.js @@ -1,3 +1,8 @@ +/** + * WordPress dependencies + */ +import { SETTINGS_DEFAULTS } from '@wordpress/block-editor'; + export const PREFERENCES_DEFAULTS = { isPublishSidebarEnabled: true, }; @@ -8,3 +13,22 @@ export const PREFERENCES_DEFAULTS = { * @type {Object} */ export const INITIAL_EDITS_DEFAULTS = {}; + +/** + * The default post editor settings + * + * richEditingEnabled boolean Whether rich editing is enabled or not + * enableCustomFields boolean Whether the WordPress custom fields are enabled or not + * autosaveInterval number Autosave Interval + * availableTemplates array? The available post templates + * disablePostFormats boolean Whether or not the post formats are disabled + * allowedMimeTypes array? List of allowed mime types and file extensions + * maxUploadFileSize number Maximum upload file size + */ +export const EDITOR_SETTINGS_DEFAULTS = { + ...SETTINGS_DEFAULTS, + + richEditingEnabled: true, + enableCustomFields: false, +}; + diff --git a/packages/editor/src/store/reducer.js b/packages/editor/src/store/reducer.js index 68a6624163ae0..b6a4759503ce7 100644 --- a/packages/editor/src/store/reducer.js +++ b/packages/editor/src/store/reducer.js @@ -24,6 +24,7 @@ import { addQueryArgs } from '@wordpress/url'; import { PREFERENCES_DEFAULTS, INITIAL_EDITS_DEFAULTS, + EDITOR_SETTINGS_DEFAULTS, } from './defaults'; import { EDIT_MERGE_PROPERTIES } from './constants'; import withChangeDetection from '../utils/with-change-detection'; @@ -825,6 +826,26 @@ export function isReady( state = false, action ) { return state; } +/** + * Reducer returning the post editor setting. + * + * @param {Object} state Current state. + * @param {Object} action Dispatched action. + * + * @return {Object} Updated state. + */ +export function editorSettings( state = EDITOR_SETTINGS_DEFAULTS, action ) { + switch ( action.type ) { + case 'UPDATE_EDITOR_SETTINGS': + return { + ...state, + ...action.settings, + }; + } + + return state; +} + export default optimist( combineReducers( { editor, initialEdits, @@ -838,4 +859,5 @@ export default optimist( combineReducers( { previewLink, postSavingLock, isReady, + editorSettings, } ) ); diff --git a/packages/editor/src/store/selectors.js b/packages/editor/src/store/selectors.js index c4d97cbd741ba..b840175a5cdd9 100644 --- a/packages/editor/src/store/selectors.js +++ b/packages/editor/src/store/selectors.js @@ -1084,6 +1084,17 @@ export function __unstableIsEditorReady( state ) { return state.isReady; } +/** + * Returns the post editor settings. + * + * @param {Object} state Editor state. + * + * @return {Object} The editor settings object. + */ +export function getEditorSettings( state ) { + return state.editorSettings; +} + /* * Backward compatibility */ @@ -1146,5 +1157,4 @@ export const getTemplateLock = getBlockEditorSelector( 'getTemplateLock' ); export const canInsertBlockType = getBlockEditorSelector( 'canInsertBlockType' ); export const getInserterItems = getBlockEditorSelector( 'getInserterItems' ); export const hasInserterItems = getBlockEditorSelector( 'hasInserterItems' ); -export const getEditorSettings = getBlockEditorSelector( 'getEditorSettings' ); export const getBlockListSettings = getBlockEditorSelector( 'getBlockListSettings' ); diff --git a/packages/editor/src/utils/media-upload/index.js b/packages/editor/src/utils/media-upload/index.js index ced9e70c6b253..f6572e29c6b0c 100644 --- a/packages/editor/src/utils/media-upload/index.js +++ b/packages/editor/src/utils/media-upload/index.js @@ -33,10 +33,7 @@ export default function( { onError = noop, onFileChange, } ) { - const { getCurrentPostId } = select( 'core/editor' ); - const { getEditorSettings } = select( 'core/block-editor' ); - - // These settings should not live in the block editor's store. + const { getCurrentPostId, getEditorSettings } = select( 'core/editor' ); const wpAllowedMimeTypes = getEditorSettings().allowedMimeTypes; maxUploadFileSize = maxUploadFileSize || getEditorSettings().maxUploadFileSize;