@angular/material-experimental 14.0.0-rc.1 → 14.0.0-rc.2

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.
Files changed (34) hide show
  1. package/esm2020/mdc-chips/chip-action.mjs +42 -76
  2. package/esm2020/mdc-chips/chip-grid.mjs +58 -69
  3. package/esm2020/mdc-chips/chip-icons.mjs +18 -32
  4. package/esm2020/mdc-chips/chip-input.mjs +2 -5
  5. package/esm2020/mdc-chips/chip-listbox.mjs +21 -63
  6. package/esm2020/mdc-chips/chip-option.mjs +36 -81
  7. package/esm2020/mdc-chips/chip-row.mjs +50 -74
  8. package/esm2020/mdc-chips/chip-set.mjs +116 -117
  9. package/esm2020/mdc-chips/chip.mjs +80 -165
  10. package/esm2020/mdc-chips/module.mjs +2 -2
  11. package/esm2020/mdc-chips/public-api.mjs +2 -2
  12. package/esm2020/mdc-chips/tokens.mjs +33 -0
  13. package/esm2020/mdc-list/list-base.mjs +1 -9
  14. package/esm2020/mdc-list/list-option.mjs +37 -19
  15. package/esm2020/mdc-list/selection-list.mjs +121 -121
  16. package/esm2020/version.mjs +1 -1
  17. package/fesm2015/material-experimental.mjs +1 -1
  18. package/fesm2015/material-experimental.mjs.map +1 -1
  19. package/fesm2015/mdc-chips.mjs +510 -766
  20. package/fesm2015/mdc-chips.mjs.map +1 -1
  21. package/fesm2015/mdc-list.mjs +158 -344
  22. package/fesm2015/mdc-list.mjs.map +1 -1
  23. package/fesm2020/material-experimental.mjs +1 -1
  24. package/fesm2020/material-experimental.mjs.map +1 -1
  25. package/fesm2020/mdc-chips.mjs +413 -672
  26. package/fesm2020/mdc-chips.mjs.map +1 -1
  27. package/fesm2020/mdc-list.mjs +157 -333
  28. package/fesm2020/mdc-list.mjs.map +1 -1
  29. package/mdc-chips/index.d.ts +102 -162
  30. package/mdc-list/index.d.ts +42 -66
  31. package/package.json +3 -3
  32. package/esm2020/mdc-chips/chip-default-options.mjs +0 -11
  33. package/esm2020/mdc-chips/emit-event.mjs +0 -27
  34. package/esm2020/mdc-list/interactive-list-base.mjs +0 -196
@@ -13,8 +13,6 @@ import { InjectionToken } from '@angular/core';
13
13
  import { MAT_LIST } from '@angular/material/list';
14
14
  import { MAT_NAV_LIST } from '@angular/material/list';
15
15
  import { MAT_SELECTION_LIST_VALUE_ACCESSOR } from '@angular/material/list';
16
- import { MDCListAdapter } from '@material/list';
17
- import { MDCListFoundation } from '@material/list';
18
16
  import { NgZone } from '@angular/core';
19
17
  import { OnChanges } from '@angular/core';
20
18
  import { OnDestroy } from '@angular/core';
@@ -100,42 +98,6 @@ export declare class MatActionList extends MatListBase {
100
98
  static ɵcmp: i0.ɵɵComponentDeclaration<MatActionList, "mat-action-list", ["matActionList"], {}, {}, never, ["*"], false>;
101
99
  }
102
100
 
