@angular/material 18.1.0-next.4 → 18.1.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (118) hide show
  1. package/badge/index.d.ts +5 -2
  2. package/button/_button-base.scss +13 -6
  3. package/button/_button-theme.scss +26 -27
  4. package/button/_fab-theme.scss +16 -16
  5. package/button/_icon-button-theme.scss +14 -20
  6. package/button/index.d.ts +7 -0
  7. package/card/_card-theme.scss +25 -52
  8. package/checkbox/index.d.ts +4 -2
  9. package/chips/_chips-theme.scss +22 -24
  10. package/core/m2/_typography.scss +5 -2
  11. package/core/mdc-helpers/_mdc-helpers.scss +2 -2
  12. package/core/style/_elevation.scss +5 -0
  13. package/core/tokens/_token-utils.scss +2 -2
  14. package/core/tokens/m2/mat/_app.scss +1 -2
  15. package/core/tokens/m2/mat/_autocomplete.scss +2 -2
  16. package/core/tokens/m2/mat/_datepicker.scss +3 -3
  17. package/core/tokens/m2/mat/_dialog.scss +2 -2
  18. package/core/tokens/m2/mat/_fab-small.scss +3 -9
  19. package/core/tokens/m2/mat/_fab.scss +3 -9
  20. package/core/tokens/m2/mat/_filled-button.scss +3 -9
  21. package/core/tokens/m2/mat/_form-field.scss +9 -6
  22. package/core/tokens/m2/mat/_icon-button.scss +3 -9
  23. package/core/tokens/m2/mat/_outlined-button.scss +3 -9
  24. package/core/tokens/m2/mat/_paginator.scss +10 -6
  25. package/core/tokens/m2/mat/_protected-button.scss +3 -9
  26. package/core/tokens/m2/mat/_select.scss +2 -2
  27. package/core/tokens/m2/mat/_sidenav.scss +2 -2
  28. package/core/tokens/m2/mat/_text-button.scss +3 -9
  29. package/core/tokens/m2/mdc/_chip.scss +2 -14
  30. package/core/tokens/m2/mdc/_elevated-card.scss +3 -7
  31. package/core/tokens/m2/mdc/_extended-fab.scss +13 -10
  32. package/core/tokens/m2/mdc/_fab-small.scss +15 -13
  33. package/core/tokens/m2/mdc/_fab.scss +15 -13
  34. package/core/tokens/m2/mdc/_outlined-card.scss +2 -6
  35. package/core/tokens/m2/mdc/_protected-button.scss +13 -7
  36. package/core/tokens/m3/mat/_app.scss +2 -2
  37. package/core/tokens/m3/mat/_autocomplete.scss +2 -2
  38. package/core/tokens/m3/mat/_datepicker.scss +3 -3
  39. package/core/tokens/m3/mat/_select.scss +2 -2
  40. package/core/tokens/m3/mdc/_chip.scss +1 -4
  41. package/core/tokens/m3/mdc/_elevated-card.scss +9 -2
  42. package/core/tokens/m3/mdc/_extended-fab.scss +19 -2
  43. package/core/tokens/m3/mdc/_fab-small.scss +19 -2
  44. package/core/tokens/m3/mdc/_fab.scss +19 -2
  45. package/core/tokens/m3/mdc/_outlined-card.scss +9 -2
  46. package/core/tokens/m3/mdc/_protected-button.scss +22 -5
  47. package/datepicker/index.d.ts +13 -5
  48. package/esm2022/badge/badge.mjs +6 -3
  49. package/esm2022/button/button-base.mjs +3 -3
  50. package/esm2022/button/button.mjs +4 -4
  51. package/esm2022/button/fab.mjs +9 -9
  52. package/esm2022/button/icon-button.mjs +4 -4
  53. package/esm2022/card/card.mjs +2 -2
  54. package/esm2022/checkbox/checkbox-config.mjs +1 -1
  55. package/esm2022/chips/chip-grid.mjs +26 -8
  56. package/esm2022/chips/chip-listbox.mjs +2 -2
  57. package/esm2022/chips/chip-option.mjs +3 -3
  58. package/esm2022/chips/chip-row.mjs +3 -3
  59. package/esm2022/chips/chip-set.mjs +2 -2
  60. package/esm2022/chips/chip.mjs +3 -3
  61. package/esm2022/core/internal-form-field/internal-form-field.mjs +2 -2
  62. package/esm2022/core/ripple/ripple-renderer.mjs +21 -3
  63. package/esm2022/core/version.mjs +1 -1
  64. package/esm2022/datepicker/datepicker-base.mjs +6 -4
  65. package/esm2022/datepicker/datepicker-input-base.mjs +1 -1
  66. package/esm2022/dialog/dialog-container.mjs +3 -3
  67. package/esm2022/form-field/form-field.mjs +9 -18
  68. package/esm2022/list/action-list.mjs +2 -2
  69. package/esm2022/list/list-option.mjs +18 -4
  70. package/esm2022/list/list.mjs +10 -4
  71. package/esm2022/list/nav-list.mjs +2 -2
  72. package/esm2022/list/selection-list.mjs +2 -2
  73. package/esm2022/slide-toggle/slide-toggle.mjs +3 -3
  74. package/esm2022/tabs/tabs-animations.mjs +2 -2
  75. package/fesm2022/badge.mjs +5 -2
  76. package/fesm2022/badge.mjs.map +1 -1
  77. package/fesm2022/button.mjs +18 -18
  78. package/fesm2022/button.mjs.map +1 -1
  79. package/fesm2022/card.mjs +2 -2
  80. package/fesm2022/card.mjs.map +1 -1
  81. package/fesm2022/checkbox.mjs.map +1 -1
  82. package/fesm2022/chips.mjs +35 -17
  83. package/fesm2022/chips.mjs.map +1 -1
  84. package/fesm2022/core.mjs +23 -5
  85. package/fesm2022/core.mjs.map +1 -1
  86. package/fesm2022/datepicker.mjs +5 -3
  87. package/fesm2022/datepicker.mjs.map +1 -1
  88. package/fesm2022/dialog.mjs +2 -2
  89. package/fesm2022/dialog.mjs.map +1 -1
  90. package/fesm2022/form-field.mjs +8 -17
  91. package/fesm2022/form-field.mjs.map +1 -1
  92. package/fesm2022/list.mjs +32 -12
  93. package/fesm2022/list.mjs.map +1 -1
  94. package/fesm2022/slide-toggle.mjs +2 -2
  95. package/fesm2022/slide-toggle.mjs.map +1 -1
  96. package/fesm2022/tabs.mjs +1 -1
  97. package/fesm2022/tabs.mjs.map +1 -1
  98. package/form-field/_form-field-subscript.scss +2 -2
  99. package/form-field/_mdc-text-field-structure-overrides.scss +2 -3
  100. package/form-field/index.d.ts +9 -7
  101. package/list/_list-inherited-structure.scss +516 -0
  102. package/list/_list-item-hcm-indicator.scss +2 -3
  103. package/list/_list-theme.scss +17 -18
  104. package/list/index.d.ts +2 -0
  105. package/package.json +7 -7
  106. package/prebuilt-themes/azure-blue.css +1 -1
  107. package/prebuilt-themes/cyan-orange.css +1 -1
  108. package/prebuilt-themes/deeppurple-amber.css +1 -1
  109. package/prebuilt-themes/indigo-pink.css +1 -1
  110. package/prebuilt-themes/magenta-violet.css +1 -1
  111. package/prebuilt-themes/pink-bluegrey.css +1 -1
  112. package/prebuilt-themes/purple-green.css +1 -1
  113. package/prebuilt-themes/rose-red.css +1 -1
  114. package/schematics/ng-add/index.js +2 -2
  115. package/schematics/ng-add/index.mjs +2 -2
  116. package/schematics/ng-generate/m3-theme/index_bundled.js +2 -2
  117. package/schematics/ng-update/index_bundled.js +31 -31
  118. package/list/_list-option-trailing-avatar-compat.scss +0 -58
