Skip to content

Commit

Permalink
fix(material/list): indexOf usage incorreect for active focus reset (#…
Browse files Browse the repository at this point in the history
…28531)

The buggy logic was using a truthiness check for checking for presence
in a list, but this check needed to compare against -1 instead.  This
corrects a mismanagement of tabIndex on the items in the selection
list: if the list of items changed, the selection list could not
be tab selected until the selection list was mouse-focused.

(cherry picked from commit f1e82da)
  • Loading branch information
dyoo authored and crisbeto committed Feb 8, 2024
1 parent 044c9ba commit 306c242
Show file tree
Hide file tree
Showing 2 changed files with 16 additions and 1 deletion.
15 changes: 15 additions & 0 deletions src/material/list/selection-list.spec.ts
Original file line number Diff line number Diff line change
Expand Up @@ -1319,6 +1319,21 @@ describe('MDC-based MatSelectionList with forms', () => {
.toBe(1);
}));

it('should focus the first option when the list items are changed', fakeAsync(() => {
fixture.componentInstance.options = ['first option', 'second option'];
fixture.detectChanges();

tick();

const listElements = fixture.debugElement
.queryAll(By.directive(MatListOption))
.map(optionDebugEl => optionDebugEl.nativeElement);

expect(listElements.length).toBe(2);
expect(listElements[0].tabIndex).toBe(0);
expect(listElements[1].tabIndex).toBe(-1);
}));

it('should not mark the model as touched when the list is blurred', fakeAsync(() => {
expect(ngModel.touched)
.withContext('Expected the selection-list to be untouched by default.')
Expand Down
2 changes: 1 addition & 1 deletion src/material/list/selection-list.ts
Original file line number Diff line number Diff line change
Expand Up @@ -429,7 +429,7 @@ export class MatSelectionList
this._items.changes.pipe(takeUntil(this._destroyed)).subscribe(() => {
const activeItem = this._keyManager.activeItem;

if (!activeItem || !this._items.toArray().indexOf(activeItem)) {
if (!activeItem || this._items.toArray().indexOf(activeItem) === -1) {
this._resetActiveOption();
}
});
Expand Down

0 comments on commit 306c242

Please sign in to comment.