UNPKG

@christian-bromann/webdriverio

Version:

A nodejs bindings implementation for selenium 2.0/webdriver

61 lines (53 loc) 1.81 kB
/** * * Get the width and height for an DOM-element based given selector. * * <example> :getElementSize.js client .getElementSize('.header-logo-wordmark').then(function(size) { console.log(size) // outputs: { width: 100, height: 200 } }) .getElementSize('.header-logo-wordmark', 'width').then(function(width) { console.log(width) // outputs: 100 }) .getElementSize('.header-logo-wordmark', 'height').then(function(height) { console.log(height) // outputs: 200 }); * </example> * * @alias browser.getElementSize * @param {String} selector element with requested size * @returns {Object} requested element size (`{width:number, height:number}`) * @uses protocol/elements, protocol/elementIdSize * @type property * */ import { CommandError } from '../utils/ErrorHandler' let getElementSize = function (selector, prop) { return this.elements(selector).then(function (res) { /** * throw NoSuchElement error if no element was found */ if (!res.value || res.value.length === 0) { throw new CommandError(7) } let elementIdSizeCommands = [] for (let elem of res.value) { elementIdSizeCommands.push(this.elementIdSize(elem.ELEMENT)) } return Promise.all(elementIdSizeCommands) }).then((sizes) => { sizes = sizes.map((size) => { if (typeof prop === 'string' && prop.match(/(width|height)/)) { return size.value[prop] } return { width: size.value.width, height: size.value.height } }) return sizes.length === 1 ? sizes[0] : sizes }) } export default getElementSize