@angular/material
Version:
Angular Material
239 lines • 22.8 kB
JavaScript
/**
* @license
* Copyright Google LLC All Rights Reserved.
*
* Use of this source code is governed by an MIT-style license that can be
* found in the LICENSE file at https://angular.io/license
*/
import { __awaiter, __extends, __generator } from "tslib";
import { ComponentHarness, HarnessPredicate } from '@angular/cdk/testing';
var EXPANSION_PANEL_CONTENT_SELECTOR = '.mat-expansion-panel-content';
/** Harness for interacting with a standard mat-expansion-panel in tests. */
var MatExpansionPanelHarness = /** @class */ (function (_super) {
__extends(MatExpansionPanelHarness, _super);
function MatExpansionPanelHarness() {
var _this = _super !== null && _super.apply(this, arguments) || this;
_this._header = _this.locatorFor('.mat-expansion-panel-header');
_this._title = _this.locatorForOptional('.mat-expansion-panel-header-title');
_this._description = _this.locatorForOptional('.mat-expansion-panel-header-description');
_this._expansionIndicator = _this.locatorForOptional('.mat-expansion-indicator');
_this._content = _this.locatorFor(EXPANSION_PANEL_CONTENT_SELECTOR);
return _this;
}
/**
* Gets a `HarnessPredicate` that can be used to search for an expansion-panel
* with specific attributes.
* @param options Options for narrowing the search:
* - `title` finds an expansion-panel with a specific title text.
* - `description` finds an expansion-panel with a specific description text.
* - `expanded` finds an expansion-panel that is currently expanded.
* - `disabled` finds an expansion-panel that is disabled.
* @return a `HarnessPredicate` configured with the given options.
*/
MatExpansionPanelHarness.with = function (options) {
var _this = this;
if (options === void 0) { options = {}; }
return new HarnessPredicate(MatExpansionPanelHarness, options)
.addOption('title', options.title, function (harness, title) { return HarnessPredicate.stringMatches(harness.getTitle(), title); })
.addOption('description', options.description, function (harness, description) {
return HarnessPredicate.stringMatches(harness.getDescription(), description);
})
.addOption('content', options.content, function (harness, content) { return HarnessPredicate.stringMatches(harness.getTextContent(), content); })
.addOption('expanded', options.expanded, function (harness, expanded) { return __awaiter(_this, void 0, void 0, function () { return __generator(this, function (_a) {
switch (_a.label) {
case 0: return [4 /*yield*/, harness.isExpanded()];
case 1: return [2 /*return*/, (_a.sent()) === expanded];
}
}); }); })
.addOption('disabled', options.disabled, function (harness, disabled) { return __awaiter(_this, void 0, void 0, function () { return __generator(this, function (_a) {
switch (_a.label) {
case 0: return [4 /*yield*/, harness.isDisabled()];
case 1: return [2 /*return*/, (_a.sent()) === disabled];
}
}); }); });
};
/** Whether the panel is expanded. */
MatExpansionPanelHarness.prototype.isExpanded = function () {
return __awaiter(this, void 0, void 0, function () {
return __generator(this, function (_a) {
switch (_a.label) {
case 0: return [4 /*yield*/, this.host()];
case 1: return [2 /*return*/, (_a.sent()).hasClass('mat-expanded')];
}
});
});
};
/**
* Gets the title text of the panel.
* @returns Title text or `null` if no title is set up.
*/
MatExpansionPanelHarness.prototype.getTitle = function () {
return __awaiter(this, void 0, void 0, function () {
var titleEl;
return __generator(this, function (_a) {
switch (_a.label) {
case 0: return [4 /*yield*/, this._title()];
case 1:
titleEl = _a.sent();
return [2 /*return*/, titleEl ? titleEl.text() : null];
}
});
});
};
/**
* Gets the description text of the panel.
* @returns Description text or `null` if no description is set up.
*/
MatExpansionPanelHarness.prototype.getDescription = function () {
return __awaiter(this, void 0, void 0, function () {
var descriptionEl;
return __generator(this, function (_a) {
switch (_a.label) {
case 0: return [4 /*yield*/, this._description()];
case 1:
descriptionEl = _a.sent();
return [2 /*return*/, descriptionEl ? descriptionEl.text() : null];
}
});
});
};
/** Whether the panel is disabled. */
MatExpansionPanelHarness.prototype.isDisabled = function () {
return __awaiter(this, void 0, void 0, function () {
return __generator(this, function (_a) {
switch (_a.label) {
case 0: return [4 /*yield*/, this._header()];
case 1: return [4 /*yield*/, (_a.sent()).getAttribute('aria-disabled')];
case 2: return [2 /*return*/, (_a.sent()) === 'true'];
}
});
});
};
/**
* Toggles the expanded state of the panel by clicking on the panel
* header. This method will not work if the panel is disabled.
*/
MatExpansionPanelHarness.prototype.toggle = function () {
return __awaiter(this, void 0, void 0, function () {
return __generator(this, function (_a) {
switch (_a.label) {
case 0: return [4 /*yield*/, this._header()];
case 1: return [4 /*yield*/, (_a.sent()).click()];
case 2:
_a.sent();
return [2 /*return*/];
}
});
});
};
/** Expands the expansion panel if collapsed. */
MatExpansionPanelHarness.prototype.expand = function () {
return __awaiter(this, void 0, void 0, function () {
return __generator(this, function (_a) {
switch (_a.label) {
case 0: return [4 /*yield*/, this.isExpanded()];
case 1:
if (!!(_a.sent())) return [3 /*break*/, 3];
return [4 /*yield*/, this.toggle()];
case 2:
_a.sent();
_a.label = 3;
case 3: return [2 /*return*/];
}
});
});
};
/** Collapses the expansion panel if expanded. */
MatExpansionPanelHarness.prototype.collapse = function () {
return __awaiter(this, void 0, void 0, function () {
return __generator(this, function (_a) {
switch (_a.label) {
case 0: return [4 /*yield*/, this.isExpanded()];
case 1:
if (!_a.sent()) return [3 /*break*/, 3];
return [4 /*yield*/, this.toggle()];
case 2:
_a.sent();
_a.label = 3;
case 3: return [2 /*return*/];
}
});
});
};
/** Gets the text content of the panel. */
MatExpansionPanelHarness.prototype.getTextContent = function () {
return __awaiter(this, void 0, void 0, function () {
return __generator(this, function (_a) {
switch (_a.label) {
case 0: return [4 /*yield*/, this._content()];
case 1: return [2 /*return*/, (_a.sent()).text()];
}
});
});
};
/**
* Gets a `HarnessLoader` that can be used to load harnesses for
* components within the panel's content area.
*/
MatExpansionPanelHarness.prototype.getHarnessLoaderForContent = function () {
return __awaiter(this, void 0, void 0, function () {
return __generator(this, function (_a) {
return [2 /*return*/, this.locatorFactory.harnessLoaderFor(EXPANSION_PANEL_CONTENT_SELECTOR)];
});
});
};
/** Focuses the panel. */
MatExpansionPanelHarness.prototype.focus = function () {
return __awaiter(this, void 0, void 0, function () {
return __generator(this, function (_a) {
switch (_a.label) {
case 0: return [4 /*yield*/, this._header()];
case 1: return [2 /*return*/, (_a.sent()).focus()];
}
});
});
};
/** Blurs the panel. */
MatExpansionPanelHarness.prototype.blur = function () {
return __awaiter(this, void 0, void 0, function () {
return __generator(this, function (_a) {
switch (_a.label) {
case 0: return [4 /*yield*/, this._header()];
case 1: return [2 /*return*/, (_a.sent()).blur()];
}
});
});
};
/** Whether the panel has a toggle indicator displayed. */
MatExpansionPanelHarness.prototype.hasToggleIndicator = function () {
return __awaiter(this, void 0, void 0, function () {
return __generator(this, function (_a) {
switch (_a.label) {
case 0: return [4 /*yield*/, this._expansionIndicator()];
case 1: return [2 /*return*/, (_a.sent()) !== null];
}
});
});
};
/** Gets the position of the toggle indicator. */
MatExpansionPanelHarness.prototype.getToggleIndicatorPosition = function () {
return __awaiter(this, void 0, void 0, function () {
return __generator(this, function (_a) {
switch (_a.label) {
case 0: return [4 /*yield*/, this._header()];
case 1: return [4 /*yield*/, (_a.sent()).hasClass('mat-expansion-toggle-indicator-before')];
case 2:
// By default the expansion indicator will show "after" the panel header content.
if (_a.sent()) {
return [2 /*return*/, 'before'];
}
return [2 /*return*/, 'after'];
}
});
});
};
MatExpansionPanelHarness.hostSelector = '.mat-expansion-panel';
return MatExpansionPanelHarness;
}(ComponentHarness));
export { MatExpansionPanelHarness };
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"expansion-harness.js","sourceRoot":"","sources":["../../../../../../../../../../../../src/material/expansion/testing/expansion-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 {ComponentHarness, HarnessLoader, HarnessPredicate} from '@angular/cdk/testing';\nimport {ExpansionPanelHarnessFilters} from './expansion-harness-filters';\n\nconst EXPANSION_PANEL_CONTENT_SELECTOR = '.mat-expansion-panel-content';\n\n/** Harness for interacting with a standard mat-expansion-panel in tests. */\nexport class MatExpansionPanelHarness extends ComponentHarness {\n  static hostSelector = '.mat-expansion-panel';\n\n  private _header = this.locatorFor('.mat-expansion-panel-header');\n  private _title = this.locatorForOptional('.mat-expansion-panel-header-title');\n  private _description = this.locatorForOptional('.mat-expansion-panel-header-description');\n  private _expansionIndicator = this.locatorForOptional('.mat-expansion-indicator');\n  private _content = this.locatorFor(EXPANSION_PANEL_CONTENT_SELECTOR);\n\n  /**\n   * Gets a `HarnessPredicate` that can be used to search for an expansion-panel\n   * with specific attributes.\n   * @param options Options for narrowing the search:\n   *   - `title` finds an expansion-panel with a specific title text.\n   *   - `description` finds an expansion-panel with a specific description text.\n   *   - `expanded` finds an expansion-panel that is currently expanded.\n   *   - `disabled` finds an expansion-panel that is disabled.\n   * @return a `HarnessPredicate` configured with the given options.\n   */\n  static with(options: ExpansionPanelHarnessFilters = {}):\n      HarnessPredicate<MatExpansionPanelHarness> {\n    return new HarnessPredicate(MatExpansionPanelHarness, options)\n        .addOption(\n            'title', options.title,\n            (harness, title) => HarnessPredicate.stringMatches(harness.getTitle(), title))\n        .addOption(\n            'description', options.description,\n            (harness, description) =>\n                HarnessPredicate.stringMatches(harness.getDescription(), description))\n        .addOption(\n            'content', options.content,\n            (harness, content) => HarnessPredicate.stringMatches(harness.getTextContent(), content))\n        .addOption(\n            'expanded', options.expanded,\n            async (harness, expanded) => (await harness.isExpanded()) === expanded)\n        .addOption(\n            'disabled', options.disabled,\n            async (harness, disabled) => (await harness.isDisabled()) === disabled);\n  }\n\n  /** Whether the panel is expanded. */\n  async isExpanded(): Promise<boolean> {\n    return (await this.host()).hasClass('mat-expanded');\n  }\n\n  /**\n   * Gets the title text of the panel.\n   * @returns Title text or `null` if no title is set up.\n   */\n  async getTitle(): Promise<string|null> {\n    const titleEl = await this._title();\n    return titleEl ? titleEl.text() : null;\n  }\n\n  /**\n   * Gets the description text of the panel.\n   * @returns Description text or `null` if no description is set up.\n   */\n  async getDescription(): Promise<string|null> {\n    const descriptionEl = await this._description();\n    return descriptionEl ? descriptionEl.text() : null;\n  }\n\n  /** Whether the panel is disabled. */\n  async isDisabled(): Promise<boolean> {\n    return await (await this._header()).getAttribute('aria-disabled') === 'true';\n  }\n\n  /**\n   * Toggles the expanded state of the panel by clicking on the panel\n   * header. This method will not work if the panel is disabled.\n   */\n  async toggle(): Promise<void> {\n    await (await this._header()).click();\n  }\n\n  /** Expands the expansion panel if collapsed. */\n  async expand(): Promise<void> {\n    if (!await this.isExpanded()) {\n      await this.toggle();\n    }\n  }\n\n  /** Collapses the expansion panel if expanded. */\n  async collapse(): Promise<void> {\n    if (await this.isExpanded()) {\n      await this.toggle();\n    }\n  }\n\n  /** Gets the text content of the panel. */\n  async getTextContent(): Promise<string> {\n    return (await this._content()).text();\n  }\n\n  /**\n   * Gets a `HarnessLoader` that can be used to load harnesses for\n   * components within the panel's content area.\n   */\n  async getHarnessLoaderForContent(): Promise<HarnessLoader> {\n    return this.locatorFactory.harnessLoaderFor(EXPANSION_PANEL_CONTENT_SELECTOR);\n  }\n\n  /** Focuses the panel. */\n  async focus(): Promise<void> {\n    return (await this._header()).focus();\n  }\n\n  /** Blurs the panel. */\n  async blur(): Promise<void> {\n    return (await this._header()).blur();\n  }\n\n  /** Whether the panel has a toggle indicator displayed. */\n  async hasToggleIndicator(): Promise<boolean> {\n    return (await this._expansionIndicator()) !== null;\n  }\n\n  /** Gets the position of the toggle indicator. */\n  async getToggleIndicatorPosition(): Promise<'before'|'after'> {\n    // By default the expansion indicator will show \"after\" the panel header content.\n    if (await (await this._header()).hasClass('mat-expansion-toggle-indicator-before')) {\n      return 'before';\n    }\n    return 'after';\n  }\n}\n"]}