From 5c0fbe03eaf9aa187a692220f537e9e53073b834 Mon Sep 17 00:00:00 2001 From: Andrew Duthie Date: Fri, 25 Jan 2019 16:33:24 -0500 Subject: [PATCH] Plugin: Deprecate gutenberg_prepare_blocks_for_js (#13457) --- .../backward-compatibility/deprecations.md | 1 + lib/client-assets.php | 24 +++---------- phpunit/class-prepare-for-js-test.php | 34 ------------------- 3 files changed, 6 insertions(+), 53 deletions(-) delete mode 100644 phpunit/class-prepare-for-js-test.php diff --git a/docs/designers-developers/developers/backward-compatibility/deprecations.md b/docs/designers-developers/developers/backward-compatibility/deprecations.md index 12b1771484923d..b5df2462e10500 100644 --- a/docs/designers-developers/developers/backward-compatibility/deprecations.md +++ b/docs/designers-developers/developers/backward-compatibility/deprecations.md @@ -35,6 +35,7 @@ The Gutenberg project's deprecation policy is intended to support backward compa - The PHP function `register_tinymce_scripts` has been removed. Use [`wp_register_tinymce_scripts`](https://developer.wordpress.org/reference/functions/wp_register_tinymce_scripts/) instead. - The PHP function `gutenberg_register_post_types` has been removed. - The `gutenberg` theme support option has been removed. Use [`align-wide`](https://wordpress.org/gutenberg/handbook/designers-developers/developers/themes/theme-support/#wide-alignment) instead. +- The PHP function `gutenberg_prepare_blocks_for_js` has been removed. Use [`get_block_editor_server_block_settings`](https://developer.wordpress.org/reference/functions/get_block_editor_server_block_settings/) instead. ## 4.5.0 - `Dropdown.refresh()` has been deprecated as the contained `Popover` is now automatically refreshed. diff --git a/lib/client-assets.php b/lib/client-assets.php index f072ee348402a5..d33ebdd12fe939 100644 --- a/lib/client-assets.php +++ b/lib/client-assets.php @@ -702,28 +702,14 @@ function gutenberg_register_vendor_script( $handle, $src, $deps = array() ) { * array of registered block data keyed by block name. Data includes properties * of a block relevant for client registration. * + * @deprecated 5.0.0 get_block_editor_server_block_settings + * * @return array An associative array of registered block data. */ function gutenberg_prepare_blocks_for_js() { - $block_registry = WP_Block_Type_Registry::get_instance(); - $blocks = array(); - $keys_to_pick = array( 'title', 'description', 'icon', 'category', 'keywords', 'supports', 'attributes' ); - - foreach ( $block_registry->get_all_registered() as $block_name => $block_type ) { - foreach ( $keys_to_pick as $key ) { - if ( ! isset( $block_type->{ $key } ) ) { - continue; - } - - if ( ! isset( $blocks[ $block_name ] ) ) { - $blocks[ $block_name ] = array(); - } - - $blocks[ $block_name ][ $key ] = $block_type->{ $key }; - } - } + _deprecated_function( __FUNCTION__, '5.0.0', 'get_block_editor_server_block_settings' ); - return $blocks; + return get_block_editor_server_block_settings(); } /** @@ -1081,7 +1067,7 @@ function gutenberg_editor_scripts_and_styles( $hook ) { // Preload server-registered block schemas. wp_add_inline_script( 'wp-blocks', - 'wp.blocks.unstable__bootstrapServerSideBlockDefinitions(' . json_encode( gutenberg_prepare_blocks_for_js() ) . ');' + 'wp.blocks.unstable__bootstrapServerSideBlockDefinitions(' . json_encode( get_block_editor_server_block_settings() ) . ');' ); // Get admin url for handling meta boxes. diff --git a/phpunit/class-prepare-for-js-test.php b/phpunit/class-prepare-for-js-test.php deleted file mode 100644 index 38dceb8fec6df4..00000000000000 --- a/phpunit/class-prepare-for-js-test.php +++ /dev/null @@ -1,34 +0,0 @@ -unregister( 'core/dummy' ); - } - - function test_gutenberg_prepare_blocks_for_js() { - $name = 'core/dummy'; - $settings = array( - 'icon' => 'text', - 'render_callback' => 'foo', - ); - - register_block_type( $name, $settings ); - - $blocks = gutenberg_prepare_blocks_for_js(); - - $this->assertArrayHasKey( $name, $blocks ); - $this->assertSame( array( 'icon' => 'text' ), $blocks[ $name ] ); - } -}