@angular/material 18.0.0-next.6 → 18.0.0-rc.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 (97) hide show
  1. package/_index.scss +1 -1
  2. package/core/tokens/_m3-tokens.scss +8 -878
  3. package/core/tokens/_token-utils.scss +151 -0
  4. package/core/tokens/m2/mat/_switch.scss +1 -0
  5. package/core/tokens/m3/_index.scss +161 -0
  6. package/core/tokens/m3/mat/_app.scss +19 -0
  7. package/core/tokens/m3/mat/_autocomplete.scss +22 -0
  8. package/core/tokens/m3/mat/_badge.scss +77 -0
  9. package/core/tokens/m3/mat/_bottom-sheet.scss +24 -0
  10. package/core/tokens/m3/mat/_card.scss +24 -0
  11. package/core/tokens/m3/mat/_checkbox.scss +21 -0
  12. package/core/tokens/m3/mat/_chip.scss +46 -0
  13. package/core/tokens/m3/mat/_datepicker.scss +123 -0
  14. package/core/tokens/m3/mat/_dialog.scss +30 -0
  15. package/core/tokens/m3/mat/_divider.scss +19 -0
  16. package/core/tokens/m3/mat/_expansion.scss +41 -0
  17. package/core/tokens/m3/mat/_fab-small.scss +50 -0
  18. package/core/tokens/m3/mat/_fab.scss +50 -0
  19. package/core/tokens/m3/mat/_filled-button.scss +54 -0
  20. package/core/tokens/m3/mat/_form-field.scss +59 -0
  21. package/core/tokens/m3/mat/_full-pseudo-checkbox.scss +42 -0
  22. package/core/tokens/m3/mat/_grid-list.scss +21 -0
  23. package/core/tokens/m3/mat/_icon-button.scss +27 -0
  24. package/core/tokens/m3/mat/_icon.scss +33 -0
  25. package/core/tokens/m3/mat/_list.scss +19 -0
  26. package/core/tokens/m3/mat/_menu.scss +42 -0
  27. package/core/tokens/m3/mat/_minimal-pseudo-checkbox.scss +33 -0
  28. package/core/tokens/m3/mat/_optgroup.scss +22 -0
  29. package/core/tokens/m3/mat/_option.scss +55 -0
  30. package/core/tokens/m3/mat/_outlined-button.scss +54 -0
  31. package/core/tokens/m3/mat/_paginator.scss +27 -0
  32. package/core/tokens/m3/mat/_protected-button.scss +55 -0
  33. package/core/tokens/m3/mat/_radio.scss +34 -0
  34. package/core/tokens/m3/mat/_ripple.scss +19 -0
  35. package/core/tokens/m3/mat/_select.scss +46 -0
  36. package/core/tokens/m3/mat/_sidenav.scss +28 -0
  37. package/core/tokens/m3/mat/_slider.scss +56 -0
  38. package/core/tokens/m3/mat/_snack-bar.scss +18 -0
  39. package/core/tokens/m3/mat/_sort.scss +18 -0
  40. package/core/tokens/m3/mat/_standard-button-toggle.scss +57 -0
  41. package/core/tokens/m3/mat/_stepper.scss +79 -0
  42. package/core/tokens/m3/mat/_switch.scss +45 -0
  43. package/core/tokens/m3/mat/_tab-header.scss +51 -0
  44. package/core/tokens/m3/mat/_table.scss +28 -0
  45. package/core/tokens/m3/mat/_text-button.scss +55 -0
  46. package/core/tokens/m3/mat/_toolbar.scss +23 -0
  47. package/core/tokens/m3/mat/_tree.scss +22 -0
  48. package/core/tokens/m3/mdc/_checkbox.scss +110 -0
  49. package/core/tokens/m3/mdc/_chip.scss +91 -0
  50. package/core/tokens/m3/mdc/_circular-progress.scss +29 -0
  51. package/core/tokens/m3/mdc/_dialog.scss +39 -0
  52. package/core/tokens/m3/mdc/_elevated-card.scss +15 -0
  53. package/core/tokens/m3/mdc/_extended-fab.scss +21 -0
  54. package/core/tokens/m3/mdc/_fab-small.scss +21 -0
  55. package/core/tokens/m3/mdc/_fab.scss +21 -0
  56. package/core/tokens/m3/mdc/_filled-button.scss +86 -0
  57. package/core/tokens/m3/mdc/_filled-text-field.scss +92 -0
  58. package/core/tokens/m3/mdc/_form-field.scss +25 -0
  59. package/core/tokens/m3/mdc/_icon-button.scss +39 -0
  60. package/core/tokens/m3/mdc/_linear-progress.scss +32 -0
  61. package/core/tokens/m3/mdc/_list.scss +37 -0
  62. package/core/tokens/m3/mdc/_outlined-button.scss +83 -0
  63. package/core/tokens/m3/mdc/_outlined-card.scss +15 -0
  64. package/core/tokens/m3/mdc/_outlined-text-field.scss +85 -0
  65. package/core/tokens/m3/mdc/_plain-tooltip.scss +15 -0
  66. package/core/tokens/m3/mdc/_protected-button.scss +84 -0
  67. package/core/tokens/m3/mdc/_radio.scss +46 -0
  68. package/core/tokens/m3/mdc/_slider.scss +61 -0
  69. package/core/tokens/m3/mdc/_snack-bar.scss +15 -0
  70. package/core/tokens/m3/mdc/_switch.scss +70 -0
  71. package/core/tokens/m3/mdc/_tab-indicator.scss +33 -0
  72. package/core/tokens/m3/mdc/_tab.scss +15 -0
  73. package/core/tokens/m3/mdc/_text-button.scss +79 -0
  74. package/dialog/index.d.ts +4 -3
  75. package/esm2022/core/version.mjs +1 -1
  76. package/esm2022/dialog/dialog-content-directives.mjs +5 -2
  77. package/esm2022/slide-toggle/slide-toggle.mjs +3 -3
  78. package/fesm2022/core.mjs +1 -1
  79. package/fesm2022/core.mjs.map +1 -1
  80. package/fesm2022/dialog.mjs +4 -1
  81. package/fesm2022/dialog.mjs.map +1 -1
  82. package/fesm2022/slide-toggle.mjs +2 -2
  83. package/fesm2022/slide-toggle.mjs.map +1 -1
  84. package/package.json +2 -2
  85. package/prebuilt-themes/azure-blue.css +1 -1
  86. package/prebuilt-themes/cyan-orange.css +1 -1
  87. package/prebuilt-themes/deeppurple-amber.css +1 -1
  88. package/prebuilt-themes/indigo-pink.css +1 -1
  89. package/prebuilt-themes/magenta-violet.css +1 -1
  90. package/prebuilt-themes/pink-bluegrey.css +1 -1
  91. package/prebuilt-themes/purple-green.css +1 -1
  92. package/prebuilt-themes/rose-red.css +1 -1
  93. package/schematics/ng-add/index.js +1 -1
  94. package/schematics/ng-add/index.mjs +1 -1
  95. package/schematics/ng-generate/m3-theme/index_bundled.js +2 -2
  96. package/schematics/ng-update/index_bundled.js +29 -29
  97. package/core/tokens/_custom-tokens.scss +0 -1918
