@angular/material-experimental 14.0.0-rc.1 → 14.0.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2020/mdc-chips/chip-action.mjs +42 -76
- package/esm2020/mdc-chips/chip-grid.mjs +58 -69
- package/esm2020/mdc-chips/chip-icons.mjs +18 -32
- package/esm2020/mdc-chips/chip-input.mjs +2 -5
- package/esm2020/mdc-chips/chip-listbox.mjs +21 -63
- package/esm2020/mdc-chips/chip-option.mjs +36 -81
- package/esm2020/mdc-chips/chip-row.mjs +50 -74
- package/esm2020/mdc-chips/chip-set.mjs +116 -117
- package/esm2020/mdc-chips/chip.mjs +80 -165
- package/esm2020/mdc-chips/module.mjs +2 -2
- package/esm2020/mdc-chips/public-api.mjs +2 -2
- package/esm2020/mdc-chips/tokens.mjs +33 -0
- package/esm2020/mdc-list/list-base.mjs +1 -9
- package/esm2020/mdc-list/list-option.mjs +37 -19
- package/esm2020/mdc-list/selection-list.mjs +121 -121
- package/esm2020/mdc-progress-bar/progress-bar.mjs +38 -102
- package/esm2020/mdc-radio/radio.mjs +2 -2
- package/esm2020/mdc-snack-bar/snack-bar-container.mjs +23 -205
- package/esm2020/version.mjs +1 -1
- package/fesm2015/material-experimental.mjs +1 -1
- package/fesm2015/material-experimental.mjs.map +1 -1
- package/fesm2015/mdc-chips.mjs +510 -766
- package/fesm2015/mdc-chips.mjs.map +1 -1
- package/fesm2015/mdc-list.mjs +158 -344
- package/fesm2015/mdc-list.mjs.map +1 -1
- package/fesm2015/mdc-progress-bar.mjs +36 -100
- package/fesm2015/mdc-progress-bar.mjs.map +1 -1
- package/fesm2015/mdc-radio.mjs +2 -2
- package/fesm2015/mdc-radio.mjs.map +1 -1
- package/fesm2015/mdc-snack-bar.mjs +27 -208
- package/fesm2015/mdc-snack-bar.mjs.map +1 -1
- package/fesm2020/material-experimental.mjs +1 -1
- package/fesm2020/material-experimental.mjs.map +1 -1
- package/fesm2020/mdc-chips.mjs +413 -672
- package/fesm2020/mdc-chips.mjs.map +1 -1
- package/fesm2020/mdc-list.mjs +157 -333
- package/fesm2020/mdc-list.mjs.map +1 -1
- package/fesm2020/mdc-progress-bar.mjs +36 -99
- package/fesm2020/mdc-progress-bar.mjs.map +1 -1
- package/fesm2020/mdc-radio.mjs +2 -2
- package/fesm2020/mdc-radio.mjs.map +1 -1
- package/fesm2020/mdc-snack-bar.mjs +27 -206
- package/fesm2020/mdc-snack-bar.mjs.map +1 -1
- package/mdc-chips/index.d.ts +102 -162
- package/mdc-list/index.d.ts +42 -66
- package/mdc-progress-bar/index.d.ts +14 -17
- package/mdc-snack-bar/index.d.ts +4 -68
- package/package.json +8 -8
- package/esm2020/mdc-chips/chip-default-options.mjs +0 -11
- package/esm2020/mdc-chips/emit-event.mjs +0 -27
- package/esm2020/mdc-list/interactive-list-base.mjs +0 -196
|
@@ -1,196 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* @license
|
|
3
|
-
* Copyright Google LLC All Rights Reserved.
|
|
4
|
-
*
|
|
5
|
-
* Use of this source code is governed by an MIT-style license that can be
|
|
6
|
-
* found in the LICENSE file at https://angular.io/license
|
|
7
|
-
*/
|
|
8
|
-
import { DOCUMENT } from '@angular/common';
|
|
9
|
-
import { Directive, ElementRef, Inject } from '@angular/core';
|
|
10
|
-
import { MDCListFoundation } from '@material/list';
|
|
11
|
-
import { Subscription } from 'rxjs';
|
|
12
|
-
import { startWith } from 'rxjs/operators';
|
|
13
|
-
import { MatListBase } from './list-base';
|
|
14
|
-
import * as i0 from "@angular/core";
|
|
15
|
-
/** @docs-private */
|
|
16
|
-
export class MatInteractiveListBase extends MatListBase {
|
|
17
|
-
constructor(_element, document) {
|
|
18
|
-
super();
|
|
19
|
-
this._element = _element;
|
|
20
|
-
this._itemsArr = [];
|
|
21
|
-
this._subscriptions = new Subscription();
|
|
22
|
-
this._document = document;
|
|
23
|
-
this._isNonInteractive = false;
|
|
24
|
-
}
|
|
25
|
-
_handleKeydown(event) {
|
|
26
|
-
const index = this._indexForElement(event.target);
|
|
27
|
-
this._foundation.handleKeydown(event, this._elementAtIndex(index) === event.target, index);
|
|
28
|
-
}
|
|
29
|
-
_handleClick(event) {
|
|
30
|
-
// The `isCheckboxAlreadyUpdatedInAdapter` parameter can always be `false` as it only has an
|
|
31
|
-
// effect if the list is recognized as checkbox selection list. For such lists, we would
|
|
32
|
-
// always want to toggle the checkbox on list item click. MDC added this parameter so that
|
|
33
|
-
// they can avoid dispatching a fake `change` event when the checkbox is directly clicked
|
|
34
|
-
// for the list item. We don't need this as we do not have an underlying native checkbox
|
|
35
|
-
// that is reachable by users through interaction.
|
|
36
|
-
// https://github.com/material-components/material-components-web/blob/08ca4d0ec5f359bc3a20bd2a302fa6b733b5e135/packages/mdc-list/component.ts#L308-L310
|
|
37
|
-
this._foundation.handleClick(this._indexForElement(event.target),
|
|
38
|
-
/* isCheckboxAlreadyUpdatedInAdapter */ false, event);
|
|
39
|
-
}
|
|
40
|
-
_handleFocusin(event) {
|
|
41
|
-
const itemIndex = this._indexForElement(event.target);
|
|
42
|
-
const tabIndex = this._itemsArr[itemIndex]?._hostElement.tabIndex;
|
|
43
|
-
// If the newly focused item is not the designated item that should have received focus
|
|
44
|
-
// first through keyboard interaction, the tabindex of the previously designated list item
|
|
45
|
-
// needs to be cleared, so that only one list item is reachable through tab key at any time.
|
|
46
|
-
// MDC sets a tabindex for the newly focused item, so we do not need to set a tabindex for it.
|
|
47
|
-
// Workaround for: https://github.com/material-components/material-components-web/issues/6363.
|
|
48
|
-
if (tabIndex === undefined || tabIndex === -1) {
|
|
49
|
-
this._clearTabindexForAllItems();
|
|
50
|
-
}
|
|
51
|
-
this._foundation.handleFocusIn(itemIndex);
|
|
52
|
-
}
|
|
53
|
-
_handleFocusout(event) {
|
|
54
|
-
this._foundation.handleFocusOut(this._indexForElement(event.target));
|
|
55
|
-
}
|
|
56
|
-
_initWithAdapter(adapter) {
|
|
57
|
-
this._adapter = adapter;
|
|
58
|
-
this._foundation = new MDCListFoundation(adapter);
|
|
59
|
-
}
|
|
60
|
-
ngAfterViewInit() {
|
|
61
|
-
if ((typeof ngDevMode === 'undefined' || ngDevMode) && !this._foundation) {
|
|
62
|
-
throw Error('MDC list foundation not initialized for Angular Material list.');
|
|
63
|
-
}
|
|
64
|
-
this._foundation.init();
|
|
65
|
-
this._watchListItems();
|
|
66
|
-
// Enable typeahead and focus wrapping for interactive lists.
|
|
67
|
-
this._foundation.setHasTypeahead(true);
|
|
68
|
-
this._foundation.setWrapFocus(true);
|
|
69
|
-
}
|
|
70
|
-
ngOnDestroy() {
|
|
71
|
-
this._foundation.destroy();
|
|
72
|
-
this._subscriptions.unsubscribe();
|
|
73
|
-
}
|
|
74
|
-
_watchListItems() {
|
|
75
|
-
this._subscriptions.add(this._items.changes.pipe(startWith(null)).subscribe(() => {
|
|
76
|
-
this._itemsArr = this._items.toArray();
|
|
77
|
-
// Whenever the items change, the foundation needs to be notified through the `layout`
|
|
78
|
-
// method. It caches items for the typeahead and detects the list type based on the items.
|
|
79
|
-
this._foundation.layout();
|
|
80
|
-
// The list items changed, so we reset the tabindex for all items and
|
|
81
|
-
// designate one list item that will be reachable through tab.
|
|
82
|
-
this._resetTabindexToFirstSelectedOrFocusedItem();
|
|
83
|
-
}));
|
|
84
|
-
}
|
|
85
|
-
/**
|
|
86
|
-
* Clears the tabindex of all items so that no items are reachable through tab key.
|
|
87
|
-
* MDC intends to always have only one tabbable item that will receive focus first.
|
|
88
|
-
* This first item is selected by MDC automatically on blur or by manually invoking
|
|
89
|
-
* the `setTabindexToFirstSelectedOrFocusedItem` method.
|
|
90
|
-
*/
|
|
91
|
-
_clearTabindexForAllItems() {
|
|
92
|
-
for (let items of this._itemsArr) {
|
|
93
|
-
items._hostElement.setAttribute('tabindex', '-1');
|
|
94
|
-
}
|
|
95
|
-
}
|
|
96
|
-
/**
|
|
97
|
-
* Resets tabindex for all options and sets tabindex for the first selected option or
|
|
98
|
-
* previously focused item so that an item can be reached when users tab into the list.
|
|
99
|
-
*/
|
|
100
|
-
_resetTabindexToFirstSelectedOrFocusedItem() {
|
|
101
|
-
this._clearTabindexForAllItems();
|
|
102
|
-
// MDC does not expose the method for setting the tabindex to the first selected
|
|
103
|
-
// or previously focused item. We can still access the method as private class
|
|
104
|
-
// members are accessible in the transpiled JavaScript. Tracked upstream with:
|
|
105
|
-
// TODO: https://github.com/material-components/material-components-web/issues/6375
|
|
106
|
-
this._foundation.setTabindexToFirstSelectedOrFocusedItem();
|
|
107
|
-
}
|
|
108
|
-
_elementAtIndex(index) {
|
|
109
|
-
return this._itemsArr[index]?._hostElement;
|
|
110
|
-
}
|
|
111
|
-
_indexForElement(element) {
|
|
112
|
-
return element ? this._itemsArr.findIndex(i => i._hostElement.contains(element)) : -1;
|
|
113
|
-
}
|
|
114
|
-
}
|
|
115
|
-
MatInteractiveListBase.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.0.0-rc.1", ngImport: i0, type: MatInteractiveListBase, deps: [{ token: i0.ElementRef }, { token: DOCUMENT }], target: i0.ɵɵFactoryTarget.Directive });
|
|
116
|
-
MatInteractiveListBase.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "14.0.0-rc.1", type: MatInteractiveListBase, host: { listeners: { "keydown": "_handleKeydown($event)", "click": "_handleClick($event)", "focusin": "_handleFocusin($event)", "focusout": "_handleFocusout($event)" } }, usesInheritance: true, ngImport: i0 });
|
|
117
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.0-rc.1", ngImport: i0, type: MatInteractiveListBase, decorators: [{
|
|
118
|
-
type: Directive,
|
|
119
|
-
args: [{
|
|
120
|
-
host: {
|
|
121
|
-
'(keydown)': '_handleKeydown($event)',
|
|
122
|
-
'(click)': '_handleClick($event)',
|
|
123
|
-
'(focusin)': '_handleFocusin($event)',
|
|
124
|
-
'(focusout)': '_handleFocusout($event)',
|
|
125
|
-
},
|
|
126
|
-
}]
|
|
127
|
-
}], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: undefined, decorators: [{
|
|
128
|
-
type: Inject,
|
|
129
|
-
args: [DOCUMENT]
|
|
130
|
-
}] }]; } });
|
|
131
|
-
// TODO: replace with class once material-components-web/pull/6256 is available.
|
|
132
|
-
/** Gets an instance of `MDcListAdapter` for the given interactive list. */
|
|
133
|
-
export function getInteractiveListAdapter(list) {
|
|
134
|
-
return {
|
|
135
|
-
getListItemCount() {
|
|
136
|
-
return list._items.length;
|
|
137
|
-
},
|
|
138
|
-
listItemAtIndexHasClass(index, className) {
|
|
139
|
-
const element = list._elementAtIndex(index);
|
|
140
|
-
return element ? element.classList.contains(className) : false;
|
|
141
|
-
},
|
|
142
|
-
addClassForElementIndex(index, className) {
|
|
143
|
-
list._elementAtIndex(index)?.classList.add(className);
|
|
144
|
-
},
|
|
145
|
-
removeClassForElementIndex(index, className) {
|
|
146
|
-
list._elementAtIndex(index)?.classList.remove(className);
|
|
147
|
-
},
|
|
148
|
-
getAttributeForElementIndex(index, attr) {
|
|
149
|
-
const element = list._elementAtIndex(index);
|
|
150
|
-
return element ? element.getAttribute(attr) : null;
|
|
151
|
-
},
|
|
152
|
-
setAttributeForElementIndex(index, attr, value) {
|
|
153
|
-
list._elementAtIndex(index)?.setAttribute(attr, value);
|
|
154
|
-
},
|
|
155
|
-
getFocusedElementIndex() {
|
|
156
|
-
return list._indexForElement(list._document?.activeElement);
|
|
157
|
-
},
|
|
158
|
-
isFocusInsideList() {
|
|
159
|
-
return list._element.nativeElement.contains(list._document?.activeElement);
|
|
160
|
-
},
|
|
161
|
-
isRootFocused() {
|
|
162
|
-
return list._element.nativeElement === list._document?.activeElement;
|
|
163
|
-
},
|
|
164
|
-
focusItemAtIndex(index) {
|
|
165
|
-
list._elementAtIndex(index)?.focus();
|
|
166
|
-
},
|
|
167
|
-
// Gets the text for a list item for the typeahead
|
|
168
|
-
getPrimaryTextAtIndex(index) {
|
|
169
|
-
return list._itemsArr[index]._getItemLabel();
|
|
170
|
-
},
|
|
171
|
-
// MDC uses this method to disable focusable children of list items. However, we believe that
|
|
172
|
-
// this is not an accessible pattern and should be avoided, therefore we intentionally do not
|
|
173
|
-
// implement this method. In addition, implementing this would require violating Angular
|
|
174
|
-
// Material's general principle of not having components modify DOM elements they do not own.
|
|
175
|
-
// A user who feels they really need this feature can simply listen to the `(focus)` and
|
|
176
|
-
// `(blur)` events on the list item and enable/disable focus on the children themselves as
|
|
177
|
-
// appropriate.
|
|
178
|
-
setTabIndexForListItemChildren() { },
|
|
179
|
-
// The following methods have a dummy implementation in the base class because they are only
|
|
180
|
-
// applicable to certain types of lists. They should be implemented for the concrete classes
|
|
181
|
-
// where they are applicable.
|
|
182
|
-
hasCheckboxAtIndex() {
|
|
183
|
-
return false;
|
|
184
|
-
},
|
|
185
|
-
hasRadioAtIndex(index) {
|
|
186
|
-
return false;
|
|
187
|
-
},
|
|
188
|
-
setCheckedCheckboxOrRadioAtIndex(index, checked) { },
|
|
189
|
-
isCheckboxCheckedAtIndex(index) {
|
|
190
|
-
return false;
|
|
191
|
-
},
|
|
192
|
-
notifySelectionChange() { },
|
|
193
|
-
notifyAction() { },
|
|
194
|
-
};
|
|
195
|
-
}
|
|
196
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"interactive-list-base.js","sourceRoot":"","sources":["../../../../../../src/material-experimental/mdc-list/interactive-list-base.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\n\nimport {DOCUMENT} from '@angular/common';\nimport {AfterViewInit, Directive, ElementRef, Inject, OnDestroy, QueryList} from '@angular/core';\nimport {MDCListAdapter, MDCListFoundation} from '@material/list';\nimport {Subscription} from 'rxjs';\nimport {startWith} from 'rxjs/operators';\nimport {MatListBase, MatListItemBase} from './list-base';\n\n@Directive({\n  host: {\n    '(keydown)': '_handleKeydown($event)',\n    '(click)': '_handleClick($event)',\n    '(focusin)': '_handleFocusin($event)',\n    '(focusout)': '_handleFocusout($event)',\n  },\n})\n/** @docs-private */\nexport abstract class MatInteractiveListBase<T extends MatListItemBase>\n  extends MatListBase\n  implements AfterViewInit, OnDestroy\n{\n  _handleKeydown(event: KeyboardEvent) {\n    const index = this._indexForElement(event.target as HTMLElement);\n    this._foundation.handleKeydown(event, this._elementAtIndex(index) === event.target, index);\n  }\n\n  _handleClick(event: MouseEvent) {\n    // The `isCheckboxAlreadyUpdatedInAdapter` parameter can always be `false` as it only has an\n    // effect if the list is recognized as checkbox selection list. For such lists, we would\n    // always want to toggle the checkbox on list item click. MDC added this parameter so that\n    // they can avoid dispatching a fake `change` event when the checkbox is directly clicked\n    // for the list item. We don't need this as we do not have an underlying native checkbox\n    // that is reachable by users through interaction.\n    // https://github.com/material-components/material-components-web/blob/08ca4d0ec5f359bc3a20bd2a302fa6b733b5e135/packages/mdc-list/component.ts#L308-L310\n    this._foundation.handleClick(\n      this._indexForElement(event.target as HTMLElement),\n      /* isCheckboxAlreadyUpdatedInAdapter */ false,\n      event,\n    );\n  }\n\n  _handleFocusin(event: FocusEvent) {\n    const itemIndex = this._indexForElement(event.target as HTMLElement);\n    const tabIndex = this._itemsArr[itemIndex]?._hostElement.tabIndex;\n\n    // If the newly focused item is not the designated item that should have received focus\n    // first through keyboard interaction, the tabindex of the previously designated list item\n    // needs to be cleared, so that only one list item is reachable through tab key at any time.\n    // MDC sets a tabindex for the newly focused item, so we do not need to set a tabindex for it.\n    // Workaround for: https://github.com/material-components/material-components-web/issues/6363.\n    if (tabIndex === undefined || tabIndex === -1) {\n      this._clearTabindexForAllItems();\n    }\n\n    this._foundation.handleFocusIn(itemIndex);\n  }\n\n  _handleFocusout(event: FocusEvent) {\n    this._foundation.handleFocusOut(this._indexForElement(event.target as HTMLElement));\n  }\n\n  /** Items in the interactive list. */\n  abstract _items: QueryList<T>;\n  _itemsArr: T[] = [];\n  _document: Document;\n\n  protected _foundation: MDCListFoundation;\n  protected _adapter: MDCListAdapter;\n\n  private _subscriptions = new Subscription();\n\n  protected constructor(public _element: ElementRef<HTMLElement>, @Inject(DOCUMENT) document: any) {\n    super();\n    this._document = document;\n    this._isNonInteractive = false;\n  }\n\n  protected _initWithAdapter(adapter: MDCListAdapter) {\n    this._adapter = adapter;\n    this._foundation = new MDCListFoundation(adapter);\n  }\n\n  ngAfterViewInit() {\n    if ((typeof ngDevMode === 'undefined' || ngDevMode) && !this._foundation) {\n      throw Error('MDC list foundation not initialized for Angular Material list.');\n    }\n\n    this._foundation.init();\n    this._watchListItems();\n\n    // Enable typeahead and focus wrapping for interactive lists.\n    this._foundation.setHasTypeahead(true);\n    this._foundation.setWrapFocus(true);\n  }\n\n  ngOnDestroy() {\n    this._foundation.destroy();\n    this._subscriptions.unsubscribe();\n  }\n\n  protected _watchListItems() {\n    this._subscriptions.add(\n      this._items.changes.pipe(startWith(null)).subscribe(() => {\n        this._itemsArr = this._items.toArray();\n        // Whenever the items change, the foundation needs to be notified through the `layout`\n        // method. It caches items for the typeahead and detects the list type based on the items.\n        this._foundation.layout();\n\n        // The list items changed, so we reset the tabindex for all items and\n        // designate one list item that will be reachable through tab.\n        this._resetTabindexToFirstSelectedOrFocusedItem();\n      }),\n    );\n  }\n\n  /**\n   * Clears the tabindex of all items so that no items are reachable through tab key.\n   * MDC intends to always have only one tabbable item that will receive focus first.\n   * This first item is selected by MDC automatically on blur or by manually invoking\n   * the `setTabindexToFirstSelectedOrFocusedItem` method.\n   */\n  private _clearTabindexForAllItems() {\n    for (let items of this._itemsArr) {\n      items._hostElement.setAttribute('tabindex', '-1');\n    }\n  }\n\n  /**\n   * Resets tabindex for all options and sets tabindex for the first selected option or\n   * previously focused item so that an item can be reached when users tab into the list.\n   */\n  protected _resetTabindexToFirstSelectedOrFocusedItem() {\n    this._clearTabindexForAllItems();\n    // MDC does not expose the method for setting the tabindex to the first selected\n    // or previously focused item. We can still access the method as private class\n    // members are accessible in the transpiled JavaScript. Tracked upstream with:\n    // TODO: https://github.com/material-components/material-components-web/issues/6375\n    (this._foundation as any).setTabindexToFirstSelectedOrFocusedItem();\n  }\n\n  _elementAtIndex(index: number): HTMLElement | undefined {\n    return this._itemsArr[index]?._hostElement;\n  }\n\n  _indexForElement(element: Element | null): number {\n    return element ? this._itemsArr.findIndex(i => i._hostElement.contains(element)) : -1;\n  }\n}\n\n// TODO: replace with class once material-components-web/pull/6256 is available.\n/** Gets an instance of `MDcListAdapter` for the given interactive list. */\nexport function getInteractiveListAdapter(\n  list: MatInteractiveListBase<MatListItemBase>,\n): MDCListAdapter {\n  return {\n    getListItemCount() {\n      return list._items.length;\n    },\n    listItemAtIndexHasClass(index: number, className: string) {\n      const element = list._elementAtIndex(index);\n      return element ? element.classList.contains(className) : false;\n    },\n    addClassForElementIndex(index: number, className: string) {\n      list._elementAtIndex(index)?.classList.add(className);\n    },\n    removeClassForElementIndex(index: number, className: string) {\n      list._elementAtIndex(index)?.classList.remove(className);\n    },\n    getAttributeForElementIndex(index: number, attr: string) {\n      const element = list._elementAtIndex(index);\n      return element ? element.getAttribute(attr) : null;\n    },\n    setAttributeForElementIndex(index: number, attr: string, value: string) {\n      list._elementAtIndex(index)?.setAttribute(attr, value);\n    },\n    getFocusedElementIndex() {\n      return list._indexForElement(list._document?.activeElement);\n    },\n    isFocusInsideList() {\n      return list._element.nativeElement.contains(list._document?.activeElement);\n    },\n    isRootFocused() {\n      return list._element.nativeElement === list._document?.activeElement;\n    },\n    focusItemAtIndex(index: number) {\n      list._elementAtIndex(index)?.focus();\n    },\n    // Gets the text for a list item for the typeahead\n    getPrimaryTextAtIndex(index: number) {\n      return list._itemsArr[index]._getItemLabel();\n    },\n\n    // MDC uses this method to disable focusable children of list items. However, we believe that\n    // this is not an accessible pattern and should be avoided, therefore we intentionally do not\n    // implement this method. In addition, implementing this would require violating Angular\n    // Material's general principle of not having components modify DOM elements they do not own.\n    // A user who feels they really need this feature can simply listen to the `(focus)` and\n    // `(blur)` events on the list item and enable/disable focus on the children themselves as\n    // appropriate.\n    setTabIndexForListItemChildren() {},\n\n    // The following methods have a dummy implementation in the base class because they are only\n    // applicable to certain types of lists. They should be implemented for the concrete classes\n    // where they are applicable.\n    hasCheckboxAtIndex() {\n      return false;\n    },\n    hasRadioAtIndex(index: number) {\n      return false;\n    },\n    setCheckedCheckboxOrRadioAtIndex(index: number, checked: boolean) {},\n    isCheckboxCheckedAtIndex(index: number) {\n      return false;\n    },\n    notifySelectionChange() {},\n    notifyAction() {},\n  };\n}\n"]}
|