@angular/material 15.0.0-next.3 → 15.0.0-next.5

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 (101) hide show
  1. package/button/_button-theme-private.scss +5 -2
  2. package/button/index.d.ts +5 -1
  3. package/button/testing/index.d.ts +8 -0
  4. package/chips/index.d.ts +13 -1
  5. package/core/_core.scss +1 -2
  6. package/core/mdc-helpers/_mdc-helpers.scss +8 -6
  7. package/core/typography/_all-typography.scss +73 -81
  8. package/datepicker/index.d.ts +10 -2
  9. package/esm2020/button/button-base.mjs +17 -3
  10. package/esm2020/button/button.mjs +4 -4
  11. package/esm2020/button/testing/button-harness-filters.mjs +1 -1
  12. package/esm2020/button/testing/button-harness.mjs +28 -2
  13. package/esm2020/checkbox/checkbox.mjs +2 -2
  14. package/esm2020/chips/chip-option.mjs +17 -7
  15. package/esm2020/core/version.mjs +1 -1
  16. package/esm2020/datepicker/datepicker-intl.mjs +11 -3
  17. package/esm2020/icon/icon.mjs +3 -2
  18. package/esm2020/legacy-button/testing/button-harness.mjs +27 -2
  19. package/esm2020/legacy-button/testing/public-api.mjs +1 -1
  20. package/esm2020/list/action-list.mjs +2 -2
  21. package/esm2020/list/list-base.mjs +5 -2
  22. package/esm2020/list/list-option.mjs +2 -2
  23. package/esm2020/list/list.mjs +12 -4
  24. package/esm2020/list/nav-list.mjs +2 -2
  25. package/esm2020/list/selection-list.mjs +36 -6
  26. package/esm2020/slider/slider.mjs +3 -3
  27. package/esm2020/table/table.mjs +2 -2
  28. package/esm2020/tooltip/tooltip.mjs +25 -14
  29. package/fesm2015/button/testing.mjs +29 -1
  30. package/fesm2015/button/testing.mjs.map +1 -1
  31. package/fesm2015/button.mjs +27 -6
  32. package/fesm2015/button.mjs.map +1 -1
  33. package/fesm2015/checkbox.mjs +2 -2
  34. package/fesm2015/checkbox.mjs.map +1 -1
  35. package/fesm2015/chips.mjs +16 -6
  36. package/fesm2015/chips.mjs.map +1 -1
  37. package/fesm2015/core.mjs +1 -1
  38. package/fesm2015/core.mjs.map +1 -1
  39. package/fesm2015/datepicker.mjs +10 -2
  40. package/fesm2015/datepicker.mjs.map +1 -1
  41. package/fesm2015/icon.mjs +2 -1
  42. package/fesm2015/icon.mjs.map +1 -1
  43. package/fesm2015/legacy-button/testing.mjs +28 -1
  44. package/fesm2015/legacy-button/testing.mjs.map +1 -1
  45. package/fesm2015/list.mjs +57 -15
  46. package/fesm2015/list.mjs.map +1 -1
  47. package/fesm2015/slider.mjs +2 -2
  48. package/fesm2015/slider.mjs.map +1 -1
  49. package/fesm2015/table.mjs +2 -2
  50. package/fesm2015/table.mjs.map +1 -1
  51. package/fesm2015/tooltip.mjs +24 -13
  52. package/fesm2015/tooltip.mjs.map +1 -1
  53. package/fesm2020/button/testing.mjs +27 -1
  54. package/fesm2020/button/testing.mjs.map +1 -1
  55. package/fesm2020/button.mjs +20 -6
  56. package/fesm2020/button.mjs.map +1 -1
  57. package/fesm2020/checkbox.mjs +2 -2
  58. package/fesm2020/checkbox.mjs.map +1 -1
  59. package/fesm2020/chips.mjs +16 -6
  60. package/fesm2020/chips.mjs.map +1 -1
  61. package/fesm2020/core.mjs +1 -1
  62. package/fesm2020/core.mjs.map +1 -1
  63. package/fesm2020/datepicker.mjs +10 -2
  64. package/fesm2020/datepicker.mjs.map +1 -1
  65. package/fesm2020/icon.mjs +2 -1
  66. package/fesm2020/icon.mjs.map +1 -1
  67. package/fesm2020/legacy-button/testing.mjs +26 -1
  68. package/fesm2020/legacy-button/testing.mjs.map +1 -1
  69. package/fesm2020/list.mjs +56 -15
  70. package/fesm2020/list.mjs.map +1 -1
  71. package/fesm2020/slider.mjs +2 -2
  72. package/fesm2020/slider.mjs.map +1 -1
  73. package/fesm2020/table.mjs +2 -2
  74. package/fesm2020/table.mjs.map +1 -1
  75. package/fesm2020/tooltip.mjs +24 -13
  76. package/fesm2020/tooltip.mjs.map +1 -1
  77. package/legacy-button/testing/index.d.ts +5 -0
  78. package/legacy-core/_core.scss +1 -2
  79. package/legacy-prebuilt-themes/legacy-deeppurple-amber.css +1 -1
  80. package/legacy-prebuilt-themes/legacy-indigo-pink.css +1 -1
  81. package/legacy-prebuilt-themes/legacy-pink-bluegrey.css +1 -1
  82. package/legacy-prebuilt-themes/legacy-purple-green.css +1 -1
  83. package/list/_list-item-hcm-indicator.scss +30 -0
  84. package/list/index.d.ts +30 -3
  85. package/package.json +49 -49
  86. package/prebuilt-themes/deeppurple-amber.css +1 -1
  87. package/prebuilt-themes/indigo-pink.css +1 -1
  88. package/prebuilt-themes/pink-bluegrey.css +1 -1
  89. package/prebuilt-themes/purple-green.css +1 -1
  90. package/schematics/ng-add/index.js +1 -1
  91. package/schematics/ng-add/index.mjs +1 -1
  92. package/schematics/ng-generate/mdc-migration/index_bundled.js +706 -410
  93. package/schematics/ng-generate/mdc-migration/index_bundled.js.map +3 -3
  94. package/schematics/ng-generate/mdc-migration/mdc_migration_bundle_metadata.json +1 -1
  95. package/schematics/ng-generate/mdc-migration/schema.json +2 -5
  96. package/schematics/ng-update/index_bundled.js +6 -1
  97. package/schematics/ng-update/index_bundled.js.map +2 -2
  98. package/schematics/ng-update/ng_update_index_metadata.json +1 -1
  99. package/slide-toggle/_slide-toggle-theme.scss +19 -19
  100. package/slider/_slider-theme.scss +50 -73
  101. package/tooltip/index.d.ts +2 -2
