UNPKG

@christian-bromann/webdriverio

Version:

A nodejs bindings implementation for selenium 2.0/webdriver

55 lines (48 loc) 1.61 kB
/** * * Return true or false if the selected DOM-element found by given selector is enabled. * * <example> :index.html <input type="text" name="inputField" class="input1"> <input type="text" name="inputField" class="input2" disabled> <input type="text" name="inputField" class="input3" disabled="disabled"> :isEnabledAsync.js client .isEnabled('.input1').then(function(isEnabled) { console.log(isEnabled); // outputs: true }) .isEnabled('.input2').then(function(isEnabled) { console.log(isEnabled); // outputs: false }) .isEnabled('.input3').then(function(isEnabled) { console.log(isEnabled); // outputs: false }) * </example> * * @alias browser.isEnabled * @param {String} selector DOM-element * @returns {Boolean|Boolean[]} true if element(s)* (is|are) enabled * @uses protocol/elements, protocol/elementIdEnabled * @type state * */ import { CommandError } from '../utils/ErrorHandler' let isEnabled = function (selector) { return this.elements(selector).then((res) => { /** * throw NoSuchElement error if no element was found */ if (!res.value || res.value.length === 0) { throw new CommandError(7) } let elementIdEnabledCommands = [] for (let elem of res.value) { elementIdEnabledCommands.push(this.elementIdEnabled(elem.ELEMENT)) } return this.unify(elementIdEnabledCommands, { extractValue: true }) }) } export default isEnabled