@@ -0,0 +1,70 @@
1
+ @use 'sass:map';
2
+ @use '../../token-utils';
3
+
4
+ // The prefix used to generate the fully qualified name for tokens in this file.
5
+ $prefix: (mdc, switch);
6
+
7
+ /// Generates the tokens for MDC switch
8
+ /// @param {Map} $systems The MDC system tokens
9
+ /// @param {Boolean} $exclude-hardcoded Whether to exclude hardcoded token values
10
+ /// @param {Map} $token-slots Possible token slots
11
+ /// @return {Map} A set of tokens for the MDC switch
12
+ @function get-tokens($systems, $exclude-hardcoded, $token-slots) {
13
+ $mdc-tokens: token-utils.get-mdc-tokens('switch', $systems, $exclude-hardcoded);
14
+ $variant-tokens: (
15
+ primary: (), // Default, no overrides needed
16
+ secondary: (
17
+ selected-focus-handle-color: map.get($systems, md-sys-color, secondary-container),
18
+ selected-focus-icon-color: map.get($systems, md-sys-color, on-secondary-container),
19
+ selected-focus-state-layer-color: map.get($systems, md-sys-color, secondary),
20
+ selected-focus-track-color: map.get($systems, md-sys-color, secondary),
21
+ selected-handle-color: map.get($systems, md-sys-color, on-secondary),
22
+ selected-hover-handle-color: map.get($systems, md-sys-color, secondary-container),
23
+ selected-hover-icon-color: map.get($systems, md-sys-color, on-secondary-container),
24
+ selected-hover-state-layer-color: map.get($systems, md-sys-color, secondary),
25
+ selected-hover-track-color: map.get($systems, md-sys-color, secondary),
26
+ selected-icon-color: map.get($systems, md-sys-color, on-secondary-container),
27
+ selected-pressed-handle-color: map.get($systems, md-sys-color, secondary-container),
28
+ selected-pressed-icon-color: map.get($systems, md-sys-color, on-secondary-container),
29
+ selected-pressed-state-layer-color: map.get($systems, md-sys-color, secondary),
30
+ selected-pressed-track-color: map.get($systems, md-sys-color, secondary),
31
+ selected-track-color: map.get($systems, md-sys-color, secondary),
32
+ ),
33
+ tertiary: (
34
+ selected-focus-handle-color: map.get($systems, md-sys-color, tertiary-container),
35
+ selected-focus-icon-color: map.get($systems, md-sys-color, on-tertiary-container),
36
+ selected-focus-state-layer-color: map.get($systems, md-sys-color, tertiary),
37
+ selected-focus-track-color: map.get($systems, md-sys-color, tertiary),
38
+ selected-handle-color: map.get($systems, md-sys-color, on-tertiary),
39
+ selected-hover-handle-color: map.get($systems, md-sys-color, tertiary-container),
40
+ selected-hover-icon-color: map.get($systems, md-sys-color, on-tertiary-container),
41
+ selected-hover-state-layer-color: map.get($systems, md-sys-color, tertiary),
42
+ selected-hover-track-color: map.get($systems, md-sys-color, tertiary),
43
+ selected-icon-color: map.get($systems, md-sys-color, on-tertiary-container),
44
+ selected-pressed-handle-color: map.get($systems, md-sys-color, tertiary-container),
45
+ selected-pressed-icon-color: map.get($systems, md-sys-color, on-tertiary-container),
46
+ selected-pressed-state-layer-color: map.get($systems, md-sys-color, tertiary),
47
+ selected-pressed-track-color: map.get($systems, md-sys-color, tertiary),
48
+ selected-track-color: map.get($systems, md-sys-color, tertiary),
49
+ ),
50
+ error: (
51
+ selected-focus-handle-color: map.get($systems, md-sys-color, error-container),
52
+ selected-focus-icon-color: map.get($systems, md-sys-color, on-error-container),
53
+ selected-focus-state-layer-color: map.get($systems, md-sys-color, error),
54
+ selected-focus-track-color: map.get($systems, md-sys-color, error),
55
+ selected-handle-color: map.get($systems, md-sys-color, on-error),
56
+ selected-hover-handle-color: map.get($systems, md-sys-color, error-container),
57
+ selected-hover-icon-color: map.get($systems, md-sys-color, on-error-container),
58
+ selected-hover-state-layer-color: map.get($systems, md-sys-color, error),
59
+ selected-hover-track-color: map.get($systems, md-sys-color, error),
60
+ selected-icon-color: map.get($systems, md-sys-color, on-error-container),
61
+ selected-pressed-handle-color: map.get($systems, md-sys-color, error-container),
62
+ selected-pressed-icon-color: map.get($systems, md-sys-color, on-error-container),
63
+ selected-pressed-state-layer-color: map.get($systems, md-sys-color, error),
64
+ selected-pressed-track-color: map.get($systems, md-sys-color, error),
65
+ selected-track-color: map.get($systems, md-sys-color, error),
66
+ ),
67
+ );
68
+
69
+ @return token-utils.namespace-tokens($prefix, ($mdc-tokens, $variant-tokens), $token-slots);
70
+ }
@@ -0,0 +1,33 @@
1
+ @use 'sass:map';
2
+ @use '../../token-utils';
3
+
4
+ // The prefix used to generate the fully qualified name for tokens in this file.
5
+ $prefix: (mdc, tab-indicator);
6
+
7
+ /// Generates the tokens for MDC tab-indicator
8
+ /// @param {Map} $systems The MDC system tokens
9
+ /// @param {Boolean} $exclude-hardcoded Whether to exclude hardcoded token values
10
+ /// @param {Map} $token-slots Possible token slots
11
+ /// @return {Map} A set of tokens for the MDC tab-indicator
12
+ @function get-tokens($systems, $exclude-hardcoded, $token-slots) {
13
+ $tokens: (
14
+ active-indicator-height: token-utils.hardcode(2px, $exclude-hardcoded),
15
+ active-indicator-shape: token-utils.hardcode(0, $exclude-hardcoded),
16
+ active-indicator-color: map.get($systems, md-sys-color, primary),
17
+ );
18
+ $variant-tokens: (
19
+ // Color variants
20
+ primary: (), // Default, no overrides needed
21
+ secondary: (
22
+ active-indicator-color: map.get($systems, md-sys-color, secondary),
23
+ ),
24
+ tertiary: (
25
+ active-indicator-color: map.get($systems, md-sys-color, tertiary),
26
+ ),
27
+ error: (
28
+ active-indicator-color: map.get($systems, md-sys-color, error),
29
+ )
30
+ );
31
+
32
+ @return token-utils.namespace-tokens($prefix, ($tokens, $variant-tokens), $token-slots);
33
+ }
@@ -0,0 +1,15 @@
1
+ @use '../../token-utils';
2
+
3
+ // The prefix used to generate the fully qualified name for tokens in this file.
4
+ $prefix: (mdc, tab);
5
+
6
+ /// Generates the tokens for MDC tab
7
+ /// @param {Map} $systems The MDC system tokens
8
+ /// @param {Boolean} $exclude-hardcoded Whether to exclude hardcoded token values
9
+ /// @param {Map} $token-slots Possible token slots
10
+ /// @return {Map} A set of tokens for the MDC tab
11
+ @function get-tokens($systems, $exclude-hardcoded, $token-slots) {
12
+ $mdc-tokens: token-utils.get-mdc-tokens('secondary-navigation-tab', $systems, $exclude-hardcoded);
13
+
14
+ @return token-utils.namespace-tokens($prefix, $mdc-tokens, $token-slots);
15
+ }
@@ -0,0 +1,79 @@
1
+ @use 'sass:map';
2
+ @use 'sass:meta';
3
+ @use '../../token-utils';
4
+
5
+ // The prefix used to generate the fully qualified name for tokens in this file.
6
+ $prefix: (mdc, text-button);
7
+
8
+ /// Generates the tokens for MDC text-button
9
+ /// @param {Map} $systems The MDC system tokens
10
+ /// @param {Boolean} $exclude-hardcoded Whether to exclude hardcoded token values
11
+ /// @param {Map} $token-slots Possible token slots
12
+ /// @return {Map} A set of tokens for the MDC text-button
13
+ @function get-tokens($systems, $exclude-hardcoded, $token-slots) {
14
+ $mdc-tokens: token-utils.get-mdc-tokens('text-button', $systems, $exclude-hardcoded);
15
+ $variant-tokens: (
16
+ primary: (), // Default, no overrides needed.
17
+ secondary: (
18
+ focus-label-text-color: map.get($systems, md-sys-color, secondary),
19
+ focus-state-layer-color: map.get($systems, md-sys-color, secondary),
20
+ hover-label-text-color: map.get($systems, md-sys-color, secondary),
21
+ hover-state-layer-color: map.get($systems, md-sys-color, secondary),
22
+ label-text-color: map.get($systems, md-sys-color, secondary),
23
+ pressed-label-text-color: map.get($systems, md-sys-color, secondary),
24
+ pressed-state-layer-color: map.get($systems, md-sys-color, secondary),
25
+ with-icon-focus-icon-color: map.get($systems, md-sys-color, secondary),
26
+ with-icon-hover-icon-color: map.get($systems, md-sys-color, secondary),
27
+ with-icon-icon-color: map.get($systems, md-sys-color, secondary),
28
+ with-icon-pressed-icon-color: map.get($systems, md-sys-color, secondary)
29
+ ),
30
+ tertiary: (
31
+ focus-label-text-color: map.get($systems, md-sys-color, tertiary),
32
+ focus-state-layer-color: map.get($systems, md-sys-color, tertiary),
33
+ hover-label-text-color: map.get($systems, md-sys-color, tertiary),
34
+ hover-state-layer-color: map.get($systems, md-sys-color, tertiary),
35
+ label-text-color: map.get($systems, md-sys-color, tertiary),
36
+ pressed-label-text-color: map.get($systems, md-sys-color, tertiary),
37
+ pressed-state-layer-color: map.get($systems, md-sys-color, tertiary),
38
+ with-icon-focus-icon-color: map.get($systems, md-sys-color, tertiary),
39
+ with-icon-hover-icon-color: map.get($systems, md-sys-color, tertiary),
40
+ with-icon-icon-color: map.get($systems, md-sys-color, tertiary),
41
+ with-icon-pressed-icon-color: map.get($systems, md-sys-color, tertiary)
42
+ ),
43
+ error: (
44
+ focus-label-text-color: map.get($systems, md-sys-color, error),
45
+ focus-state-layer-color: map.get($systems, md-sys-color, error),
46
+ hover-label-text-color: map.get($systems, md-sys-color, error),
47
+ hover-state-layer-color: map.get($systems, md-sys-color, error),
48
+ label-text-color: map.get($systems, md-sys-color, error),
49
+ pressed-label-text-color: map.get($systems, md-sys-color, error),
50
+ pressed-state-layer-color: map.get($systems, md-sys-color, error),
51
+ with-icon-focus-icon-color: map.get($systems, md-sys-color, error),
52
+ with-icon-hover-icon-color: map.get($systems, md-sys-color, error),
53
+ with-icon-icon-color: map.get($systems, md-sys-color, error),
54
+ with-icon-pressed-icon-color: map.get($systems, md-sys-color, error)
55
+ )
56
+ );
57
+
58
+ @return token-utils.namespace-tokens($prefix, (
59
+ _fix-tokens($mdc-tokens),
60
+ token-utils.map-values($variant-tokens, meta.get-function(_fix-tokens))
61
+ ), $token-slots);
62
+ }
63
+
64
+
65
+ /// Fixes inconsistent values in the text button tokens so that they can produce valid styles.
66
+ /// @param {Map} $initial-tokens Map of text button tokens currently being generated.
67
+ /// @return {Map} The given tokens, with the invalid values replaced with valid ones.
68
+ @function _fix-tokens($initial-tokens) {
69
+ // Need to get the hardcoded values, because they include opacities that are used for the disabled
70
+ // state.
71
+ $hardcoded-tokens: token-utils.get-mdc-tokens('text-button', (), false);
72
+
73
+ @return token-utils.combine-color-tokens($initial-tokens, $hardcoded-tokens, (
74
+ (
75
+ color: disabled-label-text-color,
76
+ opacity: disabled-label-text-opacity,
77
+ ),
78
+ ));
79
+ }
package/dialog/index.d.ts CHANGED
@@ -13,7 +13,8 @@ import { FocusMonitor } from '@angular/cdk/a11y';
13
13
  import { FocusOrigin } from '@angular/cdk/a11y';
