diff --git a/docs/designers-developers/developers/themes/theme-json.md b/docs/designers-developers/developers/themes/theme-json.md index 89c86b73cd50e6..987acc0b866ae2 100644 --- a/docs/designers-developers/developers/themes/theme-json.md +++ b/docs/designers-developers/developers/themes/theme-json.md @@ -191,32 +191,46 @@ This is being implemented, so it's not currently available. }, core/paragraph: { styles: { - line-height: , - font-size: , - color: , + typography: { + lineHeight: , + fontSize: + }, + color: { + text: + } } }, /* core/heading/h1, core/heading/h2, etc */ core/heading/h*: { styles: { - line-height: , - font-size: , - color: , + typography: { + lineHeight: , + fontSize: + }, + color: { + text: + } } }, core/columns: { styles: { - color: , + color: { + text: + } } }, core/group: { styles: { - color: , + color: { + text: + } } }, core/media-text: { styles: { - color: , + color: { + text: + } } }, } diff --git a/lib/global-styles.php b/lib/global-styles.php index da30437989b3ea..c2f9eb250646fc 100644 --- a/lib/global-styles.php +++ b/lib/global-styles.php @@ -314,6 +314,35 @@ function gutenberg_experimental_global_styles_get_block_data() { return $block_data; } +/** + * Given an array contain the styles shape returns the css for this styles. + * A similar function exists on the client at /packages/block-editor/src/hooks/style.js. + * + * @param array $styles Array containing the styles shape from global styles. + * + * @return array Containing a set of css rules. + */ +function gutenberg_experimental_global_styles_flatten_styles_tree( $styles ) { + $mappings = array( + 'line-height' => array( 'typography', 'lineHeight' ), + 'font-size' => array( 'typography', 'fontSize' ), + 'background' => array( 'color', 'gradient' ), + 'background-color' => array( 'color', 'background' ), + 'color' => array( 'color', 'text' ), + ); + + $result = array(); + + foreach ( $mappings as $key => $path ) { + $value = gutenberg_experimental_get( $styles, $path ); + if ( null !== $value ) { + $result[ $key ] = $value; + } + } + return $result; + +} + /** * Takes a tree adhering to the theme.json schema and generates * the corresponding stylesheet. @@ -352,7 +381,10 @@ function gutenberg_experimental_global_styles_resolver( $tree ) { $stylesheet .= gutenberg_experimental_global_styles_resolver_styles( $block_data[ $block_name ]['selector'], $block_data[ $block_name ]['supports'], - array_merge( $tree[ $block_name ]['styles'], $css_variables ) + array_merge( + gutenberg_experimental_global_styles_flatten_styles_tree( $tree[ $block_name ]['styles'] ), + $css_variables + ) ); } return $stylesheet; diff --git a/lib/load.php b/lib/load.php index 5e159089df4ab5..4d98bd38b2b37a 100644 --- a/lib/load.php +++ b/lib/load.php @@ -79,6 +79,7 @@ function gutenberg_is_experiment_enabled( $name ) { } require dirname( __FILE__ ) . '/compat.php'; +require dirname( __FILE__ ) . '/utils.php'; require dirname( __FILE__ ) . '/blocks.php'; require dirname( __FILE__ ) . '/templates.php'; diff --git a/lib/utils.php b/lib/utils.php new file mode 100644 index 00000000000000..f6a503234d0a13 --- /dev/null +++ b/lib/utils.php @@ -0,0 +1,27 @@ +