@angular/material 16.1.0-next.0 → 16.1.0-next.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/_index.scss +7 -4
- package/_token-theming.scss +2 -0
- package/button/_icon-button-theme.scss +0 -1
- package/button/index.d.ts +3 -2
- package/card/_card-theme.import.scss +1 -1
- package/card/_card-theme.scss +11 -0
- package/checkbox/_checkbox-theme.import.scss +1 -1
- package/checkbox/_checkbox-theme.scss +18 -3
- package/chips/_chips-theme.scss +44 -60
- package/core/mdc-helpers/_mdc-helpers.scss +19 -34
- package/core/style/_sass-utils.scss +37 -0
- package/core/tokens/_token-utils.scss +3 -12
- package/core/tokens/m2/_index.scss +84 -0
- package/core/tokens/m2/mat/_card.scss +17 -16
- package/core/tokens/m2/mat/_radio.scss +6 -5
- package/core/tokens/m2/mat/_snack-bar.scss +6 -5
- package/core/tokens/m2/mat/_tab-header-with-background.scss +6 -5
- package/core/tokens/m2/mat/_tab-header.scss +2 -1
- package/core/tokens/m2/mdc/_checkbox.scss +39 -38
- package/core/tokens/m2/mdc/_chip.scss +313 -0
- package/core/tokens/m2/mdc/_circular-progress.scss +5 -8
- package/core/tokens/m2/mdc/_dialog.scss +6 -7
- package/core/tokens/m2/mdc/_elevated-card.scss +2 -1
- package/core/tokens/m2/mdc/_icon-button.scss +5 -13
- package/core/tokens/m2/mdc/_linear-progress.scss +11 -16
- package/core/tokens/m2/mdc/_list.scss +102 -101
- package/core/tokens/m2/mdc/_outlined-card.scss +2 -1
- package/core/tokens/m2/mdc/_plain-tooltip.scss +6 -9
- package/core/tokens/m2/mdc/_radio.scss +6 -7
- package/core/tokens/m2/mdc/_snack-bar.scss +6 -8
- package/core/tokens/m2/mdc/_tab-indicator.scss +6 -6
- package/core/tokens/m2/mdc/_tab.scss +6 -6
- package/core/typography/_all-typography.scss +1 -154
- package/core/typography/_typography.scss +162 -0
- package/esm2022/autocomplete/autocomplete.mjs +3 -3
- package/esm2022/button/button-base.mjs +7 -11
- package/esm2022/button/button.mjs +3 -3
- package/esm2022/button/fab.mjs +5 -5
- package/esm2022/button/icon-button.mjs +3 -3
- package/esm2022/checkbox/checkbox.mjs +2 -2
- package/esm2022/chips/chip-grid.mjs +2 -2
- package/esm2022/chips/chip-listbox.mjs +5 -5
- package/esm2022/chips/chip-option.mjs +3 -3
- package/esm2022/chips/chip-row.mjs +2 -2
- package/esm2022/chips/chip-set.mjs +2 -2
- package/esm2022/chips/chip.mjs +2 -2
- package/esm2022/core/version.mjs +1 -1
- package/esm2022/datepicker/calendar-body.mjs +29 -16
- package/esm2022/datepicker/datepicker-toggle.mjs +3 -3
- package/esm2022/form-field/directives/floating-label.mjs +66 -5
- package/esm2022/form-field/directives/notched-outline.mjs +14 -16
- package/esm2022/form-field/form-field.mjs +30 -36
- package/esm2022/icon/testing/icon-harness.mjs +7 -2
- package/esm2022/legacy-autocomplete/autocomplete.mjs +3 -3
- package/esm2022/legacy-chips/chip-list.mjs +3 -3
- package/esm2022/legacy-core/option/optgroup.mjs +3 -3
- package/esm2022/legacy-form-field/form-field.mjs +3 -3
- package/esm2022/legacy-menu/menu-item.mjs +3 -3
- package/esm2022/legacy-menu/menu.mjs +3 -3
- package/esm2022/legacy-paginator/paginator.mjs +3 -3
- package/esm2022/legacy-select/public-api.mjs +2 -2
- package/esm2022/legacy-select/select.mjs +3 -3
- package/esm2022/legacy-table/table.mjs +3 -3
- package/esm2022/legacy-tabs/tab-group.mjs +3 -3
- package/esm2022/list/list-base.mjs +2 -1
- package/esm2022/menu/menu-item.mjs +3 -3
- package/esm2022/menu/menu.mjs +3 -3
- package/esm2022/paginator/paginator.mjs +3 -3
- package/esm2022/progress-bar/progress-bar.mjs +2 -2
- package/esm2022/select/select.mjs +28 -17
- package/esm2022/sidenav/drawer.mjs +7 -7
- package/esm2022/sidenav/sidenav.mjs +7 -7
- package/esm2022/slide-toggle/slide-toggle.mjs +3 -3
- package/esm2022/slider/slider-input.mjs +21 -9
- package/esm2022/stepper/stepper.mjs +3 -3
- package/esm2022/table/row.mjs +2 -2
- package/esm2022/table/table.mjs +3 -3
- package/esm2022/tabs/tab-group.mjs +3 -3
- package/esm2022/tooltip/tooltip.mjs +5 -1
- package/fesm2022/autocomplete.mjs +2 -2
- package/fesm2022/autocomplete.mjs.map +1 -1
- package/fesm2022/button.mjs +14 -18
- package/fesm2022/button.mjs.map +1 -1
- package/fesm2022/checkbox.mjs +2 -2
- package/fesm2022/checkbox.mjs.map +1 -1
- package/fesm2022/chips.mjs +14 -14
- package/fesm2022/chips.mjs.map +1 -1
- package/fesm2022/core.mjs +1 -1
- package/fesm2022/core.mjs.map +1 -1
- package/fesm2022/datepicker.mjs +30 -17
- package/fesm2022/datepicker.mjs.map +1 -1
- package/fesm2022/form-field.mjs +102 -50
- package/fesm2022/form-field.mjs.map +1 -1
- package/fesm2022/icon/testing.mjs +6 -1
- package/fesm2022/icon/testing.mjs.map +1 -1
- package/fesm2022/legacy-autocomplete.mjs +2 -2
- package/fesm2022/legacy-autocomplete.mjs.map +1 -1
- package/fesm2022/legacy-chips.mjs +2 -2
- package/fesm2022/legacy-chips.mjs.map +1 -1
- package/fesm2022/legacy-core.mjs +2 -2
- package/fesm2022/legacy-core.mjs.map +1 -1
- package/fesm2022/legacy-form-field.mjs +2 -2
- package/fesm2022/legacy-form-field.mjs.map +1 -1
- package/fesm2022/legacy-menu.mjs +4 -4
- package/fesm2022/legacy-menu.mjs.map +1 -1
- package/fesm2022/legacy-paginator.mjs +2 -2
- package/fesm2022/legacy-paginator.mjs.map +1 -1
- package/fesm2022/legacy-select.mjs +2 -2
- package/fesm2022/legacy-select.mjs.map +1 -1
- package/fesm2022/legacy-table.mjs +2 -2
- package/fesm2022/legacy-table.mjs.map +1 -1
- package/fesm2022/legacy-tabs.mjs +2 -2
- package/fesm2022/legacy-tabs.mjs.map +1 -1
- package/fesm2022/list.mjs +1 -0
- package/fesm2022/list.mjs.map +1 -1
- package/fesm2022/menu.mjs +4 -4
- package/fesm2022/menu.mjs.map +1 -1
- package/fesm2022/paginator.mjs +2 -2
- package/fesm2022/paginator.mjs.map +1 -1
- package/fesm2022/progress-bar.mjs +2 -2
- package/fesm2022/progress-bar.mjs.map +1 -1
- package/fesm2022/select.mjs +27 -16
- package/fesm2022/select.mjs.map +1 -1
- package/fesm2022/sidenav.mjs +12 -12
- package/fesm2022/sidenav.mjs.map +1 -1
- package/fesm2022/slide-toggle.mjs +2 -2
- package/fesm2022/slide-toggle.mjs.map +1 -1
- package/fesm2022/slider.mjs +20 -8
- package/fesm2022/slider.mjs.map +1 -1
- package/fesm2022/stepper.mjs +2 -2
- package/fesm2022/stepper.mjs.map +1 -1
- package/fesm2022/table.mjs +3 -3
- package/fesm2022/table.mjs.map +1 -1
- package/fesm2022/tabs.mjs +2 -2
- package/fesm2022/tabs.mjs.map +1 -1
- package/fesm2022/tooltip.mjs +4 -0
- package/fesm2022/tooltip.mjs.map +1 -1
- package/form-field/index.d.ts +44 -12
- package/legacy-select/index.d.ts +7 -2
- package/list/index.d.ts +2 -1
- package/package.json +49 -49
- 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 +1 -1
- package/schematics/ng-add/index.mjs +1 -1
- package/select/index.d.ts +13 -5
- package/slider/index.d.ts +10 -1
- package/table/index.d.ts +1 -1
- package/tabs/_tabs-theme.scss +0 -1
- package/tooltip/index.d.ts +4 -0
|
@@ -1,7 +1,3 @@
|
|
|
1
|
-
@use '@material/typography' as mdc-typography;
|
|
2
|
-
@use 'sass:map';
|
|
3
|
-
@use 'sass:math';
|
|
4
|
-
@use 'sass:meta';
|
|
5
1
|
@use './typography';
|
|
6
2
|
@use '../../autocomplete/autocomplete-theme';
|
|
7
3
|
@use '../../badge/badge-theme';
|
|
@@ -41,155 +37,6 @@
|
|
|
41
37
|
@use '../../tree/tree-theme';
|
|
42
38
|
@use '../theming/theming';
|
|
43
39
|
@use '../core-theme';
|
|
44
|
-
@use '../mdc-helpers/mdc-helpers';
|
|
45
|
-
|
|
46
|
-
// TODO(mmalerba): define-mdc-typography-config is defined here rather than in _typography.scss
|
|
47
|
-
// (where define-typography-config is defined) because putting it there would cause a circular
|
|
48
|
-
// dependency with mdc-helpers. We should refactor so these can live in the same place.
|
|
49
|
-
|
|
50
|
-
// Converts a map containing rem values to a map containing px values.
|
|
51
|
-
@function _rem-to-px($x, $px-per-rem: 16px) {
|
|
52
|
-
@if meta.type-of($x) == 'map' {
|
|
53
|
-
@each $key, $val in $x {
|
|
54
|
-
$x: map.merge($x, ($key: _rem-to-px($val)));
|
|
55
|
-
}
|
|
56
|
-
@return $x;
|
|
57
|
-
}
|
|
58
|
-
@if meta.type-of($x) == 'number' and math.unit($x) == 'rem' {
|
|
59
|
-
@return math.div($x, 1rem) * $px-per-rem;
|
|
60
|
-
}
|
|
61
|
-
@else {
|
|
62
|
-
@return $x;
|
|
63
|
-
}
|
|
64
|
-
}
|
|
65
|
-
|
|
66
|
-
// Applies the default font family to all levels in a typography config.
|
|
67
|
-
@function _apply-font-family($font-family, $initial-config) {
|
|
68
|
-
$config: $initial-config;
|
|
69
|
-
|
|
70
|
-
@each $key, $level in $config {
|
|
71
|
-
@if map.get($level, 'font-family') == null {
|
|
72
|
-
// Sass maps are immutable so we have to re-assign the variable each time.
|
|
73
|
-
$config: map.set($config, $key, map.set($level, 'font-family', $font-family));
|
|
74
|
-
}
|
|
75
|
-
}
|
|
76
|
-
|
|
77
|
-
@return map.set($config, 'font-family', $font-family);
|
|
78
|
-
}
|
|
79
|
-
|
|
80
|
-
/// Generates an Angular Material typography config based on values from the official Material
|
|
81
|
-
/// Design spec implementation (MDC Web). All arguments are optional, but may be passed to override
|
|
82
|
-
/// the default values. The `mat-typography-level` function can be used to generate a custom
|
|
83
|
-
/// typography level map which can be passed to this function to override one of the default levels.
|
|
84
|
-
/// All default typography sizing generated by this function is in `px` units.
|
|
85
|
-
///
|
|
86
|
-
/// @param {String} $font-family The font family to use for levels where it is not explicitly
|
|
87
|
-
/// specified.
|
|
88
|
-
/// @param {Map} $headline-1 The font settings for the headline-1 font level.
|
|
89
|
-
/// @param {Map} $headline-2 The font settings for the headline-2 font level.
|
|
90
|
-
/// @param {Map} $headline-3 The font settings for the headline-3 font level.
|
|
91
|
-
/// @param {Map} $headline-4 The font settings for the headline-4 font level.
|
|
92
|
-
/// @param {Map} $headline-5 The font settings for the headline-5 font level.
|
|
93
|
-
/// @param {Map} $headline-6 The font settings for the headline-6 font level.
|
|
94
|
-
/// @param {Map} $subtitle-1 The font settings for the subtitle-1 font level.
|
|
95
|
-
/// @param {Map} $subtitle-2 The font settings for the subtitle-2 font level.
|
|
96
|
-
/// @param {Map} $body-1 The font settings for the body-1 font level.
|
|
97
|
-
/// @param {Map} $body-2 The font settings for the body-2 font level.
|
|
98
|
-
/// @param {Map} $caption The font settings for the caption font level.
|
|
99
|
-
/// @param {Map} $button The font settings for the button font level.
|
|
100
|
-
/// @param {Map} $overline The font settings for the overline font level.
|
|
101
|
-
/// @return {Map} A map containing font settings for each of the levels in the Material Design spec.
|
|
102
|
-
@function define-typography-config(
|
|
103
|
-
// TODO(mmalerba): rename this function to define-typography-config,
|
|
104
|
-
// and create a predefined px based config for people that need it.
|
|
105
|
-
$font-family: mdc-typography.$font-family,
|
|
106
|
-
$headline-1: null,
|
|
107
|
-
$headline-2: null,
|
|
108
|
-
$headline-3: null,
|
|
109
|
-
$headline-4: null,
|
|
110
|
-
$headline-5: null,
|
|
111
|
-
$headline-6: null,
|
|
112
|
-
$subtitle-1: null,
|
|
113
|
-
$subtitle-2: null,
|
|
114
|
-
$body-1: null,
|
|
115
|
-
$body-2: null,
|
|
116
|
-
$caption: null,
|
|
117
|
-
$button: null,
|
|
118
|
-
$overline: null,
|
|
119
|
-
) {
|
|
120
|
-
@return _apply-font-family($font-family, (
|
|
121
|
-
headline-1: $headline-1 or _rem-to-px(mdc-helpers.typography-config-level-from-mdc(headline1)),
|
|
122
|
-
headline-2: $headline-2 or _rem-to-px(mdc-helpers.typography-config-level-from-mdc(headline2)),
|
|
123
|
-
headline-3: $headline-3 or _rem-to-px(mdc-helpers.typography-config-level-from-mdc(headline3)),
|
|
124
|
-
headline-4: $headline-4 or _rem-to-px(mdc-helpers.typography-config-level-from-mdc(headline4)),
|
|
125
|
-
headline-5: $headline-5 or _rem-to-px(mdc-helpers.typography-config-level-from-mdc(headline5)),
|
|
126
|
-
headline-6: $headline-6 or _rem-to-px(mdc-helpers.typography-config-level-from-mdc(headline6)),
|
|
127
|
-
subtitle-1: $subtitle-1 or _rem-to-px(mdc-helpers.typography-config-level-from-mdc(subtitle1)),
|
|
128
|
-
subtitle-2: $subtitle-2 or _rem-to-px(mdc-helpers.typography-config-level-from-mdc(subtitle2)),
|
|
129
|
-
body-1: $body-1 or _rem-to-px(mdc-helpers.typography-config-level-from-mdc(body1)),
|
|
130
|
-
body-2: $body-2 or _rem-to-px(mdc-helpers.typography-config-level-from-mdc(body2)),
|
|
131
|
-
caption: $caption or _rem-to-px(mdc-helpers.typography-config-level-from-mdc(caption)),
|
|
132
|
-
button: $button or _rem-to-px(mdc-helpers.typography-config-level-from-mdc(button)),
|
|
133
|
-
overline: $overline or _rem-to-px(mdc-helpers.typography-config-level-from-mdc(overline)),
|
|
134
|
-
));
|
|
135
|
-
}
|
|
136
|
-
|
|
137
|
-
/// Generates an Angular Material typography config based on values from the official Material
|
|
138
|
-
/// Design spec implementation (MDC Web). All arguments are optional, but may be passed to override
|
|
139
|
-
/// the default values. The `mat-typography-level` function can be used to generate a custom
|
|
140
|
-
/// typography level map which can be passed to this function to override one of the default levels.
|
|
141
|
-
/// All default typography sizing generated by this function is in `rem` units.
|
|
142
|
-
///
|
|
143
|
-
/// @param {String} $font-family The font family to use for levels where it is not explicitly
|
|
144
|
-
/// specified.
|
|
145
|
-
/// @param {Map} $headline-1 The font settings for the headline-1 font level.
|
|
146
|
-
/// @param {Map} $headline-2 The font settings for the headline-2 font level.
|
|
147
|
-
/// @param {Map} $headline-3 The font settings for the headline-3 font level.
|
|
148
|
-
/// @param {Map} $headline-4 The font settings for the headline-4 font level.
|
|
149
|
-
/// @param {Map} $headline-5 The font settings for the headline-5 font level.
|
|
150
|
-
/// @param {Map} $headline-6 The font settings for the headline-6 font level.
|
|
151
|
-
/// @param {Map} $subtitle-1 The font settings for the subtitle-1 font level.
|
|
152
|
-
/// @param {Map} $subtitle-2 The font settings for the subtitle-2 font level.
|
|
153
|
-
/// @param {Map} $body-1 The font settings for the body-1 font level.
|
|
154
|
-
/// @param {Map} $body-2 The font settings for the body-2 font level.
|
|
155
|
-
/// @param {Map} $caption The font settings for the caption font level.
|
|
156
|
-
/// @param {Map} $button The font settings for the button font level.
|
|
157
|
-
/// @param {Map} $overline The font settings for the overline font level.
|
|
158
|
-
/// @return {Map} A map containing font settings for each of the levels in the Material Design spec.
|
|
159
|
-
@function define-rem-typography-config(
|
|
160
|
-
// TODO(mmalerba): rename this function to define-typography-config,
|
|
161
|
-
// and create a predefined px based config for people that need it.
|
|
162
|
-
$font-family: mdc-typography.$font-family,
|
|
163
|
-
$headline-1: null,
|
|
164
|
-
$headline-2: null,
|
|
165
|
-
$headline-3: null,
|
|
166
|
-
$headline-4: null,
|
|
167
|
-
$headline-5: null,
|
|
168
|
-
$headline-6: null,
|
|
169
|
-
$subtitle-1: null,
|
|
170
|
-
$subtitle-2: null,
|
|
171
|
-
$body-1: null,
|
|
172
|
-
$body-2: null,
|
|
173
|
-
$caption: null,
|
|
174
|
-
$button: null,
|
|
175
|
-
$overline: null,
|
|
176
|
-
) {
|
|
177
|
-
@return _apply-font-family($font-family, (
|
|
178
|
-
headline-1: $headline-1 or mdc-helpers.typography-config-level-from-mdc(headline1),
|
|
179
|
-
headline-2: $headline-2 or mdc-helpers.typography-config-level-from-mdc(headline2),
|
|
180
|
-
headline-3: $headline-3 or mdc-helpers.typography-config-level-from-mdc(headline3),
|
|
181
|
-
headline-4: $headline-4 or mdc-helpers.typography-config-level-from-mdc(headline4),
|
|
182
|
-
headline-5: $headline-5 or mdc-helpers.typography-config-level-from-mdc(headline5),
|
|
183
|
-
headline-6: $headline-6 or mdc-helpers.typography-config-level-from-mdc(headline6),
|
|
184
|
-
subtitle-1: $subtitle-1 or mdc-helpers.typography-config-level-from-mdc(subtitle1),
|
|
185
|
-
subtitle-2: $subtitle-2 or mdc-helpers.typography-config-level-from-mdc(subtitle2),
|
|
186
|
-
body-1: $body-1 or mdc-helpers.typography-config-level-from-mdc(body1),
|
|
187
|
-
body-2: $body-2 or mdc-helpers.typography-config-level-from-mdc(body2),
|
|
188
|
-
caption: $caption or mdc-helpers.typography-config-level-from-mdc(caption),
|
|
189
|
-
button: $button or mdc-helpers.typography-config-level-from-mdc(button),
|
|
190
|
-
overline: $overline or mdc-helpers.typography-config-level-from-mdc(overline),
|
|
191
|
-
));
|
|
192
|
-
}
|
|
193
40
|
|
|
194
41
|
// Includes all of the typographic styles.
|
|
195
42
|
@mixin all-component-typographies($config-or-theme: null) {
|
|
@@ -198,7 +45,7 @@
|
|
|
198
45
|
|
|
199
46
|
// If no actual color configuration has been specified, create a default one.
|
|
200
47
|
@if not $config {
|
|
201
|
-
$config: define-typography-config();
|
|
48
|
+
$config: typography.define-typography-config();
|
|
202
49
|
}
|
|
203
50
|
|
|
204
51
|
// TODO: COMP-309: Do not use individual mixins. Instead, use the all-theme mixin and only
|
|
@@ -1,6 +1,9 @@
|
|
|
1
1
|
@use 'sass:map';
|
|
2
|
+
@use 'sass:math';
|
|
3
|
+
@use 'sass:meta';
|
|
2
4
|
@use 'typography-utils';
|
|
3
5
|
@use '../theming/theming';
|
|
6
|
+
@use '@material/typography' as mdc-typography;
|
|
4
7
|
|
|
5
8
|
/// Defines a typography level from the Material Design spec.
|
|
6
9
|
/// @param {String} $font-size The font-size for this level.
|
|
@@ -97,6 +100,165 @@
|
|
|
97
100
|
@return map.merge($config, (font-family: $font-family));
|
|
98
101
|
}
|
|
99
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
|
+
}
|
|
129
|
+
|
|
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
|
+
|
|
100
262
|
// Whether a config is for the Material Design 2018 typography system.
|
|
101
263
|
@function private-typography-is-2018-config($config) {
|
|
102
264
|
@return map.get($config, headline-1) != null;
|
|
@@ -268,14 +268,14 @@ class MatAutocomplete extends _MatAutocompleteBase {
|
|
|
268
268
|
return false;
|
|
269
269
|
}
|
|
270
270
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.0", ngImport: i0, type: MatAutocomplete, deps: null, target: i0.ɵɵFactoryTarget.Component }); }
|
|
271
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.0.0", type: MatAutocomplete, selector: "mat-autocomplete", inputs: { disableRipple: "disableRipple", hideSingleSelectionIndicator: "hideSingleSelectionIndicator" }, host: { attributes: { "ngSkipHydration": "
|
|
271
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.0.0", type: MatAutocomplete, selector: "mat-autocomplete", inputs: { disableRipple: "disableRipple", hideSingleSelectionIndicator: "hideSingleSelectionIndicator" }, host: { attributes: { "ngSkipHydration": "" }, 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;margin:0;padding:0;transform:scale(1);transform-origin:top left;opacity:0;overflow:auto;will-change:transform,opacity;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{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));z-index:8;border-radius:4px;border-radius:var(--mdc-shape-medium, 4px)}.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 }); }
|
|
272
272
|
}
|
|
273
273
|
export { MatAutocomplete };
|
|
274
274
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.0", ngImport: i0, type: MatAutocomplete, decorators: [{
|
|
275
275
|
type: Component,
|
|
276
276
|
args: [{ selector: 'mat-autocomplete', encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, exportAs: 'matAutocomplete', inputs: ['disableRipple'], host: {
|
|
277
277
|
'class': 'mat-mdc-autocomplete',
|
|
278
|
-
'ngSkipHydration': '
|
|
278
|
+
'ngSkipHydration': '',
|
|
279
279
|
}, providers: [{ provide: MAT_OPTION_PARENT_COMPONENT, useExisting: MatAutocomplete }], animations: [panelAnimation], 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;margin:0;padding:0;transform:scale(1);transform-origin:top left;opacity:0;overflow:auto;will-change:transform,opacity;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{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));z-index:8;border-radius:4px;border-radius:var(--mdc-shape-medium, 4px)}.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}"] }]
|
|
280
280
|
}], propDecorators: { optionGroups: [{
|
|
281
281
|
type: ContentChildren,
|
|
@@ -286,4 +286,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.0", ngImpor
|
|
|
286
286
|
}], hideSingleSelectionIndicator: [{
|
|
287
287
|
type: Input
|
|
288
288
|
}] } });
|
|
289
|
-
//# 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: 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) 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  }\n\n  ngAfterContentInit() {\n    this._keyManager = new ActiveDescendantKeyManager<_MatOptionBase>(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  }\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  protected _skipPredicate(option: _MatOptionBase) {\n    return option.disabled;\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    'ngSkipHydration': 'true',\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  // `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 override _skipPredicate(_option: _MatOptionBase) {\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    #panel>\n    <ng-content></ng-content>\n  </div>\n</ng-template>\n"]}
|
|
289
|
+
//# 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: 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) 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  }\n\n  ngAfterContentInit() {\n    this._keyManager = new ActiveDescendantKeyManager<_MatOptionBase>(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  }\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  protected _skipPredicate(option: _MatOptionBase) {\n    return option.disabled;\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    'ngSkipHydration': '',\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  // `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 override _skipPredicate(_option: _MatOptionBase) {\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    #panel>\n    <ng-content></ng-content>\n  </div>\n</ng-template>\n"]}
|