14
14
  import { FocusTrapFactory } from '@angular/cdk/a11y';
15
15
  import * as i0 from '@angular/core';
16
- import * as i1 from '@angular/cdk/dialog';
16
+ import * as i1 from '@angular/cdk/scrolling';
17
+ import * as i1_2 from '@angular/cdk/dialog';
17
18
  import * as i2 from '@angular/cdk/overlay';
18
19
  import * as i3 from '@angular/cdk/portal';
19
20
  import * as i4 from '@angular/material/core';
@@ -395,7 +396,7 @@ export declare class MatDialogContainer extends CdkDialogContainer<MatDialogConf
395
396
  */
396
397
  export declare class MatDialogContent {
397
398
  static ɵfac: i0.ɵɵFactoryDeclaration<MatDialogContent, never>;
398
- static ɵdir: i0.ɵɵDirectiveDeclaration<MatDialogContent, "[mat-dialog-content], mat-dialog-content, [matDialogContent]", never, {}, {}, never, never, true, never>;
399
+ static ɵdir: i0.ɵɵDirectiveDeclaration<MatDialogContent, "[mat-dialog-content], mat-dialog-content, [matDialogContent]", never, {}, {}, never, never, true, [{ directive: typeof i1.CdkScrollable; inputs: {}; outputs: {}; }]>;
399
400
  }
