Skip to content

Commit

Permalink
Fix navigate regions backwards for macOS Firefox and Safari. (#45019)
Browse files Browse the repository at this point in the history
* Fix navigate regions backwards for macOS Firefox and Safari.

* Add changelog entry.

* Add Playwright E2E for catching regressions in all 3 browsers.

* Adjust the test to cover browsers event.key inconsistency.

* Fix typo and add link to PR.

Co-authored-by: Alex Stine <alex.stine@yourtechadvisors.com>
Co-authored-by: Marco Ciampini <marco.ciampo@gmail.com>
  • Loading branch information
3 people authored Nov 7, 2022
1 parent d8731ed commit 4a71aae
Show file tree
Hide file tree
Showing 7 changed files with 73 additions and 0 deletions.
1 change: 1 addition & 0 deletions packages/components/CHANGELOG.md
Original file line number Diff line number Diff line change
Expand Up @@ -48,6 +48,7 @@

### Bug Fix

- `useNavigateRegions`: Add new keyboard shortcut alias to cover backtick and tilde keys inconsistencies across browsers ([#45019](https://github.com/WordPress/gutenberg/pull/45019)).
- `Button`: Tweak the destructive button primary, link, and default variants ([#44427](https://github.com/WordPress/gutenberg/pull/44427)).
- `UnitControl`: Fix `disabled` style is overridden by core `form.css` style ([#45250](https://github.com/WordPress/gutenberg/pull/45250)).
- `ItemGroup`: fix RTL `Item` styles when rendered as a button ([#45280](https://github.com/WordPress/gutenberg/pull/45280)).
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -15,6 +15,10 @@ const defaultShortcuts = {
modifier: 'ctrlShift',
character: '`',
},
{
modifier: 'ctrlShift',
character: '~',
},
{
modifier: 'access',
character: 'p',
Expand Down
4 changes: 4 additions & 0 deletions packages/edit-post/src/components/keyboard-shortcuts/index.js
Original file line number Diff line number Diff line change
Expand Up @@ -133,6 +133,10 @@ function KeyboardShortcuts() {
modifier: 'access',
character: 'p',
},
{
modifier: 'ctrlShift',
character: '~',
},
],
} );

Expand Down
4 changes: 4 additions & 0 deletions packages/edit-site/src/components/keyboard-shortcuts/index.js
Original file line number Diff line number Diff line change
Expand Up @@ -180,6 +180,10 @@ function KeyboardShortcutsRegister() {
modifier: 'access',
character: 'p',
},
{
modifier: 'ctrlShift',
character: '~',
},
],
} );
registerShortcut( {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -39,6 +39,10 @@ export default function useRegisterShortcuts() {
modifier: 'access',
character: 'p',
},
{
modifier: 'ctrlShift',
character: '~',
},
],
} );
}, [] );
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -110,6 +110,10 @@ function KeyboardShortcutsRegister() {
modifier: 'access',
character: 'p',
},
{
modifier: 'ctrlShift',
character: '~',
},
],
} );
}, [ registerShortcut ] );
Expand Down
52 changes: 52 additions & 0 deletions test/e2e/specs/editor/various/a11y-region-navigation.spec.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,52 @@
/**
* WordPress dependencies
*/
const { test, expect } = require( '@wordpress/e2e-test-utils-playwright' );

test.describe( 'Region navigation (@firefox, @webkit)', () => {
test.beforeEach( async ( { admin } ) => {
await admin.createNewPost();
} );

test.afterAll( async ( { requestUtils } ) => {
await requestUtils.deleteAllPosts();
} );

test( 'navigates forward and back again', async ( {
editor,
page,
}, testInfo ) => {
// Insert a paragraph block.
await editor.insertBlock( {
name: 'core/paragraph',
attributes: { content: 'Dummy text' },
} );

// Navigate to first region and check that we made it.
await page.keyboard.press( 'Control+`' );
const editorTopBar = page.locator(
'role=region[name="Editor top bar"i]'
);
await expect( editorTopBar ).toBeFocused();

// Navigate to next/second region and check that we made it.
await page.keyboard.press( 'Control+`' );
const editorContent = page.locator(
'role=region[name="Editor content"i]'
);
await expect( editorContent ).toBeFocused();

// Navigate to previous/first region and check that we made it.
// Make sure navigating backwards works also with the tilde character,
// as browsers interpret the combination of the crtl+shift+backtick keys
// and assign it to event.key inconsistently.
// See https://github.com/WordPress/gutenberg/pull/45019
if ( testInfo.project.name === 'chromium' ) {
await page.keyboard.press( 'Control+Shift+`' );
} else {
await page.keyboard.press( 'Control+Shift+~' );
}

await expect( editorTopBar ).toBeFocused();
} );
} );

0 comments on commit 4a71aae

Please sign in to comment.