@angular/material 15.1.1 → 15.2.0-next.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.
Files changed (66) hide show
  1. package/autocomplete/index.d.ts +11 -2
  2. package/chips/index.d.ts +14 -1
  3. package/chips/testing/index.d.ts +23 -0
  4. package/core/index.d.ts +10 -2
  5. package/core/selection/pseudo-checkbox/_pseudo-checkbox-common.scss +63 -10
  6. package/core/selection/pseudo-checkbox/_pseudo-checkbox-theme.scss +42 -27
  7. package/esm2020/autocomplete/autocomplete.mjs +30 -6
  8. package/esm2020/chips/chip-listbox.mjs +18 -3
  9. package/esm2020/chips/chip-option.mjs +21 -7
  10. package/esm2020/chips/testing/chip-edit-input-harness.mjs +33 -0
  11. package/esm2020/chips/testing/chip-harness-filters.mjs +1 -1
  12. package/esm2020/chips/testing/chip-row-harness.mjs +20 -2
  13. package/esm2020/chips/testing/public-api.mjs +2 -1
  14. package/esm2020/chips/tokens.mjs +1 -1
  15. package/esm2020/core/option/option-parent.mjs +1 -1
  16. package/esm2020/core/option/option.mjs +7 -3
  17. package/esm2020/core/selection/pseudo-checkbox/pseudo-checkbox.mjs +12 -3
  18. package/esm2020/core/version.mjs +1 -1
  19. package/esm2020/legacy-core/option/option.mjs +1 -1
  20. package/esm2020/legacy-list/selection-list.mjs +1 -1
  21. package/esm2020/paginator/paginator.mjs +1 -1
  22. package/esm2020/select/select.mjs +21 -2
  23. package/fesm2015/autocomplete.mjs +30 -5
  24. package/fesm2015/autocomplete.mjs.map +1 -1
  25. package/fesm2015/chips/testing.mjs +51 -2
  26. package/fesm2015/chips/testing.mjs.map +1 -1
  27. package/fesm2015/chips.mjs +36 -6
  28. package/fesm2015/chips.mjs.map +1 -1
  29. package/fesm2015/core.mjs +18 -5
  30. package/fesm2015/core.mjs.map +1 -1
  31. package/fesm2015/legacy-core.mjs +1 -1
  32. package/fesm2015/legacy-core.mjs.map +1 -1
  33. package/fesm2015/legacy-list.mjs +1 -1
  34. package/fesm2015/legacy-list.mjs.map +1 -1
  35. package/fesm2015/paginator.mjs +1 -1
  36. package/fesm2015/paginator.mjs.map +1 -1
  37. package/fesm2015/select.mjs +21 -1
  38. package/fesm2015/select.mjs.map +1 -1
  39. package/fesm2020/autocomplete.mjs +29 -5
  40. package/fesm2020/autocomplete.mjs.map +1 -1
  41. package/fesm2020/chips/testing.mjs +50 -2
  42. package/fesm2020/chips/testing.mjs.map +1 -1
  43. package/fesm2020/chips.mjs +34 -6
  44. package/fesm2020/chips.mjs.map +1 -1
  45. package/fesm2020/core.mjs +18 -5
  46. package/fesm2020/core.mjs.map +1 -1
  47. package/fesm2020/legacy-core.mjs +1 -1
  48. package/fesm2020/legacy-core.mjs.map +1 -1
  49. package/fesm2020/legacy-list.mjs +1 -1
  50. package/fesm2020/legacy-list.mjs.map +1 -1
  51. package/fesm2020/paginator.mjs +1 -1
  52. package/fesm2020/paginator.mjs.map +1 -1
  53. package/fesm2020/select.mjs +20 -1
  54. package/fesm2020/select.mjs.map +1 -1
  55. package/legacy-prebuilt-themes/legacy-deeppurple-amber.css +1 -1
  56. package/legacy-prebuilt-themes/legacy-indigo-pink.css +1 -1
  57. package/legacy-prebuilt-themes/legacy-pink-bluegrey.css +1 -1
  58. package/legacy-prebuilt-themes/legacy-purple-green.css +1 -1
  59. package/package.json +7 -7
  60. package/prebuilt-themes/deeppurple-amber.css +1 -1
  61. package/prebuilt-themes/indigo-pink.css +1 -1
  62. package/prebuilt-themes/pink-bluegrey.css +1 -1
  63. package/prebuilt-themes/purple-green.css +1 -1
  64. package/schematics/ng-add/index.js +2 -2
  65. package/schematics/ng-add/index.mjs +2 -2
  66. package/select/index.d.ts +10 -2
@@ -105,8 +105,14 @@ export declare class MatAutocomplete extends _MatAutocompleteBase {
105
105
  options: QueryList<MatOption>;
106
106
  protected _visibleClass: string;
107
107
  protected _hiddenClass: string;
108
+ /** Whether checkmark indicator for single-selection options is hidden. */
109
+ get hideSingleSelectionIndicator(): boolean;
110
+ set hideSingleSelectionIndicator(value: BooleanInput);
111
+ private _hideSingleSelectionIndicator;
112
+ /** Syncs the parent state with the individual options. */
113
+ _syncParentProperties(): void;
108
114
  static ɵfac: i0.ɵɵFactoryDeclaration<MatAutocomplete, never>;
109
- static ɵcmp: i0.ɵɵComponentDeclaration<MatAutocomplete, "mat-autocomplete", ["matAutocomplete"], { "disableRipple": "disableRipple"; }, {}, ["optionGroups", "options"], ["*"], false, never>;
115
+ static ɵcmp: i0.ɵɵComponentDeclaration<MatAutocomplete, "mat-autocomplete", ["matAutocomplete"], { "disableRipple": "disableRipple"; "hideSingleSelectionIndicator": "hideSingleSelectionIndicator"; }, {}, ["optionGroups", "options"], ["*"], false, never>;
110
116
  }
111
117
 
112
118
  /** Event object that is emitted when an autocomplete option is activated. */
@@ -121,6 +127,7 @@ export declare interface MatAutocompleteActivatedEvent {
121
127
  export declare abstract class _MatAutocompleteBase extends _MatAutocompleteMixinBase implements AfterContentInit, CanDisableRipple, OnDestroy {
122
128
  private _changeDetectorRef;
123
129
  private _elementRef;
130
+ protected _defaults: MatAutocompleteDefaultOptions;
124
131
  private _activeOptionChanges;
125
132
  /** Class to apply to the panel when it's visible. */
126
133
  protected abstract _visibleClass: string;
@@ -190,7 +197,7 @@ export declare abstract class _MatAutocompleteBase extends _MatAutocompleteMixin
190
197
  * @docs-private
191
198
  */
192
199
  readonly inertGroups: boolean;
193
- constructor(_changeDetectorRef: ChangeDetectorRef, _elementRef: ElementRef<HTMLElement>, defaults: MatAutocompleteDefaultOptions, platform?: Platform);
200
+ constructor(_changeDetectorRef: ChangeDetectorRef, _elementRef: ElementRef<HTMLElement>, _defaults: MatAutocompleteDefaultOptions, platform?: Platform);
194
201
  ngAfterContentInit(): void;
195
202
  ngOnDestroy(): void;
196
203
  /**
@@ -222,6 +229,8 @@ export declare interface MatAutocompleteDefaultOptions {
222
229
  autoSelectActiveOption?: boolean;
223
230
  /** Class or list of classes to be applied to the autocomplete's overlay panel. */
224
231
  overlayPanelClass?: string | string[];
232
+ /** Wheter icon indicators should be hidden for single-selection. */
233
+ hideSingleSelectionIndicator?: boolean;
225
234
  }
226
235
 
227
236
  /** @docs-private */
package/chips/index.d.ts CHANGED
@@ -614,6 +614,8 @@ export declare class MatChipListbox extends MatChipSet implements AfterContentIn
614
614
  protected _defaultRole: string;
615
615
  /** Value that was assigned before the listbox was initialized. */
616
616
  private _pendingInitialValue;
617
+ /** Default chip options. */
618
+ private _defaultOptions;
617
619
  /** Whether the user should be allowed to select multiple chips. */
618
620
  get multiple(): boolean;
619
621
  set multiple(value: BooleanInput);
@@ -641,6 +643,10 @@ export declare class MatChipListbox extends MatChipSet implements AfterContentIn
641
643
  get required(): boolean;
642
644
  set required(value: BooleanInput);
643
645
  protected _required: boolean;
646
+ /** Whether checkmark indicator for single-selection options is hidden. */
647
+ get hideSingleSelectionIndicator(): boolean;
648
+ set hideSingleSelectionIndicator(value: BooleanInput);
649
+ private _hideSingleSelectionIndicator;
644
650
  /** Combined stream of all of the child chips' selection change events. */
645
651
  get chipSelectionChanges(): Observable<MatChipSelectionChange>;
646
652
  /** Combined stream of all of the child chips' blur events. */
@@ -707,7 +713,7 @@ export declare class MatChipListbox extends MatChipSet implements AfterContentIn
707
713
  */
708
714
  protected _skipPredicate(action: MatChipAction): boolean;
709
715
  static ɵfac: i0.ɵɵFactoryDeclaration<MatChipListbox, never>;
710
- static ɵcmp: i0.ɵɵComponentDeclaration<MatChipListbox, "mat-chip-listbox", never, { "tabIndex": "tabIndex"; "multiple": "multiple"; "ariaOrientation": "aria-orientation"; "selectable": "selectable"; "compareWith": "compareWith"; "required": "required"; "value": "value"; }, { "change": "change"; }, ["_chips"], ["*"], false, never>;
716
+ static ɵcmp: i0.ɵɵComponentDeclaration<MatChipListbox, "mat-chip-listbox", never, { "tabIndex": "tabIndex"; "multiple": "multiple"; "ariaOrientation": "aria-orientation"; "selectable": "selectable"; "compareWith": "compareWith"; "required": "required"; "hideSingleSelectionIndicator": "hideSingleSelectionIndicator"; "value": "value"; }, { "change": "change"; }, ["_chips"], ["*"], false, never>;
711
717
  }