400
401
 
401
402
  declare abstract class MatDialogLayoutSection implements OnInit, OnDestroy {
@@ -413,7 +414,7 @@ declare abstract class MatDialogLayoutSection implements OnInit, OnDestroy {
413
414
 
414
415
  export declare class MatDialogModule {
415
416
  static ɵfac: i0.ɵɵFactoryDeclaration<MatDialogModule, never>;
416
- static ɵmod: i0.ɵɵNgModuleDeclaration<MatDialogModule, never, [typeof i1.DialogModule, typeof i2.OverlayModule, typeof i3.PortalModule, typeof i4.MatCommonModule, typeof i5.MatDialogContainer, typeof i6.MatDialogClose, typeof i6.MatDialogTitle, typeof i6.MatDialogActions, typeof i6.MatDialogContent], [typeof i4.MatCommonModule, typeof i5.MatDialogContainer, typeof i6.MatDialogClose, typeof i6.MatDialogTitle, typeof i6.MatDialogActions, typeof i6.MatDialogContent]>;
417
+ static ɵmod: i0.ɵɵNgModuleDeclaration<MatDialogModule, never, [typeof i1_2.DialogModule, typeof i2.OverlayModule, typeof i3.PortalModule, typeof i4.MatCommonModule, typeof i5.MatDialogContainer, typeof i6.MatDialogClose, typeof i6.MatDialogTitle, typeof i6.MatDialogActions, typeof i6.MatDialogContent], [typeof i4.MatCommonModule, typeof i5.MatDialogContainer, typeof i6.MatDialogClose, typeof i6.MatDialogTitle, typeof i6.MatDialogActions, typeof i6.MatDialogContent]>;
417
418
  static ɵinj: i0.ɵɵInjectorDeclaration<MatDialogModule>;
418
419
  }
419
420
 
@@ -7,5 +7,5 @@
7
7
  */
8
8
  import { Version } from '@angular/core';
9
9
  /** Current version of Angular Material. */
10
- export const VERSION = new Version('18.0.0-next.6');
10
+ export const VERSION = new Version('18.0.0-rc.0');
11
11
  //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidmVyc2lvbi5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3NyYy9tYXRlcmlhbC9jb3JlL3ZlcnNpb24udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7Ozs7OztHQU1HO0FBRUgsT0FBTyxFQUFDLE9BQU8sRUFBQyxNQUFNLGVBQWUsQ0FBQztBQUV0QywyQ0FBMkM7QUFDM0MsTUFBTSxDQUFDLE1BQU0sT0FBTyxHQUFHLElBQUksT0FBTyxDQUFDLG1CQUFtQixDQUFDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEBsaWNlbnNlXG4gKiBDb3B5cmlnaHQgR29vZ2xlIExMQyBBbGwgUmlnaHRzIFJlc2VydmVkLlxuICpcbiAqIFVzZSBvZiB0aGlzIHNvdXJjZSBjb2RlIGlzIGdvdmVybmVkIGJ5IGFuIE1JVC1zdHlsZSBsaWNlbnNlIHRoYXQgY2FuIGJlXG4gKiBmb3VuZCBpbiB0aGUgTElDRU5TRSBmaWxlIGF0IGh0dHBzOi8vYW5ndWxhci5pby9saWNlbnNlXG4gKi9cblxuaW1wb3J0IHtWZXJzaW9ufSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuLyoqIEN1cnJlbnQgdmVyc2lvbiBvZiBBbmd1bGFyIE1hdGVyaWFsLiAqL1xuZXhwb3J0IGNvbnN0IFZFUlNJT04gPSBuZXcgVmVyc2lvbignMC4wLjAtUExBQ0VIT0xERVInKTtcbiJdfQ==
@@ -6,11 +6,13 @@
6
6
  * found in the LICENSE file at https://angular.io/license
7
7
  */
8
8
  import { Directive, ElementRef, Input, Optional, } from '@angular/core';
9
+ import { CdkScrollable } from '@angular/cdk/scrolling';
9
10
  import { MatDialog } from './dialog';
10
11
  import { _closeDialogVia, MatDialogRef } from './dialog-ref';
11
12
  import * as i0 from "@angular/core";
12
13
  import * as i1 from "./dialog-ref";
13
14
  import * as i2 from "./dialog";
15
+ import * as i3 from "@angular/cdk/scrolling";
14
16
  /** Counter used to generate unique IDs for dialog elements. */
15
17
  let dialogElementUid = 0;
16
18
  /**
@@ -155,7 +157,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.0-next.5",
155
157
  */
156
158
  export class MatDialogContent {
157
159
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.0-next.5", ngImport: i0, type: MatDialogContent, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
158
- static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.0.0-next.5", type: MatDialogContent, isStandalone: true, selector: "[mat-dialog-content], mat-dialog-content, [matDialogContent]", host: { classAttribute: "mat-mdc-dialog-content mdc-dialog__content" }, ngImport: i0 }); }
160
+ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.0.0-next.5", type: MatDialogContent, isStandalone: true, selector: "[mat-dialog-content], mat-dialog-content, [matDialogContent]", host: { classAttribute: "mat-mdc-dialog-content mdc-dialog__content" }, hostDirectives: [{ directive: i3.CdkScrollable }], ngImport: i0 }); }
159
161
  }
160
162
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.0-next.5", ngImport: i0, type: MatDialogContent, decorators: [{
161
163
  type: Directive,
@@ -163,6 +165,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.0-next.5",
163
165
  selector: `[mat-dialog-content], mat-dialog-content, [matDialogContent]`,
164
166
  host: { 'class': 'mat-mdc-dialog-content mdc-dialog__content' },
165
167
  standalone: true,
168
+ hostDirectives: [CdkScrollable],
166
169
  }]
