diff --git a/lib/compat/wordpress-6.1/class-wp-theme-json-6-1.php b/lib/compat/wordpress-6.1/class-wp-theme-json-6-1.php index b4256992dbe0ad..946680fb44bdd7 100644 --- a/lib/compat/wordpress-6.1/class-wp-theme-json-6-1.php +++ b/lib/compat/wordpress-6.1/class-wp-theme-json-6-1.php @@ -107,7 +107,12 @@ protected static function get_blocks_metadata() { break; } - $element_selector[] = $selector . ' ' . $el_selector; + // This converts selectors like '.wp-element-button, .wp-block-button__link' + // to an array, so that the block selector is added to both parts of the selector. + $el_selectors = explode( ',', $el_selector ); + foreach ( $el_selectors as $el_selector_item ) { + $element_selector[] = $selector . ' ' . $el_selector_item; + } } static::$blocks_metadata[ $block_name ]['elements'][ $el_name ] = implode( ',', $element_selector ); } diff --git a/lib/compat/wordpress-6.1/class-wp-theme-json-resolver-6-1.php b/lib/compat/wordpress-6.1/class-wp-theme-json-resolver-6-1.php new file mode 100644 index 00000000000000..58abcc27c04ec5 --- /dev/null +++ b/lib/compat/wordpress-6.1/class-wp-theme-json-resolver-6-1.php @@ -0,0 +1,35 @@ + 0 || areCustomSolidsEnabled ); // TODO - use the right check + + const [ buttonTextColor, setButtonTextColor ] = useStyle( + 'elements.button.color.text', + name + ); + const [ userButtonTextColor ] = useStyle( + 'elements.button.color.text', + name, + 'user' + ); + + const [ buttonBgColor, setButtonBgColor ] = useStyle( + 'elements.button.color.background', + name + ); + const [ userButtonBgColor ] = useStyle( + 'elements.button.color.background', + name, + 'user' + ); + + if ( ! hasButtonColor ) { + return null; + } + + return ( + <> + + +

+ { __( 'Text color' ) } +

+ + + +

+ { __( 'Background color' ) } +

