mirror of
https://github.com/WordPress/WordPress.git
synced 2025-01-08 17:38:26 +01:00
8ddb28368a
Adds `wp_theme_has_theme_json()` for public consumption, to replace the private internal Core-only `WP_Theme_JSON_Resolver::theme_has_support()` method. This new global function checks if a theme or its parent has a `theme.json` file. For performance, results are cached as an integer `1` or `0` in the `'theme_json'` group with `'wp_theme_has_theme_json'` key. This is a non-persistent cache. Why? To make the derived data from `theme.json` is always fresh from the potential modifications done via hooks that can use dynamic data (modify the stylesheet depending on some option, settings depending on user permissions, etc.). Also adds a new public function `wp_clean_theme_json_cache()` to clear the cache on `'switch_theme'` and `start_previewing_theme'`. References: * [https://github.com/WordPress/gutenberg/pull/45168 Gutenberg PR 45168] Add `wp_theme_has_theme_json` as a public API to know whether a theme has a `theme.json`. * [https://github.com/WordPress/gutenberg/pull/45380 Gutenberg PR 45380] Deprecate `WP_Theme_JSON_Resolver:theme_has_support()`. * [https://github.com/WordPress/gutenberg/pull/46150 Gutenberg PR 46150] Make `theme.json` object caches non-persistent. * [https://github.com/WordPress/gutenberg/pull/45979 Gutenberg PR 45979] Don't check if constants set by `wp_initial_constants()` are defined. * [https://github.com/WordPress/gutenberg/pull/45950 Gutenberg PR 45950] Cleaner logic in `wp_theme_has_theme_json`. Follow-up to [54493], [53282], [52744], [52049], [50959]. Props oandregal, afragen, alexstine, aristath, azaozz, costdev, flixos90, hellofromTonya, mamaduka, mcsf, ocean90, spacedmonkey. Fixes #56975. Built from https://develop.svn.wordpress.org/trunk@55086 git-svn-id: http://core.svn.wordpress.org/trunk@54619 1a063a9b-81f0-0310-95a4-ce76da25c4cd
166 lines
5.4 KiB
PHP
166 lines
5.4 KiB
PHP
<?php
|
|
/**
|
|
* Site Editor administration screen.
|
|
*
|
|
* @package WordPress
|
|
* @subpackage Administration
|
|
*/
|
|
|
|
global $editor_styles;
|
|
|
|
/** WordPress Administration Bootstrap */
|
|
require_once __DIR__ . '/admin.php';
|
|
|
|
if ( ! current_user_can( 'edit_theme_options' ) ) {
|
|
wp_die(
|
|
'<h1>' . __( 'You need a higher level of permission.' ) . '</h1>' .
|
|
'<p>' . __( 'Sorry, you are not allowed to edit theme options on this site.' ) . '</p>',
|
|
403
|
|
);
|
|
}
|
|
|
|
if ( ! ( current_theme_supports( 'block-template-parts' ) || wp_is_block_theme() ) ) {
|
|
wp_die( __( 'The theme you are currently using is not compatible with the Site Editor.' ) );
|
|
}
|
|
|
|
$is_template_part_editor = isset( $_GET['postType'] ) && 'wp_template_part' === sanitize_key( $_GET['postType'] );
|
|
if ( ! wp_is_block_theme() && ! $is_template_part_editor ) {
|
|
wp_die( __( 'The theme you are currently using is not compatible with the Site Editor.' ) );
|
|
}
|
|
|
|
/**
|
|
* Do a server-side redirection if missing `postType` and `postId`
|
|
* query args when visiting Site Editor.
|
|
*/
|
|
$home_template = _resolve_home_block_template();
|
|
if ( $home_template && empty( $_GET['postType'] ) && empty( $_GET['postId'] ) ) {
|
|
if ( ! empty( $_GET['styles'] ) ) {
|
|
$home_template['styles'] = sanitize_key( $_GET['styles'] );
|
|
}
|
|
$redirect_url = add_query_arg(
|
|
$home_template,
|
|
admin_url( 'site-editor.php' )
|
|
);
|
|
wp_safe_redirect( $redirect_url );
|
|
exit;
|
|
}
|
|
|
|
// Used in the HTML title tag.
|
|
$title = __( 'Editor (beta)' );
|
|
$parent_file = 'themes.php';
|
|
|
|
// Flag that we're loading the block editor.
|
|
$current_screen = get_current_screen();
|
|
$current_screen->is_block_editor( true );
|
|
|
|
// Default to is-fullscreen-mode to avoid jumps in the UI.
|
|
add_filter(
|
|
'admin_body_class',
|
|
static function( $classes ) {
|
|
return "$classes is-fullscreen-mode";
|
|
}
|
|
);
|
|
|
|
$indexed_template_types = array();
|
|
foreach ( get_default_block_template_types() as $slug => $template_type ) {
|
|
$template_type['slug'] = (string) $slug;
|
|
$indexed_template_types[] = $template_type;
|
|
}
|
|
|
|
$block_editor_context = new WP_Block_Editor_Context( array( 'name' => 'core/edit-site' ) );
|
|
$custom_settings = array(
|
|
'siteUrl' => site_url(),
|
|
'postsPerPage' => get_option( 'posts_per_page' ),
|
|
'styles' => get_block_editor_theme_styles(),
|
|
'defaultTemplateTypes' => $indexed_template_types,
|
|
'defaultTemplatePartAreas' => get_allowed_block_template_part_areas(),
|
|
'supportsLayout' => wp_theme_has_theme_json(),
|
|
'supportsTemplatePartsMode' => ! wp_is_block_theme() && current_theme_supports( 'block-template-parts' ),
|
|
'__unstableHomeTemplate' => $home_template,
|
|
);
|
|
|
|
/**
|
|
* Home template resolution is not needed when block template parts are supported.
|
|
* Set the value to `true` to satisfy the editor initialization guard clause.
|
|
*/
|
|
if ( $custom_settings['supportsTemplatePartsMode'] ) {
|
|
$custom_settings['__unstableHomeTemplate'] = true;
|
|
}
|
|
|
|
// Add additional back-compat patterns registered by `current_screen` et al.
|
|
$custom_settings['__experimentalAdditionalBlockPatterns'] = WP_Block_Patterns_Registry::get_instance()->get_all_registered( true );
|
|
$custom_settings['__experimentalAdditionalBlockPatternCategories'] = WP_Block_Pattern_Categories_Registry::get_instance()->get_all_registered( true );
|
|
|
|
$editor_settings = get_block_editor_settings( $custom_settings, $block_editor_context );
|
|
|
|
if ( isset( $_GET['postType'] ) && ! isset( $_GET['postId'] ) ) {
|
|
$post_type = get_post_type_object( $_GET['postType'] );
|
|
if ( ! $post_type ) {
|
|
wp_die( __( 'Invalid post type.' ) );
|
|
}
|
|
}
|
|
|
|
$active_global_styles_id = WP_Theme_JSON_Resolver::get_user_global_styles_post_id();
|
|
$active_theme = get_stylesheet();
|
|
$preload_paths = array(
|
|
array( '/wp/v2/media', 'OPTIONS' ),
|
|
'/wp/v2/types?context=view',
|
|
'/wp/v2/types/wp_template?context=edit',
|
|
'/wp/v2/types/wp_template-part?context=edit',
|
|
'/wp/v2/templates?context=edit&per_page=-1',
|
|
'/wp/v2/template-parts?context=edit&per_page=-1',
|
|
'/wp/v2/themes?context=edit&status=active',
|
|
'/wp/v2/global-styles/' . $active_global_styles_id . '?context=edit',
|
|
'/wp/v2/global-styles/' . $active_global_styles_id,
|
|
'/wp/v2/global-styles/themes/' . $active_theme,
|
|
);
|
|
|
|
block_editor_rest_api_preload( $preload_paths, $block_editor_context );
|
|
|
|
wp_add_inline_script(
|
|
'wp-edit-site',
|
|
sprintf(
|
|
'wp.domReady( function() {
|
|
wp.editSite.initializeEditor( "site-editor", %s );
|
|
} );',
|
|
wp_json_encode( $editor_settings )
|
|
)
|
|
);
|
|
|
|
// Preload server-registered block schemas.
|
|
wp_add_inline_script(
|
|
'wp-blocks',
|
|
'wp.blocks.unstable__bootstrapServerSideBlockDefinitions(' . wp_json_encode( get_block_editor_server_block_settings() ) . ');'
|
|
);
|
|
|
|
wp_add_inline_script(
|
|
'wp-blocks',
|
|
sprintf( 'wp.blocks.setCategories( %s );', wp_json_encode( isset( $editor_settings['blockCategories'] ) ? $editor_settings['blockCategories'] : array() ) ),
|
|
'after'
|
|
);
|
|
|
|
wp_enqueue_script( 'wp-edit-site' );
|
|
wp_enqueue_script( 'wp-format-library' );
|
|
wp_enqueue_style( 'wp-edit-site' );
|
|
wp_enqueue_style( 'wp-format-library' );
|
|
wp_enqueue_media();
|
|
|
|
if (
|
|
current_theme_supports( 'wp-block-styles' ) ||
|
|
( ! is_array( $editor_styles ) || count( $editor_styles ) === 0 )
|
|
) {
|
|
wp_enqueue_style( 'wp-block-library-theme' );
|
|
}
|
|
|
|
/** This action is documented in wp-admin/edit-form-blocks.php */
|
|
do_action( 'enqueue_block_editor_assets' );
|
|
|
|
require_once ABSPATH . 'wp-admin/admin-header.php';
|
|
?>
|
|
|
|
<div id="site-editor" class="edit-site"></div>
|
|
|
|
<?php
|
|
|
|
require_once ABSPATH . 'wp-admin/admin-footer.php';
|