@angular/material
Version:
Angular Material
123 lines • 15.5 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 } 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":"AAAA;;;;;;GAMG;;AAEH,OAAO,EAAC,gBAAgB,EAAE,gBAAgB,EAAC,MAAM,sBAAsB,CAAC;AAExE,OAAO,EAAC,cAAc,EAAE,oBAAoB,EAAE,oBAAoB,EAAC,MAAM,gBAAgB,CAAC;AAO1F,0EAA0E;AAC1E,MAAM,OAAO,aAAc,SAAQ,gBAAgB;IAIjD;;;;OAIG;IACH,MAAM,CAAC,IAAI,CAAC,UAA6B,EAAE;QACzC,OAAO,IAAI,gBAAgB,CAAC,aAAa,EAAE,OAAO,CAAC,CAAC;IACtD,CAAC;IAED,gEAAgE;IAC1D,QAAQ,CAAC,SAA6B,EAAE;;YAC5C,OAAO,IAAI,CAAC,aAAa,CAAC,cAAc,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,EAAE,CAAC;QAC3D,CAAC;KAAA;IAED,6CAA6C;IACvC,kBAAkB,CAAC,SAA6B,EAAE;;YACtD,OAAO,kBAAkB,CAAC,IAAI,EAAE,MAAM,CAAC,CAAC;QAC1C,CAAC;KAAA;IAED,yDAAyD;IACnD,uBAAuB;;YAC3B,OAAO,uBAAuB,CAAC,IAAI,CAAC,CAAC;QACvC,CAAC;KAAA;;AAzBD,uEAAuE;AAChE,0BAAY,GAAG,UAAU,CAAC;AA2BnC,iFAAiF;AACjF,MAAM,OAAO,mBAAoB,SAAQ,gBAAgB;IAIvD;;;;;OAKG;IACH,MAAM,CAAC,IAAI,CAAC,UAA6B,EAAE;QACzC,OAAO,IAAI,gBAAgB,CAAC,mBAAmB,EAAE,OAAO,CAAC,CAAC;IAC5D,CAAC;IAED,sEAAsE;IAChE,QAAQ,CAAC,SAA6B,EAAE;;YAC5C,OAAO,IAAI,CAAC,aAAa,CAAC,oBAAoB,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,EAAE,CAAC;QACjE,CAAC;KAAA;IAED,oDAAoD;IAC9C,kBAAkB,CAAC,SAA6B,EAAE;;YACtD,OAAO,kBAAkB,CAAC,IAAI,EAAE,MAAM,CAAC,CAAC;QAC1C,CAAC;KAAA;IAED,gEAAgE;IAC1D,uBAAuB;;YAC3B,OAAO,uBAAuB,CAAC,IAAI,CAAC,CAAC;QACvC,CAAC;KAAA;;AA1BD,6EAA6E;AACtE,gCAAY,GAAG,iBAAiB,CAAC;AA6B1C,iFAAiF;AACjF,MAAM,OAAO,mBAAoB,SAAQ,gBAAgB;IAIvD;;;;;OAKG;IACH,MAAM,CAAC,IAAI,CAAC,UAA6B,EAAE;QACzC,OAAO,IAAI,gBAAgB,CAAC,mBAAmB,EAAE,OAAO,CAAC,CAAC;IAC5D,CAAC;IAED,sEAAsE;IAChE,QAAQ,CAAC,SAA6B,EAAE;;YAC5C,OAAO,IAAI,CAAC,aAAa,CAAC,oBAAoB,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,EAAE,CAAC;QACjE,CAAC;KAAA;IAED,oDAAoD;IAC9C,kBAAkB,CAAC,SAA6B,EAAE;;YACtD,OAAO,kBAAkB,CAAC,IAAI,EAAE,MAAM,CAAC,CAAC;QAC1C,CAAC;KAAA;IAED,gEAAgE;IAC1D,uBAAuB;;YAC3B,OAAO,uBAAuB,CAAC,IAAI,CAAC,CAAC;QACvC,CAAC;KAAA;;AA1BD,6EAA6E;AACtE,gCAAY,GAAG,iBAAiB,CAAC;AA6B1C,SAAe,kBAAkB,CAAC,OAEjC,EAAE,MAA0B;;QAC3B,MAAM,KAAK,GAAG,MAAM,OAAO,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC;QAC7C,OAAO,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,OAAO,EAAE,CAAC,CAAC,CAAC;IACxD,CAAC;CAAA;AAED,SAAe,uBAAuB,CAAC,OAEtC;;QACC,MAAM,MAAM,GAA6B,EAAE,CAAC;QAC5C,MAAM,KAAK,GAAG,MAAM,OAAO,CAAC,QAAQ,EAAE,CAAC;QACvC,MAAM,SAAS,GAAG,MAAM,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE;YACnD,OAAO,OAAO,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,aAAa,EAAE,EAAE,IAAI,CAAC,OAAO,EAAE,CAAC,CAAC,CAAC;QAC7D,CAAC,CAAC,CAAC,CAAC;QACJ,SAAS,CAAC,OAAO,CAAC,CAAC,CAAC,UAAU,EAAE,IAAI,CAAC,EAAE,EAAE,CAAC,MAAM,CAAC,UAAU,CAAC,GAAG,IAAI,CAAC,CAAC;QACrE,OAAO,MAAM,CAAC;IAChB,CAAC;CAAA","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"]}