@@ -1,19 +1,18 @@
1
+ @use 'sass:map';
1
2
  @use '../../../theming/inspection';
3
+ @use '../../../style/elevation';
2
4
  @use '../../token-utils';
3
5
 
4
- @use 'sass:map';
5
-
6
6
  // The prefix used to generate the fully qualified name for tokens in this file.
7
7
  $prefix: (mdc, fab);
8
8
 
9
9
  @function get-unthemable-tokens() {
10
10
  @return (
11
11
  container-shape: 50%,
12
- icon-size: 24px,
13
-
14
- // We don't use this token, because it doesn't set the color of any text inside the FAB.
15
- // We create a custom token for it instead.
16
- icon-color: null,
12
+ container-elevation-shadow: elevation.get-box-shadow(6),
13
+ focus-container-elevation-shadow: elevation.get-box-shadow(8),
14
+ hover-container-elevation-shadow: elevation.get-box-shadow(8),
15
+ pressed-container-elevation-shadow: elevation.get-box-shadow(12),
17
16
 
18
17
  // =============================================================================================
19
18
  // = TOKENS NOT USED IN ANGULAR MATERIAL =
@@ -21,6 +20,8 @@ $prefix: (mdc, fab);
21
20
  container-height: null,
22
21
  container-surface-tint-layer-color: null,
23
22
  container-width: null,
23
+ icon-size: null,
24
+ icon-color: null,
24
25
 
25
26
  focus-icon-color: null,
26
27
  focus-outline-color: null,
@@ -41,7 +42,13 @@ $prefix: (mdc, fab);
41
42
  pressed-ripple-color: null,
42
43
  pressed-ripple-opacity: null,
43
44
  pressed-state-layer-color: null,
44
- pressed-state-layer-opacity: null
45
+ pressed-state-layer-opacity: null,
46
+
47
+ container-elevation: null,
48
+ focus-container-elevation: null,
49
+ hover-container-elevation: null,
50
+ pressed-container-elevation: null,
51
+ container-shadow-color: null,
45
52
  );
46
53
  }
