mirror of
git://develop.git.wordpress.org/
synced 2025-01-18 05:18:42 +01:00
Editor: Make block type aware of variations
Currently block variations are only defined on the client. In some cases, creating block variations on the server can be very useful, especially when needed data is not exposed in the REST APIs. Related to https://github.com/WordPress/gutenberg/pull/29095. Props: gwwar, timothyblynjacobs. Fixes: #52688. git-svn-id: https://develop.svn.wordpress.org/trunk@50527 602fd350-edb4-49c9-b593-d223f7449a82
This commit is contained in:
parent
6877f57f36
commit
380d0445e8
@ -2257,6 +2257,7 @@ function get_block_editor_server_block_settings() {
|
|||||||
'parent' => 'parent',
|
'parent' => 'parent',
|
||||||
'keywords' => 'keywords',
|
'keywords' => 'keywords',
|
||||||
'example' => 'example',
|
'example' => 'example',
|
||||||
|
'variations' => 'variations',
|
||||||
);
|
);
|
||||||
|
|
||||||
foreach ( $block_registry->get_all_registered() as $block_name => $block_type ) {
|
foreach ( $block_registry->get_all_registered() as $block_name => $block_type ) {
|
||||||
|
@ -99,6 +99,13 @@ class WP_Block_Type {
|
|||||||
*/
|
*/
|
||||||
public $styles = array();
|
public $styles = array();
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Block variations.
|
||||||
|
* @since 5.8.0
|
||||||
|
* @var array
|
||||||
|
*/
|
||||||
|
public $variations = array();
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Supported features.
|
* Supported features.
|
||||||
*
|
*
|
||||||
|
@ -1703,6 +1703,9 @@ function _post_type_meta_capabilities( $capabilities = null ) {
|
|||||||
* - `item_scheduled` - Label used when an item is scheduled for publishing. Default is 'Post scheduled.' /
|
* - `item_scheduled` - Label used when an item is scheduled for publishing. Default is 'Post scheduled.' /
|
||||||
* 'Page scheduled.'
|
* 'Page scheduled.'
|
||||||
* - `item_updated` - Label used when an item is updated. Default is 'Post updated.' / 'Page updated.'
|
* - `item_updated` - Label used when an item is updated. Default is 'Post updated.' / 'Page updated.'
|
||||||
|
* - `item_link` - Title for a navigation link block variation. Default is 'Post Link' / 'Page Link'.
|
||||||
|
* - `item_link_description` - Description for a navigation link block variation. Default is 'A link to a post.' /
|
||||||
|
* 'A link to a page.'
|
||||||
*
|
*
|
||||||
* Above, the first default value is for non-hierarchical post types (like posts)
|
* Above, the first default value is for non-hierarchical post types (like posts)
|
||||||
* and the second one is for hierarchical post types (like pages).
|
* and the second one is for hierarchical post types (like pages).
|
||||||
@ -1757,6 +1760,14 @@ function get_post_type_labels( $post_type_object ) {
|
|||||||
'item_reverted_to_draft' => array( __( 'Post reverted to draft.' ), __( 'Page reverted to draft.' ) ),
|
'item_reverted_to_draft' => array( __( 'Post reverted to draft.' ), __( 'Page reverted to draft.' ) ),
|
||||||
'item_scheduled' => array( __( 'Post scheduled.' ), __( 'Page scheduled.' ) ),
|
'item_scheduled' => array( __( 'Post scheduled.' ), __( 'Page scheduled.' ) ),
|
||||||
'item_updated' => array( __( 'Post updated.' ), __( 'Page updated.' ) ),
|
'item_updated' => array( __( 'Post updated.' ), __( 'Page updated.' ) ),
|
||||||
|
'item_link' => array(
|
||||||
|
_x( 'Post Link', 'navigation link block title' ),
|
||||||
|
_x( 'Page Link', 'navigation link block title' ),
|
||||||
|
),
|
||||||
|
'item_link_description' => array(
|
||||||
|
_x( 'A link to a post.', 'navigation link block description' ),
|
||||||
|
_x( 'A link to a page.', 'navigation link block description' ),
|
||||||
|
),
|
||||||
);
|
);
|
||||||
$nohier_vs_hier_defaults['menu_name'] = $nohier_vs_hier_defaults['name'];
|
$nohier_vs_hier_defaults['menu_name'] = $nohier_vs_hier_defaults['name'];
|
||||||
|
|
||||||
|
@ -274,6 +274,7 @@ class WP_REST_Block_Types_Controller extends WP_REST_Controller {
|
|||||||
'script',
|
'script',
|
||||||
'editor_style',
|
'editor_style',
|
||||||
'style',
|
'style',
|
||||||
|
'variations',
|
||||||
);
|
);
|
||||||
foreach ( $extra_fields as $extra_field ) {
|
foreach ( $extra_fields as $extra_field ) {
|
||||||
if ( rest_is_field_included( $extra_field, $fields ) ) {
|
if ( rest_is_field_included( $extra_field, $fields ) ) {
|
||||||
@ -361,6 +362,71 @@ class WP_REST_Block_Types_Controller extends WP_REST_Controller {
|
|||||||
return $this->add_additional_fields_schema( $this->schema );
|
return $this->add_additional_fields_schema( $this->schema );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
//rest_validate_value_from_schema doesn't understand $refs, pull out reused definitions for readability.
|
||||||
|
$inner_blocks_definition = array(
|
||||||
|
'description' => __( 'The list of inner blocks used in the example.' ),
|
||||||
|
'type' => 'array',
|
||||||
|
'items' => array(
|
||||||
|
'type' => 'object',
|
||||||
|
'properties' => array(
|
||||||
|
'name' => array(
|
||||||
|
'description' => __( 'The name of the inner block.' ),
|
||||||
|
'type' => 'string',
|
||||||
|
),
|
||||||
|
'attributes' => array(
|
||||||
|
'description' => __( 'The attributes of the inner block.' ),
|
||||||
|
'type' => 'object',
|
||||||
|
),
|
||||||
|
'innerBlocks' => array(
|
||||||
|
'description' => __( "A list of the inner block's own inner blocks. This is a recursive definition following the parent innerBlocks schema." ),
|
||||||
|
'type' => 'array',
|
||||||
|
),
|
||||||
|
),
|
||||||
|
),
|
||||||
|
);
|
||||||
|
|
||||||
|
$example_definition = array(
|
||||||
|
'description' => __( 'Block example.' ),
|
||||||
|
'type' => array( 'object', 'null' ),
|
||||||
|
'default' => null,
|
||||||
|
'properties' => array(
|
||||||
|
'attributes' => array(
|
||||||
|
'description' => __( 'The attributes used in the example.' ),
|
||||||
|
'type' => 'object',
|
||||||
|
),
|
||||||
|
'innerBlocks' => $inner_blocks_definition,
|
||||||
|
),
|
||||||
|
'context' => array( 'embed', 'view', 'edit' ),
|
||||||
|
'readonly' => true,
|
||||||
|
);
|
||||||
|
|
||||||
|
$keywords_definition = array(
|
||||||
|
'description' => __( 'Block keywords.' ),
|
||||||
|
'type' => 'array',
|
||||||
|
'items' => array(
|
||||||
|
'type' => 'string',
|
||||||
|
),
|
||||||
|
'default' => array(),
|
||||||
|
'context' => array( 'embed', 'view', 'edit' ),
|
||||||
|
'readonly' => true,
|
||||||
|
);
|
||||||
|
|
||||||
|
$icon_definition = array(
|
||||||
|
'description' => __( 'Icon of block type.' ),
|
||||||
|
'type' => array( 'string', 'null' ),
|
||||||
|
'default' => null,
|
||||||
|
'context' => array( 'embed', 'view', 'edit' ),
|
||||||
|
'readonly' => true,
|
||||||
|
);
|
||||||
|
|
||||||
|
$category_definition = array(
|
||||||
|
'description' => __( 'Block category.' ),
|
||||||
|
'type' => array( 'string', 'null' ),
|
||||||
|
'default' => null,
|
||||||
|
'context' => array( 'embed', 'view', 'edit' ),
|
||||||
|
'readonly' => true,
|
||||||
|
);
|
||||||
|
|
||||||
$schema = array(
|
$schema = array(
|
||||||
'$schema' => 'http://json-schema.org/draft-04/schema#',
|
'$schema' => 'http://json-schema.org/draft-04/schema#',
|
||||||
'title' => 'block-type',
|
'title' => 'block-type',
|
||||||
@ -394,13 +460,7 @@ class WP_REST_Block_Types_Controller extends WP_REST_Controller {
|
|||||||
'context' => array( 'embed', 'view', 'edit' ),
|
'context' => array( 'embed', 'view', 'edit' ),
|
||||||
'readonly' => true,
|
'readonly' => true,
|
||||||
),
|
),
|
||||||
'icon' => array(
|
'icon' => $icon_definition,
|
||||||
'description' => __( 'Icon of block type.' ),
|
|
||||||
'type' => array( 'string', 'null' ),
|
|
||||||
'default' => null,
|
|
||||||
'context' => array( 'embed', 'view', 'edit' ),
|
|
||||||
'readonly' => true,
|
|
||||||
),
|
|
||||||
'attributes' => array(
|
'attributes' => array(
|
||||||
'description' => __( 'Block attributes.' ),
|
'description' => __( 'Block attributes.' ),
|
||||||
'type' => array( 'object', 'null' ),
|
'type' => array( 'object', 'null' ),
|
||||||
@ -441,13 +501,7 @@ class WP_REST_Block_Types_Controller extends WP_REST_Controller {
|
|||||||
'context' => array( 'embed', 'view', 'edit' ),
|
'context' => array( 'embed', 'view', 'edit' ),
|
||||||
'readonly' => true,
|
'readonly' => true,
|
||||||
),
|
),
|
||||||
'category' => array(
|
'category' => $category_definition,
|
||||||
'description' => __( 'Block category.' ),
|
|
||||||
'type' => array( 'string', 'null' ),
|
|
||||||
'default' => null,
|
|
||||||
'context' => array( 'embed', 'view', 'edit' ),
|
|
||||||
'readonly' => true,
|
|
||||||
),
|
|
||||||
'is_dynamic' => array(
|
'is_dynamic' => array(
|
||||||
'description' => __( 'Is the block dynamically rendered.' ),
|
'description' => __( 'Is the block dynamically rendered.' ),
|
||||||
'type' => 'boolean',
|
'type' => 'boolean',
|
||||||
@ -512,6 +566,58 @@ class WP_REST_Block_Types_Controller extends WP_REST_Controller {
|
|||||||
'context' => array( 'embed', 'view', 'edit' ),
|
'context' => array( 'embed', 'view', 'edit' ),
|
||||||
'readonly' => true,
|
'readonly' => true,
|
||||||
),
|
),
|
||||||
|
'variations' => array(
|
||||||
|
'description' => __( 'Block variations.' ),
|
||||||
|
'type' => 'array',
|
||||||
|
'items' => array(
|
||||||
|
'type' => 'object',
|
||||||
|
'properties' => array(
|
||||||
|
'name' => array(
|
||||||
|
'description' => __( 'The unique and machine-readable name.' ),
|
||||||
|
'type' => 'string',
|
||||||
|
'required' => true,
|
||||||
|
),
|
||||||
|
'title' => array(
|
||||||
|
'description' => __( 'A human-readable variation title.' ),
|
||||||
|
'type' => 'string',
|
||||||
|
'required' => true,
|
||||||
|
),
|
||||||
|
'description' => array(
|
||||||
|
'description' => __( 'A detailed variation description.' ),
|
||||||
|
'type' => 'string',
|
||||||
|
'required' => false,
|
||||||
|
),
|
||||||
|
'category' => $category_definition,
|
||||||
|
'icon' => $icon_definition,
|
||||||
|
'isDefault' => array(
|
||||||
|
'description' => __( 'Indicates whether the current variation is the default one.' ),
|
||||||
|
'type' => 'boolean',
|
||||||
|
'required' => false,
|
||||||
|
'default' => false,
|
||||||
|
),
|
||||||
|
'attributes' => array(
|
||||||
|
'description' => __( 'The initial values for attributes.' ),
|
||||||
|
'type' => 'object',
|
||||||
|
),
|
||||||
|
'innerBlocks' => $inner_blocks_definition,
|
||||||
|
'example' => $example_definition,
|
||||||
|
'scope' => array(
|
||||||
|
'description' => __( 'The list of scopes where the variation is applicable. When not provided, it assumes all available scopes.' ),
|
||||||
|
'type' => array( 'array', 'null' ),
|
||||||
|
'default' => null,
|
||||||
|
'items' => array(
|
||||||
|
'type' => 'string',
|
||||||
|
'enum' => array( 'block', 'inserter', 'transform' ),
|
||||||
|
),
|
||||||
|
'readonly' => true,
|
||||||
|
),
|
||||||
|
'keywords' => $keywords_definition,
|
||||||
|
),
|
||||||
|
),
|
||||||
|
'readonly' => true,
|
||||||
|
'context' => array( 'embed', 'view', 'edit' ),
|
||||||
|
'default' => null,
|
||||||
|
),
|
||||||
'textdomain' => array(
|
'textdomain' => array(
|
||||||
'description' => __( 'Public text domain.' ),
|
'description' => __( 'Public text domain.' ),
|
||||||
'type' => array( 'string', 'null' ),
|
'type' => array( 'string', 'null' ),
|
||||||
@ -529,50 +635,8 @@ class WP_REST_Block_Types_Controller extends WP_REST_Controller {
|
|||||||
'context' => array( 'embed', 'view', 'edit' ),
|
'context' => array( 'embed', 'view', 'edit' ),
|
||||||
'readonly' => true,
|
'readonly' => true,
|
||||||
),
|
),
|
||||||
'keywords' => array(
|
'keywords' => $keywords_definition,
|
||||||
'description' => __( 'Block keywords.' ),
|
'example' => $example_definition,
|
||||||
'type' => 'array',
|
|
||||||
'items' => array(
|
|
||||||
'type' => 'string',
|
|
||||||
),
|
|
||||||
'default' => array(),
|
|
||||||
'context' => array( 'embed', 'view', 'edit' ),
|
|
||||||
'readonly' => true,
|
|
||||||
),
|
|
||||||
'example' => array(
|
|
||||||
'description' => __( 'Block example.' ),
|
|
||||||
'type' => array( 'object', 'null' ),
|
|
||||||
'default' => null,
|
|
||||||
'properties' => array(
|
|
||||||
'attributes' => array(
|
|
||||||
'description' => __( 'The attributes used in the example.' ),
|
|
||||||
'type' => 'object',
|
|
||||||
),
|
|
||||||
'innerBlocks' => array(
|
|
||||||
'description' => __( 'The list of inner blocks used in the example.' ),
|
|
||||||
'type' => 'array',
|
|
||||||
'items' => array(
|
|
||||||
'type' => 'object',
|
|
||||||
'properties' => array(
|
|
||||||
'name' => array(
|
|
||||||
'description' => __( 'The name of the inner block.' ),
|
|
||||||
'type' => 'string',
|
|
||||||
),
|
|
||||||
'attributes' => array(
|
|
||||||
'description' => __( 'The attributes of the inner block.' ),
|
|
||||||
'type' => 'object',
|
|
||||||
),
|
|
||||||
'innerBlocks' => array(
|
|
||||||
'description' => __( "A list of the inner block's own inner blocks. This is a recursive definition following the parent innerBlocks schema." ),
|
|
||||||
'type' => 'array',
|
|
||||||
),
|
|
||||||
),
|
|
||||||
),
|
|
||||||
),
|
|
||||||
),
|
|
||||||
'context' => array( 'embed', 'view', 'edit' ),
|
|
||||||
'readonly' => true,
|
|
||||||
),
|
|
||||||
),
|
),
|
||||||
);
|
);
|
||||||
|
|
||||||
|
@ -576,6 +576,10 @@ function unregister_taxonomy( $taxonomy ) {
|
|||||||
* @type string $items_list Label for the table hidden heading.
|
* @type string $items_list Label for the table hidden heading.
|
||||||
* @type string $most_used Title for the Most Used tab. Default 'Most Used'.
|
* @type string $most_used Title for the Most Used tab. Default 'Most Used'.
|
||||||
* @type string $back_to_items Label displayed after a term has been updated.
|
* @type string $back_to_items Label displayed after a term has been updated.
|
||||||
|
* @type string $item_link Used in the block editor. Title for a navigation link block variation.
|
||||||
|
* Default 'Tag Link'/'Category Link'.
|
||||||
|
* @type string $item_link_description Used in the block editor. Description for a navigation link block
|
||||||
|
* variation. Default 'A link to a tag.'/'A link to a category'.
|
||||||
* }
|
* }
|
||||||
*/
|
*/
|
||||||
function get_taxonomy_labels( $tax ) {
|
function get_taxonomy_labels( $tax ) {
|
||||||
@ -613,6 +617,14 @@ function get_taxonomy_labels( $tax ) {
|
|||||||
/* translators: Tab heading when selecting from the most used terms. */
|
/* translators: Tab heading when selecting from the most used terms. */
|
||||||
'most_used' => array( _x( 'Most Used', 'tags' ), _x( 'Most Used', 'categories' ) ),
|
'most_used' => array( _x( 'Most Used', 'tags' ), _x( 'Most Used', 'categories' ) ),
|
||||||
'back_to_items' => array( __( '← Go to Tags' ), __( '← Go to Categories' ) ),
|
'back_to_items' => array( __( '← Go to Tags' ), __( '← Go to Categories' ) ),
|
||||||
|
'item_link' => array(
|
||||||
|
_x( 'Tag Link', 'navigation link block title' ),
|
||||||
|
_x( 'Category Link', 'navigation link block description' ),
|
||||||
|
),
|
||||||
|
'item_link_description' => array(
|
||||||
|
_x( 'A link to a tag.', 'navigation link block description' ),
|
||||||
|
_x( 'A link to a category.', 'navigation link block description' ),
|
||||||
|
),
|
||||||
);
|
);
|
||||||
$nohier_vs_hier_defaults['menu_name'] = $nohier_vs_hier_defaults['name'];
|
$nohier_vs_hier_defaults['menu_name'] = $nohier_vs_hier_defaults['name'];
|
||||||
|
|
||||||
|
@ -847,6 +847,7 @@ class Tests_Admin_Includes_Post extends WP_UnitTestCase {
|
|||||||
'category' => 'common',
|
'category' => 'common',
|
||||||
'styles' => array(),
|
'styles' => array(),
|
||||||
'keywords' => array(),
|
'keywords' => array(),
|
||||||
|
'variations' => array(),
|
||||||
),
|
),
|
||||||
$blocks[ $name ]
|
$blocks[ $name ]
|
||||||
);
|
);
|
||||||
|
@ -224,6 +224,7 @@ class REST_Block_Type_Controller_Test extends WP_Test_REST_Controller_Testcase {
|
|||||||
'styles' => 'invalid_styles',
|
'styles' => 'invalid_styles',
|
||||||
'render_callback' => 'invalid_callback',
|
'render_callback' => 'invalid_callback',
|
||||||
'textdomain' => true,
|
'textdomain' => true,
|
||||||
|
'variations' => 'invalid_variations',
|
||||||
);
|
);
|
||||||
register_block_type( $block_type, $settings );
|
register_block_type( $block_type, $settings );
|
||||||
wp_set_current_user( self::$admin_id );
|
wp_set_current_user( self::$admin_id );
|
||||||
@ -249,6 +250,7 @@ class REST_Block_Type_Controller_Test extends WP_Test_REST_Controller_Testcase {
|
|||||||
$this->assertNull( $data['category'] );
|
$this->assertNull( $data['category'] );
|
||||||
$this->assertNull( $data['textdomain'] );
|
$this->assertNull( $data['textdomain'] );
|
||||||
$this->assertFalse( $data['is_dynamic'] );
|
$this->assertFalse( $data['is_dynamic'] );
|
||||||
|
$this->assertSameSets( array( array() ), $data['variations'] );
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -275,6 +277,7 @@ class REST_Block_Type_Controller_Test extends WP_Test_REST_Controller_Testcase {
|
|||||||
'render_callback' => false,
|
'render_callback' => false,
|
||||||
'textdomain' => false,
|
'textdomain' => false,
|
||||||
'example' => false,
|
'example' => false,
|
||||||
|
'variations' => false,
|
||||||
);
|
);
|
||||||
register_block_type( $block_type, $settings );
|
register_block_type( $block_type, $settings );
|
||||||
wp_set_current_user( self::$admin_id );
|
wp_set_current_user( self::$admin_id );
|
||||||
@ -301,6 +304,65 @@ class REST_Block_Type_Controller_Test extends WP_Test_REST_Controller_Testcase {
|
|||||||
$this->assertNull( $data['example'] );
|
$this->assertNull( $data['example'] );
|
||||||
$this->assertNull( $data['textdomain'] );
|
$this->assertNull( $data['textdomain'] );
|
||||||
$this->assertFalse( $data['is_dynamic'] );
|
$this->assertFalse( $data['is_dynamic'] );
|
||||||
|
$this->assertSameSets( array(), $data['variations'] );
|
||||||
|
}
|
||||||
|
|
||||||
|
public function test_get_variation() {
|
||||||
|
$block_type = 'fake/variations';
|
||||||
|
$settings = array(
|
||||||
|
'title' => 'variations block test',
|
||||||
|
'description' => 'a variations block test',
|
||||||
|
'attributes' => array( 'kind' => array( 'type' => 'string' ) ),
|
||||||
|
'variations' => array(
|
||||||
|
array(
|
||||||
|
'name' => 'variation',
|
||||||
|
'title' => 'variation title',
|
||||||
|
'description' => 'variation description',
|
||||||
|
'category' => 'media',
|
||||||
|
'icon' => 'checkmark',
|
||||||
|
'attributes' => array( 'kind' => 'foo' ),
|
||||||
|
'isDefault' => true,
|
||||||
|
'example' => array( 'attributes' => array( 'kind' => 'example' ) ),
|
||||||
|
'scope' => array( 'inserter', 'block' ),
|
||||||
|
'keywords' => array( 'dogs', 'cats', 'mice' ),
|
||||||
|
'innerBlocks' => array(
|
||||||
|
array(
|
||||||
|
'name' => 'fake/bar',
|
||||||
|
'attributes' => array( 'label' => 'hi' ),
|
||||||
|
),
|
||||||
|
),
|
||||||
|
),
|
||||||
|
),
|
||||||
|
);
|
||||||
|
register_block_type( $block_type, $settings );
|
||||||
|
wp_set_current_user( self::$admin_id );
|
||||||
|
$request = new WP_REST_Request( 'GET', '/wp/v2/block-types/' . $block_type );
|
||||||
|
$response = rest_get_server()->dispatch( $request );
|
||||||
|
$data = $response->get_data();
|
||||||
|
$this->assertSame( $block_type, $data['name'] );
|
||||||
|
$this->assertArrayHasKey( 'variations', $data );
|
||||||
|
$this->assertSame( 1, count( $data['variations'] ) );
|
||||||
|
$variation = $data['variations'][0];
|
||||||
|
$this->assertSame( 'variation title', $variation['title'] );
|
||||||
|
$this->assertSame( 'variation description', $variation['description'] );
|
||||||
|
$this->assertSame( 'media', $variation['category'] );
|
||||||
|
$this->assertSame( 'checkmark', $variation['icon'] );
|
||||||
|
$this->assertSameSets( array( 'inserter', 'block' ), $variation['scope'] );
|
||||||
|
$this->assertSameSets( array( 'dogs', 'cats', 'mice' ), $variation['keywords'] );
|
||||||
|
$this->assertSameSets( array( 'attributes' => array( 'kind' => 'example' ) ), $variation['example'] );
|
||||||
|
$this->assertSameSets(
|
||||||
|
array(
|
||||||
|
array(
|
||||||
|
'name' => 'fake/bar',
|
||||||
|
'attributes' => array( 'label' => 'hi' ),
|
||||||
|
),
|
||||||
|
),
|
||||||
|
$variation['innerBlocks']
|
||||||
|
);
|
||||||
|
$this->assertSameSets(
|
||||||
|
array( 'kind' => 'foo' ),
|
||||||
|
$variation['attributes']
|
||||||
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -312,7 +374,7 @@ class REST_Block_Type_Controller_Test extends WP_Test_REST_Controller_Testcase {
|
|||||||
$response = rest_get_server()->dispatch( $request );
|
$response = rest_get_server()->dispatch( $request );
|
||||||
$data = $response->get_data();
|
$data = $response->get_data();
|
||||||
$properties = $data['schema']['properties'];
|
$properties = $data['schema']['properties'];
|
||||||
$this->assertCount( 20, $properties );
|
$this->assertCount( 21, $properties );
|
||||||
$this->assertArrayHasKey( 'api_version', $properties );
|
$this->assertArrayHasKey( 'api_version', $properties );
|
||||||
$this->assertArrayHasKey( 'title', $properties );
|
$this->assertArrayHasKey( 'title', $properties );
|
||||||
$this->assertArrayHasKey( 'icon', $properties );
|
$this->assertArrayHasKey( 'icon', $properties );
|
||||||
@ -333,6 +395,7 @@ class REST_Block_Type_Controller_Test extends WP_Test_REST_Controller_Testcase {
|
|||||||
$this->assertArrayHasKey( 'example', $properties );
|
$this->assertArrayHasKey( 'example', $properties );
|
||||||
$this->assertArrayHasKey( 'uses_context', $properties );
|
$this->assertArrayHasKey( 'uses_context', $properties );
|
||||||
$this->assertArrayHasKey( 'provides_context', $properties );
|
$this->assertArrayHasKey( 'provides_context', $properties );
|
||||||
|
$this->assertArrayHasKey( 'variations', $properties );
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
Loading…
x
Reference in New Issue
Block a user