712
718
 
713
719
  /** Change event object that is emitted when the chip listbox value has changed. */
@@ -740,10 +746,14 @@ declare const _MatChipMixinBase: _Constructor<HasTabIndex> & _AbstractConstructo
740
746
  * user cannot click disabled chips.
741
747
  */
742
748
  export declare class MatChipOption extends MatChip implements OnInit {
749
+ /** Default chip options. */
750
+ private _defaultOptions;
743
751
  /** Whether the chip list is selectable. */
744
752
  chipListSelectable: boolean;
745
753
  /** Whether the chip list is in multi-selection mode. */
746
754
  _chipListMultiple: boolean;
755
+ /** Whether the chip list hides single-selection indicator. */
756
+ _chipListHideSingleSelectionIndicator: boolean;
747
757
  /**
748
758
  * Whether or not the chip is selectable.
749
759
  *
@@ -786,6 +796,7 @@ export declare class MatChipOption extends MatChip implements OnInit {
786
796
  /** Toggles the current selected state of this chip. */
787
797
  toggleSelected(isUserInput?: boolean): boolean;
788
798
  _handlePrimaryActionInteraction(): void;
799
+ _hasLeadingGraphic(): boolean;
789
800
  _setSelectedState(isSelected: boolean, isUserInput: boolean, emitEvent: boolean): void;
790
801
  static ɵfac: i0.ɵɵFactoryDeclaration<MatChipOption, never>;
791
802
  static ɵcmp: i0.ɵɵComponentDeclaration<MatChipOption, "mat-basic-chip-option, mat-chip-option", never, { "color": "color"; "disabled": "disabled"; "disableRipple": "disableRipple"; "tabIndex": "tabIndex"; "selectable": "selectable"; "selected": "selected"; }, { "selectionChange": "selectionChange"; }, never, ["mat-chip-avatar, [matChipAvatar]", "*", "mat-chip-trailing-icon,[matChipRemove],[matChipTrailingIcon]"], false, never>;
@@ -855,6 +866,8 @@ export declare class MatChipRow extends MatChip implements AfterViewInit {
855
866
  export declare interface MatChipsDefaultOptions {
856
867
  /** The list of key codes that will trigger a chipEnd event. */
857
868
  separatorKeyCodes: readonly number[] | ReadonlySet<number>;
869
+ /** Wheter icon indicators should be hidden for single-selection. */
870
+ hideSingleSelectionIndicator?: boolean;
858
871
  }
859
872
 
860
873
  /** Event object emitted by MatChipOption when selected or deselected. */
@@ -10,6 +10,9 @@ import { TestKey } from '@angular/cdk/testing';
10
10
  export declare interface ChipAvatarHarnessFilters extends BaseHarnessFilters {
11
11
  }
12
12
 
13
+ export declare interface ChipEditInputHarnessFilters extends BaseHarnessFilters {
14
+ }
15
+
13
16
  export declare interface ChipGridHarnessFilters extends BaseHarnessFilters {
14
17
  /** Only find instances which match the given disabled state. */
15
18
  disabled?: boolean;
@@ -62,6 +65,20 @@ export declare class MatChipAvatarHarness extends ComponentHarness {
62
65
  static with<T extends MatChipAvatarHarness>(this: ComponentHarnessConstructor<T>, options?: ChipAvatarHarnessFilters): HarnessPredicate<T>;
63
66
  }
64
67
 
68
+ /** Harness for interacting with an editable chip's input in tests. */
69
+ export declare class MatChipEditInputHarness extends ComponentHarness {
70
+ static hostSelector: string;
71
+ /**
72
+ * Gets a `HarnessPredicate` that can be used to search for a chip edit input with specific
73
+ * attributes.
74
+ * @param options Options for filtering which input instances are considered a match.
75
+ * @return a `HarnessPredicate` configured with the given options.
76
+ */
77
+ static with<T extends MatChipEditInputHarness>(this: ComponentHarnessConstructor<T>, options?: ChipEditInputHarnessFilters): HarnessPredicate<T>;
78
+ /** Sets the value of the input. */
79
+ setValue(value: string): Promise<void>;
80
+ }
81
+
65
82
  /** Harness for interacting with a mat-chip-grid in tests. */
66
83
  export declare class MatChipGridHarness extends ComponentHarness {
67
84
  static hostSelector: string;
@@ -222,6 +239,12 @@ export declare class MatChipRowHarness extends MatChipHarness {
222
239
  isEditable(): Promise<boolean>;
223
240
  /** Whether the chip is currently being edited. */
224
241
  isEditing(): Promise<boolean>;
242
+ /** Sets the chip row into an editing state, if it is editable. */
243
+ startEditing(): Promise<void>;
244
+ /** Stops editing the chip, if it was in the editing state. */
245
+ finishEditing(): Promise<void>;
246
+ /** Gets the edit input inside the chip row. */
247
+ getEditInput(filter?: ChipEditInputHarnessFilters): Promise<MatChipEditInputHarness>;
225
248
  }
226
249
 
227
250
  /** Harness for interacting with a mat-chip-set in tests. */
package/core/index.d.ts CHANGED
@@ -564,7 +564,7 @@ export declare class MatOption<T = any> extends _MatOptionBase<T> {
564
564
 
565
565
  export declare class _MatOptionBase<T = any> implements FocusableOption, AfterViewChecked, OnDestroy {
566
566
  private _element;
567
- private _changeDetectorRef;
567
+ _changeDetectorRef: ChangeDetectorRef;
568
568
  private _parent;
569
569
  readonly group: _MatOptgroupBase;
570
570
  private _selected;
@@ -584,6 +584,8 @@ export declare class _MatOptionBase<T = any> implements FocusableOption, AfterVi
584
584
  set disabled(value: BooleanInput);
585
585
  /** Whether ripples for the option are disabled. */
586
586
  get disableRipple(): boolean;
587
+ /** Whether to display checkmark for single-selection. */
588
+ get hideSingleSelectionIndicator(): boolean;
587
589
  /** Event emitted when the option is selected or deselected. */
588
590
  readonly onSelectionChange: EventEmitter<MatOptionSelectionChange<T>>;
589
591
  /** Element containing the option's text. */
@@ -664,6 +666,7 @@ export declare interface MatOptionParentComponent {
664
666
  disableRipple?: boolean;
665
667
  multiple?: boolean;
666
668
  inertGroups?: boolean;
669
+ hideSingleSelectionIndicator?: boolean;
667
670
  }
668
671
 
669
672
  /** Event object emitted by MatOption when selected or deselected. */
@@ -698,9 +701,14 @@ export declare class MatPseudoCheckbox {
698
701
  state: MatPseudoCheckboxState;
699
702
  /** Whether the checkbox is disabled. */
700
703
  disabled: boolean;
704
+ /**
705
+ * Appearance of the pseudo checkbox. Default appearance of 'full' renders a checkmark/mixedmark
706
+ * indicator inside a square box. 'minimal' appearance only renders the checkmark/mixedmark.
707
+ */
708
+ appearance: 'minimal' | 'full';
701
709
  constructor(_animationMode?: string | undefined);
702
710
  static ɵfac: i0.ɵɵFactoryDeclaration<MatPseudoCheckbox, [{ optional: true; }]>;
703
- static ɵcmp: i0.ɵɵComponentDeclaration<MatPseudoCheckbox, "mat-pseudo-checkbox", never, { "state": "state"; "disabled": "disabled"; }, {}, never, never, false, never>;
711
+ static ɵcmp: i0.ɵɵComponentDeclaration<MatPseudoCheckbox, "mat-pseudo-checkbox", never, { "state": "state"; "disabled": "disabled"; "appearance": "appearance"; }, {}, never, never, false, never>;
704
712
  }
705
713
 
706
714
  export declare class MatPseudoCheckboxModule {
@@ -4,26 +4,79 @@
4
4
  // Padding inside of a pseudo checkbox.
5
5
  $padding: checkbox-common.$border-width * 2;
6
6
 
7
+ // Center a checkmark indicator inside the checkbox.
8
+ //
9
+ // `$box-size`: size of the checkbox
10
+ // `$mark-size`: size of the checkmark indicator
11
+ @mixin _checkbox-checked-styles-with-size($box-size, $mark-size) {
12
+ // Center a checkmark. `$checkbox-cmmon.$border-width` is the width of the line of the checkmark.
13
+ $width: $mark-size;
14
+ $height: math.div($mark-size - checkbox-common.$border-width, 2);
15
+
16
+ // The rendered length of the short-side of the checkmark graphic when rendered. Add length of
17
+ // the border-width since this element is content-box.
18
+ $short-side: $height + checkbox-common.$border-width;
19
+
20
+ width: $width;
21
+ height: $height;
22
+
23
+ // Rotate on the center of the element. This makes it easier to center the checkmark graphic.
24
+ transform-origin: center;
25
+
26
+ // Take negative one times the distance from the top corner of the checkmark graphic to the top
27
+ // of the element in its rotated position. This accounts for the top corner of the elemant being
28
+ // blank since we only use the left and bottom borders to draw the checkmark graphic.
29
+ top: -1 * math.div($short-side - checkbox-common.$border-width, math.sqrt(2));
30
+
31
+ left: 0;
32
+ bottom: 0;
33
+ right: 0;
34
+
35
+ // center the checkmark graphic with margin auto
36
+ margin: auto;
37
+ }
38
+
39
+ // Center a horizontal line placed in the vertical and horizontal center of the checkbox. It does
40
+ // not touch the border of the checkbox.
41
+ //
42
+ // `$box-size`: size of the checkbox.
43
+ // `$border-size`: size of the checkbox's border.
44
+ @mixin _checkbox-indeterminate-styles-with-size($box-size, $border-size) {
45
+ // Center the line in the the checkbox. `$checkbox-common.$border-width` is the width of the line.
46
+ top: math.div($box-size - checkbox-common.$border-width, 2) - $border-size;
47
+ width: $box-size - checkbox-common.$border-width - (2 * $border-size);
48
+ }
49
+
7
50
  /// Applies the styles that set the size of the pseudo checkbox
8
51
  @mixin size($box-size) {
9
- $mark-size: $box-size - (2 * $padding);
10
52
 
11
53
  .mat-pseudo-checkbox {
12
54
  width: $box-size;
13
55
  height: $box-size;
14
56
  }
15
57
 
16
- .mat-pseudo-checkbox-indeterminate::after {
17
- top: math.div($box-size - checkbox-common.$border-width, 2) -
18
- checkbox-common.$border-width;
19
- width: $box-size - 6px;
58
+ .mat-pseudo-checkbox-minimal {
59
+ $mark-size: $box-size - $padding;
60
+ $border-size: 0; // Minimal appearance does not have a border.
61
+
62
+ &.mat-pseudo-checkbox-checked::after {
63
+ @include _checkbox-checked-styles-with-size($box-size, $mark-size);
64
+ }
65
+ &.mat-pseudo-checkbox-indeterminate::after {
66
+ @include _checkbox-indeterminate-styles-with-size($box-size, $border-size);
67
+ }
20
68
  }
21
69
 
22
- .mat-pseudo-checkbox-checked::after {
23
- top: math.div($box-size, 2) - math.div($mark-size, 4) -
24
- math.div($box-size, 10) - checkbox-common.$border-width;
25
- width: $mark-size;
26
- height: math.div($mark-size - checkbox-common.$border-width, 2);
70
+ .mat-pseudo-checkbox-full {
71
+ $mark-size: $box-size - (2 * $padding); // Apply a smaller mark to account for the border.
72
+ $border-size: checkbox-common.$border-width;
73
+
74
+ &.mat-pseudo-checkbox-checked::after {
75
+ @include _checkbox-checked-styles-with-size($box-size, $mark-size);
76
+ }
77
+ &.mat-pseudo-checkbox-indeterminate::after {
78
+ @include _checkbox-indeterminate-styles-with-size($box-size, $border-size);
79
+ }
27
80
  }
28
81
  }
29
82
 
@@ -1,13 +1,33 @@
1
1
  @use 'sass:map';
2
2
  @use '../../theming/theming';
3
3
 
4
+ @mixin _psuedo-checkbox-styles-with-color($text-color, $background) {
5
+ .mat-pseudo-checkbox-checked,
6
+ .mat-pseudo-checkbox-indeterminate {
7
+ &.mat-pseudo-checkbox-minimal::after {
8
+ color: $text-color;
9
+ }
10
+
11
+ // Full (checkbox) appearance inverts colors of text and background.
12
+ &.mat-pseudo-checkbox-full {
13
+ &::after {
14
+ color: $background;
15
+ }
16
+
17
+ background: $text-color;
18
+ }
19
+ }
20
+ }
21
+
4
22
  @mixin color($config-or-theme) {
5
23
  $config: theming.get-color-config($config-or-theme);
6
24
  $is-dark-theme: map.get($config, is-dark);
7
- $primary: map.get($config, primary);
8
- $accent: map.get($config, accent);
9
- $warn: map.get($config, warn);
10
- $background: map.get($config, background);
25
+
26
+ $primary: theming.get-color-from-palette(map.get($config, primary));
27
+ $accent: theming.get-color-from-palette(map.get($config, accent));
28
+ $warn: theming.get-color-from-palette(map.get($config, warn));
29
+ $background: theming.get-color-from-palette(map.get($config, background), background);
30
+ $secondary-text: theming.get-color-from-palette(map.get($config, foreground), secondary-text);
11
31
 
12
32
  // NOTE(traviskaufman): While the spec calls for translucent blacks/whites for disabled colors,
13
33
  // this does not work well with elements layered on top of one another. To get around this we
@@ -17,21 +37,15 @@
17
37
  $disabled-color: if($is-dark-theme, $white-30pct-opacity-on-dark, $black-26pct-opacity-on-light);
18
38
  $colored-box-selector: '.mat-pseudo-checkbox-checked, .mat-pseudo-checkbox-indeterminate';
19
39
 
20
- .mat-pseudo-checkbox {
21
- color: theming.get-color-from-palette(map.get($config, foreground), secondary-text);
22
-
23
- &::after {
24
- color: theming.get-color-from-palette($background, background);
40
+ .mat-pseudo-checkbox-full {
41
+ color: $secondary-text;
42
+ &.mat-pseudo-checkbox-disabled {
43
+ color: $disabled-color;
25
44
  }
26
45
  }
27
46
 
28
- .mat-pseudo-checkbox-disabled {
29
- color: $disabled-color;
30
- }
31
-
32
- .mat-primary .mat-pseudo-checkbox-checked,
33
- .mat-primary .mat-pseudo-checkbox-indeterminate {
34
- background: theming.get-color-from-palette(map.get($config, primary));
47
+ .mat-primary {
48
+ @include _psuedo-checkbox-styles-with-color($primary, $background);
35
49
  }
36
50
 
37
51
  // Default to the accent color. Note that the pseudo checkboxes are meant to inherit the
@@ -39,21 +53,22 @@
39
53
  // don't attach to the `mat-*` classes. Also note that this needs to be below `.mat-primary`
40
54
  // in order to allow for the color to be overwritten if the checkbox is inside a parent that
41
55
  // has `mat-accent` and is placed inside another parent that has `mat-primary`.
42
- .mat-pseudo-checkbox-checked,
43
- .mat-pseudo-checkbox-indeterminate,
44
- .mat-accent .mat-pseudo-checkbox-checked,
45
- .mat-accent .mat-pseudo-checkbox-indeterminate {
46
- background: theming.get-color-from-palette(map.get($config, accent));
56
+ @include _psuedo-checkbox-styles-with-color($accent, $background);
57
+ .mat-accent {
58
+ @include _psuedo-checkbox-styles-with-color($accent, $background);
47
59
  }
48
60
 
49
- .mat-warn .mat-pseudo-checkbox-checked,
50
- .mat-warn .mat-pseudo-checkbox-indeterminate {
51
- background: theming.get-color-from-palette(map.get($config, warn));
61
+ .mat-warn {
62
+ @include _psuedo-checkbox-styles-with-color($warn, $background);
52
63
  }
53
64
 
54
- .mat-pseudo-checkbox-checked,
55
- .mat-pseudo-checkbox-indeterminate {
56
- &.mat-pseudo-checkbox-disabled {
65
+ .mat-pseudo-checkbox-disabled.mat-pseudo-checkbox-checked,
66
+ .mat-pseudo-checkbox-disabled.mat-pseudo-checkbox-indeterminate {
67
+ &.mat-pseudo-checkbox-minimal::after {
68
+ color: $disabled-color;
69
+ }
70
+
71
+ &.mat-pseudo-checkbox-full {
57
72
  background: $disabled-color;
58
73
  }
59
74
  }
@@ -42,7 +42,11 @@ export const MAT_AUTOCOMPLETE_DEFAULT_OPTIONS = new InjectionToken('mat-autocomp
42
42
  });
43
43
  /** @docs-private */
44
44
  export function MAT_AUTOCOMPLETE_DEFAULT_OPTIONS_FACTORY() {
45
- return { autoActiveFirstOption: false, autoSelectActiveOption: false };
45
+ return {
46
+ autoActiveFirstOption: false,
47
+ autoSelectActiveOption: false,
48
+ hideSingleSelectionIndicator: false,
49
+ };
46
50
  }
47
51
  /** Base class with all of the `MatAutocomplete` functionality. */
48
52
  export class _MatAutocompleteBase extends _MatAutocompleteMixinBase {
@@ -90,16 +94,19 @@ export class _MatAutocompleteBase extends _MatAutocompleteMixinBase {
90
94
  this._setThemeClasses(this._classList);
91
95
  this._elementRef.nativeElement.className = '';
92
96
  }
93
- constructor(_changeDetectorRef, _elementRef, defaults, platform) {
97
+ constructor(_changeDetectorRef, _elementRef, _defaults, platform) {
94
98
  super();
95
99
  this._changeDetectorRef = _changeDetectorRef;
96
100
  this._elementRef = _elementRef;
101
+ this._defaults = _defaults;
97
102
  this._activeOptionChanges = Subscription.EMPTY;
98
103
  /** Whether the autocomplete panel should be visible, depending on option length. */
99
104
  this.showPanel = false;
100
105
  this._isOpen = false;
101
106
  /** Function that maps an option's control value to its display value in the trigger. */
102
107
  this.displayWith = null;
108
+ this._autoActiveFirstOption = !!this._defaults.autoActiveFirstOption;
109
+ this._autoSelectActiveOption = !!this._defaults.autoSelectActiveOption;
103
110
  /** Event that is emitted whenever an option from the list is selected. */
104
111
  this.optionSelected = new EventEmitter();
105
112
  /** Event that is emitted when the autocomplete panel is opened. */
@@ -116,8 +123,6 @@ export class _MatAutocompleteBase extends _MatAutocompleteMixinBase {
116
123
  // wasn't resolved in VoiceOver, and if it has, we can remove this and the `inertGroups`
117
124
  // option altogether.
118
125
  this.inertGroups = platform?.SAFARI || false;
119
- this._autoActiveFirstOption = !!defaults.autoActiveFirstOption;
120
- this._autoSelectActiveOption = !!defaults.autoSelectActiveOption;
121
126
  }
122
127
  ngAfterContentInit() {
123
128
  this._keyManager = new ActiveDescendantKeyManager(this.options).withWrap();
@@ -221,10 +226,27 @@ export class MatAutocomplete extends _MatAutocompleteBase {
221
226
  super(...arguments);
222
227
  this._visibleClass = 'mat-mdc-autocomplete-visible';
223
228
  this._hiddenClass = 'mat-mdc-autocomplete-hidden';
229
+ this._hideSingleSelectionIndicator = this._defaults.hideSingleSelectionIndicator ?? false;
230
+ }
231
+ /** Whether checkmark indicator for single-selection options is hidden. */
232
+ get hideSingleSelectionIndicator() {
233
+ return this._hideSingleSelectionIndicator;
234
+ }
235
+ set hideSingleSelectionIndicator(value) {
236
+ this._hideSingleSelectionIndicator = coerceBooleanProperty(value);
237
+ this._syncParentProperties();
238
+ }
239
+ /** Syncs the parent state with the individual options. */
240
+ _syncParentProperties() {
241
+ if (this.options) {
242
+ for (const option of this.options) {
243
+ option._changeDetectorRef.markForCheck();
244
+ }
245
+ }
224
246
  }
225
247
  }
226
248
  MatAutocomplete.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.1.0", ngImport: i0, type: MatAutocomplete, deps: null, target: i0.ɵɵFactoryTarget.Component });
227
- MatAutocomplete.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.1.0", type: MatAutocomplete, selector: "mat-autocomplete", inputs: { disableRipple: "disableRipple" }, host: { classAttribute: "mat-mdc-autocomplete" }, providers: [{ provide: MAT_OPTION_PARENT_COMPONENT, useExisting: MatAutocomplete }], queries: [{ propertyName: "optionGroups", predicate: MAT_OPTGROUP, descendants: true }, { propertyName: "options", predicate: MatOption, descendants: true }], exportAs: ["matAutocomplete"], usesInheritance: true, ngImport: i0, template: "<ng-template let-formFieldId=\"id\">\n <div\n class=\"mat-mdc-autocomplete-panel mdc-menu-surface mdc-menu-surface--open\"\n role=\"listbox\"\n [id]=\"id\"\n [ngClass]=\"_classList\"\n [attr.aria-label]=\"ariaLabel || null\"\n [attr.aria-labelledby]=\"_getPanelAriaLabelledby(formFieldId)\"\n [@panelAnimation]=\"isOpen ? 'visible' : 'hidden'\"\n #panel>\n <ng-content></ng-content>\n </div>\n</ng-template>\n", styles: [".mdc-menu-surface{display:none;position:absolute;box-sizing:border-box;max-width:calc(100vw - 32px);max-width:var(--mdc-menu-max-width, calc(100vw - 32px));max-height:calc(100vh - 32px);max-height:var(--mdc-menu-max-height, calc(100vh - 32px));margin:0;padding:0;transform:scale(1);transform-origin:top left;opacity:0;overflow:auto;will-change:transform,opacity;z-index:8;border-radius:4px;border-radius:var(--mdc-shape-medium, 4px);transform-origin-left:top left;transform-origin-right:top right}.mdc-menu-surface:focus{outline:none}.mdc-menu-surface--animating-open{display:inline-block;transform:scale(0.8);opacity:0}.mdc-menu-surface--open{display:inline-block;transform:scale(1);opacity:1}.mdc-menu-surface--animating-closed{display:inline-block;opacity:0}[dir=rtl] .mdc-menu-surface,.mdc-menu-surface[dir=rtl]{transform-origin-left:top right;transform-origin-right:top left}.mdc-menu-surface--anchor{position:relative;overflow:visible}.mdc-menu-surface--fixed{position:fixed}.mdc-menu-surface--fullwidth{width:100%}.mdc-menu-surface.mat-mdc-autocomplete-panel{width:100%;max-height:256px;position:static;visibility:hidden;transform-origin:center top;margin:0;padding:8px 0;list-style-type:none}.mdc-menu-surface.mat-mdc-autocomplete-panel:focus{outline:none}.cdk-high-contrast-active .mdc-menu-surface.mat-mdc-autocomplete-panel{outline:solid 1px}.cdk-overlay-pane:not(.mat-mdc-autocomplete-panel-above) .mdc-menu-surface.mat-mdc-autocomplete-panel{border-top-left-radius:0;border-top-right-radius:0}.mat-mdc-autocomplete-panel-above .mdc-menu-surface.mat-mdc-autocomplete-panel{border-bottom-left-radius:0;border-bottom-right-radius:0;transform-origin:center bottom}.mdc-menu-surface.mat-mdc-autocomplete-panel.mat-mdc-autocomplete-visible{visibility:visible}.mdc-menu-surface.mat-mdc-autocomplete-panel.mat-mdc-autocomplete-hidden{visibility:hidden}mat-autocomplete{display:none}"], dependencies: [{ kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }], animations: [panelAnimation], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
249
+ MatAutocomplete.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.1.0", type: MatAutocomplete, selector: "mat-autocomplete", inputs: { disableRipple: "disableRipple", hideSingleSelectionIndicator: "hideSingleSelectionIndicator" }, host: { classAttribute: "mat-mdc-autocomplete" }, providers: [{ provide: MAT_OPTION_PARENT_COMPONENT, useExisting: MatAutocomplete }], queries: [{ propertyName: "optionGroups", predicate: MAT_OPTGROUP, descendants: true }, { propertyName: "options", predicate: MatOption, descendants: true }], exportAs: ["matAutocomplete"], usesInheritance: true, ngImport: i0, template: "<ng-template let-formFieldId=\"id\">\n <div\n class=\"mat-mdc-autocomplete-panel mdc-menu-surface mdc-menu-surface--open\"\n role=\"listbox\"\n [id]=\"id\"\n [ngClass]=\"_classList\"\n [attr.aria-label]=\"ariaLabel || null\"\n [attr.aria-labelledby]=\"_getPanelAriaLabelledby(formFieldId)\"\n [@panelAnimation]=\"isOpen ? 'visible' : 'hidden'\"\n #panel>\n <ng-content></ng-content>\n </div>\n</ng-template>\n", styles: [".mdc-menu-surface{display:none;position:absolute;box-sizing:border-box;max-width:calc(100vw - 32px);max-width:var(--mdc-menu-max-width, calc(100vw - 32px));max-height:calc(100vh - 32px);max-height:var(--mdc-menu-max-height, calc(100vh - 32px));margin:0;padding:0;transform:scale(1);transform-origin:top left;opacity:0;overflow:auto;will-change:transform,opacity;z-index:8;border-radius:4px;border-radius:var(--mdc-shape-medium, 4px);transform-origin-left:top left;transform-origin-right:top right}.mdc-menu-surface:focus{outline:none}.mdc-menu-surface--animating-open{display:inline-block;transform:scale(0.8);opacity:0}.mdc-menu-surface--open{display:inline-block;transform:scale(1);opacity:1}.mdc-menu-surface--animating-closed{display:inline-block;opacity:0}[dir=rtl] .mdc-menu-surface,.mdc-menu-surface[dir=rtl]{transform-origin-left:top right;transform-origin-right:top left}.mdc-menu-surface--anchor{position:relative;overflow:visible}.mdc-menu-surface--fixed{position:fixed}.mdc-menu-surface--fullwidth{width:100%}.mdc-menu-surface.mat-mdc-autocomplete-panel{width:100%;max-height:256px;position:static;visibility:hidden;transform-origin:center top;margin:0;padding:8px 0;list-style-type:none}.mdc-menu-surface.mat-mdc-autocomplete-panel:focus{outline:none}.cdk-high-contrast-active .mdc-menu-surface.mat-mdc-autocomplete-panel{outline:solid 1px}.cdk-overlay-pane:not(.mat-mdc-autocomplete-panel-above) .mdc-menu-surface.mat-mdc-autocomplete-panel{border-top-left-radius:0;border-top-right-radius:0}.mat-mdc-autocomplete-panel-above .mdc-menu-surface.mat-mdc-autocomplete-panel{border-bottom-left-radius:0;border-bottom-right-radius:0;transform-origin:center bottom}.mdc-menu-surface.mat-mdc-autocomplete-panel.mat-mdc-autocomplete-visible{visibility:visible}.mdc-menu-surface.mat-mdc-autocomplete-panel.mat-mdc-autocomplete-hidden{visibility:hidden}mat-autocomplete{display:none}"], dependencies: [{ kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }], animations: [panelAnimation], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
228
250
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.1.0", ngImport: i0, type: MatAutocomplete, decorators: [{
229
251
  type: Component,
230
252
  args: [{ selector: 'mat-autocomplete', encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, exportAs: 'matAutocomplete', inputs: ['disableRipple'], host: {
@@ -236,5 +258,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.1.0", ngImpor
236
258
  }], options: [{
237
259
  type: ContentChildren,
238
260
  args: [MatOption, { descendants: true }]
261
+ }], hideSingleSelectionIndicator: [{
262
+ type: Input
239
263
  }] } });
240
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"autocomplete.js","sourceRoot":"","sources":["../../../../../../src/material/autocomplete/autocomplete.ts","../../../../../../src/material/autocomplete/autocomplete.html"],"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 {\n  AfterContentInit,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ContentChildren,\n  Directive,\n  ElementRef,\n  EventEmitter,\n  Inject,\n  InjectionToken,\n  Input,\n  OnDestroy,\n  Output,\n  QueryList,\n  TemplateRef,\n  ViewChild,\n  ViewEncapsulation,\n} from '@angular/core';\nimport {\n  MAT_OPTGROUP,\n  MAT_OPTION_PARENT_COMPONENT,\n  MatOptgroup,\n  MatOption,\n  mixinDisableRipple,\n  CanDisableRipple,\n  _MatOptionBase,\n  _MatOptgroupBase,\n  ThemePalette,\n} from '@angular/material/core';\nimport {ActiveDescendantKeyManager} from '@angular/cdk/a11y';\nimport {BooleanInput, coerceBooleanProperty, coerceStringArray} from '@angular/cdk/coercion';\nimport {Platform} from '@angular/cdk/platform';\nimport {panelAnimation} from './animations';\nimport {Subscription} from 'rxjs';\n\n/**\n * Autocomplete IDs need to be unique across components, so this counter exists outside of\n * the component definition.\n */\nlet _uniqueAutocompleteIdCounter = 0;\n\n/** Event object that is emitted when an autocomplete option is selected. */\nexport class MatAutocompleteSelectedEvent {\n  constructor(\n    /** Reference to the autocomplete panel that emitted the event. */\n    public source: _MatAutocompleteBase,\n    /** Option that was selected. */\n    public option: _MatOptionBase,\n  ) {}\n}\n\n/** Event object that is emitted when an autocomplete option is activated. */\nexport interface MatAutocompleteActivatedEvent {\n  /** Reference to the autocomplete panel that emitted the event. */\n  source: _MatAutocompleteBase;\n\n  /** Option that was selected. */\n  option: _MatOptionBase | null;\n}\n\n// Boilerplate for applying mixins to MatAutocomplete.\n/** @docs-private */\nconst _MatAutocompleteMixinBase = mixinDisableRipple(class {});\n\n/** Default `mat-autocomplete` options that can be overridden. */\nexport interface MatAutocompleteDefaultOptions {\n  /** Whether the first option should be highlighted when an autocomplete panel is opened. */\n  autoActiveFirstOption?: boolean;\n\n  /** Whether the active option should be selected as the user is navigating. */\n  autoSelectActiveOption?: boolean;\n\n  /** Class or list of classes to be applied to the autocomplete's overlay panel. */\n  overlayPanelClass?: string | string[];\n}\n\n/** Injection token to be used to override the default options for `mat-autocomplete`. */\nexport const MAT_AUTOCOMPLETE_DEFAULT_OPTIONS = new InjectionToken<MatAutocompleteDefaultOptions>(\n  'mat-autocomplete-default-options',\n  {\n    providedIn: 'root',\n    factory: MAT_AUTOCOMPLETE_DEFAULT_OPTIONS_FACTORY,\n  },\n);\n\n/** @docs-private */\nexport function MAT_AUTOCOMPLETE_DEFAULT_OPTIONS_FACTORY(): MatAutocompleteDefaultOptions {\n  return {autoActiveFirstOption: false, autoSelectActiveOption: false};\n}\n\n/** Base class with all of the `MatAutocomplete` functionality. */\n@Directive()\nexport abstract class _MatAutocompleteBase\n  extends _MatAutocompleteMixinBase\n  implements AfterContentInit, CanDisableRipple, OnDestroy\n{\n  private _activeOptionChanges = Subscription.EMPTY;\n\n  /** Class to apply to the panel when it's visible. */\n  protected abstract _visibleClass: string;\n\n  /** Class to apply to the panel when it's hidden. */\n  protected abstract _hiddenClass: string;\n\n  /** Manages active item in option list based on key events. */\n  _keyManager: ActiveDescendantKeyManager<_MatOptionBase>;\n\n  /** Whether the autocomplete panel should be visible, depending on option length. */\n  showPanel: boolean = false;\n\n  /** Whether the autocomplete panel is open. */\n  get isOpen(): boolean {\n    return this._isOpen && this.showPanel;\n  }\n  _isOpen: boolean = false;\n\n  /** @docs-private Sets the theme color of the panel. */\n  _setColor(value: ThemePalette) {\n    this._color = value;\n    this._setThemeClasses(this._classList);\n  }\n  /** @docs-private theme color of the panel */\n  private _color: ThemePalette;\n\n  // The @ViewChild query for TemplateRef here needs to be static because some code paths\n  // lead to the overlay being created before change detection has finished for this component.\n  // Notably, another component may trigger `focus` on the autocomplete-trigger.\n\n  /** @docs-private */\n  @ViewChild(TemplateRef, {static: true}) template: TemplateRef<any>;\n\n  /** Element for the panel containing the autocomplete options. */\n  @ViewChild('panel') panel: ElementRef;\n\n  /** Reference to all options within the autocomplete. */\n  abstract options: QueryList<_MatOptionBase>;\n\n  /** Reference to all option groups within the autocomplete. */\n  abstract optionGroups: QueryList<_MatOptgroupBase>;\n\n  /** Aria label of the autocomplete. */\n  @Input('aria-label') ariaLabel: string;\n\n  /** Input that can be used to specify the `aria-labelledby` attribute. */\n  @Input('aria-labelledby') ariaLabelledby: string;\n\n  /** Function that maps an option's control value to its display value in the trigger. */\n  @Input() displayWith: ((value: any) => string) | null = null;\n\n  /**\n   * Whether the first option should be highlighted when the autocomplete panel is opened.\n   * Can be configured globally through the `MAT_AUTOCOMPLETE_DEFAULT_OPTIONS` token.\n   */\n  @Input()\n  get autoActiveFirstOption(): boolean {\n    return this._autoActiveFirstOption;\n  }\n  set autoActiveFirstOption(value: BooleanInput) {\n    this._autoActiveFirstOption = coerceBooleanProperty(value);\n  }\n  private _autoActiveFirstOption: boolean;\n\n  /** Whether the active option should be selected as the user is navigating. */\n  @Input()\n  get autoSelectActiveOption(): boolean {\n    return this._autoSelectActiveOption;\n  }\n  set autoSelectActiveOption(value: BooleanInput) {\n    this._autoSelectActiveOption = coerceBooleanProperty(value);\n  }\n  private _autoSelectActiveOption: boolean;\n\n  /**\n   * Specify the width of the autocomplete panel.  Can be any CSS sizing value, otherwise it will\n   * match the width of its host.\n   */\n  @Input() panelWidth: string | number;\n\n  /** Event that is emitted whenever an option from the list is selected. */\n  @Output() readonly optionSelected: EventEmitter<MatAutocompleteSelectedEvent> =\n    new EventEmitter<MatAutocompleteSelectedEvent>();\n\n  /** Event that is emitted when the autocomplete panel is opened. */\n  @Output() readonly opened: EventEmitter<void> = new EventEmitter<void>();\n\n  /** Event that is emitted when the autocomplete panel is closed. */\n  @Output() readonly closed: EventEmitter<void> = new EventEmitter<void>();\n\n  /** Emits whenever an option is activated. */\n  @Output() readonly optionActivated: EventEmitter<MatAutocompleteActivatedEvent> =\n    new EventEmitter<MatAutocompleteActivatedEvent>();\n\n  /**\n   * Takes classes set on the host mat-autocomplete element and applies them to the panel\n   * inside the overlay container to allow for easy styling.\n   */\n  @Input('class')\n  set classList(value: string | string[]) {\n    if (value && value.length) {\n      this._classList = coerceStringArray(value).reduce((classList, className) => {\n        classList[className] = true;\n        return classList;\n      }, {} as {[key: string]: boolean});\n    } else {\n      this._classList = {};\n    }\n\n    this._setVisibilityClasses(this._classList);\n    this._setThemeClasses(this._classList);\n    this._elementRef.nativeElement.className = '';\n  }\n  _classList: {[key: string]: boolean} = {};\n\n  /** Unique ID to be used by autocomplete trigger's \"aria-owns\" property. */\n  id: string = `mat-autocomplete-${_uniqueAutocompleteIdCounter++}`;\n\n  /**\n   * Tells any descendant `mat-optgroup` to use the inert a11y pattern.\n   * @docs-private\n   */\n  readonly inertGroups: boolean;\n\n  constructor(\n    private _changeDetectorRef: ChangeDetectorRef,\n    private _elementRef: ElementRef<HTMLElement>,\n    @Inject(MAT_AUTOCOMPLETE_DEFAULT_OPTIONS) defaults: MatAutocompleteDefaultOptions,\n    platform?: Platform,\n  ) {\n    super();\n\n    // TODO(crisbeto): the problem that the `inertGroups` option resolves is only present on\n    // Safari using VoiceOver. We should occasionally check back to see whether the bug\n    // wasn't resolved in VoiceOver, and if it has, we can remove this and the `inertGroups`\n    // option altogether.\n    this.inertGroups = platform?.SAFARI || false;\n    this._autoActiveFirstOption = !!defaults.autoActiveFirstOption;\n    this._autoSelectActiveOption = !!defaults.autoSelectActiveOption;\n  }\n\n  ngAfterContentInit() {\n    this._keyManager = new ActiveDescendantKeyManager<_MatOptionBase>(this.options).withWrap();\n    this._activeOptionChanges = this._keyManager.change.subscribe(index => {\n      if (this.isOpen) {\n        this.optionActivated.emit({source: this, option: this.options.toArray()[index] || null});\n      }\n    });\n\n    // Set the initial visibility state.\n    this._setVisibility();\n  }\n\n  ngOnDestroy() {\n    this._keyManager?.destroy();\n    this._activeOptionChanges.unsubscribe();\n  }\n\n  /**\n   * Sets the panel scrollTop. This allows us to manually scroll to display options\n   * above or below the fold, as they are not actually being focused when active.\n   */\n  _setScrollTop(scrollTop: number): void {\n    if (this.panel) {\n      this.panel.nativeElement.scrollTop = scrollTop;\n    }\n  }\n\n  /** Returns the panel's scrollTop. */\n  _getScrollTop(): number {\n    return this.panel ? this.panel.nativeElement.scrollTop : 0;\n  }\n\n  /** Panel should hide itself when the option list is empty. */\n  _setVisibility() {\n    this.showPanel = !!this.options.length;\n    this._setVisibilityClasses(this._classList);\n    this._changeDetectorRef.markForCheck();\n  }\n\n  /** Emits the `select` event. */\n  _emitSelectEvent(option: _MatOptionBase): void {\n    const event = new MatAutocompleteSelectedEvent(this, option);\n    this.optionSelected.emit(event);\n  }\n\n  /** Gets the aria-labelledby for the autocomplete panel. */\n  _getPanelAriaLabelledby(labelId: string | null): string | null {\n    if (this.ariaLabel) {\n      return null;\n    }\n\n    const labelExpression = labelId ? labelId + ' ' : '';\n    return this.ariaLabelledby ? labelExpression + this.ariaLabelledby : labelId;\n  }\n\n  /** Sets the autocomplete visibility classes on a classlist based on the panel is visible. */\n  private _setVisibilityClasses(classList: {[key: string]: boolean}) {\n    classList[this._visibleClass] = this.showPanel;\n    classList[this._hiddenClass] = !this.showPanel;\n  }\n\n  /** Sets the theming classes on a classlist based on the theme of the panel. */\n  private _setThemeClasses(classList: {[key: string]: boolean}) {\n    classList['mat-primary'] = this._color === 'primary';\n    classList['mat-warn'] = this._color === 'warn';\n    classList['mat-accent'] = this._color === 'accent';\n  }\n}\n\n@Component({\n  selector: 'mat-autocomplete',\n  templateUrl: 'autocomplete.html',\n  styleUrls: ['autocomplete.css'],\n  encapsulation: ViewEncapsulation.None,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  exportAs: 'matAutocomplete',\n  inputs: ['disableRipple'],\n  host: {\n    'class': 'mat-mdc-autocomplete',\n  },\n  providers: [{provide: MAT_OPTION_PARENT_COMPONENT, useExisting: MatAutocomplete}],\n  animations: [panelAnimation],\n})\nexport class MatAutocomplete extends _MatAutocompleteBase {\n  /** Reference to all option groups within the autocomplete. */\n  @ContentChildren(MAT_OPTGROUP, {descendants: true}) optionGroups: QueryList<MatOptgroup>;\n  /** Reference to all options within the autocomplete. */\n  @ContentChildren(MatOption, {descendants: true}) options: QueryList<MatOption>;\n  protected _visibleClass = 'mat-mdc-autocomplete-visible';\n  protected _hiddenClass = 'mat-mdc-autocomplete-hidden';\n}\n","<ng-template let-formFieldId=\"id\">\n  <div\n    class=\"mat-mdc-autocomplete-panel mdc-menu-surface mdc-menu-surface--open\"\n    role=\"listbox\"\n    [id]=\"id\"\n    [ngClass]=\"_classList\"\n    [attr.aria-label]=\"ariaLabel || null\"\n    [attr.aria-labelledby]=\"_getPanelAriaLabelledby(formFieldId)\"\n    [@panelAnimation]=\"isOpen ? 'visible' : 'hidden'\"\n    #panel>\n    <ng-content></ng-content>\n  </div>\n</ng-template>\n"]}
264
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"autocomplete.js","sourceRoot":"","sources":["../../../../../../src/material/autocomplete/autocomplete.ts","../../../../../../src/material/autocomplete/autocomplete.html"],"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 {\n  AfterContentInit,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ContentChildren,\n  Directive,\n  ElementRef,\n  EventEmitter,\n  Inject,\n  InjectionToken,\n  Input,\n  OnDestroy,\n  Output,\n  QueryList,\n  TemplateRef,\n  ViewChild,\n  ViewEncapsulation,\n} from '@angular/core';\nimport {\n  MAT_OPTGROUP,\n  MAT_OPTION_PARENT_COMPONENT,\n  MatOptgroup,\n  MatOption,\n  mixinDisableRipple,\n  CanDisableRipple,\n  _MatOptionBase,\n  _MatOptgroupBase,\n  ThemePalette,\n} from '@angular/material/core';\nimport {ActiveDescendantKeyManager} from '@angular/cdk/a11y';\nimport {BooleanInput, coerceBooleanProperty, coerceStringArray} from '@angular/cdk/coercion';\nimport {Platform} from '@angular/cdk/platform';\nimport {panelAnimation} from './animations';\nimport {Subscription} from 'rxjs';\n\n/**\n * Autocomplete IDs need to be unique across components, so this counter exists outside of\n * the component definition.\n */\nlet _uniqueAutocompleteIdCounter = 0;\n\n/** Event object that is emitted when an autocomplete option is selected. */\nexport class MatAutocompleteSelectedEvent {\n  constructor(\n    /** Reference to the autocomplete panel that emitted the event. */\n    public source: _MatAutocompleteBase,\n    /** Option that was selected. */\n    public option: _MatOptionBase,\n  ) {}\n}\n\n/** Event object that is emitted when an autocomplete option is activated. */\nexport interface MatAutocompleteActivatedEvent {\n  /** Reference to the autocomplete panel that emitted the event. */\n  source: _MatAutocompleteBase;\n\n  /** Option that was selected. */\n  option: _MatOptionBase | null;\n}\n\n// Boilerplate for applying mixins to MatAutocomplete.\n/** @docs-private */\nconst _MatAutocompleteMixinBase = mixinDisableRipple(class {});\n\n/** Default `mat-autocomplete` options that can be overridden. */\nexport interface MatAutocompleteDefaultOptions {\n  /** Whether the first option should be highlighted when an autocomplete panel is opened. */\n  autoActiveFirstOption?: boolean;\n\n  /** Whether the active option should be selected as the user is navigating. */\n  autoSelectActiveOption?: boolean;\n\n  /** Class or list of classes to be applied to the autocomplete's overlay panel. */\n  overlayPanelClass?: string | string[];\n\n  /** Wheter icon indicators should be hidden for single-selection. */\n  hideSingleSelectionIndicator?: boolean;\n}\n\n/** Injection token to be used to override the default options for `mat-autocomplete`. */\nexport const MAT_AUTOCOMPLETE_DEFAULT_OPTIONS = new InjectionToken<MatAutocompleteDefaultOptions>(\n  'mat-autocomplete-default-options',\n  {\n    providedIn: 'root',\n    factory: MAT_AUTOCOMPLETE_DEFAULT_OPTIONS_FACTORY,\n  },\n);\n\n/** @docs-private */\nexport function MAT_AUTOCOMPLETE_DEFAULT_OPTIONS_FACTORY(): MatAutocompleteDefaultOptions {\n  return {\n    autoActiveFirstOption: false,\n    autoSelectActiveOption: false,\n    hideSingleSelectionIndicator: false,\n  };\n}\n\n/** Base class with all of the `MatAutocomplete` functionality. */\n@Directive()\nexport abstract class _MatAutocompleteBase\n  extends _MatAutocompleteMixinBase\n  implements AfterContentInit, CanDisableRipple, OnDestroy\n{\n  private _activeOptionChanges = Subscription.EMPTY;\n\n  /** Class to apply to the panel when it's visible. */\n  protected abstract _visibleClass: string;\n\n  /** Class to apply to the panel when it's hidden. */\n  protected abstract _hiddenClass: string;\n\n  /** Manages active item in option list based on key events. */\n  _keyManager: ActiveDescendantKeyManager<_MatOptionBase>;\n\n  /** Whether the autocomplete panel should be visible, depending on option length. */\n  showPanel: boolean = false;\n\n  /** Whether the autocomplete panel is open. */\n  get isOpen(): boolean {\n    return this._isOpen && this.showPanel;\n  }\n  _isOpen: boolean = false;\n\n  /** @docs-private Sets the theme color of the panel. */\n  _setColor(value: ThemePalette) {\n    this._color = value;\n    this._setThemeClasses(this._classList);\n  }\n  /** @docs-private theme color of the panel */\n  private _color: ThemePalette;\n\n  // The @ViewChild query for TemplateRef here needs to be static because some code paths\n  // lead to the overlay being created before change detection has finished for this component.\n  // Notably, another component may trigger `focus` on the autocomplete-trigger.\n\n  /** @docs-private */\n  @ViewChild(TemplateRef, {static: true}) template: TemplateRef<any>;\n\n  /** Element for the panel containing the autocomplete options. */\n  @ViewChild('panel') panel: ElementRef;\n\n  /** Reference to all options within the autocomplete. */\n  abstract options: QueryList<_MatOptionBase>;\n\n  /** Reference to all option groups within the autocomplete. */\n  abstract optionGroups: QueryList<_MatOptgroupBase>;\n\n  /** Aria label of the autocomplete. */\n  @Input('aria-label') ariaLabel: string;\n\n  /** Input that can be used to specify the `aria-labelledby` attribute. */\n  @Input('aria-labelledby') ariaLabelledby: string;\n\n  /** Function that maps an option's control value to its display value in the trigger. */\n  @Input() displayWith: ((value: any) => string) | null = null;\n\n  /**\n   * Whether the first option should be highlighted when the autocomplete panel is opened.\n   * Can be configured globally through the `MAT_AUTOCOMPLETE_DEFAULT_OPTIONS` token.\n   */\n  @Input()\n  get autoActiveFirstOption(): boolean {\n    return this._autoActiveFirstOption;\n  }\n  set autoActiveFirstOption(value: BooleanInput) {\n    this._autoActiveFirstOption = coerceBooleanProperty(value);\n  }\n  private _autoActiveFirstOption = !!this._defaults.autoActiveFirstOption;\n\n  /** Whether the active option should be selected as the user is navigating. */\n  @Input()\n  get autoSelectActiveOption(): boolean {\n    return this._autoSelectActiveOption;\n  }\n  set autoSelectActiveOption(value: BooleanInput) {\n    this._autoSelectActiveOption = coerceBooleanProperty(value);\n  }\n  private _autoSelectActiveOption = !!this._defaults.autoSelectActiveOption;\n\n  /**\n   * Specify the width of the autocomplete panel.  Can be any CSS sizing value, otherwise it will\n   * match the width of its host.\n   */\n  @Input() panelWidth: string | number;\n\n  /** Event that is emitted whenever an option from the list is selected. */\n  @Output() readonly optionSelected: EventEmitter<MatAutocompleteSelectedEvent> =\n    new EventEmitter<MatAutocompleteSelectedEvent>();\n\n  /** Event that is emitted when the autocomplete panel is opened. */\n  @Output() readonly opened: EventEmitter<void> = new EventEmitter<void>();\n\n  /** Event that is emitted when the autocomplete panel is closed. */\n  @Output() readonly closed: EventEmitter<void> = new EventEmitter<void>();\n\n  /** Emits whenever an option is activated. */\n  @Output() readonly optionActivated: EventEmitter<MatAutocompleteActivatedEvent> =\n    new EventEmitter<MatAutocompleteActivatedEvent>();\n\n  /**\n   * Takes classes set on the host mat-autocomplete element and applies them to the panel\n   * inside the overlay container to allow for easy styling.\n   */\n  @Input('class')\n  set classList(value: string | string[]) {\n    if (value && value.length) {\n      this._classList = coerceStringArray(value).reduce((classList, className) => {\n        classList[className] = true;\n        return classList;\n      }, {} as {[key: string]: boolean});\n    } else {\n      this._classList = {};\n    }\n\n    this._setVisibilityClasses(this._classList);\n    this._setThemeClasses(this._classList);\n    this._elementRef.nativeElement.className = '';\n  }\n  _classList: {[key: string]: boolean} = {};\n\n  /** Unique ID to be used by autocomplete trigger's \"aria-owns\" property. */\n  id: string = `mat-autocomplete-${_uniqueAutocompleteIdCounter++}`;\n\n  /**\n   * Tells any descendant `mat-optgroup` to use the inert a11y pattern.\n   * @docs-private\n   */\n  readonly inertGroups: boolean;\n\n  constructor(\n    private _changeDetectorRef: ChangeDetectorRef,\n    private _elementRef: ElementRef<HTMLElement>,\n    @Inject(MAT_AUTOCOMPLETE_DEFAULT_OPTIONS) protected _defaults: MatAutocompleteDefaultOptions,\n    platform?: Platform,\n  ) {\n    super();\n\n    // TODO(crisbeto): the problem that the `inertGroups` option resolves is only present on\n    // Safari using VoiceOver. We should occasionally check back to see whether the bug\n    // wasn't resolved in VoiceOver, and if it has, we can remove this and the `inertGroups`\n    // option altogether.\n    this.inertGroups = platform?.SAFARI || false;\n  }\n\n  ngAfterContentInit() {\n    this._keyManager = new ActiveDescendantKeyManager<_MatOptionBase>(this.options).withWrap();\n    this._activeOptionChanges = this._keyManager.change.subscribe(index => {\n      if (this.isOpen) {\n        this.optionActivated.emit({source: this, option: this.options.toArray()[index] || null});\n      }\n    });\n\n    // Set the initial visibility state.\n    this._setVisibility();\n  }\n\n  ngOnDestroy() {\n    this._keyManager?.destroy();\n    this._activeOptionChanges.unsubscribe();\n  }\n\n  /**\n   * Sets the panel scrollTop. This allows us to manually scroll to display options\n   * above or below the fold, as they are not actually being focused when active.\n   */\n  _setScrollTop(scrollTop: number): void {\n    if (this.panel) {\n      this.panel.nativeElement.scrollTop = scrollTop;\n    }\n  }\n\n  /** Returns the panel's scrollTop. */\n  _getScrollTop(): number {\n    return this.panel ? this.panel.nativeElement.scrollTop : 0;\n  }\n\n  /** Panel should hide itself when the option list is empty. */\n  _setVisibility() {\n    this.showPanel = !!this.options.length;\n    this._setVisibilityClasses(this._classList);\n    this._changeDetectorRef.markForCheck();\n  }\n\n  /** Emits the `select` event. */\n  _emitSelectEvent(option: _MatOptionBase): void {\n    const event = new MatAutocompleteSelectedEvent(this, option);\n    this.optionSelected.emit(event);\n  }\n\n  /** Gets the aria-labelledby for the autocomplete panel. */\n  _getPanelAriaLabelledby(labelId: string | null): string | null {\n    if (this.ariaLabel) {\n      return null;\n    }\n\n    const labelExpression = labelId ? labelId + ' ' : '';\n    return this.ariaLabelledby ? labelExpression + this.ariaLabelledby : labelId;\n  }\n\n  /** Sets the autocomplete visibility classes on a classlist based on the panel is visible. */\n  private _setVisibilityClasses(classList: {[key: string]: boolean}) {\n    classList[this._visibleClass] = this.showPanel;\n    classList[this._hiddenClass] = !this.showPanel;\n  }\n\n  /** Sets the theming classes on a classlist based on the theme of the panel. */\n  private _setThemeClasses(classList: {[key: string]: boolean}) {\n    classList['mat-primary'] = this._color === 'primary';\n    classList['mat-warn'] = this._color === 'warn';\n    classList['mat-accent'] = this._color === 'accent';\n  }\n}\n\n@Component({\n  selector: 'mat-autocomplete',\n  templateUrl: 'autocomplete.html',\n  styleUrls: ['autocomplete.css'],\n  encapsulation: ViewEncapsulation.None,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  exportAs: 'matAutocomplete',\n  inputs: ['disableRipple'],\n  host: {\n    'class': 'mat-mdc-autocomplete',\n  },\n  providers: [{provide: MAT_OPTION_PARENT_COMPONENT, useExisting: MatAutocomplete}],\n  animations: [panelAnimation],\n})\nexport class MatAutocomplete extends _MatAutocompleteBase {\n  /** Reference to all option groups within the autocomplete. */\n  @ContentChildren(MAT_OPTGROUP, {descendants: true}) optionGroups: QueryList<MatOptgroup>;\n  /** Reference to all options within the autocomplete. */\n  @ContentChildren(MatOption, {descendants: true}) options: QueryList<MatOption>;\n  protected _visibleClass = 'mat-mdc-autocomplete-visible';\n  protected _hiddenClass = 'mat-mdc-autocomplete-hidden';\n\n  /** Whether checkmark indicator for single-selection options is hidden. */\n  @Input()\n  get hideSingleSelectionIndicator(): boolean {\n    return this._hideSingleSelectionIndicator;\n  }\n  set hideSingleSelectionIndicator(value: BooleanInput) {\n    this._hideSingleSelectionIndicator = coerceBooleanProperty(value);\n    this._syncParentProperties();\n  }\n  private _hideSingleSelectionIndicator: boolean =\n    this._defaults.hideSingleSelectionIndicator ?? false;\n\n  /** Syncs the parent state with the individual options. */\n  _syncParentProperties(): void {\n    if (this.options) {\n      for (const option of this.options) {\n        option._changeDetectorRef.markForCheck();\n      }\n    }\n  }\n}\n","<ng-template let-formFieldId=\"id\">\n  <div\n    class=\"mat-mdc-autocomplete-panel mdc-menu-surface mdc-menu-surface--open\"\n    role=\"listbox\"\n    [id]=\"id\"\n    [ngClass]=\"_classList\"\n    [attr.aria-label]=\"ariaLabel || null\"\n    [attr.aria-labelledby]=\"_getPanelAriaLabelledby(formFieldId)\"\n    [@panelAnimation]=\"isOpen ? 'visible' : 'hidden'\"\n    #panel>\n    <ng-content></ng-content>\n  </div>\n</ng-template>\n"]}