UNPKG

@angular/material

Version:
239 lines 22.8 kB
/** * @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"]}