mirror of
git://develop.git.wordpress.org/
synced 2025-04-04 20:23:27 +02:00
Editor: Update WordPress packages for 6.0 RC 2.
[53377] Included cherry-picked commits from the Gutenberg plugin that fix bugs discovered after WordPress 6.0 RC 1. [53378] Includes cherry-picked commit from the Gutenberg plugin that fix a bug discovered just before WordPress 6.0 RC 2. Props zieladam, ndiego, kebbet, hellofromTonya. Merges [53377] and [53378] to the 6.0 branch. Fixes #55567. git-svn-id: https://develop.svn.wordpress.org/branches/6.0@53381 602fd350-edb4-49c9-b593-d223f7449a82
This commit is contained in:
parent
d0501c4d19
commit
a3a14a5073
@ -1248,7 +1248,7 @@ module.exports = function(grunt) {
|
||||
grunt.task.run( 'wp-packages:refresh-deps' );
|
||||
|
||||
// Build the files stored in the src/ directory.
|
||||
grunt.task.run( 'build:dev' );
|
||||
grunt.task.run( 'build' );
|
||||
} );
|
||||
|
||||
grunt.renameTask( 'watch', '_watch' );
|
||||
|
847
package-lock.json
generated
847
package-lock.json
generated
File diff suppressed because it is too large
Load Diff
26
package.json
26
package.json
@ -81,33 +81,33 @@
|
||||
"@wordpress/api-fetch": "6.3.1",
|
||||
"@wordpress/autop": "3.6.1",
|
||||
"@wordpress/blob": "3.6.1",
|
||||
"@wordpress/block-directory": "3.4.6",
|
||||
"@wordpress/block-editor": "8.5.5",
|
||||
"@wordpress/block-library": "7.3.6",
|
||||
"@wordpress/block-directory": "3.4.9",
|
||||
"@wordpress/block-editor": "8.5.6",
|
||||
"@wordpress/block-library": "7.3.9",
|
||||
"@wordpress/block-serialization-default-parser": "4.6.1",
|
||||
"@wordpress/blocks": "11.5.3",
|
||||
"@wordpress/components": "19.8.4",
|
||||
"@wordpress/compose": "5.4.1",
|
||||
"@wordpress/core-data": "4.4.5",
|
||||
"@wordpress/customize-widgets": "3.3.6",
|
||||
"@wordpress/customize-widgets": "3.3.9",
|
||||
"@wordpress/data": "6.6.1",
|
||||
"@wordpress/data-controls": "2.6.1",
|
||||
"@wordpress/date": "4.6.1",
|
||||
"@wordpress/deprecated": "3.6.1",
|
||||
"@wordpress/dom": "3.6.1",
|
||||
"@wordpress/dom-ready": "3.6.1",
|
||||
"@wordpress/edit-post": "6.3.6",
|
||||
"@wordpress/edit-site": "4.3.6",
|
||||
"@wordpress/edit-widgets": "4.3.6",
|
||||
"@wordpress/editor": "12.5.5",
|
||||
"@wordpress/edit-post": "6.3.9",
|
||||
"@wordpress/edit-site": "4.3.9",
|
||||
"@wordpress/edit-widgets": "4.3.9",
|
||||
"@wordpress/editor": "12.5.6",
|
||||
"@wordpress/element": "4.4.1",
|
||||
"@wordpress/escape-html": "2.6.1",
|
||||
"@wordpress/format-library": "3.4.5",
|
||||
"@wordpress/format-library": "3.4.6",
|
||||
"@wordpress/hooks": "3.6.1",
|
||||
"@wordpress/html-entities": "3.6.1",
|
||||
"@wordpress/i18n": "4.6.1",
|
||||
"@wordpress/icons": "8.2.2",
|
||||
"@wordpress/interface": "4.5.4",
|
||||
"@wordpress/interface": "4.5.5",
|
||||
"@wordpress/is-shallow-equal": "4.6.1",
|
||||
"@wordpress/keyboard-shortcuts": "3.4.1",
|
||||
"@wordpress/keycodes": "3.6.1",
|
||||
@ -120,7 +120,7 @@
|
||||
"@wordpress/primitives": "3.4.1",
|
||||
"@wordpress/priority-queue": "2.6.1",
|
||||
"@wordpress/redux-routine": "4.6.1",
|
||||
"@wordpress/reusable-blocks": "3.4.5",
|
||||
"@wordpress/reusable-blocks": "3.4.6",
|
||||
"@wordpress/rich-text": "5.4.2",
|
||||
"@wordpress/server-side-render": "3.4.5",
|
||||
"@wordpress/shortcode": "3.6.1",
|
||||
@ -129,7 +129,7 @@
|
||||
"@wordpress/url": "3.7.1",
|
||||
"@wordpress/viewport": "4.4.1",
|
||||
"@wordpress/warning": "2.6.1",
|
||||
"@wordpress/widgets": "2.4.5",
|
||||
"@wordpress/widgets": "2.4.6",
|
||||
"@wordpress/wordcount": "3.6.1",
|
||||
"backbone": "1.4.1",
|
||||
"clipboard": "2.0.10",
|
||||
@ -175,6 +175,6 @@
|
||||
"test:php": "node ./tools/local-env/scripts/docker.js run -T php composer update -W && node ./tools/local-env/scripts/docker.js run php ./vendor/bin/phpunit",
|
||||
"test:e2e": "node ./tests/e2e/run-tests.js",
|
||||
"test:visual": "node ./tests/visual-regression/run-tests.js",
|
||||
"sync-gutenberg-packages": "grunt sync-gutenberg-packages"
|
||||
"sync-gutenberg-packages": "grunt sync-gutenberg-packages --dev"
|
||||
}
|
||||
}
|
||||
|
File diff suppressed because one or more lines are too long
@ -22,9 +22,10 @@ function render_block_core_comments_title( $attributes ) {
|
||||
$show_post_title = ! empty( $attributes['showPostTitle'] ) && $attributes['showPostTitle'];
|
||||
$show_comments_count = ! empty( $attributes['showCommentsCount'] ) && $attributes['showCommentsCount'];
|
||||
$wrapper_attributes = get_block_wrapper_attributes( array( 'class' => $align_class_name ) );
|
||||
$post_title = $show_post_title ? sprintf( '"%1$s"', get_the_title() ) : null;
|
||||
$comments_count = number_format_i18n( get_comments_number() );
|
||||
$tag_name = 'h2';
|
||||
$comments_count = get_comments_number();
|
||||
/* translators: %s: Post title. */
|
||||
$post_title = sprintf( __( '“%s”' ), get_the_title() );
|
||||
$tag_name = 'h2';
|
||||
if ( isset( $attributes['level'] ) ) {
|
||||
$tag_name = 'h' . $attributes['level'];
|
||||
}
|
||||
@ -33,28 +34,45 @@ function render_block_core_comments_title( $attributes ) {
|
||||
return;
|
||||
}
|
||||
|
||||
$single_default_comment_label = $show_post_title ? __( 'Response to' ) : __( 'Response' );
|
||||
if ( $show_comments_count ) {
|
||||
$single_default_comment_label = $show_post_title ? __( 'One response to' ) : __( 'One response' );
|
||||
if ( $show_post_title ) {
|
||||
if ( '1' === $comments_count ) {
|
||||
/* translators: %s: Post title. */
|
||||
$comments_title = sprintf( __( 'One response to %s' ), $post_title );
|
||||
} else {
|
||||
$comments_title = sprintf(
|
||||
/* translators: 1: Number of comments, 2: Post title. */
|
||||
_n(
|
||||
'%1$s response to %2$s',
|
||||
'%1$s responses to %2$s',
|
||||
$comments_count
|
||||
),
|
||||
number_format_i18n( $comments_count ),
|
||||
$post_title
|
||||
);
|
||||
}
|
||||
} elseif ( '1' === $comments_count ) {
|
||||
$comments_title = __( 'One response' );
|
||||
} else {
|
||||
$comments_title = sprintf(
|
||||
/* translators: %s: Number of comments. */
|
||||
_n( '%s responses', '%s responses', $comments_count ),
|
||||
number_format_i18n( $comments_count )
|
||||
);
|
||||
}
|
||||
} elseif ( $show_post_title ) {
|
||||
if ( '1' === $comments_count ) {
|
||||
/* translators: %s: Post title. */
|
||||
$comments_title = sprintf( __( 'Response to %s' ), $post_title );
|
||||
} else {
|
||||
/* translators: %s: Post title. */
|
||||
$comments_title = sprintf( __( 'Responses to %s' ), $post_title );
|
||||
}
|
||||
} elseif ( '1' === $comments_count ) {
|
||||
$comments_title = __( 'Response' );
|
||||
} else {
|
||||
$comments_title = __( 'Responses' );
|
||||
}
|
||||
$single_comment_label = ! empty( $attributes['singleCommentLabel'] ) ? $attributes['singleCommentLabel'] : $single_default_comment_label;
|
||||
|
||||
$multiple_default_comment_label = $show_post_title ? __( 'Responses to' ) : __( 'Responses' );
|
||||
if ( $show_comments_count ) {
|
||||
$multiple_default_comment_label = $show_post_title ? __( 'responses to' ) : __( 'responses' );
|
||||
}
|
||||
|
||||
$multiple_comment_label = ! empty( $attributes['multipleCommentsLabel'] ) ? $attributes['multipleCommentsLabel'] : $multiple_default_comment_label;
|
||||
|
||||
$comments_title = '%1$s %2$s %3$s';
|
||||
|
||||
$comments_title = sprintf(
|
||||
$comments_title,
|
||||
// If there is only one comment, only display the label.
|
||||
'1' !== $comments_count && $show_comments_count ? $comments_count : null,
|
||||
'1' === $comments_count ? $single_comment_label : $multiple_comment_label,
|
||||
$post_title
|
||||
);
|
||||
|
||||
return sprintf(
|
||||
'<%1$s id="comments" %2$s>%3$s</%1$s>',
|
||||
|
@ -12,12 +12,6 @@
|
||||
"textAlign": {
|
||||
"type": "string"
|
||||
},
|
||||
"singleCommentLabel": {
|
||||
"type": "string"
|
||||
},
|
||||
"multipleCommentsLabel": {
|
||||
"type": "string"
|
||||
},
|
||||
"showPostTitle": {
|
||||
"type": "boolean",
|
||||
"default": true
|
||||
|
@ -14,51 +14,23 @@
|
||||
* @return string Returns the cover block markup, if useFeaturedImage is true.
|
||||
*/
|
||||
function render_block_core_cover( $attributes, $content ) {
|
||||
if ( false === $attributes['useFeaturedImage'] ) {
|
||||
if ( 'image' !== $attributes['backgroundType'] || false === $attributes['useFeaturedImage'] ) {
|
||||
return $content;
|
||||
}
|
||||
|
||||
$current_featured_image = get_the_post_thumbnail_url();
|
||||
|
||||
if ( false === $current_featured_image ) {
|
||||
return $content;
|
||||
}
|
||||
|
||||
$is_img_element = ! ( $attributes['hasParallax'] || $attributes['isRepeated'] );
|
||||
$is_image_background = 'image' === $attributes['backgroundType'];
|
||||
|
||||
if ( $is_image_background && ! $is_img_element ) {
|
||||
$content = preg_replace(
|
||||
'/class=\".*?\"/',
|
||||
'${0} style="background-image:url(' . esc_url( $current_featured_image ) . ')"',
|
||||
$content,
|
||||
1
|
||||
if ( ! ( $attributes['hasParallax'] || $attributes['isRepeated'] ) ) {
|
||||
$attr = array(
|
||||
'class' => 'wp-block-cover__image-background',
|
||||
'data-object-fit' => 'cover',
|
||||
);
|
||||
}
|
||||
|
||||
if ( $is_image_background && $is_img_element ) {
|
||||
$object_position = '';
|
||||
if ( isset( $attributes['focalPoint'] ) ) {
|
||||
$object_position = round( $attributes['focalPoint']['x'] * 100 ) . '%' . ' ' .
|
||||
round( $attributes['focalPoint']['y'] * 100 ) . '%';
|
||||
$object_position = round( $attributes['focalPoint']['x'] * 100 ) . '%' . ' ' . round( $attributes['focalPoint']['y'] * 100 ) . '%';
|
||||
$attr['data-object-position'] = $object_position;
|
||||
$attr['style'] = 'object-position: ' . $object_position;
|
||||
}
|
||||
|
||||
$image_template = '<img
|
||||
class="wp-block-cover__image-background"
|
||||
alt="%s"
|
||||
src="%s"
|
||||
style="object-position: %s"
|
||||
data-object-fit="cover"
|
||||
data-object-position="%s"
|
||||
/>';
|
||||
|
||||
$image = sprintf(
|
||||
$image_template,
|
||||
esc_attr( get_the_post_thumbnail_caption() ),
|
||||
esc_url( $current_featured_image ),
|
||||
esc_attr( $object_position ),
|
||||
esc_attr( $object_position )
|
||||
);
|
||||
$image = get_the_post_thumbnail( null, 'post-thumbnail', $attr );
|
||||
|
||||
$content = str_replace(
|
||||
'</span><div',
|
||||
@ -66,6 +38,17 @@ function render_block_core_cover( $attributes, $content ) {
|
||||
$content
|
||||
);
|
||||
|
||||
} else {
|
||||
if ( in_the_loop() ) {
|
||||
update_post_thumbnail_cache();
|
||||
}
|
||||
$current_featured_image = get_the_post_thumbnail_url();
|
||||
$content = preg_replace(
|
||||
'/class=\".*?\"/',
|
||||
'${0} style="background-image:url(' . esc_url( $current_featured_image ) . ')"',
|
||||
$content,
|
||||
1
|
||||
);
|
||||
}
|
||||
|
||||
return $content;
|
||||
|
@ -37,11 +37,12 @@ function render_block_core_latest_posts( $attributes ) {
|
||||
global $post, $block_core_latest_posts_excerpt_length;
|
||||
|
||||
$args = array(
|
||||
'posts_per_page' => $attributes['postsToShow'],
|
||||
'post_status' => 'publish',
|
||||
'order' => $attributes['order'],
|
||||
'orderby' => $attributes['orderBy'],
|
||||
'suppress_filters' => false,
|
||||
'posts_per_page' => $attributes['postsToShow'],
|
||||
'post_status' => 'publish',
|
||||
'order' => $attributes['order'],
|
||||
'orderby' => $attributes['orderBy'],
|
||||
'ignore_sticky_posts' => true,
|
||||
'no_found_rows' => true,
|
||||
);
|
||||
|
||||
$block_core_latest_posts_excerpt_length = $attributes['excerptLength'];
|
||||
@ -54,7 +55,12 @@ function render_block_core_latest_posts( $attributes ) {
|
||||
$args['author'] = $attributes['selectedAuthor'];
|
||||
}
|
||||
|
||||
$recent_posts = get_posts( $args );
|
||||
$query = new WP_Query;
|
||||
$recent_posts = $query->query( $args );
|
||||
|
||||
if ( isset( $attributes['displayFeaturedImage'] ) && $attributes['displayFeaturedImage'] ) {
|
||||
update_post_thumbnail_cache( $query );
|
||||
}
|
||||
|
||||
$list_items_markup = '';
|
||||
|
||||
|
@ -350,6 +350,41 @@ function block_core_navigation_get_fallback_blocks() {
|
||||
return apply_filters( 'block_core_navigation_render_fallback', $fallback_blocks );
|
||||
}
|
||||
|
||||
/**
|
||||
* Iterate through all inner blocks recursively and get navigation link block's post IDs.
|
||||
*
|
||||
* @param WP_Block_List $inner_blocks Block list class instance.
|
||||
*
|
||||
* @return array Array of post IDs.
|
||||
*/
|
||||
function block_core_navigation_get_post_ids( $inner_blocks ) {
|
||||
$post_ids = array_map( 'block_core_navigation_from_block_get_post_ids', iterator_to_array( $inner_blocks ) );
|
||||
return array_unique( array_merge( ...$post_ids ) );
|
||||
}
|
||||
|
||||
/**
|
||||
* Get post IDs from a navigation link block instance.
|
||||
*
|
||||
* @param WP_Block $block Instance of a block.
|
||||
*
|
||||
* @return array Array of post IDs.
|
||||
*/
|
||||
function block_core_navigation_from_block_get_post_ids( $block ) {
|
||||
$post_ids = array();
|
||||
|
||||
if ( $block->inner_blocks ) {
|
||||
$post_ids = block_core_navigation_get_post_ids( $block->inner_blocks );
|
||||
}
|
||||
|
||||
if ( 'core/navigation-link' === $block->name || 'core/navigation-submenu' === $block->name ) {
|
||||
if ( $block->attributes && isset( $block->attributes['kind'] ) && 'post-type' === $block->attributes['kind'] ) {
|
||||
$post_ids[] = $block->attributes['id'];
|
||||
}
|
||||
}
|
||||
|
||||
return $post_ids;
|
||||
}
|
||||
|
||||
/**
|
||||
* Renders the `core/navigation` block on server.
|
||||
*
|
||||
@ -501,6 +536,11 @@ function render_block_core_navigation( $attributes, $content, $block ) {
|
||||
$text_decoration ? array( $text_decoration_class ) : array()
|
||||
);
|
||||
|
||||
$post_ids = block_core_navigation_get_post_ids( $inner_blocks );
|
||||
if ( $post_ids ) {
|
||||
_prime_post_caches( $post_ids, false, false );
|
||||
}
|
||||
|
||||
$inner_blocks_html = '';
|
||||
$is_list_open = false;
|
||||
foreach ( $inner_blocks as $inner_block ) {
|
||||
|
@ -39,7 +39,7 @@ function render_block_core_post_author( $attributes, $content, $block ) {
|
||||
return sprintf( '<div %1$s>', $wrapper_attributes ) .
|
||||
( ! empty( $attributes['showAvatar'] ) ? '<div class="wp-block-post-author__avatar">' . $avatar . '</div>' : '' ) .
|
||||
'<div class="wp-block-post-author__content">' .
|
||||
( ! empty( $byline ) ? '<p class="wp-block-post-author__byline">' . esc_html( $byline ) . '</p>' : '' ) .
|
||||
( ! empty( $byline ) ? '<p class="wp-block-post-author__byline">' . wp_kses_post( $byline ) . '</p>' : '' ) .
|
||||
'<p class="wp-block-post-author__name">' . get_the_author_meta( 'display_name', $author_id ) . '</p>' .
|
||||
( ! empty( $attributes['showBio'] ) ? '<p class="wp-block-post-author__bio">' . get_the_author_meta( 'user_description', $author_id ) . '</p>' : '' ) .
|
||||
'</div>' .
|
||||
|
@ -24,7 +24,7 @@ function render_block_core_post_comments_form( $attributes, $content, $block ) {
|
||||
|
||||
$classes = 'comment-respond'; // See comment further below.
|
||||
if ( isset( $attributes['textAlign'] ) ) {
|
||||
$classes .= 'has-text-align-' . $attributes['textAlign'];
|
||||
$classes .= ' has-text-align-' . $attributes['textAlign'];
|
||||
}
|
||||
|
||||
$wrapper_attributes = get_block_wrapper_attributes( array( 'class' => $classes ) );
|
||||
|
@ -5,6 +5,32 @@
|
||||
* @package WordPress
|
||||
*/
|
||||
|
||||
/**
|
||||
* Determines whether a block list contains a block that uses the featured image.
|
||||
*
|
||||
* @param WP_Block_List $inner_blocks Inner block instance.
|
||||
*
|
||||
* @return bool Whether the block list contains a block that uses the featured image.
|
||||
*/
|
||||
function block_core_post_template_uses_featured_image( $inner_blocks ) {
|
||||
foreach ( $inner_blocks as $block ) {
|
||||
if ( 'core/post-featured-image' === $block->name ) {
|
||||
return true;
|
||||
}
|
||||
if (
|
||||
'core/cover' === $block->name &&
|
||||
! empty( $block->attributes['useFeaturedImage'] )
|
||||
) {
|
||||
return true;
|
||||
}
|
||||
if ( $block->inner_blocks && block_core_post_template_uses_featured_image( $block->inner_blocks ) ) {
|
||||
return true;
|
||||
}
|
||||
}
|
||||
|
||||
return false;
|
||||
}
|
||||
|
||||
/**
|
||||
* Renders the `core/post-template` block on the server.
|
||||
*
|
||||
@ -40,6 +66,10 @@ function render_block_core_post_template( $attributes, $content, $block ) {
|
||||
return '';
|
||||
}
|
||||
|
||||
if ( block_core_post_template_uses_featured_image( $block->inner_blocks ) ) {
|
||||
update_post_thumbnail_cache( $query );
|
||||
}
|
||||
|
||||
$classnames = '';
|
||||
if ( isset( $block->context['displayLayout'] ) && isset( $block->context['query'] ) ) {
|
||||
if ( isset( $block->context['displayLayout']['type'] ) && 'flex' === $block->context['displayLayout']['type'] ) {
|
||||
|
Loading…
x
Reference in New Issue
Block a user