103
- declare abstract class MatInteractiveListBase<T extends MatListItemBase> extends MatListBase implements AfterViewInit, OnDestroy {
104
- _element: ElementRef<HTMLElement>;
105
- _handleKeydown(event: KeyboardEvent): void;
106
- _handleClick(event: MouseEvent): void;
107
- _handleFocusin(event: FocusEvent): void;
108
- _handleFocusout(event: FocusEvent): void;
109
- /** Items in the interactive list. */
110
- abstract _items: QueryList<T>;
111
- _itemsArr: T[];
112
- _document: Document;
113
- protected _foundation: MDCListFoundation;
114
- protected _adapter: MDCListAdapter;
115
- private _subscriptions;
116
- protected constructor(_element: ElementRef<HTMLElement>, document: any);
117
- protected _initWithAdapter(adapter: MDCListAdapter): void;
118
- ngAfterViewInit(): void;
119
- ngOnDestroy(): void;
120
- protected _watchListItems(): void;
121
- /**
122
- * Clears the tabindex of all items so that no items are reachable through tab key.
123
- * MDC intends to always have only one tabbable item that will receive focus first.
124
- * This first item is selected by MDC automatically on blur or by manually invoking
125
- * the `setTabindexToFirstSelectedOrFocusedItem` method.
126
- */
127
- private _clearTabindexForAllItems;
128
- /**
129
- * Resets tabindex for all options and sets tabindex for the first selected option or
130
- * previously focused item so that an item can be reached when users tab into the list.
131
- */
132
- protected _resetTabindexToFirstSelectedOrFocusedItem(): void;
133
- _elementAtIndex(index: number): HTMLElement | undefined;
134
- _indexForElement(element: Element | null): number;
135
- static ɵfac: i0.ɵɵFactoryDeclaration<MatInteractiveListBase<any>, never>;
136
- static ɵdir: i0.ɵɵDirectiveDeclaration<MatInteractiveListBase<any>, never, never, {}, {}, never, never, false>;
137
- }
138
-
139
101
  export declare class MatList extends MatListBase {
140
102
  static ɵfac: i0.ɵɵFactoryDeclaration<MatList, never>;
141
103
  static ɵcmp: i0.ɵɵComponentDeclaration<MatList, "mat-list", ["matList"], {}, {}, never, ["*"], false>;
@@ -235,11 +197,9 @@ declare abstract class MatListItemBase implements AfterViewInit, OnDestroy, Ripp
235
197
  * @docs-private
236
198
  */
237
199
  get rippleDisabled(): boolean;
238
- protected constructor(_elementRef: ElementRef<HTMLElement>, _ngZone: NgZone, _listBase: MatListBase, _platform: Platform, globalRippleOptions?: RippleGlobalOptions, animationMode?: string);
200
+ constructor(_elementRef: ElementRef<HTMLElement>, _ngZone: NgZone, _listBase: MatListBase, _platform: Platform, globalRippleOptions?: RippleGlobalOptions, animationMode?: string);
239
201
  ngAfterViewInit(): void;
240
202
  ngOnDestroy(): void;
241
- /** Gets the label for the list item. This is used for the typeahead. */
242
- _getItemLabel(): string;
243
203
  /** Whether the list item has icons or avatars. */
244
204
  _hasIconOrAvatar(): boolean;
245
205
  private _initInteractiveListItem;
@@ -345,12 +305,11 @@ export declare class MatListModule {
345
305
  }
346
306
 
347
307
  export declare class MatListOption extends MatListItemBase implements ListOption, OnInit, OnDestroy {
348
- _selectionList: SelectionList;
308
+ private _selectionList;
349
309
  private _changeDetectorRef;
350
310
  _lines: QueryList<MatListItemLine>;
351
311
  _titles: QueryList<MatListItemTitle>;
352
312
  _unscopedContent: ElementRef<HTMLSpanElement>;
353
- _itemText: ElementRef<HTMLElement>;
354
313
  /**
355
314
  * Emits when the selected state of the option has changed.
356
315
  * Use to facilitate two-data binding to the `selected` property.
@@ -376,13 +335,15 @@ export declare class MatListOption extends MatListItemBase implements ListOption
376
335
  * clear the value of `selected` in the first cycle.
377
336
  */
378
337
  private _inputsInitialized;
379
- constructor(element: ElementRef, ngZone: NgZone, platform: Platform, _selectionList: SelectionList, _changeDetectorRef: ChangeDetectorRef, globalRippleOptions?: RippleGlobalOptions, animationMode?: string);
338
+ constructor(elementRef: ElementRef<HTMLElement>, ngZone: NgZone, _selectionList: SelectionList, platform: Platform, _changeDetectorRef: ChangeDetectorRef, globalRippleOptions?: RippleGlobalOptions, animationMode?: string);
380
339
  ngOnInit(): void;
381
340
  ngOnDestroy(): void;
382
341
  /** Toggles the selection state of the option. */
383
342
  toggle(): void;
384
343
  /** Allows for programmatic focusing of the option. */
385
344
  focus(): void;
345
+ /** Gets the text label of the list option. Used for the typeahead functionality in the list. */
346
+ getLabel(): string;
386
347
  /** Whether a checkbox is shown at the given position. */
387
348
  _hasCheckboxAt(position: MatListOptionCheckboxPosition): boolean;
388
349
  /** Whether icons or avatars are shown at the given position. */
@@ -403,6 +364,10 @@ export declare class MatListOption extends MatListItemBase implements ListOption
403
364
  * list changed.
404
365
  */
405
366
  _markForCheck(): void;
367
+ /** Toggles the option's value based on a user interacion. */
368
+ _toggleOnInteraction(): void;
369
+ /** Sets the tabindex of the list option. */
370
+ _setTabindex(value: number): void;
406
371
  static ɵfac: i0.ɵɵFactoryDeclaration<MatListOption, [null, null, null, null, null, { optional: true; }, { optional: true; }]>;
407
372
  static ɵcmp: i0.ɵɵComponentDeclaration<MatListOption, "mat-list-option", ["matListOption"], { "checkboxPosition": "checkboxPosition"; "color": "color"; "value": "value"; "selected": "selected"; }, { "selectedChange": "selectedChange"; }, ["_lines", "_titles"], ["[matListItemAvatar],[matListItemIcon]", "[matListItemTitle]", "[matListItemLine]", "*", "mat-divider"], false>;
408
373
  }
@@ -428,9 +393,17 @@ export declare class MatNavList extends MatListBase {
428
393
  static ɵcmp: i0.ɵɵComponentDeclaration<MatNavList, "mat-nav-list", ["matNavList"], {}, {}, never, ["*"], false>;
429
394
  }
430
395
 
431
- export declare class MatSelectionList extends MatInteractiveListBase<MatListOption> implements SelectionList, ControlValueAccessor, AfterViewInit, OnChanges, OnDestroy {
432
- private _multiple;
396
+ export declare class MatSelectionList extends MatListBase implements SelectionList, ControlValueAccessor, AfterViewInit, OnChanges, OnDestroy {
397
+ _element: ElementRef<HTMLElement>;
398
+ private _ngZone;
433
399
  private _initialized;
400
+ private _keyManager;
401
+ /** Emits when the list has been destroyed. */
402
+ private _destroyed;
403
+ /** Whether the list has been destroyed. */
404
+ private _isDestroyed;
405
+ /** View to model callback that should be called whenever the selected options change. */
406
+ private _onChange;
434
407
  _items: QueryList<MatListOption>;
435
408
  /** Emits a change event whenever the selected state of an option changes. */
436
409
  readonly selectionChange: EventEmitter<MatSelectionListChange>;
@@ -445,19 +418,14 @@ export declare class MatSelectionList extends MatInteractiveListBase<MatListOpti
445
418
  /** Whether selection is limited to one or multiple items (default multiple). */
446
419
  get multiple(): boolean;
447
420
  set multiple(value: BooleanInput);
421
+ private _multiple;
448
422
  /** The currently selected options. */
449
423
  selectedOptions: SelectionModel<MatListOption>;
450
- /** View to model callback that should be called whenever the selected options change. */
451
- private _onChange;
452
424
  /** Keeps track of the currently-selected value. */
453
425
  _value: string[] | null;
454
- /** Emits when the list has been destroyed. */
455
- private _destroyed;
456
426
  /** View to model callback that should be called if the list or its options lost focus. */
457
427
  _onTouched: () => void;
458
- /** Whether the list has been destroyed. */
459
- private _isDestroyed;
460
- constructor(element: ElementRef<HTMLElement>, document: any);
428
+ constructor(_element: ElementRef<HTMLElement>, _ngZone: NgZone);
461
429
  ngAfterViewInit(): void;
462
430
  ngOnChanges(changes: SimpleChanges): void;
463
431
  ngOnDestroy(): void;
@@ -479,18 +447,8 @@ export declare class MatSelectionList extends MatInteractiveListBase<MatListOpti
479
447
  registerOnChange(fn: (value: any) => void): void;
480
448
  /** Implemented as part of ControlValueAccessor. */
481
449
  registerOnTouched(fn: () => void): void;
482
- /**
483
- * Resets tabindex for all options and sets tabindex for the first selected option so that
484
- * it will become active when users tab into the selection-list. This will be a noop if the
485
- * list is currently focused as otherwise multiple options might become reachable through tab.
486
- * e.g. A user currently already focused an option. We set tabindex to a new option but the
487
- * focus on the current option does persist. Pressing `TAB` then might go to the other option
488
- * that received a tabindex. We can skip the reset here as the MDC foundation resets the
489
- * tabindex to the first selected option automatically once the current item is blurred.
490
- */
491
- private _resetTabindexForItemsIfBlurred;
450
+ /** Watches for changes in the selected state of the options and updates the list accordingly. */
492
451
  private _watchForSelectionChange;
493
- private _syncSelectedOptionsWithFoundation;
494
452
  /** Sets the selected options based on the specified values. */
495
453
  private _setOptionsFromValues;
496
454
  /** Returns the values of the selected options. */
@@ -504,6 +462,23 @@ export declare class MatSelectionList extends MatInteractiveListBase<MatListOpti
504
462
  private _setAllOptionsSelected;
505
463
  /** The option components contained within this selection-list. */
506
464
  get options(): QueryList<MatListOption>;
465
+ /** Handles keydown events within the list. */
466
+ _handleKeydown(event: KeyboardEvent): void;
467
+ /** Handles focusout events within the list. */
468
+ private _handleFocusout;
469
+ /** Handles focusin events within the list. */
470
+ private _handleFocusin;
471
+ /** Sets up the logic for maintaining the roving tabindex. */
472
+ private _setupRovingTabindex;
473
+ /**
474
+ * Sets an option as active.
475
+ * @param index Index of the active option. If set to -1, no option will be active.
476
+ */
477
+ private _setActiveOption;
478
+ /** Resets the active option to the first selected option. */
479
+ private _resetActiveOption;
480
+ /** Returns whether the focus is currently within the list. */
481
+ private _containsFocus;
507
482
  static ɵfac: i0.ɵɵFactoryDeclaration<MatSelectionList, never>;
508
483
  static ɵcmp: i0.ɵɵComponentDeclaration<MatSelectionList, "mat-selection-list", ["matSelectionList"], { "color": "color"; "compareWith": "compareWith"; "multiple": "multiple"; }, { "selectionChange": "selectionChange"; }, ["_items"], ["*"], false>;
509
484
  }
@@ -551,8 +526,9 @@ export declare interface SelectionList extends MatListBase {
551
526
  selectedOptions: SelectionModel<MatListOption>;
552
527
  compareWith: (o1: any, o2: any) => boolean;
553
528
  _value: string[] | null;
554
- _reportValueChange: () => void;
555
- _onTouched: () => void;
529
+ _reportValueChange(): void;
530
+ _emitChangeEvent(options: MatListOption[]): void;
531
+ _onTouched(): void;
556
532
  }
557
533
 
558
534
  export { }
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@angular/material-experimental",
3
- "version": "14.0.0-rc.1",
3
+ "version": "14.0.0-rc.2",
4
4
  "description": "Experimental components for Angular Material",
5
5
  "repository": {
6
6
  "type": "git",
@@ -426,12 +426,12 @@
426
426
  },
427
427
  "peerDependencies": {
428
428
  "@angular/animations": "^14.0.0-0 || ^15.0.0",
429
- "@angular/cdk": "14.0.0-rc.1",
429
+ "@angular/cdk": "14.0.0-rc.2",
430
430
  "@angular/core": "^14.0.0-0 || ^15.0.0",
431
431
  "@angular/common": "^14.0.0-0 || ^15.0.0",
432
432
  "@angular/forms": "^14.0.0-0 || ^15.0.0",
433
433
  "@angular/platform-browser": "^14.0.0-0 || ^15.0.0",
434
- "@angular/material": "14.0.0-rc.1"
434
+ "@angular/material": "14.0.0-rc.2"
435
435
  },
436
436
  "dependencies": {
437
437
  "tslib": "^2.3.0",
@@ -1,11 +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 { InjectionToken } from '@angular/core';
9
- /** Injection token to be used to override the default options for the chips module. */
10
- export const MAT_CHIPS_DEFAULT_OPTIONS = new InjectionToken('mat-chips-default-options');
11
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2hpcC1kZWZhdWx0LW9wdGlvbnMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9zcmMvbWF0ZXJpYWwtZXhwZXJpbWVudGFsL21kYy1jaGlwcy9jaGlwLWRlZmF1bHQtb3B0aW9ucy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7Ozs7O0dBTUc7QUFFSCxPQUFPLEVBQUMsY0FBYyxFQUFDLE1BQU0sZUFBZSxDQUFDO0FBUTdDLHVGQUF1RjtBQUN2RixNQUFNLENBQUMsTUFBTSx5QkFBeUIsR0FBRyxJQUFJLGNBQWMsQ0FDekQsMkJBQTJCLENBQzVCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEBsaWNlbnNlXG4gKiBDb3B5cmlnaHQgR29vZ2xlIExMQyBBbGwgUmlnaHRzIFJlc2VydmVkLlxuICpcbiAqIFVzZSBvZiB0aGlzIHNvdXJjZSBjb2RlIGlzIGdvdmVybmVkIGJ5IGFuIE1JVC1zdHlsZSBsaWNlbnNlIHRoYXQgY2FuIGJlXG4gKiBmb3VuZCBpbiB0aGUgTElDRU5TRSBmaWxlIGF0IGh0dHBzOi8vYW5ndWxhci5pby9saWNlbnNlXG4gKi9cblxuaW1wb3J0IHtJbmplY3Rpb25Ub2tlbn0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbi8qKiBEZWZhdWx0IG9wdGlvbnMsIGZvciB0aGUgY2hpcHMgbW9kdWxlLCB0aGF0IGNhbiBiZSBvdmVycmlkZGVuLiAqL1xuZXhwb3J0IGludGVyZmFjZSBNYXRDaGlwc0RlZmF1bHRPcHRpb25zIHtcbiAgLyoqIFRoZSBsaXN0IG9mIGtleSBjb2RlcyB0aGF0IHdpbGwgdHJpZ2dlciBhIGNoaXBFbmQgZXZlbnQuICovXG4gIHNlcGFyYXRvcktleUNvZGVzOiByZWFkb25seSBudW1iZXJbXSB8IFJlYWRvbmx5U2V0PG51bWJlcj47XG59XG5cbi8qKiBJbmplY3Rpb24gdG9rZW4gdG8gYmUgdXNlZCB0byBvdmVycmlkZSB0aGUgZGVmYXVsdCBvcHRpb25zIGZvciB0aGUgY2hpcHMgbW9kdWxlLiAqL1xuZXhwb3J0IGNvbnN0IE1BVF9DSElQU19ERUZBVUxUX09QVElPTlMgPSBuZXcgSW5qZWN0aW9uVG9rZW48TWF0Q2hpcHNEZWZhdWx0T3B0aW9ucz4oXG4gICdtYXQtY2hpcHMtZGVmYXVsdC1vcHRpb25zJyxcbik7XG4iXX0=
@@ -1,27 +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
- /**
9
- * Emits a custom event from an element.
10
- * @param element Element from which to emit the event.
11
- * @param _document Document that the element is placed in.
12
- * @param eventName Name of the event.
13
- * @param data Data attached to the event.
14
- * @param shouldBubble Whether the event should bubble.
15
- */
16
- export function emitCustomEvent(element, _document, eventName, data, shouldBubble) {
17
- let event;
18
- if (typeof CustomEvent === 'function') {
19
- event = new CustomEvent(eventName, { bubbles: shouldBubble, detail: data });
20
- }
21
- else {
22
- event = _document.createEvent('CustomEvent');
23
- event.initCustomEvent(eventName, shouldBubble, false, data);
24
- }
25
- element.dispatchEvent(event);
26
- }
27
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZW1pdC1ldmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3NyYy9tYXRlcmlhbC1leHBlcmltZW50YWwvbWRjLWNoaXBzL2VtaXQtZXZlbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7Ozs7OztHQU1HO0FBRUg7Ozs7Ozs7R0FPRztBQUNILE1BQU0sVUFBVSxlQUFlLENBQzdCLE9BQW9CLEVBQ3BCLFNBQW1CLEVBQ25CLFNBQWlCLEVBQ2pCLElBQU8sRUFDUCxZQUFxQjtJQUVyQixJQUFJLEtBQXFCLENBQUM7SUFDMUIsSUFBSSxPQUFPLFdBQVcsS0FBSyxVQUFVLEVBQUU7UUFDckMsS0FBSyxHQUFHLElBQUksV0FBVyxDQUFJLFNBQVMsRUFBRSxFQUFDLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxFQUFFLElBQUksRUFBQyxDQUFDLENBQUM7S0FDOUU7U0FBTTtRQUNMLEtBQUssR0FBRyxTQUFTLENBQUMsV0FBVyxDQUFDLGFBQWEsQ0FBQyxDQUFDO1FBQzdDLEtBQUssQ0FBQyxlQUFlLENBQUMsU0FBUyxFQUFFLFlBQVksRUFBRSxLQUFLLEVBQUUsSUFBSSxDQUFDLENBQUM7S0FDN0Q7SUFFRCxPQUFPLENBQUMsYUFBYSxDQUFDLEtBQUssQ0FBQyxDQUFDO0FBQy9CLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEBsaWNlbnNlXG4gKiBDb3B5cmlnaHQgR29vZ2xlIExMQyBBbGwgUmlnaHRzIFJlc2VydmVkLlxuICpcbiAqIFVzZSBvZiB0aGlzIHNvdXJjZSBjb2RlIGlzIGdvdmVybmVkIGJ5IGFuIE1JVC1zdHlsZSBsaWNlbnNlIHRoYXQgY2FuIGJlXG4gKiBmb3VuZCBpbiB0aGUgTElDRU5TRSBmaWxlIGF0IGh0dHBzOi8vYW5ndWxhci5pby9saWNlbnNlXG4gKi9cblxuLyoqXG4gKiBFbWl0cyBhIGN1c3RvbSBldmVudCBmcm9tIGFuIGVsZW1lbnQuXG4gKiBAcGFyYW0gZWxlbWVudCBFbGVtZW50IGZyb20gd2hpY2ggdG8gZW1pdCB0aGUgZXZlbnQuXG4gKiBAcGFyYW0gX2RvY3VtZW50IERvY3VtZW50IHRoYXQgdGhlIGVsZW1lbnQgaXMgcGxhY2VkIGluLlxuICogQHBhcmFtIGV2ZW50TmFtZSBOYW1lIG9mIHRoZSBldmVudC5cbiAqIEBwYXJhbSBkYXRhIERhdGEgYXR0YWNoZWQgdG8gdGhlIGV2ZW50LlxuICogQHBhcmFtIHNob3VsZEJ1YmJsZSBXaGV0aGVyIHRoZSBldmVudCBzaG91bGQgYnViYmxlLlxuICovXG5leHBvcnQgZnVuY3Rpb24gZW1pdEN1c3RvbUV2ZW50PFQ+KFxuICBlbGVtZW50OiBIVE1MRWxlbWVudCxcbiAgX2RvY3VtZW50OiBEb2N1bWVudCxcbiAgZXZlbnROYW1lOiBzdHJpbmcsXG4gIGRhdGE6IFQsXG4gIHNob3VsZEJ1YmJsZTogYm9vbGVhbixcbik6IHZvaWQge1xuICBsZXQgZXZlbnQ6IEN1c3RvbUV2ZW50PFQ+O1xuICBpZiAodHlwZW9mIEN1c3RvbUV2ZW50ID09PSAnZnVuY3Rpb24nKSB7XG4gICAgZXZlbnQgPSBuZXcgQ3VzdG9tRXZlbnQ8VD4oZXZlbnROYW1lLCB7YnViYmxlczogc2hvdWxkQnViYmxlLCBkZXRhaWw6IGRhdGF9KTtcbiAgfSBlbHNlIHtcbiAgICBldmVudCA9IF9kb2N1bWVudC5jcmVhdGVFdmVudCgnQ3VzdG9tRXZlbnQnKTtcbiAgICBldmVudC5pbml0Q3VzdG9tRXZlbnQoZXZlbnROYW1lLCBzaG91bGRCdWJibGUsIGZhbHNlLCBkYXRhKTtcbiAgfVxuXG4gIGVsZW1lbnQuZGlzcGF0Y2hFdmVudChldmVudCk7XG59XG4iXX0=
@@ -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"]}