Block editor: Add ID support to block wrapper attributes.
This commit adds support for the ID attribute for dynamically rendered blocks. Props Soean, flixos90, poena, costdev, Mamaduka. Closes #56852. Built from https://develop.svn.wordpress.org/trunk@55230 git-svn-id: http://core.svn.wordpress.org/trunk@54763 1a063a9b-81f0-0310-95a4-ce76da25c4cd
This commit is contained in:
parent
ba4ed5f86c
commit
f6cb5218c1
|
@ -0,0 +1,73 @@
|
||||||
|
<?php
|
||||||
|
/**
|
||||||
|
* Anchor block support flag.
|
||||||
|
*
|
||||||
|
* @package WordPress
|
||||||
|
* @since 6.2.0
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Registers the anchor block attribute for block types that support it.
|
||||||
|
*
|
||||||
|
* @since 6.2.0
|
||||||
|
* @access private
|
||||||
|
*
|
||||||
|
* @param WP_Block_Type $block_type Block Type.
|
||||||
|
*/
|
||||||
|
function wp_register_anchor_support( $block_type ) {
|
||||||
|
$has_anchor_support = _wp_array_get( $block_type->supports, array( 'anchor' ), true );
|
||||||
|
if ( ! $has_anchor_support ) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
if ( ! $block_type->attributes ) {
|
||||||
|
$block_type->attributes = array();
|
||||||
|
}
|
||||||
|
|
||||||
|
if ( ! array_key_exists( 'anchor', $block_type->attributes ) ) {
|
||||||
|
$block_type->attributes['anchor'] = array(
|
||||||
|
'type' => 'string',
|
||||||
|
);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Add the anchor to the output.
|
||||||
|
*
|
||||||
|
* @since 6.2.0
|
||||||
|
* @access private
|
||||||
|
*
|
||||||
|
* @param WP_Block_Type $block_type Block Type.
|
||||||
|
* @param array $block_attributes Block attributes.
|
||||||
|
* @return array Block anchor.
|
||||||
|
*/
|
||||||
|
function wp_apply_anchor_support( $block_type, $block_attributes ) {
|
||||||
|
if ( ! $block_attributes ) {
|
||||||
|
return array();
|
||||||
|
}
|
||||||
|
|
||||||
|
if ( wp_should_skip_block_supports_serialization( $block_type, 'anchor' ) ) {
|
||||||
|
return array();
|
||||||
|
}
|
||||||
|
|
||||||
|
$has_anchor_support = _wp_array_get( $block_type->supports, array( 'anchor' ), true );
|
||||||
|
if ( ! $has_anchor_support ) {
|
||||||
|
return array();
|
||||||
|
}
|
||||||
|
|
||||||
|
$has_anchor = array_key_exists( 'anchor', $block_attributes );
|
||||||
|
if ( ! $has_anchor ) {
|
||||||
|
return array();
|
||||||
|
}
|
||||||
|
|
||||||
|
return array( 'id' => $block_attributes['anchor'] );
|
||||||
|
}
|
||||||
|
|
||||||
|
// Register the block support.
|
||||||
|
WP_Block_Supports::get_instance()->register(
|
||||||
|
'anchor',
|
||||||
|
array(
|
||||||
|
'register_attribute' => 'wp_register_anchor_support',
|
||||||
|
'apply' => 'wp_apply_anchor_support',
|
||||||
|
)
|
||||||
|
);
|
|
@ -181,7 +181,7 @@ function get_block_wrapper_attributes( $extra_attributes = array() ) {
|
||||||
|
|
||||||
// This is hardcoded on purpose.
|
// This is hardcoded on purpose.
|
||||||
// We only support a fixed list of attributes.
|
// We only support a fixed list of attributes.
|
||||||
$attributes_to_merge = array( 'style', 'class' );
|
$attributes_to_merge = array( 'style', 'class', 'id' );
|
||||||
$attributes = array();
|
$attributes = array();
|
||||||
foreach ( $attributes_to_merge as $attribute_name ) {
|
foreach ( $attributes_to_merge as $attribute_name ) {
|
||||||
if ( empty( $new_attributes[ $attribute_name ] ) && empty( $extra_attributes[ $attribute_name ] ) ) {
|
if ( empty( $new_attributes[ $attribute_name ] ) && empty( $extra_attributes[ $attribute_name ] ) ) {
|
||||||
|
|
|
@ -16,7 +16,7 @@
|
||||||
*
|
*
|
||||||
* @global string $wp_version
|
* @global string $wp_version
|
||||||
*/
|
*/
|
||||||
$wp_version = '6.2-alpha-55229';
|
$wp_version = '6.2-alpha-55230';
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Holds the WordPress DB revision, increments when changes are made to the WordPress DB schema.
|
* Holds the WordPress DB revision, increments when changes are made to the WordPress DB schema.
|
||||||
|
|
|
@ -327,6 +327,7 @@ require ABSPATH . WPINC . '/block-patterns.php';
|
||||||
require ABSPATH . WPINC . '/class-wp-block-supports.php';
|
require ABSPATH . WPINC . '/class-wp-block-supports.php';
|
||||||
require ABSPATH . WPINC . '/block-supports/utils.php';
|
require ABSPATH . WPINC . '/block-supports/utils.php';
|
||||||
require ABSPATH . WPINC . '/block-supports/align.php';
|
require ABSPATH . WPINC . '/block-supports/align.php';
|
||||||
|
require ABSPATH . WPINC . '/block-supports/anchor.php';
|
||||||
require ABSPATH . WPINC . '/block-supports/border.php';
|
require ABSPATH . WPINC . '/block-supports/border.php';
|
||||||
require ABSPATH . WPINC . '/block-supports/colors.php';
|
require ABSPATH . WPINC . '/block-supports/colors.php';
|
||||||
require ABSPATH . WPINC . '/block-supports/custom-classname.php';
|
require ABSPATH . WPINC . '/block-supports/custom-classname.php';
|
||||||
|
|
Loading…
Reference in New Issue