@angular/material 17.0.0-next.0 → 17.0.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 (110) hide show
  1. package/_index.scss +2 -2
  2. package/button/_button-base.scss +3 -3
  3. package/button/_button-theme-private.scss +3 -2
  4. package/button/_button-theme.scss +18 -25
  5. package/button/_fab-theme.scss +31 -49
  6. package/button/_icon-button-theme.scss +19 -26
  7. package/button/index.d.ts +22 -31
  8. package/card/_card-theme.scss +27 -38
  9. package/checkbox/_checkbox-theme.scss +28 -45
  10. package/core/_core-theme.scss +24 -39
  11. package/core/mdc-helpers/_mdc-helpers.scss +19 -22
  12. package/core/option/_optgroup-theme.scss +13 -23
  13. package/core/option/_option-theme.scss +23 -37
  14. package/core/ripple/_ripple-theme.scss +6 -10
  15. package/core/selection/pseudo-checkbox/_pseudo-checkbox-theme.scss +17 -24
  16. package/core/style/_private.scss +3 -3
  17. package/core/style/_sass-utils.scss +7 -0
  18. package/core/theming/_inspection.scss +87 -60
  19. package/core/theming/_m2-inspection.scss +211 -0
  20. package/core/theming/_theming.scss +59 -6
  21. package/core/tokens/m2/mat/_card.scss +15 -21
  22. package/core/tokens/m2/mat/_form-field.scss +21 -25
  23. package/core/tokens/m2/mat/_optgroup.scss +12 -17
  24. package/core/tokens/m2/mat/_option.scss +16 -28
  25. package/core/tokens/m2/mat/_paginator.scss +16 -18
  26. package/core/tokens/m2/mat/_radio.scss +7 -10
  27. package/core/tokens/m2/mat/_slide-toggle.scss +9 -17
  28. package/core/tokens/m2/mat/_slider.scss +5 -5
  29. package/core/tokens/m2/mdc/_checkbox.scss +21 -20
  30. package/core/tokens/m2/mdc/_elevated-card.scss +6 -9
  31. package/core/tokens/m2/mdc/_extended-fab.scss +8 -17
  32. package/core/tokens/m2/mdc/_fab.scss +6 -7
  33. package/core/tokens/m2/mdc/_filled-text-field.scss +16 -22
  34. package/core/tokens/m2/mdc/_icon-button.scss +1 -1
  35. package/core/tokens/m2/mdc/_linear-progress.scss +9 -10
  36. package/core/tokens/m2/mdc/_list.scss +44 -42
  37. package/core/tokens/m2/mdc/_outlined-card.scss +7 -10
  38. package/core/tokens/m2/mdc/_outlined-text-field.scss +14 -20
  39. package/core/tokens/m2/mdc/_radio.scss +11 -11
  40. package/core/tokens/m2/mdc/_slider.scss +16 -23
  41. package/core/tokens/m2/mdc/_switch.scss +16 -19
  42. package/core/typography/_definition.scss +258 -0
  43. package/core/typography/_property-getters.scss +63 -0
  44. package/core/typography/_typography-utils.scss +9 -69
  45. package/core/typography/_typography.scss +10 -343
  46. package/core/typography/_versioning.scss +86 -0
  47. package/datepicker/index.d.ts +3 -3
  48. package/dialog/_dialog-theme.scss +10 -0
  49. package/esm2022/autocomplete/autocomplete.mjs +1 -1
  50. package/esm2022/button/button-base.mjs +32 -27
  51. package/esm2022/button/button.mjs +6 -6
  52. package/esm2022/button/fab.mjs +23 -31
  53. package/esm2022/button/icon-button.mjs +6 -6
  54. package/esm2022/button/testing/button-harness.mjs +3 -3
  55. package/esm2022/core/version.mjs +1 -1
  56. package/esm2022/datepicker/calendar.mjs +1 -1
  57. package/esm2022/datepicker/datepicker-base.mjs +2 -2
  58. package/esm2022/datepicker/datepicker-toggle.mjs +1 -1
  59. package/esm2022/datepicker/month-view.mjs +2 -2
  60. package/esm2022/datepicker/multi-year-view.mjs +2 -2
  61. package/esm2022/datepicker/year-view.mjs +2 -2
  62. package/esm2022/dialog/dialog-container.mjs +2 -2
  63. package/esm2022/form-field/form-field.mjs +3 -3
  64. package/esm2022/paginator/paginator.mjs +1 -1
  65. package/esm2022/select/select.mjs +3 -3
  66. package/esm2022/slider/slider-input.mjs +19 -9
  67. package/esm2022/slider/slider.mjs +2 -2
  68. package/esm2022/snack-bar/simple-snack-bar.mjs +1 -1
  69. package/fesm2022/autocomplete.mjs.map +1 -1
  70. package/fesm2022/button/testing.mjs +2 -2
  71. package/fesm2022/button/testing.mjs.map +1 -1
  72. package/fesm2022/button.mjs +59 -61
  73. package/fesm2022/button.mjs.map +1 -1
  74. package/fesm2022/core.mjs +1 -1
  75. package/fesm2022/core.mjs.map +1 -1
  76. package/fesm2022/datepicker.mjs +6 -6
  77. package/fesm2022/datepicker.mjs.map +1 -1
  78. package/fesm2022/dialog.mjs +2 -2
  79. package/fesm2022/dialog.mjs.map +1 -1
  80. package/fesm2022/form-field.mjs +2 -2
  81. package/fesm2022/form-field.mjs.map +1 -1
  82. package/fesm2022/paginator.mjs +1 -1
  83. package/fesm2022/paginator.mjs.map +1 -1
  84. package/fesm2022/select.mjs +2 -2
  85. package/fesm2022/select.mjs.map +1 -1
  86. package/fesm2022/slider.mjs +20 -10
  87. package/fesm2022/slider.mjs.map +1 -1
  88. package/fesm2022/snack-bar.mjs +1 -1
  89. package/fesm2022/snack-bar.mjs.map +1 -1
  90. package/form-field/_form-field-density.scss +3 -4
  91. package/form-field/_form-field-focus-overlay.scss +1 -1
  92. package/form-field/_form-field-theme.scss +24 -34
  93. package/input/_input-theme.scss +11 -23
  94. package/list/_list-theme.scss +26 -41
  95. package/package.json +2 -2
  96. package/paginator/_paginator-theme.scss +15 -24
  97. package/prebuilt-themes/deeppurple-amber.css +1 -1
  98. package/prebuilt-themes/indigo-pink.css +1 -1
  99. package/prebuilt-themes/pink-bluegrey.css +1 -1
  100. package/prebuilt-themes/purple-green.css +1 -1
  101. package/progress-bar/_progress-bar-theme.scss +17 -24
  102. package/progress-spinner/_progress-spinner-theme.scss +3 -3
  103. package/radio/_radio-theme.scss +23 -38
  104. package/schematics/ng-add/index.js +1 -1
  105. package/schematics/ng-add/index.mjs +1 -1
  106. package/slide-toggle/_slide-toggle-theme.scss +23 -40
  107. package/slider/_slider-theme.scss +25 -42
  108. package/snack-bar/_snack-bar-theme.scss +2 -2
  109. package/button-toggle/_button-toggle-variables.scss +0 -16
  110. package/paginator/_paginator-variables.scss +0 -15
