@nova-ui/bits
Version:
SolarWinds Nova Framework
76 lines • 3.36 kB
JavaScript
"use strict";
// © 2022 SolarWinds Worldwide, LLC. All rights reserved.
//
// Permission is hereby granted, free of charge, to any person obtaining a copy
// of this software and associated documentation files (the "Software"), to
// deal in the Software without restriction, including without limitation the
// rights to use, copy, modify, merge, publish, distribute, sublicense, and/or
// sell copies of the Software, and to permit persons to whom the Software is
// furnished to do so, subject to the following conditions:
//
// The above copyright notice and this permission notice shall be included in
// all copies or substantial portions of the Software.
//
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
// OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
// THE SOFTWARE.
Object.defineProperty(exports, "__esModule", { value: true });
exports.RadioGroupAtom = void 0;
const tslib_1 = require("tslib");
const protractor_1 = require("protractor");
const atom_1 = require("../../atom");
class RadioGroupAtom extends atom_1.Atom {
getValue() {
return tslib_1.__awaiter(this, void 0, void 0, function* () {
return this.getElement()
.element(protractor_1.by.css("input:checked"))
.getAttribute("value");
});
}
// Finds and returns label element (clickable wrapper of radio button input element),
// because actual input element is hidden with "appearance: none" and is not clickable
getRadioByValue(value) {
return this.getElement()
.element(protractor_1.by.css(`input[value="${value}"]`))
.element(protractor_1.by.xpath("../.."));
}
// Finds and returns radio button input element
getRadioInputByValue(value) {
return this.getElement().element(protractor_1.by.css(`input[value="${value}"]`));
}
getHelpHintText(index) {
return tslib_1.__awaiter(this, void 0, void 0, function* () {
return this.getElement()
.all(protractor_1.by.css(".nui-help-hint"))
.get(index)
.getText();
});
}
getNumberOfItems() {
return tslib_1.__awaiter(this, void 0, void 0, function* () {
return this.getElement().all(protractor_1.by.css(".nui-radio")).count();
});
}
getFirst() {
return this.getElement().all(protractor_1.by.css(".nui-radio")).first();
}
getNumberOfDisabledItems() {
return tslib_1.__awaiter(this, void 0, void 0, function* () {
return this.getElement()
.all(protractor_1.by.css(".nui-radio__input[disabled]"))
.count();
});
}
isRadioSelected(value) {
return tslib_1.__awaiter(this, void 0, void 0, function* () {
return this.getRadioInputByValue(value).isSelected();
});
}
}
exports.RadioGroupAtom = RadioGroupAtom;
RadioGroupAtom.CSS_CLASS = "nui-radio-group";
//# sourceMappingURL=radio-group.atom.js.map