From d718cb0ae5571e9c6199a7eaacf8f063804f7d52 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Andr=C3=A9?= <583546+oandregal@users.noreply.github.com> Date: Fri, 19 Nov 2021 09:48:44 +0100 Subject: [PATCH] Color UI component: reorder palettes and update names (core by defaults, user by custom) (#36622) --- docs/how-to-guides/themes/theme-json.md | 6 +- lib/class-wp-theme-json-gutenberg.php | 22 ++--- ...class-wp-theme-json-resolver-gutenberg.php | 4 +- lib/theme.json | 4 +- .../panel-color-gradient-settings.js | 86 ++++++++++++------- .../src/components/global-styles/hooks.js | 68 +++++++++------ schemas/json/theme.json | 20 ++--- 7 files changed, 125 insertions(+), 85 deletions(-) diff --git a/docs/how-to-guides/themes/theme-json.md b/docs/how-to-guides/themes/theme-json.md index 24095cf2dd7090..1f3c6eef1dfd24 100644 --- a/docs/how-to-guides/themes/theme-json.md +++ b/docs/how-to-guides/themes/theme-json.md @@ -226,13 +226,11 @@ The settings section has the following structure: }, "color": { "background": true, - "corePalette": true, - "coreGradients": true, "custom": true, "customDuotone": true, "customGradient": true, - "corePalette": true, - "coreGradients": true, + "defaultGradients": true, + "defaultPalette": true, "duotone": [], "gradients": [], "link": false, diff --git a/lib/class-wp-theme-json-gutenberg.php b/lib/class-wp-theme-json-gutenberg.php index 2c1df8b309e790..9cd8ee501b58d4 100644 --- a/lib/class-wp-theme-json-gutenberg.php +++ b/lib/class-wp-theme-json-gutenberg.php @@ -88,17 +88,17 @@ class WP_Theme_JSON_Gutenberg { 'width' => null, ), 'color' => array( - 'background' => null, - 'corePalette' => null, - 'coreGradients' => null, - 'custom' => null, - 'customDuotone' => null, - 'customGradient' => null, - 'duotone' => null, - 'gradients' => null, - 'link' => null, - 'palette' => null, - 'text' => null, + 'background' => null, + 'custom' => null, + 'customDuotone' => null, + 'customGradient' => null, + 'defaultGradients' => null, + 'defaultPalette' => null, + 'duotone' => null, + 'gradients' => null, + 'link' => null, + 'palette' => null, + 'text' => null, ), 'custom' => null, 'layout' => array( diff --git a/lib/class-wp-theme-json-resolver-gutenberg.php b/lib/class-wp-theme-json-resolver-gutenberg.php index 3ebd995f5e706b..76138436e3408e 100644 --- a/lib/class-wp-theme-json-resolver-gutenberg.php +++ b/lib/class-wp-theme-json-resolver-gutenberg.php @@ -171,7 +171,7 @@ public static function get_theme_data() { // If the theme does not have any palette, we still want to show the core one. $default_palette = true; } - $theme_support_data['settings']['color']['corePalette'] = $default_palette; + $theme_support_data['settings']['color']['defaultPalette'] = $default_palette; $default_gradients = false; if ( current_theme_supports( 'default-gradient-presets' ) ) { @@ -181,7 +181,7 @@ public static function get_theme_data() { // If the theme does not have any gradients, we still want to show the core ones. $default_gradients = true; } - $theme_support_data['settings']['color']['coreGradients'] = $default_gradients; + $theme_support_data['settings']['color']['defaultGradients'] = $default_gradients; } $with_theme_supports = new WP_Theme_JSON_Gutenberg( $theme_support_data ); $with_theme_supports->merge( self::$theme ); diff --git a/lib/theme.json b/lib/theme.json index 82e3b4fec9ee05..390776b22dc05a 100644 --- a/lib/theme.json +++ b/lib/theme.json @@ -170,10 +170,10 @@ } ], "custom": true, - "corePalette": true, - "coreGradients": true, "customDuotone": true, "customGradient": true, + "defaultGradients": true, + "defaultPalette": true, "link": false, "text": true }, diff --git a/packages/block-editor/src/components/colors-gradients/panel-color-gradient-settings.js b/packages/block-editor/src/components/colors-gradients/panel-color-gradient-settings.js index d77447f9b726e7..a7b7324d1fdd74 100644 --- a/packages/block-editor/src/components/colors-gradients/panel-color-gradient-settings.js +++ b/packages/block-editor/src/components/colors-gradients/panel-color-gradient-settings.js @@ -8,7 +8,7 @@ import { every, isEmpty } from 'lodash'; * WordPress dependencies */ import { PanelBody, ColorIndicator } from '@wordpress/components'; -import { sprintf, __ } from '@wordpress/i18n'; +import { sprintf, __, _x } from '@wordpress/i18n'; import { useMemo } from '@wordpress/element'; /** @@ -172,64 +172,88 @@ const PanelColorGradientSettingsSingleSelect = ( props ) => { const PanelColorGradientSettingsMultipleSelect = ( props ) => { const colorGradientSettings = useCommonSingleMultipleSelects(); - const userColors = useSetting( 'color.palette.user' ); + const customColors = useSetting( 'color.palette.user' ); const themeColors = useSetting( 'color.palette.theme' ); - const coreColors = useSetting( 'color.palette.core' ); - const shouldDisplayCoreColors = useSetting( 'color.corePalette' ); + const defaultColors = useSetting( 'color.palette.core' ); + const shouldDisplayDefaultColors = useSetting( 'color.defaultPalette' ); colorGradientSettings.colors = useMemo( () => { const result = []; - if ( shouldDisplayCoreColors && coreColors && coreColors.length ) { + if ( themeColors && themeColors.length ) { result.push( { - name: __( 'Core' ), - colors: coreColors, + name: _x( + 'Theme', + 'Indicates this palette comes from the theme.' + ), + colors: themeColors, } ); } - if ( themeColors && themeColors.length ) { + if ( + shouldDisplayDefaultColors && + defaultColors && + defaultColors.length + ) { result.push( { - name: __( 'Theme' ), - colors: themeColors, + name: _x( + 'Default', + 'Indicates this palette comes from WordPress.' + ), + colors: defaultColors, } ); } - if ( userColors && userColors.length ) { + if ( customColors && customColors.length ) { result.push( { - name: __( 'User' ), - colors: userColors, + name: _x( + 'Custom', + 'Indicates this palette comes from the theme.' + ), + colors: customColors, } ); } return result; - }, [ coreColors, themeColors, userColors ] ); + }, [ defaultColors, themeColors, customColors ] ); - const userGradients = useSetting( 'color.gradients.user' ); + const customGradients = useSetting( 'color.gradients.user' ); const themeGradients = useSetting( 'color.gradients.theme' ); - const coreGradients = useSetting( 'color.gradients.core' ); - const shouldDisplayCoreGradients = useSetting( 'color.coreGradients' ); + const defaultGradients = useSetting( 'color.gradients.core' ); + const shouldDisplayDefaultGradients = useSetting( + 'color.defaultGradients' + ); colorGradientSettings.gradients = useMemo( () => { const result = []; - if ( - shouldDisplayCoreGradients && - coreGradients && - coreGradients.length - ) { + if ( themeGradients && themeGradients.length ) { result.push( { - name: __( 'Core' ), - gradients: coreGradients, + name: _x( + 'Theme', + 'Indicates this palette comes from the theme.' + ), + gradients: themeGradients, } ); } - if ( themeGradients && themeGradients.length ) { + if ( + shouldDisplayDefaultGradients && + defaultGradients && + defaultGradients.length + ) { result.push( { - name: __( 'Theme' ), - gradients: themeGradients, + name: _x( + 'Default', + 'Indicates this palette comes from WordPress.' + ), + gradients: defaultGradients, } ); } - if ( userGradients && userGradients.length ) { + if ( customGradients && customGradients.length ) { result.push( { - name: __( 'User' ), - gradients: userGradients, + name: _x( + 'Custom', + 'Indicates this palette is created by the user.' + ), + gradients: customGradients, } ); } return result; - }, [ userGradients, themeGradients, coreGradients ] ); + }, [ customGradients, themeGradients, defaultGradients ] ); return ( { const result = []; - if ( coreColors && coreColors.length ) { + if ( themeColors && themeColors.length ) { result.push( { - name: __( 'Core' ), - colors: coreColors, + name: _x( + 'Theme', + 'Indicates this palette comes from the theme.' + ), + colors: themeColors, } ); } - if ( themeColors && themeColors.length ) { + if ( defaultColors && defaultColors.length ) { result.push( { - name: __( 'Theme' ), - colors: themeColors, + name: _x( + 'Default', + 'Indicates this palette comes from WordPress.' + ), + colors: defaultColors, } ); } - if ( userColors && userColors.length ) { + if ( customColors && customColors.length ) { result.push( { - name: __( 'User' ), - colors: userColors, + name: _x( + 'Custom', + 'Indicates this palette is created by the user.' + ), + colors: customColors, } ); } return result; - }, [ userColors, themeColors, coreColors ] ); + }, [ customColors, themeColors, defaultColors ] ); } export function useGradientsPerOrigin( name ) { - const [ userGradients ] = useSetting( 'color.gradients.user', name ); + const [ customGradients ] = useSetting( 'color.gradients.user', name ); const [ themeGradients ] = useSetting( 'color.gradients.theme', name ); - const [ coreGradients ] = useSetting( 'color.gradients.core', name ); + const [ defaultGradients ] = useSetting( 'color.gradients.core', name ); return useMemo( () => { const result = []; - if ( coreGradients && coreGradients.length ) { + if ( themeGradients && themeGradients.length ) { result.push( { - name: __( 'Core' ), - gradients: coreGradients, + name: _x( + 'Theme', + 'Indicates this palette comes from the theme.' + ), + gradients: themeGradients, } ); } - if ( themeGradients && themeGradients.length ) { + if ( defaultGradients && defaultGradients.length ) { result.push( { - name: __( 'Theme' ), - gradients: themeGradients, + name: _x( + 'Default', + 'Indicates this palette comes from WordPress.' + ), + gradients: defaultGradients, } ); } - if ( userGradients && userGradients.length ) { + if ( customGradients && customGradients.length ) { result.push( { - name: __( 'User' ), - gradients: userGradients, + name: _x( + 'Custom', + 'Indicates this palette is created by the user.' + ), + gradients: customGradients, } ); } return result; - }, [ userGradients, themeGradients, coreGradients ] ); + }, [ customGradients, themeGradients, defaultGradients ] ); } diff --git a/schemas/json/theme.json b/schemas/json/theme.json index 982703a8b53324..05b29178843ad7 100644 --- a/schemas/json/theme.json +++ b/schemas/json/theme.json @@ -45,16 +45,6 @@ "type": "boolean", "default": true }, - "corePalette": { - "description": "Allow users to choose colors from the Core palette. \nGutenberg plugin required.", - "type": "boolean", - "default": true - }, - "coreGradients": { - "description": "Allow users to choose colors from the Core gradients. \nGutenberg plugin required.", - "type": "boolean", - "default": true - }, "custom": { "description": "Allow users to select custom colors.\nSince 5.8.", "type": "boolean", @@ -70,6 +60,16 @@ "type": "boolean", "default": true }, + "defaultGradients": { + "description": "Allow users to choose colors from the default gradients. \nGutenberg plugin required.", + "type": "boolean", + "default": true + }, + "defaultPalette": { + "description": "Allow users to choose colors from the default palette. \nGutenberg plugin required.", + "type": "boolean", + "default": true + }, "duotone": { "description": "Duotone presets for the duotone picker.\nDoesn't generate classes or properties.\nSince 5.8.", "type": "array",