@@ -1,354 +1,20 @@
1
- @use 'sass:map';
2
- @use 'sass:math';
3
- @use 'sass:meta';
4
1
  @use 'typography-utils';
5
2
  @use '../theming/theming';
6
- @use '@material/typography' as mdc-typography;
7
-
8
- /// Defines a typography level from the Material Design spec.
9
- /// @param {String} $font-size The font-size for this level.
10
- /// @param {String | Number} $line-height The line-height for this level.
11
- /// @param {String | Number} $font-weight The font-weight for this level.
12
- /// @param {String} $font-family The font-family for this level.
13
- /// @param {String} $letter-spacing The letter-spacing for this level.
14
- /// @returns {Map} A map representing the definition of this typographic level.
15
- @function define-typography-level(
16
- $font-size,
17
- $line-height: $font-size,
18
- $font-weight: 400,
19
- $font-family: null,
20
- $letter-spacing: normal) {
21
-
22
- @return (
23
- font-size: $font-size,
24
- line-height: $line-height,
25
- font-weight: $font-weight,
26
- font-family: $font-family,
27
- letter-spacing: $letter-spacing
28
- );
29
- }
30
-
31
- /// Defines a collection of typography levels to configure typography for an application.
32
- /// Any level not specified defaults to the values defined in the Material Design specification:
33
- /// https://material.io/guidelines/style/typography.html.
34
- ///
35
- /// Note that the Material Design specification does not describe explicit letter-spacing values.
36
- /// The values here come from reverse engineering the Material Design examples.
37
- /// @param {String} $font-family Default font-family for levels that don't specify font-family.
38
- /// @param {Map} $display-4 Configuration for the "display-4" typographic level.
39
- /// @param {Map} $display-3 Configuration for the "display-3" typographic level.
40
- /// @param {Map} $display-2 Configuration for the "display-2" typographic level.
41
- /// @param {Map} $display-1 Configuration for the "display-1" typographic level.
42
- /// @param {Map} $headline Configuration for the "headline" typographic level.
43
- /// @param {Map} $title Configuration for the "title" typographic level.
44
- /// @param {Map} $subheading-2 Configuration for the "subheading-2" typographic level.
45
- /// @param {Map} $subheading-1 Configuration for the "subheading-1" typographic level.
46
- /// @param {Map} $body-2 Configuration for the "body-2" typographic level.
47
- /// @param {Map} $body-1 Configuration for the "body-1" typographic level.
48
- /// @param {Map} $caption Configuration for the "caption" typographic level.
49
- /// @param {Map} $button Configuration for the "button" typographic level.
50
- /// @param {Map} $input Configuration for the "input" typographic level.
51
- /// @returns {Map} A typography config for the application.
52
- ///
53
- /// @deprecated Use `mat.define-typography-config` instead. See https://material.angular.io/guide/mdc-migration for information about migrating.
54
- /// @breaking-change 17.0.0
55
- @function define-legacy-typography-config(
56
- $font-family: 'Roboto, "Helvetica Neue", sans-serif',
57
- $display-4: define-typography-level(112px, 112px, 300, $letter-spacing: -0.05em),
58
- $display-3: define-typography-level(56px, 56px, 400, $letter-spacing: -0.02em),
59
- $display-2: define-typography-level(45px, 48px, 400, $letter-spacing: -0.005em),
60
- $display-1: define-typography-level(34px, 40px, 400),
61
- $headline: define-typography-level(24px, 32px, 400),
62
- $title: define-typography-level(20px, 32px, 500),
63
- $subheading-2: define-typography-level(16px, 28px, 400),
64
- $subheading-1: define-typography-level(15px, 24px, 400),
65
- $body-2: define-typography-level(14px, 24px, 500),
66
- $body-1: define-typography-level(14px, 20px, 400),
67
- $caption: define-typography-level(12px, 20px, 400),
68
- $button: define-typography-level(14px, 14px, 500),
69
- // Line-height must be unit-less fraction of the font-size.
70
- $input: define-typography-level(inherit, 1.125, 400)
71
- ) {
72
-
73
- // Declare an initial map with all of the levels.
74
- $config: (
75
- display-4: $display-4,
76
- display-3: $display-3,
77
- display-2: $display-2,
78
- display-1: $display-1,
79
- headline: $headline,
80
- title: $title,
81
- subheading-2: $subheading-2,
82
- subheading-1: $subheading-1,
83
- body-2: $body-2,
84
- body-1: $body-1,
85
- caption: $caption,
86
- button: $button,
87
- input: $input,
88
- );
89
-
90
- // Loop through the levels and set the `font-family` of the ones that don't have one to the base.
91
- // Note that Sass can't modify maps in place, which means that we need to merge and re-assign.
92
- @each $key, $level in $config {
93
- @if map.get($level, font-family) == null {
94
- $new-level: map.merge($level, (font-family: $font-family));
95
- $config: map.merge($config, ($key: $new-level));
96
- }
97
- }
98
-
99
- // Add the base font family to the config.
100
- @return map.merge($config, (font-family: $font-family));
101
- }
102
-
103
- // Converts a map containing rem values to a map containing px values.
104
- @function _rem-to-px($x, $px-per-rem: 16px) {
105
- @if meta.type-of($x) == 'map' {
106
- @each $key, $val in $x {
107
- $x: map.merge($x, ($key: _rem-to-px($val)));
108
- }
109
- @return $x;
110
- }
111
- @if meta.type-of($x) == 'number' and math.unit($x) == 'rem' {
112
- @return math.div($x, 1rem) * $px-per-rem;
113
- }
114
- @else {
115
- @return $x;
116
- }
117
- }
118
-
119
- // Applies the default font family to all levels in a typography config.
120
- @function _apply-font-family($font-family, $initial-config) {
121
- $config: $initial-config;
122
-
123
- @each $key, $level in $config {
124
- @if map.get($level, 'font-family') == null {
125
- // Sass maps are immutable so we have to re-assign the variable each time.
126
- $config: map.set($config, $key, map.set($level, 'font-family', $font-family));
127
- }
128
- }
3
+ @use './versioning';
129
4
 
130
- @return map.set($config, 'font-family', $font-family);
131
- }
132
-
133
- // Converts an MDC typography level config to an Angular Material one.
134
- @function typography-config-level-from-mdc($mdc-level, $font-family: null) {
135
- $mdc-level-config: map.get(mdc-typography.$styles, $mdc-level);
136
-
137
- // Explicitly default the font family to null since we'll apply it globally
138
- // through the `define-typgraphy-config`/`define-legacy-typography-config`.
139
- @return define-typography-level(
140
- $font-family: $font-family,
141
- $font-size: map.get($mdc-level-config, font-size),
142
- $line-height: map.get($mdc-level-config, line-height),
143
- $font-weight: map.get($mdc-level-config, font-weight),
144
- $letter-spacing: map.get($mdc-level-config, letter-spacing)
145
- );
146
- }
147
-
148
- /// Generates an Angular Material typography config based on values from the official Material
149
- /// Design spec implementation (MDC Web). All arguments are optional, but may be passed to override
150
- /// the default values. The `mat-typography-level` function can be used to generate a custom
151
- /// typography level map which can be passed to this function to override one of the default levels.
152
- /// All default typography sizing generated by this function is in `px` units.
153
- ///
154
- /// @param {String} $font-family The font family to use for levels where it is not explicitly
155
- /// specified.
156
- /// @param {Map} $headline-1 The font settings for the headline-1 font level.
157
- /// @param {Map} $headline-2 The font settings for the headline-2 font level.
158
- /// @param {Map} $headline-3 The font settings for the headline-3 font level.
159
- /// @param {Map} $headline-4 The font settings for the headline-4 font level.
160
- /// @param {Map} $headline-5 The font settings for the headline-5 font level.
161
- /// @param {Map} $headline-6 The font settings for the headline-6 font level.
162
- /// @param {Map} $subtitle-1 The font settings for the subtitle-1 font level.
163
- /// @param {Map} $subtitle-2 The font settings for the subtitle-2 font level.
164
- /// @param {Map} $body-1 The font settings for the body-1 font level.
165
- /// @param {Map} $body-2 The font settings for the body-2 font level.
166
- /// @param {Map} $caption The font settings for the caption font level.
167
- /// @param {Map} $button The font settings for the button font level.
168
- /// @param {Map} $overline The font settings for the overline font level.
169
- /// @return {Map} A map containing font settings for each of the levels in the Material Design spec.
170
- @function define-typography-config(
171
- // TODO(mmalerba): rename this function to define-typography-config,
172
- // and create a predefined px based config for people that need it.
173
- $font-family: mdc-typography.$font-family,
174
- $headline-1: null,
175
- $headline-2: null,
176
- $headline-3: null,
177
- $headline-4: null,
178
- $headline-5: null,
179
- $headline-6: null,
180
- $subtitle-1: null,
181
- $subtitle-2: null,
182
- $body-1: null,
183
- $body-2: null,
184
- $caption: null,
185
- $button: null,
186
- $overline: null,
187
- ) {
188
- @return _apply-font-family($font-family, (
189
- headline-1: $headline-1 or _rem-to-px(typography-config-level-from-mdc(headline1)),
190
- headline-2: $headline-2 or _rem-to-px(typography-config-level-from-mdc(headline2)),
191
- headline-3: $headline-3 or _rem-to-px(typography-config-level-from-mdc(headline3)),
192
- headline-4: $headline-4 or _rem-to-px(typography-config-level-from-mdc(headline4)),
193
- headline-5: $headline-5 or _rem-to-px(typography-config-level-from-mdc(headline5)),
194
- headline-6: $headline-6 or _rem-to-px(typography-config-level-from-mdc(headline6)),
195
- subtitle-1: $subtitle-1 or _rem-to-px(typography-config-level-from-mdc(subtitle1)),
196
- subtitle-2: $subtitle-2 or _rem-to-px(typography-config-level-from-mdc(subtitle2)),
197
- body-1: $body-1 or _rem-to-px(typography-config-level-from-mdc(body1)),
198
- body-2: $body-2 or _rem-to-px(typography-config-level-from-mdc(body2)),
199
- caption: $caption or _rem-to-px(typography-config-level-from-mdc(caption)),
200
- button: $button or _rem-to-px(typography-config-level-from-mdc(button)),
201
- overline: $overline or _rem-to-px(typography-config-level-from-mdc(overline)),
202
- ));
203
- }
204
-
205
- /// Generates an Angular Material typography config based on values from the official Material
206
- /// Design spec implementation (MDC Web). All arguments are optional, but may be passed to override
207
- /// the default values. The `mat-typography-level` function can be used to generate a custom
208
- /// typography level map which can be passed to this function to override one of the default levels.
209
- /// All default typography sizing generated by this function is in `rem` units.
210
- ///
211
- /// @param {String} $font-family The font family to use for levels where it is not explicitly
212
- /// specified.
213
- /// @param {Map} $headline-1 The font settings for the headline-1 font level.
214
- /// @param {Map} $headline-2 The font settings for the headline-2 font level.
215
- /// @param {Map} $headline-3 The font settings for the headline-3 font level.
216
- /// @param {Map} $headline-4 The font settings for the headline-4 font level.
217
- /// @param {Map} $headline-5 The font settings for the headline-5 font level.
218
- /// @param {Map} $headline-6 The font settings for the headline-6 font level.
219
- /// @param {Map} $subtitle-1 The font settings for the subtitle-1 font level.
220
- /// @param {Map} $subtitle-2 The font settings for the subtitle-2 font level.
221
- /// @param {Map} $body-1 The font settings for the body-1 font level.
222
- /// @param {Map} $body-2 The font settings for the body-2 font level.
223
- /// @param {Map} $caption The font settings for the caption font level.
224
- /// @param {Map} $button The font settings for the button font level.
225
- /// @param {Map} $overline The font settings for the overline font level.
226
- /// @return {Map} A map containing font settings for each of the levels in the Material Design spec.
227
- @function define-rem-typography-config(
228
- // TODO(mmalerba): rename this function to define-typography-config,
229
- // and create a predefined px based config for people that need it.
230
- $font-family: mdc-typography.$font-family,
231
- $headline-1: null,
232
- $headline-2: null,
233
- $headline-3: null,
234
- $headline-4: null,
235
- $headline-5: null,
236
- $headline-6: null,
237
- $subtitle-1: null,
238
- $subtitle-2: null,
239
- $body-1: null,
240
- $body-2: null,
241
- $caption: null,
242
- $button: null,
243
- $overline: null,
244
- ) {
245
- @return _apply-font-family($font-family, (
246
- headline-1: $headline-1 or typography-config-level-from-mdc(headline1),
247
- headline-2: $headline-2 or typography-config-level-from-mdc(headline2),
248
- headline-3: $headline-3 or typography-config-level-from-mdc(headline3),
249
- headline-4: $headline-4 or typography-config-level-from-mdc(headline4),
250
- headline-5: $headline-5 or typography-config-level-from-mdc(headline5),
251
- headline-6: $headline-6 or typography-config-level-from-mdc(headline6),
252
- subtitle-1: $subtitle-1 or typography-config-level-from-mdc(subtitle1),
253
- subtitle-2: $subtitle-2 or typography-config-level-from-mdc(subtitle2),
254
- body-1: $body-1 or typography-config-level-from-mdc(body1),
255
- body-2: $body-2 or typography-config-level-from-mdc(body2),
256
- caption: $caption or typography-config-level-from-mdc(caption),
257
- button: $button or typography-config-level-from-mdc(button),
258
- overline: $overline or typography-config-level-from-mdc(overline),
259
- ));
260
- }
261
-
262
- // Whether a config is for the Material Design 2018 typography system.
263
- @function private-typography-is-2018-config($config) {
264
- @return map.get($config, headline-1) != null;
265
- }
266
-
267
- // Whether a config is for the Material Design 2014 typography system.
268
- @function private-typography-is-2014-config($config) {
269
- @return map.get($config, headline) != null;
270
- }
271
-
272
- // Given a config for either the 2014 or 2018 Material Design typography system,
273
- // produces a normalized typography config for the 2014 Material Design typography system.
274
- // 2014 - https://material.io/archive/guidelines/style/typography.html#typography-styles
275
- // 2018 - https://material.io/design/typography/the-type-system.html#type-scale
276
- //
277
- // Components using this function should be migrated to normalize to the 2018 style config instead.
278
- // New components should not use this function.
279
- @function private-typography-to-2014-config($config) {
280
- @if $config == null {
281
- @return null;
282
- }
283
- @if not private-typography-is-2014-config($config) {
284
- $args: (
285
- display-4: map.get($config, headline-1),
286
- display-3: map.get($config, headline-2),
287
- display-2: map.get($config, headline-3),
288
- display-1: map.get($config, headline-4),
289
- headline: map.get($config, headline-5),
290
- title: map.get($config, headline-6),
291
- subheading-2: map.get($config, subtitle-1),
292
- subheading-1: map.get($config, subtitle-2),
293
- body-2: map.get($config, body-1),
294
- body-1: map.get($config, body-2),
295
- button: map.get($config, button),
296
- caption: map.get($config, caption),
297
- font-family: map.get($config, font-family),
298
- );
299
- $non-null-args: ();
300
- @each $key, $value in $args {
301
- @if $value != null {
302
- $non-null-args: map.merge($non-null-args, ($key: $value));
303
- }
304
- }
305
- @return define-legacy-typography-config($non-null-args...);
306
- }
307
- @return $config;
308
- }
309
-
310
- // Given a config for either the 2014 or 2018 Material Design typography system,
311
- // produces a normalized typography config for the 2018 Material Design typography system.
312
- // 2014 - https://material.io/archive/guidelines/style/typography.html#typography-styles
313
- // 2018 - https://material.io/design/typography/the-type-system.html#type-scale
314
- @function private-typography-to-2018-config($config) {
315
- @if $config == null {
316
- @return null;
317
- }
318
- @if not private-typography-is-2018-config($config) {
319
- @return (
320
- headline-1: map.get($config, display-4),
321
- headline-2: map.get($config, display-3),
322
- headline-3: map.get($config, display-2),
323
- headline-4: map.get($config, display-1),
324
- headline-5: map.get($config, headline),
325
- headline-6: map.get($config, title),
326
- subtitle-1: map.get($config, subheading-2),
327
- font-famiy: map.get($config, font-family),
328
-
329
- // These mappings are odd, but body-2 in the 2014 system actually looks closer to subtitle-2
330
- // in the 2018 system, and subeading-1 in the 2014 system looks more like body-1 in the 2018
331
- // system.
332
- subtitle-2: map.get($config, body-2),
333
- body-1: map.get($config, subheading-1),
334
-
335
- body-2: map.get($config, body-1),
336
- button: map.get($config, button),
337
- caption: map.get($config, caption),
338
- overline: if(map.get($config, overline), map.get($config, overline),
339
- define-typography-level(12px, 32px, 500)
340
- )
341
- );
342
- }
343
- @return $config;
344
- }
5
+ // Definition and versioning functions live in their own files to avoid circular dependencies, but
6
+ // we re-export them here so that historical imports from this file continue to work without needing
7
+ // to be updated.
8
+ @forward './definition';
9
+ @forward './versioning';
345
10
 