47
54
 
@@ -50,11 +57,6 @@ $prefix: (mdc, fab);
50
57
  @return (
51
58
  // Background color of the FAB.
52
59
  container-color: inspection.get-theme-color($theme, background, card),
53
- container-elevation: 6,
54
- focus-container-elevation: 8,
55
- hover-container-elevation: 8,
56
- pressed-container-elevation: 12,
57
- container-shadow-color: #000,
58
60
  );
59
61
  }
60
62
 
@@ -41,6 +41,7 @@ $prefix: (mdc, outlined-card);
41
41
  pressed-outline-color: null,
42
42
  pressed-state-layer-color: null,
43
43
  pressed-state-layer-opacity: null,
44
+ container-shadow-color: null,
44
45
  // Angular Material does not currently support surface tint.
45
46
  container-surface-tint-layer-color: null,
46
47
  // MDC does not seem to use these tokens.
@@ -58,12 +59,7 @@ $prefix: (mdc, outlined-card);
58
59
  container-color: inspection.get-theme-color($theme, background, card),
59
60
  // The border color of the card.
60
61
  outline-color: rgba(inspection.get-theme-color($theme, foreground, base), 0.12),
61
- // The elevation level of the card.
62
- // (Part of the color tokens because it needs to be combined with the shadow color to generate
63
- // the final box-shadow).
64
- container-elevation: 0,
65
- // The color of the card's shadow.
66
- container-shadow-color: if($elevation != null, $elevation, elevation.$color),
62
+ container-elevation: elevation.get-box-shadow(0),
67
63
  );
68
64
  }
69
65
 
@@ -1,6 +1,7 @@
1
1
  @use 'sass:map';
2
2
  @use '../../token-utils';
3
3
  @use '../../../style/sass-utils';
4
+ @use '../../../style/elevation';
4
5
  @use '../../../theming/inspection';
5
6
  @use '../../../theming/theming';
6
7
  @use '../../../mdc-helpers/mdc-helpers';
@@ -17,7 +18,11 @@ $prefix: (mdc, protected-button);
17
18
  @function get-unthemable-tokens() {
18
19
  @return (
19
20
  container-shape: 4px,
20
- keep-touch-target: false,
21
+ container-elevation-shadow: elevation.get-box-shadow(2),
22
+ disabled-container-elevation-shadow: elevation.get-box-shadow(0),
23
+ focus-container-elevation-shadow: elevation.get-box-shadow(4),
24
+ hover-container-elevation-shadow: elevation.get-box-shadow(4),
25
+ pressed-container-elevation-shadow: elevation.get-box-shadow(8),
21
26
 
22
27
  // =============================================================================================
23
28
  // = TOKENS NOT USED IN ANGULAR MATERIAL =
@@ -39,6 +44,13 @@ $prefix: (mdc, protected-button);
39
44
  focus-state-layer-color: null,
40
45
  hover-state-layer-color: null,
41
46
  pressed-state-layer-color: null,
47
+ keep-touch-target: null,
48
+ container-elevation: null,
49
+ disabled-container-elevation: null,
50
+ focus-container-elevation: null,
51
+ hover-container-elevation: null,
52
+ pressed-container-elevation: null,
53
+ container-shadow-color: null,
42
54
  );
43
55
  }
44
56
 
@@ -53,12 +65,6 @@ $prefix: (mdc, protected-button);
53
65
  0.12),
54
66
  disabled-label-text-color: inspection.get-theme-color($theme, foreground, disabled-button,
55
67
  if($is-dark, 0.5, 0.38)),
56
- container-elevation: 2,
57
- disabled-container-elevation: 0,
58
- focus-container-elevation: 4,
59
- hover-container-elevation: 4,
60
- pressed-container-elevation: 8,
61
- container-shadow-color: #000,
62
68
  );
63
69
  }
64
70
 
@@ -1,5 +1,5 @@
1
1
  @use 'sass:map';
2
- @use '@material/elevation' as mdc-elevation;
2
+ @use '../../../style/elevation';
3
3
  @use '../../token-utils';
