render_block_core_latest_posts( array $attributes )
Renders the core/latest-posts
block on server.
Description Description
Parameters Parameters
- $attributes
-
(array) (Required) The block attributes.
Return Return
(string) Returns the post content with latest posts added.
Source Source
File: wp-includes/blocks/latest-posts.php
function render_block_core_latest_posts( $attributes ) { $args = array( 'numberposts' => $attributes['postsToShow'], 'post_status' => 'publish', 'order' => $attributes['order'], 'orderby' => $attributes['orderBy'], ); if ( isset( $attributes['categories'] ) ) { $args['category'] = $attributes['categories']; } $recent_posts = wp_get_recent_posts( $args ); $list_items_markup = ''; foreach ( $recent_posts as $post ) { $post_id = $post['ID']; $title = get_the_title( $post_id ); if ( ! $title ) { $title = __( '(Untitled)' ); } $list_items_markup .= sprintf( '<li><a href="%1$s">%2$s</a>', esc_url( get_permalink( $post_id ) ), esc_html( $title ) ); if ( isset( $attributes['displayPostDate'] ) && $attributes['displayPostDate'] ) { $list_items_markup .= sprintf( '<time datetime="%1$s" class="wp-block-latest-posts__post-date">%2$s</time>', esc_attr( get_the_date( 'c', $post_id ) ), esc_html( get_the_date( '', $post_id ) ) ); } $list_items_markup .= "</li>\n"; } $class = 'wp-block-latest-posts'; if ( isset( $attributes['align'] ) ) { $class .= ' align' . $attributes['align']; } if ( isset( $attributes['postLayout'] ) && 'grid' === $attributes['postLayout'] ) { $class .= ' is-grid'; } if ( isset( $attributes['columns'] ) && 'grid' === $attributes['postLayout'] ) { $class .= ' columns-' . $attributes['columns']; } if ( isset( $attributes['displayPostDate'] ) && $attributes['displayPostDate'] ) { $class .= ' has-dates'; } if ( isset( $attributes['className'] ) ) { $class .= ' ' . $attributes['className']; } $block_content = sprintf( '<ul class="%1$s">%2$s</ul>', esc_attr( $class ), $list_items_markup ); return $block_content; }
Expand full source code Collapse full source code View on Trac