Skip to content

Commit

Permalink
Add some tests for TreeGrid. Update README to reflect latest function…
Browse files Browse the repository at this point in the history
…ality. (#39302)

* Start working on updating/implementing new tests.

* Update README docs.

* Add tests for Home/End. Fix missing onFocus consumer for Home/End.

* Add item to changelog.

* A few more changelog details.

* Fix changelog formatting.
  • Loading branch information
alexstine authored and gziolo committed Mar 11, 2022
1 parent b851c38 commit 4f3e096
Show file tree
Hide file tree
Showing 4 changed files with 67 additions and 18 deletions.
1 change: 1 addition & 0 deletions packages/components/CHANGELOG.md
Original file line number Diff line number Diff line change
Expand Up @@ -6,6 +6,7 @@

- `ConfirmDialog`: Add support for custom label text on the confirmation and cancelation buttons ([#38994](https://github.com/WordPress/gutenberg/pull/38994))
- `InputControl`: Allow `onBlur` for empty values to commit the change when `isPressEnterToChange` is true, and move reset behavior to the ESCAPE key. ([#39109](https://github.com/WordPress/gutenberg/pull/39109)).
- `TreeGrid`: Add tests for Home/End keyboard navigation. Add `onFocusRow` callback for Home/End keyboard navigation, this was missed in the implementation PR. Modify test for expanding/collapsing a row as row 1 implements this now. Update README with latest changes. ([#39302](https://github.com/WordPress/gutenberg/pull/39302))

### Bug Fix

Expand Down
2 changes: 1 addition & 1 deletion packages/components/src/tree-grid/README.md
Original file line number Diff line number Diff line change
Expand Up @@ -114,7 +114,7 @@ Aside from the documented callback functions, any props specified will be passed

###### onFocusRow( event: Event, startRow: HTMLElement, destinationRow: HTMLElement )

Callback that fires when focus is shifted from one row to another via the UP and DOWN keys.
Callback that fires when focus is shifted from one row to another via the Up and Down keys. Callback is also fired on Home and End keys which move focus from the beginning row to the end row.
The callback is passed the event, the start row element that the focus was on originally, and
the destination row element after the focus has moved.

Expand Down
4 changes: 4 additions & 0 deletions packages/components/src/tree-grid/index.js
Original file line number Diff line number Diff line change
Expand Up @@ -275,6 +275,10 @@ function TreeGrid(
);
focusablesInNextRow[ nextIndex ].focus();

// Let consumers know the row that was originally focused,
// and the row that is now in focus.
onFocusRow( event, activeRow, rows[ nextRowIndex ] );

// Prevent key use for anything else. This ensures Voiceover
// doesn't try to handle key navigation.
event.preventDefault();
Expand Down
78 changes: 61 additions & 17 deletions packages/components/src/tree-grid/test/index.js
Original file line number Diff line number Diff line change
Expand Up @@ -6,7 +6,7 @@ import { fireEvent, render, screen } from '@testing-library/react';
/**
* WordPress dependencies
*/
import { LEFT, RIGHT, UP, DOWN } from '@wordpress/keycodes';
import { LEFT, RIGHT, UP, DOWN, HOME, END } from '@wordpress/keycodes';
import { forwardRef } from '@wordpress/element';

/**
Expand Down Expand Up @@ -68,10 +68,10 @@ describe( 'TreeGrid', () => {
level={ 1 }
positionInSet={ 1 }
setSize={ 3 }
isExpanded={ true }
isExpanded={ false }
>
<TreeGridCell withoutGridItem>
<TestButton>Row 1</TestButton>
<TestButton aria-expanded="false">Row 1</TestButton>
</TreeGridCell>
</TreeGridRow>
<TreeGridRow
Expand All @@ -88,7 +88,7 @@ describe( 'TreeGrid', () => {
level={ 1 }
positionInSet={ 3 }
setSize={ 3 }
isExpanded={ true }
isExpanded={ false }
>
<TreeGridCell withoutGridItem>
<TestButton>Row 3</TestButton>
Expand All @@ -97,16 +97,16 @@ describe( 'TreeGrid', () => {
</TreeGrid>
);

screen.getByText( 'Row 2' ).focus();
const row2Element = screen.getByText( 'Row 2' ).closest( 'tr' );
screen.getByText( 'Row 1' ).focus();
const row1Element = screen.getByText( 'Row 1' ).closest( 'tr' );

fireEvent.keyDown( screen.getByText( 'Row 2' ), {
fireEvent.keyDown( screen.getByText( 'Row 1' ), {
key: 'ArrowRight',
keyCode: RIGHT,
currentTarget: row2Element,
currentTarget: row1Element,
} );

expect( onExpandRow ).toHaveBeenCalledWith( row2Element );
expect( onExpandRow ).toHaveBeenCalledWith( row1Element );
} );
} );

Expand All @@ -120,17 +120,17 @@ describe( 'TreeGrid', () => {
level={ 1 }
positionInSet={ 1 }
setSize={ 3 }
isExpanded={ false }
isExpanded={ true }
>
<TreeGridCell withoutGridItem>
<TestButton>Row 1</TestButton>
<TestButton aria-expanded="true">Row 1</TestButton>
</TreeGridCell>
</TreeGridRow>
<TreeGridRow
level={ 1 }
positionInSet={ 2 }
setSize={ 3 }
isExpanded={ true }
isExpanded={ false }
>
<TreeGridCell withoutGridItem>
<TestButton>Row 2</TestButton>
Expand All @@ -149,16 +149,16 @@ describe( 'TreeGrid', () => {
</TreeGrid>
);

screen.getByText( 'Row 2' ).focus();
const row2Element = screen.getByText( 'Row 2' ).closest( 'tr' );
screen.getByText( 'Row 1' ).focus();
const row1Element = screen.getByText( 'Row 1' ).closest( 'tr' );

fireEvent.keyDown( screen.getByText( 'Row 2' ), {
fireEvent.keyDown( screen.getByText( 'Row 1' ), {
key: 'ArrowLeft',
keyCode: LEFT,
currentTarget: row2Element,
currentTarget: row1Element,
} );

expect( onCollapseRow ).toHaveBeenCalledWith( row2Element );
expect( onCollapseRow ).toHaveBeenCalledWith( row1Element );
} );
} );

Expand Down Expand Up @@ -205,6 +205,28 @@ describe( 'TreeGrid', () => {
);
} );

it( 'should call onFocusRow with event, start and end nodes when pressing End', () => {
const onFocusRow = jest.fn();
render( <TestTree onFocusRow={ onFocusRow } /> );

screen.getByText( 'Row 1' ).focus();

const row1Element = screen.getByText( 'Row 1' ).closest( 'tr' );
const row3Element = screen.getByText( 'Row 3' ).closest( 'tr' );

fireEvent.keyDown( screen.getByText( 'Row 1' ), {
key: 'End',
keyCode: END,
currentTarget: row1Element,
} );

expect( onFocusRow ).toHaveBeenCalledWith(
expect.objectContaining( { key: 'End', keyCode: END } ),
row1Element,
row3Element
);
} );

it( 'should call onFocusRow with event, start and end nodes when pressing Up Arrow', () => {
const onFocusRow = jest.fn();
render( <TestTree onFocusRow={ onFocusRow } /> );
Expand All @@ -227,6 +249,28 @@ describe( 'TreeGrid', () => {
);
} );

it( 'should call onFocusRow with event, start and end nodes when pressing Home', () => {
const onFocusRow = jest.fn();
render( <TestTree onFocusRow={ onFocusRow } /> );

screen.getByText( 'Row 3' ).focus();

const row3Element = screen.getByText( 'Row 3' ).closest( 'tr' );
const row1Element = screen.getByText( 'Row 1' ).closest( 'tr' );

fireEvent.keyDown( screen.getByText( 'Row 3' ), {
key: 'Home',
keyCode: HOME,
currentTarget: row3Element,
} );

expect( onFocusRow ).toHaveBeenCalledWith(
expect.objectContaining( { key: 'Home', keyCode: HOME } ),
row3Element,
row1Element
);
} );

it( 'should call onFocusRow when shift key is held', () => {
const onFocusRow = jest.fn();
render( <TestTree onFocusRow={ onFocusRow } /> );
Expand Down

0 comments on commit 4f3e096

Please sign in to comment.