@angular/material 12.2.6 → 12.2.7
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/bundles/material-core.umd.js +7 -17
- package/bundles/material-core.umd.js.map +1 -1
- package/bundles/material-list.umd.js +3 -3
- package/bundles/material-select.umd.js +3 -1
- package/bundles/material-select.umd.js.map +1 -1
- package/bundles/material-snack-bar-testing.umd.js +19 -20
- package/bundles/material-snack-bar-testing.umd.js.map +1 -1
- package/bundles/material-tabs.umd.js +22 -8
- package/bundles/material-tabs.umd.js.map +1 -1
- package/core/common-behaviors/common-module.d.ts +0 -4
- package/core/index.metadata.json +1 -1
- package/esm2015/core/common-behaviors/common-module.js +4 -13
- package/esm2015/core/version.js +1 -1
- package/esm2015/list/list.js +2 -2
- package/esm2015/list/selection-list.js +1 -1
- package/esm2015/select/select.js +4 -2
- package/esm2015/snack-bar/testing/snack-bar-harness.js +20 -21
- package/esm2015/tabs/public-api.js +2 -2
- package/esm2015/tabs/tab-label.js +16 -2
- package/esm2015/tabs/tab.js +9 -8
- package/fesm2015/core.js +4 -14
- package/fesm2015/core.js.map +1 -1
- package/fesm2015/list.js +3 -3
- package/fesm2015/select.js +3 -1
- package/fesm2015/select.js.map +1 -1
- package/fesm2015/snack-bar/testing.js +19 -20
- package/fesm2015/snack-bar/testing.js.map +1 -1
- package/fesm2015/tabs.js +23 -8
- package/fesm2015/tabs.js.map +1 -1
- package/list/index.metadata.json +1 -1
- package/package.json +2 -2
- package/schematics/ng-add/index.js +1 -1
- package/schematics/ng-add/index.mjs +1 -1
- package/select/index.metadata.json +1 -1
- package/snack-bar/testing/snack-bar-harness.d.ts +8 -9
- package/tabs/index.metadata.json +1 -1
- package/tabs/public-api.d.ts +1 -1
- package/tabs/tab-label.d.ts +8 -1
- package/tabs/tab.d.ts +1 -1
|
@@ -12,9 +12,8 @@ export class MatSnackBarHarness extends ContentContainerComponentHarness {
|
|
|
12
12
|
constructor() {
|
|
13
13
|
super(...arguments);
|
|
14
14
|
this._messageSelector = '.mat-simple-snackbar > span';
|
|
15
|
-
this._simpleSnackBarSelector = '.mat-simple-snackbar';
|
|
16
15
|
this._actionButtonSelector = '.mat-simple-snackbar-action > button';
|
|
17
|
-
this.
|
|
16
|
+
this._snackBarLiveRegion = this.locatorFor('[aria-live]');
|
|
18
17
|
}
|
|
19
18
|
/**
|
|
20
19
|
* Gets a `HarnessPredicate` that can be used to search for a `MatSnackBarHarness` that meets
|
|
@@ -42,7 +41,7 @@ export class MatSnackBarHarness extends ContentContainerComponentHarness {
|
|
|
42
41
|
*/
|
|
43
42
|
getAriaLive() {
|
|
44
43
|
return __awaiter(this, void 0, void 0, function* () {
|
|
45
|
-
return (yield this.
|
|
44
|
+
return (yield this._snackBarLiveRegion())
|
|
46
45
|
.getAttribute('aria-live');
|
|
47
46
|
});
|
|
48
47
|
}
|
|
@@ -51,8 +50,8 @@ export class MatSnackBarHarness extends ContentContainerComponentHarness {
|
|
|
51
50
|
*/
|
|
52
51
|
hasAction() {
|
|
53
52
|
return __awaiter(this, void 0, void 0, function* () {
|
|
54
|
-
yield this.
|
|
55
|
-
return (yield this.
|
|
53
|
+
yield this._assertContentAnnotated();
|
|
54
|
+
return (yield this._getActionButton()) !== null;
|
|
56
55
|
});
|
|
57
56
|
}
|
|
58
57
|
/**
|
|
@@ -61,8 +60,8 @@ export class MatSnackBarHarness extends ContentContainerComponentHarness {
|
|
|
61
60
|
*/
|
|
62
61
|
getActionDescription() {
|
|
63
62
|
return __awaiter(this, void 0, void 0, function* () {
|
|
64
|
-
yield this.
|
|
65
|
-
return (yield this.
|
|
63
|
+
yield this._assertHasAction();
|
|
64
|
+
return (yield this._getActionButton()).text();
|
|
66
65
|
});
|
|
67
66
|
}
|
|
68
67
|
/**
|
|
@@ -71,8 +70,8 @@ export class MatSnackBarHarness extends ContentContainerComponentHarness {
|
|
|
71
70
|
*/
|
|
72
71
|
dismissWithAction() {
|
|
73
72
|
return __awaiter(this, void 0, void 0, function* () {
|
|
74
|
-
yield this.
|
|
75
|
-
yield (yield this.
|
|
73
|
+
yield this._assertHasAction();
|
|
74
|
+
yield (yield this._getActionButton()).click();
|
|
76
75
|
});
|
|
77
76
|
}
|
|
78
77
|
/**
|
|
@@ -80,7 +79,7 @@ export class MatSnackBarHarness extends ContentContainerComponentHarness {
|
|
|
80
79
|
*/
|
|
81
80
|
getMessage() {
|
|
82
81
|
return __awaiter(this, void 0, void 0, function* () {
|
|
83
|
-
yield this.
|
|
82
|
+
yield this._assertContentAnnotated();
|
|
84
83
|
return (yield this.locatorFor(this._messageSelector)()).text();
|
|
85
84
|
});
|
|
86
85
|
}
|
|
@@ -100,10 +99,10 @@ export class MatSnackBarHarness extends ContentContainerComponentHarness {
|
|
|
100
99
|
});
|
|
101
100
|
}
|
|
102
101
|
/**
|
|
103
|
-
* Asserts that the current snack-bar
|
|
104
|
-
*
|
|
102
|
+
* Asserts that the current snack-bar has annotated content. Promise reject
|
|
103
|
+
* if content is not annotated.
|
|
105
104
|
*/
|
|
106
|
-
|
|
105
|
+
_assertContentAnnotated() {
|
|
107
106
|
return __awaiter(this, void 0, void 0, function* () {
|
|
108
107
|
if (!(yield this._isSimpleSnackBar())) {
|
|
109
108
|
throw Error('Method cannot be used for snack-bar with custom content.');
|
|
@@ -111,25 +110,25 @@ export class MatSnackBarHarness extends ContentContainerComponentHarness {
|
|
|
111
110
|
});
|
|
112
111
|
}
|
|
113
112
|
/**
|
|
114
|
-
* Asserts that the current snack-bar
|
|
115
|
-
*
|
|
113
|
+
* Asserts that the current snack-bar has an action defined. Otherwise the
|
|
114
|
+
* promise will reject.
|
|
116
115
|
*/
|
|
117
|
-
|
|
116
|
+
_assertHasAction() {
|
|
118
117
|
return __awaiter(this, void 0, void 0, function* () {
|
|
119
|
-
yield this.
|
|
118
|
+
yield this._assertContentAnnotated();
|
|
120
119
|
if (!(yield this.hasAction())) {
|
|
121
|
-
throw Error('Method cannot be used for
|
|
120
|
+
throw Error('Method cannot be used for a snack-bar without an action.');
|
|
122
121
|
}
|
|
123
122
|
});
|
|
124
123
|
}
|
|
125
124
|
/** Whether the snack-bar is using the default content template. */
|
|
126
125
|
_isSimpleSnackBar() {
|
|
127
126
|
return __awaiter(this, void 0, void 0, function* () {
|
|
128
|
-
return (yield this.locatorForOptional(
|
|
127
|
+
return (yield this.locatorForOptional('.mat-simple-snackbar')()) !== null;
|
|
129
128
|
});
|
|
130
129
|
}
|
|
131
130
|
/** Gets the simple snack bar action button. */
|
|
132
|
-
|
|
131
|
+
_getActionButton() {
|
|
133
132
|
return __awaiter(this, void 0, void 0, function* () {
|
|
134
133
|
return this.locatorForOptional(this._actionButtonSelector)();
|
|
135
134
|
});
|
|
@@ -139,4 +138,4 @@ export class MatSnackBarHarness extends ContentContainerComponentHarness {
|
|
|
139
138
|
// snackbar. The canonical snack-bar parent is the "MatSnackBarContainer".
|
|
140
139
|
/** The selector for the host element of a `MatSnackBar` instance. */
|
|
141
140
|
MatSnackBarHarness.hostSelector = '.mat-snack-bar-container';
|
|
142
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"snack-bar-harness.js","sourceRoot":"","sources":["../../../../../../../src/material/snack-bar/testing/snack-bar-harness.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 {AriaLivePoliteness} from '@angular/cdk/a11y';\nimport {ContentContainerComponentHarness, HarnessPredicate, parallel} from '@angular/cdk/testing';\nimport {SnackBarHarnessFilters} from './snack-bar-harness-filters';\n\n/** Harness for interacting with a standard mat-snack-bar in tests. */\nexport class MatSnackBarHarness extends ContentContainerComponentHarness<string> {\n  // Developers can provide a custom component or template for the\n  // snackbar. The canonical snack-bar parent is the \"MatSnackBarContainer\".\n  /** The selector for the host element of a `MatSnackBar` instance. */\n  static hostSelector = '.mat-snack-bar-container';\n  protected _messageSelector = '.mat-simple-snackbar > span';\n  protected _simpleSnackBarSelector = '.mat-simple-snackbar';\n  protected _actionButtonSelector = '.mat-simple-snackbar-action > button';\n  private _simpleSnackBarLiveRegion = this.locatorFor('[aria-live]');\n\n  /**\n   * Gets a `HarnessPredicate` that can be used to search for a `MatSnackBarHarness` that meets\n   * certain criteria.\n   * @param options Options for filtering which snack bar instances are considered a match.\n   * @return a `HarnessPredicate` configured with the given options.\n   */\n  static with(options: SnackBarHarnessFilters = {}): HarnessPredicate<MatSnackBarHarness> {\n    return new HarnessPredicate(MatSnackBarHarness, options);\n  }\n\n  /**\n   * Gets the role of the snack-bar. The role of a snack-bar is determined based\n   * on the ARIA politeness specified in the snack-bar config.\n   * @deprecated Use `getAriaLive` instead.\n   * @breaking-change 13.0.0\n   */\n  async getRole(): Promise<'alert'|'status'|null> {\n    return (await this.host()).getAttribute('role') as Promise<'alert'|'status'|null>;\n  }\n\n  /**\n   * Gets the aria-live of the snack-bar's live region. The aria-live of a snack-bar is\n   * determined based on the ARIA politeness specified in the snack-bar config.\n   */\n  async getAriaLive(): Promise<AriaLivePoliteness> {\n    return (await this._simpleSnackBarLiveRegion())\n        .getAttribute('aria-live') as Promise<AriaLivePoliteness>;\n  }\n\n  /**\n   * Whether the snack-bar has an action. Method cannot be used for snack-bar's with custom content.\n   */\n  async hasAction(): Promise<boolean> {\n    await this._assertSimpleSnackBar();\n    return (await this._getSimpleSnackBarActionButton()) !== null;\n  }\n\n  /**\n   * Gets the description of the snack-bar. Method cannot be used for snack-bar's without action or\n   * with custom content.\n   */\n  async getActionDescription(): Promise<string> {\n    await this._assertSimpleSnackBarWithAction();\n    return (await this._getSimpleSnackBarActionButton())!.text();\n  }\n\n\n  /**\n   * Dismisses the snack-bar by clicking the action button. Method cannot be used for snack-bar's\n   * without action or with custom content.\n   */\n  async dismissWithAction(): Promise<void> {\n    await this._assertSimpleSnackBarWithAction();\n    await (await this._getSimpleSnackBarActionButton())!.click();\n  }\n\n  /**\n   * Gets the message of the snack-bar. Method cannot be used for snack-bar's with custom content.\n   */\n  async getMessage(): Promise<string> {\n    await this._assertSimpleSnackBar();\n    return (await this.locatorFor(this._messageSelector)()).text();\n  }\n\n  /** Gets whether the snack-bar has been dismissed. */\n  async isDismissed(): Promise<boolean> {\n    // We consider the snackbar dismissed if it's not in the DOM. We can assert that the\n    // element isn't in the DOM by seeing that its width and height are zero.\n\n    const host = await this.host();\n    const [exit, dimensions] = await parallel(() => [\n      // The snackbar container is marked with the \"exit\" attribute after it has been dismissed\n      // but before the animation has finished (after which it's removed from the DOM).\n      host.getAttribute('mat-exit'),\n      host.getDimensions(),\n    ]);\n\n    return exit != null || (!!dimensions && dimensions.height === 0 && dimensions.width === 0);\n  }\n\n  /**\n   * Asserts that the current snack-bar does not use custom content. Promise rejects if\n   * custom content is used.\n   */\n  private async _assertSimpleSnackBar(): Promise<void> {\n    if (!await this._isSimpleSnackBar()) {\n      throw Error('Method cannot be used for snack-bar with custom content.');\n    }\n  }\n\n  /**\n   * Asserts that the current snack-bar does not use custom content and has\n   * an action defined. Otherwise the promise will reject.\n   */\n  private async _assertSimpleSnackBarWithAction(): Promise<void> {\n    await this._assertSimpleSnackBar();\n    if (!await this.hasAction()) {\n      throw Error('Method cannot be used for standard snack-bar without action.');\n    }\n  }\n\n  /** Whether the snack-bar is using the default content template. */\n  private async _isSimpleSnackBar(): Promise<boolean> {\n    return await this.locatorForOptional(this._simpleSnackBarSelector)() !== null;\n  }\n\n  /** Gets the simple snack bar action button. */\n  private async _getSimpleSnackBarActionButton() {\n    return this.locatorForOptional(this._actionButtonSelector)();\n  }\n}\n"]}
|
|
141
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"snack-bar-harness.js","sourceRoot":"","sources":["../../../../../../../src/material/snack-bar/testing/snack-bar-harness.ts"],"names":[],"mappings":"AAAA;;;;;;GAMG;;AAGH,OAAO,EAAC,gCAAgC,EAAE,gBAAgB,EAAE,QAAQ,EAAC,MAAM,sBAAsB,CAAC;AAGlG,sEAAsE;AACtE,MAAM,OAAO,kBAAmB,SAAQ,gCAAwC;IAAhF;;QAKY,qBAAgB,GAAG,6BAA6B,CAAC;QACjD,0BAAqB,GAAG,sCAAsC,CAAC;QACjE,wBAAmB,GAAG,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,CAAC;IAgH/D,CAAC;IA9GC;;;;;OAKG;IACH,MAAM,CAAC,IAAI,CAAC,UAAkC,EAAE;QAC9C,OAAO,IAAI,gBAAgB,CAAC,kBAAkB,EAAE,OAAO,CAAC,CAAC;IAC3D,CAAC;IAED;;;;;OAKG;IACG,OAAO;;YACX,OAAO,CAAC,MAAM,IAAI,CAAC,IAAI,EAAE,CAAC,CAAC,YAAY,CAAC,MAAM,CAAmC,CAAC;QACpF,CAAC;KAAA;IAED;;;OAGG;IACG,WAAW;;YACf,OAAO,CAAC,MAAM,IAAI,CAAC,mBAAmB,EAAE,CAAC;iBACpC,YAAY,CAAC,WAAW,CAAgC,CAAC;QAChE,CAAC;KAAA;IAED;;OAEG;IACG,SAAS;;YACb,MAAM,IAAI,CAAC,uBAAuB,EAAE,CAAC;YACrC,OAAO,CAAC,MAAM,IAAI,CAAC,gBAAgB,EAAE,CAAC,KAAK,IAAI,CAAC;QAClD,CAAC;KAAA;IAED;;;OAGG;IACG,oBAAoB;;YACxB,MAAM,IAAI,CAAC,gBAAgB,EAAE,CAAC;YAC9B,OAAO,CAAC,MAAM,IAAI,CAAC,gBAAgB,EAAE,CAAE,CAAC,IAAI,EAAE,CAAC;QACjD,CAAC;KAAA;IAGD;;;OAGG;IACG,iBAAiB;;YACrB,MAAM,IAAI,CAAC,gBAAgB,EAAE,CAAC;YAC9B,MAAM,CAAC,MAAM,IAAI,CAAC,gBAAgB,EAAE,CAAE,CAAC,KAAK,EAAE,CAAC;QACjD,CAAC;KAAA;IAED;;OAEG;IACG,UAAU;;YACd,MAAM,IAAI,CAAC,uBAAuB,EAAE,CAAC;YACrC,OAAO,CAAC,MAAM,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,gBAAgB,CAAC,EAAE,CAAC,CAAC,IAAI,EAAE,CAAC;QACjE,CAAC;KAAA;IAED,qDAAqD;IAC/C,WAAW;;YACf,oFAAoF;YACpF,yEAAyE;YAEzE,MAAM,IAAI,GAAG,MAAM,IAAI,CAAC,IAAI,EAAE,CAAC;YAC/B,MAAM,CAAC,IAAI,EAAE,UAAU,CAAC,GAAG,MAAM,QAAQ,CAAC,GAAG,EAAE,CAAC;gBAC9C,yFAAyF;gBACzF,iFAAiF;gBACjF,IAAI,CAAC,YAAY,CAAC,UAAU,CAAC;gBAC7B,IAAI,CAAC,aAAa,EAAE;aACrB,CAAC,CAAC;YAEH,OAAO,IAAI,IAAI,IAAI,IAAI,CAAC,CAAC,CAAC,UAAU,IAAI,UAAU,CAAC,MAAM,KAAK,CAAC,IAAI,UAAU,CAAC,KAAK,KAAK,CAAC,CAAC,CAAC;QAC7F,CAAC;KAAA;IAED;;;OAGG;IACa,uBAAuB;;YACrC,IAAI,CAAC,CAAA,MAAM,IAAI,CAAC,iBAAiB,EAAE,CAAA,EAAE;gBACnC,MAAM,KAAK,CAAC,0DAA0D,CAAC,CAAC;aACzE;QACH,CAAC;KAAA;IAED;;;OAGG;IACa,gBAAgB;;YAC9B,MAAM,IAAI,CAAC,uBAAuB,EAAE,CAAC;YACrC,IAAI,CAAC,CAAA,MAAM,IAAI,CAAC,SAAS,EAAE,CAAA,EAAE;gBAC3B,MAAM,KAAK,CAAC,0DAA0D,CAAC,CAAC;aACzE;QACH,CAAC;KAAA;IAED,mEAAmE;IACrD,iBAAiB;;YAC7B,OAAO,CAAA,MAAM,IAAI,CAAC,kBAAkB,CAAC,sBAAsB,CAAC,EAAE,MAAK,IAAI,CAAC;QAC1E,CAAC;KAAA;IAED,+CAA+C;IACjC,gBAAgB;;YAC5B,OAAO,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,qBAAqB,CAAC,EAAE,CAAC;QAC/D,CAAC;KAAA;;AArHD,gEAAgE;AAChE,0EAA0E;AAC1E,qEAAqE;AAC9D,+BAAY,GAAG,0BAA0B,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 {AriaLivePoliteness} from '@angular/cdk/a11y';\nimport {ContentContainerComponentHarness, HarnessPredicate, parallel} from '@angular/cdk/testing';\nimport {SnackBarHarnessFilters} from './snack-bar-harness-filters';\n\n/** Harness for interacting with a standard mat-snack-bar in tests. */\nexport class MatSnackBarHarness extends ContentContainerComponentHarness<string> {\n  // Developers can provide a custom component or template for the\n  // snackbar. The canonical snack-bar parent is the \"MatSnackBarContainer\".\n  /** The selector for the host element of a `MatSnackBar` instance. */\n  static hostSelector = '.mat-snack-bar-container';\n  protected _messageSelector = '.mat-simple-snackbar > span';\n  protected _actionButtonSelector = '.mat-simple-snackbar-action > button';\n  private _snackBarLiveRegion = this.locatorFor('[aria-live]');\n\n  /**\n   * Gets a `HarnessPredicate` that can be used to search for a `MatSnackBarHarness` that meets\n   * certain criteria.\n   * @param options Options for filtering which snack bar instances are considered a match.\n   * @return a `HarnessPredicate` configured with the given options.\n   */\n  static with(options: SnackBarHarnessFilters = {}): HarnessPredicate<MatSnackBarHarness> {\n    return new HarnessPredicate(MatSnackBarHarness, options);\n  }\n\n  /**\n   * Gets the role of the snack-bar. The role of a snack-bar is determined based\n   * on the ARIA politeness specified in the snack-bar config.\n   * @deprecated Use `getAriaLive` instead.\n   * @breaking-change 13.0.0\n   */\n  async getRole(): Promise<'alert'|'status'|null> {\n    return (await this.host()).getAttribute('role') as Promise<'alert'|'status'|null>;\n  }\n\n  /**\n   * Gets the aria-live of the snack-bar's live region. The aria-live of a snack-bar is\n   * determined based on the ARIA politeness specified in the snack-bar config.\n   */\n  async getAriaLive(): Promise<AriaLivePoliteness> {\n    return (await this._snackBarLiveRegion())\n        .getAttribute('aria-live') as Promise<AriaLivePoliteness>;\n  }\n\n  /**\n   * Whether the snack-bar has an action. Method cannot be used for snack-bar's with custom content.\n   */\n  async hasAction(): Promise<boolean> {\n    await this._assertContentAnnotated();\n    return (await this._getActionButton()) !== null;\n  }\n\n  /**\n   * Gets the description of the snack-bar. Method cannot be used for snack-bar's without action or\n   * with custom content.\n   */\n  async getActionDescription(): Promise<string> {\n    await this._assertHasAction();\n    return (await this._getActionButton())!.text();\n  }\n\n\n  /**\n   * Dismisses the snack-bar by clicking the action button. Method cannot be used for snack-bar's\n   * without action or with custom content.\n   */\n  async dismissWithAction(): Promise<void> {\n    await this._assertHasAction();\n    await (await this._getActionButton())!.click();\n  }\n\n  /**\n   * Gets the message of the snack-bar. Method cannot be used for snack-bar's with custom content.\n   */\n  async getMessage(): Promise<string> {\n    await this._assertContentAnnotated();\n    return (await this.locatorFor(this._messageSelector)()).text();\n  }\n\n  /** Gets whether the snack-bar has been dismissed. */\n  async isDismissed(): Promise<boolean> {\n    // We consider the snackbar dismissed if it's not in the DOM. We can assert that the\n    // element isn't in the DOM by seeing that its width and height are zero.\n\n    const host = await this.host();\n    const [exit, dimensions] = await parallel(() => [\n      // The snackbar container is marked with the \"exit\" attribute after it has been dismissed\n      // but before the animation has finished (after which it's removed from the DOM).\n      host.getAttribute('mat-exit'),\n      host.getDimensions(),\n    ]);\n\n    return exit != null || (!!dimensions && dimensions.height === 0 && dimensions.width === 0);\n  }\n\n  /**\n   * Asserts that the current snack-bar has annotated content. Promise reject\n   * if content is not annotated.\n   */\n  protected async _assertContentAnnotated(): Promise<void> {\n    if (!await this._isSimpleSnackBar()) {\n      throw Error('Method cannot be used for snack-bar with custom content.');\n    }\n  }\n\n  /**\n   * Asserts that the current snack-bar has an action defined. Otherwise the\n   * promise will reject.\n   */\n  protected async _assertHasAction(): Promise<void> {\n    await this._assertContentAnnotated();\n    if (!await this.hasAction()) {\n      throw Error('Method cannot be used for a snack-bar without an action.');\n    }\n  }\n\n  /** Whether the snack-bar is using the default content template. */\n  private async _isSimpleSnackBar(): Promise<boolean> {\n    return await this.locatorForOptional('.mat-simple-snackbar')() !== null;\n  }\n\n  /** Gets the simple snack bar action button. */\n  private async _getActionButton() {\n    return this.locatorForOptional(this._actionButtonSelector)();\n  }\n}\n"]}
|
|
@@ -12,9 +12,9 @@ export { MatTabBody, _MatTabBodyBase, MatTabBodyPortal } from './tab-body';
|
|
|
12
12
|
export { MatTabHeader, _MatTabHeaderBase } from './tab-header';
|
|
13
13
|
export { MatTabLabelWrapper } from './tab-label-wrapper';
|
|
14
14
|
export { MatTab, MAT_TAB_GROUP } from './tab';
|
|
15
|
-
export { MatTabLabel } from './tab-label';
|
|
15
|
+
export { MatTabLabel, MAT_TAB } from './tab-label';
|
|
16
16
|
export { MatTabNav, MatTabLink, _MatTabNavBase, _MatTabLinkBase } from './tab-nav-bar/index';
|
|
17
17
|
export { MatTabContent } from './tab-content';
|
|
18
18
|
export * from './tabs-animations';
|
|
19
19
|
export { MAT_TABS_CONFIG } from './tab-config';
|
|
20
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
20
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3NyYy9tYXRlcmlhbC90YWJzL3B1YmxpYy1hcGkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7Ozs7OztHQU1HO0FBRUgsT0FBTyxFQUFDLGFBQWEsRUFBQyxNQUFNLGVBQWUsQ0FBQztBQUM1QyxjQUFjLGFBQWEsQ0FBQztBQUM1QixPQUFPLEVBQUMsU0FBUyxFQUF3Qix1QkFBdUIsRUFBQyxNQUFNLFdBQVcsQ0FBQztBQUNuRixPQUFPLEVBQ0wsVUFBVSxFQUNWLGVBQWUsRUFHZixnQkFBZ0IsRUFDakIsTUFBTSxZQUFZLENBQUM7QUFDcEIsT0FBTyxFQUFDLFlBQVksRUFBRSxpQkFBaUIsRUFBQyxNQUFNLGNBQWMsQ0FBQztBQUM3RCxPQUFPLEVBQUMsa0JBQWtCLEVBQUMsTUFBTSxxQkFBcUIsQ0FBQztBQUN2RCxPQUFPLEVBQUMsTUFBTSxFQUFFLGFBQWEsRUFBQyxNQUFNLE9BQU8sQ0FBQztBQUM1QyxPQUFPLEVBQUMsV0FBVyxFQUFFLE9BQU8sRUFBQyxNQUFNLGFBQWEsQ0FBQztBQUNqRCxPQUFPLEVBQUMsU0FBUyxFQUFFLFVBQVUsRUFBRSxjQUFjLEVBQUUsZUFBZSxFQUFDLE1BQU0scUJBQXFCLENBQUM7QUFDM0YsT0FBTyxFQUFDLGFBQWEsRUFBQyxNQUFNLGVBQWUsQ0FBQztBQUU1QyxjQUFjLG1CQUFtQixDQUFDO0FBQ2xDLE9BQU8sRUFBQyxlQUFlLEVBQWdCLE1BQU0sY0FBYyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBAbGljZW5zZVxuICogQ29weXJpZ2h0IEdvb2dsZSBMTEMgQWxsIFJpZ2h0cyBSZXNlcnZlZC5cbiAqXG4gKiBVc2Ugb2YgdGhpcyBzb3VyY2UgY29kZSBpcyBnb3Zlcm5lZCBieSBhbiBNSVQtc3R5bGUgbGljZW5zZSB0aGF0IGNhbiBiZVxuICogZm91bmQgaW4gdGhlIExJQ0VOU0UgZmlsZSBhdCBodHRwczovL2FuZ3VsYXIuaW8vbGljZW5zZVxuICovXG5cbmV4cG9ydCB7TWF0VGFic01vZHVsZX0gZnJvbSAnLi90YWJzLW1vZHVsZSc7XG5leHBvcnQgKiBmcm9tICcuL3RhYi1ncm91cCc7XG5leHBvcnQge01hdElua0JhciwgX01hdElua0JhclBvc2l0aW9uZXIsIF9NQVRfSU5LX0JBUl9QT1NJVElPTkVSfSBmcm9tICcuL2luay1iYXInO1xuZXhwb3J0IHtcbiAgTWF0VGFiQm9keSxcbiAgX01hdFRhYkJvZHlCYXNlLFxuICBNYXRUYWJCb2R5T3JpZ2luU3RhdGUsXG4gIE1hdFRhYkJvZHlQb3NpdGlvblN0YXRlLFxuICBNYXRUYWJCb2R5UG9ydGFsXG59IGZyb20gJy4vdGFiLWJvZHknO1xuZXhwb3J0IHtNYXRUYWJIZWFkZXIsIF9NYXRUYWJIZWFkZXJCYXNlfSBmcm9tICcuL3RhYi1oZWFkZXInO1xuZXhwb3J0IHtNYXRUYWJMYWJlbFdyYXBwZXJ9IGZyb20gJy4vdGFiLWxhYmVsLXdyYXBwZXInO1xuZXhwb3J0IHtNYXRUYWIsIE1BVF9UQUJfR1JPVVB9IGZyb20gJy4vdGFiJztcbmV4cG9ydCB7TWF0VGFiTGFiZWwsIE1BVF9UQUJ9IGZyb20gJy4vdGFiLWxhYmVsJztcbmV4cG9ydCB7TWF0VGFiTmF2LCBNYXRUYWJMaW5rLCBfTWF0VGFiTmF2QmFzZSwgX01hdFRhYkxpbmtCYXNlfSBmcm9tICcuL3RhYi1uYXYtYmFyL2luZGV4JztcbmV4cG9ydCB7TWF0VGFiQ29udGVudH0gZnJvbSAnLi90YWItY29udGVudCc7XG5leHBvcnQge1Njcm9sbERpcmVjdGlvbn0gZnJvbSAnLi9wYWdpbmF0ZWQtdGFiLWhlYWRlcic7XG5leHBvcnQgKiBmcm9tICcuL3RhYnMtYW5pbWF0aW9ucyc7XG5leHBvcnQge01BVF9UQUJTX0NPTkZJRywgTWF0VGFic0NvbmZpZ30gZnJvbSAnLi90YWItY29uZmlnJztcbiJdfQ==
|
|
@@ -5,7 +5,7 @@
|
|
|
5
5
|
* Use of this source code is governed by an MIT-style license that can be
|
|
6
6
|
* found in the LICENSE file at https://angular.io/license
|
|
7
7
|
*/
|
|
8
|
-
import { Directive, InjectionToken } from '@angular/core';
|
|
8
|
+
import { Directive, Inject, InjectionToken, Optional, TemplateRef, ViewContainerRef, } from '@angular/core';
|
|
9
9
|
import { CdkPortal } from '@angular/cdk/portal';
|
|
10
10
|
/**
|
|
11
11
|
* Injection token that can be used to reference instances of `MatTabLabel`. It serves as
|
|
@@ -13,8 +13,17 @@ import { CdkPortal } from '@angular/cdk/portal';
|
|
|
13
13
|
* retention of the class and its directive metadata.
|
|
14
14
|
*/
|
|
15
15
|
export const MAT_TAB_LABEL = new InjectionToken('MatTabLabel');
|
|
16
|
+
/**
|
|
17
|
+
* Used to provide a tab label to a tab without causing a circular dependency.
|
|
18
|
+
* @docs-private
|
|
19
|
+
*/
|
|
20
|
+
export const MAT_TAB = new InjectionToken('MAT_TAB');
|
|
16
21
|
/** Used to flag tab labels for use with the portal directive */
|
|
17
22
|
export class MatTabLabel extends CdkPortal {
|
|
23
|
+
constructor(templateRef, viewContainerRef, _closestTab) {
|
|
24
|
+
super(templateRef, viewContainerRef);
|
|
25
|
+
this._closestTab = _closestTab;
|
|
26
|
+
}
|
|
18
27
|
}
|
|
19
28
|
MatTabLabel.decorators = [
|
|
20
29
|
{ type: Directive, args: [{
|
|
@@ -22,4 +31,9 @@ MatTabLabel.decorators = [
|
|
|
22
31
|
providers: [{ provide: MAT_TAB_LABEL, useExisting: MatTabLabel }],
|
|
23
32
|
},] }
|
|
24
33
|
];
|
|
25
|
-
|
|
34
|
+
MatTabLabel.ctorParameters = () => [
|
|
35
|
+
{ type: TemplateRef },
|
|
36
|
+
{ type: ViewContainerRef },
|
|
37
|
+
{ type: undefined, decorators: [{ type: Inject, args: [MAT_TAB,] }, { type: Optional }] }
|
|
38
|
+
];
|
|
39
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFiLWxhYmVsLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vc3JjL21hdGVyaWFsL3RhYnMvdGFiLWxhYmVsLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOzs7Ozs7R0FNRztBQUVILE9BQU8sRUFDTCxTQUFTLEVBQ1QsTUFBTSxFQUNOLGNBQWMsRUFDZCxRQUFRLEVBQ1IsV0FBVyxFQUNYLGdCQUFnQixHQUNqQixNQUFNLGVBQWUsQ0FBQztBQUN2QixPQUFPLEVBQUMsU0FBUyxFQUFDLE1BQU0scUJBQXFCLENBQUM7QUFFOUM7Ozs7R0FJRztBQUNILE1BQU0sQ0FBQyxNQUFNLGFBQWEsR0FBRyxJQUFJLGNBQWMsQ0FBYyxhQUFhLENBQUMsQ0FBQztBQUU1RTs7O0dBR0c7QUFDRixNQUFNLENBQUMsTUFBTSxPQUFPLEdBQUcsSUFBSSxjQUFjLENBQU0sU0FBUyxDQUFDLENBQUM7QUFFM0QsZ0VBQWdFO0FBS2hFLE1BQU0sT0FBTyxXQUFZLFNBQVEsU0FBUztJQUN4QyxZQUNFLFdBQTZCLEVBQzdCLGdCQUFrQyxFQUNFLFdBQWdCO1FBQ3BELEtBQUssQ0FBQyxXQUFXLEVBQUUsZ0JBQWdCLENBQUMsQ0FBQztRQURELGdCQUFXLEdBQVgsV0FBVyxDQUFLO0lBRXRELENBQUM7OztZQVZGLFNBQVMsU0FBQztnQkFDVCxRQUFRLEVBQUUsZ0NBQWdDO2dCQUMxQyxTQUFTLEVBQUUsQ0FBQyxFQUFDLE9BQU8sRUFBRSxhQUFhLEVBQUUsV0FBVyxFQUFFLFdBQVcsRUFBQyxDQUFDO2FBQ2hFOzs7WUF0QkMsV0FBVztZQUNYLGdCQUFnQjs0Q0EwQmIsTUFBTSxTQUFDLE9BQU8sY0FBRyxRQUFRIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBAbGljZW5zZVxuICogQ29weXJpZ2h0IEdvb2dsZSBMTEMgQWxsIFJpZ2h0cyBSZXNlcnZlZC5cbiAqXG4gKiBVc2Ugb2YgdGhpcyBzb3VyY2UgY29kZSBpcyBnb3Zlcm5lZCBieSBhbiBNSVQtc3R5bGUgbGljZW5zZSB0aGF0IGNhbiBiZVxuICogZm91bmQgaW4gdGhlIExJQ0VOU0UgZmlsZSBhdCBodHRwczovL2FuZ3VsYXIuaW8vbGljZW5zZVxuICovXG5cbmltcG9ydCB7XG4gIERpcmVjdGl2ZSxcbiAgSW5qZWN0LFxuICBJbmplY3Rpb25Ub2tlbixcbiAgT3B0aW9uYWwsXG4gIFRlbXBsYXRlUmVmLFxuICBWaWV3Q29udGFpbmVyUmVmLFxufSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7Q2RrUG9ydGFsfSBmcm9tICdAYW5ndWxhci9jZGsvcG9ydGFsJztcblxuLyoqXG4gKiBJbmplY3Rpb24gdG9rZW4gdGhhdCBjYW4gYmUgdXNlZCB0byByZWZlcmVuY2UgaW5zdGFuY2VzIG9mIGBNYXRUYWJMYWJlbGAuIEl0IHNlcnZlcyBhc1xuICogYWx0ZXJuYXRpdmUgdG9rZW4gdG8gdGhlIGFjdHVhbCBgTWF0VGFiTGFiZWxgIGNsYXNzIHdoaWNoIGNvdWxkIGNhdXNlIHVubmVjZXNzYXJ5XG4gKiByZXRlbnRpb24gb2YgdGhlIGNsYXNzIGFuZCBpdHMgZGlyZWN0aXZlIG1ldGFkYXRhLlxuICovXG5leHBvcnQgY29uc3QgTUFUX1RBQl9MQUJFTCA9IG5ldyBJbmplY3Rpb25Ub2tlbjxNYXRUYWJMYWJlbD4oJ01hdFRhYkxhYmVsJyk7XG5cbi8qKlxuICogVXNlZCB0byBwcm92aWRlIGEgdGFiIGxhYmVsIHRvIGEgdGFiIHdpdGhvdXQgY2F1c2luZyBhIGNpcmN1bGFyIGRlcGVuZGVuY3kuXG4gKiBAZG9jcy1wcml2YXRlXG4gKi9cbiBleHBvcnQgY29uc3QgTUFUX1RBQiA9IG5ldyBJbmplY3Rpb25Ub2tlbjxhbnk+KCdNQVRfVEFCJyk7XG5cbi8qKiBVc2VkIHRvIGZsYWcgdGFiIGxhYmVscyBmb3IgdXNlIHdpdGggdGhlIHBvcnRhbCBkaXJlY3RpdmUgKi9cbkBEaXJlY3RpdmUoe1xuICBzZWxlY3RvcjogJ1ttYXQtdGFiLWxhYmVsXSwgW21hdFRhYkxhYmVsXScsXG4gIHByb3ZpZGVyczogW3twcm92aWRlOiBNQVRfVEFCX0xBQkVMLCB1c2VFeGlzdGluZzogTWF0VGFiTGFiZWx9XSxcbn0pXG5leHBvcnQgY2xhc3MgTWF0VGFiTGFiZWwgZXh0ZW5kcyBDZGtQb3J0YWwge1xuICBjb25zdHJ1Y3RvcihcbiAgICB0ZW1wbGF0ZVJlZjogVGVtcGxhdGVSZWY8YW55PixcbiAgICB2aWV3Q29udGFpbmVyUmVmOiBWaWV3Q29udGFpbmVyUmVmLFxuICAgIEBJbmplY3QoTUFUX1RBQikgQE9wdGlvbmFsKCkgcHVibGljIF9jbG9zZXN0VGFiOiBhbnkpIHtcbiAgICBzdXBlcih0ZW1wbGF0ZVJlZiwgdmlld0NvbnRhaW5lclJlZik7XG4gIH1cbn1cbiJdfQ==
|
package/esm2015/tabs/tab.js
CHANGED
|
@@ -10,7 +10,7 @@ import { ChangeDetectionStrategy, Component, ContentChild, Input, TemplateRef, V
|
|
|
10
10
|
import { mixinDisabled } from '@angular/material/core';
|
|
11
11
|
import { Subject } from 'rxjs';
|
|
12
12
|
import { MAT_TAB_CONTENT } from './tab-content';
|
|
13
|
-
import { MAT_TAB_LABEL, MatTabLabel } from './tab-label';
|
|
13
|
+
import { MAT_TAB_LABEL, MatTabLabel, MAT_TAB } from './tab-label';
|
|
14
14
|
// Boilerplate for applying mixins to MatTab.
|
|
15
15
|
/** @docs-private */
|
|
16
16
|
const _MatTabBase = mixinDisabled(class {
|
|
@@ -71,11 +71,11 @@ export class MatTab extends _MatTabBase {
|
|
|
71
71
|
* @docs-private
|
|
72
72
|
*/
|
|
73
73
|
_setTemplateLabelInput(value) {
|
|
74
|
-
// Only update the
|
|
75
|
-
//
|
|
76
|
-
//
|
|
77
|
-
//
|
|
78
|
-
if (value) {
|
|
74
|
+
// Only update the label if the query managed to find one. This works around an issue where a
|
|
75
|
+
// user may have manually set `templateLabel` during creation mode, which would then get
|
|
76
|
+
// clobbered by `undefined` when the query resolves. Also note that we check that the closest
|
|
77
|
+
// tab matches the current one so that we don't pick up labels from nested tabs.
|
|
78
|
+
if (value && value._closestTab === this) {
|
|
79
79
|
this._templateLabel = value;
|
|
80
80
|
}
|
|
81
81
|
}
|
|
@@ -88,7 +88,8 @@ MatTab.decorators = [
|
|
|
88
88
|
// tslint:disable-next-line:validate-decorators
|
|
89
89
|
changeDetection: ChangeDetectionStrategy.Default,
|
|
90
90
|
encapsulation: ViewEncapsulation.None,
|
|
91
|
-
exportAs: 'matTab'
|
|
91
|
+
exportAs: 'matTab',
|
|
92
|
+
providers: [{ provide: MAT_TAB, useExisting: MatTab }]
|
|
92
93
|
},] }
|
|
93
94
|
];
|
|
94
95
|
MatTab.ctorParameters = () => [
|
|
@@ -103,4 +104,4 @@ MatTab.propDecorators = {
|
|
|
103
104
|
ariaLabel: [{ type: Input, args: ['aria-label',] }],
|
|
104
105
|
ariaLabelledby: [{ type: Input, args: ['aria-labelledby',] }]
|
|
105
106
|
};
|
|
106
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
107
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tab.js","sourceRoot":"","sources":["../../../../../../src/material/tabs/tab.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 {BooleanInput} from '@angular/cdk/coercion';\nimport {TemplatePortal} from '@angular/cdk/portal';\nimport {\n  ChangeDetectionStrategy,\n  Component,\n  ContentChild,\n  Input,\n  OnChanges,\n  OnDestroy,\n  OnInit,\n  SimpleChanges,\n  TemplateRef,\n  ViewChild,\n  ViewContainerRef,\n  ViewEncapsulation,\n  InjectionToken,\n  Inject,\n  Optional,\n} from '@angular/core';\nimport {CanDisable, mixinDisabled} from '@angular/material/core';\nimport {Subject} from 'rxjs';\nimport {MAT_TAB_CONTENT} from './tab-content';\nimport {MAT_TAB_LABEL, MatTabLabel, MAT_TAB} from './tab-label';\n\n\n// Boilerplate for applying mixins to MatTab.\n/** @docs-private */\nconst _MatTabBase = mixinDisabled(class {});\n\n/**\n * Used to provide a tab group to a tab without causing a circular dependency.\n * @docs-private\n */\nexport const MAT_TAB_GROUP = new InjectionToken<any>('MAT_TAB_GROUP');\n\n@Component({\n  selector: 'mat-tab',\n  templateUrl: 'tab.html',\n  inputs: ['disabled'],\n  // tslint:disable-next-line:validate-decorators\n  changeDetection: ChangeDetectionStrategy.Default,\n  encapsulation: ViewEncapsulation.None,\n  exportAs: 'matTab',\n  providers: [{provide: MAT_TAB, useExisting: MatTab}]\n})\nexport class MatTab extends _MatTabBase implements OnInit, CanDisable, OnChanges, OnDestroy {\n  /** Content for the tab label given by `<ng-template mat-tab-label>`. */\n  @ContentChild(MAT_TAB_LABEL)\n  get templateLabel(): MatTabLabel { return this._templateLabel; }\n  set templateLabel(value: MatTabLabel) { this._setTemplateLabelInput(value); }\n  protected _templateLabel: MatTabLabel;\n\n  /**\n   * Template provided in the tab content that will be used if present, used to enable lazy-loading\n   */\n  @ContentChild(MAT_TAB_CONTENT, {read: TemplateRef, static: true})\n  _explicitContent: TemplateRef<any>;\n\n  /** Template inside the MatTab view that contains an `<ng-content>`. */\n  @ViewChild(TemplateRef, {static: true}) _implicitContent: TemplateRef<any>;\n\n  /** Plain text label for the tab, used when there is no template label. */\n  @Input('label') textLabel: string = '';\n\n  /** Aria label for the tab. */\n  @Input('aria-label') ariaLabel: string;\n\n  /**\n   * Reference to the element that the tab is labelled by.\n   * Will be cleared if `aria-label` is set at the same time.\n   */\n  @Input('aria-labelledby') ariaLabelledby: string;\n\n  /** Portal that will be the hosted content of the tab */\n  private _contentPortal: TemplatePortal | null = null;\n\n  /** @docs-private */\n  get content(): TemplatePortal | null {\n    return this._contentPortal;\n  }\n\n  /** Emits whenever the internal state of the tab changes. */\n  readonly _stateChanges = new Subject<void>();\n\n  /**\n   * The relatively indexed position where 0 represents the center, negative is left, and positive\n   * represents the right.\n   */\n  position: number | null = null;\n\n  /**\n   * The initial relatively index origin of the tab if it was created and selected after there\n   * was already a selected tab. Provides context of what position the tab should originate from.\n   */\n  origin: number | null = null;\n\n  /**\n   * Whether the tab is currently active.\n   */\n  isActive = false;\n\n  constructor(\n    private _viewContainerRef: ViewContainerRef,\n    @Inject(MAT_TAB_GROUP) @Optional() public _closestTabGroup: any) {\n    super();\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if (changes.hasOwnProperty('textLabel') || changes.hasOwnProperty('disabled')) {\n      this._stateChanges.next();\n    }\n  }\n\n  ngOnDestroy(): void {\n    this._stateChanges.complete();\n  }\n\n  ngOnInit(): void {\n    this._contentPortal = new TemplatePortal(\n        this._explicitContent || this._implicitContent, this._viewContainerRef);\n  }\n\n  /**\n   * This has been extracted to a util because of TS 4 and VE.\n   * View Engine doesn't support property rename inheritance.\n   * TS 4.0 doesn't allow properties to override accessors or vice-versa.\n   * @docs-private\n   */\n  protected _setTemplateLabelInput(value: MatTabLabel|undefined) {\n    // Only update the label if the query managed to find one. This works around an issue where a\n    // user may have manually set `templateLabel` during creation mode, which would then get\n    // clobbered by `undefined` when the query resolves. Also note that we check that the closest\n    // tab matches the current one so that we don't pick up labels from nested tabs.\n    if (value && value._closestTab === this) {\n      this._templateLabel = value;\n    }\n  }\n\n  static ngAcceptInputType_disabled: BooleanInput;\n}\n"]}
|
package/fesm2015/core.js
CHANGED
|
@@ -4,9 +4,9 @@ import { HighContrastModeDetector, isFakeMousedownFromScreenReader, isFakeTouchs
|
|
|
4
4
|
import { BidiModule } from '@angular/cdk/bidi';
|
|
5
5
|
import { VERSION as VERSION$2 } from '@angular/cdk';
|
|
6
6
|
import { DOCUMENT, CommonModule } from '@angular/common';
|
|
7
|
+
import { _isTestEnvironment, Platform, PlatformModule, normalizePassiveListenerOptions } from '@angular/cdk/platform';
|
|
7
8
|
import { coerceBooleanProperty, coerceNumberProperty, coerceElement } from '@angular/cdk/coercion';
|
|
8
9
|
import { Subject, Observable } from 'rxjs';
|
|
9
|
-
import { Platform, PlatformModule, normalizePassiveListenerOptions } from '@angular/cdk/platform';
|
|
10
10
|
import { startWith } from 'rxjs/operators';
|
|
11
11
|
import { ANIMATION_MODULE_TYPE } from '@angular/platform-browser/animations';
|
|
12
12
|
import { ENTER, SPACE, hasModifierKey } from '@angular/cdk/keycodes';
|
|
@@ -19,7 +19,7 @@ import { ENTER, SPACE, hasModifierKey } from '@angular/cdk/keycodes';
|
|
|
19
19
|
* found in the LICENSE file at https://angular.io/license
|
|
20
20
|
*/
|
|
21
21
|
/** Current version of Angular Material. */
|
|
22
|
-
const VERSION$1 = new Version('12.2.
|
|
22
|
+
const VERSION$1 = new Version('12.2.7');
|
|
23
23
|
|
|
24
24
|
/**
|
|
25
25
|
* @license
|
|
@@ -53,7 +53,7 @@ AnimationDurations.EXITING = '195ms';
|
|
|
53
53
|
// i.e. avoid core to depend on the @angular/material primary entry-point
|
|
54
54
|
// Can be removed once the Material primary entry-point no longer
|
|
55
55
|
// re-exports all secondary entry-points
|
|
56
|
-
const VERSION = new Version('12.2.
|
|
56
|
+
const VERSION = new Version('12.2.7');
|
|
57
57
|
/** @docs-private */
|
|
58
58
|
function MATERIAL_SANITY_CHECKS_FACTORY() {
|
|
59
59
|
return true;
|
|
@@ -87,18 +87,13 @@ class MatCommonModule {
|
|
|
87
87
|
this._hasDoneGlobalChecks = true;
|
|
88
88
|
}
|
|
89
89
|
}
|
|
90
|
-
/** Use defaultView of injected document if available or fallback to global window reference */
|
|
91
|
-
_getWindow() {
|
|
92
|
-
const win = this._document.defaultView || window;
|
|
93
|
-
return typeof win === 'object' && win ? win : null;
|
|
94
|
-
}
|
|
95
90
|
/** Gets whether a specific sanity check is enabled. */
|
|
96
91
|
_checkIsEnabled(name) {
|
|
97
92
|
// TODO(crisbeto): we can't use `ngDevMode` here yet, because ViewEngine apps might not support
|
|
98
93
|
// it. Since these checks can have performance implications and they aren't tree shakeable
|
|
99
94
|
// in their current form, we can leave the `isDevMode` check in for now.
|
|
100
95
|
// tslint:disable-next-line:ban
|
|
101
|
-
if (!isDevMode() ||
|
|
96
|
+
if (!isDevMode() || _isTestEnvironment()) {
|
|
102
97
|
return false;
|
|
103
98
|
}
|
|
104
99
|
if (typeof this._sanityChecks === 'boolean') {
|
|
@@ -106,11 +101,6 @@ class MatCommonModule {
|
|
|
106
101
|
}
|
|
107
102
|
return !!this._sanityChecks[name];
|
|
108
103
|
}
|
|
109
|
-
/** Whether the code is running in tests. */
|
|
110
|
-
_isTestEnv() {
|
|
111
|
-
const window = this._getWindow();
|
|
112
|
-
return window && (window.__karma__ || window.jasmine);
|
|
113
|
-
}
|
|
114
104
|
_checkDoctypeIsDefined() {
|
|
115
105
|
if (this._checkIsEnabled('doctype') && !this._document.doctype) {
|
|
116
106
|
console.warn('Current document does not have a doctype. This may cause ' +
|