' . $attributes['moreText'] . '' : '';
-
- $filter_excerpt_length = function() use ( $attributes ) {
- return isset( $attributes['wordCount'] ) ? $attributes['wordCount'] : 55;
+ $more_text = ! empty( $attributes['moreText'] ) ? '' . $attributes['moreText'] . '' : '';
+ $filter_excerpt_more = function( $more ) use ( $more_text ) {
+ return empty( $more_text ) ? $more : '';
};
- add_filter(
- 'excerpt_length',
- $filter_excerpt_length
- );
-
+ /**
+ * Some themes might use `excerpt_more` filter to handle the
+ * `more` link displayed after a trimmed excerpt. Since the
+ * block has a `more text` attribute we have to check and
+ * override if needed the return value from this filter.
+ * So if the block's attribute is not empty override the
+ * `excerpt_more` filter and return nothing. This will
+ * result in showing only one `read more` link at a time.
+ */
+ add_filter( 'excerpt_more', $filter_excerpt_more );
$classes = '';
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 ) );
- $content = '' . get_the_excerpt( $block->context['postId'] );
- if ( ! isset( $attributes['showMoreOnNewLine'] ) || $attributes['showMoreOnNewLine'] ) {
+ $content = '
' . get_the_excerpt( $block->context['postId'] );
+ $show_more_on_new_line = ! isset( $attributes['showMoreOnNewLine'] ) || $attributes['showMoreOnNewLine'];
+ if ( $show_more_on_new_line && ! empty( $more_text ) ) {
$content .= '
' . $more_text . '
';
} else {
$content .= " $more_text";
}
-
- remove_filter(
- 'excerpt_length',
- $filter_excerpt_length
- );
-
+ remove_filter( 'excerpt_more', $filter_excerpt_more );
return sprintf( '%2$s
', $wrapper_attributes, $content );
}
diff --git a/packages/e2e-tests/fixtures/blocks/core__post-excerpt.json b/packages/e2e-tests/fixtures/blocks/core__post-excerpt.json
index 57d658a4423d05..4378d6e27b6071 100644
--- a/packages/e2e-tests/fixtures/blocks/core__post-excerpt.json
+++ b/packages/e2e-tests/fixtures/blocks/core__post-excerpt.json
@@ -4,7 +4,6 @@
"name": "core/post-excerpt",
"isValid": true,
"attributes": {
- "wordCount": 55,
"showMoreOnNewLine": true
},
"innerBlocks": [],