UNPKG

@angular/material

Version:
123 lines 15.5 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 } from "tslib"; import { ComponentHarness, HarnessPredicate } from '@angular/cdk/testing'; import { MatCellHarness, MatHeaderCellHarness, MatFooterCellHarness } from './cell-harness'; /** Harness for interacting with a standard Angular Material table row. */ export class MatRowHarness extends ComponentHarness { /** * Gets a `HarnessPredicate` that can be used to search for a table row with specific attributes. * @param options Options for narrowing the search * @return a `HarnessPredicate` configured with the given options. */ static with(options = {}) { return new HarnessPredicate(MatRowHarness, options); } /** Gets a list of `MatCellHarness` for all cells in the row. */ getCells(filter = {}) { return __awaiter(this, void 0, void 0, function* () { return this.locatorForAll(MatCellHarness.with(filter))(); }); } /** Gets the text of the cells in the row. */ getCellTextByIndex(filter = {}) { return __awaiter(this, void 0, void 0, function* () { return getCellTextByIndex(this, filter); }); } /** Gets the text inside the row organized by columns. */ getCellTextByColumnName() { return __awaiter(this, void 0, void 0, function* () { return getCellTextByColumnName(this); }); } } /** The selector for the host element of a `MatRowHarness` instance. */ MatRowHarness.hostSelector = '.mat-row'; /** Harness for interacting with a standard Angular Material table header row. */ export class MatHeaderRowHarness extends ComponentHarness { /** * Gets a `HarnessPredicate` that can be used to search for * a table header row with specific attributes. * @param options Options for narrowing the search * @return a `HarnessPredicate` configured with the given options. */ static with(options = {}) { return new HarnessPredicate(MatHeaderRowHarness, options); } /** Gets a list of `MatHeaderCellHarness` for all cells in the row. */ getCells(filter = {}) { return __awaiter(this, void 0, void 0, function* () { return this.locatorForAll(MatHeaderCellHarness.with(filter))(); }); } /** Gets the text of the cells in the header row. */ getCellTextByIndex(filter = {}) { return __awaiter(this, void 0, void 0, function* () { return getCellTextByIndex(this, filter); }); } /** Gets the text inside the header row organized by columns. */ getCellTextByColumnName() { return __awaiter(this, void 0, void 0, function* () { return getCellTextByColumnName(this); }); } } /** The selector for the host element of a `MatHeaderRowHarness` instance. */ MatHeaderRowHarness.hostSelector = '.mat-header-row'; /** Harness for interacting with a standard Angular Material table footer row. */ export class MatFooterRowHarness extends ComponentHarness { /** * Gets a `HarnessPredicate` that can be used to search for * a table footer row cell with specific attributes. * @param options Options for narrowing the search * @return a `HarnessPredicate` configured with the given options. */ static with(options = {}) { return new HarnessPredicate(MatFooterRowHarness, options); } /** Gets a list of `MatFooterCellHarness` for all cells in the row. */ getCells(filter = {}) { return __awaiter(this, void 0, void 0, function* () { return this.locatorForAll(MatFooterCellHarness.with(filter))(); }); } /** Gets the text of the cells in the footer row. */ getCellTextByIndex(filter = {}) { return __awaiter(this, void 0, void 0, function* () { return getCellTextByIndex(this, filter); }); } /** Gets the text inside the footer row organized by columns. */ getCellTextByColumnName() { return __awaiter(this, void 0, void 0, function* () { return getCellTextByColumnName(this); }); } } /** The selector for the host element of a `MatFooterRowHarness` instance. */ MatFooterRowHarness.hostSelector = '.mat-footer-row'; function getCellTextByIndex(harness, filter) { return __awaiter(this, void 0, void 0, function* () { const cells = yield harness.getCells(filter); return Promise.all(cells.map(cell => cell.getText())); }); } function getCellTextByColumnName(harness) { return __awaiter(this, void 0, void 0, function* () { const output = {}; const cells = yield harness.getCells(); const cellsData = yield Promise.all(cells.map(cell => { return Promise.all([cell.getColumnName(), cell.getText()]); })); cellsData.forEach(([columnName, text]) => output[columnName] = text); return output; }); } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"row-harness.js","sourceRoot":"","sources":["../../../../../../../src/material/table/testing/row-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, HarnessPredicate} from '@angular/cdk/testing';\nimport {RowHarnessFilters, CellHarnessFilters} from './table-harness-filters';\nimport {MatCellHarness, MatHeaderCellHarness, MatFooterCellHarness} from './cell-harness';\n\n/** Text extracted from a table row organized by columns. */\nexport interface MatRowHarnessColumnsText {\n  [columnName: string]: string;\n}\n\n/** Harness for interacting with a standard Angular Material table row. */\nexport class MatRowHarness extends ComponentHarness {\n  /** The selector for the host element of a `MatRowHarness` instance. */\n  static hostSelector = '.mat-row';\n\n  /**\n   * Gets a `HarnessPredicate` that can be used to search for a table row with specific attributes.\n   * @param options Options for narrowing the search\n   * @return a `HarnessPredicate` configured with the given options.\n   */\n  static with(options: RowHarnessFilters = {}): HarnessPredicate<MatRowHarness> {\n    return new HarnessPredicate(MatRowHarness, options);\n  }\n\n  /** Gets a list of `MatCellHarness` for all cells in the row. */\n  async getCells(filter: CellHarnessFilters = {}): Promise<MatCellHarness[]> {\n    return this.locatorForAll(MatCellHarness.with(filter))();\n  }\n\n  /** Gets the text of the cells in the row. */\n  async getCellTextByIndex(filter: CellHarnessFilters = {}): Promise<string[]> {\n    return getCellTextByIndex(this, filter);\n  }\n\n  /** Gets the text inside the row organized by columns. */\n  async getCellTextByColumnName(): Promise<MatRowHarnessColumnsText> {\n    return getCellTextByColumnName(this);\n  }\n}\n\n/** Harness for interacting with a standard Angular Material table header row. */\nexport class MatHeaderRowHarness extends ComponentHarness {\n  /** The selector for the host element of a `MatHeaderRowHarness` instance. */\n  static hostSelector = '.mat-header-row';\n\n  /**\n   * Gets a `HarnessPredicate` that can be used to search for\n   * a table header row with specific attributes.\n   * @param options Options for narrowing the search\n   * @return a `HarnessPredicate` configured with the given options.\n   */\n  static with(options: RowHarnessFilters = {}): HarnessPredicate<MatHeaderRowHarness> {\n    return new HarnessPredicate(MatHeaderRowHarness, options);\n  }\n\n  /** Gets a list of `MatHeaderCellHarness` for all cells in the row. */\n  async getCells(filter: CellHarnessFilters = {}): Promise<MatHeaderCellHarness[]> {\n    return this.locatorForAll(MatHeaderCellHarness.with(filter))();\n  }\n\n  /** Gets the text of the cells in the header row. */\n  async getCellTextByIndex(filter: CellHarnessFilters = {}): Promise<string[]> {\n    return getCellTextByIndex(this, filter);\n  }\n\n  /** Gets the text inside the header row organized by columns. */\n  async getCellTextByColumnName(): Promise<MatRowHarnessColumnsText> {\n    return getCellTextByColumnName(this);\n  }\n}\n\n\n/** Harness for interacting with a standard Angular Material table footer row. */\nexport class MatFooterRowHarness extends ComponentHarness {\n  /** The selector for the host element of a `MatFooterRowHarness` instance. */\n  static hostSelector = '.mat-footer-row';\n\n  /**\n   * Gets a `HarnessPredicate` that can be used to search for\n   * a table footer row cell with specific attributes.\n   * @param options Options for narrowing the search\n   * @return a `HarnessPredicate` configured with the given options.\n   */\n  static with(options: RowHarnessFilters = {}): HarnessPredicate<MatFooterRowHarness> {\n    return new HarnessPredicate(MatFooterRowHarness, options);\n  }\n\n  /** Gets a list of `MatFooterCellHarness` for all cells in the row. */\n  async getCells(filter: CellHarnessFilters = {}): Promise<MatFooterCellHarness[]> {\n    return this.locatorForAll(MatFooterCellHarness.with(filter))();\n  }\n\n  /** Gets the text of the cells in the footer row. */\n  async getCellTextByIndex(filter: CellHarnessFilters = {}): Promise<string[]> {\n    return getCellTextByIndex(this, filter);\n  }\n\n  /** Gets the text inside the footer row organized by columns. */\n  async getCellTextByColumnName(): Promise<MatRowHarnessColumnsText> {\n    return getCellTextByColumnName(this);\n  }\n}\n\n\nasync function getCellTextByIndex(harness: {\n  getCells: (filter?: CellHarnessFilters) => Promise<MatCellHarness[]>\n}, filter: CellHarnessFilters): Promise<string[]> {\n  const cells = await harness.getCells(filter);\n  return Promise.all(cells.map(cell => cell.getText()));\n}\n\nasync function getCellTextByColumnName(harness: {\n  getCells: () => Promise<MatCellHarness[]>\n}): Promise<MatRowHarnessColumnsText> {\n  const output: MatRowHarnessColumnsText = {};\n  const cells = await harness.getCells();\n  const cellsData = await Promise.all(cells.map(cell => {\n    return Promise.all([cell.getColumnName(), cell.getText()]);\n  }));\n  cellsData.forEach(([columnName, text]) => output[columnName] = text);\n  return output;\n}\n"]}