blob: 8df43c4c394b6b83d625e33b996cabb3d3cd3f61 [file] [log] [blame]
"use strict";
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
return new (P || (P = Promise))(function (resolve, reject) {
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
function step(result) { result.done ? resolve(result.value) : new P(function (resolve) { resolve(result.value); }).then(fulfilled, rejected); }
step((generator = generator.apply(thisArg, _arguments || [])).next());
});
};
Object.defineProperty(exports, "__esModule", { value: true });
const webdriver_commands_1 = require("./webdriver_commands");
const HIGHLIGHT_COMMAND = [webdriver_commands_1.CommandName.ElementClick, webdriver_commands_1.CommandName.ElementSendKeys, webdriver_commands_1.CommandName.ElementClear];
let clientScripts = require('./client_scripts/highlight.js');
/**
* A barrier that delays forwarding WebDriver commands that can affect the app (ie, clicks or
* sending text) for a fixed amount of time. During the delay, the element that's the target
* of the command will be highlighted by drawing a transparent div on top of it.
*/
class HighlightDelayBarrier {
constructor(client, delay) {
this.client = client;
this.delay = delay;
}
isHighlightCommand(command) {
return HIGHLIGHT_COMMAND.indexOf(command.commandName) !== -1;
}
highlightData(top, left, width, height) {
return JSON.stringify({
script: 'return (' + clientScripts.HIGHLIGHT_FN + ').apply(null, arguments);',
args: [top, left, width, height]
});
}
removeHighlightData() {
return JSON.stringify({
script: 'return (' + clientScripts.REMOVE_HIGHLIGHT_FN + ').apply(null, arguments);',
args: []
});
}
// Simple promise-based sleep so we can use async/await
sleep(delay) {
return new Promise((resolve) => {
setTimeout(() => {
resolve();
}, delay);
});
}
onCommand(command) {
return __awaiter(this, void 0, void 0, function* () {
if (!this.isHighlightCommand(command) || !this.delay) {
return;
}
const sessId = command.sessionId;
const el = command.getParam('elementId');
// The W3C spec does have a 'getRect', but the standalone server doesn't support it yet.
const loc = yield this.client.getLocation(sessId, el);
const size = yield this.client.getSize(sessId, el);
// Set the highlight
yield this.client.execute(sessId, this.highlightData(loc['y'], loc['x'], size['width'], size['height']));
// Wait
yield this.sleep(this.delay);
// Clear the highlight
yield this.client.execute(sessId, this.removeHighlightData());
});
}
}
exports.HighlightDelayBarrier = HighlightDelayBarrier;
//# sourceMappingURL=highlight_delay_barrier.js.map