summaryrefslogtreecommitdiffstats
path: root/wp-includes/block-patterns
diff options
context:
space:
mode:
Diffstat (limited to '')
-rw-r--r--wp-includes/block-patterns.php400
-rw-r--r--wp-includes/block-patterns/query-grid-posts.php23
-rw-r--r--wp-includes/block-patterns/query-large-title-posts.php31
-rw-r--r--wp-includes/block-patterns/query-medium-posts.php27
-rw-r--r--wp-includes/block-patterns/query-offset-posts.php40
-rw-r--r--wp-includes/block-patterns/query-small-posts.php26
-rw-r--r--wp-includes/block-patterns/query-standard-posts.php25
-rw-r--r--wp-includes/block-patterns/social-links-shared-background-color.php18
8 files changed, 590 insertions, 0 deletions
diff --git a/wp-includes/block-patterns.php b/wp-includes/block-patterns.php
new file mode 100644
index 0000000..66bdfd6
--- /dev/null
+++ b/wp-includes/block-patterns.php
@@ -0,0 +1,400 @@
+<?php
+/**
+ * Register the block patterns and block patterns categories
+ *
+ * @package WordPress
+ * @since 5.5.0
+ */
+
+add_theme_support( 'core-block-patterns' );
+
+/**
+ * Registers the core block patterns and categories.
+ *
+ * @since 5.5.0
+ * @since 6.3.0 Added source to core block patterns.
+ * @access private
+ */
+function _register_core_block_patterns_and_categories() {
+ $should_register_core_patterns = get_theme_support( 'core-block-patterns' );
+
+ if ( $should_register_core_patterns ) {
+ $core_block_patterns = array(
+ 'query-standard-posts',
+ 'query-medium-posts',
+ 'query-small-posts',
+ 'query-grid-posts',
+ 'query-large-title-posts',
+ 'query-offset-posts',
+ 'social-links-shared-background-color',
+ );
+
+ foreach ( $core_block_patterns as $core_block_pattern ) {
+ $pattern = require __DIR__ . '/block-patterns/' . $core_block_pattern . '.php';
+ $pattern['source'] = 'core';
+ register_block_pattern( 'core/' . $core_block_pattern, $pattern );
+ }
+ }
+
+ register_block_pattern_category( 'banner', array( 'label' => _x( 'Banners', 'Block pattern category' ) ) );
+ register_block_pattern_category(
+ 'buttons',
+ array(
+ 'label' => _x( 'Buttons', 'Block pattern category' ),
+ 'description' => __( 'Patterns that contain buttons and call to actions.' ),
+ )
+ );
+ register_block_pattern_category(
+ 'columns',
+ array(
+ 'label' => _x( 'Columns', 'Block pattern category' ),
+ 'description' => __( 'Multi-column patterns with more complex layouts.' ),
+ )
+ );
+ register_block_pattern_category(
+ 'text',
+ array(
+ 'label' => _x( 'Text', 'Block pattern category' ),
+ 'description' => __( 'Patterns containing mostly text.' ),
+ )
+ );
+ register_block_pattern_category(
+ 'query',
+ array(
+ 'label' => _x( 'Posts', 'Block pattern category' ),
+ 'description' => __( 'Display your latest posts in lists, grids or other layouts.' ),
+ )
+ );
+ register_block_pattern_category(
+ 'featured',
+ array(
+ 'label' => _x( 'Featured', 'Block pattern category' ),
+ 'description' => __( 'A set of high quality curated patterns.' ),
+ )
+ );
+ register_block_pattern_category(
+ 'call-to-action',
+ array(
+ 'label' => _x( 'Call to Action', 'Block pattern category' ),
+ 'description' => __( 'Sections whose purpose is to trigger a specific action.' ),
+ )
+ );
+ register_block_pattern_category(
+ 'team',
+ array(
+ 'label' => _x( 'Team', 'Block pattern category' ),
+ 'description' => __( 'A variety of designs to display your team members.' ),
+ )
+ );
+ register_block_pattern_category(
+ 'testimonials',
+ array(
+ 'label' => _x( 'Testimonials', 'Block pattern category' ),
+ 'description' => __( 'Share reviews and feedback about your brand/business.' ),
+ )
+ );
+ register_block_pattern_category(
+ 'services',
+ array(
+ 'label' => _x( 'Services', 'Block pattern category' ),
+ 'description' => __( 'Briefly describe what your business does and how you can help.' ),
+ )
+ );
+ register_block_pattern_category(
+ 'contact',
+ array(
+ 'label' => _x( 'Contact', 'Block pattern category' ),
+ 'description' => __( 'Display your contact information.' ),
+ )
+ );
+ register_block_pattern_category(
+ 'about',
+ array(
+ 'label' => _x( 'About', 'Block pattern category' ),
+ 'description' => __( 'Introduce yourself.' ),
+ )
+ );
+ register_block_pattern_category(
+ 'portfolio',
+ array(
+ 'label' => _x( 'Portfolio', 'Block pattern category' ),
+ 'description' => __( 'Showcase your latest work.' ),
+ )
+ );
+ register_block_pattern_category(
+ 'gallery',
+ array(
+ 'label' => _x( 'Gallery', 'Block pattern category' ),
+ 'description' => __( 'Different layouts for displaying images.' ),
+ )
+ );
+ register_block_pattern_category(
+ 'media',
+ array(
+ 'label' => _x( 'Media', 'Block pattern category' ),
+ 'description' => __( 'Different layouts containing video or audio.' ),
+ )
+ );
+ register_block_pattern_category(
+ 'posts',
+ array(
+ 'label' => _x( 'Posts', 'Block pattern category' ),
+ 'description' => __( 'Display your latest posts in lists, grids or other layouts.' ),
+ )
+ );
+ register_block_pattern_category(
+ 'footer',
+ array(
+ 'label' => _x( 'Footers', 'Block pattern category' ),
+ 'description' => __( 'A variety of footer designs displaying information and site navigation.' ),
+ )
+ );
+ register_block_pattern_category(
+ 'header',
+ array(
+ 'label' => _x( 'Headers', 'Block pattern category' ),
+ 'description' => __( 'A variety of header designs displaying your site title and navigation.' ),
+ )
+ );
+}
+
+/**
+ * Normalize the pattern properties to camelCase.
+ *
+ * The API's format is snake_case, `register_block_pattern()` expects camelCase.
+ *
+ * @since 6.2.0
+ * @access private
+ *
+ * @param array $pattern Pattern as returned from the Pattern Directory API.
+ * @return array Normalized pattern.
+ */
+function wp_normalize_remote_block_pattern( $pattern ) {
+ if ( isset( $pattern['block_types'] ) ) {
+ $pattern['blockTypes'] = $pattern['block_types'];
+ unset( $pattern['block_types'] );
+ }
+
+ if ( isset( $pattern['viewport_width'] ) ) {
+ $pattern['viewportWidth'] = $pattern['viewport_width'];
+ unset( $pattern['viewport_width'] );
+ }
+
+ return (array) $pattern;
+}
+
+/**
+ * Register Core's official patterns from wordpress.org/patterns.
+ *
+ * @since 5.8.0
+ * @since 5.9.0 The $current_screen argument was removed.
+ * @since 6.2.0 Normalize the pattern from the API (snake_case) to the
+ * format expected by `register_block_pattern` (camelCase).
+ * @since 6.3.0 Add 'pattern-directory/core' to the pattern's 'source'.
+ *
+ * @param WP_Screen $deprecated Unused. Formerly the screen that the current request was triggered from.
+ */
+function _load_remote_block_patterns( $deprecated = null ) {
+ if ( ! empty( $deprecated ) ) {
+ _deprecated_argument( __FUNCTION__, '5.9.0' );
+ $current_screen = $deprecated;
+ if ( ! $current_screen->is_block_editor ) {
+ return;
+ }
+ }
+
+ $supports_core_patterns = get_theme_support( 'core-block-patterns' );
+
+ /**
+ * Filter to disable remote block patterns.
+ *
+ * @since 5.8.0
+ *
+ * @param bool $should_load_remote
+ */
+ $should_load_remote = apply_filters( 'should_load_remote_block_patterns', true );
+
+ if ( $supports_core_patterns && $should_load_remote ) {
+ $request = new WP_REST_Request( 'GET', '/wp/v2/pattern-directory/patterns' );
+ $core_keyword_id = 11; // 11 is the ID for "core".
+ $request->set_param( 'keyword', $core_keyword_id );
+ $response = rest_do_request( $request );
+ if ( $response->is_error() ) {
+ return;
+ }
+ $patterns = $response->get_data();
+
+ foreach ( $patterns as $pattern ) {
+ $pattern['source'] = 'pattern-directory/core';
+ $normalized_pattern = wp_normalize_remote_block_pattern( $pattern );
+ $pattern_name = 'core/' . sanitize_title( $normalized_pattern['title'] );
+ register_block_pattern( $pattern_name, $normalized_pattern );
+ }
+ }
+}
+
+/**
+ * Register `Featured` (category) patterns from wordpress.org/patterns.
+ *
+ * @since 5.9.0
+ * @since 6.2.0 Normalized the pattern from the API (snake_case) to the
+ * format expected by `register_block_pattern()` (camelCase).
+ * @since 6.3.0 Add 'pattern-directory/featured' to the pattern's 'source'.
+ */
+function _load_remote_featured_patterns() {
+ $supports_core_patterns = get_theme_support( 'core-block-patterns' );
+
+ /** This filter is documented in wp-includes/block-patterns.php */
+ $should_load_remote = apply_filters( 'should_load_remote_block_patterns', true );
+
+ if ( ! $should_load_remote || ! $supports_core_patterns ) {
+ return;
+ }
+
+ $request = new WP_REST_Request( 'GET', '/wp/v2/pattern-directory/patterns' );
+ $featured_cat_id = 26; // This is the `Featured` category id from pattern directory.
+ $request->set_param( 'category', $featured_cat_id );
+ $response = rest_do_request( $request );
+ if ( $response->is_error() ) {
+ return;
+ }
+ $patterns = $response->get_data();
+ $registry = WP_Block_Patterns_Registry::get_instance();
+ foreach ( $patterns as $pattern ) {
+ $pattern['source'] = 'pattern-directory/featured';
+ $normalized_pattern = wp_normalize_remote_block_pattern( $pattern );
+ $pattern_name = sanitize_title( $normalized_pattern['title'] );
+ // Some patterns might be already registered as core patterns with the `core` prefix.
+ $is_registered = $registry->is_registered( $pattern_name ) || $registry->is_registered( "core/$pattern_name" );
+ if ( ! $is_registered ) {
+ register_block_pattern( $pattern_name, $normalized_pattern );
+ }
+ }
+}
+
+/**
+ * Registers patterns from Pattern Directory provided by a theme's
+ * `theme.json` file.
+ *
+ * @since 6.0.0
+ * @since 6.2.0 Normalized the pattern from the API (snake_case) to the
+ * format expected by `register_block_pattern()` (camelCase).
+ * @since 6.3.0 Add 'pattern-directory/theme' to the pattern's 'source'.
+ * @access private
+ */
+function _register_remote_theme_patterns() {
+ /** This filter is documented in wp-includes/block-patterns.php */
+ if ( ! apply_filters( 'should_load_remote_block_patterns', true ) ) {
+ return;
+ }
+
+ if ( ! wp_theme_has_theme_json() ) {
+ return;
+ }
+
+ $pattern_settings = wp_get_theme_directory_pattern_slugs();
+ if ( empty( $pattern_settings ) ) {
+ return;
+ }
+
+ $request = new WP_REST_Request( 'GET', '/wp/v2/pattern-directory/patterns' );
+ $request['slug'] = $pattern_settings;
+ $response = rest_do_request( $request );
+ if ( $response->is_error() ) {
+ return;
+ }
+ $patterns = $response->get_data();
+ $patterns_registry = WP_Block_Patterns_Registry::get_instance();
+ foreach ( $patterns as $pattern ) {
+ $pattern['source'] = 'pattern-directory/theme';
+ $normalized_pattern = wp_normalize_remote_block_pattern( $pattern );
+ $pattern_name = sanitize_title( $normalized_pattern['title'] );
+ // Some patterns might be already registered as core patterns with the `core` prefix.
+ $is_registered = $patterns_registry->is_registered( $pattern_name ) || $patterns_registry->is_registered( "core/$pattern_name" );
+ if ( ! $is_registered ) {
+ register_block_pattern( $pattern_name, $normalized_pattern );
+ }
+ }
+}
+
+/**
+ * Register any patterns that the active theme may provide under its
+ * `./patterns/` directory.
+ *
+ * @since 6.0.0
+ * @since 6.1.0 The `postTypes` property was added.
+ * @since 6.2.0 The `templateTypes` property was added.
+ * @since 6.4.0 Uses the `WP_Theme::get_block_patterns` method.
+ * @access private
+ */
+function _register_theme_block_patterns() {
+
+ /*
+ * During the bootstrap process, a check for active and valid themes is run.
+ * If no themes are returned, the theme's functions.php file will not be loaded,
+ * which can lead to errors if patterns expect some variables or constants to
+ * already be set at this point, so bail early if that is the case.
+ */
+ if ( empty( wp_get_active_and_valid_themes() ) ) {
+ return;
+ }
+
+ /*
+ * Register patterns for the active theme. If the theme is a child theme,
+ * let it override any patterns from the parent theme that shares the same slug.
+ */
+ $themes = array();
+ $theme = wp_get_theme();
+ $themes[] = $theme;
+ if ( $theme->parent() ) {
+ $themes[] = $theme->parent();
+ }
+ $registry = WP_Block_Patterns_Registry::get_instance();
+
+ foreach ( $themes as $theme ) {
+ $patterns = $theme->get_block_patterns();
+ $dirpath = $theme->get_stylesheet_directory() . '/patterns/';
+ $text_domain = $theme->get( 'TextDomain' );
+
+ foreach ( $patterns as $file => $pattern_data ) {
+ if ( $registry->is_registered( $pattern_data['slug'] ) ) {
+ continue;
+ }
+
+ $file_path = $dirpath . $file;
+
+ if ( ! file_exists( $file_path ) ) {
+ _doing_it_wrong(
+ __FUNCTION__,
+ sprintf(
+ /* translators: %s: file name. */
+ __( 'Could not register file "%s" as a block pattern as the file does not exist.' ),
+ $file
+ ),
+ '6.4.0'
+ );
+ $theme->delete_pattern_cache();
+ continue;
+ }
+
+ // The actual pattern content is the output of the file.
+ ob_start();
+ include $file_path;
+ $pattern_data['content'] = ob_get_clean();
+ if ( ! $pattern_data['content'] ) {
+ continue;
+ }
+
+ // Translate the pattern metadata.
+ // phpcs:ignore WordPress.WP.I18n.NonSingularStringLiteralText,WordPress.WP.I18n.NonSingularStringLiteralDomain,WordPress.WP.I18n.LowLevelTranslationFunction
+ $pattern_data['title'] = translate_with_gettext_context( $pattern_data['title'], 'Pattern title', $text_domain );
+ if ( ! empty( $pattern_data['description'] ) ) {
+ // phpcs:ignore WordPress.WP.I18n.NonSingularStringLiteralText,WordPress.WP.I18n.NonSingularStringLiteralDomain,WordPress.WP.I18n.LowLevelTranslationFunction
+ $pattern_data['description'] = translate_with_gettext_context( $pattern_data['description'], 'Pattern description', $text_domain );
+ }
+
+ register_block_pattern( $pattern_data['slug'], $pattern_data );
+ }
+ }
+}
+add_action( 'init', '_register_theme_block_patterns' );
diff --git a/wp-includes/block-patterns/query-grid-posts.php b/wp-includes/block-patterns/query-grid-posts.php
new file mode 100644
index 0000000..27a0b1d
--- /dev/null
+++ b/wp-includes/block-patterns/query-grid-posts.php
@@ -0,0 +1,23 @@
+<?php
+/**
+ * Query: Grid.
+ *
+ * @package WordPress
+ */
+
+return array(
+ 'title' => _x( 'Grid', 'Block pattern title' ),
+ 'blockTypes' => array( 'core/query' ),
+ 'categories' => array( 'query' ),
+ 'content' => '<!-- wp:query {"query":{"perPage":6,"pages":0,"offset":0,"postType":"post","order":"desc","orderBy":"date","author":"","search":"","exclude":[],"sticky":"exclude","inherit":false},"displayLayout":{"type":"flex","columns":3}} -->
+ <div class="wp-block-query">
+ <!-- wp:post-template -->
+ <!-- wp:group {"style":{"spacing":{"padding":{"top":"30px","right":"30px","bottom":"30px","left":"30px"}}},"layout":{"inherit":false}} -->
+ <div class="wp-block-group" style="padding-top:30px;padding-right:30px;padding-bottom:30px;padding-left:30px"><!-- wp:post-title {"isLink":true} /-->
+ <!-- wp:post-excerpt /-->
+ <!-- wp:post-date /--></div>
+ <!-- /wp:group -->
+ <!-- /wp:post-template -->
+ </div>
+ <!-- /wp:query -->',
+);
diff --git a/wp-includes/block-patterns/query-large-title-posts.php b/wp-includes/block-patterns/query-large-title-posts.php
new file mode 100644
index 0000000..0adf63a
--- /dev/null
+++ b/wp-includes/block-patterns/query-large-title-posts.php
@@ -0,0 +1,31 @@
+<?php
+/**
+ * Query: Large title.
+ *
+ * @package WordPress
+ */
+
+return array(
+ 'title' => _x( 'Large title', 'Block pattern title' ),
+ 'blockTypes' => array( 'core/query' ),
+ 'categories' => array( 'query' ),
+ 'content' => '<!-- wp:group {"align":"full","style":{"spacing":{"padding":{"top":"100px","right":"100px","bottom":"100px","left":"100px"}},"color":{"text":"#ffffff","background":"#000000"}}} -->
+ <div class="wp-block-group alignfull has-text-color has-background" style="background-color:#000000;color:#ffffff;padding-top:100px;padding-right:100px;padding-bottom:100px;padding-left:100px"><!-- wp:query {"query":{"perPage":3,"pages":0,"offset":0,"postType":"post","order":"desc","orderBy":"date","author":"","search":"","exclude":[],"sticky":"","inherit":false}} -->
+ <div class="wp-block-query"><!-- wp:post-template -->
+ <!-- wp:separator {"customColor":"#ffffff","align":"wide","className":"is-style-wide"} -->
+ <hr class="wp-block-separator alignwide has-text-color has-background is-style-wide" style="background-color:#ffffff;color:#ffffff"/>
+ <!-- /wp:separator -->
+
+ <!-- wp:columns {"verticalAlignment":"center","align":"wide"} -->
+ <div class="wp-block-columns alignwide are-vertically-aligned-center"><!-- wp:column {"verticalAlignment":"center","width":"20%"} -->
+ <div class="wp-block-column is-vertically-aligned-center" style="flex-basis:20%"><!-- wp:post-date {"style":{"color":{"text":"#ffffff"}},"fontSize":"extra-small"} /--></div>
+ <!-- /wp:column -->
+
+ <!-- wp:column {"verticalAlignment":"center","width":"80%"} -->
+ <div class="wp-block-column is-vertically-aligned-center" style="flex-basis:80%"><!-- wp:post-title {"isLink":true,"style":{"typography":{"fontSize":"72px","lineHeight":"1.1"},"color":{"text":"#ffffff","link":"#ffffff"}}} /--></div>
+ <!-- /wp:column --></div>
+ <!-- /wp:columns -->
+ <!-- /wp:post-template --></div>
+ <!-- /wp:query --></div>
+ <!-- /wp:group -->',
+);
diff --git a/wp-includes/block-patterns/query-medium-posts.php b/wp-includes/block-patterns/query-medium-posts.php
new file mode 100644
index 0000000..125ffd3
--- /dev/null
+++ b/wp-includes/block-patterns/query-medium-posts.php
@@ -0,0 +1,27 @@
+<?php
+/**
+ * Query: Image at left.
+ *
+ * @package WordPress
+ */
+
+return array(
+ 'title' => _x( 'Image at left', 'Block pattern title' ),
+ 'blockTypes' => array( 'core/query' ),
+ 'categories' => array( 'query' ),
+ 'content' => '<!-- wp:query {"query":{"perPage":3,"pages":0,"offset":0,"postType":"post","order":"desc","orderBy":"date","author":"","search":"","exclude":[],"sticky":"","inherit":false}} -->
+ <div class="wp-block-query">
+ <!-- wp:post-template -->
+ <!-- wp:columns {"align":"wide"} -->
+ <div class="wp-block-columns alignwide"><!-- wp:column {"width":"66.66%"} -->
+ <div class="wp-block-column" style="flex-basis:66.66%"><!-- wp:post-featured-image {"isLink":true} /--></div>
+ <!-- /wp:column -->
+ <!-- wp:column {"width":"33.33%"} -->
+ <div class="wp-block-column" style="flex-basis:33.33%"><!-- wp:post-title {"isLink":true} /-->
+ <!-- wp:post-excerpt /--></div>
+ <!-- /wp:column --></div>
+ <!-- /wp:columns -->
+ <!-- /wp:post-template -->
+ </div>
+ <!-- /wp:query -->',
+);
diff --git a/wp-includes/block-patterns/query-offset-posts.php b/wp-includes/block-patterns/query-offset-posts.php
new file mode 100644
index 0000000..139a4cb
--- /dev/null
+++ b/wp-includes/block-patterns/query-offset-posts.php
@@ -0,0 +1,40 @@
+<?php
+/**
+ * Query: Offset.
+ *
+ * @package WordPress
+ */
+
+return array(
+ 'title' => _x( 'Offset', 'Block pattern title' ),
+ 'blockTypes' => array( 'core/query' ),
+ 'categories' => array( 'query' ),
+ 'content' => '<!-- wp:group {"style":{"spacing":{"padding":{"top":"30px","right":"30px","bottom":"30px","left":"30px"}}},"layout":{"inherit":false}} -->
+ <div class="wp-block-group" style="padding-top:30px;padding-right:30px;padding-bottom:30px;padding-left:30px"><!-- wp:columns -->
+ <div class="wp-block-columns"><!-- wp:column {"width":"50%"} -->
+ <div class="wp-block-column" style="flex-basis:50%"><!-- wp:query {"query":{"perPage":2,"pages":0,"offset":0,"postType":"post","order":"desc","orderBy":"date","author":"","search":"","exclude":[],"sticky":"exclude","inherit":false},"displayLayout":{"type":"list"}} -->
+ <div class="wp-block-query"><!-- wp:post-template -->
+ <!-- wp:post-featured-image /-->
+ <!-- wp:post-title /-->
+ <!-- wp:post-date /-->
+ <!-- wp:spacer {"height":200} -->
+ <div style="height:200px" aria-hidden="true" class="wp-block-spacer"></div>
+ <!-- /wp:spacer -->
+ <!-- /wp:post-template --></div>
+ <!-- /wp:query --></div>
+ <!-- /wp:column -->
+ <!-- wp:column {"width":"50%"} -->
+ <div class="wp-block-column" style="flex-basis:50%"><!-- wp:query {"query":{"perPage":2,"pages":0,"offset":2,"postType":"post","order":"desc","orderBy":"date","author":"","search":"","exclude":[],"sticky":"exclude","inherit":false},"displayLayout":{"type":"list"}} -->
+ <div class="wp-block-query"><!-- wp:post-template -->
+ <!-- wp:spacer {"height":200} -->
+ <div style="height:200px" aria-hidden="true" class="wp-block-spacer"></div>
+ <!-- /wp:spacer -->
+ <!-- wp:post-featured-image /-->
+ <!-- wp:post-title /-->
+ <!-- wp:post-date /-->
+ <!-- /wp:post-template --></div>
+ <!-- /wp:query --></div>
+ <!-- /wp:column --></div>
+ <!-- /wp:columns --></div>
+ <!-- /wp:group -->',
+);
diff --git a/wp-includes/block-patterns/query-small-posts.php b/wp-includes/block-patterns/query-small-posts.php
new file mode 100644
index 0000000..66d57fc
--- /dev/null
+++ b/wp-includes/block-patterns/query-small-posts.php
@@ -0,0 +1,26 @@
+<?php
+/**
+ * Query: Small image and title.
+ *
+ * @package WordPress
+ */
+
+return array(
+ 'title' => _x( 'Small image and title', 'Block pattern title' ),
+ 'blockTypes' => array( 'core/query' ),
+ 'categories' => array( 'query' ),
+ 'content' => '<!-- wp:query {"query":{"perPage":3,"pages":0,"offset":0,"postType":"post","order":"desc","orderBy":"date","author":"","search":"","exclude":[],"sticky":"","inherit":false}} -->
+ <div class="wp-block-query">
+ <!-- wp:post-template -->
+ <!-- wp:columns {"verticalAlignment":"center"} -->
+ <div class="wp-block-columns are-vertically-aligned-center"><!-- wp:column {"verticalAlignment":"center","width":"25%"} -->
+ <div class="wp-block-column is-vertically-aligned-center" style="flex-basis:25%"><!-- wp:post-featured-image {"isLink":true} /--></div>
+ <!-- /wp:column -->
+ <!-- wp:column {"verticalAlignment":"center","width":"75%"} -->
+ <div class="wp-block-column is-vertically-aligned-center" style="flex-basis:75%"><!-- wp:post-title {"isLink":true} /--></div>
+ <!-- /wp:column --></div>
+ <!-- /wp:columns -->
+ <!-- /wp:post-template -->
+ </div>
+ <!-- /wp:query -->',
+);
diff --git a/wp-includes/block-patterns/query-standard-posts.php b/wp-includes/block-patterns/query-standard-posts.php
new file mode 100644
index 0000000..c6fde30
--- /dev/null
+++ b/wp-includes/block-patterns/query-standard-posts.php
@@ -0,0 +1,25 @@
+<?php
+/**
+ * Query: Standard.
+ *
+ * @package WordPress
+ */
+
+return array(
+ 'title' => _x( 'Standard', 'Block pattern title' ),
+ 'blockTypes' => array( 'core/query' ),
+ 'categories' => array( 'query' ),
+ 'content' => '<!-- wp:query {"query":{"perPage":3,"pages":0,"offset":0,"postType":"post","order":"desc","orderBy":"date","author":"","search":"","exclude":[],"sticky":"","inherit":false}} -->
+ <div class="wp-block-query">
+ <!-- wp:post-template -->
+ <!-- wp:post-title {"isLink":true} /-->
+ <!-- wp:post-featured-image {"isLink":true,"align":"wide"} /-->
+ <!-- wp:post-excerpt /-->
+ <!-- wp:separator -->
+ <hr class="wp-block-separator"/>
+ <!-- /wp:separator -->
+ <!-- wp:post-date /-->
+ <!-- /wp:post-template -->
+ </div>
+ <!-- /wp:query -->',
+);
diff --git a/wp-includes/block-patterns/social-links-shared-background-color.php b/wp-includes/block-patterns/social-links-shared-background-color.php
new file mode 100644
index 0000000..2ed1607
--- /dev/null
+++ b/wp-includes/block-patterns/social-links-shared-background-color.php
@@ -0,0 +1,18 @@
+<?php
+/**
+ * Social links with a shared background color.
+ *
+ * @package WordPress
+ */
+
+return array(
+ 'title' => _x( 'Social links with a shared background color', 'Block pattern title' ),
+ 'categories' => array( 'buttons' ),
+ 'blockTypes' => array( 'core/social-links' ),
+ 'viewportWidth' => 500,
+ 'content' => '<!-- wp:social-links {"customIconColor":"#ffffff","iconColorValue":"#ffffff","customIconBackgroundColor":"#3962e3","iconBackgroundColorValue":"#3962e3","className":"has-icon-color"} -->
+ <ul class="wp-block-social-links has-icon-color has-icon-background-color"><!-- wp:social-link {"url":"https://wordpress.org","service":"wordpress"} /-->
+ <!-- wp:social-link {"url":"#","service":"chain"} /-->
+ <!-- wp:social-link {"url":"#","service":"mail"} /--></ul>
+ <!-- /wp:social-links -->',
+);