@angular/material
Version:
Angular Material
160 lines • 20.4 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, __read, __spread, __values } from "tslib";
import { ComponentHarness } from '@angular/cdk/testing';
import { MatDividerHarness } from '@angular/material/divider/testing';
import { MatSubheaderHarness } from './list-item-harness-base';
/**
* Shared behavior among the harnesses for the various `MatList` flavors.
* @template T A constructor type for a list item harness type used by this list harness.
* @template C The list item harness type that `T` constructs.
* @template F The filter type used filter list item harness of type `C`.
* @docs-private
*/
var MatListHarnessBase = /** @class */ (function (_super) {
__extends(MatListHarnessBase, _super);
function MatListHarnessBase() {
return _super !== null && _super.apply(this, arguments) || this;
}
/**
* Gets a list of harnesses representing the items in this list.
* @param filters Optional filters used to narrow which harnesses are included
* @return The list of items matching the given filters.
*/
MatListHarnessBase.prototype.getItems = function (filters) {
return __awaiter(this, void 0, void 0, function () {
return __generator(this, function (_a) {
return [2 /*return*/, this.locatorForAll(this._itemHarness.with(filters))()];
});
});
};
/**
* Gets a list of `ListSection` representing the list items grouped by subheaders. If the list has
* no subheaders it is represented as a single `ListSection` with an undefined `heading` property.
* @param filters Optional filters used to narrow which list item harnesses are included
* @return The list of items matching the given filters, grouped into sections by subheader.
*/
MatListHarnessBase.prototype.getItemsGroupedBySubheader = function (filters) {
return __awaiter(this, void 0, void 0, function () {
var listSections, currentSection, itemsAndSubheaders, itemsAndSubheaders_1, itemsAndSubheaders_1_1, itemOrSubheader, _a, e_1_1;
var e_1, _b;
return __generator(this, function (_c) {
switch (_c.label) {
case 0:
listSections = [];
currentSection = { items: [] };
return [4 /*yield*/, this.getItemsWithSubheadersAndDividers({ item: filters, divider: false })];
case 1:
itemsAndSubheaders = _c.sent();
_c.label = 2;
case 2:
_c.trys.push([2, 8, 9, 10]);
itemsAndSubheaders_1 = __values(itemsAndSubheaders), itemsAndSubheaders_1_1 = itemsAndSubheaders_1.next();
_c.label = 3;
case 3:
if (!!itemsAndSubheaders_1_1.done) return [3 /*break*/, 7];
itemOrSubheader = itemsAndSubheaders_1_1.value;
if (!(itemOrSubheader instanceof MatSubheaderHarness)) return [3 /*break*/, 5];
if (currentSection.heading !== undefined || currentSection.items.length) {
listSections.push(currentSection);
}
_a = {};
return [4 /*yield*/, itemOrSubheader.getText()];
case 4:
currentSection = (_a.heading = _c.sent(), _a.items = [], _a);
return [3 /*break*/, 6];
case 5:
currentSection.items.push(itemOrSubheader);
_c.label = 6;
case 6:
itemsAndSubheaders_1_1 = itemsAndSubheaders_1.next();
return [3 /*break*/, 3];
case 7: return [3 /*break*/, 10];
case 8:
e_1_1 = _c.sent();
e_1 = { error: e_1_1 };
return [3 /*break*/, 10];
case 9:
try {
if (itemsAndSubheaders_1_1 && !itemsAndSubheaders_1_1.done && (_b = itemsAndSubheaders_1.return)) _b.call(itemsAndSubheaders_1);
}
finally { if (e_1) throw e_1.error; }
return [7 /*endfinally*/];
case 10:
if (currentSection.heading !== undefined || currentSection.items.length ||
!listSections.length) {
listSections.push(currentSection);
}
return [2 /*return*/, listSections];
}
});
});
};
/**
* Gets a list of sub-lists representing the list items grouped by dividers. If the list has no
* dividers it is represented as a list with a single sub-list.
* @param filters Optional filters used to narrow which list item harnesses are included
* @return The list of items matching the given filters, grouped into sub-lists by divider.
*/
MatListHarnessBase.prototype.getItemsGroupedByDividers = function (filters) {
return __awaiter(this, void 0, void 0, function () {
var listSections, itemsAndDividers, itemsAndDividers_1, itemsAndDividers_1_1, itemOrDivider;
var e_2, _a;
return __generator(this, function (_b) {
switch (_b.label) {
case 0:
listSections = [[]];
return [4 /*yield*/, this.getItemsWithSubheadersAndDividers({ item: filters, subheader: false })];
case 1:
itemsAndDividers = _b.sent();
try {
for (itemsAndDividers_1 = __values(itemsAndDividers), itemsAndDividers_1_1 = itemsAndDividers_1.next(); !itemsAndDividers_1_1.done; itemsAndDividers_1_1 = itemsAndDividers_1.next()) {
itemOrDivider = itemsAndDividers_1_1.value;
if (itemOrDivider instanceof MatDividerHarness) {
listSections.push([]);
}
else {
listSections[listSections.length - 1].push(itemOrDivider);
}
}
}
catch (e_2_1) { e_2 = { error: e_2_1 }; }
finally {
try {
if (itemsAndDividers_1_1 && !itemsAndDividers_1_1.done && (_a = itemsAndDividers_1.return)) _a.call(itemsAndDividers_1);
}
finally { if (e_2) throw e_2.error; }
}
return [2 /*return*/, listSections];
}
});
});
};
MatListHarnessBase.prototype.getItemsWithSubheadersAndDividers = function (filters) {
if (filters === void 0) { filters = {}; }
return __awaiter(this, void 0, void 0, function () {
var query;
return __generator(this, function (_a) {
query = [];
if (filters.item !== false) {
query.push(this._itemHarness.with(filters.item || {}));
}
if (filters.subheader !== false) {
query.push(MatSubheaderHarness.with(filters.subheader));
}
if (filters.divider !== false) {
query.push(MatDividerHarness.with(filters.divider));
}
return [2 /*return*/, this.locatorForAll.apply(this, __spread(query))()];
});
});
};
return MatListHarnessBase;
}(ComponentHarness));
export { MatListHarnessBase };
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"list-harness-base.js","sourceRoot":"","sources":["../../../../../../../../../../../../src/material/list/testing/list-harness-base.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 {\n  ComponentHarness,\n  ComponentHarnessConstructor,\n  HarnessPredicate\n} from '@angular/cdk/testing';\nimport {DividerHarnessFilters, MatDividerHarness} from '@angular/material/divider/testing';\nimport {BaseListItemHarnessFilters, SubheaderHarnessFilters} from './list-harness-filters';\nimport {MatSubheaderHarness} from './list-item-harness-base';\n\n/** Represents a section of a list falling under a specific header. */\nexport interface ListSection<I> {\n  /** The heading for this list section. `undefined` if there is no heading. */\n  heading?: string;\n\n  /** The items in this list section. */\n  items: I[];\n}\n\n/**\n * Shared behavior among the harnesses for the various `MatList` flavors.\n * @template T A constructor type for a list item harness type used by this list harness.\n * @template C The list item harness type that `T` constructs.\n * @template F The filter type used filter list item harness of type `C`.\n * @docs-private\n */\nexport class MatListHarnessBase\n    <\n      T extends (ComponentHarnessConstructor<C> & {with: (options?: F) => HarnessPredicate<C>}),\n      C extends ComponentHarness,\n      F extends BaseListItemHarnessFilters\n    > extends ComponentHarness {\n  protected _itemHarness: T;\n\n  /**\n   * Gets a list of harnesses representing the items in this list.\n   * @param filters Optional filters used to narrow which harnesses are included\n   * @return The list of items matching the given filters.\n   */\n  async getItems(filters?: F): Promise<C[]> {\n    return this.locatorForAll(this._itemHarness.with(filters))();\n  }\n\n  /**\n   * Gets a list of `ListSection` representing the list items grouped by subheaders. If the list has\n   * no subheaders it is represented as a single `ListSection` with an undefined `heading` property.\n   * @param filters Optional filters used to narrow which list item harnesses are included\n   * @return The list of items matching the given filters, grouped into sections by subheader.\n   */\n  async getItemsGroupedBySubheader(filters?: F): Promise<ListSection<C>[]> {\n    const listSections = [];\n    let currentSection: ListSection<C> = {items: []};\n    const itemsAndSubheaders =\n        await this.getItemsWithSubheadersAndDividers({item: filters, divider: false});\n    for (const itemOrSubheader of itemsAndSubheaders) {\n      if (itemOrSubheader instanceof MatSubheaderHarness) {\n        if (currentSection.heading !== undefined || currentSection.items.length) {\n          listSections.push(currentSection);\n        }\n        currentSection = {heading: await itemOrSubheader.getText(), items: []};\n      } else {\n        currentSection.items.push(itemOrSubheader);\n      }\n    }\n    if (currentSection.heading !== undefined || currentSection.items.length ||\n        !listSections.length) {\n      listSections.push(currentSection);\n    }\n    return listSections;\n  }\n\n  /**\n   * Gets a list of sub-lists representing the list items grouped by dividers. If the list has no\n   * dividers it is represented as a list with a single sub-list.\n   * @param filters Optional filters used to narrow which list item harnesses are included\n   * @return The list of items matching the given filters, grouped into sub-lists by divider.\n   */\n  async getItemsGroupedByDividers(filters?: F): Promise<C[][]> {\n    const listSections: C[][] = [[]];\n    const itemsAndDividers =\n        await this.getItemsWithSubheadersAndDividers({item: filters, subheader: false});\n    for (const itemOrDivider of itemsAndDividers) {\n      if (itemOrDivider instanceof MatDividerHarness) {\n        listSections.push([]);\n      } else {\n        listSections[listSections.length - 1].push(itemOrDivider);\n      }\n    }\n    return listSections;\n  }\n\n  /**\n   * Gets a list of harnesses representing all of the items, subheaders, and dividers\n   * (in the order they appear in the list). Use `instanceof` to check which type of harness a given\n   * item is.\n   * @param filters Optional filters used to narrow which list items, subheaders, and dividers are\n   *     included. A value of `false` for the `item`, `subheader`, or `divider` properties indicates\n   *     that the respective harness type should be omitted completely.\n   * @return The list of harnesses representing the items, subheaders, and dividers matching the\n   *     given filters.\n   */\n  getItemsWithSubheadersAndDividers(filters: {\n    item: false,\n    subheader: false,\n    divider: false\n  }): Promise<[]>;\n  getItemsWithSubheadersAndDividers(filters: {\n    item?: F | false,\n    subheader: false,\n    divider: false\n  }): Promise<C[]>;\n  getItemsWithSubheadersAndDividers(filters: {\n    item: false,\n    subheader?: SubheaderHarnessFilters | false,\n    divider: false\n  }): Promise<MatSubheaderHarness[]>;\n  getItemsWithSubheadersAndDividers(filters: {\n    item: false,\n    subheader: false,\n    divider?: DividerHarnessFilters | false\n  }): Promise<MatDividerHarness[]>;\n  getItemsWithSubheadersAndDividers(filters: {\n    item?: F | false,\n    subheader?: SubheaderHarnessFilters | false,\n    divider: false\n  }): Promise<(C | MatSubheaderHarness)[]>;\n  getItemsWithSubheadersAndDividers(filters: {\n    item?: F | false,\n    subheader: false,\n    divider?: false | DividerHarnessFilters\n  }): Promise<(C | MatDividerHarness)[]>;\n  getItemsWithSubheadersAndDividers(filters: {\n    item: false,\n    subheader?: false | SubheaderHarnessFilters,\n    divider?: false | DividerHarnessFilters\n  }): Promise<(MatSubheaderHarness | MatDividerHarness)[]>;\n  getItemsWithSubheadersAndDividers(filters?: {\n    item?: F | false,\n    subheader?: SubheaderHarnessFilters | false,\n    divider?: DividerHarnessFilters | false\n  }): Promise<(C | MatSubheaderHarness | MatDividerHarness)[]>;\n  async getItemsWithSubheadersAndDividers(filters: {\n    item?: F | false,\n    subheader?: SubheaderHarnessFilters | false,\n    divider?: DividerHarnessFilters | false\n  } = {}): Promise<(C | MatSubheaderHarness | MatDividerHarness)[]> {\n    const query = [];\n    if (filters.item !== false) {\n      query.push(this._itemHarness.with(filters.item || {} as F));\n    }\n    if (filters.subheader !== false) {\n      query.push(MatSubheaderHarness.with(filters.subheader));\n    }\n    if (filters.divider !== false) {\n      query.push(MatDividerHarness.with(filters.divider));\n    }\n    return this.locatorForAll(...query)();\n  }\n}\n"]}