From 59277f109b895ab28070d132dfd5c1001c906ea2 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Andr=C3=A9s?= Date: Tue, 7 Apr 2020 13:31:48 +0200 Subject: [PATCH] Take block selector from block.json --- experimental-default-global-styles.json | 1 - lib/global-styles.php | 31 ++++++++++++++----- .../block-library/src/paragraph/block.json | 1 + 3 files changed, 24 insertions(+), 9 deletions(-) diff --git a/experimental-default-global-styles.json b/experimental-default-global-styles.json index a133af0de0ea4..e6c72e4881186 100644 --- a/experimental-default-global-styles.json +++ b/experimental-default-global-styles.json @@ -1,7 +1,6 @@ { "core": { "color": { - "primary": "#52accc", "background": "white", "text": "black" } diff --git a/lib/global-styles.php b/lib/global-styles.php index d388fff10e549..1fd76c196e202 100644 --- a/lib/global-styles.php +++ b/lib/global-styles.php @@ -173,14 +173,29 @@ function gutenberg_experimental_global_styles_get_theme() { function gutenberg_experimental_global_styles_resolver( $global_styles ) { $css_rules = ''; - // This is only for demo purposes, it should be pluggable - // so new selectors can be register - // (3rd party blocks, custom selectors, etc). - $selectors = array( - 'core' => ':root', - 'core/paragraph' => '.wp-site-blocks p', - 'custom/paragraph-in-quote' => '.wp-site-blocks .wp-block-quote p', - ); + $selectors = array( 'core' => ':root' ); + + // We need to provide a mechanism for blocks to opt-in into this + // that can be used by 3rd party blocks as well. + // This list is an interim approach to avoid the performance cost of + // having to detect support by reading all core block's block.json. + $blocks_supported = [ + 'paragraph', + ]; + // The block library dir may not exist if working from a fresh clone => bail out early. + $block_library_dir = dirname( __FILE__ ) . '/../build/block-library/blocks/'; + if ( file_exists( $block_library_dir ) ) { + foreach( $blocks_supported as $block_dir ) { + $block_json_file = $block_library_dir . $block_dir . '/block.json'; + if ( file_exists( $block_json_file ) ) { + $block_json = json_decode( file_get_contents( $block_json_file ), true ); + if ( $block_json['selector'] ) { + $selectors[ $block_json['name'] ] = $block_json['selector']; + } + } + } + } + foreach ( $global_styles as $blockname => $subtree ) { $token = '--'; $prefix = '--wp' . $token; diff --git a/packages/block-library/src/paragraph/block.json b/packages/block-library/src/paragraph/block.json index acd5e48f0f63e..70ee110d9a7e2 100644 --- a/packages/block-library/src/paragraph/block.json +++ b/packages/block-library/src/paragraph/block.json @@ -1,6 +1,7 @@ { "name": "core/paragraph", "category": "common", + "selector": "p", "attributes": { "align": { "type": "string"