mirror of
https://github.com/WordPress/WordPress.git
synced 2025-01-22 00:01:27 +01:00
General: add block theme previews.
Adds a preview link to block themes in the themes screen, opening the previews in the site editor. Props onemaggie, andraganescu, audrasjb, flixos90, peterwilsoncc, spacedmonkey, scruffian. Fixes #58561. Built from https://develop.svn.wordpress.org/trunk@56059 git-svn-id: http://core.svn.wordpress.org/trunk@55571 1a063a9b-81f0-0310-95a4-ce76da25c4cd
This commit is contained in:
parent
d9e41aa9e9
commit
fbbe0f0a76
@ -168,3 +168,10 @@ add_action( 'post_updated', array( 'WP_Privacy_Policy_Content', '_policy_page_up
|
||||
|
||||
// Append '(Draft)' to draft page titles in the privacy page dropdown.
|
||||
add_filter( 'list_pages', '_wp_privacy_settings_filter_draft_page_titles', 10, 2 );
|
||||
|
||||
// Attaches filters to enable theme previews in the Site Editor.
|
||||
if ( ! empty( $_GET['wp_theme_preview'] ) ) {
|
||||
add_filter( 'stylesheet', 'wp_get_theme_preview_path' );
|
||||
add_filter( 'template', 'wp_get_theme_preview_path' );
|
||||
add_action( 'init', 'wp_attach_theme_preview_middleware' );
|
||||
}
|
||||
|
@ -71,6 +71,7 @@ require_once ABSPATH . 'wp-admin/includes/list-table.php';
|
||||
|
||||
/** WordPress Theme Administration API */
|
||||
require_once ABSPATH . 'wp-admin/includes/theme.php';
|
||||
require_once ABSPATH . 'wp-admin/includes/theme-previews.php';
|
||||
|
||||
/** WordPress Privacy Functions */
|
||||
require_once ABSPATH . 'wp-admin/includes/privacy-tools.php';
|
||||
|
56
wp-admin/includes/theme-previews.php
Normal file
56
wp-admin/includes/theme-previews.php
Normal file
@ -0,0 +1,56 @@
|
||||
<?php
|
||||
/**
|
||||
* Theme previews using the Site Editor for block themes.
|
||||
*
|
||||
* @package WordPress
|
||||
*/
|
||||
|
||||
/**
|
||||
* Filters the blog option to return the path for the previewed theme.
|
||||
*
|
||||
* @since 6.3.0
|
||||
*
|
||||
* @param string $current_stylesheet The current theme's stylesheet or template path.
|
||||
* @return string The previewed theme's stylesheet or template path.
|
||||
*/
|
||||
function wp_get_theme_preview_path( $current_stylesheet = null ) {
|
||||
if ( ! current_user_can( 'switch_themes' ) ) {
|
||||
return $current_stylesheet;
|
||||
}
|
||||
|
||||
$preview_stylesheet = ! empty( $_GET['wp_theme_preview'] ) ? sanitize_text_field( wp_unslash( $_GET['wp_theme_preview'] ) ) : null;
|
||||
$wp_theme = wp_get_theme( $preview_stylesheet );
|
||||
if ( ! is_wp_error( $wp_theme->errors() ) ) {
|
||||
if ( current_filter() === 'template' ) {
|
||||
$theme_path = $wp_theme->get_template();
|
||||
} else {
|
||||
$theme_path = $wp_theme->get_stylesheet();
|
||||
}
|
||||
|
||||
return sanitize_text_field( $theme_path );
|
||||
}
|
||||
|
||||
return $current_stylesheet;
|
||||
}
|
||||
|
||||
/**
|
||||
* Adds a middleware to `apiFetch` to set the theme for the preview.
|
||||
* This adds a `wp_theme_preview` URL parameter to API requests from the Site Editor, so they also respond as if the theme is set to the value of the parameter.
|
||||
*
|
||||
* @since 6.3.0
|
||||
*/
|
||||
function wp_attach_theme_preview_middleware() {
|
||||
// Don't allow non-admins to preview themes.
|
||||
if ( ! current_user_can( 'switch_themes' ) ) {
|
||||
return;
|
||||
}
|
||||
|
||||
wp_add_inline_script(
|
||||
'wp-api-fetch',
|
||||
sprintf(
|
||||
'wp.apiFetch.use( wp.apiFetch.createThemePreviewMiddleware( %s ) );',
|
||||
wp_json_encode( sanitize_text_field( wp_unslash( $_GET['wp_theme_preview'] ) ) )
|
||||
),
|
||||
'after'
|
||||
);
|
||||
}
|
@ -711,16 +711,21 @@ function wp_prepare_themes_for_js( $themes = null ) {
|
||||
$is_block_theme = $theme->is_block_theme();
|
||||
|
||||
if ( $is_block_theme && $can_edit_theme_options ) {
|
||||
$customize_action = esc_url( admin_url( 'site-editor.php' ) );
|
||||
$customize_action = admin_url( 'site-editor.php' );
|
||||
if ( $current_theme !== $slug ) {
|
||||
$customize_action = add_query_arg( 'wp_theme_preview', $slug, $customize_action );
|
||||
}
|
||||
} elseif ( ! $is_block_theme && $can_customize && $can_edit_theme_options ) {
|
||||
$customize_action = esc_url(
|
||||
add_query_arg(
|
||||
array(
|
||||
'return' => urlencode( sanitize_url( remove_query_arg( wp_removable_query_args(), wp_unslash( $_SERVER['REQUEST_URI'] ) ) ) ),
|
||||
),
|
||||
wp_customize_url( $slug )
|
||||
)
|
||||
$customize_action = wp_customize_url( $slug );
|
||||
}
|
||||
if ( null !== $customize_action ) {
|
||||
$customize_action = add_query_arg(
|
||||
array(
|
||||
'return' => urlencode( sanitize_url( remove_query_arg( wp_removable_query_args(), wp_unslash( $_SERVER['REQUEST_URI'] ) ) ) ),
|
||||
),
|
||||
$customize_action
|
||||
);
|
||||
$customize_action = esc_url( $customize_action );
|
||||
}
|
||||
|
||||
$update_requires_wp = isset( $updates[ $slug ]['requires'] ) ? $updates[ $slug ]['requires'] : null;
|
||||
|
@ -555,7 +555,8 @@ foreach ( $themes as $theme ) :
|
||||
?>
|
||||
<a class="button activate" href="<?php echo $theme['actions']['activate']; ?>" aria-label="<?php echo esc_attr( $aria_label ); ?>"><?php _e( 'Activate' ); ?></a>
|
||||
<?php
|
||||
if ( ! $theme['blockTheme'] && current_user_can( 'edit_theme_options' ) && current_user_can( 'customize' ) ) {
|
||||
// Only classic themes require the "customize" capability.
|
||||
if ( current_user_can( 'edit_theme_options' ) && ( $theme['blockTheme'] || current_user_can( 'customize' ) ) ) {
|
||||
/* translators: %s: Theme name. */
|
||||
$live_preview_aria_label = sprintf( _x( 'Live Preview %s', 'theme' ), '{{ data.name }}' );
|
||||
?>
|
||||
@ -914,13 +915,11 @@ function wp_theme_auto_update_setting_template() {
|
||||
$aria_label = sprintf( _x( 'Activate %s', 'theme' ), '{{ data.name }}' );
|
||||
?>
|
||||
<a class="button activate" href="{{{ data.actions.activate }}}" aria-label="<?php echo esc_attr( $aria_label ); ?>"><?php _e( 'Activate' ); ?></a>
|
||||
<# if ( ! data.blockTheme ) { #>
|
||||
<?php
|
||||
/* translators: %s: Theme name. */
|
||||
$live_preview_aria_label = sprintf( _x( 'Live Preview %s', 'theme' ), '{{ data.name }}' );
|
||||
?>
|
||||
<a aria-label="<?php echo esc_attr( $live_preview_aria_label ); ?>" class="button button-primary load-customize hide-if-no-customize" href="{{{ data.actions.customize }}}"><?php _e( 'Live Preview' ); ?></a>
|
||||
<# } #>
|
||||
<?php
|
||||
/* translators: %s: Theme name. */
|
||||
$live_preview_aria_label = sprintf( _x( 'Live Preview %s', 'theme' ), '{{ data.name }}' );
|
||||
?>
|
||||
<a aria-label="<?php echo esc_attr( $live_preview_aria_label ); ?>" class="button button-primary load-customize hide-if-no-customize" href="{{{ data.actions.customize }}}"><?php _e( 'Live Preview' ); ?></a>
|
||||
<# } else { #>
|
||||
<?php
|
||||
/* translators: %s: Theme name. */
|
||||
|
@ -16,7 +16,7 @@
|
||||
*
|
||||
* @global string $wp_version
|
||||
*/
|
||||
$wp_version = '6.3-alpha-56058';
|
||||
$wp_version = '6.3-alpha-56059';
|
||||
|
||||
/**
|
||||
* Holds the WordPress DB revision, increments when changes are made to the WordPress DB schema.
|
||||
|
Loading…
Reference in New Issue
Block a user