From c9e4e1776b9fc514521088a7bab0b71ee01f66d2 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Andr=C3=A9?= <583546+oandregal@users.noreply.github.com> Date: Wed, 23 Mar 2022 16:11:09 +0100 Subject: [PATCH] Quote v2: bootstrap --- lib/compat/experimental/blocks.php | 10 +++++++--- lib/experiments-page.php | 11 +++++++++++ packages/block-library/src/quote/index.js | 7 ++++++- packages/block-library/src/quote/v2/edit.js | 5 +++++ packages/block-library/src/quote/v2/index.js | 18 ++++++++++++++++++ packages/block-library/src/quote/v2/save.js | 5 +++++ 6 files changed, 52 insertions(+), 4 deletions(-) create mode 100644 packages/block-library/src/quote/v2/edit.js create mode 100644 packages/block-library/src/quote/v2/index.js create mode 100644 packages/block-library/src/quote/v2/save.js diff --git a/lib/compat/experimental/blocks.php b/lib/compat/experimental/blocks.php index fbd109ec18103..030963305cb2e 100644 --- a/lib/compat/experimental/blocks.php +++ b/lib/compat/experimental/blocks.php @@ -166,12 +166,16 @@ function ( $response ) { add_action( 'rest_api_init', 'gutenberg_rest_comment_set_children_as_embeddable' ); /** - * Sets a global JS variable used to trigger the availability of the experimental list block. + * Sets a global JS variable used to trigger the availability of the experimental blocks. */ -function gutenberg_enable_experimental_list_block() { +function gutenberg_enable_experimental_blocks() { if ( get_option( 'gutenberg-experiments' ) && array_key_exists( 'gutenberg-list-v2', get_option( 'gutenberg-experiments' ) ) ) { wp_add_inline_script( 'wp-block-library', 'window.__experimentalEnableListBlockV2 = true', 'before' ); } + + if ( get_option( 'gutenberg-experiments' ) && array_key_exists( 'gutenberg-quote-v2', get_option( 'gutenberg-experiments' ) ) ) { + wp_add_inline_script( 'wp-block-library', 'window.__experimentalEnableQuoteBlockV2 = true', 'before' ); + } } -add_action( 'admin_init', 'gutenberg_enable_experimental_list_block' ); +add_action( 'admin_init', 'gutenberg_enable_experimental_blocks' ); diff --git a/lib/experiments-page.php b/lib/experiments-page.php index a0aabb3f3ec6b..23a6af6207941 100644 --- a/lib/experiments-page.php +++ b/lib/experiments-page.php @@ -62,6 +62,17 @@ function gutenberg_initialize_experiments_settings() { 'id' => 'gutenberg-list-v2', ) ); + add_settings_field( + 'gutenberg-quote-v2', + __( 'Quote block v2', 'gutenberg' ), + 'gutenberg_display_experiment_field', + 'gutenberg-experiments', + 'gutenberg_experiments_section', + array( + 'label' => __( 'Test a new quote block that allows nested blocks (Warning: The new block is not ready. You may experience content loss, avoid using it on production sites)', 'gutenberg' ), + 'id' => 'gutenberg-quote-v2', + ) + ); register_setting( 'gutenberg-experiments', 'gutenberg-experiments' diff --git a/packages/block-library/src/quote/index.js b/packages/block-library/src/quote/index.js index 621365a46abbe..13876d46974b9 100644 --- a/packages/block-library/src/quote/index.js +++ b/packages/block-library/src/quote/index.js @@ -12,12 +12,13 @@ import edit from './edit'; import metadata from './block.json'; import save from './save'; import transforms from './transforms'; +import settingsV2 from './v2'; const { name } = metadata; export { metadata, name }; -export const settings = { +export const settingsV1 = { icon, example: { attributes: { @@ -51,3 +52,7 @@ export const settings = { }, deprecated, }; + +export const settings = window?.__experimentalEnableQuoteBlockV2 + ? settingsV2 + : settingsV1; diff --git a/packages/block-library/src/quote/v2/edit.js b/packages/block-library/src/quote/v2/edit.js new file mode 100644 index 0000000000000..d64d4b36538ef --- /dev/null +++ b/packages/block-library/src/quote/v2/edit.js @@ -0,0 +1,5 @@ +function Edit() { + return
Quote block v2
; +} + +export default Edit; diff --git a/packages/block-library/src/quote/v2/index.js b/packages/block-library/src/quote/v2/index.js new file mode 100644 index 0000000000000..c142bf957c6de --- /dev/null +++ b/packages/block-library/src/quote/v2/index.js @@ -0,0 +1,18 @@ +/** + * WordPress dependencies + */ +import { quote as icon } from '@wordpress/icons'; + +/** + * Internal dependencies + */ +import edit from './edit'; +import save from './save'; + +const settings = { + icon, + edit, + save, +}; + +export default settings; diff --git a/packages/block-library/src/quote/v2/save.js b/packages/block-library/src/quote/v2/save.js new file mode 100644 index 0000000000000..1a851b19b2959 --- /dev/null +++ b/packages/block-library/src/quote/v2/save.js @@ -0,0 +1,5 @@ +function Save() { + return
Quote block v2
; +} + +export default Save;