/**
 * @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 } from "tslib";
import { ComponentHarness, HarnessPredicate } from '@angular/cdk/testing';
import { coerceBooleanProperty } from '@angular/cdk/coercion';
/** Harness for interacting with a standard mat-button-toggle in tests. */
var MatButtonToggleHarness = /** @class */ (function (_super) {
    __extends(MatButtonToggleHarness, _super);
    function MatButtonToggleHarness() {
        var _this = _super !== null && _super.apply(this, arguments) || this;
        _this._label = _this.locatorFor('.mat-button-toggle-label-content');
        _this._button = _this.locatorFor('.mat-button-toggle-button');
        return _this;
    }
    /**
     * Gets a `HarnessPredicate` that can be used to search for a `MatButtonToggleHarness` that meets
     * certain criteria.
     * @param options Options for filtering which button toggle instances are considered a match.
     * @return a `HarnessPredicate` configured with the given options.
     */
    MatButtonToggleHarness.with = function (options) {
        var _this = this;
        if (options === void 0) { options = {}; }
        return new HarnessPredicate(MatButtonToggleHarness, options)
            .addOption('text', options.text, function (harness, text) { return HarnessPredicate.stringMatches(harness.getText(), text); })
            .addOption('name', options.name, function (harness, name) { return HarnessPredicate.stringMatches(harness.getName(), name); })
            .addOption('checked', options.checked, function (harness, checked) { return __awaiter(_this, void 0, void 0, function () { return __generator(this, function (_a) {
            switch (_a.label) {
                case 0: return [4 /*yield*/, harness.isChecked()];
                case 1: return [2 /*return*/, (_a.sent()) === checked];
            }
        }); }); });
    };
    /** Gets a boolean promise indicating if the button toggle is checked. */
    MatButtonToggleHarness.prototype.isChecked = function () {
        return __awaiter(this, void 0, void 0, function () {
            var checked, _a;
            return __generator(this, function (_b) {
                switch (_b.label) {
                    case 0: return [4 /*yield*/, this._button()];
                    case 1:
                        checked = (_b.sent()).getAttribute('aria-pressed');
                        _a = coerceBooleanProperty;
                        return [4 /*yield*/, checked];
                    case 2: return [2 /*return*/, _a.apply(void 0, [_b.sent()])];
                }
            });
        });
    };
    /** Gets a boolean promise indicating if the button toggle is disabled. */
    MatButtonToggleHarness.prototype.isDisabled = function () {
        return __awaiter(this, void 0, void 0, function () {
            var disabled, _a;
            return __generator(this, function (_b) {
                switch (_b.label) {
                    case 0: return [4 /*yield*/, this._button()];
                    case 1:
                        disabled = (_b.sent()).getAttribute('disabled');
                        _a = coerceBooleanProperty;
                        return [4 /*yield*/, disabled];
                    case 2: return [2 /*return*/, _a.apply(void 0, [_b.sent()])];
                }
            });
        });
    };
    /** Gets a promise for the button toggle's name. */
    MatButtonToggleHarness.prototype.getName = function () {
        return __awaiter(this, void 0, void 0, function () {
            return __generator(this, function (_a) {
                switch (_a.label) {
                    case 0: return [4 /*yield*/, this._button()];
                    case 1: return [2 /*return*/, (_a.sent()).getAttribute('name')];
                }
            });
        });
    };
    /** Gets a promise for the button toggle's aria-label. */
    MatButtonToggleHarness.prototype.getAriaLabel = function () {
        return __awaiter(this, void 0, void 0, function () {
            return __generator(this, function (_a) {
                switch (_a.label) {
                    case 0: return [4 /*yield*/, this._button()];
                    case 1: return [2 /*return*/, (_a.sent()).getAttribute('aria-label')];
                }
            });
        });
    };
    /** Gets a promise for the button toggles's aria-labelledby. */
    MatButtonToggleHarness.prototype.getAriaLabelledby = function () {
        return __awaiter(this, void 0, void 0, function () {
            return __generator(this, function (_a) {
                switch (_a.label) {
                    case 0: return [4 /*yield*/, this._button()];
                    case 1: return [2 /*return*/, (_a.sent()).getAttribute('aria-labelledby')];
                }
            });
        });
    };
    /** Gets a promise for the button toggle's text. */
    MatButtonToggleHarness.prototype.getText = function () {
        return __awaiter(this, void 0, void 0, function () {
            return __generator(this, function (_a) {
                switch (_a.label) {
                    case 0: return [4 /*yield*/, this._label()];
                    case 1: return [2 /*return*/, (_a.sent()).text()];
                }
            });
        });
    };
    /** Gets the appearance that the button toggle is using. */
    MatButtonToggleHarness.prototype.getAppearance = function () {
        return __awaiter(this, void 0, void 0, function () {
            var host, className;
            return __generator(this, function (_a) {
                switch (_a.label) {
                    case 0: return [4 /*yield*/, this.host()];
                    case 1:
                        host = _a.sent();
                        className = 'mat-button-toggle-appearance-standard';
                        return [4 /*yield*/, host.hasClass(className)];
                    case 2: return [2 /*return*/, (_a.sent()) ? 'standard' : 'legacy'];
                }
            });
        });
    };
    /** Focuses the toggle. */
    MatButtonToggleHarness.prototype.focus = function () {
        return __awaiter(this, void 0, void 0, function () {
            return __generator(this, function (_a) {
                switch (_a.label) {
                    case 0: return [4 /*yield*/, this._button()];
                    case 1: return [2 /*return*/, (_a.sent()).focus()];
                }
            });
        });
    };
    /** Blurs the toggle. */
    MatButtonToggleHarness.prototype.blur = function () {
        return __awaiter(this, void 0, void 0, function () {
            return __generator(this, function (_a) {
                switch (_a.label) {
                    case 0: return [4 /*yield*/, this._button()];
                    case 1: return [2 /*return*/, (_a.sent()).blur()];
                }
            });
        });
    };
    /** Toggle the checked state of the buttons toggle. */
    MatButtonToggleHarness.prototype.toggle = function () {
        return __awaiter(this, void 0, void 0, function () {
            return __generator(this, function (_a) {
                switch (_a.label) {
                    case 0: return [4 /*yield*/, this._button()];
                    case 1: return [2 /*return*/, (_a.sent()).click()];
                }
            });
        });
    };
    /**
     * Puts the button toggle in a checked state by toggling it if it's
     * currently unchecked, or doing nothing if it is already checked.
     */
    MatButtonToggleHarness.prototype.check = function () {
        return __awaiter(this, void 0, void 0, function () {
            return __generator(this, function (_a) {
                switch (_a.label) {
                    case 0: return [4 /*yield*/, this.isChecked()];
                    case 1:
                        if (!!(_a.sent())) return [3 /*break*/, 3];
                        return [4 /*yield*/, this.toggle()];
                    case 2:
                        _a.sent();
                        _a.label = 3;
                    case 3: return [2 /*return*/];
                }
            });
        });
    };
    /**
     * Puts the button toggle in an unchecked state by toggling it if it's
     * currently checked, or doing nothing if it's already unchecked.
     */
    MatButtonToggleHarness.prototype.uncheck = function () {
        return __awaiter(this, void 0, void 0, function () {
            return __generator(this, function (_a) {
                switch (_a.label) {
                    case 0: return [4 /*yield*/, this.isChecked()];
                    case 1:
                        if (!_a.sent()) return [3 /*break*/, 3];
                        return [4 /*yield*/, this.toggle()];
                    case 2:
                        _a.sent();
                        _a.label = 3;
                    case 3: return [2 /*return*/];
                }
            });
        });
    };
    /** The selector for the host element of a `MatButton` instance. */
    MatButtonToggleHarness.hostSelector = 'mat-button-toggle';
    return MatButtonToggleHarness;
}(ComponentHarness));
export { MatButtonToggleHarness };
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"button-toggle-harness.js","sourceRoot":"","sources":["../../../../../../../../../../../../src/material/button-toggle/testing/button-toggle-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 {ComponentHarness, HarnessPredicate} from '@angular/cdk/testing';\nimport {coerceBooleanProperty} from '@angular/cdk/coercion';\nimport {MatButtonToggleAppearance} from '@angular/material/button-toggle';\nimport {ButtonToggleHarnessFilters} from './button-toggle-harness-filters';\n\n\n/** Harness for interacting with a standard mat-button-toggle in tests. */\nexport class MatButtonToggleHarness extends ComponentHarness {\n  /** The selector for the host element of a `MatButton` instance. */\n  static hostSelector = 'mat-button-toggle';\n\n  private _label = this.locatorFor('.mat-button-toggle-label-content');\n  private _button = this.locatorFor('.mat-button-toggle-button');\n\n  /**\n   * Gets a `HarnessPredicate` that can be used to search for a `MatButtonToggleHarness` that meets\n   * certain criteria.\n   * @param options Options for filtering which button toggle instances are considered a match.\n   * @return a `HarnessPredicate` configured with the given options.\n   */\n  static with(options: ButtonToggleHarnessFilters = {}): HarnessPredicate<MatButtonToggleHarness> {\n    return new HarnessPredicate(MatButtonToggleHarness, options)\n        .addOption('text', options.text,\n            (harness, text) => HarnessPredicate.stringMatches(harness.getText(), text))\n        .addOption('name', options.name,\n            (harness, name) => HarnessPredicate.stringMatches(harness.getName(), name))\n        .addOption('checked', options.checked,\n            async (harness, checked) => (await harness.isChecked()) === checked);\n  }\n\n  /** Gets a boolean promise indicating if the button toggle is checked. */\n  async isChecked(): Promise<boolean> {\n    const checked = (await this._button()).getAttribute('aria-pressed');\n    return coerceBooleanProperty(await checked);\n  }\n\n  /** Gets a boolean promise indicating if the button toggle is disabled. */\n  async isDisabled(): Promise<boolean> {\n    const disabled = (await this._button()).getAttribute('disabled');\n    return coerceBooleanProperty(await disabled);\n  }\n\n  /** Gets a promise for the button toggle's name. */\n  async getName(): Promise<string | null> {\n    return (await this._button()).getAttribute('name');\n  }\n\n  /** Gets a promise for the button toggle's aria-label. */\n  async getAriaLabel(): Promise<string | null> {\n    return (await this._button()).getAttribute('aria-label');\n  }\n\n  /** Gets a promise for the button toggles's aria-labelledby. */\n  async getAriaLabelledby(): Promise<string | null> {\n    return (await this._button()).getAttribute('aria-labelledby');\n  }\n\n  /** Gets a promise for the button toggle's text. */\n  async getText(): Promise<string> {\n    return (await this._label()).text();\n  }\n\n  /** Gets the appearance that the button toggle is using. */\n  async getAppearance(): Promise<MatButtonToggleAppearance> {\n    const host = await this.host();\n    const className = 'mat-button-toggle-appearance-standard';\n    return await host.hasClass(className) ? 'standard' : 'legacy';\n  }\n\n  /** Focuses the toggle. */\n  async focus(): Promise<void> {\n    return (await this._button()).focus();\n  }\n\n  /** Blurs the toggle. */\n  async blur(): Promise<void> {\n    return (await this._button()).blur();\n  }\n\n  /** Toggle the checked state of the buttons toggle. */\n  async toggle(): Promise<void> {\n    return (await this._button()).click();\n  }\n\n  /**\n   * Puts the button toggle in a checked state by toggling it if it's\n   * currently unchecked, or doing nothing if it is already checked.\n   */\n  async check(): Promise<void> {\n    if (!(await this.isChecked())) {\n      await this.toggle();\n    }\n  }\n\n  /**\n   * Puts the button toggle in an unchecked state by toggling it if it's\n   * currently checked, or doing nothing if it's already unchecked.\n   */\n  async uncheck(): Promise<void> {\n    if (await this.isChecked()) {\n      await this.toggle();\n    }\n  }\n}\n"]}