@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.
Files changed (39) hide show
  1. package/bundles/material-core.umd.js +7 -17
  2. package/bundles/material-core.umd.js.map +1 -1
  3. package/bundles/material-list.umd.js +3 -3
  4. package/bundles/material-select.umd.js +3 -1
  5. package/bundles/material-select.umd.js.map +1 -1
  6. package/bundles/material-snack-bar-testing.umd.js +19 -20
  7. package/bundles/material-snack-bar-testing.umd.js.map +1 -1
  8. package/bundles/material-tabs.umd.js +22 -8
  9. package/bundles/material-tabs.umd.js.map +1 -1
  10. package/core/common-behaviors/common-module.d.ts +0 -4
  11. package/core/index.metadata.json +1 -1
  12. package/esm2015/core/common-behaviors/common-module.js +4 -13
  13. package/esm2015/core/version.js +1 -1
  14. package/esm2015/list/list.js +2 -2
  15. package/esm2015/list/selection-list.js +1 -1
  16. package/esm2015/select/select.js +4 -2
  17. package/esm2015/snack-bar/testing/snack-bar-harness.js +20 -21
  18. package/esm2015/tabs/public-api.js +2 -2
  19. package/esm2015/tabs/tab-label.js +16 -2
  20. package/esm2015/tabs/tab.js +9 -8
  21. package/fesm2015/core.js +4 -14
  22. package/fesm2015/core.js.map +1 -1
  23. package/fesm2015/list.js +3 -3
  24. package/fesm2015/select.js +3 -1
  25. package/fesm2015/select.js.map +1 -1
  26. package/fesm2015/snack-bar/testing.js +19 -20
  27. package/fesm2015/snack-bar/testing.js.map +1 -1
  28. package/fesm2015/tabs.js +23 -8
  29. package/fesm2015/tabs.js.map +1 -1
  30. package/list/index.metadata.json +1 -1
  31. package/package.json +2 -2
  32. package/schematics/ng-add/index.js +1 -1
  33. package/schematics/ng-add/index.mjs +1 -1
  34. package/select/index.metadata.json +1 -1
  35. package/snack-bar/testing/snack-bar-harness.d.ts +8 -9
  36. package/tabs/index.metadata.json +1 -1
  37. package/tabs/public-api.d.ts +1 -1
  38. package/tabs/tab-label.d.ts +8 -1
  39. 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._simpleSnackBarLiveRegion = this.locatorFor('[aria-live]');
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._simpleSnackBarLiveRegion())
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._assertSimpleSnackBar();
55
- return (yield this._getSimpleSnackBarActionButton()) !== null;
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._assertSimpleSnackBarWithAction();
65
- return (yield this._getSimpleSnackBarActionButton()).text();
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._assertSimpleSnackBarWithAction();
75
- yield (yield this._getSimpleSnackBarActionButton()).click();
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._assertSimpleSnackBar();
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 does not use custom content. Promise rejects if
104
- * custom content is used.
102
+ * Asserts that the current snack-bar has annotated content. Promise reject
103
+ * if content is not annotated.
105
104
  */
