@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.
- package/autocomplete/index.d.ts +11 -2
- package/chips/index.d.ts +14 -1
- package/chips/testing/index.d.ts +23 -0
- package/core/index.d.ts +10 -2
- package/core/selection/pseudo-checkbox/_pseudo-checkbox-common.scss +63 -10
- package/core/selection/pseudo-checkbox/_pseudo-checkbox-theme.scss +42 -27
- package/esm2020/autocomplete/autocomplete.mjs +30 -6
- package/esm2020/chips/chip-listbox.mjs +18 -3
- package/esm2020/chips/chip-option.mjs +21 -7
- package/esm2020/chips/testing/chip-edit-input-harness.mjs +33 -0
- package/esm2020/chips/testing/chip-harness-filters.mjs +1 -1
- package/esm2020/chips/testing/chip-row-harness.mjs +20 -2
- package/esm2020/chips/testing/public-api.mjs +2 -1
- package/esm2020/chips/tokens.mjs +1 -1
- package/esm2020/core/option/option-parent.mjs +1 -1
- package/esm2020/core/option/option.mjs +7 -3
- package/esm2020/core/selection/pseudo-checkbox/pseudo-checkbox.mjs +12 -3
- package/esm2020/core/version.mjs +1 -1
- package/esm2020/legacy-core/option/option.mjs +1 -1
- package/esm2020/legacy-list/selection-list.mjs +1 -1
- package/esm2020/paginator/paginator.mjs +1 -1
- package/esm2020/select/select.mjs +21 -2
- package/fesm2015/autocomplete.mjs +30 -5
- package/fesm2015/autocomplete.mjs.map +1 -1
- package/fesm2015/chips/testing.mjs +51 -2
- package/fesm2015/chips/testing.mjs.map +1 -1
- package/fesm2015/chips.mjs +36 -6
- package/fesm2015/chips.mjs.map +1 -1
- package/fesm2015/core.mjs +18 -5
- package/fesm2015/core.mjs.map +1 -1
- package/fesm2015/legacy-core.mjs +1 -1
- package/fesm2015/legacy-core.mjs.map +1 -1
- package/fesm2015/legacy-list.mjs +1 -1
- package/fesm2015/legacy-list.mjs.map +1 -1
- package/fesm2015/paginator.mjs +1 -1
- package/fesm2015/paginator.mjs.map +1 -1
- package/fesm2015/select.mjs +21 -1
- package/fesm2015/select.mjs.map +1 -1
- package/fesm2020/autocomplete.mjs +29 -5
- package/fesm2020/autocomplete.mjs.map +1 -1
- package/fesm2020/chips/testing.mjs +50 -2
- package/fesm2020/chips/testing.mjs.map +1 -1
- package/fesm2020/chips.mjs +34 -6
- package/fesm2020/chips.mjs.map +1 -1
- package/fesm2020/core.mjs +18 -5
- package/fesm2020/core.mjs.map +1 -1
- package/fesm2020/legacy-core.mjs +1 -1
- package/fesm2020/legacy-core.mjs.map +1 -1
- package/fesm2020/legacy-list.mjs +1 -1
- package/fesm2020/legacy-list.mjs.map +1 -1
- package/fesm2020/paginator.mjs +1 -1
- package/fesm2020/paginator.mjs.map +1 -1
- package/fesm2020/select.mjs +20 -1
- package/fesm2020/select.mjs.map +1 -1
- package/legacy-prebuilt-themes/legacy-deeppurple-amber.css +1 -1
- package/legacy-prebuilt-themes/legacy-indigo-pink.css +1 -1
- package/legacy-prebuilt-themes/legacy-pink-bluegrey.css +1 -1
- package/legacy-prebuilt-themes/legacy-purple-green.css +1 -1
- package/package.json +7 -7
- package/prebuilt-themes/deeppurple-amber.css +1 -1
- package/prebuilt-themes/indigo-pink.css +1 -1
- package/prebuilt-themes/pink-bluegrey.css +1 -1
- package/prebuilt-themes/purple-green.css +1 -1
- package/schematics/ng-add/index.js +2 -2
- package/schematics/ng-add/index.mjs +2 -2
- package/select/index.d.ts +10 -2
package/autocomplete/index.d.ts
CHANGED
|
@@ -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>,
|
|
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. */
|
package/chips/testing/index.d.ts
CHANGED
|
@@ -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
|
-
|
|
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-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
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-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
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
|
-
|
|
8
|
-
$
|
|
9
|
-
$
|
|
10
|
-
$
|
|
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:
|
|
22
|
-
|
|
23
|
-
|
|
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-
|
|
29
|
-
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
|
-
|
|
43
|
-
.mat-
|
|
44
|
-
|
|
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
|
|
50
|
-
|
|
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-
|
|
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 {
|
|
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,
|
|
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"]}
|