4
4
 
5
5
  // The prefix used to generate the fully qualified name for tokens in this file.
@@ -19,7 +19,7 @@ $prefix: (mat, app);
19
19
 
20
20
  @if ($shadow-color) {
21
21
  @for $zValue from 0 through 24 {
22
- $shadow: mdc-elevation.elevation-box-shadow($zValue, $shadow-color);
22
+ $shadow: elevation.get-box-shadow($zValue, $shadow-color);
23
23
  $tokens: map.set($tokens, 'elevation-shadow-level-#{$zValue}', $shadow);
24
24
  }
25
25
  }
@@ -1,5 +1,5 @@
1
1
  @use 'sass:map';
2
- @use '@material/elevation/elevation-theme' as mdc-elevation;
2
+ @use '../../../style/elevation';
3
3
  @use '../../token-utils';
4
4
 
5
5
  // The prefix used to generate the fully qualified name for tokens in this file.
@@ -15,7 +15,7 @@ $prefix: (mat, autocomplete);
15
15
  background-color: map.get($systems, md-sys-color, surface-container),
16
16
  container-shape: map.get($systems, md-sys-shape, corner-extra-small),
17
17
  container-elevation-shadow:
18
- token-utils.hardcode(mdc-elevation.elevation-box-shadow(2), $exclude-hardcoded),
18
+ token-utils.hardcode(elevation.get-box-shadow(2), $exclude-hardcoded),
19
19
  );
20
20
 
21
21
  @return token-utils.namespace-tokens($prefix, $tokens, $token-slots);
@@ -1,7 +1,7 @@
1
1
  @use 'sass:map';
2
+ @use '../../../style/elevation';
2
3
  @use '../../../style/sass-utils';
3
4
  @use '../../token-utils';
4
- @use '@material/elevation' as mdc-elevation;
5
5
 
6
6
  // The prefix used to generate the fully qualified name for tokens in this file.
7
7
  $prefix: (mat, datepicker);
@@ -67,10 +67,10 @@ $prefix: (mat, datepicker);
67
67
  ),
68
68
  calendar-container-background-color: map.get($systems, md-sys-color, surface-container-high),
69
69
  calendar-container-text-color: map.get($systems, md-sys-color, on-surface),
70
- calendar-container-elevation-shadow: token-utils.hardcode(mdc-elevation.elevation-box-shadow(0),
70
+ calendar-container-elevation-shadow: token-utils.hardcode(elevation.get-box-shadow(0),
71
71
  $exclude-hardcoded),
72
72
  calendar-container-touch-elevation-shadow:
73
- token-utils.hardcode(mdc-elevation.elevation-box-shadow(0), $exclude-hardcoded),
73
+ token-utils.hardcode(elevation.get-box-shadow(0), $exclude-hardcoded),
74
74
  calendar-container-shape: map.get($systems, md-sys-shape, corner-large),
75
75
  calendar-container-touch-shape: map.get($systems, md-sys-shape, corner-extra-large),
76
76
  calendar-text-font: map.get($systems, md-sys-typescale, body-large-font),
@@ -1,7 +1,7 @@
1
1
  @use 'sass:map';
2
2
  @use '../../../style/sass-utils';
3
+ @use '../../../style/elevation';
3
4
  @use '../../token-utils';
4
- @use '@material/elevation' as mdc-elevation;
5
5
 
6
6
  // The prefix used to generate the fully qualified name for tokens in this file.
7
7
  $prefix: (mat, select);
@@ -26,7 +26,7 @@ $prefix: (mat, select);
26
26
  focused-arrow-color: map.get($systems, md-sys-color, primary),
27
27
  invalid-arrow-color: map.get($systems, md-sys-color, error),
28
28
  container-elevation-shadow:
29
- token-utils.hardcode(mdc-elevation.elevation-box-shadow(2), $exclude-hardcoded),
29
+ token-utils.hardcode(elevation.get-box-shadow(2), $exclude-hardcoded),
30
30
  )