106
- _assertSimpleSnackBar() {
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 does not use custom content and has
115
- * an action defined. Otherwise the promise will reject.
113
+ * Asserts that the current snack-bar has an action defined. Otherwise the
114
+ * promise will reject.
116
115
  */
117
- _assertSimpleSnackBarWithAction() {
116
+ _assertHasAction() {
118
117
  return __awaiter(this, void 0, void 0, function* () {
119
- yield this._assertSimpleSnackBar();
118
+ yield this._assertContentAnnotated();
120
119
  if (!(yield this.hasAction())) {
121
- throw Error('Method cannot be used for standard snack-bar without action.');
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(this._simpleSnackBarSelector)()) !== null;
127
+ return (yield this.locatorForOptional('.mat-simple-snackbar')()) !== null;
129
128
  });
130
129
  }
131
130
  /** Gets the simple snack bar action button. */
132
- _getSimpleSnackBarActionButton() {
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,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3NyYy9tYXRlcmlhbC90YWJzL3B1YmxpYy1hcGkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7Ozs7OztHQU1HO0FBRUgsT0FBTyxFQUFDLGFBQWEsRUFBQyxNQUFNLGVBQWUsQ0FBQztBQUM1QyxjQUFjLGFBQWEsQ0FBQztBQUM1QixPQUFPLEVBQUMsU0FBUyxFQUF3Qix1QkFBdUIsRUFBQyxNQUFNLFdBQVcsQ0FBQztBQUNuRixPQUFPLEVBQ0wsVUFBVSxFQUNWLGVBQWUsRUFHZixnQkFBZ0IsRUFDakIsTUFBTSxZQUFZLENBQUM7QUFDcEIsT0FBTyxFQUFDLFlBQVksRUFBRSxpQkFBaUIsRUFBQyxNQUFNLGNBQWMsQ0FBQztBQUM3RCxPQUFPLEVBQUMsa0JBQWtCLEVBQUMsTUFBTSxxQkFBcUIsQ0FBQztBQUN2RCxPQUFPLEVBQUMsTUFBTSxFQUFFLGFBQWEsRUFBQyxNQUFNLE9BQU8sQ0FBQztBQUM1QyxPQUFPLEVBQUMsV0FBVyxFQUFDLE1BQU0sYUFBYSxDQUFDO0FBQ3hDLE9BQU8sRUFBQyxTQUFTLEVBQUUsVUFBVSxFQUFFLGNBQWMsRUFBRSxlQUFlLEVBQUMsTUFBTSxxQkFBcUIsQ0FBQztBQUMzRixPQUFPLEVBQUMsYUFBYSxFQUFDLE1BQU0sZUFBZSxDQUFDO0FBRTVDLGNBQWMsbUJBQW1CLENBQUM7QUFDbEMsT0FBTyxFQUFDLGVBQWUsRUFBZ0IsTUFBTSxjQUFjLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEBsaWNlbnNlXG4gKiBDb3B5cmlnaHQgR29vZ2xlIExMQyBBbGwgUmlnaHRzIFJlc2VydmVkLlxuICpcbiAqIFVzZSBvZiB0aGlzIHNvdXJjZSBjb2RlIGlzIGdvdmVybmVkIGJ5IGFuIE1JVC1zdHlsZSBsaWNlbnNlIHRoYXQgY2FuIGJlXG4gKiBmb3VuZCBpbiB0aGUgTElDRU5TRSBmaWxlIGF0IGh0dHBzOi8vYW5ndWxhci5pby9saWNlbnNlXG4gKi9cblxuZXhwb3J0IHtNYXRUYWJzTW9kdWxlfSBmcm9tICcuL3RhYnMtbW9kdWxlJztcbmV4cG9ydCAqIGZyb20gJy4vdGFiLWdyb3VwJztcbmV4cG9ydCB7TWF0SW5rQmFyLCBfTWF0SW5rQmFyUG9zaXRpb25lciwgX01BVF9JTktfQkFSX1BPU0lUSU9ORVJ9IGZyb20gJy4vaW5rLWJhcic7XG5leHBvcnQge1xuICBNYXRUYWJCb2R5LFxuICBfTWF0VGFiQm9keUJhc2UsXG4gIE1hdFRhYkJvZHlPcmlnaW5TdGF0ZSxcbiAgTWF0VGFiQm9keVBvc2l0aW9uU3RhdGUsXG4gIE1hdFRhYkJvZHlQb3J0YWxcbn0gZnJvbSAnLi90YWItYm9keSc7XG5leHBvcnQge01hdFRhYkhlYWRlciwgX01hdFRhYkhlYWRlckJhc2V9IGZyb20gJy4vdGFiLWhlYWRlcic7XG5leHBvcnQge01hdFRhYkxhYmVsV3JhcHBlcn0gZnJvbSAnLi90YWItbGFiZWwtd3JhcHBlcic7XG5leHBvcnQge01hdFRhYiwgTUFUX1RBQl9HUk9VUH0gZnJvbSAnLi90YWInO1xuZXhwb3J0IHtNYXRUYWJMYWJlbH0gZnJvbSAnLi90YWItbGFiZWwnO1xuZXhwb3J0IHtNYXRUYWJOYXYsIE1hdFRhYkxpbmssIF9NYXRUYWJOYXZCYXNlLCBfTWF0VGFiTGlua0Jhc2V9IGZyb20gJy4vdGFiLW5hdi1iYXIvaW5kZXgnO1xuZXhwb3J0IHtNYXRUYWJDb250ZW50fSBmcm9tICcuL3RhYi1jb250ZW50JztcbmV4cG9ydCB7U2Nyb2xsRGlyZWN0aW9ufSBmcm9tICcuL3BhZ2luYXRlZC10YWItaGVhZGVyJztcbmV4cG9ydCAqIGZyb20gJy4vdGFicy1hbmltYXRpb25zJztcbmV4cG9ydCB7TUFUX1RBQlNfQ09ORklHLCBNYXRUYWJzQ29uZmlnfSBmcm9tICcuL3RhYi1jb25maWcnO1xuIl19
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
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFiLWxhYmVsLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vc3JjL21hdGVyaWFsL3RhYnMvdGFiLWxhYmVsLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOzs7Ozs7R0FNRztBQUVILE9BQU8sRUFBQyxTQUFTLEVBQUUsY0FBYyxFQUFDLE1BQU0sZUFBZSxDQUFDO0FBQ3hELE9BQU8sRUFBQyxTQUFTLEVBQUMsTUFBTSxxQkFBcUIsQ0FBQztBQUU5Qzs7OztHQUlHO0FBQ0gsTUFBTSxDQUFDLE1BQU0sYUFBYSxHQUFHLElBQUksY0FBYyxDQUFjLGFBQWEsQ0FBQyxDQUFDO0FBRTVFLGdFQUFnRTtBQUtoRSxNQUFNLE9BQU8sV0FBWSxTQUFRLFNBQVM7OztZQUp6QyxTQUFTLFNBQUM7Z0JBQ1QsUUFBUSxFQUFFLGdDQUFnQztnQkFDMUMsU0FBUyxFQUFFLENBQUMsRUFBQyxPQUFPLEVBQUUsYUFBYSxFQUFFLFdBQVcsRUFBRSxXQUFXLEVBQUMsQ0FBQzthQUNoRSIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQGxpY2Vuc2VcbiAqIENvcHlyaWdodCBHb29nbGUgTExDIEFsbCBSaWdodHMgUmVzZXJ2ZWQuXG4gKlxuICogVXNlIG9mIHRoaXMgc291cmNlIGNvZGUgaXMgZ292ZXJuZWQgYnkgYW4gTUlULXN0eWxlIGxpY2Vuc2UgdGhhdCBjYW4gYmVcbiAqIGZvdW5kIGluIHRoZSBMSUNFTlNFIGZpbGUgYXQgaHR0cHM6Ly9hbmd1bGFyLmlvL2xpY2Vuc2VcbiAqL1xuXG5pbXBvcnQge0RpcmVjdGl2ZSwgSW5qZWN0aW9uVG9rZW59IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHtDZGtQb3J0YWx9IGZyb20gJ0Bhbmd1bGFyL2Nkay9wb3J0YWwnO1xuXG4vKipcbiAqIEluamVjdGlvbiB0b2tlbiB0aGF0IGNhbiBiZSB1c2VkIHRvIHJlZmVyZW5jZSBpbnN0YW5jZXMgb2YgYE1hdFRhYkxhYmVsYC4gSXQgc2VydmVzIGFzXG4gKiBhbHRlcm5hdGl2ZSB0b2tlbiB0byB0aGUgYWN0dWFsIGBNYXRUYWJMYWJlbGAgY2xhc3Mgd2hpY2ggY291bGQgY2F1c2UgdW5uZWNlc3NhcnlcbiAqIHJldGVudGlvbiBvZiB0aGUgY2xhc3MgYW5kIGl0cyBkaXJlY3RpdmUgbWV0YWRhdGEuXG4gKi9cbmV4cG9ydCBjb25zdCBNQVRfVEFCX0xBQkVMID0gbmV3IEluamVjdGlvblRva2VuPE1hdFRhYkxhYmVsPignTWF0VGFiTGFiZWwnKTtcblxuLyoqIFVzZWQgdG8gZmxhZyB0YWIgbGFiZWxzIGZvciB1c2Ugd2l0aCB0aGUgcG9ydGFsIGRpcmVjdGl2ZSAqL1xuQERpcmVjdGl2ZSh7XG4gIHNlbGVjdG9yOiAnW21hdC10YWItbGFiZWxdLCBbbWF0VGFiTGFiZWxdJyxcbiAgcHJvdmlkZXJzOiBbe3Byb3ZpZGU6IE1BVF9UQUJfTEFCRUwsIHVzZUV4aXN0aW5nOiBNYXRUYWJMYWJlbH1dLFxufSlcbmV4cG9ydCBjbGFzcyBNYXRUYWJMYWJlbCBleHRlbmRzIENka1BvcnRhbCB7fVxuIl19
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==
@@ -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 templateLabel via query if there is actually
75
- // a MatTabLabel found. This works around an issue where a user may have
76
- // manually set `templateLabel` during creation mode, which would then get clobbered
77
- // by `undefined` when this query resolves.
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,{"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} 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})\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) {\n    // Only update the templateLabel via query if there is actually\n    // a MatTabLabel found. This works around an issue where a user may have\n    // manually set `templateLabel` during creation mode, which would then get clobbered\n    // by `undefined` when this query resolves.\n    if (value) {\n      this._templateLabel = value;\n    }\n  }\n\n  static ngAcceptInputType_disabled: BooleanInput;\n}\n"]}
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.6');
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.6');
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() || this._isTestEnv()) {
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 ' +