@testim/testim-cli
Version:
Command line interface for running Testing on you CI
67 lines (54 loc) • 2.14 kB
JavaScript
/**
*
* Move the mouse by an offset of the specificed element. If no element is specified,
* the move is relative to the current mouse cursor. If an element is provided but no
* offset, the mouse will be moved to the center of the element. If the element is not
* visible, it will be scrolled into view.
*
* @param {String} selector element to move to
* @param {Number} xoffset X offset to move to, relative to the top-left corner of the element. If not specified, the mouse will move to the middle of the element.
* @param {Number} yoffset Y offset to move to, relative to the top-left corner of the element. If not specified, the mouse will move to the middle of the element.
*
* @uses protocol/element, protocol/elementIdLocation
* @type action
*
*/
module.exports = function moveToObject(selector, xoffset, yoffset) {
/**
* check for offset params
*/
var hasOffsetParams = true;
if (typeof xoffset !== 'number' && typeof yoffset !== 'number') {
hasOffsetParams = false;
}
if (typeof xoffset !== 'number') {
xoffset = 0;
}
if (typeof yoffset !== 'number') {
yoffset = 0;
}
if (this.isMobile) {
return this.element(selector).then(function(res) {
return this.elementIdSize(res.value.ELEMENT).then(function(size) {
return this.elementIdLocation(res.element.value.ELEMENT).then(function(location) {
return {
size: size,
location: location
};
});
});
}).then(function(res) {
var x = res.location.value.x,
y = res.location.value.y;
if(hasOffsetParams) {
x = res.location.value.x - (res.size.value.width / 2) + xoffset;
y = res.location.value.y - (res.size.value.height / 2) + yoffset;
}
return this.touchMove(x, y);
});
} else {
return this.element(selector).then(function(res) {
return this.moveTo(res.value.ELEMENT, xoffset, yoffset);
});
}
};