-
Notifications
You must be signed in to change notification settings - Fork 4.3k
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Add: Global styles css variables generation mechanism
- Loading branch information
1 parent
b42cde3
commit be1ddec
Showing
4 changed files
with
140 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,9 @@ | ||
{ | ||
"global": { | ||
"color": { | ||
"primary": "#52accc", | ||
"background": "white", | ||
"text": "black" | ||
} | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,126 @@ | ||
<?php | ||
/** | ||
* Global styles functions, filters and actions, etc. | ||
* | ||
* @package gutenberg | ||
*/ | ||
|
||
/** | ||
* Function that given a branch of the global styles object recursively generates | ||
* an array defining all the css vars that the global styles object represents. | ||
* | ||
* @param array $global_styles_branch Array repreeting a brach of the global styles object. | ||
* @param string $prefix Prefix to append to each variable. | ||
* @return array An array whose keys are css variable names and whose values are the css variables value. | ||
*/ | ||
function gutenberg_get_css_vars( $global_styles_branch, $prefix = '' ) { | ||
$result = array(); | ||
foreach ( $global_styles_branch as $key => $value ) { | ||
$processed_key = str_replace( '/', '-', $key ); | ||
$new_key = ( $prefix ? $prefix . '-' : '' ) . $processed_key; | ||
|
||
if ( is_array( $value ) ) { | ||
$result = array_merge( | ||
$result, | ||
gutenberg_get_css_vars( $value, $new_key ) | ||
); | ||
} else { | ||
$result[ $new_key ] = $value; | ||
} | ||
} | ||
return $result; | ||
} | ||
|
||
/** | ||
* Function responsible for enqueuing the style that define the global styles css variables. | ||
*/ | ||
function gutenberg_enqueue_global_styles_assets() { | ||
$default_global_styles_path = dirname( dirname( __FILE__ ) ) . '/default-global-styles.json'; | ||
$default_global_styles = null; | ||
|
||
if ( file_exists( $default_global_styles_path ) ) { | ||
$default_global_styles = json_decode( | ||
file_get_contents( $default_global_styles_path ), | ||
true | ||
); | ||
} | ||
|
||
$theme_json_path = locate_template( 'theme.json' ); | ||
$theme_json_global_styles = null; | ||
if ( $theme_json_path ) { | ||
$theme_json_global_styles = json_decode( | ||
file_get_contents( $theme_json_path ), | ||
true | ||
); | ||
} | ||
|
||
// To-do: Load user customizations from a CPT. | ||
$css_vars = array(); | ||
foreach ( | ||
array( | ||
$default_global_styles, | ||
$theme_json_global_styles, | ||
) as $global_styles_definition | ||
) { | ||
if ( ! $global_styles_definition ) { | ||
continue; | ||
} | ||
if ( isset( $global_styles_definition['global'] ) ) { | ||
$css_vars = array_merge( | ||
$css_vars, | ||
gutenberg_get_css_vars( $global_styles_definition['global'], '--wp-gs' ) | ||
); | ||
} | ||
if ( isset( $global_styles_definition['blocks'] ) ) { | ||
$css_vars = array_merge( | ||
$css_vars, | ||
gutenberg_get_css_vars( $global_styles_definition['blocks'], '--wp-gs' ) | ||
); | ||
} | ||
} | ||
|
||
if ( empty( $css_vars ) ) { | ||
return; | ||
} | ||
|
||
$inline_style = ":root {\n"; | ||
foreach ( $css_vars as $var => $value ) { | ||
$inline_style .= "\t" . $var . ': ' . $value . ";\n"; | ||
} | ||
$inline_style .= '}'; | ||
|
||
wp_register_style( 'global-styles', false, array(), true, true ); | ||
wp_add_inline_style( 'global-styles', $inline_style ); | ||
wp_enqueue_style( 'global-styles' ); | ||
} | ||
add_action( 'enqueue_block_assets', 'gutenberg_enqueue_global_styles_assets' ); | ||
|
||
/** | ||
* Adds class wp-gs to the frontend body class if the theme defines a theme.json. | ||
* | ||
* @param array $classes Existing body classes. | ||
* @return array The filtered array of body classes. | ||
*/ | ||
function gutenberg_add_wp_gs_class_front_end( $classes ) { | ||
if ( locate_template( 'theme.json' ) ) { | ||
return array_merge( $classes, array( 'wp-gs' ) ); | ||
} | ||
return $classes; | ||
} | ||
add_filter( 'body_class', 'gutenberg_add_wp_gs_class_front_end' ); | ||
|
||
|
||
/** | ||
* Adds class wp-gs to the block-editor body class if the theme defines a theme.json. | ||
* | ||
* @param string $classes Existing body classes separated by space. | ||
* @return string The filtered string of body classes. | ||
*/ | ||
function gutenberg_add_wp_gs_class_editor( $classes ) { | ||
global $current_screen; | ||
if ( $current_screen->is_block_editor() && locate_template( 'theme.json' ) ) { | ||
return $classes . ' wp-gs'; | ||
} | ||
return $classes; | ||
} | ||
add_filter( 'admin_body_class', 'gutenberg_add_wp_gs_class_editor' ); |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters