Skip to content

Commit

Permalink
Inserter: Should receive focus on open (WordPress#67754)
Browse files Browse the repository at this point in the history
* Set default tab to 'blocks' if none passed
* Add tests for focusing blocks tab and closing inserter on keypresses
  • Loading branch information
jeryj authored and yogeshbhutkar committed Dec 18, 2024
1 parent 7d3fa75 commit b4e2222
Show file tree
Hide file tree
Showing 2 changed files with 38 additions and 17 deletions.
2 changes: 2 additions & 0 deletions packages/block-editor/src/components/inserter/menu.js
Original file line number Diff line number Diff line change
Expand Up @@ -82,6 +82,8 @@ function InserterMenu(
if ( isZoomOutMode ) {
return 'patterns';
}

return 'blocks';
}
const [ selectedTab, setSelectedTab ] = useState( getInitialTab() );

Expand Down
53 changes: 36 additions & 17 deletions test/e2e/specs/site-editor/site-editor-inserter.spec.js
Original file line number Diff line number Diff line change
Expand Up @@ -28,32 +28,51 @@ test.describe( 'Site Editor Inserter', () => {
},
} );

// eslint-disable-next-line playwright/expect-expect
test( 'inserter toggle button should toggle global inserter', async ( {
InserterUtils,
page,
editor,
} ) => {
await InserterUtils.openBlockLibrary();
await InserterUtils.closeBlockLibrary();
} );

// A test for https://github.com/WordPress/gutenberg/issues/43090.
test( 'should close the inserter when clicking on the toggle button', async ( {
editor,
InserterUtils,
} ) => {
const beforeBlocks = await editor.getBlocks();
await test.step( 'should open the inserter via enter keypress on toggle button', async () => {
await InserterUtils.inserterButton.focus();
await page.keyboard.press( 'Enter' );
await expect( InserterUtils.blockLibrary ).toBeVisible();
} );

await InserterUtils.openBlockLibrary();
await InserterUtils.expectActiveTab( 'Blocks' );
await InserterUtils.blockLibrary
.getByRole( 'option', { name: 'Buttons' } )
.click();
await test.step( 'should set focus to the blocks tab when opening the inserter', async () => {
await expect(
InserterUtils.getBlockLibraryTab( 'Blocks' )
).toBeFocused();
} );

await test.step( 'should close the inserter via escape keypress', async () => {
await page.keyboard.press( 'Escape' );
await expect( InserterUtils.blockLibrary ).toBeHidden();
} );

await expect
.poll( editor.getBlocks )
.toMatchObject( [ ...beforeBlocks, { name: 'core/buttons' } ] );
await test.step( 'should focus inserter toggle button after closing the inserter via escape keypress', async () => {
await expect( InserterUtils.inserterButton ).toBeFocused();
} );

await InserterUtils.closeBlockLibrary();
// A test for https://github.com/WordPress/gutenberg/issues/43090.
await test.step( 'should close the inserter when clicking on the toggle button', async () => {
const beforeBlocks = await editor.getBlocks();

await InserterUtils.openBlockLibrary();
await InserterUtils.expectActiveTab( 'Blocks' );
await InserterUtils.blockLibrary
.getByRole( 'option', { name: 'Buttons' } )
.click();

await expect
.poll( editor.getBlocks )
.toMatchObject( [ ...beforeBlocks, { name: 'core/buttons' } ] );

await InserterUtils.closeBlockLibrary();
} );
} );

test.describe( 'Inserter Zoom Level UX', () => {
Expand Down

0 comments on commit b4e2222

Please sign in to comment.