@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.
- package/_index.scss +1 -1
- package/core/tokens/_m3-tokens.scss +8 -878
- package/core/tokens/_token-utils.scss +151 -0
- package/core/tokens/m2/mat/_switch.scss +1 -0
- package/core/tokens/m3/_index.scss +161 -0
- package/core/tokens/m3/mat/_app.scss +19 -0
- package/core/tokens/m3/mat/_autocomplete.scss +22 -0
- package/core/tokens/m3/mat/_badge.scss +77 -0
- package/core/tokens/m3/mat/_bottom-sheet.scss +24 -0
- package/core/tokens/m3/mat/_card.scss +24 -0
- package/core/tokens/m3/mat/_checkbox.scss +21 -0
- package/core/tokens/m3/mat/_chip.scss +46 -0
- package/core/tokens/m3/mat/_datepicker.scss +123 -0
- package/core/tokens/m3/mat/_dialog.scss +30 -0
- package/core/tokens/m3/mat/_divider.scss +19 -0
- package/core/tokens/m3/mat/_expansion.scss +41 -0
- package/core/tokens/m3/mat/_fab-small.scss +50 -0
- package/core/tokens/m3/mat/_fab.scss +50 -0
- package/core/tokens/m3/mat/_filled-button.scss +54 -0
- package/core/tokens/m3/mat/_form-field.scss +59 -0
- package/core/tokens/m3/mat/_full-pseudo-checkbox.scss +42 -0
- package/core/tokens/m3/mat/_grid-list.scss +21 -0
- package/core/tokens/m3/mat/_icon-button.scss +27 -0
- package/core/tokens/m3/mat/_icon.scss +33 -0
- package/core/tokens/m3/mat/_list.scss +19 -0
- package/core/tokens/m3/mat/_menu.scss +42 -0
- package/core/tokens/m3/mat/_minimal-pseudo-checkbox.scss +33 -0
- package/core/tokens/m3/mat/_optgroup.scss +22 -0
- package/core/tokens/m3/mat/_option.scss +55 -0
- package/core/tokens/m3/mat/_outlined-button.scss +54 -0
- package/core/tokens/m3/mat/_paginator.scss +27 -0
- package/core/tokens/m3/mat/_protected-button.scss +55 -0
- package/core/tokens/m3/mat/_radio.scss +34 -0
- package/core/tokens/m3/mat/_ripple.scss +19 -0
- package/core/tokens/m3/mat/_select.scss +46 -0
- package/core/tokens/m3/mat/_sidenav.scss +28 -0
- package/core/tokens/m3/mat/_slider.scss +56 -0
- package/core/tokens/m3/mat/_snack-bar.scss +18 -0
- package/core/tokens/m3/mat/_sort.scss +18 -0
- package/core/tokens/m3/mat/_standard-button-toggle.scss +57 -0
- package/core/tokens/m3/mat/_stepper.scss +79 -0
- package/core/tokens/m3/mat/_switch.scss +45 -0
- package/core/tokens/m3/mat/_tab-header.scss +51 -0
- package/core/tokens/m3/mat/_table.scss +28 -0
- package/core/tokens/m3/mat/_text-button.scss +55 -0
- package/core/tokens/m3/mat/_toolbar.scss +23 -0
- package/core/tokens/m3/mat/_tree.scss +22 -0
- package/core/tokens/m3/mdc/_checkbox.scss +110 -0
- package/core/tokens/m3/mdc/_chip.scss +91 -0
- package/core/tokens/m3/mdc/_circular-progress.scss +29 -0
- package/core/tokens/m3/mdc/_dialog.scss +39 -0
- package/core/tokens/m3/mdc/_elevated-card.scss +15 -0
- package/core/tokens/m3/mdc/_extended-fab.scss +21 -0
- package/core/tokens/m3/mdc/_fab-small.scss +21 -0
- package/core/tokens/m3/mdc/_fab.scss +21 -0
- package/core/tokens/m3/mdc/_filled-button.scss +86 -0
- package/core/tokens/m3/mdc/_filled-text-field.scss +92 -0
- package/core/tokens/m3/mdc/_form-field.scss +25 -0
- package/core/tokens/m3/mdc/_icon-button.scss +39 -0
- package/core/tokens/m3/mdc/_linear-progress.scss +32 -0
- package/core/tokens/m3/mdc/_list.scss +37 -0
- package/core/tokens/m3/mdc/_outlined-button.scss +83 -0
- package/core/tokens/m3/mdc/_outlined-card.scss +15 -0
- package/core/tokens/m3/mdc/_outlined-text-field.scss +85 -0
- package/core/tokens/m3/mdc/_plain-tooltip.scss +15 -0
- package/core/tokens/m3/mdc/_protected-button.scss +84 -0
- package/core/tokens/m3/mdc/_radio.scss +46 -0
- package/core/tokens/m3/mdc/_slider.scss +61 -0
- package/core/tokens/m3/mdc/_snack-bar.scss +15 -0
- package/core/tokens/m3/mdc/_switch.scss +70 -0
- package/core/tokens/m3/mdc/_tab-indicator.scss +33 -0
- package/core/tokens/m3/mdc/_tab.scss +15 -0
- package/core/tokens/m3/mdc/_text-button.scss +79 -0
- package/dialog/index.d.ts +4 -3
- package/esm2022/core/version.mjs +1 -1
- package/esm2022/dialog/dialog-content-directives.mjs +5 -2
- package/esm2022/slide-toggle/slide-toggle.mjs +3 -3
- package/fesm2022/core.mjs +1 -1
- package/fesm2022/core.mjs.map +1 -1
- package/fesm2022/dialog.mjs +4 -1
- package/fesm2022/dialog.mjs.map +1 -1
- package/fesm2022/slide-toggle.mjs +2 -2
- package/fesm2022/slide-toggle.mjs.map +1 -1
- package/package.json +2 -2
- package/prebuilt-themes/azure-blue.css +1 -1
- package/prebuilt-themes/cyan-orange.css +1 -1
- package/prebuilt-themes/deeppurple-amber.css +1 -1
- package/prebuilt-themes/indigo-pink.css +1 -1
- package/prebuilt-themes/magenta-violet.css +1 -1
- package/prebuilt-themes/pink-bluegrey.css +1 -1
- package/prebuilt-themes/purple-green.css +1 -1
- package/prebuilt-themes/rose-red.css +1 -1
- package/schematics/ng-add/index.js +1 -1
- package/schematics/ng-add/index.mjs +1 -1
- package/schematics/ng-generate/m3-theme/index_bundled.js +2 -2
- package/schematics/ng-update/index_bundled.js +29 -29
- 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/
|
|
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,
|
|
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
|
|
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
|
|
package/esm2022/core/version.mjs
CHANGED
|
@@ -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-
|
|
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":"AAAA;;;;;;GAMG;AAEH,OAAO,EACL,SAAS,EACT,UAAU,EACV,KAAK,EAIL,QAAQ,GAET,MAAM,eAAe,CAAC;AAEvB,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;AAMH,MAAM,OAAO,gBAAgB;qHAAhB,gBAAgB;yGAAhB,gBAAgB;;kGAAhB,gBAAgB;kBAL5B,SAAS;mBAAC;oBACT,QAAQ,EAAE,8DAA8D;oBACxE,IAAI,EAAE,EAAC,OAAO,EAAE,4CAA4C,EAAC;oBAC7D,UAAU,EAAE,IAAI;iBACjB;;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';\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":"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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';\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"]}
|