mirror of
https://github.com/gosticks/wordpress-develop.git
synced 2026-06-30 23:30:05 +00:00
Editor: Universalize functions for checking block editor status.
`use_block_editor_for_post_type` and `use_block_editor_for_post` can be very useful in more contexts than wp-admin, especially when a site is in transition. For example, you may want to do things on init that are different. Neither function depends on other functions that are available only in wp-admin (other than use_block_editor_for_post() relying on use_block_editor_for_post_type() and an admin-referrer check that's historically gated by a query variable and now also gated by is_admin), therefore moving them to wp-includes seems both feasible and beneficial Props ethitter, jorbin. Fixes #51819. git-svn-id: https://develop.svn.wordpress.org/trunk@53559 602fd350-edb4-49c9-b593-d223f7449a82
This commit is contained in:
@@ -2147,76 +2147,6 @@ function taxonomy_meta_box_sanitize_cb_input( $taxonomy, $terms ) {
|
||||
return $clean_terms;
|
||||
}
|
||||
|
||||
/**
|
||||
* Returns whether the post can be edited in the block editor.
|
||||
*
|
||||
* @since 5.0.0
|
||||
*
|
||||
* @param int|WP_Post $post Post ID or WP_Post object.
|
||||
* @return bool Whether the post can be edited in the block editor.
|
||||
*/
|
||||
function use_block_editor_for_post( $post ) {
|
||||
$post = get_post( $post );
|
||||
|
||||
if ( ! $post ) {
|
||||
return false;
|
||||
}
|
||||
|
||||
// We're in the meta box loader, so don't use the block editor.
|
||||
if ( isset( $_GET['meta-box-loader'] ) ) {
|
||||
check_admin_referer( 'meta-box-loader', 'meta-box-loader-nonce' );
|
||||
return false;
|
||||
}
|
||||
|
||||
$use_block_editor = use_block_editor_for_post_type( $post->post_type );
|
||||
|
||||
/**
|
||||
* Filters whether a post is able to be edited in the block editor.
|
||||
*
|
||||
* @since 5.0.0
|
||||
*
|
||||
* @param bool $use_block_editor Whether the post can be edited or not.
|
||||
* @param WP_Post $post The post being checked.
|
||||
*/
|
||||
return apply_filters( 'use_block_editor_for_post', $use_block_editor, $post );
|
||||
}
|
||||
|
||||
/**
|
||||
* Returns whether a post type is compatible with the block editor.
|
||||
*
|
||||
* The block editor depends on the REST API, and if the post type is not shown in the
|
||||
* REST API, then it won't work with the block editor.
|
||||
*
|
||||
* @since 5.0.0
|
||||
*
|
||||
* @param string $post_type The post type.
|
||||
* @return bool Whether the post type can be edited with the block editor.
|
||||
*/
|
||||
function use_block_editor_for_post_type( $post_type ) {
|
||||
if ( ! post_type_exists( $post_type ) ) {
|
||||
return false;
|
||||
}
|
||||
|
||||
if ( ! post_type_supports( $post_type, 'editor' ) ) {
|
||||
return false;
|
||||
}
|
||||
|
||||
$post_type_object = get_post_type_object( $post_type );
|
||||
if ( $post_type_object && ! $post_type_object->show_in_rest ) {
|
||||
return false;
|
||||
}
|
||||
|
||||
/**
|
||||
* Filters whether a post is able to be edited in the block editor.
|
||||
*
|
||||
* @since 5.0.0
|
||||
*
|
||||
* @param bool $use_block_editor Whether the post type can be edited or not. Default true.
|
||||
* @param string $post_type The post type being checked.
|
||||
*/
|
||||
return apply_filters( 'use_block_editor_for_post_type', true, $post_type );
|
||||
}
|
||||
|
||||
/**
|
||||
* Prepares server-registered blocks for the block editor.
|
||||
*
|
||||
|
||||
@@ -8106,3 +8106,75 @@ function wp_get_original_image_url( $attachment_id ) {
|
||||
function wp_untrash_post_set_previous_status( $new_status, $post_id, $previous_status ) {
|
||||
return $previous_status;
|
||||
}
|
||||
|
||||
/**
|
||||
* Returns whether the post can be edited in the block editor.
|
||||
*
|
||||
* @since 5.0.0
|
||||
* @since 6.1.0 Moved to wp-includes from wp-admin.
|
||||
*
|
||||
* @param int|WP_Post $post Post ID or WP_Post object.
|
||||
* @return bool Whether the post can be edited in the block editor.
|
||||
*/
|
||||
function use_block_editor_for_post( $post ) {
|
||||
$post = get_post( $post );
|
||||
|
||||
if ( ! $post ) {
|
||||
return false;
|
||||
}
|
||||
|
||||
// We're in the meta box loader, so don't use the block editor.
|
||||
if ( is_admin() && isset( $_GET['meta-box-loader'] ) ) {
|
||||
check_admin_referer( 'meta-box-loader', 'meta-box-loader-nonce' );
|
||||
return false;
|
||||
}
|
||||
|
||||
$use_block_editor = use_block_editor_for_post_type( $post->post_type );
|
||||
|
||||
/**
|
||||
* Filters whether a post is able to be edited in the block editor.
|
||||
*
|
||||
* @since 5.0.0
|
||||
*
|
||||
* @param bool $use_block_editor Whether the post can be edited or not.
|
||||
* @param WP_Post $post The post being checked.
|
||||
*/
|
||||
return apply_filters( 'use_block_editor_for_post', $use_block_editor, $post );
|
||||
}
|
||||
|
||||
/**
|
||||
* Returns whether a post type is compatible with the block editor.
|
||||
*
|
||||
* The block editor depends on the REST API, and if the post type is not shown in the
|
||||
* REST API, then it won't work with the block editor.
|
||||
*
|
||||
* @since 5.0.0
|
||||
* @since 6.1.0 Moved to wp-includes from wp-admin.
|
||||
*
|
||||
* @param string $post_type The post type.
|
||||
* @return bool Whether the post type can be edited with the block editor.
|
||||
*/
|
||||
function use_block_editor_for_post_type( $post_type ) {
|
||||
if ( ! post_type_exists( $post_type ) ) {
|
||||
return false;
|
||||
}
|
||||
|
||||
if ( ! post_type_supports( $post_type, 'editor' ) ) {
|
||||
return false;
|
||||
}
|
||||
|
||||
$post_type_object = get_post_type_object( $post_type );
|
||||
if ( $post_type_object && ! $post_type_object->show_in_rest ) {
|
||||
return false;
|
||||
}
|
||||
|
||||
/**
|
||||
* Filters whether a post is able to be edited in the block editor.
|
||||
*
|
||||
* @since 5.0.0
|
||||
*
|
||||
* @param bool $use_block_editor Whether the post type can be edited or not. Default true.
|
||||
* @param string $post_type The post type being checked.
|
||||
*/
|
||||
return apply_filters( 'use_block_editor_for_post_type', true, $post_type );
|
||||
}
|
||||
|
||||
@@ -789,39 +789,6 @@ class Tests_Admin_IncludesPost extends WP_UnitTestCase {
|
||||
$this->assertSame( $p, post_exists( $title, $content, $date ) );
|
||||
}
|
||||
|
||||
public function test_use_block_editor_for_post() {
|
||||
$this->assertFalse( use_block_editor_for_post( -1 ) );
|
||||
$bogus_post_id = $this->factory()->post->create(
|
||||
array(
|
||||
'post_type' => 'bogus',
|
||||
)
|
||||
);
|
||||
$this->assertFalse( use_block_editor_for_post( $bogus_post_id ) );
|
||||
|
||||
register_post_type(
|
||||
'restless',
|
||||
array(
|
||||
'show_in_rest' => false,
|
||||
)
|
||||
);
|
||||
$restless_post_id = $this->factory()->post->create(
|
||||
array(
|
||||
'post_type' => 'restless',
|
||||
)
|
||||
);
|
||||
$this->assertFalse( use_block_editor_for_post( $restless_post_id ) );
|
||||
|
||||
$generic_post_id = $this->factory()->post->create();
|
||||
|
||||
add_filter( 'use_block_editor_for_post', '__return_false' );
|
||||
$this->assertFalse( use_block_editor_for_post( $generic_post_id ) );
|
||||
remove_filter( 'use_block_editor_for_post', '__return_false' );
|
||||
|
||||
add_filter( 'use_block_editor_for_post', '__return_true' );
|
||||
$this->assertTrue( use_block_editor_for_post( $restless_post_id ) );
|
||||
remove_filter( 'use_block_editor_for_post', '__return_true' );
|
||||
}
|
||||
|
||||
public function test_get_block_editor_server_block_settings() {
|
||||
$name = 'core/test';
|
||||
$settings = array(
|
||||
|
||||
@@ -1844,4 +1844,43 @@ class Tests_Post extends WP_UnitTestCase {
|
||||
unstick_post( 3 );
|
||||
$this->assertSameSets( array( 1, 2, 2 ), get_option( 'sticky_posts' ) );
|
||||
}
|
||||
|
||||
/**
|
||||
* Check if post supports block editor.
|
||||
*
|
||||
* @ticket 51819
|
||||
* @covers ::use_block_editor_for_post
|
||||
*/
|
||||
public function test_use_block_editor_for_post() {
|
||||
$this->assertFalse( use_block_editor_for_post( -1 ) );
|
||||
$bogus_post_id = $this->factory()->post->create(
|
||||
array(
|
||||
'post_type' => 'bogus',
|
||||
)
|
||||
);
|
||||
$this->assertFalse( use_block_editor_for_post( $bogus_post_id ) );
|
||||
|
||||
register_post_type(
|
||||
'restless',
|
||||
array(
|
||||
'show_in_rest' => false,
|
||||
)
|
||||
);
|
||||
$restless_post_id = $this->factory()->post->create(
|
||||
array(
|
||||
'post_type' => 'restless',
|
||||
)
|
||||
);
|
||||
$this->assertFalse( use_block_editor_for_post( $restless_post_id ) );
|
||||
|
||||
$generic_post_id = $this->factory()->post->create();
|
||||
|
||||
add_filter( 'use_block_editor_for_post', '__return_false' );
|
||||
$this->assertFalse( use_block_editor_for_post( $generic_post_id ) );
|
||||
remove_filter( 'use_block_editor_for_post', '__return_false' );
|
||||
|
||||
add_filter( 'use_block_editor_for_post', '__return_true' );
|
||||
$this->assertTrue( use_block_editor_for_post( $restless_post_id ) );
|
||||
remove_filter( 'use_block_editor_for_post', '__return_true' );
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user