mirror of
https://github.com/WordPress/WordPress.git
synced 2025-01-11 02:49:04 +01:00
c1fa1f8b21
In core, you can run `tests/gutenberg/run.js` script to run the Gutenberg e2e tests against Core with the plugin being disabled. This test ensures that the integration of the block editor with Core is working properly. This commit updates the Gutenberg base branch to be used for the tests to be wp/trunk which corresponds to the latest packages that are included in Core. See #52991. Built from https://develop.svn.wordpress.org/trunk@51052 git-svn-id: http://core.svn.wordpress.org/trunk@50661 1a063a9b-81f0-0310-95a4-ce76da25c4cd
114 lines
2.8 KiB
PHP
114 lines
2.8 KiB
PHP
<?php
|
|
/**
|
|
* Server-side rendering of the `core/legacy-widget` block.
|
|
*
|
|
* @package WordPress
|
|
*/
|
|
|
|
/**
|
|
* Renders the 'core/legacy-widget' block.
|
|
*
|
|
* @param array $attributes The block attributes.
|
|
*
|
|
* @return string Rendered block.
|
|
*/
|
|
function render_block_core_legacy_widget( $attributes ) {
|
|
global $wp_widget_factory;
|
|
|
|
if ( isset( $attributes['id'] ) ) {
|
|
$sidebar_id = wp_find_widgets_sidebar( $attributes['id'] );
|
|
return wp_render_widget( $attributes['id'], $sidebar_id );
|
|
}
|
|
|
|
if ( ! isset( $attributes['idBase'] ) ) {
|
|
return '';
|
|
}
|
|
|
|
if ( method_exists( $wp_widget_factory, 'get_widget_object' ) ) {
|
|
$widget_object = $wp_widget_factory->get_widget_object( $attributes['idBase'] );
|
|
} else {
|
|
$widget_object = gutenberg_get_widget_object( $attributes['idBase'] );
|
|
}
|
|
|
|
if ( ! $widget_object ) {
|
|
return '';
|
|
}
|
|
|
|
if ( isset( $attributes['instance']['encoded'], $attributes['instance']['hash'] ) ) {
|
|
$serialized_instance = base64_decode( $attributes['instance']['encoded'] );
|
|
if ( wp_hash( $serialized_instance ) !== $attributes['instance']['hash'] ) {
|
|
return '';
|
|
}
|
|
$instance = unserialize( $serialized_instance );
|
|
} else {
|
|
$instance = array();
|
|
}
|
|
|
|
ob_start();
|
|
the_widget( get_class( $widget_object ), $instance );
|
|
return ob_get_clean();
|
|
}
|
|
|
|
/**
|
|
* On application init this does two things:
|
|
*
|
|
* - Registers the 'core/legacy-widget' block.
|
|
* - Intercepts any request with legacy-widget-preview in the query param and,
|
|
* if set, renders a page containing a preview of the requested Legacy Widget
|
|
* block.
|
|
*/
|
|
function init_legacy_widget_block() {
|
|
register_block_type_from_metadata(
|
|
__DIR__ . '/legacy-widget',
|
|
array(
|
|
'render_callback' => 'render_block_core_legacy_widget',
|
|
)
|
|
);
|
|
|
|
if ( empty( $_GET['legacy-widget-preview'] ) ) {
|
|
return;
|
|
}
|
|
|
|
if ( ! current_user_can( 'edit_theme_options' ) ) {
|
|
return;
|
|
}
|
|
|
|
define( 'IFRAME_REQUEST', true );
|
|
|
|
?>
|
|
<!doctype html>
|
|
<html <?php language_attributes(); ?>>
|
|
<head>
|
|
<meta charset="<?php bloginfo( 'charset' ); ?>" />
|
|
<meta name="viewport" content="width=device-width, initial-scale=1" />
|
|
<link rel="profile" href="https://gmpg.org/xfn/11" />
|
|
<?php wp_head(); ?>
|
|
<style>
|
|
/* Reset theme styles */
|
|
html, body, #page, #content {
|
|
background: #FFF !important;
|
|
padding: 0 !important;
|
|
margin: 0 !important;
|
|
}
|
|
</style>
|
|
</head>
|
|
<body <?php body_class(); ?>>
|
|
<div id="page" class="site">
|
|
<div id="content" class="site-content">
|
|
<?php
|
|
$registry = WP_Block_Type_Registry::get_instance();
|
|
$block = $registry->get_registered( 'core/legacy-widget' );
|
|
echo $block->render( $_GET['legacy-widget-preview'] );
|
|
?>
|
|
</div><!-- #content -->
|
|
</div><!-- #page -->
|
|
<?php wp_footer(); ?>
|
|
</body>
|
|
</html>
|
|
<?php
|
|
|
|
exit;
|
|
}
|
|
|
|
add_action( 'init', 'init_legacy_widget_block' );
|