346
11
  /// Emits baseline typographic styles based on a given config.
347
12
  /// @param {Map} $config-or-theme A typography config for an entire theme.
348
13
  /// @param {String} $selector Ancestor selector under which native elements, such as h1, will
349
14
  /// be styled.
350
15
  @mixin typography-hierarchy($config-or-theme, $selector: '.mat-typography') {
351
- $config: private-typography-to-2018-config(theming.get-typography-config($config-or-theme));
16
+ $config: versioning.private-typography-to-2018-config(
17
+ theming.get-typography-config($config-or-theme));
352
18
 
353
19
  // Note that it seems redundant to prefix the class rules with the `$selector`, however it's
354
20
  // necessary if we want to allow people to overwrite the tag selectors. This is due to
@@ -478,7 +144,8 @@
478
144
  /// @deprecated Use `mat.typography-hierarchy` instead. See https://material.angular.io/guide/mdc-migration for information about migrating.
479
145
  /// @breaking-change 17.0.0
480
146
  @mixin legacy-typography-hierarchy($config-or-theme, $selector: '.mat-typography') {
481
- $config: private-typography-to-2014-config(theming.get-typography-config($config-or-theme));
147
+ $config: versioning.private-typography-to-2014-config(
148
+ theming.get-typography-config($config-or-theme));
482
149
 
483
150
  // Note that it seems redundant to prefix the class rules with the `$selector`, however it's
484
151
  // necessary if we want to allow people to overwrite the tag selectors. This is due to
@@ -0,0 +1,86 @@
1
+ @use 'sass:map';
2
+ @use './definition';
3
+
4
+ // Whether a config is for the Material Design 2018 typography system.
5
+ @function private-typography-is-2018-config($config) {
6
+ @return map.get($config, headline-1) != null;
7
+ }
8
+
9
+ // Whether a config is for the Material Design 2014 typography system.
10
+ @function private-typography-is-2014-config($config) {
11
+ @return map.get($config, headline) != null;
12
+ }
13
+
14
+ // Given a config for either the 2014 or 2018 Material Design typography system,
15
+ // produces a normalized typography config for the 2014 Material Design typography system.
16
+ // 2014 - https://material.io/archive/guidelines/style/typography.html#typography-styles
17
+ // 2018 - https://material.io/design/typography/the-type-system.html#type-scale
18
+ //
19
+ // Components using this function should be migrated to normalize to the 2018 style config instead.
20
+ // New components should not use this function.
21
+ @function private-typography-to-2014-config($config) {
22
+ @if $config == null {
23
+ @return null;
24
+ }
25
+ @if not private-typography-is-2014-config($config) {
26
+ $args: (
27
+ display-4: map.get($config, headline-1),
28
+ display-3: map.get($config, headline-2),
29
+ display-2: map.get($config, headline-3),
30
+ display-1: map.get($config, headline-4),
31
+ headline: map.get($config, headline-5),
32
+ title: map.get($config, headline-6),
33
+ subheading-2: map.get($config, subtitle-1),
34
+ subheading-1: map.get($config, subtitle-2),
35
+ body-2: map.get($config, body-1),
36
+ body-1: map.get($config, body-2),
37
+ button: map.get($config, button),
38
+ caption: map.get($config, caption),
39
+ font-family: map.get($config, font-family),
40
+ );
41
+ $non-null-args: ();
42
+ @each $key, $value in $args {
43
+ @if $value != null {
44
+ $non-null-args: map.merge($non-null-args, ($key: $value));
45
+ }
46
+ }
47
+ @return definition.define-legacy-typography-config($non-null-args...);
48
+ }
49
+ @return $config;
50
+ }
51
+
52
+ // Given a config for either the 2014 or 2018 Material Design typography system,
53
+ // produces a normalized typography config for the 2018 Material Design typography system.
54
+ // 2014 - https://material.io/archive/guidelines/style/typography.html#typography-styles
55
+ // 2018 - https://material.io/design/typography/the-type-system.html#type-scale
56
+ @function private-typography-to-2018-config($config) {
57
+ @if $config == null {
58
+ @return null;
59
+ }
60
+ @if not private-typography-is-2018-config($config) {
61
+ @return (
62
+ headline-1: map.get($config, display-4),
63
+ headline-2: map.get($config, display-3),
64
+ headline-3: map.get($config, display-2),
65
+ headline-4: map.get($config, display-1),
66
+ headline-5: map.get($config, headline),
67
+ headline-6: map.get($config, title),
68
+ subtitle-1: map.get($config, subheading-2),
69
+ font-famiy: map.get($config, font-family),
70
+
71
+ // These mappings are odd, but body-2 in the 2014 system actually looks closer to subtitle-2
72
+ // in the 2018 system, and subeading-1 in the 2014 system looks more like body-1 in the 2018
73
+ // system.
74
+ subtitle-2: map.get($config, body-2),
75
+ body-1: map.get($config, subheading-1),
76
+
77
+ body-2: map.get($config, body-1),
78
+ button: map.get($config, button),
79
+ caption: map.get($config, caption),
80
+ overline: if(map.get($config, overline), map.get($config, overline),
81
+ definition.define-typography-level(12px, 32px, 500)
82
+ )
83
+ );
84
+ }
85
+ @return $config;
86
+ }
@@ -1594,7 +1594,7 @@ export declare class MatMonthView<D> implements AfterContentInit, OnChanges, OnD
1594
1594
  /** Handles when a new date is selected. */
1595
1595
  _dateSelected(event: MatCalendarUserEvent<number>): void;
1596
1596
  /**
1597
- * Takes the index of a calendar body cell wrapped in in an event as argument. For the date that
1597
+ * Takes the index of a calendar body cell wrapped in an event as argument. For the date that
1598
1598
  * corresponds to the given cell, set `activeDate` to that date and fire `activeDateChange` with
1599
1599
  * that date.
1600
1600
  *
@@ -1706,7 +1706,7 @@ export declare class MatMultiYearView<D> implements AfterContentInit, OnDestroy
1706
1706
  /** Handles when a new year is selected. */
1707
1707
  _yearSelected(event: MatCalendarUserEvent<number>): void;
1708
1708
  /**
1709
- * Takes the index of a calendar body cell wrapped in in an event as argument. For the date that
1709
+ * Takes the index of a calendar body cell wrapped in an event as argument. For the date that
1710
1710
  * corresponds to the given cell, set `activeDate` to that date and fire `activeDateChange` with
1711
1711
  * that date.
1712
1712
  *
@@ -1863,7 +1863,7 @@ export declare class MatYearView<D> implements AfterContentInit, OnDestroy {
1863
1863
  /** Handles when a new month is selected. */
1864
1864
  _monthSelected(event: MatCalendarUserEvent<number>): void;
1865
1865
  /**
1866
- * Takes the index of a calendar body cell wrapped in in an event as argument. For the date that
1866
+ * Takes the index of a calendar body cell wrapped in an event as argument. For the date that
1867
1867
  * corresponds to the given cell, set `activeDate` to that date and fire `activeDateChange` with
1868
1868
  * that date.
1869
1869
  *
@@ -1,8 +1,17 @@
1
1
  @use '@material/dialog/dialog-theme' as mdc-dialog-theme;
2
+ @use '../core/style/sass-utils';
2
3
  @use '../core/tokens/m2/mdc/dialog' as tokens-mdc-dialog;
3
4
  @use '../core/theming/theming';
4
5
  @use '../core/typography/typography';
5
6
 
7
+
8
+ @mixin base($config-or-theme) {
9
+ // Add default values for tokens not related to color, typography, or density.
10
+ @include sass-utils.current-selector-or-root() {
11
+ @include mdc-dialog-theme.theme(tokens-mdc-dialog.get-unthemable-tokens());
12
+ }
13
+ }
14
+
6
15
  @mixin color($config-or-theme) {
7
16
  $config: theming.get-color-config($config-or-theme);
8
17
 
@@ -31,6 +40,7 @@
31
40
  $density: theming.get-density-config($theme);
32
41
  $typography: theming.get-typography-config($theme);
33
42
 
43
+ @include base($theme);
34
44
  @if $color != null {
35
45
  @include color($color);
36
46
  }
@@ -292,4 +292,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.1", ngImpor
292
292
  }], hideSingleSelectionIndicator: [{
293
293
  type: Input
294
294
  }] } });
295
- //# 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  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 {AnimationEvent} from '@angular/animations';\nimport {\n  MAT_OPTGROUP,\n  MAT_OPTION_PARENT_COMPONENT,\n  MatOptgroup,\n  MatOption,\n  mixinDisableRipple,\n  CanDisableRipple,\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: MatAutocomplete,\n    /** Option that was selected. */\n    public option: MatOption,\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: MatAutocomplete;\n\n  /** Option that was selected. */\n  option: MatOption | 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  /**\n   * Whether the user is required to make a selection when\n   * they're interacting with the autocomplete.\n   */\n  requireSelection?: 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    requireSelection: false,\n  };\n}\n\n/** Autocomplete component. */\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    'ngSkipHydration': '',\n  },\n  providers: [{provide: MAT_OPTION_PARENT_COMPONENT, useExisting: MatAutocomplete}],\n  animations: [panelAnimation],\n})\nexport class MatAutocomplete\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  private _visibleClass = 'mat-mdc-autocomplete-visible';\n\n  /** Class to apply to the panel when it's hidden. */\n  private _hiddenClass = 'mat-mdc-autocomplete-hidden';\n\n  /** Emits when the panel animation is done. Null if the panel doesn't animate. */\n  _animationDone = new EventEmitter<AnimationEvent>();\n\n  /** Manages active item in option list based on key events. */\n  _keyManager: ActiveDescendantKeyManager<MatOption>;\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  @ContentChildren(MatOption, {descendants: true}) options: QueryList<MatOption>;\n\n  /** Reference to all option groups within the autocomplete. */\n  @ContentChildren(MAT_OPTGROUP, {descendants: true}) optionGroups: QueryList<MatOptgroup>;\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   * Whether the user is required to make a selection when they're interacting with the\n   * autocomplete. If the user moves away from the autocomplete without selecting an option from\n   * the list, the value will be reset. If the user opens the panel and closes it without\n   * interacting or selecting a value, the initial value will be kept.\n   */\n  @Input()\n  get requireSelection(): boolean {\n    return this._requireSelection;\n  }\n  set requireSelection(value: BooleanInput) {\n    this._requireSelection = coerceBooleanProperty(value);\n  }\n  private _requireSelection: 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  /** 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  /** 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    this._autoActiveFirstOption = !!_defaults.autoActiveFirstOption;\n    this._autoSelectActiveOption = !!_defaults.autoSelectActiveOption;\n    this._requireSelection = !!_defaults.requireSelection;\n  }\n\n  ngAfterContentInit() {\n    this._keyManager = new ActiveDescendantKeyManager<MatOption>(this.options)\n      .withWrap()\n      .skipPredicate(this._skipPredicate);\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    this._animationDone.complete();\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: MatOption): 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  // `skipPredicate` determines if key manager should avoid putting a given option in the tab\n  // order. Allow disabled list items to receive focus via keyboard to align with WAI ARIA\n  // recommendation.\n  //\n  // Normally WAI ARIA's instructions are to exclude disabled items from the tab order, but it\n  // makes a few exceptions for compound widgets.\n  //\n  // From [Developing a Keyboard Interface](\n  // https://www.w3.org/WAI/ARIA/apg/practices/keyboard-interface/):\n  //   \"For the following composite widget elements, keep them focusable when disabled: Options in a\n  //   Listbox...\"\n  //\n  // The user can focus disabled options using the keyboard, but the user cannot click disabled\n  // options.\n  protected _skipPredicate() {\n    return false;\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    (@panelAnimation.done)=\"_animationDone.next($event)\"\n    #panel>\n    <ng-content></ng-content>\n  </div>\n</ng-template>\n"]}
295
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"autocomplete.js","sourceRoot":"","sources":["../../../../../../src/material/autocomplete/autocomplete.ts","../../../../../../src/material/autocomplete/autocomplete.html"],"names":[],"mappings":"AAAA;;;;;;GAMG;AAEH,OAAO,EAEL,uBAAuB,EACvB,iBAAiB,EACjB,SAAS,EACT,eAAe,EACf,UAAU,EACV,YAAY,EACZ,MAAM,EACN,cAAc,EACd,KAAK,EAEL,MAAM,EACN,SAAS,EACT,WAAW,EACX,SAAS,EACT,iBAAiB,GAClB,MAAM,eAAe,CAAC;AAEvB,OAAO,EACL,YAAY,EACZ,2BAA2B,EAE3B,SAAS,EACT,kBAAkB,GAGnB,MAAM,wBAAwB,CAAC;AAChC,OAAO,EAAC,0BAA0B,EAAC,MAAM,mBAAmB,CAAC;AAC7D,OAAO,EAAe,qBAAqB,EAAE,iBAAiB,EAAC,MAAM,uBAAuB,CAAC;AAC7F,OAAO,EAAC,QAAQ,EAAC,MAAM,uBAAuB,CAAC;AAC/C,OAAO,EAAC,cAAc,EAAC,MAAM,cAAc,CAAC;AAC5C,OAAO,EAAC,YAAY,EAAC,MAAM,MAAM,CAAC;;;;AAElC;;;GAGG;AACH,IAAI,4BAA4B,GAAG,CAAC,CAAC;AAErC,4EAA4E;AAC5E,MAAM,OAAO,4BAA4B;IACvC;IACE,kEAAkE;IAC3D,MAAuB;IAC9B,gCAAgC;IACzB,MAAiB;QAFjB,WAAM,GAAN,MAAM,CAAiB;QAEvB,WAAM,GAAN,MAAM,CAAW;IACvB,CAAC;CACL;AAWD,sDAAsD;AACtD,oBAAoB;AACpB,MAAM,yBAAyB,GAAG,kBAAkB,CAAC;CAAQ,CAAC,CAAC;AAuB/D,yFAAyF;AACzF,MAAM,CAAC,MAAM,gCAAgC,GAAG,IAAI,cAAc,CAChE,kCAAkC,EAClC;IACE,UAAU,EAAE,MAAM;IAClB,OAAO,EAAE,wCAAwC;CAClD,CACF,CAAC;AAEF,oBAAoB;AACpB,MAAM,UAAU,wCAAwC;IACtD,OAAO;QACL,qBAAqB,EAAE,KAAK;QAC5B,sBAAsB,EAAE,KAAK;QAC7B,4BAA4B,EAAE,KAAK;QACnC,gBAAgB,EAAE,KAAK;KACxB,CAAC;AACJ,CAAC;AAED,8BAA8B;AAgB9B,MAAM,OAAO,eACX,SAAQ,yBAAyB;IAoBjC,8CAA8C;IAC9C,IAAI,MAAM;QACR,OAAO,IAAI,CAAC,OAAO,IAAI,IAAI,CAAC,SAAS,CAAC;IACxC,CAAC;IAGD,uDAAuD;IACvD,SAAS,CAAC,KAAmB;QAC3B,IAAI,CAAC,MAAM,GAAG,KAAK,CAAC;QACpB,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;IACzC,CAAC;IA6BD;;;OAGG;IACH,IACI,qBAAqB;QACvB,OAAO,IAAI,CAAC,sBAAsB,CAAC;IACrC,CAAC;IACD,IAAI,qBAAqB,CAAC,KAAmB;QAC3C,IAAI,CAAC,sBAAsB,GAAG,qBAAqB,CAAC,KAAK,CAAC,CAAC;IAC7D,CAAC;IAGD,8EAA8E;IAC9E,IACI,sBAAsB;QACxB,OAAO,IAAI,CAAC,uBAAuB,CAAC;IACtC,CAAC;IACD,IAAI,sBAAsB,CAAC,KAAmB;QAC5C,IAAI,CAAC,uBAAuB,GAAG,qBAAqB,CAAC,KAAK,CAAC,CAAC;IAC9D,CAAC;IAGD;;;;;OAKG;IACH,IACI,gBAAgB;QAClB,OAAO,IAAI,CAAC,iBAAiB,CAAC;IAChC,CAAC;IACD,IAAI,gBAAgB,CAAC,KAAmB;QACtC,IAAI,CAAC,iBAAiB,GAAG,qBAAqB,CAAC,KAAK,CAAC,CAAC;IACxD,CAAC;IAuBD;;;OAGG;IACH,IACI,SAAS,CAAC,KAAwB;QACpC,IAAI,KAAK,IAAI,KAAK,CAAC,MAAM,EAAE;YACzB,IAAI,CAAC,UAAU,GAAG,iBAAiB,CAAC,KAAK,CAAC,CAAC,MAAM,CAC/C,CAAC,SAAS,EAAE,SAAS,EAAE,EAAE;gBACvB,SAAS,CAAC,SAAS,CAAC,GAAG,IAAI,CAAC;gBAC5B,OAAO,SAAS,CAAC;YACnB,CAAC,EACD,EAA8B,CAC/B,CAAC;SACH;aAAM;YACL,IAAI,CAAC,UAAU,GAAG,EAAE,CAAC;SACtB;QAED,IAAI,CAAC,qBAAqB,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;QAC5C,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;QACvC,IAAI,CAAC,WAAW,CAAC,aAAa,CAAC,SAAS,GAAG,EAAE,CAAC;IAChD,CAAC;IAGD,0EAA0E;IAC1E,IACI,4BAA4B;QAC9B,OAAO,IAAI,CAAC,6BAA6B,CAAC;IAC5C,CAAC;IACD,IAAI,4BAA4B,CAAC,KAAmB;QAClD,IAAI,CAAC,6BAA6B,GAAG,qBAAqB,CAAC,KAAK,CAAC,CAAC;QAClE,IAAI,CAAC,qBAAqB,EAAE,CAAC;IAC/B,CAAC;IAID,0DAA0D;IAC1D,qBAAqB;QACnB,IAAI,IAAI,CAAC,OAAO,EAAE;YAChB,KAAK,MAAM,MAAM,IAAI,IAAI,CAAC,OAAO,EAAE;gBACjC,MAAM,CAAC,kBAAkB,CAAC,YAAY,EAAE,CAAC;aAC1C;SACF;IACH,CAAC;IAWD,YACU,kBAAqC,EACrC,WAAoC,EACQ,SAAwC,EAC5F,QAAmB;QAEnB,KAAK,EAAE,CAAC;QALA,uBAAkB,GAAlB,kBAAkB,CAAmB;QACrC,gBAAW,GAAX,WAAW,CAAyB;QACQ,cAAS,GAAT,SAAS,CAA+B;QA3KtF,yBAAoB,GAAG,YAAY,CAAC,KAAK,CAAC;QAElD,qDAAqD;QAC7C,kBAAa,GAAG,8BAA8B,CAAC;QAEvD,oDAAoD;QAC5C,iBAAY,GAAG,6BAA6B,CAAC;QAErD,iFAAiF;QACjF,mBAAc,GAAG,IAAI,YAAY,EAAkB,CAAC;QAKpD,oFAAoF;QACpF,cAAS,GAAY,KAAK,CAAC;QAM3B,YAAO,GAAY,KAAK,CAAC;QAgCzB,wFAAwF;QAC/E,gBAAW,GAAoC,IAAI,CAAC;QA8C7D,0EAA0E;QACvD,mBAAc,GAC/B,IAAI,YAAY,EAAgC,CAAC;QAEnD,mEAAmE;QAChD,WAAM,GAAuB,IAAI,YAAY,EAAQ,CAAC;QAEzE,mEAAmE;QAChD,WAAM,GAAuB,IAAI,YAAY,EAAQ,CAAC;QAEzE,6CAA6C;QAC1B,oBAAe,GAChC,IAAI,YAAY,EAAiC,CAAC;QAwBpD,eAAU,GAA6B,EAAE,CAAC;QAWlC,kCAA6B,GACnC,IAAI,CAAC,SAAS,CAAC,4BAA4B,IAAI,KAAK,CAAC;QAWvD,2EAA2E;QAC3E,OAAE,GAAW,oBAAoB,4BAA4B,EAAE,EAAE,CAAC;QAgBhE,wFAAwF;QACxF,mFAAmF;QACnF,wFAAwF;QACxF,qBAAqB;QACrB,IAAI,CAAC,WAAW,GAAG,QAAQ,EAAE,MAAM,IAAI,KAAK,CAAC;QAC7C,IAAI,CAAC,sBAAsB,GAAG,CAAC,CAAC,SAAS,CAAC,qBAAqB,CAAC;QAChE,IAAI,CAAC,uBAAuB,GAAG,CAAC,CAAC,SAAS,CAAC,sBAAsB,CAAC;QAClE,IAAI,CAAC,iBAAiB,GAAG,CAAC,CAAC,SAAS,CAAC,gBAAgB,CAAC;IACxD,CAAC;IAED,kBAAkB;QAChB,IAAI,CAAC,WAAW,GAAG,IAAI,0BAA0B,CAAY,IAAI,CAAC,OAAO,CAAC;aACvE,QAAQ,EAAE;aACV,aAAa,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC;QACtC,IAAI,CAAC,oBAAoB,GAAG,IAAI,CAAC,WAAW,CAAC,MAAM,CAAC,SAAS,CAAC,KAAK,CAAC,EAAE;YACpE,IAAI,IAAI,CAAC,MAAM,EAAE;gBACf,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,EAAC,MAAM,EAAE,IAAI,EAAE,MAAM,EAAE,IAAI,CAAC,OAAO,CAAC,OAAO,EAAE,CAAC,KAAK,CAAC,IAAI,IAAI,EAAC,CAAC,CAAC;aAC1F;QACH,CAAC,CAAC,CAAC;QAEH,oCAAoC;QACpC,IAAI,CAAC,cAAc,EAAE,CAAC;IACxB,CAAC;IAED,WAAW;QACT,IAAI,CAAC,WAAW,EAAE,OAAO,EAAE,CAAC;QAC5B,IAAI,CAAC,oBAAoB,CAAC,WAAW,EAAE,CAAC;QACxC,IAAI,CAAC,cAAc,CAAC,QAAQ,EAAE,CAAC;IACjC,CAAC;IAED;;;OAGG;IACH,aAAa,CAAC,SAAiB;QAC7B,IAAI,IAAI,CAAC,KAAK,EAAE;YACd,IAAI,CAAC,KAAK,CAAC,aAAa,CAAC,SAAS,GAAG,SAAS,CAAC;SAChD;IACH,CAAC;IAED,qCAAqC;IACrC,aAAa;QACX,OAAO,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,aAAa,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC;IAC7D,CAAC;IAED,8DAA8D;IAC9D,cAAc;QACZ,IAAI,CAAC,SAAS,GAAG,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC;QACvC,IAAI,CAAC,qBAAqB,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;QAC5C,IAAI,CAAC,kBAAkB,CAAC,YAAY,EAAE,CAAC;IACzC,CAAC;IAED,gCAAgC;IAChC,gBAAgB,CAAC,MAAiB;QAChC,MAAM,KAAK,GAAG,IAAI,4BAA4B,CAAC,IAAI,EAAE,MAAM,CAAC,CAAC;QAC7D,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IAClC,CAAC;IAED,2DAA2D;IAC3D,uBAAuB,CAAC,OAAsB;QAC5C,IAAI,IAAI,CAAC,SAAS,EAAE;YAClB,OAAO,IAAI,CAAC;SACb;QAED,MAAM,eAAe,GAAG,OAAO,CAAC,CAAC,CAAC,OAAO,GAAG,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC;QACrD,OAAO,IAAI,CAAC,cAAc,CAAC,CAAC,CAAC,eAAe,GAAG,IAAI,CAAC,cAAc,CAAC,CAAC,CAAC,OAAO,CAAC;IAC/E,CAAC;IAED,6FAA6F;IACrF,qBAAqB,CAAC,SAAmC;QAC/D,SAAS,CAAC,IAAI,CAAC,aAAa,CAAC,GAAG,IAAI,CAAC,SAAS,CAAC;QAC/C,SAAS,CAAC,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC,IAAI,CAAC,SAAS,CAAC;IACjD,CAAC;IAED,+EAA+E;IACvE,gBAAgB,CAAC,SAAmC;QAC1D,SAAS,CAAC,aAAa,CAAC,GAAG,IAAI,CAAC,MAAM,KAAK,SAAS,CAAC;QACrD,SAAS,CAAC,UAAU,CAAC,GAAG,IAAI,CAAC,MAAM,KAAK,MAAM,CAAC;QAC/C,SAAS,CAAC,YAAY,CAAC,GAAG,IAAI,CAAC,MAAM,KAAK,QAAQ,CAAC;IACrD,CAAC;IAED,2FAA2F;IAC3F,wFAAwF;IACxF,kBAAkB;IAClB,EAAE;IACF,4FAA4F;IAC5F,+CAA+C;IAC/C,EAAE;IACF,0CAA0C;IAC1C,kEAAkE;IAClE,kGAAkG;IAClG,gBAAgB;IAChB,EAAE;IACF,6FAA6F;IAC7F,WAAW;IACD,cAAc;QACtB,OAAO,KAAK,CAAC;IACf,CAAC;8GArRU,eAAe,6EA+KhB,gCAAgC;kGA/K/B,eAAe,qqBAHf,CAAC,EAAC,OAAO,EAAE,2BAA2B,EAAE,WAAW,EAAE,eAAe,EAAC,CAAC,kDAiDhE,SAAS,kEAGT,YAAY,0FATlB,WAAW,qMCvKxB,ofAcA,qiCD+Gc,CAAC,cAAc,CAAC;;2FAEjB,eAAe;kBAf3B,SAAS;+BACE,kBAAkB,iBAGb,iBAAiB,CAAC,IAAI,mBACpB,uBAAuB,CAAC,MAAM,YACrC,iBAAiB,UACnB,CAAC,eAAe,CAAC,QACnB;wBACJ,OAAO,EAAE,sBAAsB;wBAC/B,iBAAiB,EAAE,EAAE;qBACtB,aACU,CAAC,EAAC,OAAO,EAAE,2BAA2B,EAAE,WAAW,iBAAiB,EAAC,CAAC,cACrE,CAAC,cAAc,CAAC;;0BAiLzB,MAAM;2BAAC,gCAAgC;mEAvIF,QAAQ;sBAA/C,SAAS;uBAAC,WAAW,EAAE,EAAC,MAAM,EAAE,IAAI,EAAC;gBAGlB,KAAK;sBAAxB,SAAS;uBAAC,OAAO;gBAG+B,OAAO;sBAAvD,eAAe;uBAAC,SAAS,EAAE,EAAC,WAAW,EAAE,IAAI,EAAC;gBAGK,YAAY;sBAA/D,eAAe;uBAAC,YAAY,EAAE,EAAC,WAAW,EAAE,IAAI,EAAC;gBAG7B,SAAS;sBAA7B,KAAK;uBAAC,YAAY;gBAGO,cAAc;sBAAvC,KAAK;uBAAC,iBAAiB;gBAGf,WAAW;sBAAnB,KAAK;gBAOF,qBAAqB;sBADxB,KAAK;gBAWF,sBAAsB;sBADzB,KAAK;gBAgBF,gBAAgB;sBADnB,KAAK;gBAaG,UAAU;sBAAlB,KAAK;gBAGa,cAAc;sBAAhC,MAAM;gBAIY,MAAM;sBAAxB,MAAM;gBAGY,MAAM;sBAAxB,MAAM;gBAGY,eAAe;sBAAjC,MAAM;gBAQH,SAAS;sBADZ,KAAK;uBAAC,OAAO;gBAsBV,4BAA4B;sBAD/B,KAAK","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  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 {AnimationEvent} from '@angular/animations';\nimport {\n  MAT_OPTGROUP,\n  MAT_OPTION_PARENT_COMPONENT,\n  MatOptgroup,\n  MatOption,\n  mixinDisableRipple,\n  CanDisableRipple,\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: MatAutocomplete,\n    /** Option that was selected. */\n    public option: MatOption,\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: MatAutocomplete;\n\n  /** Option that was selected. */\n  option: MatOption | 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  /**\n   * Whether the user is required to make a selection when\n   * they're interacting with the autocomplete.\n   */\n  requireSelection?: 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    requireSelection: false,\n  };\n}\n\n/** Autocomplete component. */\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    'ngSkipHydration': '',\n  },\n  providers: [{provide: MAT_OPTION_PARENT_COMPONENT, useExisting: MatAutocomplete}],\n  animations: [panelAnimation],\n})\nexport class MatAutocomplete\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  private _visibleClass = 'mat-mdc-autocomplete-visible';\n\n  /** Class to apply to the panel when it's hidden. */\n  private _hiddenClass = 'mat-mdc-autocomplete-hidden';\n\n  /** Emits when the panel animation is done. Null if the panel doesn't animate. */\n  _animationDone = new EventEmitter<AnimationEvent>();\n\n  /** Manages active item in option list based on key events. */\n  _keyManager: ActiveDescendantKeyManager<MatOption>;\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  @ContentChildren(MatOption, {descendants: true}) options: QueryList<MatOption>;\n\n  /** Reference to all option groups within the autocomplete. */\n  @ContentChildren(MAT_OPTGROUP, {descendants: true}) optionGroups: QueryList<MatOptgroup>;\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   * Whether the user is required to make a selection when they're interacting with the\n   * autocomplete. If the user moves away from the autocomplete without selecting an option from\n   * the list, the value will be reset. If the user opens the panel and closes it without\n   * interacting or selecting a value, the initial value will be kept.\n   */\n  @Input()\n  get requireSelection(): boolean {\n    return this._requireSelection;\n  }\n  set requireSelection(value: BooleanInput) {\n    this._requireSelection = coerceBooleanProperty(value);\n  }\n  private _requireSelection: 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(\n        (classList, className) => {\n          classList[className] = true;\n          return classList;\n        },\n        {} as {[key: string]: boolean},\n      );\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  /** 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  /** 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    this._autoActiveFirstOption = !!_defaults.autoActiveFirstOption;\n    this._autoSelectActiveOption = !!_defaults.autoSelectActiveOption;\n    this._requireSelection = !!_defaults.requireSelection;\n  }\n\n  ngAfterContentInit() {\n    this._keyManager = new ActiveDescendantKeyManager<MatOption>(this.options)\n      .withWrap()\n      .skipPredicate(this._skipPredicate);\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    this._animationDone.complete();\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: MatOption): 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  // `skipPredicate` determines if key manager should avoid putting a given option in the tab\n  // order. Allow disabled list items to receive focus via keyboard to align with WAI ARIA\n  // recommendation.\n  //\n  // Normally WAI ARIA's instructions are to exclude disabled items from the tab order, but it\n  // makes a few exceptions for compound widgets.\n  //\n  // From [Developing a Keyboard Interface](\n  // https://www.w3.org/WAI/ARIA/apg/practices/keyboard-interface/):\n  //   \"For the following composite widget elements, keep them focusable when disabled: Options in a\n  //   Listbox...\"\n  //\n  // The user can focus disabled options using the keyboard, but the user cannot click disabled\n  // options.\n  protected _skipPredicate() {\n    return false;\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    (@panelAnimation.done)=\"_animationDone.next($event)\"\n    #panel>\n    <ng-content></ng-content>\n  </div>\n</ng-template>\n"]}