UNPKG

@testim/testim-cli

Version:

Command line interface for running Testing on you CI

59 lines (53 loc) 1.97 kB
/** * * Return true if the selected DOM-element found by given selector is visible and within the viewport. * * <example> :index.html <div id="notDisplayed" style="display: none"></div> <div id="notVisible" style="visibility: hidden"></div> <div id="notInViewport" style="position:absolute; left: 9999999"></div> <div id="zeroOpacity" style="opacity: 0"></div> :isVisibleWithinViewport.js client .isVisibleWithinViewport('#notDisplayed').then(function(isVisible) { console.log(isVisible); // outputs: false }) .isVisibleWithinViewport('#notVisible').then(function(isVisible) { console.log(isVisible); // outputs: false }) .isVisible('#notExisting').then(function(isVisible) { console.log(isVisible); // outputs: false }) .isVisibleWithinViewport('#notInViewport').then(function(isVisible) { console.log(isVisible); // outputs: false }) .isVisibleWithinViewport('#zeroOpacity').then(function(isVisible) { console.log(isVisible); // outputs: false }); * </example> * * @param {String} selector DOM-element * @returns {Boolean|Boolean[]} true if element(s)* [is|are] visible * * @uses protocol/selectorExecute, protocol/timeoutsAsyncScript * @type state * */ var isVisibleWithinViewportFunc = require('../helpers/_isWithinViewport.js'); module.exports = function isVisibleWithinViewport (selector) { return this.selectorExecute(selector, isVisibleWithinViewportFunc).then(function(res) { if(Array.isArray(res) && res.length === 1) { return res[0]; } return res; }, function(err) { /** * if element does not exist it is automatically not visible ;-) */ if(err.message.indexOf('NoSuchElement') > -1) { return true; } throw err; }); };