mirror of
https://github.com/WordPress/WordPress.git
synced 2024-12-22 17:18:32 +01:00
268203f8aa
Most block feature checks are for a single feature string, and for such cases it is not intuitive to require an array for the `$feature` parameter of the `block_has_support()` function. This changeset brings it in line with other functions like `post_type_supports()`, allowing to pass a string for the `$feature`. An array is still supported for more complex cases where support for sub-features needs to be determined. This change furthermore includes a very minor performance tweak by avoiding calls to the `_wp_array_get()` function if a single feature string is being checked for. Props thekt12, nihar007, mukesh27, swissspidy. Fixes #58532. Built from https://develop.svn.wordpress.org/trunk@56382 git-svn-id: http://core.svn.wordpress.org/trunk@55894 1a063a9b-81f0-0310-95a4-ce76da25c4cd
72 lines
1.7 KiB
PHP
72 lines
1.7 KiB
PHP
<?php
|
|
/**
|
|
* Generated classname block support flag.
|
|
*
|
|
* @package WordPress
|
|
* @since 5.6.0
|
|
*/
|
|
|
|
/**
|
|
* Gets the generated classname from a given block name.
|
|
*
|
|
* @since 5.6.0
|
|
*
|
|
* @access private
|
|
*
|
|
* @param string $block_name Block Name.
|
|
* @return string Generated classname.
|
|
*/
|
|
function wp_get_block_default_classname( $block_name ) {
|
|
// Generated HTML classes for blocks follow the `wp-block-{name}` nomenclature.
|
|
// Blocks provided by WordPress drop the prefixes 'core/' or 'core-' (historically used in 'core-embed/').
|
|
$classname = 'wp-block-' . preg_replace(
|
|
'/^core-/',
|
|
'',
|
|
str_replace( '/', '-', $block_name )
|
|
);
|
|
|
|
/**
|
|
* Filters the default block className for server rendered blocks.
|
|
*
|
|
* @since 5.6.0
|
|
*
|
|
* @param string $class_name The current applied classname.
|
|
* @param string $block_name The block name.
|
|
*/
|
|
$classname = apply_filters( 'block_default_classname', $classname, $block_name );
|
|
|
|
return $classname;
|
|
}
|
|
|
|
/**
|
|
* Adds the generated classnames to the output.
|
|
*
|
|
* @since 5.6.0
|
|
*
|
|
* @access private
|
|
*
|
|
* @param WP_Block_Type $block_type Block Type.
|
|
* @return array Block CSS classes and inline styles.
|
|
*/
|
|
function wp_apply_generated_classname_support( $block_type ) {
|
|
$attributes = array();
|
|
$has_generated_classname_support = block_has_support( $block_type, 'className', true );
|
|
if ( $has_generated_classname_support ) {
|
|
$block_classname = wp_get_block_default_classname( $block_type->name );
|
|
|
|
if ( $block_classname ) {
|
|
$attributes['class'] = $block_classname;
|
|
}
|
|
}
|
|
|
|
return $attributes;
|
|
}
|
|
|
|
// Register the block support.
|
|
WP_Block_Supports::get_instance()->register(
|
|
'generated-classname',
|
|
array(
|
|
'apply' => 'wp_apply_generated_classname_support',
|
|
)
|
|
);
|