@angular/material
Version:
Angular Material
65 lines (62 loc) • 2.33 kB
JavaScript
import { ComponentHarness, HarnessPredicate } from '@angular/cdk/testing';
/** Harness for interacting with a standard Material badge in tests. */
class MatBadgeHarness extends ComponentHarness {
static hostSelector = '.mat-badge';
/**
* Gets a `HarnessPredicate` that can be used to search for a badge with specific attributes.
* @param options Options for narrowing the search:
* - `text` finds a badge host with a particular text.
* @return a `HarnessPredicate` configured with the given options.
*/
static with(options = {}) {
return new HarnessPredicate(MatBadgeHarness, options).addOption('text', options.text, (harness, text) => HarnessPredicate.stringMatches(harness.getText(), text));
}
_badgeElement = this.locatorFor('.mat-badge-content');
/** Gets a promise for the badge text. */
async getText() {
return (await this._badgeElement()).text();
}
/** Gets whether the badge is overlapping the content. */
async isOverlapping() {
return (await this.host()).hasClass('mat-badge-overlap');
}
/** Gets the position of the badge. */
async getPosition() {
const host = await this.host();
let result = '';
if (await host.hasClass('mat-badge-above')) {
result += 'above';
}
else if (await host.hasClass('mat-badge-below')) {
result += 'below';
}
if (await host.hasClass('mat-badge-before')) {
result += ' before';
}
else if (await host.hasClass('mat-badge-after')) {
result += ' after';
}
return result.trim();
}
/** Gets the size of the badge. */
async getSize() {
const host = await this.host();
if (await host.hasClass('mat-badge-small')) {
return 'small';
}
else if (await host.hasClass('mat-badge-large')) {
return 'large';
}
return 'medium';
}
/** Gets whether the badge is hidden. */
async isHidden() {
return (await this.host()).hasClass('mat-badge-hidden');
}
/** Gets whether the badge is disabled. */
async isDisabled() {
return (await this.host()).hasClass('mat-badge-disabled');
}
}
export { MatBadgeHarness };
//# sourceMappingURL=testing.mjs.map