From 7e7b3b88e0017d47e7ce2d319135d9139a87bd9d Mon Sep 17 00:00:00 2001 From: Dennis Snell Date: Fri, 16 Dec 2022 13:46:22 -0700 Subject: [PATCH] Replace usage in block supports elements too --- lib/block-supports/elements.php | 25 +++++-------------------- 1 file changed, 5 insertions(+), 20 deletions(-) diff --git a/lib/block-supports/elements.php b/lib/block-supports/elements.php index 0b6e31db3d66d..f55f087b0be82 100644 --- a/lib/block-supports/elements.php +++ b/lib/block-supports/elements.php @@ -49,29 +49,14 @@ function gutenberg_render_elements_support( $block_content, $block ) { return $block_content; } - $class_name = gutenberg_get_elements_class_name( $block ); - // Like the layout hook this assumes the hook only applies to blocks with a single wrapper. - // Retrieve the opening tag of the first HTML element. - $html_element_matches = array(); - preg_match( '/<[^>]+>/', $block_content, $html_element_matches, PREG_OFFSET_CAPTURE ); - $first_element = $html_element_matches[0][0]; - // If the first HTML element has a class attribute just add the new class - // as we do on layout and duotone. - if ( str_contains( $first_element, 'class="' ) ) { - $content = preg_replace( - '/' . preg_quote( 'class="', '/' ) . '/', - 'class="' . $class_name . ' ', - $block_content, - 1 - ); - } else { - // If the first HTML element has no class attribute we should inject the attribute before the attribute at the end. - $first_element_offset = $html_element_matches[0][1]; - $content = substr_replace( $block_content, ' class="' . $class_name . '"', $first_element_offset + strlen( $first_element ) - 1, 0 ); + // Add the class name to the first element, presuming it's the wrapper, if it exists. + $tags = new WP_HTML_Tag_Processor( $block_content ); + if ( $tags->next_tag() ) { + $tags->add_class( gutenberg_get_elements_class_name( $block ) ); } - return $content; + return $tags->get_updated_html(); } /**