167
170
  }] });
168
171
  /**
@@ -206,4 +209,4 @@ function getClosestDialog(element, openDialogs) {
206
209
  }
207
210
  return parent ? openDialogs.find(dialog => dialog.id === parent.id) : null;
208
211
  }
209
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dialog-content-directives.js","sourceRoot":"","sources":["../../../../../../src/material/dialog/dialog-content-directives.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 {\n  Directive,\n  ElementRef,\n  Input,\n  OnChanges,\n  OnDestroy,\n  OnInit,\n  Optional,\n  SimpleChanges,\n} from '@angular/core';\n\nimport {MatDialog} from './dialog';\nimport {_closeDialogVia, MatDialogRef} from './dialog-ref';\n\n/** Counter used to generate unique IDs for dialog elements. */\nlet dialogElementUid = 0;\n\n/**\n * Button that will close the current dialog.\n */\n@Directive({\n  selector: '[mat-dialog-close], [matDialogClose]',\n  exportAs: 'matDialogClose',\n  standalone: true,\n  host: {\n    '(click)': '_onButtonClick($event)',\n    '[attr.aria-label]': 'ariaLabel || null',\n    '[attr.type]': 'type',\n  },\n})\nexport class MatDialogClose implements OnInit, OnChanges {\n  /** Screen-reader label for the button. */\n  @Input('aria-label') ariaLabel: string;\n\n  /** Default to \"button\" to prevents accidental form submits. */\n  @Input() type: 'submit' | 'button' | 'reset' = 'button';\n\n  /** Dialog close input. */\n  @Input('mat-dialog-close') dialogResult: any;\n\n  @Input('matDialogClose') _matDialogClose: any;\n\n  constructor(\n    // The dialog title directive is always used in combination with a `MatDialogRef`.\n    // tslint:disable-next-line: lightweight-tokens\n    @Optional() public dialogRef: MatDialogRef<any>,\n    private _elementRef: ElementRef<HTMLElement>,\n    private _dialog: MatDialog,\n  ) {}\n\n  ngOnInit() {\n    if (!this.dialogRef) {\n      // When this directive is included in a dialog via TemplateRef (rather than being\n      // in a Component), the DialogRef isn't available via injection because embedded\n      // views cannot be given a custom injector. Instead, we look up the DialogRef by\n      // ID. This must occur in `onInit`, as the ID binding for the dialog container won't\n      // be resolved at constructor time.\n      this.dialogRef = getClosestDialog(this._elementRef, this._dialog.openDialogs)!;\n    }\n  }\n\n  ngOnChanges(changes: SimpleChanges) {\n    const proxiedChange = changes['_matDialogClose'] || changes['_matDialogCloseResult'];\n\n    if (proxiedChange) {\n      this.dialogResult = proxiedChange.currentValue;\n    }\n  }\n\n  _onButtonClick(event: MouseEvent) {\n    // Determinate the focus origin using the click event, because using the FocusMonitor will\n    // result in incorrect origins. Most of the time, close buttons will be auto focused in the\n    // dialog, and therefore clicking the button won't result in a focus change. This means that\n    // the FocusMonitor won't detect any origin change, and will always output `program`.\n    _closeDialogVia(\n      this.dialogRef,\n      event.screenX === 0 && event.screenY === 0 ? 'keyboard' : 'mouse',\n      this.dialogResult,\n    );\n  }\n}\n\n@Directive({standalone: true})\nexport abstract class MatDialogLayoutSection implements OnInit, OnDestroy {\n  constructor(\n    // The dialog title directive is always used in combination with a `MatDialogRef`.\n    // tslint:disable-next-line: lightweight-tokens\n    @Optional() protected _dialogRef: MatDialogRef<any>,\n    private _elementRef: ElementRef<HTMLElement>,\n    private _dialog: MatDialog,\n  ) {}\n\n  protected abstract _onAdd(): void;\n  protected abstract _onRemove(): void;\n\n  ngOnInit() {\n    if (!this._dialogRef) {\n      this._dialogRef = getClosestDialog(this._elementRef, this._dialog.openDialogs)!;\n    }\n\n    if (this._dialogRef) {\n      Promise.resolve().then(() => {\n        this._onAdd();\n      });\n    }\n  }\n\n  ngOnDestroy() {\n    // Note: we null check because there are some internal\n    // tests that are mocking out `MatDialogRef` incorrectly.\n    const instance = this._dialogRef?._containerInstance;\n\n    if (instance) {\n      Promise.resolve().then(() => {\n        this._onRemove();\n      });\n    }\n  }\n}\n\n/**\n * Title of a dialog element. Stays fixed to the top of the dialog when scrolling.\n */\n@Directive({\n  selector: '[mat-dialog-title], [matDialogTitle]',\n  exportAs: 'matDialogTitle',\n  standalone: true,\n  host: {\n    'class': 'mat-mdc-dialog-title mdc-dialog__title',\n    '[id]': 'id',\n  },\n})\nexport class MatDialogTitle extends MatDialogLayoutSection {\n  @Input() id: string = `mat-mdc-dialog-title-${dialogElementUid++}`;\n\n  protected _onAdd() {\n    // Note: we null check the queue, because there are some internal\n    // tests that are mocking out `MatDialogRef` incorrectly.\n    this._dialogRef._containerInstance?._addAriaLabelledBy?.(this.id);\n  }\n\n  protected override _onRemove(): void {\n    this._dialogRef?._containerInstance?._removeAriaLabelledBy?.(this.id);\n  }\n}\n\n/**\n * Scrollable content container of a dialog.\n */\n@Directive({\n  selector: `[mat-dialog-content], mat-dialog-content, [matDialogContent]`,\n  host: {'class': 'mat-mdc-dialog-content mdc-dialog__content'},\n  standalone: true,\n})\nexport class MatDialogContent {}\n\n/**\n * Container for the bottom action buttons in a dialog.\n * Stays fixed to the bottom when scrolling.\n */\n@Directive({\n  selector: `[mat-dialog-actions], mat-dialog-actions, [matDialogActions]`,\n  standalone: true,\n  host: {\n    'class': 'mat-mdc-dialog-actions mdc-dialog__actions',\n    '[class.mat-mdc-dialog-actions-align-start]': 'align === \"start\"',\n    '[class.mat-mdc-dialog-actions-align-center]': 'align === \"center\"',\n    '[class.mat-mdc-dialog-actions-align-end]': 'align === \"end\"',\n  },\n})\nexport class MatDialogActions extends MatDialogLayoutSection {\n  /**\n   * Horizontal alignment of action buttons.\n   */\n  @Input() align?: 'start' | 'center' | 'end';\n\n  protected _onAdd() {\n    this._dialogRef._containerInstance?._updateActionSectionCount?.(1);\n  }\n\n  protected override _onRemove(): void {\n    this._dialogRef._containerInstance?._updateActionSectionCount?.(-1);\n  }\n}\n\n/**\n * Finds the closest MatDialogRef to an element by looking at the DOM.\n * @param element Element relative to which to look for a dialog.\n * @param openDialogs References to the currently-open dialogs.\n */\nfunction getClosestDialog(element: ElementRef<HTMLElement>, openDialogs: MatDialogRef<any>[]) {\n  let parent: HTMLElement | null = element.nativeElement.parentElement;\n\n  while (parent && !parent.classList.contains('mat-mdc-dialog-container')) {\n    parent = parent.parentElement;\n  }\n\n  return parent ? openDialogs.find(dialog => dialog.id === parent!.id) : null;\n}\n"]}
212
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dialog-content-directives.js","sourceRoot":"","sources":["../../../../../../src/material/dialog/dialog-content-directives.ts"],"names":[],"mappings":"AAAA;;;;;;GAMG;AAEH,OAAO,EACL,SAAS,EACT,UAAU,EACV,KAAK,EAIL,QAAQ,GAET,MAAM,eAAe,CAAC;AACvB,OAAO,EAAC,aAAa,EAAC,MAAM,wBAAwB,CAAC;AAErD,OAAO,EAAC,SAAS,EAAC,MAAM,UAAU,CAAC;AACnC,OAAO,EAAC,eAAe,EAAE,YAAY,EAAC,MAAM,cAAc,CAAC;;;;;AAE3D,+DAA+D;AAC/D,IAAI,gBAAgB,GAAG,CAAC,CAAC;AAEzB;;GAEG;AAWH,MAAM,OAAO,cAAc;IAYzB;IACE,kFAAkF;IAClF,+CAA+C;IAC5B,SAA4B,EACvC,WAAoC,EACpC,OAAkB;QAFP,cAAS,GAAT,SAAS,CAAmB;QACvC,gBAAW,GAAX,WAAW,CAAyB;QACpC,YAAO,GAAP,OAAO,CAAW;QAb5B,+DAA+D;QACtD,SAAI,GAAkC,QAAQ,CAAC;IAarD,CAAC;IAEJ,QAAQ;QACN,IAAI,CAAC,IAAI,CAAC,SAAS,EAAE,CAAC;YACpB,iFAAiF;YACjF,gFAAgF;YAChF,gFAAgF;YAChF,oFAAoF;YACpF,mCAAmC;YACnC,IAAI,CAAC,SAAS,GAAG,gBAAgB,CAAC,IAAI,CAAC,WAAW,EAAE,IAAI,CAAC,OAAO,CAAC,WAAW,CAAE,CAAC;QACjF,CAAC;IACH,CAAC;IAED,WAAW,CAAC,OAAsB;QAChC,MAAM,aAAa,GAAG,OAAO,CAAC,iBAAiB,CAAC,IAAI,OAAO,CAAC,uBAAuB,CAAC,CAAC;QAErF,IAAI,aAAa,EAAE,CAAC;YAClB,IAAI,CAAC,YAAY,GAAG,aAAa,CAAC,YAAY,CAAC;QACjD,CAAC;IACH,CAAC;IAED,cAAc,CAAC,KAAiB;QAC9B,0FAA0F;QAC1F,2FAA2F;QAC3F,4FAA4F;QAC5F,qFAAqF;QACrF,eAAe,CACb,IAAI,CAAC,SAAS,EACd,KAAK,CAAC,OAAO,KAAK,CAAC,IAAI,KAAK,CAAC,OAAO,KAAK,CAAC,CAAC,CAAC,CAAC,UAAU,CAAC,CAAC,CAAC,OAAO,EACjE,IAAI,CAAC,YAAY,CAClB,CAAC;IACJ,CAAC;qHAjDU,cAAc;yGAAd,cAAc;;kGAAd,cAAc;kBAV1B,SAAS;mBAAC;oBACT,QAAQ,EAAE,sCAAsC;oBAChD,QAAQ,EAAE,gBAAgB;oBAC1B,UAAU,EAAE,IAAI;oBAChB,IAAI,EAAE;wBACJ,SAAS,EAAE,wBAAwB;wBACnC,mBAAmB,EAAE,mBAAmB;wBACxC,aAAa,EAAE,MAAM;qBACtB;iBACF;;0BAgBI,QAAQ;0FAbU,SAAS;sBAA7B,KAAK;uBAAC,YAAY;gBAGV,IAAI;sBAAZ,KAAK;gBAGqB,YAAY;sBAAtC,KAAK;uBAAC,kBAAkB;gBAEA,eAAe;sBAAvC,KAAK;uBAAC,gBAAgB;;AA2CzB,MAAM,OAAgB,sBAAsB;IAC1C;IACE,kFAAkF;IAClF,+CAA+C;IACzB,UAA6B,EAC3C,WAAoC,EACpC,OAAkB;QAFJ,eAAU,GAAV,UAAU,CAAmB;QAC3C,gBAAW,GAAX,WAAW,CAAyB;QACpC,YAAO,GAAP,OAAO,CAAW;IACzB,CAAC;IAKJ,QAAQ;QACN,IAAI,CAAC,IAAI,CAAC,UAAU,EAAE,CAAC;YACrB,IAAI,CAAC,UAAU,GAAG,gBAAgB,CAAC,IAAI,CAAC,WAAW,EAAE,IAAI,CAAC,OAAO,CAAC,WAAW,CAAE,CAAC;QAClF,CAAC;QAED,IAAI,IAAI,CAAC,UAAU,EAAE,CAAC;YACpB,OAAO,CAAC,OAAO,EAAE,CAAC,IAAI,CAAC,GAAG,EAAE;gBAC1B,IAAI,CAAC,MAAM,EAAE,CAAC;YAChB,CAAC,CAAC,CAAC;QACL,CAAC;IACH,CAAC;IAED,WAAW;QACT,sDAAsD;QACtD,yDAAyD;QACzD,MAAM,QAAQ,GAAG,IAAI,CAAC,UAAU,EAAE,kBAAkB,CAAC;QAErD,IAAI,QAAQ,EAAE,CAAC;YACb,OAAO,CAAC,OAAO,EAAE,CAAC,IAAI,CAAC,GAAG,EAAE;gBAC1B,IAAI,CAAC,SAAS,EAAE,CAAC;YACnB,CAAC,CAAC,CAAC;QACL,CAAC;IACH,CAAC;qHAlCmB,sBAAsB;yGAAtB,sBAAsB;;kGAAtB,sBAAsB;kBAD3C,SAAS;mBAAC,EAAC,UAAU,EAAE,IAAI,EAAC;;0BAKxB,QAAQ;;AAiCb;;GAEG;AAUH,MAAM,OAAO,cAAe,SAAQ,sBAAsB;IAT1D;;QAUW,OAAE,GAAW,wBAAwB,gBAAgB,EAAE,EAAE,CAAC;KAWpE;IATW,MAAM;QACd,iEAAiE;QACjE,yDAAyD;QACzD,IAAI,CAAC,UAAU,CAAC,kBAAkB,EAAE,kBAAkB,EAAE,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;IACpE,CAAC;IAEkB,SAAS;QAC1B,IAAI,CAAC,UAAU,EAAE,kBAAkB,EAAE,qBAAqB,EAAE,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;IACxE,CAAC;qHAXU,cAAc;yGAAd,cAAc;;kGAAd,cAAc;kBAT1B,SAAS;mBAAC;oBACT,QAAQ,EAAE,sCAAsC;oBAChD,QAAQ,EAAE,gBAAgB;oBAC1B,UAAU,EAAE,IAAI;oBAChB,IAAI,EAAE;wBACJ,OAAO,EAAE,wCAAwC;wBACjD,MAAM,EAAE,IAAI;qBACb;iBACF;8BAEU,EAAE;sBAAV,KAAK;;AAaR;;GAEG;AAOH,MAAM,OAAO,gBAAgB;qHAAhB,gBAAgB;yGAAhB,gBAAgB;;kGAAhB,gBAAgB;kBAN5B,SAAS;mBAAC;oBACT,QAAQ,EAAE,8DAA8D;oBACxE,IAAI,EAAE,EAAC,OAAO,EAAE,4CAA4C,EAAC;oBAC7D,UAAU,EAAE,IAAI;oBAChB,cAAc,EAAE,CAAC,aAAa,CAAC;iBAChC;;AAGD;;;GAGG;AAWH,MAAM,OAAO,gBAAiB,SAAQ,sBAAsB;IAMhD,MAAM;QACd,IAAI,CAAC,UAAU,CAAC,kBAAkB,EAAE,yBAAyB,EAAE,CAAC,CAAC,CAAC,CAAC;IACrE,CAAC;IAEkB,SAAS;QAC1B,IAAI,CAAC,UAAU,CAAC,kBAAkB,EAAE,yBAAyB,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC;IACtE,CAAC;qHAZU,gBAAgB;yGAAhB,gBAAgB;;kGAAhB,gBAAgB;kBAV5B,SAAS;mBAAC;oBACT,QAAQ,EAAE,8DAA8D;oBACxE,UAAU,EAAE,IAAI;oBAChB,IAAI,EAAE;wBACJ,OAAO,EAAE,4CAA4C;wBACrD,4CAA4C,EAAE,mBAAmB;wBACjE,6CAA6C,EAAE,oBAAoB;wBACnE,0CAA0C,EAAE,iBAAiB;qBAC9D;iBACF;8BAKU,KAAK;sBAAb,KAAK;;AAWR;;;;GAIG;AACH,SAAS,gBAAgB,CAAC,OAAgC,EAAE,WAAgC;IAC1F,IAAI,MAAM,GAAuB,OAAO,CAAC,aAAa,CAAC,aAAa,CAAC;IAErE,OAAO,MAAM,IAAI,CAAC,MAAM,CAAC,SAAS,CAAC,QAAQ,CAAC,0BAA0B,CAAC,EAAE,CAAC;QACxE,MAAM,GAAG,MAAM,CAAC,aAAa,CAAC;IAChC,CAAC;IAED,OAAO,MAAM,CAAC,CAAC,CAAC,WAAW,CAAC,IAAI,CAAC,MAAM,CAAC,EAAE,CAAC,MAAM,CAAC,EAAE,KAAK,MAAO,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC;AAC9E,CAAC","sourcesContent":["/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\n\nimport {\n  Directive,\n  ElementRef,\n  Input,\n  OnChanges,\n  OnDestroy,\n  OnInit,\n  Optional,\n  SimpleChanges,\n} from '@angular/core';\nimport {CdkScrollable} from '@angular/cdk/scrolling';\n\nimport {MatDialog} from './dialog';\nimport {_closeDialogVia, MatDialogRef} from './dialog-ref';\n\n/** Counter used to generate unique IDs for dialog elements. */\nlet dialogElementUid = 0;\n\n/**\n * Button that will close the current dialog.\n */\n@Directive({\n  selector: '[mat-dialog-close], [matDialogClose]',\n  exportAs: 'matDialogClose',\n  standalone: true,\n  host: {\n    '(click)': '_onButtonClick($event)',\n    '[attr.aria-label]': 'ariaLabel || null',\n    '[attr.type]': 'type',\n  },\n})\nexport class MatDialogClose implements OnInit, OnChanges {\n  /** Screen-reader label for the button. */\n  @Input('aria-label') ariaLabel: string;\n\n  /** Default to \"button\" to prevents accidental form submits. */\n  @Input() type: 'submit' | 'button' | 'reset' = 'button';\n\n  /** Dialog close input. */\n  @Input('mat-dialog-close') dialogResult: any;\n\n  @Input('matDialogClose') _matDialogClose: any;\n\n  constructor(\n    // The dialog title directive is always used in combination with a `MatDialogRef`.\n    // tslint:disable-next-line: lightweight-tokens\n    @Optional() public dialogRef: MatDialogRef<any>,\n    private _elementRef: ElementRef<HTMLElement>,\n    private _dialog: MatDialog,\n  ) {}\n\n  ngOnInit() {\n    if (!this.dialogRef) {\n      // When this directive is included in a dialog via TemplateRef (rather than being\n      // in a Component), the DialogRef isn't available via injection because embedded\n      // views cannot be given a custom injector. Instead, we look up the DialogRef by\n      // ID. This must occur in `onInit`, as the ID binding for the dialog container won't\n      // be resolved at constructor time.\n      this.dialogRef = getClosestDialog(this._elementRef, this._dialog.openDialogs)!;\n    }\n  }\n\n  ngOnChanges(changes: SimpleChanges) {\n    const proxiedChange = changes['_matDialogClose'] || changes['_matDialogCloseResult'];\n\n    if (proxiedChange) {\n      this.dialogResult = proxiedChange.currentValue;\n    }\n  }\n\n  _onButtonClick(event: MouseEvent) {\n    // Determinate the focus origin using the click event, because using the FocusMonitor will\n    // result in incorrect origins. Most of the time, close buttons will be auto focused in the\n    // dialog, and therefore clicking the button won't result in a focus change. This means that\n    // the FocusMonitor won't detect any origin change, and will always output `program`.\n    _closeDialogVia(\n      this.dialogRef,\n      event.screenX === 0 && event.screenY === 0 ? 'keyboard' : 'mouse',\n      this.dialogResult,\n    );\n  }\n}\n\n@Directive({standalone: true})\nexport abstract class MatDialogLayoutSection implements OnInit, OnDestroy {\n  constructor(\n    // The dialog title directive is always used in combination with a `MatDialogRef`.\n    // tslint:disable-next-line: lightweight-tokens\n    @Optional() protected _dialogRef: MatDialogRef<any>,\n    private _elementRef: ElementRef<HTMLElement>,\n    private _dialog: MatDialog,\n  ) {}\n\n  protected abstract _onAdd(): void;\n  protected abstract _onRemove(): void;\n\n  ngOnInit() {\n    if (!this._dialogRef) {\n      this._dialogRef = getClosestDialog(this._elementRef, this._dialog.openDialogs)!;\n    }\n\n    if (this._dialogRef) {\n      Promise.resolve().then(() => {\n        this._onAdd();\n      });\n    }\n  }\n\n  ngOnDestroy() {\n    // Note: we null check because there are some internal\n    // tests that are mocking out `MatDialogRef` incorrectly.\n    const instance = this._dialogRef?._containerInstance;\n\n    if (instance) {\n      Promise.resolve().then(() => {\n        this._onRemove();\n      });\n    }\n  }\n}\n\n/**\n * Title of a dialog element. Stays fixed to the top of the dialog when scrolling.\n */\n@Directive({\n  selector: '[mat-dialog-title], [matDialogTitle]',\n  exportAs: 'matDialogTitle',\n  standalone: true,\n  host: {\n    'class': 'mat-mdc-dialog-title mdc-dialog__title',\n    '[id]': 'id',\n  },\n})\nexport class MatDialogTitle extends MatDialogLayoutSection {\n  @Input() id: string = `mat-mdc-dialog-title-${dialogElementUid++}`;\n\n  protected _onAdd() {\n    // Note: we null check the queue, because there are some internal\n    // tests that are mocking out `MatDialogRef` incorrectly.\n    this._dialogRef._containerInstance?._addAriaLabelledBy?.(this.id);\n  }\n\n  protected override _onRemove(): void {\n    this._dialogRef?._containerInstance?._removeAriaLabelledBy?.(this.id);\n  }\n}\n\n/**\n * Scrollable content container of a dialog.\n */\n@Directive({\n  selector: `[mat-dialog-content], mat-dialog-content, [matDialogContent]`,\n  host: {'class': 'mat-mdc-dialog-content mdc-dialog__content'},\n  standalone: true,\n  hostDirectives: [CdkScrollable],\n})\nexport class MatDialogContent {}\n\n/**\n * Container for the bottom action buttons in a dialog.\n * Stays fixed to the bottom when scrolling.\n */\n@Directive({\n  selector: `[mat-dialog-actions], mat-dialog-actions, [matDialogActions]`,\n  standalone: true,\n  host: {\n    'class': 'mat-mdc-dialog-actions mdc-dialog__actions',\n    '[class.mat-mdc-dialog-actions-align-start]': 'align === \"start\"',\n    '[class.mat-mdc-dialog-actions-align-center]': 'align === \"center\"',\n    '[class.mat-mdc-dialog-actions-align-end]': 'align === \"end\"',\n  },\n})\nexport class MatDialogActions extends MatDialogLayoutSection {\n  /**\n   * Horizontal alignment of action buttons.\n   */\n  @Input() align?: 'start' | 'center' | 'end';\n\n  protected _onAdd() {\n    this._dialogRef._containerInstance?._updateActionSectionCount?.(1);\n  }\n\n  protected override _onRemove(): void {\n    this._dialogRef._containerInstance?._updateActionSectionCount?.(-1);\n  }\n}\n\n/**\n * Finds the closest MatDialogRef to an element by looking at the DOM.\n * @param element Element relative to which to look for a dialog.\n * @param openDialogs References to the currently-open dialogs.\n */\nfunction getClosestDialog(element: ElementRef<HTMLElement>, openDialogs: MatDialogRef<any>[]) {\n  let parent: HTMLElement | null = element.nativeElement.parentElement;\n\n  while (parent && !parent.classList.contains('mat-mdc-dialog-container')) {\n    parent = parent.parentElement;\n  }\n\n  return parent ? openDialogs.find(dialog => dialog.id === parent!.id) : null;\n}\n"]}