[ Index ] |
PHP Cross Reference of WordPress Trunk (Updated Daily) |
[Summary view] [Print] [Text view]
1 <?php 2 /** 3 * Blocks API: WP_Block_Styles_Registry class 4 * 5 * @package WordPress 6 * @subpackage Blocks 7 * @since 5.3.0 8 */ 9 10 /** 11 * Class used for interacting with block styles. 12 * 13 * @since 5.3.0 14 */ 15 #[AllowDynamicProperties] 16 final class WP_Block_Styles_Registry { 17 /** 18 * Registered block styles, as `$block_name => $block_style_name => $block_style_properties` multidimensional arrays. 19 * 20 * @since 5.3.0 21 * 22 * @var array[] 23 */ 24 private $registered_block_styles = array(); 25 26 /** 27 * Container for the main instance of the class. 28 * 29 * @since 5.3.0 30 * 31 * @var WP_Block_Styles_Registry|null 32 */ 33 private static $instance = null; 34 35 /** 36 * Registers a block style for the given block type. 37 * 38 * If the block styles are present in a standalone stylesheet, register it and pass 39 * its handle as the `style_handle` argument. If the block styles should be inline, 40 * use the `inline_style` argument. Usually, one of them would be used to pass CSS 41 * styles. However, you could also skip them and provide CSS styles in any stylesheet 42 * or with an inline tag. 43 * 44 * @since 5.3.0 45 * @since 6.6.0 Added ability to register style across multiple block types along with theme.json-like style data. 46 * 47 * @link https://developer.wordpress.org/block-editor/reference-guides/block-api/block-styles/ 48 * 49 * @param string|string[] $block_name Block type name including namespace or array of namespaced block type names. 50 * @param array $style_properties { 51 * Array containing the properties of the style. 52 * 53 * @type string $name The identifier of the style used to compute a CSS class. 54 * @type string $label A human-readable label for the style. 55 * @type string $inline_style Inline CSS code that registers the CSS class required 56 * for the style. 57 * @type string $style_handle The handle to an already registered style that should be 58 * enqueued in places where block styles are needed. 59 * @type bool $is_default Whether this is the default style for the block type. 60 * @type array $style_data Theme.json-like object to generate CSS from. 61 * } 62 * @return bool True if the block style was registered with success and false otherwise. 63 */ 64 public function register( $block_name, $style_properties ) { 65 66 if ( ! is_string( $block_name ) && ! is_array( $block_name ) ) { 67 _doing_it_wrong( 68 __METHOD__, 69 __( 'Block name must be a string or array.' ), 70 '6.6.0' 71 ); 72 return false; 73 } 74 75 if ( ! isset( $style_properties['name'] ) || ! is_string( $style_properties['name'] ) ) { 76 _doing_it_wrong( 77 __METHOD__, 78 __( 'Block style name must be a string.' ), 79 '5.3.0' 80 ); 81 return false; 82 } 83 84 if ( str_contains( $style_properties['name'], ' ' ) ) { 85 _doing_it_wrong( 86 __METHOD__, 87 __( 'Block style name must not contain any spaces.' ), 88 '5.9.0' 89 ); 90 return false; 91 } 92 93 $block_style_name = $style_properties['name']; 94 $block_names = is_string( $block_name ) ? array( $block_name ) : $block_name; 95 96 foreach ( $block_names as $name ) { 97 if ( ! isset( $this->registered_block_styles[ $name ] ) ) { 98 $this->registered_block_styles[ $name ] = array(); 99 } 100 $this->registered_block_styles[ $name ][ $block_style_name ] = $style_properties; 101 } 102 103 return true; 104 } 105 106 /** 107 * Unregisters a block style of the given block type. 108 * 109 * @since 5.3.0 110 * 111 * @param string $block_name Block type name including namespace. 112 * @param string $block_style_name Block style name. 113 * @return bool True if the block style was unregistered with success and false otherwise. 114 */ 115 public function unregister( $block_name, $block_style_name ) { 116 if ( ! $this->is_registered( $block_name, $block_style_name ) ) { 117 _doing_it_wrong( 118 __METHOD__, 119 /* translators: 1: Block name, 2: Block style name. */ 120 sprintf( __( 'Block "%1$s" does not contain a style named "%2$s".' ), $block_name, $block_style_name ), 121 '5.3.0' 122 ); 123 return false; 124 } 125 126 unset( $this->registered_block_styles[ $block_name ][ $block_style_name ] ); 127 128 return true; 129 } 130 131 /** 132 * Retrieves the properties of a registered block style for the given block type. 133 * 134 * @since 5.3.0 135 * 136 * @param string $block_name Block type name including namespace. 137 * @param string $block_style_name Block style name. 138 * @return array Registered block style properties. 139 */ 140 public function get_registered( $block_name, $block_style_name ) { 141 if ( ! $this->is_registered( $block_name, $block_style_name ) ) { 142 return null; 143 } 144 145 return $this->registered_block_styles[ $block_name ][ $block_style_name ]; 146 } 147 148 /** 149 * Retrieves all registered block styles. 150 * 151 * @since 5.3.0 152 * 153 * @return array[] Array of arrays containing the registered block styles properties grouped by block type. 154 */ 155 public function get_all_registered() { 156 return $this->registered_block_styles; 157 } 158 159 /** 160 * Retrieves registered block styles for a specific block type. 161 * 162 * @since 5.3.0 163 * 164 * @param string $block_name Block type name including namespace. 165 * @return array[] Array whose keys are block style names and whose values are block style properties. 166 */ 167 public function get_registered_styles_for_block( $block_name ) { 168 if ( isset( $this->registered_block_styles[ $block_name ] ) ) { 169 return $this->registered_block_styles[ $block_name ]; 170 } 171 return array(); 172 } 173 174 /** 175 * Checks if a block style is registered for the given block type. 176 * 177 * @since 5.3.0 178 * 179 * @param string $block_name Block type name including namespace. 180 * @param string $block_style_name Block style name. 181 * @return bool True if the block style is registered, false otherwise. 182 */ 183 public function is_registered( $block_name, $block_style_name ) { 184 return isset( $this->registered_block_styles[ $block_name ][ $block_style_name ] ); 185 } 186 187 /** 188 * Utility method to retrieve the main instance of the class. 189 * 190 * The instance will be created if it does not exist yet. 191 * 192 * @since 5.3.0 193 * 194 * @return WP_Block_Styles_Registry The main instance. 195 */ 196 public static function get_instance() { 197 if ( null === self::$instance ) { 198 self::$instance = new self(); 199 } 200 201 return self::$instance; 202 } 203 }
title
Description
Body
title
Description
Body
title
Description
Body
title
Body
Generated : Tue Jan 21 08:20:01 2025 | Cross-referenced by PHPXref |