@angular/material 16.1.2 → 16.1.4
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/core/option/_optgroup-theme.scss +11 -8
- package/core/option/_option-theme.scss +14 -46
- package/core/tokens/_token-utils.scss +16 -0
- package/core/tokens/m2/mat/_menu.scss +62 -0
- package/core/tokens/m2/mat/_optgroup.scss +60 -0
- package/core/tokens/m2/mat/_option.scss +75 -0
- package/core/tokens/m2/mat/_stepper.scss +118 -0
- package/core/tokens/m2/mdc/_dialog.scss +1 -0
- package/core/typography/_typography-utils.scss +13 -0
- package/dialog/index.d.ts +2 -2
- package/esm2022/badge/badge.mjs +11 -1
- package/esm2022/button-toggle/button-toggle.mjs +2 -1
- package/esm2022/chips/chip-option.mjs +2 -2
- package/esm2022/chips/chip-row.mjs +3 -3
- package/esm2022/chips/chip-set.mjs +2 -2
- package/esm2022/chips/chip.mjs +2 -2
- package/esm2022/core/option/optgroup.mjs +2 -2
- package/esm2022/core/option/option.mjs +2 -2
- package/esm2022/core/ripple/ripple-renderer.mjs +7 -3
- package/esm2022/core/version.mjs +1 -1
- package/esm2022/dialog/dialog-container.mjs +11 -11
- package/esm2022/menu/menu-item.mjs +4 -4
- package/esm2022/menu/menu.mjs +3 -3
- package/esm2022/stepper/step-header.mjs +2 -2
- package/esm2022/stepper/stepper.mjs +3 -3
- package/esm2022/table/table.mjs +2 -2
- package/fesm2022/badge.mjs +10 -0
- package/fesm2022/badge.mjs.map +1 -1
- package/fesm2022/button-toggle.mjs +1 -0
- package/fesm2022/button-toggle.mjs.map +1 -1
- package/fesm2022/chips.mjs +7 -7
- package/fesm2022/chips.mjs.map +1 -1
- package/fesm2022/core.mjs +11 -7
- package/fesm2022/core.mjs.map +1 -1
- package/fesm2022/dialog.mjs +10 -10
- package/fesm2022/dialog.mjs.map +1 -1
- package/fesm2022/menu.mjs +5 -5
- package/fesm2022/menu.mjs.map +1 -1
- package/fesm2022/stepper.mjs +4 -4
- package/fesm2022/stepper.mjs.map +1 -1
- package/fesm2022/table.mjs +2 -2
- package/legacy-prebuilt-themes/legacy-deeppurple-amber.css +1 -1
- package/legacy-prebuilt-themes/legacy-indigo-pink.css +1 -1
- package/legacy-prebuilt-themes/legacy-pink-bluegrey.css +1 -1
- package/legacy-prebuilt-themes/legacy-purple-green.css +1 -1
- package/menu/_menu-theme.scss +9 -52
- package/menu/index.d.ts +1 -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/schematics/ng-add/theming/theming.js +1 -1
- package/schematics/ng-add/theming/theming.mjs +1 -1
- package/schematics/ng-generate/mdc-migration/index_bundled.js +44 -44
- package/schematics/ng-generate/mdc-migration/index_bundled.js.map +1 -1
- package/schematics/ng-generate/table/files/__path__/__name@dasherize@if-flat__/__name@dasherize__.component.html.template +1 -1
- package/schematics/ng-generate/table/files/__path__/__name@dasherize@if-flat__/__name@dasherize__.component.ts.template +1 -5
- package/schematics/ng-update/index_bundled.js +25 -25
- package/stepper/_stepper-theme.scss +18 -147
|
@@ -1,24 +1,27 @@
|
|
|
1
|
-
@use '
|
|
1
|
+
@use '../tokens/m2/mat/optgroup' as tokens-mat-optgroup;
|
|
2
|
+
@use '../tokens/token-utils';
|
|
3
|
+
@use '../style/sass-utils';
|
|
2
4
|
|
|
3
5
|
@use '../theming/theming';
|
|
4
6
|
@use '../typography/typography';
|
|
5
|
-
@use '../mdc-helpers/mdc-helpers';
|
|
6
7
|
|
|
7
8
|
@mixin color($config-or-theme) {
|
|
8
9
|
$config: theming.get-color-config($config-or-theme);
|
|
9
10
|
|
|
10
|
-
@include
|
|
11
|
-
.mat-
|
|
12
|
-
|
|
13
|
-
// we have to explicitly set the default color.
|
|
14
|
-
@include mdc-theme.prop(color, text-primary-on-background);
|
|
15
|
-
}
|
|
11
|
+
@include sass-utils.current-selector-or-root() {
|
|
12
|
+
@include token-utils.create-token-values(tokens-mat-optgroup.$prefix,
|
|
13
|
+
tokens-mat-optgroup.get-color-tokens($config));
|
|
16
14
|
}
|
|
17
15
|
}
|
|
18
16
|
|
|
19
17
|
@mixin typography($config-or-theme) {
|
|
20
18
|
$config: typography.private-typography-to-2018-config(
|
|
21
19
|
theming.get-typography-config($config-or-theme));
|
|
20
|
+
|
|
21
|
+
@include sass-utils.current-selector-or-root() {
|
|
22
|
+
@include token-utils.create-token-values(tokens-mat-optgroup.$prefix,
|
|
23
|
+
tokens-mat-optgroup.get-typography-tokens($config));
|
|
24
|
+
}
|
|
22
25
|
}
|
|
23
26
|
|
|
24
27
|
@mixin density($config-or-theme) {
|
|
@@ -1,8 +1,7 @@
|
|
|
1
|
-
@use '
|
|
2
|
-
@use '
|
|
3
|
-
@use '
|
|
4
|
-
@use '
|
|
5
|
-
@use '@material/ripple' as mdc-ripple;
|
|
1
|
+
@use 'sass:map';
|
|
2
|
+
@use '../tokens/m2/mat/option' as tokens-mat-option;
|
|
3
|
+
@use '../tokens/token-utils';
|
|
4
|
+
@use '../style/sass-utils';
|
|
6
5
|
|
|
7
6
|
@use '../theming/theming';
|
|
8
7
|
@use '../typography/typography';
|
|
@@ -12,42 +11,19 @@
|
|
|
12
11
|
$config: theming.get-color-config($config-or-theme);
|
|
13
12
|
|
|
14
13
|
@include mdc-helpers.using-mdc-theme($config) {
|
|
15
|
-
.
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
@include mdc-theme.prop(color, text-primary-on-background);
|
|
19
|
-
|
|
20
|
-
// Increase specificity to override styles from list theme.
|
|
21
|
-
&:hover:not(.mdc-list-item--disabled),
|
|
22
|
-
&:focus.mdc-list-item,
|
|
23
|
-
&.mat-mdc-option-active.mdc-list-item,
|
|
24
|
-
|
|
25
|
-
// In multiple mode there is a checkbox to show that the option is selected.
|
|
26
|
-
&.mdc-list-item--selected:not(.mat-mdc-option-multiple):not(.mdc-list-item--disabled) {
|
|
27
|
-
$color: mdc-theme-color.$on-surface;
|
|
28
|
-
background: rgba($color, mdc-ripple.states-opacity($color, hover));
|
|
29
|
-
}
|
|
30
|
-
}
|
|
31
|
-
|
|
32
|
-
.mat-primary {
|
|
33
|
-
.mat-mdc-option.mdc-list-item--selected:not(.mdc-list-item--disabled) {
|
|
34
|
-
@include mdc-list-mixins.list-primary-text-ink-color(primary,
|
|
35
|
-
$query: mdc-helpers.$mdc-theme-styles-query);
|
|
36
|
-
}
|
|
14
|
+
@include sass-utils.current-selector-or-root() {
|
|
15
|
+
@include token-utils.create-token-values(tokens-mat-option.$prefix,
|
|
16
|
+
tokens-mat-option.get-color-tokens($config));
|
|
37
17
|
}
|
|
38
18
|
|
|
39
19
|
.mat-accent {
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
$query: mdc-helpers.$mdc-theme-styles-query);
|
|
43
|
-
}
|
|
20
|
+
@include token-utils.create-token-values(tokens-mat-option.$prefix,
|
|
21
|
+
tokens-mat-option.private-get-color-palette-color-tokens(map.get($config, accent)));
|
|
44
22
|
}
|
|
45
23
|
|
|
46
24
|
.mat-warn {
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
$query: mdc-helpers.$mdc-theme-styles-query);
|
|
50
|
-
}
|
|
25
|
+
@include token-utils.create-token-values(tokens-mat-option.$prefix,
|
|
26
|
+
tokens-mat-option.private-get-color-palette-color-tokens(map.get($config, warn)));
|
|
51
27
|
}
|
|
52
28
|
}
|
|
53
29
|
}
|
|
@@ -56,17 +32,9 @@
|
|
|
56
32
|
$config: typography.private-typography-to-2018-config(
|
|
57
33
|
theming.get-typography-config($config-or-theme));
|
|
58
34
|
|
|
59
|
-
@include
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
.mat-mdc-option {
|
|
63
|
-
@include mdc-typography.typography(body1,
|
|
64
|
-
$query: mdc-helpers.$mdc-typography-styles-query,
|
|
65
|
-
// Exclude these properties, because they cause some build
|
|
66
|
-
// issues internally and they aren't used for anything.
|
|
67
|
-
$exclude-props: (text-decoration, text-transform)
|
|
68
|
-
);
|
|
69
|
-
}
|
|
35
|
+
@include sass-utils.current-selector-or-root() {
|
|
36
|
+
@include token-utils.create-token-values(tokens-mat-option.$prefix,
|
|
37
|
+
tokens-mat-option.get-typography-tokens($config));
|
|
70
38
|
}
|
|
71
39
|
}
|
|
72
40
|
|
|
@@ -75,12 +75,28 @@ $_component-prefix: null;
|
|
|
75
75
|
@if $_component-prefix == null or $_tokens == null {
|
|
76
76
|
@error '`create-token-slot` must be used within `use-tokens`';
|
|
77
77
|
}
|
|
78
|
+
@if not map.has-key($_tokens, $token) {
|
|
79
|
+
@error 'Token #{$token} does not exist. Configured tokens are: #{map.keys($_tokens)}';
|
|
80
|
+
}
|
|
78
81
|
@if map.get($_tokens, $token) != null {
|
|
79
82
|
$value: mdc-custom-properties.create('#{$_component-prefix}-#{$token}');
|
|
80
83
|
@include mdc-theme.property($property, $value);
|
|
81
84
|
}
|
|
82
85
|
}
|
|
83
86
|
|
|
87
|
+
// Returns the name of a token including the current prefix. Intended to be used in calculations
|
|
88
|
+
// involving tokens. `create-token-slot` should be used when outputting tokens.
|
|
89
|
+
@function get-token-variable($token) {
|
|
90
|
+
@if $_component-prefix == null or $_tokens == null {
|
|
91
|
+
@error '`get-token-variable` must be used within `use-tokens`';
|
|
92
|
+
}
|
|
93
|
+
@if not map.has-key($_tokens, $token) {
|
|
94
|
+
@error 'Token #{$token} does not exist. Configured tokens are: #{map.keys($_tokens)}';
|
|
95
|
+
}
|
|
96
|
+
|
|
97
|
+
@return mdc-custom-properties.create-varname('#{$_component-prefix}-#{$token}');
|
|
98
|
+
}
|
|
99
|
+
|
|
84
100
|
@mixin create-token-values($prefix, $tokens) {
|
|
85
101
|
@include _configure-token-prefix($prefix...) {
|
|
86
102
|
@include mdc-keys.declare-custom-properties($tokens, $_component-prefix);
|
|
@@ -0,0 +1,62 @@
|
|
|
1
|
+
@use 'sass:map';
|
|
2
|
+
@use '../../token-utils';
|
|
3
|
+
@use '../../../theming/theming';
|
|
4
|
+
@use '../../../style/sass-utils';
|
|
5
|
+
@use '../../../typography/typography-utils';
|
|
6
|
+
|
|
7
|
+
// The prefix used to generate the fully qualified name for tokens in this file.
|
|
8
|
+
$prefix: (mat, menu);
|
|
9
|
+
|
|
10
|
+
// Tokens that can't be configured through Angular Material's current theming API,
|
|
11
|
+
// but may be in a future version of the theming API.
|
|
12
|
+
@function get-unthemable-tokens() {
|
|
13
|
+
@return (
|
|
14
|
+
container-shape: 4px,
|
|
15
|
+
);
|
|
16
|
+
}
|
|
17
|
+
|
|
18
|
+
// Tokens that can be configured through Angular Material's color theming API.
|
|
19
|
+
@function get-color-tokens($config) {
|
|
20
|
+
$is-dark: map.get($config, is-dark);
|
|
21
|
+
$foreground: map.get($config, foreground);
|
|
22
|
+
$background: map.get($config, background);
|
|
23
|
+
$on-surface: if($is-dark, #fff, #000);
|
|
24
|
+
$active-state-layer-color: rgba($on-surface, if($is-dark, 0.08, 0.04));
|
|
25
|
+
$text-color: theming.get-color-from-palette($foreground, text);
|
|
26
|
+
|
|
27
|
+
@return (
|
|
28
|
+
item-label-text-color: $text-color,
|
|
29
|
+
item-icon-color: $text-color,
|
|
30
|
+
item-hover-state-layer-color: $active-state-layer-color,
|
|
31
|
+
item-focus-state-layer-color: $active-state-layer-color,
|
|
32
|
+
container-color: theming.get-color-from-palette($background, card),
|
|
33
|
+
);
|
|
34
|
+
}
|
|
35
|
+
|
|
36
|
+
// Tokens that can be configured through Angular Material's typography theming API.
|
|
37
|
+
@function get-typography-tokens($config) {
|
|
38
|
+
@return (
|
|
39
|
+
item-label-text-font:
|
|
40
|
+
typography-utils.font-family($config, body-1) or typography-utils.font-family($config),
|
|
41
|
+
item-label-text-size: typography-utils.font-size($config, body-1),
|
|
42
|
+
item-label-text-tracking: typography-utils.letter-spacing($config, body-1),
|
|
43
|
+
item-label-text-line-height: typography-utils.line-height($config, body-1),
|
|
44
|
+
item-label-text-weight: typography-utils.font-weight($config, body-1),
|
|
45
|
+
);
|
|
46
|
+
}
|
|
47
|
+
|
|
48
|
+
// Tokens that can be configured through Angular Material's density theming API.
|
|
49
|
+
@function get-density-tokens($config) {
|
|
50
|
+
@return ();
|
|
51
|
+
}
|
|
52
|
+
|
|
53
|
+
// Combines the tokens generated by the above functions into a single map with placeholder values.
|
|
54
|
+
// This is used to create token slots.
|
|
55
|
+
@function get-token-slots() {
|
|
56
|
+
@return sass-utils.deep-merge-all(
|
|
57
|
+
get-unthemable-tokens(),
|
|
58
|
+
get-color-tokens(token-utils.$placeholder-color-config),
|
|
59
|
+
get-typography-tokens(token-utils.$placeholder-typography-config),
|
|
60
|
+
get-density-tokens(token-utils.$placeholder-density-config)
|
|
61
|
+
);
|
|
62
|
+
}
|
|
@@ -0,0 +1,60 @@
|
|
|
1
|
+
@use 'sass:map';
|
|
2
|
+
@use '../../token-utils';
|
|
3
|
+
@use '../../../theming/theming';
|
|
4
|
+
@use '../../../style/sass-utils';
|
|
5
|
+
@use '../../../typography/typography-utils';
|
|
6
|
+
@use '../../../mdc-helpers/mdc-helpers';
|
|
7
|
+
|
|
8
|
+
// The prefix used to generate the fully qualified name for tokens in this file.
|
|
9
|
+
$prefix: (mat, optgroup);
|
|
10
|
+
|
|
11
|
+
// Tokens that can't be configured through Angular Material's current theming API,
|
|
12
|
+
// but may be in a future version of the theming API.
|
|
13
|
+
@function get-unthemable-tokens() {
|
|
14
|
+
@return ();
|
|
15
|
+
}
|
|
16
|
+
|
|
17
|
+
// Tokens that can be configured through Angular Material's color theming API.
|
|
18
|
+
@function get-color-tokens($config) {
|
|
19
|
+
$foreground: map.get($config, foreground);
|
|
20
|
+
|
|
21
|
+
@return (
|
|
22
|
+
label-text-color: theming.get-color-from-palette($foreground, text),
|
|
23
|
+
);
|
|
24
|
+
}
|
|
25
|
+
|
|
26
|
+
// Tokens that can be configured through Angular Material's typography theming API.
|
|
27
|
+
@function get-typography-tokens($config) {
|
|
28
|
+
// TODO(crisbeto): The earlier implementation of the option used MDC's APIs to create the
|
|
29
|
+
// typography tokens. As a result, we unintentionally allowed `null` typography configs to be
|
|
30
|
+
// passed in. Since there a lot of apps that now depend on this pattern, we need this temporary
|
|
31
|
+
// fallback.
|
|
32
|
+
@if ($config == null) {
|
|
33
|
+
$config: mdc-helpers.private-fallback-typography-from-mdc();
|
|
34
|
+
}
|
|
35
|
+
|
|
36
|
+
@return (
|
|
37
|
+
label-text-font: typography-utils.font-family($config, body-1) or
|
|
38
|
+
typography-utils.font-family($config),
|
|
39
|
+
label-text-line-height: typography-utils.line-height($config, body-1),
|
|
40
|
+
label-text-size: typography-utils.font-size($config, body-1),
|
|
41
|
+
label-text-tracking: typography-utils.letter-spacing($config, body-1),
|
|
42
|
+
label-text-weight: typography-utils.font-weight($config, body-1)
|
|
43
|
+
);
|
|
44
|
+
}
|
|
45
|
+
|
|
46
|
+
// Tokens that can be configured through Angular Material's density theming API.
|
|
47
|
+
@function get-density-tokens($config) {
|
|
48
|
+
@return ();
|
|
49
|
+
}
|
|
50
|
+
|
|
51
|
+
// Combines the tokens generated by the above functions into a single map with placeholder values.
|
|
52
|
+
// This is used to create token slots.
|
|
53
|
+
@function get-token-slots() {
|
|
54
|
+
@return sass-utils.deep-merge-all(
|
|
55
|
+
get-unthemable-tokens(),
|
|
56
|
+
get-color-tokens(token-utils.$placeholder-color-config),
|
|
57
|
+
get-typography-tokens(token-utils.$placeholder-typography-config),
|
|
58
|
+
get-density-tokens(token-utils.$placeholder-density-config)
|
|
59
|
+
);
|
|
60
|
+
}
|
|
@@ -0,0 +1,75 @@
|
|
|
1
|
+
@use 'sass:map';
|
|
2
|
+
@use '../../token-utils';
|
|
3
|
+
@use '../../../theming/theming';
|
|
4
|
+
@use '../../../style/sass-utils';
|
|
5
|
+
@use '../../../typography/typography-utils';
|
|
6
|
+
@use '../../../mdc-helpers/mdc-helpers';
|
|
7
|
+
|
|
8
|
+
// The prefix used to generate the fully qualified name for tokens in this file.
|
|
9
|
+
$prefix: (mat, option);
|
|
10
|
+
|
|
11
|
+
// Tokens that can't be configured through Angular Material's current theming API,
|
|
12
|
+
// but may be in a future version of the theming API.
|
|
13
|
+
@function get-unthemable-tokens() {
|
|
14
|
+
@return ();
|
|
15
|
+
}
|
|
16
|
+
|
|
17
|
+
// Tokens that can be configured through Angular Material's color theming API.
|
|
18
|
+
@function get-color-tokens($config) {
|
|
19
|
+
$is-dark: map.get($config, is-dark);
|
|
20
|
+
$foreground: map.get($config, foreground);
|
|
21
|
+
$primary: map.get($config, primary);
|
|
22
|
+
$on-surface: if($is-dark, #fff, #000);
|
|
23
|
+
$active-state-layer-color: rgba($on-surface, if($is-dark, 0.08, 0.04));
|
|
24
|
+
$palette-tokens: private-get-color-palette-color-tokens($primary);
|
|
25
|
+
|
|
26
|
+
@return map.merge($palette-tokens, (
|
|
27
|
+
label-text-color: theming.get-color-from-palette($foreground, text),
|
|
28
|
+
hover-state-layer-color: $active-state-layer-color,
|
|
29
|
+
focus-state-layer-color: $active-state-layer-color,
|
|
30
|
+
selected-state-layer-color: $active-state-layer-color,
|
|
31
|
+
));
|
|
32
|
+
}
|
|
33
|
+
|
|
34
|
+
// Tokens that can be configured through Angular Material's typography theming API.
|
|
35
|
+
@function get-typography-tokens($config) {
|
|
36
|
+
// TODO(crisbeto): The earlier implementation of the option used MDC's APIs to create the
|
|
37
|
+
// typography tokens. As a result, we unintentionally allowed `null` typography configs to be
|
|
38
|
+
// passed in. Since there a lot of apps that now depend on this pattern, we need this temporary
|
|
39
|
+
// fallback.
|
|
40
|
+
@if ($config == null) {
|
|
41
|
+
$config: mdc-helpers.private-fallback-typography-from-mdc();
|
|
42
|
+
}
|
|
43
|
+
|
|
44
|
+
@return (
|
|
45
|
+
label-text-font: typography-utils.font-family($config, body-1) or
|
|
46
|
+
typography-utils.font-family($config),
|
|
47
|
+
label-text-line-height: typography-utils.line-height($config, body-1),
|
|
48
|
+
label-text-size: typography-utils.font-size($config, body-1),
|
|
49
|
+
label-text-tracking: typography-utils.letter-spacing($config, body-1),
|
|
50
|
+
label-text-weight: typography-utils.font-weight($config, body-1)
|
|
51
|
+
);
|
|
52
|
+
}
|
|
53
|
+
|
|
54
|
+
// Generates the tokens used to theme the option based on a palette.
|
|
55
|
+
@function private-get-color-palette-color-tokens($palette) {
|
|
56
|
+
@return (
|
|
57
|
+
selected-state-label-text-color: theming.get-color-from-palette($palette),
|
|
58
|
+
);
|
|
59
|
+
}
|
|
60
|
+
|
|
61
|
+
// Tokens that can be configured through Angular Material's density theming API.
|
|
62
|
+
@function get-density-tokens($config) {
|
|
63
|
+
@return ();
|
|
64
|
+
}
|
|
65
|
+
|
|
66
|
+
// Combines the tokens generated by the above functions into a single map with placeholder values.
|
|
67
|
+
// This is used to create token slots.
|
|
68
|
+
@function get-token-slots() {
|
|
69
|
+
@return sass-utils.deep-merge-all(
|
|
70
|
+
get-unthemable-tokens(),
|
|
71
|
+
get-color-tokens(token-utils.$placeholder-color-config),
|
|
72
|
+
get-typography-tokens(token-utils.$placeholder-typography-config),
|
|
73
|
+
get-density-tokens(token-utils.$placeholder-density-config)
|
|
74
|
+
);
|
|
75
|
+
}
|
|
@@ -0,0 +1,118 @@
|
|
|
1
|
+
@use 'sass:map';
|
|
2
|
+
@use '../../token-utils';
|
|
3
|
+
@use '../../../theming/theming';
|
|
4
|
+
@use '../../../typography/typography-utils';
|
|
5
|
+
@use '../../../style/sass-utils';
|
|
6
|
+
|
|
7
|
+
// The prefix used to generate the fully qualified name for tokens in this file.
|
|
8
|
+
$prefix: (mat, stepper);
|
|
9
|
+
|
|
10
|
+
// Tokens that can't be configured through Angular Material's current theming API,
|
|
11
|
+
// but may be in a future version of the theming API.
|
|
12
|
+
@function get-unthemable-tokens() {
|
|
13
|
+
@return ();
|
|
14
|
+
}
|
|
15
|
+
|
|
16
|
+
// Tokens that can be configured through Angular Material's color theming API.
|
|
17
|
+
@function get-color-tokens($config) {
|
|
18
|
+
$foreground: map.get($config, foreground);
|
|
19
|
+
$background: map.get($config, background);
|
|
20
|
+
$primary: map.get($config, primary);
|
|
21
|
+
$warn: map.get($config, warn);
|
|
22
|
+
|
|
23
|
+
@return map.merge(private-get-color-palette-color-tokens($primary), (
|
|
24
|
+
// Background for stepper container.
|
|
25
|
+
container-color: theming.get-color-from-palette($background, card),
|
|
26
|
+
// Color of the line indicator connecting the steps.
|
|
27
|
+
line-color: theming.get-color-from-palette($foreground, divider),
|
|
28
|
+
// Background color of the header while hovered.
|
|
29
|
+
header-hover-state-layer-color: theming.get-color-from-palette($background, hover),
|
|
30
|
+
// Background color of the header while focused.
|
|
31
|
+
header-focus-state-layer-color: theming.get-color-from-palette($background, hover),
|
|
32
|
+
// Color of the text inside the step header.
|
|
33
|
+
header-label-text-color: theming.get-color-from-palette($foreground, secondary-text),
|
|
34
|
+
// Color for the "optional" label in the step header.
|
|
35
|
+
header-optional-label-text-color: theming.get-color-from-palette($foreground, secondary-text),
|
|
36
|
+
// Color of the header text when a step is selected.
|
|
37
|
+
header-selected-state-label-text-color: theming.get-color-from-palette($foreground, text),
|
|
38
|
+
// Color of the header text when a step is in an error state.
|
|
39
|
+
header-error-state-label-text-color: theming.get-color-from-palette($warn, text),
|
|
40
|
+
// Background color of the header icon.
|
|
41
|
+
header-icon-background-color: theming.get-color-from-palette($foreground, secondary-text),
|
|
42
|
+
// Foreground color of the header icon in the error state.
|
|
43
|
+
header-error-state-icon-foreground-color: theming.get-color-from-palette($warn, text),
|
|
44
|
+
// Background color of the header icon in the error state.
|
|
45
|
+
header-error-state-icon-background-color: transparent,
|
|
46
|
+
));
|
|
47
|
+
}
|
|
48
|
+
|
|
49
|
+
// Tokens that can be configured through Angular Material's typography theming API.
|
|
50
|
+
@function get-typography-tokens($config) {
|
|
51
|
+
@return (
|
|
52
|
+
// Font family of the entire stepper.
|
|
53
|
+
container-text-font: typography-utils.font-family($config),
|
|
54
|
+
// Font family of the text inside the step header.
|
|
55
|
+
header-label-text-font: typography-utils.font-family($config, body-1) or
|
|
56
|
+
typography-utils.font-family($config),
|
|
57
|
+
// Size of the text inside the step header.
|
|
58
|
+
header-label-text-size: typography-utils.font-size($config, body-1),
|
|
59
|
+
// Weight of the text inside the step header.
|
|
60
|
+
header-label-text-weight: typography-utils.font-weight($config, body-1),
|
|
61
|
+
// Color of the header text when a step is in an error state.
|
|
62
|
+
header-error-state-label-text-size: typography-utils.font-size($config, body-2),
|
|
63
|
+
// Size of the header text in the selected state.
|
|
64
|
+
header-selected-state-label-text-size: typography-utils.font-size($config, body-2),
|
|
65
|
+
// Weight of the header text in the selected state.
|
|
66
|
+
header-selected-state-label-text-weight: typography-utils.font-weight($config, body-2),
|
|
67
|
+
);
|
|
68
|
+
}
|
|
69
|
+
|
|
70
|
+
// Tokens that can be configured through Angular Material's density theming API.
|
|
71
|
+
@function get-density-tokens($config) {
|
|
72
|
+
$scale: theming.clamp-density($config, -4);
|
|
73
|
+
$height-config: (
|
|
74
|
+
0: 72px,
|
|
75
|
+
-1: 68px,
|
|
76
|
+
-2: 64px,
|
|
77
|
+
-3: 60px,
|
|
78
|
+
-4: 42px,
|
|
79
|
+
);
|
|
80
|
+
|
|
81
|
+
@return (
|
|
82
|
+
header-height: map.get($height-config, $scale),
|
|
83
|
+
);
|
|
84
|
+
}
|
|
85
|
+
|
|
86
|
+
// Generates the tokens used to theme the stepper based on a palette.
|
|
87
|
+
@function private-get-color-palette-color-tokens($palette) {
|
|
88
|
+
$active-state-foreground: theming.get-color-from-palette($palette, default-contrast);
|
|
89
|
+
$active-state-background: theming.get-color-from-palette($palette);
|
|
90
|
+
|
|
91
|
+
@return (
|
|
92
|
+
// Foreground color of the header icon.
|
|
93
|
+
header-icon-foreground-color: theming.get-color-from-palette($palette, default-contrast),
|
|
94
|
+
// Background color of the header icon in the selected state.
|
|
95
|
+
header-selected-state-icon-background-color: $active-state-background,
|
|
96
|
+
// Foreground color of the header icon in the selected state.
|
|
97
|
+
header-selected-state-icon-foreground-color: $active-state-foreground,
|
|
98
|
+
// Background color of the header icon in the selected state.
|
|
99
|
+
header-done-state-icon-background-color: $active-state-background,
|
|
100
|
+
// Foreground color of the header icon in the selected state.
|
|
101
|
+
header-done-state-icon-foreground-color: $active-state-foreground,
|
|
102
|
+
// Background color of the header icon in the editing state.
|
|
103
|
+
header-edit-state-icon-background-color: $active-state-background,
|
|
104
|
+
// Foreground color of the header icon in the editing state.
|
|
105
|
+
header-edit-state-icon-foreground-color: $active-state-foreground,
|
|
106
|
+
);
|
|
107
|
+
}
|
|
108
|
+
|
|
109
|
+
// Combines the tokens generated by the above functions into a single map with placeholder values.
|
|
110
|
+
// This is used to create token slots.
|
|
111
|
+
@function get-token-slots() {
|
|
112
|
+
@return sass-utils.deep-merge-all(
|
|
113
|
+
get-unthemable-tokens(),
|
|
114
|
+
get-color-tokens(token-utils.$placeholder-color-config),
|
|
115
|
+
get-typography-tokens(token-utils.$placeholder-typography-config),
|
|
116
|
+
get-density-tokens(token-utils.$placeholder-density-config)
|
|
117
|
+
);
|
|
118
|
+
}
|
|
@@ -7,6 +7,15 @@
|
|
|
7
7
|
|
|
8
8
|
// Utility for fetching a nested value from a typography config.
|
|
9
9
|
@function _mat-get-type-value($config, $level, $name) {
|
|
10
|
+
@if meta.type-of($config) != 'map' {
|
|
11
|
+
@error 'Typography config must be a map. Received #{meta.type-of($config)}.';
|
|
12
|
+
}
|
|
13
|
+
|
|
14
|
+
@if not map.has-key($config, $level) {
|
|
15
|
+
@error 'Typography config does not have a level called "#{$level}". ' +
|
|
16
|
+
'Available levels are: #{map.keys($config)}.';
|
|
17
|
+
}
|
|
18
|
+
|
|
10
19
|
@return map.get(map.get($config, $level), $name);
|
|
11
20
|
}
|
|
12
21
|
|
|
@@ -42,6 +51,10 @@
|
|
|
42
51
|
/// @param {Map} $config A typography config.
|
|
43
52
|
/// @param {Map} $level A typography level.
|
|
44
53
|
@function font-family($config, $level: null) {
|
|
54
|
+
@if meta.type-of($config) != 'map' {
|
|
55
|
+
@error 'Typography config must be a map. Received #{meta.type-of($config)}.';
|
|
56
|
+
}
|
|
57
|
+
|
|
45
58
|
$font-family: map.get($config, font-family);
|
|
46
59
|
|
|
47
60
|
@if $level != null {
|
package/dialog/index.d.ts
CHANGED
|
@@ -356,9 +356,9 @@ export declare class MatDialogContainer extends _MatDialogContainerBase implemen
|
|
|
356
356
|
/** Host element of the dialog container component. */
|
|
357
357
|
private _hostElement;
|
|
358
358
|
/** Duration of the dialog open animation. */
|
|
359
|
-
private
|
|
359
|
+
private _enterAnimationDuration;
|
|
360
360
|
/** Duration of the dialog close animation. */
|
|
361
|
-
private
|
|
361
|
+
private _exitAnimationDuration;
|
|
362
362
|
/** Current timer for dialog animations. */
|
|
363
363
|
private _animationTimer;
|
|
364
364
|
constructor(elementRef: ElementRef, focusTrapFactory: FocusTrapFactory, document: any, dialogConfig: MatDialogConfig, checker: InteractivityChecker, ngZone: NgZone, overlayRef: OverlayRef, _animationMode?: string | undefined, focusMonitor?: FocusMonitor);
|
package/esm2022/badge/badge.mjs
CHANGED
|
@@ -85,6 +85,16 @@ export class MatBadge extends _MatBadgeBase {
|
|
|
85
85
|
if (nativeElement.nodeType !== nativeElement.ELEMENT_NODE) {
|
|
86
86
|
throw Error('matBadge must be attached to an element node.');
|
|
87
87
|
}
|
|
88
|
+
const matIconTagName = 'mat-icon';
|
|
89
|
+
// Heads-up for developers to avoid putting matBadge on <mat-icon>
|
|
90
|
+
// as it is aria-hidden by default docs mention this at:
|
|
91
|
+
// https://material.angular.io/components/badge/overview#accessibility
|
|
92
|
+
if (nativeElement.tagName.toLowerCase() === matIconTagName &&
|
|
93
|
+
nativeElement.getAttribute('aria-hidden') === 'true') {
|
|
94
|
+
console.warn(`Detected a matBadge on an "aria-hidden" "<mat-icon>". ` +
|
|
95
|
+
`Consider setting aria-hidden="false" in order to surface the information assistive technology.` +
|
|
96
|
+
`\n${nativeElement.outerHTML}`);
|
|
97
|
+
}
|
|
88
98
|
}
|
|
89
99
|
}
|
|
90
100
|
/** Whether the badge is above the host or not */
|
|
@@ -273,4 +283,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.1", ngImpor
|
|
|
273
283
|
type: Input,
|
|
274
284
|
args: ['matBadgeHidden']
|
|
275
285
|
}] } });
|
|
276
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"badge.js","sourceRoot":"","sources":["../../../../../../src/material/badge/badge.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\n\nimport {AriaDescriber, InteractivityChecker} from '@angular/cdk/a11y';\nimport {BooleanInput, coerceBooleanProperty} from '@angular/cdk/coercion';\nimport {DOCUMENT} from '@angular/common';\nimport {\n  Directive,\n  ElementRef,\n  inject,\n  Inject,\n  Input,\n  NgZone,\n  OnDestroy,\n  OnInit,\n  Optional,\n  Renderer2,\n} from '@angular/core';\nimport {CanDisable, mixinDisabled, ThemePalette} from '@angular/material/core';\nimport {ANIMATION_MODULE_TYPE} from '@angular/platform-browser/animations';\n\nlet nextId = 0;\n\n// Boilerplate for applying mixins to MatBadge.\n/** @docs-private */\nconst _MatBadgeBase = mixinDisabled(class {});\n\n/** Allowed position options for matBadgePosition */\nexport type MatBadgePosition =\n  | 'above after'\n  | 'above before'\n  | 'below before'\n  | 'below after'\n  | 'before'\n  | 'after'\n  | 'above'\n  | 'below';\n\n/** Allowed size options for matBadgeSize */\nexport type MatBadgeSize = 'small' | 'medium' | 'large';\n\nconst BADGE_CONTENT_CLASS = 'mat-badge-content';\n\n/** Directive to display a text badge. */\n@Directive({\n  selector: '[matBadge]',\n  inputs: ['disabled: matBadgeDisabled'],\n  host: {\n    'class': 'mat-badge',\n    '[class.mat-badge-overlap]': 'overlap',\n    '[class.mat-badge-above]': 'isAbove()',\n    '[class.mat-badge-below]': '!isAbove()',\n    '[class.mat-badge-before]': '!isAfter()',\n    '[class.mat-badge-after]': 'isAfter()',\n    '[class.mat-badge-small]': 'size === \"small\"',\n    '[class.mat-badge-medium]': 'size === \"medium\"',\n    '[class.mat-badge-large]': 'size === \"large\"',\n    '[class.mat-badge-hidden]': 'hidden || !content',\n    '[class.mat-badge-disabled]': 'disabled',\n  },\n})\nexport class MatBadge extends _MatBadgeBase implements OnInit, OnDestroy, CanDisable {\n  /** The color of the badge. Can be `primary`, `accent`, or `warn`. */\n  @Input('matBadgeColor')\n  get color(): ThemePalette {\n    return this._color;\n  }\n  set color(value: ThemePalette) {\n    this._setColor(value);\n    this._color = value;\n  }\n  private _color: ThemePalette = 'primary';\n\n  /** Whether the badge should overlap its contents or not */\n  @Input('matBadgeOverlap')\n  get overlap(): boolean {\n    return this._overlap;\n  }\n  set overlap(val: BooleanInput) {\n    this._overlap = coerceBooleanProperty(val);\n  }\n  private _overlap: boolean = true;\n\n  /**\n   * Position the badge should reside.\n   * Accepts any combination of 'above'|'below' and 'before'|'after'\n   */\n  @Input('matBadgePosition') position: MatBadgePosition = 'above after';\n\n  /** The content for the badge */\n  @Input('matBadge')\n  get content(): string | number | undefined | null {\n    return this._content;\n  }\n  set content(newContent: string | number | undefined | null) {\n    this._updateRenderedContent(newContent);\n  }\n  private _content: string | number | undefined | null;\n\n  /** Message used to describe the decorated element via aria-describedby */\n  @Input('matBadgeDescription')\n  get description(): string {\n    return this._description;\n  }\n  set description(newDescription: string) {\n    this._updateDescription(newDescription);\n  }\n  private _description: string;\n\n  /** Size of the badge. Can be 'small', 'medium', or 'large'. */\n  @Input('matBadgeSize') size: MatBadgeSize = 'medium';\n\n  /** Whether the badge is hidden. */\n  @Input('matBadgeHidden')\n  get hidden(): boolean {\n    return this._hidden;\n  }\n  set hidden(val: BooleanInput) {\n    this._hidden = coerceBooleanProperty(val);\n  }\n  private _hidden: boolean;\n\n  /** Unique id for the badge */\n  _id: number = nextId++;\n\n  /** Visible badge element. */\n  private _badgeElement: HTMLElement | undefined;\n\n  /** Inline badge description. Used when the badge is applied to non-interactive host elements. */\n  private _inlineBadgeDescription: HTMLElement | undefined;\n\n  /** Whether the OnInit lifecycle hook has run yet */\n  private _isInitialized = false;\n\n  /** InteractivityChecker to determine if the badge host is focusable. */\n  private _interactivityChecker = inject(InteractivityChecker);\n\n  private _document = inject(DOCUMENT);\n\n  constructor(\n    private _ngZone: NgZone,\n    private _elementRef: ElementRef<HTMLElement>,\n    private _ariaDescriber: AriaDescriber,\n    private _renderer: Renderer2,\n    @Optional() @Inject(ANIMATION_MODULE_TYPE) private _animationMode?: string,\n  ) {\n    super();\n\n    if (typeof ngDevMode === 'undefined' || ngDevMode) {\n      const nativeElement = _elementRef.nativeElement;\n      if (nativeElement.nodeType !== nativeElement.ELEMENT_NODE) {\n        throw Error('matBadge must be attached to an element node.');\n      }\n    }\n  }\n\n  /** Whether the badge is above the host or not */\n  isAbove(): boolean {\n    return this.position.indexOf('below') === -1;\n  }\n\n  /** Whether the badge is after the host or not */\n  isAfter(): boolean {\n    return this.position.indexOf('before') === -1;\n  }\n\n  /**\n   * Gets the element into which the badge's content is being rendered. Undefined if the element\n   * hasn't been created (e.g. if the badge doesn't have content).\n   */\n  getBadgeElement(): HTMLElement | undefined {\n    return this._badgeElement;\n  }\n\n  ngOnInit() {\n    // We may have server-side rendered badge that we need to clear.\n    // We need to do this in ngOnInit because the full content of the component\n    // on which the badge is attached won't necessarily be in the DOM until this point.\n    this._clearExistingBadges();\n\n    if (this.content && !this._badgeElement) {\n      this._badgeElement = this._createBadgeElement();\n      this._updateRenderedContent(this.content);\n    }\n\n    this._isInitialized = true;\n  }\n\n  ngOnDestroy() {\n    // ViewEngine only: when creating a badge through the Renderer, Angular remembers its index.\n    // We have to destroy it ourselves, otherwise it'll be retained in memory.\n    if (this._renderer.destroyNode) {\n      this._renderer.destroyNode(this._badgeElement);\n      this._inlineBadgeDescription?.remove();\n    }\n\n    this._ariaDescriber.removeDescription(this._elementRef.nativeElement, this.description);\n  }\n\n  /** Gets whether the badge's host element is interactive. */\n  private _isHostInteractive(): boolean {\n    // Ignore visibility since it requires an expensive style caluclation.\n    return this._interactivityChecker.isFocusable(this._elementRef.nativeElement, {\n      ignoreVisibility: true,\n    });\n  }\n\n  /** Creates the badge element */\n  private _createBadgeElement(): HTMLElement {\n    const badgeElement = this._renderer.createElement('span');\n    const activeClass = 'mat-badge-active';\n\n    badgeElement.setAttribute('id', `mat-badge-content-${this._id}`);\n\n    // The badge is aria-hidden because we don't want it to appear in the page's navigation\n    // flow. Instead, we use the badge to describe the decorated element with aria-describedby.\n    badgeElement.setAttribute('aria-hidden', 'true');\n    badgeElement.classList.add(BADGE_CONTENT_CLASS);\n\n    if (this._animationMode === 'NoopAnimations') {\n      badgeElement.classList.add('_mat-animation-noopable');\n    }\n\n    this._elementRef.nativeElement.appendChild(badgeElement);\n\n    // animate in after insertion\n    if (typeof requestAnimationFrame === 'function' && this._animationMode !== 'NoopAnimations') {\n      this._ngZone.runOutsideAngular(() => {\n        requestAnimationFrame(() => {\n          badgeElement.classList.add(activeClass);\n        });\n      });\n    } else {\n      badgeElement.classList.add(activeClass);\n    }\n\n    return badgeElement;\n  }\n\n  /** Update the text content of the badge element in the DOM, creating the element if necessary. */\n  private _updateRenderedContent(newContent: string | number | undefined | null): void {\n    const newContentNormalized: string = `${newContent ?? ''}`.trim();\n\n    // Don't create the badge element if the directive isn't initialized because we want to\n    // append the badge element to the *end* of the host element's content for backwards\n    // compatibility.\n    if (this._isInitialized && newContentNormalized && !this._badgeElement) {\n      this._badgeElement = this._createBadgeElement();\n    }\n\n    if (this._badgeElement) {\n      this._badgeElement.textContent = newContentNormalized;\n    }\n\n    this._content = newContentNormalized;\n  }\n\n  /** Updates the host element's aria description via AriaDescriber. */\n  private _updateDescription(newDescription: string): void {\n    // Always start by removing the aria-describedby; we will add a new one if necessary.\n    this._ariaDescriber.removeDescription(this._elementRef.nativeElement, this.description);\n\n    // NOTE: We only check whether the host is interactive here, which happens during\n    // when then badge content changes. It is possible that the host changes\n    // interactivity status separate from one of these. However, watching the interactivity\n    // status of the host would require a `MutationObserver`, which is likely more code + overhead\n    // than it's worth; from usages inside Google, we see that the vats majority of badges either\n    // never change interactivity, or also set `matBadgeHidden` based on the same condition.\n\n    if (!newDescription || this._isHostInteractive()) {\n      this._removeInlineDescription();\n    }\n\n    this._description = newDescription;\n\n    // We don't add `aria-describedby` for non-interactive hosts elements because we\n    // instead insert the description inline.\n    if (this._isHostInteractive()) {\n      this._ariaDescriber.describe(this._elementRef.nativeElement, newDescription);\n    } else {\n      this._updateInlineDescription();\n    }\n  }\n\n  private _updateInlineDescription() {\n    // Create the inline description element if it doesn't exist\n    if (!this._inlineBadgeDescription) {\n      this._inlineBadgeDescription = this._document.createElement('span');\n      this._inlineBadgeDescription.classList.add('cdk-visually-hidden');\n    }\n\n    this._inlineBadgeDescription.textContent = this.description;\n    this._badgeElement?.appendChild(this._inlineBadgeDescription);\n  }\n\n  private _removeInlineDescription() {\n    this._inlineBadgeDescription?.remove();\n    this._inlineBadgeDescription = undefined;\n  }\n\n  /** Adds css theme class given the color to the component host */\n  private _setColor(colorPalette: ThemePalette) {\n    const classList = this._elementRef.nativeElement.classList;\n    classList.remove(`mat-badge-${this._color}`);\n    if (colorPalette) {\n      classList.add(`mat-badge-${colorPalette}`);\n    }\n  }\n\n  /** Clears any existing badges that might be left over from server-side rendering. */\n  private _clearExistingBadges() {\n    // Only check direct children of this host element in order to avoid deleting\n    // any badges that might exist in descendant elements.\n    const badges = this._elementRef.nativeElement.querySelectorAll(\n      `:scope > .${BADGE_CONTENT_CLASS}`,\n    );\n    for (const badgeElement of Array.from(badges)) {\n      if (badgeElement !== this._badgeElement) {\n        badgeElement.remove();\n      }\n    }\n  }\n}\n"]}
|
|
286
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"badge.js","sourceRoot":"","sources":["../../../../../../src/material/badge/badge.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\n\nimport {AriaDescriber, InteractivityChecker} from '@angular/cdk/a11y';\nimport {BooleanInput, coerceBooleanProperty} from '@angular/cdk/coercion';\nimport {DOCUMENT} from '@angular/common';\nimport {\n  Directive,\n  ElementRef,\n  inject,\n  Inject,\n  Input,\n  NgZone,\n  OnDestroy,\n  OnInit,\n  Optional,\n  Renderer2,\n} from '@angular/core';\nimport {CanDisable, mixinDisabled, ThemePalette} from '@angular/material/core';\nimport {ANIMATION_MODULE_TYPE} from '@angular/platform-browser/animations';\n\nlet nextId = 0;\n\n// Boilerplate for applying mixins to MatBadge.\n/** @docs-private */\nconst _MatBadgeBase = mixinDisabled(class {});\n\n/** Allowed position options for matBadgePosition */\nexport type MatBadgePosition =\n  | 'above after'\n  | 'above before'\n  | 'below before'\n  | 'below after'\n  | 'before'\n  | 'after'\n  | 'above'\n  | 'below';\n\n/** Allowed size options for matBadgeSize */\nexport type MatBadgeSize = 'small' | 'medium' | 'large';\n\nconst BADGE_CONTENT_CLASS = 'mat-badge-content';\n\n/** Directive to display a text badge. */\n@Directive({\n  selector: '[matBadge]',\n  inputs: ['disabled: matBadgeDisabled'],\n  host: {\n    'class': 'mat-badge',\n    '[class.mat-badge-overlap]': 'overlap',\n    '[class.mat-badge-above]': 'isAbove()',\n    '[class.mat-badge-below]': '!isAbove()',\n    '[class.mat-badge-before]': '!isAfter()',\n    '[class.mat-badge-after]': 'isAfter()',\n    '[class.mat-badge-small]': 'size === \"small\"',\n    '[class.mat-badge-medium]': 'size === \"medium\"',\n    '[class.mat-badge-large]': 'size === \"large\"',\n    '[class.mat-badge-hidden]': 'hidden || !content',\n    '[class.mat-badge-disabled]': 'disabled',\n  },\n})\nexport class MatBadge extends _MatBadgeBase implements OnInit, OnDestroy, CanDisable {\n  /** The color of the badge. Can be `primary`, `accent`, or `warn`. */\n  @Input('matBadgeColor')\n  get color(): ThemePalette {\n    return this._color;\n  }\n  set color(value: ThemePalette) {\n    this._setColor(value);\n    this._color = value;\n  }\n  private _color: ThemePalette = 'primary';\n\n  /** Whether the badge should overlap its contents or not */\n  @Input('matBadgeOverlap')\n  get overlap(): boolean {\n    return this._overlap;\n  }\n  set overlap(val: BooleanInput) {\n    this._overlap = coerceBooleanProperty(val);\n  }\n  private _overlap: boolean = true;\n\n  /**\n   * Position the badge should reside.\n   * Accepts any combination of 'above'|'below' and 'before'|'after'\n   */\n  @Input('matBadgePosition') position: MatBadgePosition = 'above after';\n\n  /** The content for the badge */\n  @Input('matBadge')\n  get content(): string | number | undefined | null {\n    return this._content;\n  }\n  set content(newContent: string | number | undefined | null) {\n    this._updateRenderedContent(newContent);\n  }\n  private _content: string | number | undefined | null;\n\n  /** Message used to describe the decorated element via aria-describedby */\n  @Input('matBadgeDescription')\n  get description(): string {\n    return this._description;\n  }\n  set description(newDescription: string) {\n    this._updateDescription(newDescription);\n  }\n  private _description: string;\n\n  /** Size of the badge. Can be 'small', 'medium', or 'large'. */\n  @Input('matBadgeSize') size: MatBadgeSize = 'medium';\n\n  /** Whether the badge is hidden. */\n  @Input('matBadgeHidden')\n  get hidden(): boolean {\n    return this._hidden;\n  }\n  set hidden(val: BooleanInput) {\n    this._hidden = coerceBooleanProperty(val);\n  }\n  private _hidden: boolean;\n\n  /** Unique id for the badge */\n  _id: number = nextId++;\n\n  /** Visible badge element. */\n  private _badgeElement: HTMLElement | undefined;\n\n  /** Inline badge description. Used when the badge is applied to non-interactive host elements. */\n  private _inlineBadgeDescription: HTMLElement | undefined;\n\n  /** Whether the OnInit lifecycle hook has run yet */\n  private _isInitialized = false;\n\n  /** InteractivityChecker to determine if the badge host is focusable. */\n  private _interactivityChecker = inject(InteractivityChecker);\n\n  private _document = inject(DOCUMENT);\n\n  constructor(\n    private _ngZone: NgZone,\n    private _elementRef: ElementRef<HTMLElement>,\n    private _ariaDescriber: AriaDescriber,\n    private _renderer: Renderer2,\n    @Optional() @Inject(ANIMATION_MODULE_TYPE) private _animationMode?: string,\n  ) {\n    super();\n\n    if (typeof ngDevMode === 'undefined' || ngDevMode) {\n      const nativeElement = _elementRef.nativeElement;\n      if (nativeElement.nodeType !== nativeElement.ELEMENT_NODE) {\n        throw Error('matBadge must be attached to an element node.');\n      }\n\n      const matIconTagName: string = 'mat-icon';\n\n      // Heads-up for developers to avoid putting matBadge on <mat-icon>\n      // as it is aria-hidden by default docs mention this at:\n      // https://material.angular.io/components/badge/overview#accessibility\n      if (\n        nativeElement.tagName.toLowerCase() === matIconTagName &&\n        nativeElement.getAttribute('aria-hidden') === 'true'\n      ) {\n        console.warn(\n          `Detected a matBadge on an \"aria-hidden\" \"<mat-icon>\". ` +\n            `Consider setting aria-hidden=\"false\" in order to surface the information assistive technology.` +\n            `\\n${nativeElement.outerHTML}`,\n        );\n      }\n    }\n  }\n\n  /** Whether the badge is above the host or not */\n  isAbove(): boolean {\n    return this.position.indexOf('below') === -1;\n  }\n\n  /** Whether the badge is after the host or not */\n  isAfter(): boolean {\n    return this.position.indexOf('before') === -1;\n  }\n\n  /**\n   * Gets the element into which the badge's content is being rendered. Undefined if the element\n   * hasn't been created (e.g. if the badge doesn't have content).\n   */\n  getBadgeElement(): HTMLElement | undefined {\n    return this._badgeElement;\n  }\n\n  ngOnInit() {\n    // We may have server-side rendered badge that we need to clear.\n    // We need to do this in ngOnInit because the full content of the component\n    // on which the badge is attached won't necessarily be in the DOM until this point.\n    this._clearExistingBadges();\n\n    if (this.content && !this._badgeElement) {\n      this._badgeElement = this._createBadgeElement();\n      this._updateRenderedContent(this.content);\n    }\n\n    this._isInitialized = true;\n  }\n\n  ngOnDestroy() {\n    // ViewEngine only: when creating a badge through the Renderer, Angular remembers its index.\n    // We have to destroy it ourselves, otherwise it'll be retained in memory.\n    if (this._renderer.destroyNode) {\n      this._renderer.destroyNode(this._badgeElement);\n      this._inlineBadgeDescription?.remove();\n    }\n\n    this._ariaDescriber.removeDescription(this._elementRef.nativeElement, this.description);\n  }\n\n  /** Gets whether the badge's host element is interactive. */\n  private _isHostInteractive(): boolean {\n    // Ignore visibility since it requires an expensive style caluclation.\n    return this._interactivityChecker.isFocusable(this._elementRef.nativeElement, {\n      ignoreVisibility: true,\n    });\n  }\n\n  /** Creates the badge element */\n  private _createBadgeElement(): HTMLElement {\n    const badgeElement = this._renderer.createElement('span');\n    const activeClass = 'mat-badge-active';\n\n    badgeElement.setAttribute('id', `mat-badge-content-${this._id}`);\n\n    // The badge is aria-hidden because we don't want it to appear in the page's navigation\n    // flow. Instead, we use the badge to describe the decorated element with aria-describedby.\n    badgeElement.setAttribute('aria-hidden', 'true');\n    badgeElement.classList.add(BADGE_CONTENT_CLASS);\n\n    if (this._animationMode === 'NoopAnimations') {\n      badgeElement.classList.add('_mat-animation-noopable');\n    }\n\n    this._elementRef.nativeElement.appendChild(badgeElement);\n\n    // animate in after insertion\n    if (typeof requestAnimationFrame === 'function' && this._animationMode !== 'NoopAnimations') {\n      this._ngZone.runOutsideAngular(() => {\n        requestAnimationFrame(() => {\n          badgeElement.classList.add(activeClass);\n        });\n      });\n    } else {\n      badgeElement.classList.add(activeClass);\n    }\n\n    return badgeElement;\n  }\n\n  /** Update the text content of the badge element in the DOM, creating the element if necessary. */\n  private _updateRenderedContent(newContent: string | number | undefined | null): void {\n    const newContentNormalized: string = `${newContent ?? ''}`.trim();\n\n    // Don't create the badge element if the directive isn't initialized because we want to\n    // append the badge element to the *end* of the host element's content for backwards\n    // compatibility.\n    if (this._isInitialized && newContentNormalized && !this._badgeElement) {\n      this._badgeElement = this._createBadgeElement();\n    }\n\n    if (this._badgeElement) {\n      this._badgeElement.textContent = newContentNormalized;\n    }\n\n    this._content = newContentNormalized;\n  }\n\n  /** Updates the host element's aria description via AriaDescriber. */\n  private _updateDescription(newDescription: string): void {\n    // Always start by removing the aria-describedby; we will add a new one if necessary.\n    this._ariaDescriber.removeDescription(this._elementRef.nativeElement, this.description);\n\n    // NOTE: We only check whether the host is interactive here, which happens during\n    // when then badge content changes. It is possible that the host changes\n    // interactivity status separate from one of these. However, watching the interactivity\n    // status of the host would require a `MutationObserver`, which is likely more code + overhead\n    // than it's worth; from usages inside Google, we see that the vats majority of badges either\n    // never change interactivity, or also set `matBadgeHidden` based on the same condition.\n\n    if (!newDescription || this._isHostInteractive()) {\n      this._removeInlineDescription();\n    }\n\n    this._description = newDescription;\n\n    // We don't add `aria-describedby` for non-interactive hosts elements because we\n    // instead insert the description inline.\n    if (this._isHostInteractive()) {\n      this._ariaDescriber.describe(this._elementRef.nativeElement, newDescription);\n    } else {\n      this._updateInlineDescription();\n    }\n  }\n\n  private _updateInlineDescription() {\n    // Create the inline description element if it doesn't exist\n    if (!this._inlineBadgeDescription) {\n      this._inlineBadgeDescription = this._document.createElement('span');\n      this._inlineBadgeDescription.classList.add('cdk-visually-hidden');\n    }\n\n    this._inlineBadgeDescription.textContent = this.description;\n    this._badgeElement?.appendChild(this._inlineBadgeDescription);\n  }\n\n  private _removeInlineDescription() {\n    this._inlineBadgeDescription?.remove();\n    this._inlineBadgeDescription = undefined;\n  }\n\n  /** Adds css theme class given the color to the component host */\n  private _setColor(colorPalette: ThemePalette) {\n    const classList = this._elementRef.nativeElement.classList;\n    classList.remove(`mat-badge-${this._color}`);\n    if (colorPalette) {\n      classList.add(`mat-badge-${colorPalette}`);\n    }\n  }\n\n  /** Clears any existing badges that might be left over from server-side rendering. */\n  private _clearExistingBadges() {\n    // Only check direct children of this host element in order to avoid deleting\n    // any badges that might exist in descendant elements.\n    const badges = this._elementRef.nativeElement.querySelectorAll(\n      `:scope > .${BADGE_CONTENT_CLASS}`,\n    );\n    for (const badgeElement of Array.from(badges)) {\n      if (badgeElement !== this._badgeElement) {\n        badgeElement.remove();\n      }\n    }\n  }\n}\n"]}
|