UNPKG

@angular/material

Version:
352 lines 35.3 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, __extends, __generator, __read } from "tslib"; import { ComponentHarness, HarnessPredicate } from '@angular/cdk/testing'; import { MatInputHarness } from '@angular/material/input/testing'; import { MatSelectHarness } from '@angular/material/select/testing'; /** Harness for interacting with a standard Material form-field's in tests. */ var MatFormFieldHarness = /** @class */ (function (_super) { __extends(MatFormFieldHarness, _super); function MatFormFieldHarness() { var _this = _super !== null && _super.apply(this, arguments) || this; _this._prefixContainer = _this.locatorForOptional('.mat-form-field-prefix'); _this._suffixContainer = _this.locatorForOptional('.mat-form-field-suffix'); _this._label = _this.locatorForOptional('.mat-form-field-label'); _this._errors = _this.locatorForAll('.mat-error'); _this._hints = _this.locatorForAll('mat-hint, .mat-hint'); _this._inputControl = _this.locatorForOptional(MatInputHarness); _this._selectControl = _this.locatorForOptional(MatSelectHarness); return _this; } /** * Gets a `HarnessPredicate` that can be used to search for a `MatFormFieldHarness` that meets * certain criteria. * @param options Options for filtering which form field instances are considered a match. * @return a `HarnessPredicate` configured with the given options. */ MatFormFieldHarness.with = function (options) { var _this = this; if (options === void 0) { options = {}; } return new HarnessPredicate(MatFormFieldHarness, options) .addOption('floatingLabelText', options.floatingLabelText, function (harness, text) { return __awaiter(_this, void 0, void 0, function () { var _a, _b; return __generator(this, function (_c) { switch (_c.label) { case 0: _b = (_a = HarnessPredicate).stringMatches; return [4 /*yield*/, harness.getLabel()]; case 1: return [2 /*return*/, _b.apply(_a, [_c.sent(), text])]; } }); }); }) .addOption('hasErrors', options.hasErrors, function (harness, hasErrors) { return __awaiter(_this, void 0, void 0, function () { return __generator(this, function (_a) { switch (_a.label) { case 0: return [4 /*yield*/, harness.hasErrors()]; case 1: return [2 /*return*/, (_a.sent()) === hasErrors]; } }); }); }); }; /** Gets the appearance of the form-field. */ MatFormFieldHarness.prototype.getAppearance = function () { return __awaiter(this, void 0, void 0, function () { var hostClasses, appearanceMatch; return __generator(this, function (_a) { switch (_a.label) { case 0: return [4 /*yield*/, this.host()]; case 1: return [4 /*yield*/, (_a.sent()).getAttribute('class')]; case 2: hostClasses = _a.sent(); if (hostClasses !== null) { appearanceMatch = hostClasses.match(/mat-form-field-appearance-(legacy|standard|fill|outline)(?:$| )/); if (appearanceMatch) { return [2 /*return*/, appearanceMatch[1]]; } } throw Error('Could not determine appearance of form-field.'); } }); }); }; // Implementation of the "getControl" method overload signatures. MatFormFieldHarness.prototype.getControl = function (type) { return __awaiter(this, void 0, void 0, function () { var hostEl, _a, isInput, isSelect; return __generator(this, function (_b) { switch (_b.label) { case 0: if (type) { return [2 /*return*/, this.locatorForOptional(type)()]; } return [4 /*yield*/, this.host()]; case 1: hostEl = _b.sent(); return [4 /*yield*/, Promise.all([ hostEl.hasClass('mat-form-field-type-mat-input'), hostEl.hasClass('mat-form-field-type-mat-select'), ])]; case 2: _a = __read.apply(void 0, [_b.sent(), 2]), isInput = _a[0], isSelect = _a[1]; if (isInput) { return [2 /*return*/, this._inputControl()]; } else if (isSelect) { return [2 /*return*/, this._selectControl()]; } return [2 /*return*/, null]; } }); }); }; /** Whether the form-field has a label. */ MatFormFieldHarness.prototype.hasLabel = function () { return __awaiter(this, void 0, void 0, function () { return __generator(this, function (_a) { switch (_a.label) { case 0: return [4 /*yield*/, this.host()]; case 1: return [2 /*return*/, (_a.sent()).hasClass('mat-form-field-has-label')]; } }); }); }; /** Gets the label of the form-field. */ MatFormFieldHarness.prototype.getLabel = function () { return __awaiter(this, void 0, void 0, function () { var labelEl; return __generator(this, function (_a) { switch (_a.label) { case 0: return [4 /*yield*/, this._label()]; case 1: labelEl = _a.sent(); return [2 /*return*/, labelEl ? labelEl.text() : null]; } }); }); }; /** Whether the form-field has errors. */ MatFormFieldHarness.prototype.hasErrors = function () { return __awaiter(this, void 0, void 0, function () { return __generator(this, function (_a) { switch (_a.label) { case 0: return [4 /*yield*/, this.getTextErrors()]; case 1: return [2 /*return*/, (_a.sent()).length > 0]; } }); }); }; /** Whether the label is currently floating. */ MatFormFieldHarness.prototype.isLabelFloating = function () { return __awaiter(this, void 0, void 0, function () { var _a, hasLabel, shouldFloat, _b, _c, _d; return __generator(this, function (_e) { switch (_e.label) { case 0: _c = (_b = Promise).all; _d = [this.hasLabel()]; return [4 /*yield*/, this.host()]; case 1: return [4 /*yield*/, _c.apply(_b, [_d.concat([ (_e.sent()).hasClass('mat-form-field-should-float') ])])]; case 2: _a = __read.apply(void 0, [_e.sent(), 2]), hasLabel = _a[0], shouldFloat = _a[1]; // If there is no label, the label conceptually can never float. The `should-float` class // is just always set regardless of whether the label is displayed or not. return [2 /*return*/, hasLabel && shouldFloat]; } }); }); }; /** Whether the form-field is disabled. */ MatFormFieldHarness.prototype.isDisabled = function () { return __awaiter(this, void 0, void 0, function () { return __generator(this, function (_a) { switch (_a.label) { case 0: return [4 /*yield*/, this.host()]; case 1: return [2 /*return*/, (_a.sent()).hasClass('mat-form-field-disabled')]; } }); }); }; /** Whether the form-field is currently autofilled. */ MatFormFieldHarness.prototype.isAutofilled = function () { return __awaiter(this, void 0, void 0, function () { return __generator(this, function (_a) { switch (_a.label) { case 0: return [4 /*yield*/, this.host()]; case 1: return [2 /*return*/, (_a.sent()).hasClass('mat-form-field-autofilled')]; } }); }); }; /** Gets the theme color of the form-field. */ MatFormFieldHarness.prototype.getThemeColor = function () { return __awaiter(this, void 0, void 0, function () { var hostEl, _a, isAccent, isWarn; return __generator(this, function (_b) { switch (_b.label) { case 0: return [4 /*yield*/, this.host()]; case 1: hostEl = _b.sent(); return [4 /*yield*/, Promise.all([hostEl.hasClass('mat-accent'), hostEl.hasClass('mat-warn')])]; case 2: _a = __read.apply(void 0, [_b.sent(), 2]), isAccent = _a[0], isWarn = _a[1]; if (isAccent) { return [2 /*return*/, 'accent']; } else if (isWarn) { return [2 /*return*/, 'warn']; } return [2 /*return*/, 'primary']; } }); }); }; /** Gets error messages which are currently displayed in the form-field. */ MatFormFieldHarness.prototype.getTextErrors = function () { return __awaiter(this, void 0, void 0, function () { var _a, _b; return __generator(this, function (_c) { switch (_c.label) { case 0: _b = (_a = Promise).all; return [4 /*yield*/, this._errors()]; case 1: return [2 /*return*/, _b.apply(_a, [(_c.sent()).map(function (e) { return e.text(); })])]; } }); }); }; /** Gets hint messages which are currently displayed in the form-field. */ MatFormFieldHarness.prototype.getTextHints = function () { return __awaiter(this, void 0, void 0, function () { var _a, _b; return __generator(this, function (_c) { switch (_c.label) { case 0: _b = (_a = Promise).all; return [4 /*yield*/, this._hints()]; case 1: return [2 /*return*/, _b.apply(_a, [(_c.sent()).map(function (e) { return e.text(); })])]; } }); }); }; /** * Gets a reference to the container element which contains all projected * prefixes of the form-field. */ MatFormFieldHarness.prototype.getHarnessLoaderForPrefix = function () { return __awaiter(this, void 0, void 0, function () { return __generator(this, function (_a) { return [2 /*return*/, this._prefixContainer()]; }); }); }; /** * Gets a reference to the container element which contains all projected * suffixes of the form-field. */ MatFormFieldHarness.prototype.getHarnessLoaderForSuffix = function () { return __awaiter(this, void 0, void 0, function () { return __generator(this, function (_a) { return [2 /*return*/, this._suffixContainer()]; }); }); }; /** * Whether the form control has been touched. Returns "null" * if no form control is set up. */ MatFormFieldHarness.prototype.isControlTouched = function () { return __awaiter(this, void 0, void 0, function () { return __generator(this, function (_a) { switch (_a.label) { case 0: return [4 /*yield*/, this._hasFormControl()]; case 1: if (!(_a.sent())) { return [2 /*return*/, null]; } return [4 /*yield*/, this.host()]; case 2: return [2 /*return*/, (_a.sent()).hasClass('ng-touched')]; } }); }); }; /** * Whether the form control is dirty. Returns "null" * if no form control is set up. */ MatFormFieldHarness.prototype.isControlDirty = function () { return __awaiter(this, void 0, void 0, function () { return __generator(this, function (_a) { switch (_a.label) { case 0: return [4 /*yield*/, this._hasFormControl()]; case 1: if (!(_a.sent())) { return [2 /*return*/, null]; } return [4 /*yield*/, this.host()]; case 2: return [2 /*return*/, (_a.sent()).hasClass('ng-dirty')]; } }); }); }; /** * Whether the form control is valid. Returns "null" * if no form control is set up. */ MatFormFieldHarness.prototype.isControlValid = function () { return __awaiter(this, void 0, void 0, function () { return __generator(this, function (_a) { switch (_a.label) { case 0: return [4 /*yield*/, this._hasFormControl()]; case 1: if (!(_a.sent())) { return [2 /*return*/, null]; } return [4 /*yield*/, this.host()]; case 2: return [2 /*return*/, (_a.sent()).hasClass('ng-valid')]; } }); }); }; /** * Whether the form control is pending validation. Returns "null" * if no form control is set up. */ MatFormFieldHarness.prototype.isControlPending = function () { return __awaiter(this, void 0, void 0, function () { return __generator(this, function (_a) { switch (_a.label) { case 0: return [4 /*yield*/, this._hasFormControl()]; case 1: if (!(_a.sent())) { return [2 /*return*/, null]; } return [4 /*yield*/, this.host()]; case 2: return [2 /*return*/, (_a.sent()).hasClass('ng-pending')]; } }); }); }; /** Checks whether the form-field control has set up a form control. */ MatFormFieldHarness.prototype._hasFormControl = function () { return __awaiter(this, void 0, void 0, function () { var hostEl, _a, isTouched, isUntouched; return __generator(this, function (_b) { switch (_b.label) { case 0: return [4 /*yield*/, this.host()]; case 1: hostEl = _b.sent(); return [4 /*yield*/, Promise.all([hostEl.hasClass('ng-touched'), hostEl.hasClass('ng-untouched')])]; case 2: _a = __read.apply(void 0, [_b.sent(), 2]), isTouched = _a[0], isUntouched = _a[1]; return [2 /*return*/, isTouched || isUntouched]; } }); }); }; MatFormFieldHarness.hostSelector = '.mat-form-field'; return MatFormFieldHarness; }(ComponentHarness)); export { MatFormFieldHarness }; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"form-field-harness.js","sourceRoot":"","sources":["../../../../../../../../../../../../src/material/form-field/testing/form-field-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 {\n  ComponentHarness,\n  ComponentHarnessConstructor,\n  HarnessPredicate,\n  HarnessQuery,\n  TestElement\n} from '@angular/cdk/testing';\nimport {MatFormFieldControlHarness} from '@angular/material/form-field/testing/control';\nimport {MatInputHarness} from '@angular/material/input/testing';\nimport {MatSelectHarness} from '@angular/material/select/testing';\nimport {FormFieldHarnessFilters} from './form-field-harness-filters';\n\n// TODO(devversion): support datepicker harness once developed (COMP-203).\n// Also support chip list harness.\n/** Possible harnesses of controls which can be bound to a form-field. */\nexport type FormFieldControlHarness = MatInputHarness|MatSelectHarness;\n\n/** Harness for interacting with a standard Material form-field's in tests. */\nexport class MatFormFieldHarness extends ComponentHarness {\n  static hostSelector = '.mat-form-field';\n\n  /**\n   * Gets a `HarnessPredicate` that can be used to search for a `MatFormFieldHarness` that meets\n   * certain criteria.\n   * @param options Options for filtering which form field instances are considered a match.\n   * @return a `HarnessPredicate` configured with the given options.\n   */\n  static with(options: FormFieldHarnessFilters = {}): HarnessPredicate<MatFormFieldHarness> {\n    return new HarnessPredicate(MatFormFieldHarness, options)\n      .addOption('floatingLabelText', options.floatingLabelText, async (harness, text) =>\n          HarnessPredicate.stringMatches(await harness.getLabel(), text))\n      .addOption('hasErrors', options.hasErrors, async (harness, hasErrors) =>\n          await harness.hasErrors() === hasErrors);\n  }\n\n  private _prefixContainer = this.locatorForOptional('.mat-form-field-prefix');\n  private _suffixContainer = this.locatorForOptional('.mat-form-field-suffix');\n  private _label = this.locatorForOptional('.mat-form-field-label');\n  private _errors = this.locatorForAll('.mat-error');\n  private _hints = this.locatorForAll('mat-hint, .mat-hint');\n\n  private _inputControl = this.locatorForOptional(MatInputHarness);\n  private _selectControl = this.locatorForOptional(MatSelectHarness);\n\n  /** Gets the appearance of the form-field. */\n  async getAppearance(): Promise<'legacy'|'standard'|'fill'|'outline'> {\n    const hostClasses = await (await this.host()).getAttribute('class');\n    if (hostClasses !== null) {\n      const appearanceMatch =\n          hostClasses.match(/mat-form-field-appearance-(legacy|standard|fill|outline)(?:$| )/);\n      if (appearanceMatch) {\n        return appearanceMatch[1] as 'legacy' | 'standard' | 'fill' | 'outline';\n      }\n    }\n    throw Error('Could not determine appearance of form-field.');\n  }\n\n  /**\n   * Gets the harness of the control that is bound to the form-field. Only\n   * default controls such as \"MatInputHarness\" and \"MatSelectHarness\" are\n   * supported.\n   */\n  async getControl(): Promise<FormFieldControlHarness|null>;\n\n  /**\n   * Gets the harness of the control that is bound to the form-field. Searches\n   * for a control that matches the specified harness type.\n   */\n  async getControl<X extends MatFormFieldControlHarness>(type: ComponentHarnessConstructor<X>):\n      Promise<X|null>;\n\n  /**\n   * Gets the harness of the control that is bound to the form-field. Searches\n   * for a control that matches the specified harness predicate.\n   */\n  async getControl<X extends MatFormFieldControlHarness>(type: HarnessPredicate<X>):\n      Promise<X|null>;\n\n  // Implementation of the \"getControl\" method overload signatures.\n  async getControl<X extends MatFormFieldControlHarness>(type?: HarnessQuery<X>) {\n    if (type) {\n      return this.locatorForOptional(type)();\n    }\n    const hostEl = await this.host();\n    const [isInput, isSelect] = await Promise.all([\n      hostEl.hasClass('mat-form-field-type-mat-input'),\n      hostEl.hasClass('mat-form-field-type-mat-select'),\n    ]);\n    if (isInput) {\n      return this._inputControl();\n    } else if (isSelect) {\n      return this._selectControl();\n    }\n    return null;\n  }\n\n  /** Whether the form-field has a label. */\n  async hasLabel(): Promise<boolean> {\n    return (await this.host()).hasClass('mat-form-field-has-label');\n  }\n\n  /** Gets the label of the form-field. */\n  async getLabel(): Promise<string|null> {\n    const labelEl = await this._label();\n    return labelEl ? labelEl.text() : null;\n  }\n\n  /** Whether the form-field has errors. */\n  async hasErrors(): Promise<boolean> {\n    return (await this.getTextErrors()).length > 0;\n  }\n\n  /** Whether the label is currently floating. */\n  async isLabelFloating(): Promise<boolean> {\n    const [hasLabel, shouldFloat] = await Promise.all([\n      this.hasLabel(),\n      (await this.host()).hasClass('mat-form-field-should-float'),\n    ]);\n    // If there is no label, the label conceptually can never float. The `should-float` class\n    // is just always set regardless of whether the label is displayed or not.\n    return hasLabel && shouldFloat;\n  }\n\n  /** Whether the form-field is disabled. */\n  async isDisabled(): Promise<boolean> {\n    return (await this.host()).hasClass('mat-form-field-disabled');\n  }\n\n  /** Whether the form-field is currently autofilled. */\n  async isAutofilled(): Promise<boolean> {\n    return (await this.host()).hasClass('mat-form-field-autofilled');\n  }\n\n  /** Gets the theme color of the form-field. */\n  async getThemeColor(): Promise<'primary'|'accent'|'warn'> {\n    const hostEl = await this.host();\n    const [isAccent, isWarn] =\n        await Promise.all([hostEl.hasClass('mat-accent'), hostEl.hasClass('mat-warn')]);\n    if (isAccent) {\n      return 'accent';\n    } else if (isWarn) {\n      return 'warn';\n    }\n    return 'primary';\n  }\n\n  /** Gets error messages which are currently displayed in the form-field. */\n  async getTextErrors(): Promise<string[]> {\n    return Promise.all((await this._errors()).map(e => e.text()));\n  }\n\n  /** Gets hint messages which are currently displayed in the form-field. */\n  async getTextHints(): Promise<string[]> {\n    return Promise.all((await this._hints()).map(e => e.text()));\n  }\n\n  /**\n   * Gets a reference to the container element which contains all projected\n   * prefixes of the form-field.\n   */\n  async getHarnessLoaderForPrefix(): Promise<TestElement|null> {\n    return this._prefixContainer();\n  }\n\n  /**\n   * Gets a reference to the container element which contains all projected\n   * suffixes of the form-field.\n   */\n  async getHarnessLoaderForSuffix(): Promise<TestElement|null> {\n    return this._suffixContainer();\n  }\n\n  /**\n   * Whether the form control has been touched. Returns \"null\"\n   * if no form control is set up.\n   */\n  async isControlTouched(): Promise<boolean|null> {\n    if (!await this._hasFormControl()) {\n      return null;\n    }\n    return (await this.host()).hasClass('ng-touched');\n  }\n\n  /**\n   * Whether the form control is dirty. Returns \"null\"\n   * if no form control is set up.\n   */\n  async isControlDirty(): Promise<boolean|null> {\n    if (!await this._hasFormControl()) {\n      return null;\n    }\n    return (await this.host()).hasClass('ng-dirty');\n  }\n\n  /**\n   * Whether the form control is valid. Returns \"null\"\n   * if no form control is set up.\n   */\n  async isControlValid(): Promise<boolean|null> {\n    if (!await this._hasFormControl()) {\n      return null;\n    }\n    return (await this.host()).hasClass('ng-valid');\n  }\n\n  /**\n   * Whether the form control is pending validation. Returns \"null\"\n   * if no form control is set up.\n   */\n  async isControlPending(): Promise<boolean|null> {\n    if (!await this._hasFormControl()) {\n      return null;\n    }\n    return (await this.host()).hasClass('ng-pending');\n  }\n\n  /** Checks whether the form-field control has set up a form control. */\n  private async _hasFormControl(): Promise<boolean> {\n    const hostEl = await this.host();\n    // If no form \"NgControl\" is bound to the form-field control, the form-field\n    // is not able to forward any control status classes. Therefore if either the\n    // \"ng-touched\" or \"ng-untouched\" class is set, we know that it has a form control\n    const [isTouched, isUntouched] =\n        await Promise.all([hostEl.hasClass('ng-touched'), hostEl.hasClass('ng-untouched')]);\n    return isTouched || isUntouched;\n  }\n}\n"]}