source: trip-planner-front/node_modules/@angular/material/esm2015/table/testing/row-harness.js@ 84d0fbb

Last change on this file since 84d0fbb was 6a3a178, checked in by Ema <ema_spirova@…>, 3 years ago

initial commit

  • Property mode set to 100644
File size: 11.8 KB
Line 
1/**
2 * @license
3 * Copyright Google LLC All Rights Reserved.
4 *
5 * Use of this source code is governed by an MIT-style license that can be
6 * found in the LICENSE file at https://angular.io/license
7 */
8import { __awaiter } from "tslib";
9import { ComponentHarness, HarnessPredicate, parallel, } from '@angular/cdk/testing';
10import { MatCellHarness, MatHeaderCellHarness, MatFooterCellHarness } from './cell-harness';
11export class _MatRowHarnessBase extends ComponentHarness {
12 /** Gets a list of `MatCellHarness` for all cells in the row. */
13 getCells(filter = {}) {
14 return __awaiter(this, void 0, void 0, function* () {
15 return this.locatorForAll(this._cellHarness.with(filter))();
16 });
17 }
18 /** Gets the text of the cells in the row. */
19 getCellTextByIndex(filter = {}) {
20 return __awaiter(this, void 0, void 0, function* () {
21 const cells = yield this.getCells(filter);
22 return parallel(() => cells.map(cell => cell.getText()));
23 });
24 }
25 /** Gets the text inside the row organized by columns. */
26 getCellTextByColumnName() {
27 return __awaiter(this, void 0, void 0, function* () {
28 const output = {};
29 const cells = yield this.getCells();
30 const cellsData = yield parallel(() => cells.map(cell => {
31 return parallel(() => [cell.getColumnName(), cell.getText()]);
32 }));
33 cellsData.forEach(([columnName, text]) => output[columnName] = text);
34 return output;
35 });
36 }
37}
38/** Harness for interacting with a standard Angular Material table row. */
39export class MatRowHarness extends _MatRowHarnessBase {
40 constructor() {
41 super(...arguments);
42 this._cellHarness = MatCellHarness;
43 }
44 /**
45 * Gets a `HarnessPredicate` that can be used to search for a table row with specific attributes.
46 * @param options Options for narrowing the search
47 * @return a `HarnessPredicate` configured with the given options.
48 */
49 static with(options = {}) {
50 return new HarnessPredicate(MatRowHarness, options);
51 }
52}
53/** The selector for the host element of a `MatRowHarness` instance. */
54MatRowHarness.hostSelector = '.mat-row';
55/** Harness for interacting with a standard Angular Material table header row. */
56export class MatHeaderRowHarness extends _MatRowHarnessBase {
57 constructor() {
58 super(...arguments);
59 this._cellHarness = MatHeaderCellHarness;
60 }
61 /**
62 * Gets a `HarnessPredicate` that can be used to search for
63 * a table header row with specific attributes.
64 * @param options Options for narrowing the search
65 * @return a `HarnessPredicate` configured with the given options.
66 */
67 static with(options = {}) {
68 return new HarnessPredicate(MatHeaderRowHarness, options);
69 }
70}
71/** The selector for the host element of a `MatHeaderRowHarness` instance. */
72MatHeaderRowHarness.hostSelector = '.mat-header-row';
73/** Harness for interacting with a standard Angular Material table footer row. */
74export class MatFooterRowHarness extends _MatRowHarnessBase {
75 constructor() {
76 super(...arguments);
77 this._cellHarness = MatFooterCellHarness;
78 }
79 /**
80 * Gets a `HarnessPredicate` that can be used to search for
81 * a table footer row cell with specific attributes.
82 * @param options Options for narrowing the search
83 * @return a `HarnessPredicate` configured with the given options.
84 */
85 static with(options = {}) {
86 return new HarnessPredicate(MatFooterRowHarness, options);
87 }
88}
89/** The selector for the host element of a `MatFooterRowHarness` instance. */
90MatFooterRowHarness.hostSelector = '.mat-footer-row';
91//# 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,EACL,gBAAgB,EAEhB,gBAAgB,EAChB,QAAQ,GACT,MAAM,sBAAsB,CAAC;AAE9B,OAAO,EAAC,cAAc,EAAE,oBAAoB,EAAE,oBAAoB,EAAC,MAAM,gBAAgB,CAAC;AAO1F,MAAM,OAAgB,kBAIpB,SAAQ,gBAAgB;IAGxB,gEAAgE;IAC1D,QAAQ,CAAC,SAA6B,EAAE;;YAC5C,OAAO,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,EAAE,CAAC;QAC9D,CAAC;KAAA;IAED,6CAA6C;IACvC,kBAAkB,CAAC,SAA6B,EAAE;;YACtD,MAAM,KAAK,GAAG,MAAM,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC;YAC1C,OAAO,QAAQ,CAAC,GAAG,EAAE,CAAC,KAAK,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,OAAO,EAAE,CAAC,CAAC,CAAC;QAC3D,CAAC;KAAA;IAED,yDAAyD;IACnD,uBAAuB;;YAC3B,MAAM,MAAM,GAA6B,EAAE,CAAC;YAC5C,MAAM,KAAK,GAAG,MAAM,IAAI,CAAC,QAAQ,EAAE,CAAC;YACpC,MAAM,SAAS,GAAG,MAAM,QAAQ,CAAC,GAAG,EAAE,CAAC,KAAK,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE;gBACtD,OAAO,QAAQ,CAAC,GAAG,EAAE,CAAC,CAAC,IAAI,CAAC,aAAa,EAAE,EAAE,IAAI,CAAC,OAAO,EAAE,CAAC,CAAC,CAAC;YAChE,CAAC,CAAC,CAAC,CAAC;YACJ,SAAS,CAAC,OAAO,CAAC,CAAC,CAAC,UAAU,EAAE,IAAI,CAAC,EAAE,EAAE,CAAC,MAAM,CAAC,UAAU,CAAC,GAAG,IAAI,CAAC,CAAC;YACrE,OAAO,MAAM,CAAC;QAChB,CAAC;KAAA;CACF;AAED,0EAA0E;AAC1E,MAAM,OAAO,aAAc,SAAQ,kBAAyD;IAA5F;;QAGY,iBAAY,GAAG,cAAc,CAAC;IAU1C,CAAC;IARC;;;;OAIG;IACH,MAAM,CAAC,IAAI,CAAC,UAA6B,EAAE;QACzC,OAAO,IAAI,gBAAgB,CAAC,aAAa,EAAE,OAAO,CAAC,CAAC;IACtD,CAAC;;AAXD,uEAAuE;AAChE,0BAAY,GAAG,UAAU,CAAC;AAanC,iFAAiF;AACjF,MAAM,OAAO,mBAAoB,SAAQ,kBACW;IADpD;;QAIY,iBAAY,GAAG,oBAAoB,CAAC;IAWhD,CAAC;IATC;;;;;OAKG;IACH,MAAM,CAAC,IAAI,CAAC,UAA6B,EAAE;QACzC,OAAO,IAAI,gBAAgB,CAAC,mBAAmB,EAAE,OAAO,CAAC,CAAC;IAC5D,CAAC;;AAZD,6EAA6E;AACtE,gCAAY,GAAG,iBAAiB,CAAC;AAe1C,iFAAiF;AACjF,MAAM,OAAO,mBAAoB,SAAQ,kBACW;IADpD;;QAIY,iBAAY,GAAG,oBAAoB,CAAC;IAWhD,CAAC;IATC;;;;;OAKG;IACH,MAAM,CAAC,IAAI,CAAC,UAA6B,EAAE;QACzC,OAAO,IAAI,gBAAgB,CAAC,mBAAmB,EAAE,OAAO,CAAC,CAAC;IAC5D,CAAC;;AAZD,6EAA6E;AACtE,gCAAY,GAAG,iBAAiB,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 {\n  ComponentHarness,\n  ComponentHarnessConstructor,\n  HarnessPredicate,\n  parallel,\n} 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\nexport abstract class _MatRowHarnessBase<\n  CellType extends (ComponentHarnessConstructor<Cell> & {\n    with: (options?: CellHarnessFilters) => HarnessPredicate<Cell>}),\n  Cell extends ComponentHarness & {getText(): Promise<string>, getColumnName(): Promise<string>}\n> extends ComponentHarness {\n  protected abstract _cellHarness: CellType;\n\n  /** Gets a list of `MatCellHarness` for all cells in the row. */\n  async getCells(filter: CellHarnessFilters = {}): Promise<Cell[]> {\n    return this.locatorForAll(this._cellHarness.with(filter))();\n  }\n\n  /** Gets the text of the cells in the row. */\n  async getCellTextByIndex(filter: CellHarnessFilters = {}): Promise<string[]> {\n    const cells = await this.getCells(filter);\n    return parallel(() => cells.map(cell => cell.getText()));\n  }\n\n  /** Gets the text inside the row organized by columns. */\n  async getCellTextByColumnName(): Promise<MatRowHarnessColumnsText> {\n    const output: MatRowHarnessColumnsText = {};\n    const cells = await this.getCells();\n    const cellsData = await parallel(() => cells.map(cell => {\n      return parallel(() => [cell.getColumnName(), cell.getText()]);\n    }));\n    cellsData.forEach(([columnName, text]) => output[columnName] = text);\n    return output;\n  }\n}\n\n/** Harness for interacting with a standard Angular Material table row. */\nexport class MatRowHarness extends _MatRowHarnessBase<typeof MatCellHarness, MatCellHarness> {\n  /** The selector for the host element of a `MatRowHarness` instance. */\n  static hostSelector = '.mat-row';\n  protected _cellHarness = MatCellHarness;\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\n/** Harness for interacting with a standard Angular Material table header row. */\nexport class MatHeaderRowHarness extends _MatRowHarnessBase<\n  typeof MatHeaderCellHarness, MatHeaderCellHarness> {\n  /** The selector for the host element of a `MatHeaderRowHarness` instance. */\n  static hostSelector = '.mat-header-row';\n  protected _cellHarness = MatHeaderCellHarness;\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\n\n/** Harness for interacting with a standard Angular Material table footer row. */\nexport class MatFooterRowHarness extends _MatRowHarnessBase<\n  typeof MatFooterCellHarness, MatFooterCellHarness> {\n  /** The selector for the host element of a `MatFooterRowHarness` instance. */\n  static hostSelector = '.mat-footer-row';\n  protected _cellHarness = MatFooterCellHarness;\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"]}
Note: See TracBrowser for help on using the repository browser.