31
31
  ), (
32
32
  // Color variants:
@@ -16,10 +16,7 @@ $prefix: (mdc, chip);
16
16
  $tokens: sass-utils.merge-all(
17
17
  token-utils.generate-typography-tokens($systems, label-text, label-large),
18
18
  (
19
- container-shape: token-utils.hardcode((
20
- family: rounded,
21
- radius: 8px,
22
- ), $exclude-hardcoded),
19
+ container-shape-radius: token-utils.hardcode(8px, $exclude-hardcoded),
23
20
  with-avatar-avatar-size: token-utils.hardcode(24px, $exclude-hardcoded),
24
21
  label-text-color: map.get($systems, md-sys-color, on-surface-variant),
25
22
  disabled-label-text-color: sass-utils.safe-color-change(
@@ -1,3 +1,5 @@
1
+ @use 'sass:map';
2
+ @use '../../../style/elevation';
1
3
  @use '../../token-utils';
2
4
 
3
5
  // The prefix used to generate the fully qualified name for tokens in this file.
@@ -9,7 +11,12 @@ $prefix: (mdc, elevated-card);
9
11
  /// @param {Map} $token-slots Possible token slots
10
12
  /// @return {Map} A set of tokens for the MDC elevated-card
11
13
  @function get-tokens($systems, $exclude-hardcoded, $token-slots) {
12
- $mdc-tokens: token-utils.get-mdc-tokens('elevated-card', $systems, $exclude-hardcoded);
14
+ $tokens: token-utils.get-mdc-tokens('elevated-card', $systems, $exclude-hardcoded);
15
+ $elevation: map.get($tokens, container-elevation);
13
16
 
14
- @return token-utils.namespace-tokens($prefix, $mdc-tokens, $token-slots);
17
+ @if ($elevation != null) {
18
+ $tokens: map.set($tokens, container-elevation, elevation.get-box-shadow($elevation));
19
+ }
20
+
21
+ @return token-utils.namespace-tokens($prefix, $tokens, $token-slots);
15
22
  }
@@ -1,3 +1,5 @@
1
+ @use 'sass:map';
2
+ @use '../../../style/elevation';
1
3
  @use '../../token-utils';
2
4
 
3
5
  // The prefix used to generate the fully qualified name for tokens in this file.
@@ -9,7 +11,22 @@ $prefix: (mdc, extended-fab);
9
11
  /// @param {Map} $token-slots Possible token slots
10
12
  /// @return {Map} A set of tokens for the MDC extended-fab
11
13
  @function get-tokens($systems, $exclude-hardcoded, $token-slots) {
12
- $mdc-tokens: token-utils.get-mdc-tokens('extended-fab-primary', $systems, $exclude-hardcoded);
14
+ $tokens: token-utils.get-mdc-tokens('extended-fab-primary', $systems, $exclude-hardcoded);
15
+ $elevation-tokens: (
16
+ container-elevation,
17
+ focus-container-elevation,
18
+ hover-container-elevation,
19
+ pressed-container-elevation,
20
+ );
21
+
22
+ @each $token in $elevation-tokens {
23
+ $elevation: map.get($tokens, $token);
24
+
25
+ @if ($elevation != null) {
26
+ $tokens: map.set($tokens, $token + '-shadow', elevation.get-box-shadow($elevation));
27
+ }
28
+ }
29
+
13
30
  $variant-tokens: (
14
31
  // Color variants
15
32
  primary: (), // Default, no overrides needed.
@@ -17,5 +34,5 @@ $prefix: (mdc, extended-fab);
17
34
  tertiary: token-utils.get-mdc-tokens('extended-fab-tertiary', $systems, $exclude-hardcoded)
18
35
  );
19
36
 
20
- @return token-utils.namespace-tokens($prefix, ($mdc-tokens, $variant-tokens), $token-slots);
37
+ @return token-utils.namespace-tokens($prefix, ($tokens, $variant-tokens), $token-slots);
21
38
  }
@@ -1,3 +1,5 @@
1
+ @use 'sass:map';
2
+ @use '../../../style/elevation';
1
3
  @use '../../token-utils';
2
4
 
3
5
  // The prefix used to generate the fully qualified name for tokens in this file.
@@ -9,7 +11,22 @@ $prefix: (mdc, fab-small);
9
11
  /// @param {Map} $token-slots Possible token slots
10
12
  /// @return {Map} A set of tokens for the MDC fab-small
11
13
  @function get-tokens($systems, $exclude-hardcoded, $token-slots) {
12
- $mdc-tokens: token-utils.get-mdc-tokens('fab-primary-small', $systems, $exclude-hardcoded);
14
+ $tokens: token-utils.get-mdc-tokens('fab-primary-small', $systems, $exclude-hardcoded);
15
+ $elevation-tokens: (
16
+ container-elevation,
17
+ focus-container-elevation,
18
+ hover-container-elevation,
19
+ pressed-container-elevation,
20
+ );
21
+
22
+ @each $token in $elevation-tokens {
23
+ $elevation: map.get($tokens, $token);
24
+
25
+ @if ($elevation != null) {
26
+ $tokens: map.set($tokens, $token + '-shadow', elevation.get-box-shadow($elevation));
27
+ }
28
+ }
29
+
13
30
  $variant-tokens: (
14
31
  // Color variants
15
32
  primary: (), // Default, no overrides needed.
@@ -17,5 +34,5 @@ $prefix: (mdc, fab-small);
17
34
  tertiary: token-utils.get-mdc-tokens('fab-tertiary-small', $systems, $exclude-hardcoded)
18
35
  );
19
36
 
20
- @return token-utils.namespace-tokens($prefix, ($mdc-tokens, $variant-tokens), $token-slots);
37
+ @return token-utils.namespace-tokens($prefix, ($tokens, $variant-tokens), $token-slots);
21
38
  }
@@ -1,3 +1,5 @@
1
+ @use 'sass:map';
2
+ @use '../../../style/elevation';
1
3
  @use '../../token-utils';
2
4
 
3
5
  // The prefix used to generate the fully qualified name for tokens in this file.
@@ -9,7 +11,22 @@ $prefix: (mdc, fab);
9
11
  /// @param {Map} $token-slots Possible token slots
10
12
  /// @return {Map} A set of tokens for the MDC fab
11
13
  @function get-tokens($systems, $exclude-hardcoded, $token-slots) {
12
- $mdc-tokens: token-utils.get-mdc-tokens('fab-primary', $systems, $exclude-hardcoded);
14
+ $tokens: token-utils.get-mdc-tokens('fab-primary', $systems, $exclude-hardcoded);
15
+ $elevation-tokens: (
16
+ container-elevation,
17
+ focus-container-elevation,
18
+ hover-container-elevation,
19
+ pressed-container-elevation,
20
+ );
21
+
22
+ @each $token in $elevation-tokens {
23
+ $elevation: map.get($tokens, $token);
24
+
25
+ @if ($elevation != null) {
26
+ $tokens: map.set($tokens, $token + '-shadow', elevation.get-box-shadow($elevation));
27
+ }
28
+ }
29
+
13
30
  $variant-tokens: (
14
31
  // Color variants
15
32
  primary: (), // Default, no overrides needed.
@@ -17,5 +34,5 @@ $prefix: (mdc, fab);
17
34
  tertiary: token-utils.get-mdc-tokens('fab-tertiary', $systems, $exclude-hardcoded)
18
35
  );
19
36
 
20
- @return token-utils.namespace-tokens($prefix, ($mdc-tokens, $variant-tokens), $token-slots);
37
+ @return token-utils.namespace-tokens($prefix, ($tokens, $variant-tokens), $token-slots);
21
38
  }
@@ -1,3 +1,5 @@
1
+ @use 'sass:map';
2
+ @use '../../../style/elevation';
1
3
  @use '../../token-utils';
2
4
 
3
5
  // The prefix used to generate the fully qualified name for tokens in this file.
@@ -9,7 +11,12 @@ $prefix: (mdc, outlined-card);
9
11
  /// @param {Map} $token-slots Possible token slots
10
12
  /// @return {Map} A set of tokens for the MDC outlined-card
11
13
  @function get-tokens($systems, $exclude-hardcoded, $token-slots) {
12
- $mdc-tokens: token-utils.get-mdc-tokens('outlined-card', $systems, $exclude-hardcoded);
14
+ $tokens: token-utils.get-mdc-tokens('outlined-card', $systems, $exclude-hardcoded);
15
+ $elevation: map.get($tokens, container-elevation);
13
16
 
14
- @return token-utils.namespace-tokens($prefix, $mdc-tokens, $token-slots);
17
+ @if ($elevation != null) {
18
+ $tokens: map.set($tokens, container-elevation, elevation.get-box-shadow($elevation));
19
+ }
20
+
21
+ @return token-utils.namespace-tokens($prefix, $tokens, $token-slots);
15
22
  }
@@ -1,5 +1,6 @@
1
1
  @use 'sass:map';
2
2
  @use 'sass:meta';
3
+ @use '../../../style/elevation';
3
4
  @use '../../token-utils';
4
5
 
5
6
  // The prefix used to generate the fully qualified name for tokens in this file.
@@ -12,7 +13,7 @@ $prefix: (mdc, protected-button);
12
13
  /// @return {Map} A set of tokens for the MDC protected-button
13
14
  @function get-tokens($systems, $exclude-hardcoded, $token-slots) {
14
15
  // Note: in M3 the "protected" button is called "elevated".
15
- $mdc-tokens: token-utils.get-mdc-tokens('elevated-button', $systems, $exclude-hardcoded);
16
+ $tokens: token-utils.get-mdc-tokens('elevated-button', $systems, $exclude-hardcoded);
16
17
  $variant-tokens: (
17
18
  primary: (), // Default, no overrides needed.
18
19
  secondary: (
@@ -57,7 +58,7 @@ $prefix: (mdc, protected-button);
57
58
  );
58
59
 
59
60
  @return token-utils.namespace-tokens($prefix, (
60
- _fix-tokens($mdc-tokens),
61
+ _fix-tokens($tokens),
61
62
  token-utils.map-values($variant-tokens, meta.get-function(_fix-tokens)),
62
63
  ), $token-slots);
63
64
  }
@@ -67,11 +68,27 @@ $prefix: (mdc, protected-button);
67
68
  /// @param {Map} $initial-tokens Map of protected button tokens currently being generated.
68
69
  /// @return {Map} The given tokens, with the invalid values replaced with valid ones.
69
70
  @function _fix-tokens($initial-tokens) {
70
- // Need to get the hardcoded values, because they include opacities that are used for the disabled
71
- // state.
71
+ // Need to get the hardcoded values, because they include
72
+ // opacities that are used for the disabled state.
72
73
  $hardcoded-tokens: token-utils.get-mdc-tokens('elevated-button', (), false);
74
+ $tokens: $initial-tokens;
75
+ $elevation-tokens: (
76
+ container-elevation,
77
+ disabled-container-elevation,
78
+ focus-container-elevation,
79
+ hover-container-elevation,
80
+ pressed-container-elevation,
81
+ );
82
+
83
+ @each $token in $elevation-tokens {
84
+ $elevation: map.get($tokens, $token);
85
+
86
+ @if ($elevation != null) {
87
+ $tokens: map.set($tokens, $token + '-shadow', elevation.get-box-shadow($elevation));
88
+ }
89
+ }
73
90
 
74
- @return token-utils.combine-color-tokens($initial-tokens, $hardcoded-tokens, (
91
+ @return token-utils.combine-color-tokens($tokens, $hardcoded-tokens, (
75
92
  (
76
93
  color: disabled-label-text-color,
77
94
  opacity: disabled-label-text-opacity,
@@ -52,7 +52,11 @@ import { ValidatorFn } from '@angular/forms';
52
52
  import { ViewContainerRef } from '@angular/core';
53
53
  import { WritableSignal } from '@angular/core';
54
54
 
55
- /** Function that can be used to filter out dates from a calendar. */
55
+ /**
56
+ * Function that can be used to filter out dates from a calendar.
57
+ * Datepicker can sometimes receive a null value as input for the date argument.
58
+ * This doesn't represent a "null date" but rather signifies that no date has been selected yet in the calendar.
59
+ */
56
60
  export declare type DateFilterFn<D> = (date: D | null) => boolean;
57
61
 
58
62
  /** Possible positions for the datepicker dropdown along the X axis. */
@@ -699,9 +703,11 @@ declare abstract class MatDatepickerBase<C extends MatDatepickerControl<D>, S, D
699
703
  /** The view that the calendar should start in. */
700
704
  startView: 'month' | 'year' | 'multi-year';
701
705
  /**
702
- * Color palette to use on the datepicker's calendar. This API is supported in M2 themes only, it
703
- * has no effect in M3 themes. For information on applying color variants in M3, see
704
- * https://material.angular.io/guide/theming#using-component-color-variants
706
+ * Theme color of the datepicker's calendar. This API is supported in M2 themes only, it
707
+ * has no effect in M3 themes.
708
+ *
709
+ * For information on applying color variants in M3, see
710
+ * https://material.angular.io/guide/theming#using-component-color-variants.
705
711
  */
706
712
  get color(): ThemePalette;
707
713
  set color(value: ThemePalette);
@@ -1162,7 +1168,9 @@ export declare interface MatDatepickerPanel<C extends MatDatepickerControl<D>, S
1162
1168
  closedStream: EventEmitter<void>;
1163
1169
  /**
1164
1170
  * Color palette to use on the datepicker's calendar. This API is supported in M2 themes only, it
1165
- * has no effect in M3 themes. For information on applying color variants in M3, see
1171
+ * has no effect in M3 themes.
1172
+ *
1173
+ * For information on applying color variants in M3, see
1166
1174
  * https://material.angular.io/guide/theming#using-component-color-variants
1167
1175
  */
1168
1176
  color: ThemePalette;
@@ -29,8 +29,11 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.0-next.3",
29
29
  /** Directive to display a text badge. */
30
30
  export class MatBadge {
31
31
  /**
32
- * The color of the badge. Can be `primary`, `accent`, or `warn`.
33
- * Not recommended in M3, for more information see https://material.angular.io/guide/material-2-theming#optional-add-backwards-compatibility-styles-for-color-variants.
32
+ * Theme color of the badge. This API is supported in M2 themes only, it
33
+ * has no effect in M3 themes.
34
+ *
35
+ * For information on applying color variants in M3, see
36
+ * https://material.angular.io/guide/theming#using-component-color-variants.
34
37
  */
35
38
  get color() {
36
39
  return this._color;
@@ -295,4 +298,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.0-next.3",
295
298
  type: Input,
296
299
  args: [{ alias: 'matBadgeHidden', transform: booleanAttribute }]
297
300
  }] } });
298
- //# 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 {DOCUMENT} from '@angular/common';\nimport {\n  ApplicationRef,\n  booleanAttribute,\n  ChangeDetectionStrategy,\n  Component,\n  createComponent,\n  Directive,\n  ElementRef,\n  EnvironmentInjector,\n  inject,\n  Inject,\n  Input,\n  NgZone,\n  OnDestroy,\n  OnInit,\n  Optional,\n  Renderer2,\n  ViewEncapsulation,\n  ANIMATION_MODULE_TYPE,\n} from '@angular/core';\nimport {ThemePalette} from '@angular/material/core';\n\nlet nextId = 0;\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/** Keeps track of the apps currently containing badges. */\nconst badgeApps = new Set<ApplicationRef>();\n\n/**\n * Component used to load the structural styles of the badge.\n * @docs-private\n */\n@Component({\n  standalone: true,\n  styleUrl: 'badge.css',\n  encapsulation: ViewEncapsulation.None,\n  template: '',\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class _MatBadgeStyleLoader {}\n\n/** Directive to display a text badge. */\n@Directive({\n  selector: '[matBadge]',\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  standalone: true,\n})\nexport class MatBadge implements OnInit, OnDestroy {\n  /**\n   * The color of the badge. Can be `primary`, `accent`, or `warn`.\n   * Not recommended in M3, for more information see https://material.angular.io/guide/material-2-theming#optional-add-backwards-compatibility-styles-for-color-variants.\n   */\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({alias: 'matBadgeOverlap', transform: booleanAttribute}) overlap: boolean = true;\n\n  /** Whether the badge is disabled. */\n  @Input({alias: 'matBadgeDisabled', transform: booleanAttribute}) disabled: boolean;\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({alias: 'matBadgeHidden', transform: booleanAttribute}) 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    const appRef = inject(ApplicationRef);\n\n    if (!badgeApps.has(appRef)) {\n      badgeApps.add(appRef);\n\n      const componentRef = createComponent(_MatBadgeStyleLoader, {\n        environmentInjector: inject(EnvironmentInjector),\n      });\n\n      appRef.onDestroy(() => {\n        badgeApps.delete(appRef);\n        if (badgeApps.size === 0) {\n          componentRef.destroy();\n        }\n      });\n    }\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"]}
301
+ //# 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 {DOCUMENT} from '@angular/common';\nimport {\n  ApplicationRef,\n  booleanAttribute,\n  ChangeDetectionStrategy,\n  Component,\n  createComponent,\n  Directive,\n  ElementRef,\n  EnvironmentInjector,\n  inject,\n  Inject,\n  Input,\n  NgZone,\n  OnDestroy,\n  OnInit,\n  Optional,\n  Renderer2,\n  ViewEncapsulation,\n  ANIMATION_MODULE_TYPE,\n} from '@angular/core';\nimport {ThemePalette} from '@angular/material/core';\n\nlet nextId = 0;\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/** Keeps track of the apps currently containing badges. */\nconst badgeApps = new Set<ApplicationRef>();\n\n/**\n * Component used to load the structural styles of the badge.\n * @docs-private\n */\n@Component({\n  standalone: true,\n  styleUrl: 'badge.css',\n  encapsulation: ViewEncapsulation.None,\n  template: '',\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class _MatBadgeStyleLoader {}\n\n/** Directive to display a text badge. */\n@Directive({\n  selector: '[matBadge]',\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  standalone: true,\n})\nexport class MatBadge implements OnInit, OnDestroy {\n  /**\n   * Theme color of the badge. This API is supported in M2 themes only, it\n   * has no effect in M3 themes.\n   *\n   * For information on applying color variants in M3, see\n   * https://material.angular.io/guide/theming#using-component-color-variants.\n   */\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({alias: 'matBadgeOverlap', transform: booleanAttribute}) overlap: boolean = true;\n\n  /** Whether the badge is disabled. */\n  @Input({alias: 'matBadgeDisabled', transform: booleanAttribute}) disabled: boolean;\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({alias: 'matBadgeHidden', transform: booleanAttribute}) 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    const appRef = inject(ApplicationRef);\n\n    if (!badgeApps.has(appRef)) {\n      badgeApps.add(appRef);\n\n      const componentRef = createComponent(_MatBadgeStyleLoader, {\n        environmentInjector: inject(EnvironmentInjector),\n      });\n\n      appRef.onDestroy(() => {\n        badgeApps.delete(appRef);\n        if (badgeApps.size === 0) {\n          componentRef.destroy();\n        }\n      });\n    }\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"]}