@@ -18,8 +18,11 @@
18
18
  opacity: map.get($opacities, hover);
19
19
  }
20
20
 
21
- &:focus .mat-mdc-button-persistent-ripple::before {
22
- opacity: map.get($opacities, focus);
21
+ &.cdk-program-focused,
22
+ &.cdk-keyboard-focused {
23
+ .mat-mdc-button-persistent-ripple::before {
24
+ opacity: map.get($opacities, focus);
25
+ }
23
26
  }
24
27
 
25
28
  &:active .mat-mdc-button-persistent-ripple::before {
package/button/index.d.ts CHANGED
@@ -1,4 +1,5 @@
1
1
  import { _AbstractConstructor } from '@angular/material/core';
2
+ import { AfterViewInit } from '@angular/core';
2
3
  import { BooleanInput } from '@angular/cdk/coercion';
3
4
  import { CanColor } from '@angular/material/core';
4
5
  import { CanDisable } from '@angular/material/core';
@@ -93,15 +94,18 @@ export declare class MatButton extends MatButtonBase {
93
94
  }
94
95
 
95
96
  /** Base class for all buttons. */
96
- declare class MatButtonBase extends _MatButtonMixin implements CanDisable, CanColor, CanDisableRipple {
97
+ declare class MatButtonBase extends _MatButtonMixin implements CanDisable, CanColor, CanDisableRipple, AfterViewInit, OnDestroy {
97
98
  _platform: Platform;
98
99
  _ngZone: NgZone;
99
100
  _animationMode?: string | undefined;
101
+ private readonly _focusMonitor;
100
102
  /** Whether this button is a FAB. Used to apply the correct class on the ripple. */
101
103
  _isFab: boolean;
102
104
  /** Reference to the MatRipple instance of the button. */
103
105
  ripple: MatRipple;
104
106
  constructor(elementRef: ElementRef, _platform: Platform, _ngZone: NgZone, _animationMode?: string | undefined);
107
+ ngAfterViewInit(): void;
108
+ ngOnDestroy(): void;
105
109
  /** Focuses the button. */
106
110
  focus(_origin?: FocusOrigin, options?: FocusOptions): void;
107
111
  /** Gets whether the button has one of the given attributes. */
@@ -7,8 +7,13 @@ import { HarnessPredicate } from '@angular/cdk/testing';
7
7
  export declare interface ButtonHarnessFilters extends BaseHarnessFilters {
8
8
  /** Only find instances whose text matches the given value. */
9
9
  text?: string | RegExp;
10
+ /** Only find instances with a variant. */
11
+ variant?: ButtonVariant;
10
12
  }
11
13
 
14
+ /** Possible button appearances. */
15
+ export declare type ButtonVariant = 'basic' | 'raised' | 'flat' | 'icon' | 'stroked' | 'fab' | 'mini-fab';
16
+
12
17
  /** Harness for interacting with a MDC-based mat-button in tests. */
13
18
  export declare class MatButtonHarness extends ContentContainerComponentHarness {
14
19
  static hostSelector: string;
@@ -17,6 +22,7 @@ export declare class MatButtonHarness extends ContentContainerComponentHarness {
17
22
  * @param options Options for narrowing the search:
18
23
  * - `selector` finds a button whose host element matches the given selector.
19
24
  * - `text` finds a button with specific text content.
25
+ * - `variant` finds buttons matching a specific variant.
20
26
  * @return a `HarnessPredicate` configured with the given options.
21
27
  */
22
28
  static with<T extends MatButtonHarness>(this: ComponentHarnessConstructor<T>, options?: ButtonHarnessFilters): HarnessPredicate<T>;
@@ -40,6 +46,8 @@ export declare class MatButtonHarness extends ContentContainerComponentHarness {
40
46
  blur(): Promise<void>;
41
47
  /** Whether the button is focused. */
42
48
  isFocused(): Promise<boolean>;
49
+ /** Gets the variant of the button. */
50
+ getVariant(): Promise<ButtonVariant>;
43
51
  }
44
52
 
45
53
  export { }
package/chips/index.d.ts CHANGED
@@ -739,7 +739,19 @@ export declare class MatChipOption extends MatChip implements OnInit {
739
739
  get selected(): boolean;
740
740
  set selected(value: BooleanInput);
741
741
  private _selected;
742
- /** The ARIA selected applied to the chip. */
742
+ /**
743
+ * The ARIA selected applied to the chip. Conforms to WAI ARIA best practices for listbox
744
+ * interaction patterns.
745
+ *
746
+ * From [WAI ARIA Listbox authoring practices guide](
747
+ * https://www.w3.org/WAI/ARIA/apg/patterns/listbox/):
748
+ * "If any options are selected, each selected option has either aria-selected or aria-checked
749
+ * set to true. All options that are selectable but not selected have either aria-selected or
750
+ * aria-checked set to false."
751
+ *
752
+ * Set `aria-selected="false"` on not-selected listbox options that are selectable to fix
753
+ * VoiceOver reading every option as "selected" (#25736).
754
+ */
743
755
  get ariaSelected(): string | null;
744
756
  /** The unstyled chip selector for this component. */
745
757
  protected basicChipAttrName: string;
package/core/_core.scss CHANGED
@@ -5,8 +5,7 @@
5
5
  @use './focus-indicators/private';
6
6
 
7
7
  // Mixin that renders all of the core styles that are not theme-dependent.
8
- // TODO: Remove the mixin's parameters after all internal clients migrated
9
- @mixin core($typography-config: null, $exclude-typography: false) {
8
+ @mixin core() {
10
9
  @include ripple.ripple();
11
10
  @include cdk.a11y-visually-hidden();
12
11
  @include cdk.overlay();
@@ -84,15 +84,17 @@ $mat-typography-mdc-level-mappings: (
84
84
  }
85
85
 
86
86
  // Converts an MDC typography level config to an Angular Material one.
87
- @function typography-config-level-from-mdc($mdc-level) {
87
+ @function typography-config-level-from-mdc($mdc-level, $overrides: ()) {
88
88
  $mdc-level-config: map.get(mdc-typography.$styles, $mdc-level);
89
89
 
90
90
  @return typography.define-typography-level(
91
- map.get($mdc-level-config, font-size),
92
- map.get($mdc-level-config, line-height),
93
- map.get($mdc-level-config, font-weight),
94
- map.get($mdc-level-config, font-family),
95
- map.get($mdc-level-config, letter-spacing));
91
+ $font-size: map.get($overrides, font-size) or map.get($mdc-level-config, font-size),
92
+ $font-family: map.get($overrides, font-family) or map.get($mdc-level-config, font-family),
93
+ $line-height: map.get($overrides, line-height) or map.get($mdc-level-config, line-height),
94
+ $font-weight: map.get($overrides, font-weight) or map.get($mdc-level-config, font-weight),
95
+ $letter-spacing:
96
+ map.get($overrides, letter-spacing) or map.get($mdc-level-config, letter-spacing)
97
+ );
96
98
  }
97
99
 
98
100
  // Configures MDC's global variables to reflect the given theme, applies the given styles,
@@ -1,7 +1,6 @@
1
1
  @use 'sass:map';
2
2
  @use 'sass:math';
3
3
  @use 'sass:meta';
4
- @use '@material/typography' as mdc-typography;
5
4
  @use './typography';
6
5
  @use '../../autocomplete/autocomplete-theme';
7
6
  @use '../../badge/badge-theme';
@@ -88,49 +87,52 @@
88
87
  @function define-typography-config(
89
88
  // TODO(mmalerba): rename this function to define-typography-config,
90
89
  // and create a predefined px based config for people that need it.
91
- $font-family: mdc-typography.$font-family,
92
- $headline-1: _rem-to-px(mdc-helpers.typography-config-level-from-mdc(headline1)),
93
- $headline-2: _rem-to-px(mdc-helpers.typography-config-level-from-mdc(headline2)),
94
- $headline-3: _rem-to-px(mdc-helpers.typography-config-level-from-mdc(headline3)),
95
- $headline-4: _rem-to-px(mdc-helpers.typography-config-level-from-mdc(headline4)),
96
- $headline-5: _rem-to-px(mdc-helpers.typography-config-level-from-mdc(headline5)),
97
- $headline-6: _rem-to-px(mdc-helpers.typography-config-level-from-mdc(headline6)),
98
- $subtitle-1: _rem-to-px(mdc-helpers.typography-config-level-from-mdc(subtitle1)),
99
- $subtitle-2: _rem-to-px(mdc-helpers.typography-config-level-from-mdc(subtitle2)),
100
- $body-1: _rem-to-px(mdc-helpers.typography-config-level-from-mdc(body1)),
101
- $body-2: _rem-to-px(mdc-helpers.typography-config-level-from-mdc(body2)),
102
- $caption: _rem-to-px(mdc-helpers.typography-config-level-from-mdc(caption)),
103
- $button: _rem-to-px(mdc-helpers.typography-config-level-from-mdc(button)),
104
- $overline: _rem-to-px(mdc-helpers.typography-config-level-from-mdc(overline)),
90
+ $font-family: null,
91
+ $headline-1: null,
92
+ $headline-2: null,
93
+ $headline-3: null,
94
+ $headline-4: null,
95
+ $headline-5: null,
96
+ $headline-6: null,
97
+ $subtitle-1: null,
98
+ $subtitle-2: null,
99
+ $body-1: null,
100
+ $body-2: null,
101
+ $caption: null,
102
+ $button: null,
103
+ $overline: null,
105
104
  ) {
106
105
  // Declare an initial map with all of the levels.
107
- $config: (
108
- headline-1: $headline-1,
109
- headline-2: $headline-2,
110
- headline-3: $headline-3,
111
- headline-4: $headline-4,
112
- headline-5: $headline-5,
113
- headline-6: $headline-6,
114
- subtitle-1: $subtitle-1,
115
- subtitle-2: $subtitle-2,
116
- body-1: $body-1,
117
- body-2: $body-2,
118
- caption: $caption,
119
- button: $button,
120
- overline: $overline,
121
- );
106
+ $overrides: if($font-family, (font-family: $font-family), ());
122
107
 
123
- // Loop through the levels and set the `font-family` of the ones that don't have one to the base.
124
- // Note that Sass can't modify maps in place, which means that we need to merge and re-assign.
125
- @each $key, $level in $config {
126
- @if map.get($level, font-family) == null {
127
- $new-level: map.merge($level, (font-family: $font-family));
128
- $config: map.merge($config, ($key: $new-level));
129
- }
130
- }
131
-
132
- // Add the base font family to the config.
133
- @return map.merge($config, (font-family: $font-family));
108
+ @return (
109
+ headline-1: $headline-1 or _rem-to-px(
110
+ mdc-helpers.typography-config-level-from-mdc(headline1, $overrides)),
111
+ headline-2: $headline-2 or _rem-to-px(
112
+ mdc-helpers.typography-config-level-from-mdc(headline2, $overrides)),
113
+ headline-3: $headline-3 or _rem-to-px(
114
+ mdc-helpers.typography-config-level-from-mdc(headline3, $overrides)),
115
+ headline-4: $headline-4 or _rem-to-px(
116
+ mdc-helpers.typography-config-level-from-mdc(headline4, $overrides)),
117
+ headline-5: $headline-5 or _rem-to-px(
118
+ mdc-helpers.typography-config-level-from-mdc(headline5, $overrides)),
119
+ headline-6: $headline-6 or _rem-to-px(
120
+ mdc-helpers.typography-config-level-from-mdc(headline6, $overrides)),
121
+ subtitle-1: $subtitle-1 or _rem-to-px(
122
+ mdc-helpers.typography-config-level-from-mdc(subtitle1, $overrides)),
123
+ subtitle-2: $subtitle-2 or _rem-to-px(
124
+ mdc-helpers.typography-config-level-from-mdc(subtitle2, $overrides)),
125
+ body-1: $body-1 or _rem-to-px(
126
+ mdc-helpers.typography-config-level-from-mdc(body1, $overrides)),
127
+ body-2: $body-2 or _rem-to-px(
128
+ mdc-helpers.typography-config-level-from-mdc(body2, $overrides)),
129
+ caption: $caption or _rem-to-px(
130
+ mdc-helpers.typography-config-level-from-mdc(caption, $overrides)),
131
+ button: $button or _rem-to-px(
132
+ mdc-helpers.typography-config-level-from-mdc(button, $overrides)),
133
+ overline: $overline or _rem-to-px(
134
+ mdc-helpers.typography-config-level-from-mdc(overline, $overrides)),
135
+ );
134
136
  }
135
137
 
136
138
  /// Generates an Angular Material typography config based on values from the official Material
@@ -158,49 +160,39 @@
158
160
  @function define-rem-typography-config(
159
161
  // TODO(mmalerba): rename this function to define-typography-config,
160
162
  // and create a predefined px based config for people that need it.
161
- $font-family: mdc-typography.$font-family,
162
- $headline-1: mdc-helpers.typography-config-level-from-mdc(headline1),
163
- $headline-2: mdc-helpers.typography-config-level-from-mdc(headline2),
164
- $headline-3: mdc-helpers.typography-config-level-from-mdc(headline3),
165
- $headline-4: mdc-helpers.typography-config-level-from-mdc(headline4),
166
- $headline-5: mdc-helpers.typography-config-level-from-mdc(headline5),
167
- $headline-6: mdc-helpers.typography-config-level-from-mdc(headline6),
168
- $subtitle-1: mdc-helpers.typography-config-level-from-mdc(subtitle1),
169
- $subtitle-2: mdc-helpers.typography-config-level-from-mdc(subtitle2),
170
- $body-1: mdc-helpers.typography-config-level-from-mdc(body1),
171
- $body-2: mdc-helpers.typography-config-level-from-mdc(body2),
172
- $caption: mdc-helpers.typography-config-level-from-mdc(caption),
173
- $button: mdc-helpers.typography-config-level-from-mdc(button),
174
- $overline: mdc-helpers.typography-config-level-from-mdc(overline),
163
+ $font-family: null,
164
+ $headline-1: null,
165
+ $headline-2: null,
166
+ $headline-3: null,
167
+ $headline-4: null,
168
+ $headline-5: null,
169
+ $headline-6: null,
170
+ $subtitle-1: null,
171
+ $subtitle-2: null,
172
+ $body-1: null,
173
+ $body-2: null,
174
+ $caption: null,
175
+ $button: null,
176
+ $overline: null,
175
177
  ) {
176
178
  // Declare an initial map with all of the levels.
177
- $config: (
178
- headline-1: $headline-1,
179
- headline-2: $headline-2,
180
- headline-3: $headline-3,
181
- headline-4: $headline-4,
182
- headline-5: $headline-5,
183
- headline-6: $headline-6,
184
- subtitle-1: $subtitle-1,
185
- subtitle-2: $subtitle-2,
186
- body-1: $body-1,
187
- body-2: $body-2,
188
- caption: $caption,
189
- button: $button,
190
- overline: $overline,
191
- );
179
+ $overrides: if($font-family, (font-family: $font-family), ());
192
180
 
193
- // Loop through the levels and set the `font-family` of the ones that don't have one to the base.
194
- // Note that Sass can't modify maps in place, which means that we need to merge and re-assign.
195
- @each $key, $level in $config {
196
- @if map.get($level, font-family) == null {
197
- $new-level: map.merge($level, (font-family: $font-family));
198
- $config: map.merge($config, ($key: $new-level));
199
- }
200
- }
201
-
202
- // Add the base font family to the config.
203
- @return map.merge($config, (font-family: $font-family));
181
+ @return (
182
+ headline-1: $headline-1 or mdc-helpers.typography-config-level-from-mdc(headline1, $overrides),
183
+ headline-2: $headline-2 or mdc-helpers.typography-config-level-from-mdc(headline2, $overrides),
184
+ headline-3: $headline-3 or mdc-helpers.typography-config-level-from-mdc(headline3, $overrides),
185
+ headline-4: $headline-4 or mdc-helpers.typography-config-level-from-mdc(headline4, $overrides),
186
+ headline-5: $headline-5 or mdc-helpers.typography-config-level-from-mdc(headline5, $overrides),
187
+ headline-6: $headline-6 or mdc-helpers.typography-config-level-from-mdc(headline6, $overrides),
188
+ subtitle-1: $subtitle-1 or mdc-helpers.typography-config-level-from-mdc(subtitle1, $overrides),
189
+ subtitle-2: $subtitle-2 or mdc-helpers.typography-config-level-from-mdc(subtitle2, $overrides),
190
+ body-1: $body-1 or mdc-helpers.typography-config-level-from-mdc(body1, $overrides),
191
+ body-2: $body-2 or mdc-helpers.typography-config-level-from-mdc(body2, $overrides),
192
+ caption: $caption or mdc-helpers.typography-config-level-from-mdc(caption, $overrides),
193
+ button: $button or mdc-helpers.typography-config-level-from-mdc(button, $overrides),
194
+ overline: $overline or mdc-helpers.typography-config-level-from-mdc(overline, $overrides),
195
+ );
204
196
  }
205
197
 
206
198
  @mixin private-all-unmigrated-component-typographies($config) {
@@ -1080,9 +1080,17 @@ export declare class MatDatepickerIntl {
1080
1080
  switchToMonthViewLabel: string;
1081
1081
  /** A label for the 'switch to year view' button (used by screen readers). */
1082
1082
  switchToMultiYearViewLabel: string;
1083
- /** A label for the first date of a range of dates (used by screen readers). */
1083
+ /**
1084
+ * A label for the first date of a range of dates (used by screen readers).
1085
+ * @deprecated Provide your own internationalization string.
1086
+ * @breaking-change 17.0.0
1087
+ */
1084
1088
  startDateLabel: string;
1085
- /** A label for the last date of a range of dates (used by screen readers). */
1089
+ /**
1090
+ * A label for the last date of a range of dates (used by screen readers).
1091
+ * @deprecated Provide your own internationalization string.
1092
+ * @breaking-change 17.0.0
1093
+ */
1086
1094
  endDateLabel: string;
1087
1095
  /** Formats a range of years (used for visuals). */
1088
1096
  formatYearRange(start: string, end: string): string;
@@ -5,8 +5,9 @@
5
5
  * Use of this source code is governed by an MIT-style license that can be
6
6
  * found in the LICENSE file at https://angular.io/license
7
7
  */
8
+ import { FocusMonitor } from '@angular/cdk/a11y';
8
9
  import { Platform } from '@angular/cdk/platform';
9
- import { Directive, ElementRef, NgZone, ViewChild } from '@angular/core';
10
+ import { Directive, ElementRef, inject, NgZone, ViewChild, } from '@angular/core';
10
11
  import { MatRipple, mixinColor, mixinDisabled, mixinDisableRipple, } from '@angular/material/core';
11
12
  import * as i0 from "@angular/core";
12
13
  import * as i1 from "@angular/cdk/platform";
@@ -69,6 +70,7 @@ export class MatButtonBase extends _MatButtonMixin {
69
70
  this._platform = _platform;
70
71
  this._ngZone = _ngZone;
71
72
  this._animationMode = _animationMode;
73
+ this._focusMonitor = inject(FocusMonitor);
72
74
  /** Whether this button is a FAB. Used to apply the correct class on the ripple. */
73
75
  this._isFab = false;
74
76
  const classList = elementRef.nativeElement.classList;
@@ -82,9 +84,20 @@ export class MatButtonBase extends _MatButtonMixin {
82
84
  }
83
85
  }
84
86
  }
87
+ ngAfterViewInit() {
88
+ this._focusMonitor.monitor(this._elementRef, true);
89
+ }
90
+ ngOnDestroy() {
91
+ this._focusMonitor.stopMonitoring(this._elementRef);
92
+ }
85
93
  /** Focuses the button. */
86
94
  focus(_origin = 'program', options) {
87
- this._elementRef.nativeElement.focus(options);
95
+ if (_origin) {
96
+ this._focusMonitor.focusVia(this._elementRef.nativeElement, _origin, options);
97
+ }
98
+ else {
99
+ this._elementRef.nativeElement.focus(options);
100
+ }
88
101
  }
89
102
  /** Gets whether the button has one of the given attributes. */
90
103
  _hasHostAttributes(...attributes) {
@@ -141,6 +154,7 @@ export class MatAnchorBase extends MatButtonBase {
141
154
  });
142
155
  }
143
156
  ngOnDestroy() {
157
+ super.ngOnDestroy();
144
158
  this._elementRef.nativeElement.removeEventListener('click', this._haltDisabledEvents);
145
159
  }
146
160
  }
@@ -149,4 +163,4 @@ MatAnchorBase.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version:
149
163
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.0.0-next.1", ngImport: i0, type: MatAnchorBase, decorators: [{
150
164
  type: Directive
151
165
  }], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i1.Platform }, { type: i0.NgZone }, { type: undefined }]; } });
152
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"button-base.js","sourceRoot":"","sources":["../../../../../../src/material/button/button-base.ts"],"names":[],"mappings":"AAAA;;;;;;GAMG;AAEH,OAAO,EAAC,QAAQ,EAAC,MAAM,uBAAuB,CAAC;AAC/C,OAAO,EAAC,SAAS,EAAE,UAAU,EAAE,MAAM,EAAqB,SAAS,EAAC,MAAM,eAAe,CAAC;AAC1F,OAAO,EAIL,SAAS,EACT,UAAU,EACV,aAAa,EACb,kBAAkB,GACnB,MAAM,wBAAwB,CAAC;;;AAGhC,oCAAoC;AACpC,MAAM,CAAC,MAAM,iBAAiB,GAAG,CAAC,UAAU,EAAE,eAAe,EAAE,OAAO,CAAC,CAAC;AAExE,gDAAgD;AAChD,MAAM,CAAC,MAAM,eAAe,GAAG;IAC7B,iBAAiB,EAAE,kBAAkB;IACrC,iCAAiC,EAAE,qCAAqC;IACxE,0FAA0F;IAC1F,sFAAsF;IACtF,iCAAiC;IACjC,sBAAsB,EAAE,QAAQ;IAChC,sFAAsF;IACtF,wCAAwC;IACxC,6BAA6B,EAAE,MAAM;CACtC,CAAC;AAEF,oFAAoF;AACpF,MAAM,4BAA4B,GAA+C;IAC/E;QACE,QAAQ,EAAE,YAAY;QACtB,UAAU,EAAE,CAAC,YAAY,EAAE,gBAAgB,CAAC;KAC7C;IACD;QACE,QAAQ,EAAE,iBAAiB;QAC3B,UAAU,EAAE,CAAC,YAAY,EAAE,wBAAwB,EAAE,2BAA2B,CAAC;KAClF;IACD;QACE,QAAQ,EAAE,mBAAmB;QAC7B,UAAU,EAAE,CAAC,YAAY,EAAE,oBAAoB,EAAE,uBAAuB,CAAC;KAC1E;IACD;QACE,QAAQ,EAAE,oBAAoB;QAC9B,UAAU,EAAE,CAAC,YAAY,EAAE,sBAAsB,EAAE,yBAAyB,CAAC;KAC9E;IACD;QACE,QAAQ,EAAE,SAAS;QACnB,UAAU,EAAE,CAAC,SAAS,EAAE,aAAa,CAAC;KACvC;IACD;QACE,QAAQ,EAAE,cAAc;QACxB,UAAU,EAAE,CAAC,SAAS,EAAE,eAAe,EAAE,kBAAkB,CAAC;KAC7D;IACD;QACE,QAAQ,EAAE,iBAAiB;QAC3B,UAAU,EAAE,CAAC,iBAAiB,EAAE,qBAAqB,CAAC;KACvD;CACF,CAAC;AAEF,gDAAgD;AAChD,oBAAoB;AACpB,MAAM,CAAC,MAAM,eAAe,GAAG,UAAU,CACvC,aAAa,CACX,kBAAkB,CAChB;IACE,YAAmB,WAAuB;QAAvB,gBAAW,GAAX,WAAW,CAAY;IAAG,CAAC;CAC/C,CACF,CACF,CACF,CAAC;AAEF,mCAAmC;AAEnC,MAAM,OAAO,aACX,SAAQ,eAAe;IASvB,YACE,UAAsB,EACf,SAAmB,EACnB,OAAe,EACf,cAAuB;QAE9B,KAAK,CAAC,UAAU,CAAC,CAAC;QAJX,cAAS,GAAT,SAAS,CAAU;QACnB,YAAO,GAAP,OAAO,CAAQ;QACf,mBAAc,GAAd,cAAc,CAAS;QAVhC,mFAAmF;QACnF,WAAM,GAAG,KAAK,CAAC;QAab,MAAM,SAAS,GAAI,UAAU,CAAC,aAA6B,CAAC,SAAS,CAAC;QAEtE,yEAAyE;QACzE,yDAAyD;QACzD,KAAK,MAAM,IAAI,IAAI,4BAA4B,EAAE;YAC/C,IAAI,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,QAAQ,CAAC,EAAE;gBAC1C,IAAI,CAAC,UAAU,CAAC,OAAO,CAAC,CAAC,SAAiB,EAAE,EAAE;oBAC5C,SAAS,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC;gBAC3B,CAAC,CAAC,CAAC;aACJ;SACF;IACH,CAAC;IAED,0BAA0B;IAC1B,KAAK,CAAC,UAAuB,SAAS,EAAE,OAAsB;QAC5D,IAAI,CAAC,WAAW,CAAC,aAAa,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC;IAChD,CAAC;IAED,+DAA+D;IACvD,kBAAkB,CAAC,GAAG,UAAoB;QAChD,OAAO,UAAU,CAAC,IAAI,CAAC,SAAS,CAAC,EAAE,CAAC,IAAI,CAAC,WAAW,CAAC,aAAa,CAAC,YAAY,CAAC,SAAS,CAAC,CAAC,CAAC;IAC9F,CAAC;IAED,iBAAiB;QACf,OAAO,IAAI,CAAC,aAAa,IAAI,IAAI,CAAC,QAAQ,CAAC;IAC7C,CAAC;;iHA3CU,aAAa;qGAAb,aAAa,kEAQb,SAAS;kGART,aAAa;kBADzB,SAAS;kKASc,MAAM;sBAA3B,SAAS;uBAAC,SAAS;;AAsCtB,mDAAmD;AACnD,MAAM,CAAC,MAAM,iBAAiB,GAAG,CAAC,UAAU,EAAE,eAAe,EAAE,OAAO,EAAE,UAAU,CAAC,CAAC;AAEpF,iEAAiE;AACjE,MAAM,CAAC,MAAM,eAAe,GAAG;IAC7B,iBAAiB,EAAE,kBAAkB;IACrC,iCAAiC,EAAE,qCAAqC;IAExE,yEAAyE;IACzE,yEAAyE;IACzE,mDAAmD;IACnD,iBAAiB,EAAE,0BAA0B;IAC7C,sBAAsB,EAAE,qBAAqB;IAC7C,0FAA0F;IAC1F,sFAAsF;IACtF,iCAAiC;IACjC,sBAAsB,EAAE,QAAQ;IAChC,sFAAsF;IACtF,wCAAwC;IACxC,6BAA6B,EAAE,MAAM;CACtC,CAAC;AAEF;;GAEG;AAEH,MAAM,OAAO,aAAc,SAAQ,aAAa;IAG9C,YAAY,UAAsB,EAAE,QAAkB,EAAE,MAAc,EAAE,aAAsB;QAC5F,KAAK,CAAC,UAAU,EAAE,QAAQ,EAAE,MAAM,EAAE,aAAa,CAAC,CAAC;QAarD,wBAAmB,GAAG,CAAC,KAAY,EAAQ,EAAE;YAC3C,gDAAgD;YAChD,IAAI,IAAI,CAAC,QAAQ,EAAE;gBACjB,KAAK,CAAC,cAAc,EAAE,CAAC;gBACvB,KAAK,CAAC,wBAAwB,EAAE,CAAC;aAClC;QACH,CAAC,CAAC;IAlBF,CAAC;IAED,QAAQ;QACN,IAAI,CAAC,OAAO,CAAC,iBAAiB,CAAC,GAAG,EAAE;YAClC,IAAI,CAAC,WAAW,CAAC,aAAa,CAAC,gBAAgB,CAAC,OAAO,EAAE,IAAI,CAAC,mBAAmB,CAAC,CAAC;QACrF,CAAC,CAAC,CAAC;IACL,CAAC;IAED,WAAW;QACT,IAAI,CAAC,WAAW,CAAC,aAAa,CAAC,mBAAmB,CAAC,OAAO,EAAE,IAAI,CAAC,mBAAmB,CAAC,CAAC;IACxF,CAAC;;iHAfU,aAAa;qGAAb,aAAa;kGAAb,aAAa;kBADzB,SAAS","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 {Platform} from '@angular/cdk/platform';\nimport {Directive, ElementRef, NgZone, OnDestroy, OnInit, ViewChild} from '@angular/core';\nimport {\n  CanColor,\n  CanDisable,\n  CanDisableRipple,\n  MatRipple,\n  mixinColor,\n  mixinDisabled,\n  mixinDisableRipple,\n} from '@angular/material/core';\nimport {FocusOrigin} from '@angular/cdk/a11y';\n\n/** Inputs common to all buttons. */\nexport const MAT_BUTTON_INPUTS = ['disabled', 'disableRipple', 'color'];\n\n/** Shared host configuration for all buttons */\nexport const MAT_BUTTON_HOST = {\n  '[attr.disabled]': 'disabled || null',\n  '[class._mat-animation-noopable]': '_animationMode === \"NoopAnimations\"',\n  // MDC automatically applies the primary theme color to the button, but we want to support\n  // an unthemed version. If color is undefined, apply a CSS class that makes it easy to\n  // select and style this \"theme\".\n  '[class.mat-unthemed]': '!color',\n  // Add a class that applies to all buttons. This makes it easier to target if somebody\n  // wants to target all Material buttons.\n  '[class.mat-mdc-button-base]': 'true',\n};\n\n/** List of classes to add to buttons instances based on host attribute selector. */\nconst HOST_SELECTOR_MDC_CLASS_PAIR: {selector: string; mdcClasses: string[]}[] = [\n  {\n    selector: 'mat-button',\n    mdcClasses: ['mdc-button', 'mat-mdc-button'],\n  },\n  {\n    selector: 'mat-flat-button',\n    mdcClasses: ['mdc-button', 'mdc-button--unelevated', 'mat-mdc-unelevated-button'],\n  },\n  {\n    selector: 'mat-raised-button',\n    mdcClasses: ['mdc-button', 'mdc-button--raised', 'mat-mdc-raised-button'],\n  },\n  {\n    selector: 'mat-stroked-button',\n    mdcClasses: ['mdc-button', 'mdc-button--outlined', 'mat-mdc-outlined-button'],\n  },\n  {\n    selector: 'mat-fab',\n    mdcClasses: ['mdc-fab', 'mat-mdc-fab'],\n  },\n  {\n    selector: 'mat-mini-fab',\n    mdcClasses: ['mdc-fab', 'mdc-fab--mini', 'mat-mdc-mini-fab'],\n  },\n  {\n    selector: 'mat-icon-button',\n    mdcClasses: ['mdc-icon-button', 'mat-mdc-icon-button'],\n  },\n];\n\n// Boilerplate for applying mixins to MatButton.\n/** @docs-private */\nexport const _MatButtonMixin = mixinColor(\n  mixinDisabled(\n    mixinDisableRipple(\n      class {\n        constructor(public _elementRef: ElementRef) {}\n      },\n    ),\n  ),\n);\n\n/** Base class for all buttons.  */\n@Directive()\nexport class MatButtonBase\n  extends _MatButtonMixin\n  implements CanDisable, CanColor, CanDisableRipple\n{\n  /** Whether this button is a FAB. Used to apply the correct class on the ripple. */\n  _isFab = false;\n\n  /** Reference to the MatRipple instance of the button. */\n  @ViewChild(MatRipple) ripple: MatRipple;\n\n  constructor(\n    elementRef: ElementRef,\n    public _platform: Platform,\n    public _ngZone: NgZone,\n    public _animationMode?: string,\n  ) {\n    super(elementRef);\n\n    const classList = (elementRef.nativeElement as HTMLElement).classList;\n\n    // For each of the variant selectors that is present in the button's host\n    // attributes, add the correct corresponding MDC classes.\n    for (const pair of HOST_SELECTOR_MDC_CLASS_PAIR) {\n      if (this._hasHostAttributes(pair.selector)) {\n        pair.mdcClasses.forEach((className: string) => {\n          classList.add(className);\n        });\n      }\n    }\n  }\n\n  /** Focuses the button. */\n  focus(_origin: FocusOrigin = 'program', options?: FocusOptions): void {\n    this._elementRef.nativeElement.focus(options);\n  }\n\n  /** Gets whether the button has one of the given attributes. */\n  private _hasHostAttributes(...attributes: string[]) {\n    return attributes.some(attribute => this._elementRef.nativeElement.hasAttribute(attribute));\n  }\n\n  _isRippleDisabled() {\n    return this.disableRipple || this.disabled;\n  }\n}\n\n/** Shared inputs by buttons using the `<a>` tag */\nexport const MAT_ANCHOR_INPUTS = ['disabled', 'disableRipple', 'color', 'tabIndex'];\n\n/** Shared host configuration for buttons using the `<a>` tag. */\nexport const MAT_ANCHOR_HOST = {\n  '[attr.disabled]': 'disabled || null',\n  '[class._mat-animation-noopable]': '_animationMode === \"NoopAnimations\"',\n\n  // Note that we ignore the user-specified tabindex when it's disabled for\n  // consistency with the `mat-button` applied on native buttons where even\n  // though they have an index, they're not tabbable.\n  '[attr.tabindex]': 'disabled ? -1 : tabIndex',\n  '[attr.aria-disabled]': 'disabled.toString()',\n  // MDC automatically applies the primary theme color to the button, but we want to support\n  // an unthemed version. If color is undefined, apply a CSS class that makes it easy to\n  // select and style this \"theme\".\n  '[class.mat-unthemed]': '!color',\n  // Add a class that applies to all buttons. This makes it easier to target if somebody\n  // wants to target all Material buttons.\n  '[class.mat-mdc-button-base]': 'true',\n};\n\n/**\n * Anchor button base.\n */\n@Directive()\nexport class MatAnchorBase extends MatButtonBase implements OnInit, OnDestroy {\n  tabIndex: number;\n\n  constructor(elementRef: ElementRef, platform: Platform, ngZone: NgZone, animationMode?: string) {\n    super(elementRef, platform, ngZone, animationMode);\n  }\n\n  ngOnInit(): void {\n    this._ngZone.runOutsideAngular(() => {\n      this._elementRef.nativeElement.addEventListener('click', this._haltDisabledEvents);\n    });\n  }\n\n  ngOnDestroy(): void {\n    this._elementRef.nativeElement.removeEventListener('click', this._haltDisabledEvents);\n  }\n\n  _haltDisabledEvents = (event: Event): void => {\n    // A disabled button shouldn't apply any actions\n    if (this.disabled) {\n      event.preventDefault();\n      event.stopImmediatePropagation();\n    }\n  };\n}\n"]}
166
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"button-base.js","sourceRoot":"","sources":["../../../../../../src/material/button/button-base.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 {FocusMonitor, FocusOrigin} from '@angular/cdk/a11y';\nimport {Platform} from '@angular/cdk/platform';\nimport {\n  AfterViewInit,\n  Directive,\n  ElementRef,\n  inject,\n  NgZone,\n  OnDestroy,\n  OnInit,\n  ViewChild,\n} from '@angular/core';\nimport {\n  CanColor,\n  CanDisable,\n  CanDisableRipple,\n  MatRipple,\n  mixinColor,\n  mixinDisabled,\n  mixinDisableRipple,\n} from '@angular/material/core';\n\n/** Inputs common to all buttons. */\nexport const MAT_BUTTON_INPUTS = ['disabled', 'disableRipple', 'color'];\n\n/** Shared host configuration for all buttons */\nexport const MAT_BUTTON_HOST = {\n  '[attr.disabled]': 'disabled || null',\n  '[class._mat-animation-noopable]': '_animationMode === \"NoopAnimations\"',\n  // MDC automatically applies the primary theme color to the button, but we want to support\n  // an unthemed version. If color is undefined, apply a CSS class that makes it easy to\n  // select and style this \"theme\".\n  '[class.mat-unthemed]': '!color',\n  // Add a class that applies to all buttons. This makes it easier to target if somebody\n  // wants to target all Material buttons.\n  '[class.mat-mdc-button-base]': 'true',\n};\n\n/** List of classes to add to buttons instances based on host attribute selector. */\nconst HOST_SELECTOR_MDC_CLASS_PAIR: {selector: string; mdcClasses: string[]}[] = [\n  {\n    selector: 'mat-button',\n    mdcClasses: ['mdc-button', 'mat-mdc-button'],\n  },\n  {\n    selector: 'mat-flat-button',\n    mdcClasses: ['mdc-button', 'mdc-button--unelevated', 'mat-mdc-unelevated-button'],\n  },\n  {\n    selector: 'mat-raised-button',\n    mdcClasses: ['mdc-button', 'mdc-button--raised', 'mat-mdc-raised-button'],\n  },\n  {\n    selector: 'mat-stroked-button',\n    mdcClasses: ['mdc-button', 'mdc-button--outlined', 'mat-mdc-outlined-button'],\n  },\n  {\n    selector: 'mat-fab',\n    mdcClasses: ['mdc-fab', 'mat-mdc-fab'],\n  },\n  {\n    selector: 'mat-mini-fab',\n    mdcClasses: ['mdc-fab', 'mdc-fab--mini', 'mat-mdc-mini-fab'],\n  },\n  {\n    selector: 'mat-icon-button',\n    mdcClasses: ['mdc-icon-button', 'mat-mdc-icon-button'],\n  },\n];\n\n// Boilerplate for applying mixins to MatButton.\n/** @docs-private */\nexport const _MatButtonMixin = mixinColor(\n  mixinDisabled(\n    mixinDisableRipple(\n      class {\n        constructor(public _elementRef: ElementRef) {}\n      },\n    ),\n  ),\n);\n\n/** Base class for all buttons.  */\n@Directive()\nexport class MatButtonBase\n  extends _MatButtonMixin\n  implements CanDisable, CanColor, CanDisableRipple, AfterViewInit, OnDestroy\n{\n  private readonly _focusMonitor = inject(FocusMonitor);\n\n  /** Whether this button is a FAB. Used to apply the correct class on the ripple. */\n  _isFab = false;\n\n  /** Reference to the MatRipple instance of the button. */\n  @ViewChild(MatRipple) ripple: MatRipple;\n\n  constructor(\n    elementRef: ElementRef,\n    public _platform: Platform,\n    public _ngZone: NgZone,\n    public _animationMode?: string,\n  ) {\n    super(elementRef);\n\n    const classList = (elementRef.nativeElement as HTMLElement).classList;\n\n    // For each of the variant selectors that is present in the button's host\n    // attributes, add the correct corresponding MDC classes.\n    for (const pair of HOST_SELECTOR_MDC_CLASS_PAIR) {\n      if (this._hasHostAttributes(pair.selector)) {\n        pair.mdcClasses.forEach((className: string) => {\n          classList.add(className);\n        });\n      }\n    }\n  }\n\n  ngAfterViewInit() {\n    this._focusMonitor.monitor(this._elementRef, true);\n  }\n\n  ngOnDestroy() {\n    this._focusMonitor.stopMonitoring(this._elementRef);\n  }\n\n  /** Focuses the button. */\n  focus(_origin: FocusOrigin = 'program', options?: FocusOptions): void {\n    if (_origin) {\n      this._focusMonitor.focusVia(this._elementRef.nativeElement, _origin, options);\n    } else {\n      this._elementRef.nativeElement.focus(options);\n    }\n  }\n\n  /** Gets whether the button has one of the given attributes. */\n  private _hasHostAttributes(...attributes: string[]) {\n    return attributes.some(attribute => this._elementRef.nativeElement.hasAttribute(attribute));\n  }\n\n  _isRippleDisabled() {\n    return this.disableRipple || this.disabled;\n  }\n}\n\n/** Shared inputs by buttons using the `<a>` tag */\nexport const MAT_ANCHOR_INPUTS = ['disabled', 'disableRipple', 'color', 'tabIndex'];\n\n/** Shared host configuration for buttons using the `<a>` tag. */\nexport const MAT_ANCHOR_HOST = {\n  '[attr.disabled]': 'disabled || null',\n  '[class._mat-animation-noopable]': '_animationMode === \"NoopAnimations\"',\n\n  // Note that we ignore the user-specified tabindex when it's disabled for\n  // consistency with the `mat-button` applied on native buttons where even\n  // though they have an index, they're not tabbable.\n  '[attr.tabindex]': 'disabled ? -1 : tabIndex',\n  '[attr.aria-disabled]': 'disabled.toString()',\n  // MDC automatically applies the primary theme color to the button, but we want to support\n  // an unthemed version. If color is undefined, apply a CSS class that makes it easy to\n  // select and style this \"theme\".\n  '[class.mat-unthemed]': '!color',\n  // Add a class that applies to all buttons. This makes it easier to target if somebody\n  // wants to target all Material buttons.\n  '[class.mat-mdc-button-base]': 'true',\n};\n\n/**\n * Anchor button base.\n */\n@Directive()\nexport class MatAnchorBase extends MatButtonBase implements OnInit, OnDestroy {\n  tabIndex: number;\n\n  constructor(elementRef: ElementRef, platform: Platform, ngZone: NgZone, animationMode?: string) {\n    super(elementRef, platform, ngZone, animationMode);\n  }\n\n  ngOnInit(): void {\n    this._ngZone.runOutsideAngular(() => {\n      this._elementRef.nativeElement.addEventListener('click', this._haltDisabledEvents);\n    });\n  }\n\n  override ngOnDestroy(): void {\n    super.ngOnDestroy();\n    this._elementRef.nativeElement.removeEventListener('click', this._haltDisabledEvents);\n  }\n\n  _haltDisabledEvents = (event: Event): void => {\n    // A disabled button shouldn't apply any actions\n    if (this.disabled) {\n      event.preventDefault();\n      event.stopImmediatePropagation();\n    }\n  };\n}\n"]}