diff --git a/lib/experimental/editor-settings.php b/lib/experimental/editor-settings.php index 67e08265558e1f..f0b16eeb7f257a 100644 --- a/lib/experimental/editor-settings.php +++ b/lib/experimental/editor-settings.php @@ -89,6 +89,9 @@ function gutenberg_enable_experiments() { if ( $gutenberg_experiments && array_key_exists( 'gutenberg-pattern-enhancements', $gutenberg_experiments ) ) { wp_add_inline_script( 'wp-block-editor', 'window.__experimentalEnablePatternEnhancements = true', 'before' ); } + if ( $gutenberg_experiments && array_key_exists( 'gutenberg-interactivity-api-core-blocks', $gutenberg_experiments ) ) { + wp_add_inline_script( 'wp-block-editor', 'window.__experimentalInteractivityAPI = true', 'before' ); + } } diff --git a/packages/block-editor/src/hooks/behaviors.js b/packages/block-editor/src/hooks/behaviors.js index 7c2c0164640b29..8e6ce479f174d1 100644 --- a/packages/block-editor/src/hooks/behaviors.js +++ b/packages/block-editor/src/hooks/behaviors.js @@ -38,7 +38,6 @@ export const withBehaviors = createHigherOrderComponent( ( BlockEdit ) => { const settings = select( blockEditorStore ).getSettings()?.__experimentalFeatures ?.blocks?.[ props.name ]?.behaviors; - if ( ! settings || // If every behavior is disabled, do not show the behaviors inspector control. @@ -102,8 +101,10 @@ export const withBehaviors = createHigherOrderComponent( ( BlockEdit ) => { }; }, 'withBehaviors' ); -addFilter( - 'editor.BlockEdit', - 'core/behaviors/with-inspector-control', - withBehaviors -); +if ( window?.__experimentalInteractivityAPI ) { + addFilter( + 'editor.BlockEdit', + 'core/behaviors/with-inspector-control', + withBehaviors + ); +} diff --git a/test/e2e/specs/editor/various/behaviors.spec.js b/test/e2e/specs/editor/various/behaviors.spec.js index 1559723a944bda..12be68b8f94793 100644 --- a/test/e2e/specs/editor/various/behaviors.spec.js +++ b/test/e2e/specs/editor/various/behaviors.spec.js @@ -21,9 +21,32 @@ test.describe( 'Testing behaviors functionality', () => { await requestUtils.activateTheme( 'twentytwentyone' ); await requestUtils.deleteAllPosts(); } ); + test.beforeEach( async ( { admin, page, requestUtils } ) => { + await requestUtils.deleteAllMedia(); + await admin.visitAdminPage( + '/admin.php', + 'page=gutenberg-experiments' + ); + + await page + .locator( `#gutenberg-interactivity-api-core-blocks` ) + .setChecked( true ); + await page.locator( `input[name="submit"]` ).click(); + await page.waitForLoadState(); + } ); - test.afterEach( async ( { requestUtils } ) => { + test.afterEach( async ( { admin, page, requestUtils } ) => { await requestUtils.deleteAllMedia(); + await admin.visitAdminPage( + '/admin.php', + 'page=gutenberg-experiments' + ); + + await page + .locator( `#gutenberg-interactivity-api-core-blocks` ) + .setChecked( false ); + await page.locator( `input[name="submit"]` ).click(); + await page.waitForLoadState(); } ); test( '`No Behaviors` should be the default as defined in the core theme.json', async ( {