@angular/material 15.0.0-next.4 → 15.0.0-next.5
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/button/testing/index.d.ts +8 -0
- package/chips/index.d.ts +13 -1
- package/core/mdc-helpers/_mdc-helpers.scss +8 -6
- package/core/typography/_all-typography.scss +73 -81
- package/datepicker/index.d.ts +10 -2
- package/esm2020/button/testing/button-harness-filters.mjs +1 -1
- package/esm2020/button/testing/button-harness.mjs +28 -2
- package/esm2020/checkbox/checkbox.mjs +2 -2
- package/esm2020/chips/chip-option.mjs +15 -7
- package/esm2020/core/version.mjs +1 -1
- package/esm2020/datepicker/datepicker-intl.mjs +11 -3
- package/esm2020/icon/icon.mjs +3 -2
- package/esm2020/legacy-button/testing/button-harness.mjs +27 -2
- package/esm2020/legacy-button/testing/public-api.mjs +1 -1
- package/esm2020/list/list-base.mjs +5 -2
- package/esm2020/list/selection-list.mjs +34 -4
- package/fesm2015/button/testing.mjs +29 -1
- package/fesm2015/button/testing.mjs.map +1 -1
- package/fesm2015/checkbox.mjs +2 -2
- package/fesm2015/checkbox.mjs.map +1 -1
- package/fesm2015/chips.mjs +14 -6
- package/fesm2015/chips.mjs.map +1 -1
- package/fesm2015/core.mjs +1 -1
- package/fesm2015/core.mjs.map +1 -1
- package/fesm2015/datepicker.mjs +10 -2
- package/fesm2015/datepicker.mjs.map +1 -1
- package/fesm2015/icon.mjs +2 -1
- package/fesm2015/icon.mjs.map +1 -1
- package/fesm2015/legacy-button/testing.mjs +28 -1
- package/fesm2015/legacy-button/testing.mjs.map +1 -1
- package/fesm2015/list.mjs +38 -4
- package/fesm2015/list.mjs.map +1 -1
- package/fesm2020/button/testing.mjs +27 -1
- package/fesm2020/button/testing.mjs.map +1 -1
- package/fesm2020/checkbox.mjs +2 -2
- package/fesm2020/checkbox.mjs.map +1 -1
- package/fesm2020/chips.mjs +14 -6
- package/fesm2020/chips.mjs.map +1 -1
- package/fesm2020/core.mjs +1 -1
- package/fesm2020/core.mjs.map +1 -1
- package/fesm2020/datepicker.mjs +10 -2
- package/fesm2020/datepicker.mjs.map +1 -1
- package/fesm2020/icon.mjs +2 -1
- package/fesm2020/icon.mjs.map +1 -1
- package/fesm2020/legacy-button/testing.mjs +26 -1
- package/fesm2020/legacy-button/testing.mjs.map +1 -1
- package/fesm2020/list.mjs +37 -4
- package/fesm2020/list.mjs.map +1 -1
- package/legacy-button/testing/index.d.ts +5 -0
- package/list/index.d.ts +25 -3
- package/package.json +2 -2
- 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 +1 -1
- package/schematics/ng-add/index.mjs +1 -1
- package/schematics/ng-generate/mdc-migration/index_bundled.js +262 -316
- package/schematics/ng-generate/mdc-migration/index_bundled.js.map +3 -3
- package/schematics/ng-generate/mdc-migration/mdc_migration_bundle_metadata.json +1 -1
- package/schematics/ng-update/index_bundled.js +6 -1
- package/schematics/ng-update/index_bundled.js.map +2 -2
- package/schematics/ng-update/ng_update_index_metadata.json +1 -1
- package/slide-toggle/_slide-toggle-theme.scss +19 -19
|
@@ -7,8 +7,13 @@ import { HarnessPredicate } from '@angular/cdk/testing';
|
|
|
7
7
|
export declare interface ButtonHarnessFilters extends BaseHarnessFilters {
|
|
8
8
|
/** Only find instances whose text matches the given value. */
|
|
9
9
|
text?: string | RegExp;
|
|
10
|
+
/** Only find instances with a variant. */
|
|
11
|
+
variant?: ButtonVariant;
|
|
10
12
|
}
|
|
11
13
|
|
|
14
|
+
/** Possible button appearances. */
|
|
15
|
+
export declare type ButtonVariant = 'basic' | 'raised' | 'flat' | 'icon' | 'stroked' | 'fab' | 'mini-fab';
|
|
16
|
+
|
|
12
17
|
/** Harness for interacting with a MDC-based mat-button in tests. */
|
|
13
18
|
export declare class MatButtonHarness extends ContentContainerComponentHarness {
|
|
14
19
|
static hostSelector: string;
|
|
@@ -17,6 +22,7 @@ export declare class MatButtonHarness extends ContentContainerComponentHarness {
|
|
|
17
22
|
* @param options Options for narrowing the search:
|
|
18
23
|
* - `selector` finds a button whose host element matches the given selector.
|
|
19
24
|
* - `text` finds a button with specific text content.
|
|
25
|
+
* - `variant` finds buttons matching a specific variant.
|
|
20
26
|
* @return a `HarnessPredicate` configured with the given options.
|
|
21
27
|
*/
|
|
22
28
|
static with<T extends MatButtonHarness>(this: ComponentHarnessConstructor<T>, options?: ButtonHarnessFilters): HarnessPredicate<T>;
|
|
@@ -40,6 +46,8 @@ export declare class MatButtonHarness extends ContentContainerComponentHarness {
|
|
|
40
46
|
blur(): Promise<void>;
|
|
41
47
|
/** Whether the button is focused. */
|
|
42
48
|
isFocused(): Promise<boolean>;
|
|
49
|
+
/** Gets the variant of the button. */
|
|
50
|
+
getVariant(): Promise<ButtonVariant>;
|
|
43
51
|
}
|
|
44
52
|
|
|
45
53
|
export { }
|
package/chips/index.d.ts
CHANGED
|
@@ -739,7 +739,19 @@ export declare class MatChipOption extends MatChip implements OnInit {
|
|
|
739
739
|
get selected(): boolean;
|
|
740
740
|
set selected(value: BooleanInput);
|
|
741
741
|
private _selected;
|
|
742
|
-
/**
|
|
742
|
+
/**
|
|
743
|
+
* The ARIA selected applied to the chip. Conforms to WAI ARIA best practices for listbox
|
|
744
|
+
* interaction patterns.
|
|
745
|
+
*
|
|
746
|
+
* From [WAI ARIA Listbox authoring practices guide](
|
|
747
|
+
* https://www.w3.org/WAI/ARIA/apg/patterns/listbox/):
|
|
748
|
+
* "If any options are selected, each selected option has either aria-selected or aria-checked
|
|
749
|
+
* set to true. All options that are selectable but not selected have either aria-selected or
|
|
750
|
+
* aria-checked set to false."
|
|
751
|
+
*
|
|
752
|
+
* Set `aria-selected="false"` on not-selected listbox options that are selectable to fix
|
|
753
|
+
* VoiceOver reading every option as "selected" (#25736).
|
|
754
|
+
*/
|
|
743
755
|
get ariaSelected(): string | null;
|
|
744
756
|
/** The unstyled chip selector for this component. */
|
|
745
757
|
protected basicChipAttrName: string;
|
|
@@ -84,15 +84,17 @@ $mat-typography-mdc-level-mappings: (
|
|
|
84
84
|
}
|
|
85
85
|
|
|
86
86
|
// Converts an MDC typography level config to an Angular Material one.
|
|
87
|
-
@function typography-config-level-from-mdc($mdc-level) {
|
|
87
|
+
@function typography-config-level-from-mdc($mdc-level, $overrides: ()) {
|
|
88
88
|
$mdc-level-config: map.get(mdc-typography.$styles, $mdc-level);
|
|
89
89
|
|
|
90
90
|
@return typography.define-typography-level(
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
91
|
+
$font-size: map.get($overrides, font-size) or map.get($mdc-level-config, font-size),
|
|
92
|
+
$font-family: map.get($overrides, font-family) or map.get($mdc-level-config, font-family),
|
|
93
|
+
$line-height: map.get($overrides, line-height) or map.get($mdc-level-config, line-height),
|
|
94
|
+
$font-weight: map.get($overrides, font-weight) or map.get($mdc-level-config, font-weight),
|
|
95
|
+
$letter-spacing:
|
|
96
|
+
map.get($overrides, letter-spacing) or map.get($mdc-level-config, letter-spacing)
|
|
97
|
+
);
|
|
96
98
|
}
|
|
97
99
|
|
|
98
100
|
// Configures MDC's global variables to reflect the given theme, applies the given styles,
|
|
@@ -1,7 +1,6 @@
|
|
|
1
1
|
@use 'sass:map';
|
|
2
2
|
@use 'sass:math';
|
|
3
3
|
@use 'sass:meta';
|
|
4
|
-
@use '@material/typography' as mdc-typography;
|
|
5
4
|
@use './typography';
|
|
6
5
|
@use '../../autocomplete/autocomplete-theme';
|
|
7
6
|
@use '../../badge/badge-theme';
|
|
@@ -88,49 +87,52 @@
|
|
|
88
87
|
@function define-typography-config(
|
|
89
88
|
// TODO(mmalerba): rename this function to define-typography-config,
|
|
90
89
|
// and create a predefined px based config for people that need it.
|
|
91
|
-
$font-family:
|
|
92
|
-
$headline-1:
|
|
93
|
-
$headline-2:
|
|
94
|
-
$headline-3:
|
|
95
|
-
$headline-4:
|
|
96
|
-
$headline-5:
|
|
97
|
-
$headline-6:
|
|
98
|
-
$subtitle-1:
|
|
99
|
-
$subtitle-2:
|
|
100
|
-
$body-1:
|
|
101
|
-
$body-2:
|
|
102
|
-
$caption:
|
|
103
|
-
$button:
|
|
104
|
-
$overline:
|
|
90
|
+
$font-family: null,
|
|
91
|
+
$headline-1: null,
|
|
92
|
+
$headline-2: null,
|
|
93
|
+
$headline-3: null,
|
|
94
|
+
$headline-4: null,
|
|
95
|
+
$headline-5: null,
|
|
96
|
+
$headline-6: null,
|
|
97
|
+
$subtitle-1: null,
|
|
98
|
+
$subtitle-2: null,
|
|
99
|
+
$body-1: null,
|
|
100
|
+
$body-2: null,
|
|
101
|
+
$caption: null,
|
|
102
|
+
$button: null,
|
|
103
|
+
$overline: null,
|
|
105
104
|
) {
|
|
106
105
|
// Declare an initial map with all of the levels.
|
|
107
|
-
$
|
|
108
|
-
headline-1: $headline-1,
|
|
109
|
-
headline-2: $headline-2,
|
|
110
|
-
headline-3: $headline-3,
|
|
111
|
-
headline-4: $headline-4,
|
|
112
|
-
headline-5: $headline-5,
|
|
113
|
-
headline-6: $headline-6,
|
|
114
|
-
subtitle-1: $subtitle-1,
|
|
115
|
-
subtitle-2: $subtitle-2,
|
|
116
|
-
body-1: $body-1,
|
|
117
|
-
body-2: $body-2,
|
|
118
|
-
caption: $caption,
|
|
119
|
-
button: $button,
|
|
120
|
-
overline: $overline,
|
|
121
|
-
);
|
|
106
|
+
$overrides: if($font-family, (font-family: $font-family), ());
|
|
122
107
|
|
|
123
|
-
|
|
124
|
-
|
|
125
|
-
|
|
126
|
-
|
|
127
|
-
|
|
128
|
-
|
|
129
|
-
|
|
130
|
-
|
|
131
|
-
|
|
132
|
-
|
|
133
|
-
|
|
108
|
+
@return (
|
|
109
|
+
headline-1: $headline-1 or _rem-to-px(
|
|
110
|
+
mdc-helpers.typography-config-level-from-mdc(headline1, $overrides)),
|
|
111
|
+
headline-2: $headline-2 or _rem-to-px(
|
|
112
|
+
mdc-helpers.typography-config-level-from-mdc(headline2, $overrides)),
|
|
113
|
+
headline-3: $headline-3 or _rem-to-px(
|
|
114
|
+
mdc-helpers.typography-config-level-from-mdc(headline3, $overrides)),
|
|
115
|
+
headline-4: $headline-4 or _rem-to-px(
|
|
116
|
+
mdc-helpers.typography-config-level-from-mdc(headline4, $overrides)),
|
|
117
|
+
headline-5: $headline-5 or _rem-to-px(
|
|
118
|
+
mdc-helpers.typography-config-level-from-mdc(headline5, $overrides)),
|
|
119
|
+
headline-6: $headline-6 or _rem-to-px(
|
|
120
|
+
mdc-helpers.typography-config-level-from-mdc(headline6, $overrides)),
|
|
121
|
+
subtitle-1: $subtitle-1 or _rem-to-px(
|
|
122
|
+
mdc-helpers.typography-config-level-from-mdc(subtitle1, $overrides)),
|
|
123
|
+
subtitle-2: $subtitle-2 or _rem-to-px(
|
|
124
|
+
mdc-helpers.typography-config-level-from-mdc(subtitle2, $overrides)),
|
|
125
|
+
body-1: $body-1 or _rem-to-px(
|
|
126
|
+
mdc-helpers.typography-config-level-from-mdc(body1, $overrides)),
|
|
127
|
+
body-2: $body-2 or _rem-to-px(
|
|
128
|
+
mdc-helpers.typography-config-level-from-mdc(body2, $overrides)),
|
|
129
|
+
caption: $caption or _rem-to-px(
|
|
130
|
+
mdc-helpers.typography-config-level-from-mdc(caption, $overrides)),
|
|
131
|
+
button: $button or _rem-to-px(
|
|
132
|
+
mdc-helpers.typography-config-level-from-mdc(button, $overrides)),
|
|
133
|
+
overline: $overline or _rem-to-px(
|
|
134
|
+
mdc-helpers.typography-config-level-from-mdc(overline, $overrides)),
|
|
135
|
+
);
|
|
134
136
|
}
|
|
135
137
|
|
|
136
138
|
/// Generates an Angular Material typography config based on values from the official Material
|
|
@@ -158,49 +160,39 @@
|
|
|
158
160
|
@function define-rem-typography-config(
|
|
159
161
|
// TODO(mmalerba): rename this function to define-typography-config,
|
|
160
162
|
// and create a predefined px based config for people that need it.
|
|
161
|
-
$font-family:
|
|
162
|
-
$headline-1:
|
|
163
|
-
$headline-2:
|
|
164
|
-
$headline-3:
|
|
165
|
-
$headline-4:
|
|
166
|
-
$headline-5:
|
|
167
|
-
$headline-6:
|
|
168
|
-
$subtitle-1:
|
|
169
|
-
$subtitle-2:
|
|
170
|
-
$body-1:
|
|
171
|
-
$body-2:
|
|
172
|
-
$caption:
|
|
173
|
-
$button:
|
|
174
|
-
$overline:
|
|
163
|
+
$font-family: null,
|
|
164
|
+
$headline-1: null,
|
|
165
|
+
$headline-2: null,
|
|
166
|
+
$headline-3: null,
|
|
167
|
+
$headline-4: null,
|
|
168
|
+
$headline-5: null,
|
|
169
|
+
$headline-6: null,
|
|
170
|
+
$subtitle-1: null,
|
|
171
|
+
$subtitle-2: null,
|
|
172
|
+
$body-1: null,
|
|
173
|
+
$body-2: null,
|
|
174
|
+
$caption: null,
|
|
175
|
+
$button: null,
|
|
176
|
+
$overline: null,
|
|
175
177
|
) {
|
|
176
178
|
// Declare an initial map with all of the levels.
|
|
177
|
-
$
|
|
178
|
-
headline-1: $headline-1,
|
|
179
|
-
headline-2: $headline-2,
|
|
180
|
-
headline-3: $headline-3,
|
|
181
|
-
headline-4: $headline-4,
|
|
182
|
-
headline-5: $headline-5,
|
|
183
|
-
headline-6: $headline-6,
|
|
184
|
-
subtitle-1: $subtitle-1,
|
|
185
|
-
subtitle-2: $subtitle-2,
|
|
186
|
-
body-1: $body-1,
|
|
187
|
-
body-2: $body-2,
|
|
188
|
-
caption: $caption,
|
|
189
|
-
button: $button,
|
|
190
|
-
overline: $overline,
|
|
191
|
-
);
|
|
179
|
+
$overrides: if($font-family, (font-family: $font-family), ());
|
|
192
180
|
|
|
193
|
-
|
|
194
|
-
|
|
195
|
-
|
|
196
|
-
|
|
197
|
-
|
|
198
|
-
|
|
199
|
-
|
|
200
|
-
|
|
201
|
-
|
|
202
|
-
|
|
203
|
-
|
|
181
|
+
@return (
|
|
182
|
+
headline-1: $headline-1 or mdc-helpers.typography-config-level-from-mdc(headline1, $overrides),
|
|
183
|
+
headline-2: $headline-2 or mdc-helpers.typography-config-level-from-mdc(headline2, $overrides),
|
|
184
|
+
headline-3: $headline-3 or mdc-helpers.typography-config-level-from-mdc(headline3, $overrides),
|
|
185
|
+
headline-4: $headline-4 or mdc-helpers.typography-config-level-from-mdc(headline4, $overrides),
|
|
186
|
+
headline-5: $headline-5 or mdc-helpers.typography-config-level-from-mdc(headline5, $overrides),
|
|
187
|
+
headline-6: $headline-6 or mdc-helpers.typography-config-level-from-mdc(headline6, $overrides),
|
|
188
|
+
subtitle-1: $subtitle-1 or mdc-helpers.typography-config-level-from-mdc(subtitle1, $overrides),
|
|
189
|
+
subtitle-2: $subtitle-2 or mdc-helpers.typography-config-level-from-mdc(subtitle2, $overrides),
|
|
190
|
+
body-1: $body-1 or mdc-helpers.typography-config-level-from-mdc(body1, $overrides),
|
|
191
|
+
body-2: $body-2 or mdc-helpers.typography-config-level-from-mdc(body2, $overrides),
|
|
192
|
+
caption: $caption or mdc-helpers.typography-config-level-from-mdc(caption, $overrides),
|
|
193
|
+
button: $button or mdc-helpers.typography-config-level-from-mdc(button, $overrides),
|
|
194
|
+
overline: $overline or mdc-helpers.typography-config-level-from-mdc(overline, $overrides),
|
|
195
|
+
);
|
|
204
196
|
}
|
|
205
197
|
|
|
206
198
|
@mixin private-all-unmigrated-component-typographies($config) {
|
package/datepicker/index.d.ts
CHANGED
|
@@ -1080,9 +1080,17 @@ export declare class MatDatepickerIntl {
|
|
|
1080
1080
|
switchToMonthViewLabel: string;
|
|
1081
1081
|
/** A label for the 'switch to year view' button (used by screen readers). */
|
|
1082
1082
|
switchToMultiYearViewLabel: string;
|
|
1083
|
-
/**
|
|
1083
|
+
/**
|
|
1084
|
+
* A label for the first date of a range of dates (used by screen readers).
|
|
1085
|
+
* @deprecated Provide your own internationalization string.
|
|
1086
|
+
* @breaking-change 17.0.0
|
|
1087
|
+
*/
|
|
1084
1088
|
startDateLabel: string;
|
|
1085
|
-
/**
|
|
1089
|
+
/**
|
|
1090
|
+
* A label for the last date of a range of dates (used by screen readers).
|
|
1091
|
+
* @deprecated Provide your own internationalization string.
|
|
1092
|
+
* @breaking-change 17.0.0
|
|
1093
|
+
*/
|
|
1086
1094
|
endDateLabel: string;
|
|
1087
1095
|
/** Formats a range of years (used for visuals). */
|
|
1088
1096
|
formatYearRange(start: string, end: string): string;
|
|
@@ -6,4 +6,4 @@
|
|
|
6
6
|
* found in the LICENSE file at https://angular.io/license
|
|
7
7
|
*/
|
|
8
8
|
export {};
|
|
9
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
9
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYnV0dG9uLWhhcm5lc3MtZmlsdGVycy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3NyYy9tYXRlcmlhbC9idXR0b24vdGVzdGluZy9idXR0b24taGFybmVzcy1maWx0ZXJzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOzs7Ozs7R0FNRyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQGxpY2Vuc2VcbiAqIENvcHlyaWdodCBHb29nbGUgTExDIEFsbCBSaWdodHMgUmVzZXJ2ZWQuXG4gKlxuICogVXNlIG9mIHRoaXMgc291cmNlIGNvZGUgaXMgZ292ZXJuZWQgYnkgYW4gTUlULXN0eWxlIGxpY2Vuc2UgdGhhdCBjYW4gYmVcbiAqIGZvdW5kIGluIHRoZSBMSUNFTlNFIGZpbGUgYXQgaHR0cHM6Ly9hbmd1bGFyLmlvL2xpY2Vuc2VcbiAqL1xuXG5pbXBvcnQge0Jhc2VIYXJuZXNzRmlsdGVyc30gZnJvbSAnQGFuZ3VsYXIvY2RrL3Rlc3RpbmcnO1xuXG4vKiogUG9zc2libGUgYnV0dG9uIGFwcGVhcmFuY2VzLiAqL1xuZXhwb3J0IHR5cGUgQnV0dG9uVmFyaWFudCA9ICdiYXNpYycgfCAncmFpc2VkJyB8ICdmbGF0JyB8ICdpY29uJyB8ICdzdHJva2VkJyB8ICdmYWInIHwgJ21pbmktZmFiJztcblxuLyoqIEEgc2V0IG9mIGNyaXRlcmlhIHRoYXQgY2FuIGJlIHVzZWQgdG8gZmlsdGVyIGEgbGlzdCBvZiBidXR0b24gaGFybmVzcyBpbnN0YW5jZXMuICovXG5leHBvcnQgaW50ZXJmYWNlIEJ1dHRvbkhhcm5lc3NGaWx0ZXJzIGV4dGVuZHMgQmFzZUhhcm5lc3NGaWx0ZXJzIHtcbiAgLyoqIE9ubHkgZmluZCBpbnN0YW5jZXMgd2hvc2UgdGV4dCBtYXRjaGVzIHRoZSBnaXZlbiB2YWx1ZS4gKi9cbiAgdGV4dD86IHN0cmluZyB8IFJlZ0V4cDtcblxuICAvKiogT25seSBmaW5kIGluc3RhbmNlcyB3aXRoIGEgdmFyaWFudC4gKi9cbiAgdmFyaWFudD86IEJ1dHRvblZhcmlhbnQ7XG59XG4iXX0=
|
|
@@ -14,10 +14,13 @@ export class MatButtonHarness extends ContentContainerComponentHarness {
|
|
|
14
14
|
* @param options Options for narrowing the search:
|
|
15
15
|
* - `selector` finds a button whose host element matches the given selector.
|
|
16
16
|
* - `text` finds a button with specific text content.
|
|
17
|
+
* - `variant` finds buttons matching a specific variant.
|
|
17
18
|
* @return a `HarnessPredicate` configured with the given options.
|
|
18
19
|
*/
|
|
19
20
|
static with(options = {}) {
|
|
20
|
-
return new HarnessPredicate(this, options)
|
|
21
|
+
return new HarnessPredicate(this, options)
|
|
22
|
+
.addOption('text', options.text, (harness, text) => HarnessPredicate.stringMatches(harness.getText(), text))
|
|
23
|
+
.addOption('variant', options.variant, (harness, variant) => HarnessPredicate.stringMatches(harness.getVariant(), variant));
|
|
21
24
|
}
|
|
22
25
|
async click(...args) {
|
|
23
26
|
return (await this.host()).click(...args);
|
|
@@ -43,8 +46,31 @@ export class MatButtonHarness extends ContentContainerComponentHarness {
|
|
|
43
46
|
async isFocused() {
|
|
44
47
|
return (await this.host()).isFocused();
|
|
45
48
|
}
|
|
49
|
+
/** Gets the variant of the button. */
|
|
50
|
+
async getVariant() {
|
|
51
|
+
const host = await this.host();
|
|
52
|
+
if ((await host.getAttribute('mat-raised-button')) != null) {
|
|
53
|
+
return 'raised';
|
|
54
|
+
}
|
|
55
|
+
else if ((await host.getAttribute('mat-flat-button')) != null) {
|
|
56
|
+
return 'flat';
|
|
57
|
+
}
|
|
58
|
+
else if ((await host.getAttribute('mat-icon-button')) != null) {
|
|
59
|
+
return 'icon';
|
|
60
|
+
}
|
|
61
|
+
else if ((await host.getAttribute('mat-stroked-button')) != null) {
|
|
62
|
+
return 'stroked';
|
|
63
|
+
}
|
|
64
|
+
else if ((await host.getAttribute('mat-fab')) != null) {
|
|
65
|
+
return 'fab';
|
|
66
|
+
}
|
|
67
|
+
else if ((await host.getAttribute('mat-mini-fab')) != null) {
|
|
68
|
+
return 'mini-fab';
|
|
69
|
+
}
|
|
70
|
+
return 'basic';
|
|
71
|
+
}
|
|
46
72
|
}
|
|
47
73
|
// TODO(jelbourn) use a single class, like `.mat-button-base`
|
|
48
74
|
MatButtonHarness.hostSelector = `[mat-button], [mat-raised-button], [mat-flat-button],
|
|
49
75
|
[mat-icon-button], [mat-stroked-button], [mat-fab], [mat-mini-fab]`;
|
|
50
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
76
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"button-harness.js","sourceRoot":"","sources":["../../../../../../../src/material/button/testing/button-harness.ts"],"names":[],"mappings":"AAAA;;;;;;GAMG;AAEH,OAAO,EAEL,gCAAgC,EAChC,gBAAgB,GACjB,MAAM,sBAAsB,CAAC;AAC9B,OAAO,EAAC,qBAAqB,EAAC,MAAM,uBAAuB,CAAC;AAG5D,oEAAoE;AACpE,MAAM,OAAO,gBAAiB,SAAQ,gCAAgC;IAKpE;;;;;;;OAOG;IACH,MAAM,CAAC,IAAI,CAET,UAAgC,EAAE;QAElC,OAAO,IAAI,gBAAgB,CAAC,IAAI,EAAE,OAAO,CAAC;aACvC,SAAS,CAAC,MAAM,EAAE,OAAO,CAAC,IAAI,EAAE,CAAC,OAAO,EAAE,IAAI,EAAE,EAAE,CACjD,gBAAgB,CAAC,aAAa,CAAC,OAAO,CAAC,OAAO,EAAE,EAAE,IAAI,CAAC,CACxD;aACA,SAAS,CAAC,SAAS,EAAE,OAAO,CAAC,OAAO,EAAE,CAAC,OAAO,EAAE,OAAO,EAAE,EAAE,CAC1D,gBAAgB,CAAC,aAAa,CAAC,OAAO,CAAC,UAAU,EAAE,EAAE,OAAO,CAAC,CAC9D,CAAC;IACN,CAAC;IAYD,KAAK,CAAC,KAAK,CAAC,GAAG,IAAwC;QACrD,OAAO,CAAC,MAAM,IAAI,CAAC,IAAI,EAAE,CAAC,CAAC,KAAK,CAAC,GAAI,IAAW,CAAC,CAAC;IACpD,CAAC;IAED,mEAAmE;IACnE,KAAK,CAAC,UAAU;QACd,MAAM,QAAQ,GAAG,CAAC,MAAM,IAAI,CAAC,IAAI,EAAE,CAAC,CAAC,YAAY,CAAC,UAAU,CAAC,CAAC;QAC9D,OAAO,qBAAqB,CAAC,MAAM,QAAQ,CAAC,CAAC;IAC/C,CAAC;IAED,kDAAkD;IAClD,KAAK,CAAC,OAAO;QACX,OAAO,CAAC,MAAM,IAAI,CAAC,IAAI,EAAE,CAAC,CAAC,IAAI,EAAE,CAAC;IACpC,CAAC;IAED,gGAAgG;IAChG,KAAK,CAAC,KAAK;QACT,OAAO,CAAC,MAAM,IAAI,CAAC,IAAI,EAAE,CAAC,CAAC,KAAK,EAAE,CAAC;IACrC,CAAC;IAED,8FAA8F;IAC9F,KAAK,CAAC,IAAI;QACR,OAAO,CAAC,MAAM,IAAI,CAAC,IAAI,EAAE,CAAC,CAAC,IAAI,EAAE,CAAC;IACpC,CAAC;IAED,qCAAqC;IACrC,KAAK,CAAC,SAAS;QACb,OAAO,CAAC,MAAM,IAAI,CAAC,IAAI,EAAE,CAAC,CAAC,SAAS,EAAE,CAAC;IACzC,CAAC;IAED,sCAAsC;IACtC,KAAK,CAAC,UAAU;QACd,MAAM,IAAI,GAAG,MAAM,IAAI,CAAC,IAAI,EAAE,CAAC;QAE/B,IAAI,CAAC,MAAM,IAAI,CAAC,YAAY,CAAC,mBAAmB,CAAC,CAAC,IAAI,IAAI,EAAE;YAC1D,OAAO,QAAQ,CAAC;SACjB;aAAM,IAAI,CAAC,MAAM,IAAI,CAAC,YAAY,CAAC,iBAAiB,CAAC,CAAC,IAAI,IAAI,EAAE;YAC/D,OAAO,MAAM,CAAC;SACf;aAAM,IAAI,CAAC,MAAM,IAAI,CAAC,YAAY,CAAC,iBAAiB,CAAC,CAAC,IAAI,IAAI,EAAE;YAC/D,OAAO,MAAM,CAAC;SACf;aAAM,IAAI,CAAC,MAAM,IAAI,CAAC,YAAY,CAAC,oBAAoB,CAAC,CAAC,IAAI,IAAI,EAAE;YAClE,OAAO,SAAS,CAAC;SAClB;aAAM,IAAI,CAAC,MAAM,IAAI,CAAC,YAAY,CAAC,SAAS,CAAC,CAAC,IAAI,IAAI,EAAE;YACvD,OAAO,KAAK,CAAC;SACd;aAAM,IAAI,CAAC,MAAM,IAAI,CAAC,YAAY,CAAC,cAAc,CAAC,CAAC,IAAI,IAAI,EAAE;YAC5D,OAAO,UAAU,CAAC;SACnB;QAED,OAAO,OAAO,CAAC;IACjB,CAAC;;AApFD,6DAA6D;AACtD,6BAAY,GAAG;4FACoE,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  ComponentHarnessConstructor,\n  ContentContainerComponentHarness,\n  HarnessPredicate,\n} from '@angular/cdk/testing';\nimport {coerceBooleanProperty} from '@angular/cdk/coercion';\nimport {ButtonHarnessFilters, ButtonVariant} from './button-harness-filters';\n\n/** Harness for interacting with a MDC-based mat-button in tests. */\nexport class MatButtonHarness extends ContentContainerComponentHarness {\n  // TODO(jelbourn) use a single class, like `.mat-button-base`\n  static hostSelector = `[mat-button], [mat-raised-button], [mat-flat-button],\n                         [mat-icon-button], [mat-stroked-button], [mat-fab], [mat-mini-fab]`;\n\n  /**\n   * Gets a `HarnessPredicate` that can be used to search for a button with specific attributes.\n   * @param options Options for narrowing the search:\n   *   - `selector` finds a button whose host element matches the given selector.\n   *   - `text` finds a button with specific text content.\n   *   - `variant` finds buttons matching a specific variant.\n   * @return a `HarnessPredicate` configured with the given options.\n   */\n  static with<T extends MatButtonHarness>(\n    this: ComponentHarnessConstructor<T>,\n    options: ButtonHarnessFilters = {},\n  ): HarnessPredicate<T> {\n    return new HarnessPredicate(this, options)\n      .addOption('text', options.text, (harness, text) =>\n        HarnessPredicate.stringMatches(harness.getText(), text),\n      )\n      .addOption('variant', options.variant, (harness, variant) =>\n        HarnessPredicate.stringMatches(harness.getVariant(), variant),\n      );\n  }\n\n  /**\n   * Clicks the button at the given position relative to its top-left.\n   * @param relativeX The relative x position of the click.\n   * @param relativeY The relative y position of the click.\n   */\n  click(relativeX: number, relativeY: number): Promise<void>;\n  /** Clicks the button at its center. */\n  click(location: 'center'): Promise<void>;\n  /** Clicks the button. */\n  click(): Promise<void>;\n  async click(...args: [] | ['center'] | [number, number]): Promise<void> {\n    return (await this.host()).click(...(args as []));\n  }\n\n  /** Gets a boolean promise indicating if the button is disabled. */\n  async isDisabled(): Promise<boolean> {\n    const disabled = (await this.host()).getAttribute('disabled');\n    return coerceBooleanProperty(await disabled);\n  }\n\n  /** Gets a promise for the button's label text. */\n  async getText(): Promise<string> {\n    return (await this.host()).text();\n  }\n\n  /** Focuses the button and returns a void promise that indicates when the action is complete. */\n  async focus(): Promise<void> {\n    return (await this.host()).focus();\n  }\n\n  /** Blurs the button and returns a void promise that indicates when the action is complete. */\n  async blur(): Promise<void> {\n    return (await this.host()).blur();\n  }\n\n  /** Whether the button is focused. */\n  async isFocused(): Promise<boolean> {\n    return (await this.host()).isFocused();\n  }\n\n  /** Gets the variant of the button. */\n  async getVariant(): Promise<ButtonVariant> {\n    const host = await this.host();\n\n    if ((await host.getAttribute('mat-raised-button')) != null) {\n      return 'raised';\n    } else if ((await host.getAttribute('mat-flat-button')) != null) {\n      return 'flat';\n    } else if ((await host.getAttribute('mat-icon-button')) != null) {\n      return 'icon';\n    } else if ((await host.getAttribute('mat-stroked-button')) != null) {\n      return 'stroked';\n    } else if ((await host.getAttribute('mat-fab')) != null) {\n      return 'fab';\n    } else if ((await host.getAttribute('mat-mini-fab')) != null) {\n      return 'mini-fab';\n    }\n\n    return 'basic';\n  }\n}\n"]}
|