diff --git a/lib/edit-site-page.php b/lib/edit-site-page.php index 441433fc2b952..9062d3b858dc3 100644 --- a/lib/edit-site-page.php +++ b/lib/edit-site-page.php @@ -128,7 +128,6 @@ function gutenberg_edit_site_init( $hook ) { $settings = array( 'alignWide' => get_theme_support( 'align-wide' ), - 'disableCustomColors' => get_theme_support( 'disable-custom-colors' ), 'disableCustomFontSizes' => get_theme_support( 'disable-custom-font-sizes' ), 'imageSizes' => $available_image_sizes, 'isRTL' => is_rtl(), @@ -144,6 +143,7 @@ function gutenberg_edit_site_init( $hook ) { $settings['fontSizes'] = $font_sizes; } $settings['styles'] = gutenberg_get_editor_styles(); + $settings = gutenberg_experimental_global_styles_settings( $settings ); // This is so other parts of the code can hook their own settings. // Example: Global Styles. diff --git a/lib/experimental-default-theme.json b/lib/experimental-default-theme.json index 1d1cfdabce390..2cf63a73b0010 100644 --- a/lib/experimental-default-theme.json +++ b/lib/experimental-default-theme.json @@ -127,6 +127,9 @@ "features": { "typography": { "dropCap": false + }, + "colors": { + "custom": true } } } diff --git a/lib/global-styles.php b/lib/global-styles.php index b8ca0e433052e..a90815eb36453 100644 --- a/lib/global-styles.php +++ b/lib/global-styles.php @@ -600,7 +600,15 @@ function gutenberg_experimental_global_styles_get_editor_features( $config ) { empty( $config['global']['features'] ) || ! is_array( $config['global']['features'] ) ) { - return array(); + $config['global']['features'] = array(); + } + + // Deprecated theme supports. + if ( get_theme_support( 'disable-custom-colors' ) ) { + if ( ! isset( $config['global']['features']['colors'] ) ) { + $config['global']['features']['colors'] = array(); + } + $config['global']['features']['colors']['custom'] = false; } return $config['global']['features']; @@ -633,6 +641,8 @@ function gutenberg_experimental_global_styles_settings( $settings ) { $settings['styles'][] = array( 'css' => $stylesheet ); $settings['__experimentalFeatures'] = gutenberg_experimental_global_styles_get_editor_features( $merged ); + // Unsetting deprecated settings defined by Core. + unset( $settings['disableCustomColors'] ); return $settings; } diff --git a/lib/navigation-page.php b/lib/navigation-page.php index e2e37f16f2859..d592bf9b83153 100644 --- a/lib/navigation-page.php +++ b/lib/navigation-page.php @@ -58,7 +58,6 @@ function gutenberg_navigation_init( $hook ) { } $settings = array( - 'disableCustomColors' => get_theme_support( 'disable-custom-colors' ), 'disableCustomFontSizes' => get_theme_support( 'disable-custom-font-sizes' ), 'imageSizes' => $available_image_sizes, 'isRTL' => is_rtl(), @@ -77,6 +76,8 @@ function gutenberg_navigation_init( $hook ) { $settings['fontSizes'] = $font_sizes; } + $settings = gutenberg_experimental_global_styles_settings( $settings ); + wp_add_inline_script( 'wp-edit-navigation', sprintf( diff --git a/lib/widgets-page.php b/lib/widgets-page.php index 408dd217b6685..b459a547e343a 100644 --- a/lib/widgets-page.php +++ b/lib/widgets-page.php @@ -76,7 +76,6 @@ function gutenberg_widgets_init( $hook ) { $settings = array_merge( array( - 'disableCustomColors' => get_theme_support( 'disable-custom-colors' ), 'disableCustomFontSizes' => get_theme_support( 'disable-custom-font-sizes' ), 'imageSizes' => $available_image_sizes, 'isRTL' => is_rtl(), @@ -95,6 +94,7 @@ function gutenberg_widgets_init( $hook ) { if ( false !== $font_sizes ) { $settings['fontSizes'] = $font_sizes; } + $settings = gutenberg_experimental_global_styles_settings( $settings ); wp_add_inline_script( 'wp-edit-widgets', diff --git a/packages/block-editor/README.md b/packages/block-editor/README.md index 17934b030b5dd..029e4ba72ad05 100644 --- a/packages/block-editor/README.md +++ b/packages/block-editor/README.md @@ -478,7 +478,6 @@ _Properties_ - _alignWide_ `boolean`: Enable/Disable Wide/Full Alignments - _availableLegacyWidgets_ `Array`: Array of objects representing the legacy widgets available. - _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 - _imageEditing_ `boolean`: Image Editing settings set to false to disable. diff --git a/packages/block-editor/src/components/color-palette/with-color-context.js b/packages/block-editor/src/components/color-palette/with-color-context.js index 1198a304d6735..b03e3eec9f18c 100644 --- a/packages/block-editor/src/components/color-palette/with-color-context.js +++ b/packages/block-editor/src/components/color-palette/with-color-context.js @@ -6,24 +6,48 @@ import { isEmpty } from 'lodash'; /** * WordPress dependencies */ -import { createHigherOrderComponent } from '@wordpress/compose'; +import { createHigherOrderComponent, compose } from '@wordpress/compose'; import { withSelect } from '@wordpress/data'; -export default createHigherOrderComponent( - withSelect( ( select, ownProps ) => { - const settings = select( 'core/block-editor' ).getSettings(); - const colors = - ownProps.colors === undefined ? settings.colors : ownProps.colors; +/** + * Internal dependencies + */ +import useEditorFeature from '../use-editor-feature'; + +const withDisableCustomColors = createHigherOrderComponent( + ( WrappedComponent ) => { + return ( props ) => { + const disableCustomColors = ! useEditorFeature( 'colors.custom' ); - const disableCustomColors = - ownProps.disableCustomColors === undefined - ? settings.disableCustomColors - : ownProps.disableCustomColors; - return { - colors, - disableCustomColors, - hasColorsToChoose: ! isEmpty( colors ) || ! disableCustomColors, + return ( + + ); }; - } ), + }, + 'withDisableCustomColors' +); + +export default createHigherOrderComponent( + compose( + withDisableCustomColors, + withSelect( ( select, ownProps ) => { + const settings = select( 'core/block-editor' ).getSettings(); + const colors = + ownProps.colors === undefined + ? settings.colors + : ownProps.colors; + + return { + colors, + hasColorsToChoose: + ! isEmpty( colors ) || ! ownProps.disableCustomColors, + }; + } ) + ), 'withColorContext' ); diff --git a/packages/block-editor/src/components/colors-gradients/control.js b/packages/block-editor/src/components/colors-gradients/control.js index 98b03edb39b14..9d1302870ba65 100644 --- a/packages/block-editor/src/components/colors-gradients/control.js +++ b/packages/block-editor/src/components/colors-gradients/control.js @@ -24,6 +24,7 @@ import { useSelect } from '@wordpress/data'; */ import { getColorObjectByColorValue } from '../colors'; import { __experimentalGetGradientObjectByGradientValue } from '../gradients'; +import useEditorFeature from '../use-editor-feature'; // translators: first %s: the color name or value (e.g. red or #ff0000) const colorIndicatorAriaLabel = __( '(Color: %s)' ); @@ -177,6 +178,10 @@ function ColorGradientControlSelect( props ) { const settings = select( 'core/block-editor' ).getSettings(); return pick( settings, colorsAndGradientKeys ); } ); + colorGradientSettings.disableCustomColors = ! useEditorFeature( + 'colors.custom' + ); + return ( { const settings = select( 'core/block-editor' ).getSettings(); return pick( settings, colorsAndGradientKeys ); } ); + colorGradientSettings.disableCustomColors = ! useEditorFeature( + 'colors.custom' + ); return ( + settings.disableCustomColors === undefined + ? undefined + : ! settings.disableCustomColors, +}; + /** * Hook that retrieves the setting for the given editor feature. * It works with nested objects using by finding the value at path. @@ -28,22 +35,23 @@ import { useBlockEditContext } from '../block-edit'; */ export default function useEditorFeature( featurePath ) { const { name: blockName } = useBlockEditContext(); - const path = `__experimentalFeatures.${ featurePath }`; const setting = useSelect( ( select ) => { - const { getBlockSupport } = select( 'core/blocks' ); - - const blockSupportValue = getBlockSupport( blockName, path ); - if ( blockSupportValue !== undefined ) { - return blockSupportValue; - } - + const path = `__experimentalFeatures.${ featurePath }`; const { getSettings } = select( 'core/block-editor' ); + const settings = getSettings(); + + const deprecatedSettingsValue = deprecatedFlags[ featurePath ] + ? deprecatedFlags[ featurePath ]( settings ) + : undefined; - return get( getSettings(), path ); + if ( deprecatedSettingsValue !== undefined ) { + return deprecatedSettingsValue; + } + return get( settings, path ); }, - [ blockName, path ] + [ blockName, featurePath ] ); return setting; diff --git a/packages/block-editor/src/store/defaults.js b/packages/block-editor/src/store/defaults.js index 3c62084982791..0ea72197adf76 100644 --- a/packages/block-editor/src/store/defaults.js +++ b/packages/block-editor/src/store/defaults.js @@ -14,7 +14,6 @@ export const PREFERENCES_DEFAULTS = { * @property {boolean} alignWide Enable/Disable Wide/Full Alignments * @property {Array} availableLegacyWidgets Array of objects representing the legacy widgets available. * @property {Array} colors Palette colors - * @property {boolean} disableCustomColors Whether or not the custom colors are disabled * @property {Array} fontSizes Available font sizes * @property {boolean} disableCustomFontSizes Whether or not the custom font sizes are disabled * @property {boolean} imageEditing Image Editing settings set to false to disable. diff --git a/packages/format-library/src/text-color/index.js b/packages/format-library/src/text-color/index.js index 60b1a5307f87c..30e86387ed931 100644 --- a/packages/format-library/src/text-color/index.js +++ b/packages/format-library/src/text-color/index.js @@ -9,7 +9,10 @@ import { get, isEmpty } from 'lodash'; import { __ } from '@wordpress/i18n'; import { useSelect } from '@wordpress/data'; import { useCallback, useMemo, useState } from '@wordpress/element'; -import { RichTextToolbarButton } from '@wordpress/block-editor'; +import { + RichTextToolbarButton, + __experimentalUseEditorFeature as useEditorFeature, +} from '@wordpress/block-editor'; import { Icon, textColor as textColorIcon } from '@wordpress/icons'; import { removeFormat } from '@wordpress/rich-text'; @@ -24,7 +27,8 @@ const title = __( 'Text Color' ); const EMPTY_ARRAY = []; function TextColorEdit( { value, onChange, isActive, activeAttributes } ) { - const { colors, disableCustomColors } = useSelect( ( select ) => { + const allowCustomControl = useEditorFeature( 'colors.custom' ); + const { colors } = useSelect( ( select ) => { const blockEditorSelect = select( 'core/block-editor' ); let settings; if ( blockEditorSelect && blockEditorSelect.getSettings ) { @@ -34,7 +38,6 @@ function TextColorEdit( { value, onChange, isActive, activeAttributes } ) { } return { colors: get( settings, [ 'colors' ], EMPTY_ARRAY ), - disableCustomColors: settings.disableCustomColors, }; } ); const [ isAddingColor, setIsAddingColor ] = useState( false ); @@ -54,8 +57,7 @@ function TextColorEdit( { value, onChange, isActive, activeAttributes } ) { }; }, [ value, colors ] ); - const hasColorsToChoose = - ! isEmpty( colors ) || disableCustomColors !== true; + const hasColorsToChoose = ! isEmpty( colors ) || ! allowCustomControl; if ( ! hasColorsToChoose && ! isActive ) { return null; }