+ + + + ); +} + +export default ScreenButtonColor; diff --git a/packages/edit-site/src/components/global-styles/screen-colors.js b/packages/edit-site/src/components/global-styles/screen-colors.js index 78607e0d1997f9..e908a8b9fc947b 100644 --- a/packages/edit-site/src/components/global-styles/screen-colors.js +++ b/packages/edit-site/src/components/global-styles/screen-colors.js @@ -6,6 +6,7 @@ import { __experimentalItemGroup as ItemGroup, __experimentalHStack as HStack, __experimentalVStack as VStack, + __experimentalZStack as ZStack, FlexItem, ColorIndicator, } from '@wordpress/components'; @@ -101,6 +102,33 @@ function LinkColorItem( { name, parentMenu } ) { ); } +function ButtonColorItem( { name, parentMenu } ) { + const supports = getSupportedGlobalStylesPanels( name ); + const hasSupport = supports.includes( 'linkColor' ); // TODO - use a real support + const [ color ] = useStyle( 'elements.button.color.text', name ); + const [ bgColor ] = useStyle( 'elements.button.color.background', name ); + + if ( ! hasSupport ) { + return null; + } + + return ( + + + + + + + + + + + { __( 'Buttons' ) } + + + ); +} + function ScreenColors( { name } ) { const parentMenu = name === undefined ? '' : '/blocks/' + name; @@ -132,6 +160,10 @@ function ScreenColors( { name } ) { name={ name } parentMenu={ parentMenu } /> + diff --git a/packages/edit-site/src/components/global-styles/screen-typography-element.js b/packages/edit-site/src/components/global-styles/screen-typography-element.js index 46b53a3a7b3d31..4f7abe955803ee 100644 --- a/packages/edit-site/src/components/global-styles/screen-typography-element.js +++ b/packages/edit-site/src/components/global-styles/screen-typography-element.js @@ -18,6 +18,10 @@ const elements = { description: __( 'Manage the fonts and typography used on the links.' ), title: __( 'Links' ), }, + button: { + description: __( 'Manage the fonts and typography used on buttons.' ), + title: __( 'Buttons' ), + }, }; function ScreenTypographyElement( { name, element } ) { diff --git a/packages/edit-site/src/components/global-styles/screen-typography.js b/packages/edit-site/src/components/global-styles/screen-typography.js index f271ee43c4d0d8..f2b59ee320f301 100644 --- a/packages/edit-site/src/components/global-styles/screen-typography.js +++ b/packages/edit-site/src/components/global-styles/screen-typography.js @@ -104,6 +104,12 @@ function ScreenTypography( { name } ) { element="link" label={ __( 'Links' ) } /> + diff --git a/packages/edit-site/src/components/global-styles/style.scss b/packages/edit-site/src/components/global-styles/style.scss index 122b753dffa172..1b58a0ec05adbd 100644 --- a/packages/edit-site/src/components/global-styles/style.scss +++ b/packages/edit-site/src/components/global-styles/style.scss @@ -57,6 +57,16 @@ font-size: 11px !important; } +.edit-site-global-styles-section-title { + font-size: calc(1.95 * 8px); + color: rgb(30, 30, 30); + font-weight: 600; + line-height: 1.2; + padding: $grid-unit-20; + padding-bottom: 0; + margin: 0; +} + .edit-site-screen-color-palette-toggle.edit-site-screen-color-palette-toggle { margin-right: $grid-unit-20; margin-left: $grid-unit-20; @@ -68,6 +78,7 @@ .edit-site-screen-text-color__control, .edit-site-screen-link-color__control, +.edit-site-screen-button-color__control, .edit-site-screen-background-color__control { padding: $grid-unit-20; } diff --git a/packages/edit-site/src/components/global-styles/ui.js b/packages/edit-site/src/components/global-styles/ui.js index 793b0939d9014c..750985ad1f94fb 100644 --- a/packages/edit-site/src/components/global-styles/ui.js +++ b/packages/edit-site/src/components/global-styles/ui.js @@ -20,6 +20,7 @@ import ScreenColorPalette from './screen-color-palette'; import ScreenBackgroundColor from './screen-background-color'; import ScreenTextColor from './screen-text-color'; import ScreenLinkColor from './screen-link-color'; +import ScreenButtonColor from './screen-button-color'; import ScreenLayout from './screen-layout'; import ScreenStyleVariations from './screen-style-variations'; @@ -58,6 +59,12 @@ function ContextScreens( { name } ) { + + + + @@ -82,6 +89,12 @@ function ContextScreens( { name } ) { + + + + diff --git a/packages/edit-site/src/components/global-styles/use-global-styles-output.js b/packages/edit-site/src/components/global-styles/use-global-styles-output.js index 0be47a7000b539..4f6265a56a920a 100644 --- a/packages/edit-site/src/components/global-styles/use-global-styles-output.js +++ b/packages/edit-site/src/components/global-styles/use-global-styles-output.js @@ -283,7 +283,14 @@ export const getNodesWithStyles = ( tree, blockSelectors ) => { styles: value, selector: blockSelectors[ blockName ].selector .split( ',' ) - .map( ( sel ) => sel + ' ' + ELEMENTS[ elementName ] ) + .map( ( sel ) => { + const elementSelectors = + ELEMENTS[ elementName ].split( ',' ); + return elementSelectors.map( + ( elementSelector ) => + sel + ' ' + elementSelector + ); + } ) .join( ',' ), } ); } diff --git a/packages/edit-site/src/components/global-styles/utils.js b/packages/edit-site/src/components/global-styles/utils.js index 50c412fc06cd59..833255b624b47c 100644 --- a/packages/edit-site/src/components/global-styles/utils.js +++ b/packages/edit-site/src/components/global-styles/utils.js @@ -11,6 +11,7 @@ export const ROOT_BLOCK_SUPPORTS = [ 'backgroundColor', 'color', 'linkColor', + 'buttonColor', 'fontFamily', 'fontSize', 'fontStyle', @@ -75,6 +76,8 @@ const STYLE_PATH_TO_CSS_VAR_INFIX = { 'color.background': 'color', 'color.text': 'color', 'elements.link.color.text': 'color', + 'elements.button.color.text': 'color', + 'elements.button.backgroundColor': 'background-color', 'color.gradient': 'gradient', 'typography.fontSize': 'font-size', 'typography.fontFamily': 'font-family',