@angular/material 16.1.2 → 16.2.0-next.1
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/button/index.d.ts +11 -35
- package/card/_card-theme.scss +4 -7
- package/checkbox/_checkbox-theme.scss +1 -4
- package/core/index.d.ts +37 -0
- package/core/style/_sass-utils.scss +12 -0
- package/core/tokens/_token-utils.scss +11 -2
- package/core/tokens/m2/mat/_slide-toggle.scss +52 -0
- package/core/tokens/m2/mat/_table.scss +97 -0
- package/core/tokens/m2/mdc/_switch.scss +182 -0
- package/esm2022/button/button-base.mjs +32 -17
- package/esm2022/button/button.mjs +3 -3
- package/esm2022/button/fab.mjs +5 -5
- package/esm2022/button/icon-button.mjs +4 -15
- package/esm2022/core/private/index.mjs +9 -0
- package/esm2022/core/private/ripple-loader.mjs +133 -0
- package/esm2022/core/public-api.mjs +2 -1
- package/esm2022/core/version.mjs +1 -1
- package/esm2022/legacy-autocomplete/autocomplete-trigger.mjs +2 -2
- package/esm2022/slide-toggle/slide-toggle-config.mjs +2 -2
- package/esm2022/slide-toggle/slide-toggle.mjs +16 -4
- package/esm2022/table/table.mjs +2 -2
- package/fesm2022/button.mjs +57 -156
- package/fesm2022/button.mjs.map +1 -1
- package/fesm2022/core.mjs +124 -3
- package/fesm2022/core.mjs.map +1 -1
- package/fesm2022/legacy-autocomplete.mjs.map +1 -1
- package/fesm2022/slide-toggle.mjs +16 -4
- package/fesm2022/slide-toggle.mjs.map +1 -1
- package/fesm2022/table.mjs +2 -2
- package/fesm2022/table.mjs.map +1 -1
- package/package.json +7 -7
- package/prebuilt-themes/deeppurple-amber.css +1 -1
- package/prebuilt-themes/indigo-pink.css +1 -1
- package/prebuilt-themes/pink-bluegrey.css +1 -1
- package/prebuilt-themes/purple-green.css +1 -1
- package/schematics/ng-add/index.js +2 -2
- package/schematics/ng-add/index.mjs +2 -2
- package/slide-toggle/_slide-toggle-theme.scss +26 -75
- package/slide-toggle/index.d.ts +7 -1
- package/table/_table-theme.scss +24 -40
- package/esm2022/button/button-lazy-loader.mjs +0 -113
|
@@ -1,73 +1,12 @@
|
|
|
1
1
|
@use 'sass:map';
|
|
2
|
-
@use 'sass:color';
|
|
3
2
|
@use '@material/switch/switch-theme' as mdc-switch-theme;
|
|
4
|
-
@use '@material/theme/color-palette' as mdc-color-palette;
|
|
5
3
|
@use '@material/form-field' as mdc-form-field;
|
|
6
4
|
@use '../core/theming/theming';
|
|
7
5
|
@use '../core/mdc-helpers/mdc-helpers';
|
|
8
6
|
@use '../core/typography/typography';
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
@function _get-theme-base-map($is-dark) {
|
|
13
|
-
$on-surface: if($is-dark, mdc-color-palette.$grey-100, mdc-color-palette.$grey-800);
|
|
14
|
-
$hairline: if($is-dark, mdc-color-palette.$grey-700, mdc-color-palette.$grey-300);
|
|
15
|
-
$on-surface-variant: if($is-dark, mdc-color-palette.$grey-500, mdc-color-palette.$grey-700);
|
|
16
|
-
$on-surface-state-content: if($is-dark, mdc-color-palette.$grey-50, mdc-color-palette.$grey-900);
|
|
17
|
-
$disabled-handle-color: if($is-dark, #000, mdc-color-palette.$grey-800);
|
|
18
|
-
$icon-color: if($is-dark, mdc-color-palette.$grey-900, #fff);
|
|
19
|
-
|
|
20
|
-
@return (
|
|
21
|
-
disabled-selected-handle-color: $disabled-handle-color,
|
|
22
|
-
disabled-unselected-handle-color: $disabled-handle-color,
|
|
23
|
-
|
|
24
|
-
disabled-selected-track-color: $on-surface,
|
|
25
|
-
disabled-unselected-track-color: $on-surface,
|
|
26
|
-
unselected-focus-state-layer-color: $on-surface,
|
|
27
|
-
unselected-pressed-state-layer-color: $on-surface,
|
|
28
|
-
unselected-hover-state-layer-color: $on-surface,
|
|
29
|
-
|
|
30
|
-
unselected-focus-track-color: $hairline,
|
|
31
|
-
unselected-hover-track-color: $hairline,
|
|
32
|
-
unselected-pressed-track-color: $hairline,
|
|
33
|
-
unselected-track-color: $hairline,
|
|
34
|
-
|
|
35
|
-
unselected-focus-handle-color: $on-surface-state-content,
|
|
36
|
-
unselected-hover-handle-color: $on-surface-state-content,
|
|
37
|
-
unselected-pressed-handle-color: $on-surface-state-content,
|
|
38
|
-
|
|
39
|
-
handle-surface-color: surface,
|
|
40
|
-
unselected-handle-color: $on-surface-variant,
|
|
41
|
-
|
|
42
|
-
selected-icon-color: $icon-color,
|
|
43
|
-
disabled-selected-icon-color: $icon-color,
|
|
44
|
-
disabled-unselected-icon-color: $icon-color,
|
|
45
|
-
unselected-icon-color: $icon-color,
|
|
46
|
-
);
|
|
47
|
-
}
|
|
48
|
-
|
|
49
|
-
// Generates the mapping for the properties that change based on the slide toggle color.
|
|
50
|
-
@function _get-theme-color-map($color-palette, $is-dark) {
|
|
51
|
-
$primary: theming.get-color-from-palette($color-palette, if($is-dark, 300, 600));
|
|
52
|
-
$state-content: theming.get-color-from-palette($color-palette, if($is-dark, 200, 900));
|
|
53
|
-
$inverse: theming.get-color-from-palette($color-palette, if($is-dark, 600, 300));
|
|
54
|
-
|
|
55
|
-
@return (
|
|
56
|
-
selected-focus-state-layer-color: $primary,
|
|
57
|
-
selected-handle-color: $primary,
|
|
58
|
-
selected-hover-state-layer-color: $primary,
|
|
59
|
-
selected-pressed-state-layer-color: $primary,
|
|
60
|
-
|
|
61
|
-
selected-focus-handle-color: $state-content,
|
|
62
|
-
selected-hover-handle-color: $state-content,
|
|
63
|
-
selected-pressed-handle-color: $state-content,
|
|
64
|
-
|
|
65
|
-
selected-focus-track-color: $inverse,
|
|
66
|
-
selected-hover-track-color: $inverse,
|
|
67
|
-
selected-pressed-track-color: $inverse,
|
|
68
|
-
selected-track-color: $inverse,
|
|
69
|
-
);
|
|
70
|
-
}
|
|
7
|
+
@use '../core/tokens/m2/mdc/switch' as m2-mdc-switch;
|
|
8
|
+
@use '../core/tokens/m2/mat/slide-toggle' as m2-mat-slide-toggle;
|
|
9
|
+
@use '../core/tokens/token-utils';
|
|
71
10
|
|
|
72
11
|
@mixin color($config-or-theme) {
|
|
73
12
|
$config: theming.get-color-config($config-or-theme);
|
|
@@ -77,28 +16,32 @@
|
|
|
77
16
|
$is-dark: map.get($config, is-dark);
|
|
78
17
|
$foreground: map.get($config, foreground);
|
|
79
18
|
|
|
19
|
+
$mdc-switch-color-tokens: m2-mdc-switch.get-color-tokens($config);
|
|
20
|
+
|
|
80
21
|
@include mdc-helpers.using-mdc-theme($config) {
|
|
81
|
-
//
|
|
82
|
-
// for it by adding a CSS class for accent and warn style.
|
|
22
|
+
// Add values for MDC slide toggles tokens
|
|
83
23
|
.mat-mdc-slide-toggle {
|
|
84
24
|
@include mdc-form-field.core-styles($query: mdc-helpers.$mdc-theme-styles-query);
|
|
85
|
-
@include mdc-switch-theme.theme(
|
|
25
|
+
@include mdc-switch-theme.theme($mdc-switch-color-tokens);
|
|
86
26
|
|
|
87
27
|
// MDC should set the disabled color on the label, but doesn't, so we do it here instead.
|
|
88
28
|
.mdc-switch--disabled + label {
|
|
89
29
|
color: theming.get-color-from-palette($foreground, disabled-text);
|
|
90
30
|
}
|
|
91
31
|
|
|
92
|
-
|
|
93
|
-
@include mdc-switch-theme.theme(_get-theme-color-map($primary, $is-dark));
|
|
94
|
-
}
|
|
95
|
-
|
|
32
|
+
// Change the color palette related tokens to accent or warn if applicable
|
|
96
33
|
&.mat-accent {
|
|
97
|
-
@include mdc-switch-theme.theme(
|
|
34
|
+
@include mdc-switch-theme.theme(m2-mdc-switch.private-get-color-palette-color-tokens(
|
|
35
|
+
map.get($config, accent),
|
|
36
|
+
map.get($config, is-dark)
|
|
37
|
+
));
|
|
98
38
|
}
|
|
99
39
|
|
|
100
40
|
&.mat-warn {
|
|
101
|
-
@include mdc-switch-theme.theme(
|
|
41
|
+
@include mdc-switch-theme.theme(m2-mdc-switch.private-get-color-palette-color-tokens(
|
|
42
|
+
map.get($config, warn),
|
|
43
|
+
map.get($config, is-dark)
|
|
44
|
+
));
|
|
102
45
|
}
|
|
103
46
|
}
|
|
104
47
|
}
|
|
@@ -107,8 +50,17 @@
|
|
|
107
50
|
@mixin typography($config-or-theme) {
|
|
108
51
|
$config: typography.private-typography-to-2018-config(
|
|
109
52
|
theming.get-typography-config($config-or-theme));
|
|
110
|
-
|
|
53
|
+
$mdc-switch-typography-tokens: m2-mdc-switch.get-typography-tokens($config);
|
|
54
|
+
$mat-slide-toggle-typography-tokens: m2-mat-slide-toggle.get-typography-tokens($config);
|
|
55
|
+
|
|
56
|
+
//Add values for MDC slide toggle tokens
|
|
57
|
+
.mat-mdc-slide-toggle {
|
|
111
58
|
@include mdc-form-field.core-styles($query: mdc-helpers.$mdc-typography-styles-query);
|
|
59
|
+
@include mdc-switch-theme.theme($mdc-switch-typography-tokens);
|
|
60
|
+
@include token-utils.create-token-values(
|
|
61
|
+
m2-mat-slide-toggle.$prefix,
|
|
62
|
+
$mat-slide-toggle-typography-tokens
|
|
63
|
+
);
|
|
112
64
|
}
|
|
113
65
|
}
|
|
114
66
|
|
|
@@ -138,4 +90,3 @@
|
|
|
138
90
|
}
|
|
139
91
|
}
|
|
140
92
|
}
|
|
141
|
-
|
package/slide-toggle/index.d.ts
CHANGED
|
@@ -101,6 +101,10 @@ export declare abstract class _MatSlideToggleBase<T> extends _MatSlideToggleMixi
|
|
|
101
101
|
/** Whether the slide-toggle element is checked or not. */
|
|
102
102
|
get checked(): boolean;
|
|
103
103
|
set checked(value: BooleanInput);
|
|
104
|
+
/** Whether to hide the icon inside of the slide toggle. */
|
|
105
|
+
get hideIcon(): boolean;
|
|
106
|
+
set hideIcon(value: BooleanInput);
|
|
107
|
+
private _hideIcon;
|
|
104
108
|
/** An event will be dispatched each time the slide-toggle changes its value. */
|
|
105
109
|
readonly change: EventEmitter<T>;
|
|
106
110
|
/**
|
|
@@ -129,7 +133,7 @@ export declare abstract class _MatSlideToggleBase<T> extends _MatSlideToggleMixi
|
|
|
129
133
|
*/
|
|
130
134
|
protected _emitChangeEvent(): void;
|
|
131
135
|
static ɵfac: i0.ɵɵFactoryDeclaration<_MatSlideToggleBase<any>, never>;
|
|
132
|
-
static ɵdir: i0.ɵɵDirectiveDeclaration<_MatSlideToggleBase<any>, never, never, { "name": { "alias": "name"; "required": false; }; "id": { "alias": "id"; "required": false; }; "labelPosition": { "alias": "labelPosition"; "required": false; }; "ariaLabel": { "alias": "aria-label"; "required": false; }; "ariaLabelledby": { "alias": "aria-labelledby"; "required": false; }; "ariaDescribedby": { "alias": "aria-describedby"; "required": false; }; "required": { "alias": "required"; "required": false; }; "checked": { "alias": "checked"; "required": false; }; }, { "change": "change"; "toggleChange": "toggleChange"; }, never, never, false, never>;
|
|
136
|
+
static ɵdir: i0.ɵɵDirectiveDeclaration<_MatSlideToggleBase<any>, never, never, { "name": { "alias": "name"; "required": false; }; "id": { "alias": "id"; "required": false; }; "labelPosition": { "alias": "labelPosition"; "required": false; }; "ariaLabel": { "alias": "aria-label"; "required": false; }; "ariaLabelledby": { "alias": "aria-labelledby"; "required": false; }; "ariaDescribedby": { "alias": "aria-describedby"; "required": false; }; "required": { "alias": "required"; "required": false; }; "checked": { "alias": "checked"; "required": false; }; "hideIcon": { "alias": "hideIcon"; "required": false; }; }, { "change": "change"; "toggleChange": "toggleChange"; }, never, never, false, never>;
|
|
133
137
|
}
|
|
134
138
|
|
|
135
139
|
/** Change event object emitted by a slide toggle. */
|
|
@@ -151,6 +155,8 @@ export declare interface MatSlideToggleDefaultOptions {
|
|
|
151
155
|
disableToggleValue?: boolean;
|
|
152
156
|
/** Default color for slide toggles. */
|
|
153
157
|
color?: ThemePalette;
|
|
158
|
+
/** Whether to hide the icon inside the slide toggle. */
|
|
159
|
+
hideIcon?: boolean;
|
|
154
160
|
}
|
|
155
161
|
|
|
156
162
|
/** @docs-private */
|
package/table/_table-theme.scss
CHANGED
|
@@ -1,60 +1,44 @@
|
|
|
1
|
-
@use '
|
|
2
|
-
@use '@material/theme/theme-color' as mdc-theme-color;
|
|
3
|
-
@use '@material/data-table/data-table' as mdc-data-table;
|
|
4
|
-
@use '@material/data-table' as mdc-data-table-theme;
|
|
1
|
+
@use '../core/tokens/m2/mat/table' as tokens-mat-table;
|
|
5
2
|
@use '../core/theming/theming';
|
|
6
|
-
@use '../core/mdc-helpers/mdc-helpers';
|
|
7
3
|
@use '../core/typography/typography';
|
|
4
|
+
@use '../core/tokens/token-utils';
|
|
8
5
|
|
|
9
|
-
@mixin
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
$orig-row-text-color: mdc-data-table-theme.$row-text-color;
|
|
18
|
-
$orig-stroke-color: mdc-data-table-theme.$stroke-color;
|
|
19
|
-
|
|
20
|
-
@include mdc-helpers.using-mdc-theme($config) {
|
|
21
|
-
mdc-data-table-theme.$selected-row-fill-color: rgba(mdc-theme-color.prop-value(primary), 0.04);
|
|
22
|
-
mdc-data-table-theme.$divider-color: rgba(mdc-theme-color.prop-value(on-surface), 0.12);
|
|
23
|
-
mdc-data-table-theme.$row-hover-fill-color: rgba(mdc-theme-color.prop-value(on-surface), 0.04);
|
|
24
|
-
mdc-data-table-theme.$header-row-text-color: rgba(mdc-theme-color.prop-value(on-surface), 0.87);
|
|
25
|
-
mdc-data-table-theme.$row-text-color: rgba(mdc-theme-color.prop-value(on-surface), 0.87);
|
|
26
|
-
mdc-data-table-theme.$stroke-color: rgba(mdc-theme-color.prop-value(on-surface), 0.12);
|
|
27
|
-
|
|
28
|
-
@include mdc-data-table.table-styles($query: mdc-helpers.$mdc-theme-styles-query);
|
|
6
|
+
@mixin _output-tokens {
|
|
7
|
+
@if (&) {
|
|
8
|
+
@content;
|
|
9
|
+
}
|
|
10
|
+
@else {
|
|
11
|
+
html {
|
|
12
|
+
@content;
|
|
13
|
+
}
|
|
29
14
|
}
|
|
15
|
+
}
|
|
30
16
|
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
mdc-data-table-theme.$divider-color: $orig-divider-color;
|
|
34
|
-
mdc-data-table-theme.$row-hover-fill-color: $orig-row-hover-fill-color;
|
|
35
|
-
mdc-data-table-theme.$header-row-text-color: $orig-header-row-text-color;
|
|
36
|
-
mdc-data-table-theme.$row-text-color: $orig-row-text-color;
|
|
37
|
-
mdc-data-table-theme.$stroke-color: $orig-stroke-color;
|
|
17
|
+
@mixin color($config-or-theme) {
|
|
18
|
+
$config: theming.get-color-config($config-or-theme);
|
|
38
19
|
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
20
|
+
@include _output-tokens {
|
|
21
|
+
@include token-utils.create-token-values(tokens-mat-table.$prefix,
|
|
22
|
+
tokens-mat-table.get-color-tokens($config));
|
|
42
23
|
}
|
|
43
24
|
}
|
|
44
25
|
|
|
45
26
|
@mixin typography($config-or-theme) {
|
|
46
27
|
$config: typography.private-typography-to-2018-config(
|
|
47
28
|
theming.get-typography-config($config-or-theme));
|
|
48
|
-
|
|
49
|
-
|
|
29
|
+
|
|
30
|
+
@include _output-tokens {
|
|
31
|
+
@include token-utils.create-token-values(tokens-mat-table.$prefix,
|
|
32
|
+
tokens-mat-table.get-typography-tokens($config));
|
|
50
33
|
}
|
|
51
34
|
}
|
|
52
35
|
|
|
53
36
|
@mixin density($config-or-theme) {
|
|
54
37
|
$density-scale: theming.get-density-config($config-or-theme);
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
38
|
+
|
|
39
|
+
@include _output-tokens {
|
|
40
|
+
@include token-utils.create-token-values(tokens-mat-table.$prefix,
|
|
41
|
+
tokens-mat-table.get-density-tokens($density-scale));
|
|
58
42
|
}
|
|
59
43
|
}
|
|
60
44
|
|
|
@@ -1,113 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* @license
|
|
3
|
-
* Copyright Google LLC All Rights Reserved.
|
|
4
|
-
*
|
|
5
|
-
* Use of this source code is governed by an MIT-style license that can be
|
|
6
|
-
* found in the LICENSE file at https://angular.io/license
|
|
7
|
-
*/
|
|
8
|
-
import { DOCUMENT } from '@angular/common';
|
|
9
|
-
import { ANIMATION_MODULE_TYPE, ElementRef, Injectable, NgZone, inject, } from '@angular/core';
|
|
10
|
-
import { MAT_RIPPLE_GLOBAL_OPTIONS, MatRipple, RippleRenderer, } from '@angular/material/core';
|
|
11
|
-
import { Platform } from '@angular/cdk/platform';
|
|
12
|
-
import * as i0 from "@angular/core";
|
|
13
|
-
/** The options for the MatButtonRippleLoader's event listeners. */
|
|
14
|
-
const eventListenerOptions = { capture: true };
|
|
15
|
-
/** The events that should trigger the initialization of the ripple. */
|
|
16
|
-
const rippleInteractionEvents = ['focus', 'click', 'mouseenter', 'touchstart'];
|
|
17
|
-
/** The attribute attached to a mat-button whose ripple has not yet been initialized. */
|
|
18
|
-
export const MAT_BUTTON_RIPPLE_UNINITIALIZED = 'mat-button-ripple-uninitialized';
|
|
19
|
-
/**
|
|
20
|
-
* Handles attaching the MatButton's ripple on demand.
|
|
21
|
-
*
|
|
22
|
-
* This service allows us to avoid eagerly creating & attaching the MatButton's ripple.
|
|
23
|
-
* It works by creating & attaching the ripple only when a MatButton is first interacted with.
|
|
24
|
-
*/
|
|
25
|
-
export class MatButtonLazyLoader {
|
|
26
|
-
constructor() {
|
|
27
|
-
this._document = inject(DOCUMENT, { optional: true });
|
|
28
|
-
this._animationMode = inject(ANIMATION_MODULE_TYPE, { optional: true });
|
|
29
|
-
this._globalRippleOptions = inject(MAT_RIPPLE_GLOBAL_OPTIONS, { optional: true });
|
|
30
|
-
this._platform = inject(Platform);
|
|
31
|
-
this._ngZone = inject(NgZone);
|
|
32
|
-
/** Handles creating and attaching button internals when a button is initially interacted with. */
|
|
33
|
-
this._onInteraction = (event) => {
|
|
34
|
-
if (event.target === this._document) {
|
|
35
|
-
return;
|
|
36
|
-
}
|
|
37
|
-
const eventTarget = event.target;
|
|
38
|
-
// TODO(wagnermaciel): Consider batching these events to improve runtime performance.
|
|
39
|
-
const button = eventTarget.closest(`[${MAT_BUTTON_RIPPLE_UNINITIALIZED}]`);
|
|
40
|
-
if (button) {
|
|
41
|
-
button.removeAttribute(MAT_BUTTON_RIPPLE_UNINITIALIZED);
|
|
42
|
-
this._appendRipple(button);
|
|
43
|
-
}
|
|
44
|
-
};
|
|
45
|
-
this._ngZone.runOutsideAngular(() => {
|
|
46
|
-
for (const event of rippleInteractionEvents) {
|
|
47
|
-
this._document?.addEventListener(event, this._onInteraction, eventListenerOptions);
|
|
48
|
-
}
|
|
49
|
-
});
|
|
50
|
-
}
|
|
51
|
-
ngOnDestroy() {
|
|
52
|
-
for (const event of rippleInteractionEvents) {
|
|
53
|
-
this._document?.removeEventListener(event, this._onInteraction, eventListenerOptions);
|
|
54
|
-
}
|
|
55
|
-
}
|
|
56
|
-
/** Creates a MatButtonRipple and appends it to the given button element. */
|
|
57
|
-
_appendRipple(button) {
|
|
58
|
-
if (!this._document) {
|
|
59
|
-
return;
|
|
60
|
-
}
|
|
61
|
-
const ripple = this._document.createElement('span');
|
|
62
|
-
ripple.classList.add('mat-mdc-button-ripple');
|
|
63
|
-
const target = new MatButtonRippleTarget(button, this._globalRippleOptions ? this._globalRippleOptions : undefined, this._animationMode ? this._animationMode : undefined);
|
|
64
|
-
target.rippleConfig.centered = button.hasAttribute('mat-icon-button');
|
|
65
|
-
const rippleRenderer = new RippleRenderer(target, this._ngZone, ripple, this._platform);
|
|
66
|
-
rippleRenderer.setupTriggerEvents(button);
|
|
67
|
-
button.append(ripple);
|
|
68
|
-
}
|
|
69
|
-
_createMatRipple(button) {
|
|
70
|
-
if (!this._document) {
|
|
71
|
-
return;
|
|
72
|
-
}
|
|
73
|
-
button.querySelector('.mat-mdc-button-ripple')?.remove();
|
|
74
|
-
button.removeAttribute(MAT_BUTTON_RIPPLE_UNINITIALIZED);
|
|
75
|
-
const rippleEl = this._document.createElement('span');
|
|
76
|
-
rippleEl.classList.add('mat-mdc-button-ripple');
|
|
77
|
-
const ripple = new MatRipple(new ElementRef(rippleEl), this._ngZone, this._platform, this._globalRippleOptions ? this._globalRippleOptions : undefined, this._animationMode ? this._animationMode : undefined);
|
|
78
|
-
ripple._isInitialized = true;
|
|
79
|
-
ripple.trigger = button;
|
|
80
|
-
button.append(rippleEl);
|
|
81
|
-
return ripple;
|
|
82
|
-
}
|
|
83
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.1.1", ngImport: i0, type: MatButtonLazyLoader, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
|
|
84
|
-
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "16.1.1", ngImport: i0, type: MatButtonLazyLoader, providedIn: 'root' }); }
|
|
85
|
-
}
|
|
86
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.1", ngImport: i0, type: MatButtonLazyLoader, decorators: [{
|
|
87
|
-
type: Injectable,
|
|
88
|
-
args: [{ providedIn: 'root' }]
|
|
89
|
-
}], ctorParameters: function () { return []; } });
|
|
90
|
-
/**
|
|
91
|
-
* The RippleTarget for the lazily rendered MatButton ripple.
|
|
92
|
-
* It handles ripple configuration and disabled state for ripples interactions.
|
|
93
|
-
*
|
|
94
|
-
* Note that this configuration is usually handled by the MatRipple, but the MatButtonLazyLoader does not use the
|
|
95
|
-
* MatRipple Directive. In order to create & attach a ripple on demand, it uses the "lower level" RippleRenderer.
|
|
96
|
-
*/
|
|
97
|
-
class MatButtonRippleTarget {
|
|
98
|
-
constructor(_button, _globalRippleOptions, animationMode) {
|
|
99
|
-
this._button = _button;
|
|
100
|
-
this._globalRippleOptions = _globalRippleOptions;
|
|
101
|
-
this._setRippleConfig(_globalRippleOptions, animationMode);
|
|
102
|
-
}
|
|
103
|
-
_setRippleConfig(globalRippleOptions, animationMode) {
|
|
104
|
-
this.rippleConfig = globalRippleOptions || {};
|
|
105
|
-
if (animationMode === 'NoopAnimations') {
|
|
106
|
-
this.rippleConfig.animation = { enterDuration: 0, exitDuration: 0 };
|
|
107
|
-
}
|
|
108
|
-
}
|
|
109
|
-
get rippleDisabled() {
|
|
110
|
-
return this._button.hasAttribute('disabled') || !!this._globalRippleOptions?.disabled;
|
|
111
|
-
}
|
|
112
|
-
}
|
|
113
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"button-lazy-loader.js","sourceRoot":"","sources":["../../../../../../src/material/button/button-lazy-loader.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 {DOCUMENT} from '@angular/common';\nimport {\n  ANIMATION_MODULE_TYPE,\n  ElementRef,\n  Injectable,\n  NgZone,\n  OnDestroy,\n  inject,\n} from '@angular/core';\nimport {\n  MAT_RIPPLE_GLOBAL_OPTIONS,\n  MatRipple,\n  RippleConfig,\n  RippleGlobalOptions,\n  RippleRenderer,\n  RippleTarget,\n} from '@angular/material/core';\nimport {Platform} from '@angular/cdk/platform';\n\n/** The options for the MatButtonRippleLoader's event listeners. */\nconst eventListenerOptions = {capture: true};\n\n/** The events that should trigger the initialization of the ripple. */\nconst rippleInteractionEvents = ['focus', 'click', 'mouseenter', 'touchstart'];\n\n/** The attribute attached to a mat-button whose ripple has not yet been initialized. */\nexport const MAT_BUTTON_RIPPLE_UNINITIALIZED = 'mat-button-ripple-uninitialized';\n\n/**\n * Handles attaching the MatButton's ripple on demand.\n *\n * This service allows us to avoid eagerly creating & attaching the MatButton's ripple.\n * It works by creating & attaching the ripple only when a MatButton is first interacted with.\n */\n@Injectable({providedIn: 'root'})\nexport class MatButtonLazyLoader implements OnDestroy {\n  private _document = inject(DOCUMENT, {optional: true});\n  private _animationMode = inject(ANIMATION_MODULE_TYPE, {optional: true});\n  private _globalRippleOptions = inject(MAT_RIPPLE_GLOBAL_OPTIONS, {optional: true});\n  private _platform = inject(Platform);\n  private _ngZone = inject(NgZone);\n\n  constructor() {\n    this._ngZone.runOutsideAngular(() => {\n      for (const event of rippleInteractionEvents) {\n        this._document?.addEventListener(event, this._onInteraction, eventListenerOptions);\n      }\n    });\n  }\n\n  ngOnDestroy() {\n    for (const event of rippleInteractionEvents) {\n      this._document?.removeEventListener(event, this._onInteraction, eventListenerOptions);\n    }\n  }\n\n  /** Handles creating and attaching button internals when a button is initially interacted with. */\n  private _onInteraction = (event: Event) => {\n    if (event.target === this._document) {\n      return;\n    }\n    const eventTarget = event.target as Element;\n\n    // TODO(wagnermaciel): Consider batching these events to improve runtime performance.\n\n    const button = eventTarget.closest(`[${MAT_BUTTON_RIPPLE_UNINITIALIZED}]`);\n    if (button) {\n      button.removeAttribute(MAT_BUTTON_RIPPLE_UNINITIALIZED);\n      this._appendRipple(button as HTMLElement);\n    }\n  };\n\n  /** Creates a MatButtonRipple and appends it to the given button element. */\n  private _appendRipple(button: HTMLElement): void {\n    if (!this._document) {\n      return;\n    }\n    const ripple = this._document.createElement('span');\n    ripple.classList.add('mat-mdc-button-ripple');\n\n    const target = new MatButtonRippleTarget(\n      button,\n      this._globalRippleOptions ? this._globalRippleOptions : undefined,\n      this._animationMode ? this._animationMode : undefined,\n    );\n    target.rippleConfig.centered = button.hasAttribute('mat-icon-button');\n\n    const rippleRenderer = new RippleRenderer(target, this._ngZone, ripple, this._platform);\n    rippleRenderer.setupTriggerEvents(button);\n    button.append(ripple);\n  }\n\n  _createMatRipple(button: HTMLElement): MatRipple | undefined {\n    if (!this._document) {\n      return;\n    }\n    button.querySelector('.mat-mdc-button-ripple')?.remove();\n    button.removeAttribute(MAT_BUTTON_RIPPLE_UNINITIALIZED);\n    const rippleEl = this._document!.createElement('span');\n    rippleEl.classList.add('mat-mdc-button-ripple');\n    const ripple = new MatRipple(\n      new ElementRef(rippleEl),\n      this._ngZone,\n      this._platform,\n      this._globalRippleOptions ? this._globalRippleOptions : undefined,\n      this._animationMode ? this._animationMode : undefined,\n    );\n    ripple._isInitialized = true;\n    ripple.trigger = button;\n    button.append(rippleEl);\n    return ripple;\n  }\n}\n\n/**\n * The RippleTarget for the lazily rendered MatButton ripple.\n * It handles ripple configuration and disabled state for ripples interactions.\n *\n * Note that this configuration is usually handled by the MatRipple, but the MatButtonLazyLoader does not use the\n * MatRipple Directive. In order to create & attach a ripple on demand, it uses the \"lower level\" RippleRenderer.\n */\nclass MatButtonRippleTarget implements RippleTarget {\n  rippleConfig: RippleConfig & RippleGlobalOptions;\n\n  constructor(\n    private _button: HTMLElement,\n    private _globalRippleOptions?: RippleGlobalOptions,\n    animationMode?: string,\n  ) {\n    this._setRippleConfig(_globalRippleOptions, animationMode);\n  }\n\n  private _setRippleConfig(globalRippleOptions?: RippleGlobalOptions, animationMode?: string) {\n    this.rippleConfig = globalRippleOptions || {};\n    if (animationMode === 'NoopAnimations') {\n      this.rippleConfig.animation = {enterDuration: 0, exitDuration: 0};\n    }\n  }\n\n  get rippleDisabled(): boolean {\n    return this._button.hasAttribute('disabled') || !!this._globalRippleOptions?.disabled;\n  }\n}\n"]}
|