Skip to content

Commit

Permalink
implement feedback
Browse files Browse the repository at this point in the history
  • Loading branch information
chad1008 committed Jan 17, 2024
1 parent 8c086f2 commit 1c3a994
Show file tree
Hide file tree
Showing 2 changed files with 75 additions and 58 deletions.
1 change: 1 addition & 0 deletions packages/components/src/tabs/index.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -174,6 +174,7 @@ function Tabs( {
return activeElement === item.element;
} );
const previousSelectedTabHadFocus =
typeof previousSelectedId === 'string' &&
previousSelectedId === activeElement?.id;

// If the previously selected tab had focus when the selection changed,
Expand Down
132 changes: 74 additions & 58 deletions packages/components/src/tabs/test/index.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -14,6 +14,7 @@ import { useEffect, useState } from '@wordpress/element';
*/
import Tabs from '..';
import type { TabsProps } from '../types';
import { act } from 'react-dom/test-utils';

type Tab = {
tabId: string;
Expand Down Expand Up @@ -1173,64 +1174,79 @@ describe( 'Tabs', () => {
} );
} );
describe( 'When `selectedId` is changed by the controlling component', () => {
it( 'should automatically update focus if the selected tab already had focus', async () => {
const { rerender } = render(
<ControlledTabs
tabs={ TABS }
selectedTabId="beta"
selectOnMove={ false }
/>
);

// Tab key should focus the currently selected tab, which is Beta.
await press.Tab();
expect( await getSelectedTab() ).toHaveTextContent( 'Beta' );
expect( await getSelectedTab() ).toHaveFocus();

rerender(
<ControlledTabs
tabs={ TABS }
selectedTabId="gamma"
selectOnMove={ false }
/>
);

// When the selected tab is changed, it should automatically receive focus.
expect( await getSelectedTab() ).toHaveTextContent( 'Gamma' );
expect( await getSelectedTab() ).toHaveFocus();
} );
it( 'should not automatically update focus if the selected tab was not already focused', async () => {
const { rerender } = render(
<ControlledTabs
tabs={ TABS }
selectedTabId="beta"
selectOnMove={ false }
/>
);

expect( await getSelectedTab() ).toHaveTextContent( 'Beta' );

// Tab key should focus the currently selected tab, which is Beta.
await press.Tab();
expect( await getSelectedTab() ).toHaveFocus();
// Arrow left to focus Alpha, which is not the currently
// selected tab
await press.ArrowLeft();

rerender(
<ControlledTabs
tabs={ TABS }
selectedTabId="gamma"
selectOnMove={ false }
/>
);

// When the selected tab is changed, it should not automatically receive focus.
expect( await getSelectedTab() ).toHaveTextContent( 'Gamma' );
expect(
screen.getByRole( 'tab', { name: 'Alpha' } )
).toHaveFocus();
} );
describe.each( [ true, false ] )(
'When `selectOnMove` is `%s`',
( selectOnMove ) => {
it( 'should move focus to the newly selected tab if the previously selected tab was focused', async () => {
const { rerender } = render(
<ControlledTabs
tabs={ TABS }
selectedTabId="beta"
selectOnMove={ selectOnMove }
/>
);

// Tab key should focus the currently selected tab, which is Beta.
await press.Tab();
expect( await getSelectedTab() ).toHaveTextContent(
'Beta'
);
expect( await getSelectedTab() ).toHaveFocus();

rerender(
<ControlledTabs
tabs={ TABS }
selectedTabId="gamma"
selectOnMove={ selectOnMove }
/>
);

// When the selected tab is changed, it should automatically receive focus.
expect( await getSelectedTab() ).toHaveTextContent(
'Gamma'
);
expect( await getSelectedTab() ).toHaveFocus();
} );
it( 'should not move focus to the newly selected tab if the previously selected tab was not focused', async () => {
const { rerender } = render(
<ControlledTabs
tabs={ TABS }
selectedTabId="beta"
selectOnMove={ selectOnMove }
/>
);

expect( await getSelectedTab() ).toHaveTextContent(
'Beta'
);

// Tab key should focus the currently selected tab, which is Beta.
await press.Tab();
expect( await getSelectedTab() ).toHaveFocus();
// Focus Alpha, which is not the currently selected tab
// (not the most elegant way, but it does the job).
act( () =>
screen.getByRole( 'tab', { name: 'Alpha' } ).focus()
);

rerender(
<ControlledTabs
tabs={ TABS }
selectedTabId="gamma"
selectOnMove={ selectOnMove }
/>
);

// When the selected tab is changed, it should not automatically receive focus.
expect( await getSelectedTab() ).toHaveTextContent(
'Gamma'
);
expect(
screen.getByRole( 'tab', { name: 'Alpha' } )
).toHaveFocus();
} );
}
);
} );

describe( 'When `selectOnMove` is `true`', () => {
Expand Down

0 comments on commit 1c3a994

Please sign in to comment.