testcafe 1.18.3 → 1.18.4
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.md +13 -0
- package/lib/browser/provider/built-in/dedicated/chrome/cdp-client/automations/click/create-mouse-click-strategy.js +59 -0
- package/lib/browser/provider/built-in/dedicated/chrome/cdp-client/shared-adapter-initializer.js +15 -1
- package/lib/browser/provider/built-in/dedicated/chrome/cdp-client/utils/dom-utils.js +94 -3
- package/lib/browser/provider/built-in/dedicated/chrome/cdp-client/utils/position-utils.js +38 -7
- package/lib/browser/provider/built-in/dedicated/chrome/cdp-client/utils/style-utils.js +8 -15
- package/lib/client/automation/index.js +1699 -1380
- package/lib/client/automation/index.min.js +1 -1
- package/lib/client/core/index.js +33 -4
- package/lib/client/core/index.min.js +1 -1
- package/lib/client/core/scroll/index.js +2 -2
- package/lib/client/core/utils/shared/position.js +2 -2
- package/lib/client/driver/index.js +143 -94
- package/lib/client/driver/index.min.js +1 -1
- package/lib/client/proxyless/index.js +5 -3
- package/lib/shared/actions/action-executor.js +4 -4
- package/lib/shared/actions/automations/click/index.js +53 -0
- package/lib/shared/actions/automations/click/mouse-click-strategy-base.js +21 -0
- package/lib/shared/actions/automations/move.js +4 -4
- package/lib/shared/actions/automations/visible-element-automation.js +162 -0
- package/lib/shared/actions/get-element.js +68 -0
- package/lib/shared/actions/utils/is-window-iframe.js +8 -0
- package/lib/shared/actions/utils/offsets.js +33 -0
- package/lib/shared/actions/utils/screen-point-to-client.js +15 -0
- package/package.json +3 -3
package/CHANGELOG.md
CHANGED
|
@@ -1,5 +1,18 @@
|
|
|
1
1
|
# Changelog
|
|
2
2
|
|
|
3
|
+
## v1.18.4
|
|
4
|
+
|
|
5
|
+
### What’s Changed
|
|
6
|
+
|
|
7
|
+
* TestCafe does not display reporter output during initialization ([#6842](https://github.com/DevExpress/testcafe/issues/6842))
|
|
8
|
+
|
|
9
|
+
* TestCafe uses outdated automation scripts after cache expiration ([testcafe-hammerhead#2738](https://github.com/DevExpress/testcafe-hammerhead/issues/2738), [PR](https://github.com/DevExpress/testcafe-hammerhead/issues/2739) by @rr13k)
|
|
10
|
+
|
|
11
|
+
* The `Node.append` method causes the `Illegal invocation` error (PR [testcafe-hammerhead#2730](https://github.com/DevExpress/testcafe-hammerhead/pull/2730) by @danieltroger)
|
|
12
|
+
|
|
13
|
+
* Scripts in SVG documents cause the `Illegal invocation` error ([testcafe-hammerhead#2735](https://github.com/DevExpress/testcafe-hammerhead/issues/2735
|
|
14
|
+
))
|
|
15
|
+
|
|
3
16
|
## v1.18.3 (2022-01-25)
|
|
4
17
|
|
|
5
18
|
### Bug Fixes
|
|
@@ -0,0 +1,59 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } });
|
|
5
|
+
}) : (function(o, m, k, k2) {
|
|
6
|
+
if (k2 === undefined) k2 = k;
|
|
7
|
+
o[k2] = m[k];
|
|
8
|
+
}));
|
|
9
|
+
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
10
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
11
|
+
}) : function(o, v) {
|
|
12
|
+
o["default"] = v;
|
|
13
|
+
});
|
|
14
|
+
var __importStar = (this && this.__importStar) || function (mod) {
|
|
15
|
+
if (mod && mod.__esModule) return mod;
|
|
16
|
+
var result = {};
|
|
17
|
+
if (mod != null) for (var k in mod) if (k !== "default" && Object.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
|
|
18
|
+
__setModuleDefault(result, mod);
|
|
19
|
+
return result;
|
|
20
|
+
};
|
|
21
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
22
|
+
const mouse_click_strategy_base_1 = require("../../../../../../../../shared/actions/automations/click/mouse-click-strategy-base");
|
|
23
|
+
const clientsManager = __importStar(require("../../clients-manager"));
|
|
24
|
+
const BUTTON = 'left';
|
|
25
|
+
const CLICK_COUNT = 1;
|
|
26
|
+
class CDPMouseClickStategy extends mouse_click_strategy_base_1.MouseClickStrategyBase {
|
|
27
|
+
constructor() {
|
|
28
|
+
super();
|
|
29
|
+
}
|
|
30
|
+
async mousedown(options) {
|
|
31
|
+
var _a, _b, _c, _d;
|
|
32
|
+
const { Input } = clientsManager.getClient();
|
|
33
|
+
await Input.dispatchMouseEvent({
|
|
34
|
+
type: 'mousePressed',
|
|
35
|
+
x: (_b = (_a = options.point) === null || _a === void 0 ? void 0 : _a.x) !== null && _b !== void 0 ? _b : -1,
|
|
36
|
+
y: (_d = (_c = options.point) === null || _c === void 0 ? void 0 : _c.y) !== null && _d !== void 0 ? _d : -1,
|
|
37
|
+
button: BUTTON,
|
|
38
|
+
clickCount: CLICK_COUNT,
|
|
39
|
+
});
|
|
40
|
+
}
|
|
41
|
+
async mouseup(element, options) {
|
|
42
|
+
var _a, _b, _c, _d;
|
|
43
|
+
const { Input } = clientsManager.getClient();
|
|
44
|
+
await Input.dispatchMouseEvent({
|
|
45
|
+
type: 'mouseReleased',
|
|
46
|
+
x: (_b = (_a = options.point) === null || _a === void 0 ? void 0 : _a.x) !== null && _b !== void 0 ? _b : -1,
|
|
47
|
+
y: (_d = (_c = options.point) === null || _c === void 0 ? void 0 : _c.y) !== null && _d !== void 0 ? _d : -1,
|
|
48
|
+
button: BUTTON,
|
|
49
|
+
clickCount: CLICK_COUNT,
|
|
50
|
+
});
|
|
51
|
+
return options;
|
|
52
|
+
}
|
|
53
|
+
}
|
|
54
|
+
function createMouseClickStrategy() {
|
|
55
|
+
return new CDPMouseClickStategy();
|
|
56
|
+
}
|
|
57
|
+
exports.default = createMouseClickStrategy;
|
|
58
|
+
module.exports = exports.default;
|
|
59
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY3JlYXRlLW1vdXNlLWNsaWNrLXN0cmF0ZWd5LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vc3JjL2Jyb3dzZXIvcHJvdmlkZXIvYnVpbHQtaW4vZGVkaWNhdGVkL2Nocm9tZS9jZHAtY2xpZW50L2F1dG9tYXRpb25zL2NsaWNrL2NyZWF0ZS1tb3VzZS1jbGljay1zdHJhdGVneS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7QUFDQSxrSUFBNEg7QUFDNUgsc0VBQXdEO0FBRXhELE1BQU0sTUFBTSxHQUFHLE1BQU0sQ0FBQztBQUN0QixNQUFNLFdBQVcsR0FBRyxDQUFDLENBQUM7QUFFdEIsTUFBTSxvQkFBd0IsU0FBUSxrREFBeUI7SUFDM0Q7UUFDSSxLQUFLLEVBQUUsQ0FBQztJQUNaLENBQUM7SUFFTSxLQUFLLENBQUMsU0FBUyxDQUFFLE9BQTBCOztRQUM5QyxNQUFNLEVBQUUsS0FBSyxFQUFFLEdBQUcsY0FBYyxDQUFDLFNBQVMsRUFBRSxDQUFDO1FBRTdDLE1BQU0sS0FBSyxDQUFDLGtCQUFrQixDQUFDO1lBQzNCLElBQUksRUFBUSxjQUFjO1lBQzFCLENBQUMsY0FBVyxPQUFPLENBQUMsS0FBSywwQ0FBRSxDQUFDLG1DQUFJLENBQUMsQ0FBQztZQUNsQyxDQUFDLGNBQVcsT0FBTyxDQUFDLEtBQUssMENBQUUsQ0FBQyxtQ0FBSSxDQUFDLENBQUM7WUFDbEMsTUFBTSxFQUFNLE1BQU07WUFDbEIsVUFBVSxFQUFFLFdBQVc7U0FDMUIsQ0FBQyxDQUFDO0lBQ1AsQ0FBQztJQUVNLEtBQUssQ0FBQyxPQUFPLENBQUUsT0FBVSxFQUFFLE9BQTBCOztRQUN4RCxNQUFNLEVBQUUsS0FBSyxFQUFFLEdBQUcsY0FBYyxDQUFDLFNBQVMsRUFBRSxDQUFDO1FBRTdDLE1BQU0sS0FBSyxDQUFDLGtCQUFrQixDQUFDO1lBQzNCLElBQUksRUFBUSxlQUFlO1lBQzNCLENBQUMsY0FBVyxPQUFPLENBQUMsS0FBSywwQ0FBRSxDQUFDLG1DQUFJLENBQUMsQ0FBQztZQUNsQyxDQUFDLGNBQVcsT0FBTyxDQUFDLEtBQUssMENBQUUsQ0FBQyxtQ0FBSSxDQUFDLENBQUM7WUFDbEMsTUFBTSxFQUFNLE1BQU07WUFDbEIsVUFBVSxFQUFFLFdBQVc7U0FDMUIsQ0FBQyxDQUFDO1FBRUgsT0FBTyxPQUFPLENBQUM7SUFDbkIsQ0FBQztDQUNKO0FBRUQsU0FBd0Isd0JBQXdCO0lBQzVDLE9BQU8sSUFBSSxvQkFBb0IsRUFBSyxDQUFDO0FBQ3pDLENBQUM7QUFGRCwyQ0FFQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE1vdXNlRXZlbnRBcmdzIH0gZnJvbSAnLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vc2hhcmVkL2FjdGlvbnMvYXV0b21hdGlvbnMvdmlzaWJsZS1lbGVtZW50LWF1dG9tYXRpb24nO1xuaW1wb3J0IHsgTW91c2VDbGlja1N0cmF0ZWd5QmFzZSB9IGZyb20gJy4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL3NoYXJlZC9hY3Rpb25zL2F1dG9tYXRpb25zL2NsaWNrL21vdXNlLWNsaWNrLXN0cmF0ZWd5LWJhc2UnO1xuaW1wb3J0ICogYXMgY2xpZW50c01hbmFnZXIgZnJvbSAnLi4vLi4vY2xpZW50cy1tYW5hZ2VyJztcblxuY29uc3QgQlVUVE9OID0gJ2xlZnQnO1xuY29uc3QgQ0xJQ0tfQ09VTlQgPSAxO1xuXG5jbGFzcyBDRFBNb3VzZUNsaWNrU3RhdGVneTxFPiBleHRlbmRzIE1vdXNlQ2xpY2tTdHJhdGVneUJhc2U8RT4ge1xuICAgIHB1YmxpYyBjb25zdHJ1Y3RvciAoKSB7XG4gICAgICAgIHN1cGVyKCk7XG4gICAgfVxuXG4gICAgcHVibGljIGFzeW5jIG1vdXNlZG93biAob3B0aW9uczogTW91c2VFdmVudEFyZ3M8RT4pOiBQcm9taXNlPHZvaWQ+IHtcbiAgICAgICAgY29uc3QgeyBJbnB1dCB9ID0gY2xpZW50c01hbmFnZXIuZ2V0Q2xpZW50KCk7XG5cbiAgICAgICAgYXdhaXQgSW5wdXQuZGlzcGF0Y2hNb3VzZUV2ZW50KHtcbiAgICAgICAgICAgIHR5cGU6ICAgICAgICdtb3VzZVByZXNzZWQnLFxuICAgICAgICAgICAgeDogICAgICAgICAgb3B0aW9ucy5wb2ludD8ueCA/PyAtMSxcbiAgICAgICAgICAgIHk6ICAgICAgICAgIG9wdGlvbnMucG9pbnQ/LnkgPz8gLTEsXG4gICAgICAgICAgICBidXR0b246ICAgICBCVVRUT04sXG4gICAgICAgICAgICBjbGlja0NvdW50OiBDTElDS19DT1VOVCxcbiAgICAgICAgfSk7XG4gICAgfVxuXG4gICAgcHVibGljIGFzeW5jIG1vdXNldXAgKGVsZW1lbnQ6IEUsIG9wdGlvbnM6IE1vdXNlRXZlbnRBcmdzPEU+KTogUHJvbWlzZTxNb3VzZUV2ZW50QXJnczxFPj4ge1xuICAgICAgICBjb25zdCB7IElucHV0IH0gPSBjbGllbnRzTWFuYWdlci5nZXRDbGllbnQoKTtcblxuICAgICAgICBhd2FpdCBJbnB1dC5kaXNwYXRjaE1vdXNlRXZlbnQoe1xuICAgICAgICAgICAgdHlwZTogICAgICAgJ21vdXNlUmVsZWFzZWQnLFxuICAgICAgICAgICAgeDogICAgICAgICAgb3B0aW9ucy5wb2ludD8ueCA/PyAtMSxcbiAgICAgICAgICAgIHk6ICAgICAgICAgIG9wdGlvbnMucG9pbnQ/LnkgPz8gLTEsXG4gICAgICAgICAgICBidXR0b246ICAgICBCVVRUT04sXG4gICAgICAgICAgICBjbGlja0NvdW50OiBDTElDS19DT1VOVCxcbiAgICAgICAgfSk7XG5cbiAgICAgICAgcmV0dXJuIG9wdGlvbnM7XG4gICAgfVxufVxuXG5leHBvcnQgZGVmYXVsdCBmdW5jdGlvbiBjcmVhdGVNb3VzZUNsaWNrU3RyYXRlZ3k8RT4gKCk6IE1vdXNlQ2xpY2tTdHJhdGVneUJhc2U8RT4ge1xuICAgIHJldHVybiBuZXcgQ0RQTW91c2VDbGlja1N0YXRlZ3k8RT4oKTtcbn1cbiJdfQ==
|
package/lib/browser/provider/built-in/dedicated/chrome/cdp-client/shared-adapter-initializer.js
CHANGED
|
@@ -30,6 +30,7 @@ const positionUtils = __importStar(require("./utils/position-utils"));
|
|
|
30
30
|
const styleUtils = __importStar(require("./utils/style-utils"));
|
|
31
31
|
const eventUtils = __importStar(require("./utils/event-utils"));
|
|
32
32
|
const create_event_sequence_1 = __importDefault(require("./utils/create-event-sequence"));
|
|
33
|
+
const create_mouse_click_strategy_1 = __importDefault(require("./automations/click/create-mouse-click-strategy"));
|
|
33
34
|
adapter_1.initializeAdapter({
|
|
34
35
|
PromiseCtor: Promise,
|
|
35
36
|
nativeMethods: {
|
|
@@ -76,6 +77,11 @@ adapter_1.initializeAdapter({
|
|
|
76
77
|
featureDetection: {
|
|
77
78
|
isTouchDevice: false,
|
|
78
79
|
},
|
|
80
|
+
utils: {
|
|
81
|
+
extend(target, ...args) {
|
|
82
|
+
return Object.assign(target, ...args);
|
|
83
|
+
},
|
|
84
|
+
},
|
|
79
85
|
createEventSequence: create_event_sequence_1.default,
|
|
80
86
|
sendRequestToFrame: () => { },
|
|
81
87
|
getElementExceptUI: positionUtils.getElementFromPoint,
|
|
@@ -83,5 +89,13 @@ adapter_1.initializeAdapter({
|
|
|
83
89
|
position: positionUtils,
|
|
84
90
|
style: styleUtils,
|
|
85
91
|
event: eventUtils,
|
|
92
|
+
ensureMouseEventAfterScroll: () => Promise.resolve(),
|
|
93
|
+
automations: {
|
|
94
|
+
click: {
|
|
95
|
+
createMouseClickStrategy: create_mouse_click_strategy_1.default,
|
|
96
|
+
},
|
|
97
|
+
_ensureWindowAndCursorForLegacyTests() {
|
|
98
|
+
},
|
|
99
|
+
},
|
|
86
100
|
});
|
|
87
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
101
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2hhcmVkLWFkYXB0ZXItaW5pdGlhbGl6ZXIuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9zcmMvYnJvd3Nlci9wcm92aWRlci9idWlsdC1pbi9kZWRpY2F0ZWQvY2hyb21lL2NkcC1jbGllbnQvc2hhcmVkLWFkYXB0ZXItaW5pdGlhbGl6ZXIudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0FBQUEsNEVBQW1EO0FBR25ELHVEQUE4QztBQUM5Qyw4REFBcUU7QUFHckUsNERBQThDO0FBQzlDLHNFQUF3RDtBQUN4RCxnRUFBa0Q7QUFDbEQsZ0VBQWtEO0FBQ2xELDBGQUFnRTtBQUNoRSxrSEFBdUY7QUFHdkYsMkJBQWlCLENBQUM7SUFDZCxXQUFXLEVBQUUsT0FBTztJQUVwQixhQUFhLEVBQUU7UUFDWCxVQUFVO1FBQ1YsWUFBWTtRQUNaLFlBQVksRUFBRSxLQUFLLENBQUMsU0FBUyxDQUFDLE9BQU87UUFDckMsV0FBVyxFQUFHLEtBQUssQ0FBQyxTQUFTLENBQUMsTUFBTTtRQUNwQyxVQUFVLEVBQUksS0FBSyxDQUFDLFNBQVMsQ0FBQyxLQUFLO1FBQ25DLFdBQVcsRUFBRyxLQUFLLENBQUMsU0FBUyxDQUFDLE1BQU07UUFDcEMsWUFBWSxFQUFFLE1BQU0sQ0FBQyxNQUFNO1FBQzNCLFVBQVUsRUFBSSxNQUFNLENBQUMsSUFBSTtRQUN6QixPQUFPLEVBQU8sSUFBSSxDQUFDLEdBQUc7S0FDekI7SUFFRCxNQUFNLEVBQUUsS0FBSyxFQUFFLEVBQWMsRUFBRSxJQUFtQixFQUFFLEVBQUU7UUFDbEQsSUFBSSxPQUFPLEdBQUcsMkJBQWdCLENBQUMsT0FBa0MsQ0FBQztRQUNsRSxJQUFJLE1BQU0sR0FBSSxJQUFzQixDQUFDO1FBQ3JDLElBQUksTUFBTSxHQUFJLEtBQUssQ0FBc0MsQ0FBQztRQUUxRCxHQUFHO1lBQ0MsTUFBTSxFQUFFLGdCQUFnQixFQUFFLE1BQU0sRUFBRSxTQUFTLEVBQUUsR0FBRyxNQUFNLDJCQUFTLEVBQUUsQ0FBQyxPQUFPLENBQUMsY0FBYyxDQUFDO2dCQUNyRixhQUFhLEVBQVEsSUFBSTtnQkFDekIsWUFBWSxFQUFTLElBQUk7Z0JBQ3pCLGtCQUFrQixFQUFHLDJCQUFnQixDQUFDLG1CQUFtQixFQUFFO2dCQUMzRCxTQUFTLEVBQVksQ0FBQyxFQUFFLFFBQVEsRUFBRSxFQUFFLENBQUMsUUFBUSxFQUFFLEVBQUUsRUFBRSxLQUFLLEVBQUUsSUFBSSxFQUFFLEVBQUUsRUFBRSxLQUFLLEVBQUUsTUFBTSxFQUFFLENBQUM7Z0JBQ3BGLG1CQUFtQixFQUFFOztrQkFFbkI7YUFDTCxDQUFDLENBQUM7WUFFSCxJQUFJLGdCQUFnQjtnQkFDaEIsTUFBTSxnQkFBZ0IsQ0FBQztZQUUzQixNQUFNLFlBQVksR0FBRyxTQUFTLENBQUMsS0FBOEIsQ0FBQztZQUU5RCxJQUFJLE9BQU8sSUFBSSxPQUFPLEtBQUssT0FBTyxDQUFDLE1BQU0sRUFBRTtnQkFDdkMsUUFBUTtnQkFDUiw2Q0FBNkM7Z0JBQzdDLE9BQU8sR0FBUSxPQUFPLENBQUMsTUFBTSxDQUFDO2dCQUM5QixNQUFNLEdBQVMsTUFBTSxhQUFOLE1BQU0sY0FBTixNQUFNLEdBQUksWUFBWSxDQUFDLGtCQUFrQixDQUFDO2dCQUN6RCxNQUFNLEdBQVMsWUFBWSxDQUFDLGVBQWUsQ0FBQztnQkFDNUMsSUFBSSxDQUFDLE9BQU8sR0FBRyxZQUFZLENBQUMsT0FBTyxDQUFDO2dCQUNwQyxJQUFJLENBQUMsT0FBTyxHQUFHLFlBQVksQ0FBQyxPQUFPLENBQUM7YUFDdkM7U0FFSixRQUNNLE9BQU8sSUFBSSxPQUFPLEtBQUssT0FBTyxDQUFDLE1BQU0sRUFBRTtRQUU5QyxPQUFPLE1BQWlCLENBQUM7SUFDN0IsQ0FBQztJQUVELE9BQU8sRUFBRSxFQUFFLFFBQVEsRUFBRSxJQUFJLEVBQUU7SUFFM0IsZ0JBQWdCLEVBQUU7UUFDZCxhQUFhLEVBQUUsS0FBSztLQUN2QjtJQUVELEtBQUssRUFBRTtRQUNILE1BQU0sQ0FBRSxNQUEyQixFQUFFLEdBQUcsSUFBSTtZQUN4QyxPQUFPLE1BQU0sQ0FBQyxNQUFNLENBQUMsTUFBTSxFQUFFLEdBQUcsSUFBSSxDQUFDLENBQUM7UUFDMUMsQ0FBQztLQUNKO0lBRUQsbUJBQW1CLEVBQW5CLCtCQUFtQjtJQUVuQixrQkFBa0IsRUFBRSxHQUFHLEVBQUUsR0FBRyxDQUFDO0lBRTdCLGtCQUFrQixFQUFFLGFBQWEsQ0FBQyxtQkFBbUI7SUFDckQsR0FBRyxFQUFpQixRQUFRO0lBQzVCLFFBQVEsRUFBWSxhQUFhO0lBQ2pDLEtBQUssRUFBZSxVQUFVO0lBQzlCLEtBQUssRUFBZSxVQUFVO0lBRTlCLDJCQUEyQixFQUFFLEdBQUcsRUFBRSxDQUFDLE9BQU8sQ0FBQyxPQUFPLEVBQUU7SUFFcEQsV0FBVyxFQUFFO1FBQ1QsS0FBSyxFQUFFO1lBQ0gsd0JBQXdCLEVBQXhCLHFDQUF3QjtTQUMzQjtRQUVELG9DQUFvQztRQUNwQyxDQUFDO0tBQ0o7Q0FDSixDQUFDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgRXhlY3V0aW9uQ29udGV4dCBmcm9tICcuL2V4ZWN1dGlvbi1jb250ZXh0JztcbmltcG9ydCB7IFNlcnZlck5vZGUgfSBmcm9tICcuL3R5cGVzJztcbmltcG9ydCB7IFNjcm9sbE9wdGlvbnMgfSBmcm9tICcuLi8uLi8uLi8uLi8uLi8uLi90ZXN0LXJ1bi9jb21tYW5kcy9vcHRpb25zJztcbmltcG9ydCB7IGdldENsaWVudCB9IGZyb20gJy4vY2xpZW50cy1tYW5hZ2VyJztcbmltcG9ydCB7IGluaXRpYWxpemVBZGFwdGVyIH0gZnJvbSAnLi4vLi4vLi4vLi4vLi4vLi4vc2hhcmVkL2FkYXB0ZXInO1xuaW1wb3J0IHsgTGVmdFRvcFZhbHVlcyB9IGZyb20gJy4uLy4uLy4uLy4uLy4uLy4uL3NoYXJlZC91dGlscy92YWx1ZXMvYXhpcy12YWx1ZXMnO1xuaW1wb3J0IHsgU2Nyb2xsUmVzdWx0UHJveHlsZXNzIH0gZnJvbSAnLi4vLi4vLi4vLi4vLi4vLi4vY2xpZW50L2NvcmUvc2Nyb2xsJztcbmltcG9ydCAqIGFzIGRvbVV0aWxzIGZyb20gJy4vdXRpbHMvZG9tLXV0aWxzJztcbmltcG9ydCAqIGFzIHBvc2l0aW9uVXRpbHMgZnJvbSAnLi91dGlscy9wb3NpdGlvbi11dGlscyc7XG5pbXBvcnQgKiBhcyBzdHlsZVV0aWxzIGZyb20gJy4vdXRpbHMvc3R5bGUtdXRpbHMnO1xuaW1wb3J0ICogYXMgZXZlbnRVdGlscyBmcm9tICcuL3V0aWxzL2V2ZW50LXV0aWxzJztcbmltcG9ydCBjcmVhdGVFdmVudFNlcXVlbmNlIGZyb20gJy4vdXRpbHMvY3JlYXRlLWV2ZW50LXNlcXVlbmNlJztcbmltcG9ydCBjcmVhdGVNb3VzZUNsaWNrU3RyYXRlZ3kgZnJvbSAnLi9hdXRvbWF0aW9ucy9jbGljay9jcmVhdGUtbW91c2UtY2xpY2stc3RyYXRlZ3knO1xuXG5cbmluaXRpYWxpemVBZGFwdGVyKHtcbiAgICBQcm9taXNlQ3RvcjogUHJvbWlzZSxcblxuICAgIG5hdGl2ZU1ldGhvZHM6IHtcbiAgICAgICAgc2V0VGltZW91dCxcbiAgICAgICAgY2xlYXJUaW1lb3V0LFxuICAgICAgICBhcnJheUluZGV4T2Y6IEFycmF5LnByb3RvdHlwZS5pbmRleE9mLFxuICAgICAgICBhcnJheVNwbGljZTogIEFycmF5LnByb3RvdHlwZS5zcGxpY2UsXG4gICAgICAgIGFycmF5U2xpY2U6ICAgQXJyYXkucHJvdG90eXBlLnNsaWNlLFxuICAgICAgICBhcnJheUZpbHRlcjogIEFycmF5LnByb3RvdHlwZS5maWx0ZXIsXG4gICAgICAgIG9iamVjdEFzc2lnbjogT2JqZWN0LmFzc2lnbixcbiAgICAgICAgb2JqZWN0S2V5czogICBPYmplY3Qua2V5cyxcbiAgICAgICAgZGF0ZU5vdzogICAgICBEYXRlLm5vdyxcbiAgICB9LFxuXG4gICAgc2Nyb2xsOiBhc3luYyAoZWw6IFNlcnZlck5vZGUsIG9wdHM6IFNjcm9sbE9wdGlvbnMpID0+IHtcbiAgICAgICAgbGV0IGN1cnJDeHQgPSBFeGVjdXRpb25Db250ZXh0LmN1cnJlbnQgYXMgRXhlY3V0aW9uQ29udGV4dCB8IG51bGw7XG4gICAgICAgIGxldCByZXN1bHQgID0gbnVsbCBhcyBib29sZWFuIHwgbnVsbDtcbiAgICAgICAgbGV0IG1hcmdpbiAgPSB2b2lkIDAgYXMgdW5kZWZpbmVkIHwgTGVmdFRvcFZhbHVlczxudW1iZXI+O1xuXG4gICAgICAgIGRvIHtcbiAgICAgICAgICAgIGNvbnN0IHsgZXhjZXB0aW9uRGV0YWlscywgcmVzdWx0OiByZXN1bHRPYmogfSA9IGF3YWl0IGdldENsaWVudCgpLlJ1bnRpbWUuY2FsbEZ1bmN0aW9uT24oe1xuICAgICAgICAgICAgICAgIHJldHVybkJ5VmFsdWU6ICAgICAgIHRydWUsXG4gICAgICAgICAgICAgICAgYXdhaXRQcm9taXNlOiAgICAgICAgdHJ1ZSxcbiAgICAgICAgICAgICAgICBleGVjdXRpb25Db250ZXh0SWQ6ICBFeGVjdXRpb25Db250ZXh0LmdldEN1cnJlbnRDb250ZXh0SWQoKSxcbiAgICAgICAgICAgICAgICBhcmd1bWVudHM6ICAgICAgICAgICBbeyBvYmplY3RJZDogZWwub2JqZWN0SWQgfSwgeyB2YWx1ZTogb3B0cyB9LCB7IHZhbHVlOiBtYXJnaW4gfV0sXG4gICAgICAgICAgICAgICAgZnVuY3Rpb25EZWNsYXJhdGlvbjogYGZ1bmN0aW9uIChlbCwgb3B0cykge1xuICAgICAgICAgICAgICAgICAgICByZXR1cm4gd2luZG93W1wiJXByb3h5bGVzcyVcIl0uc2Nyb2xsKGVsLCBvcHRzKTtcbiAgICAgICAgICAgICAgICB9YCxcbiAgICAgICAgICAgIH0pO1xuXG4gICAgICAgICAgICBpZiAoZXhjZXB0aW9uRGV0YWlscylcbiAgICAgICAgICAgICAgICB0aHJvdyBleGNlcHRpb25EZXRhaWxzO1xuXG4gICAgICAgICAgICBjb25zdCBzY3JvbGxSZXN1bHQgPSByZXN1bHRPYmoudmFsdWUgYXMgU2Nyb2xsUmVzdWx0UHJveHlsZXNzO1xuXG4gICAgICAgICAgICBpZiAoY3VyckN4dCAmJiBjdXJyQ3h0ICE9PSBjdXJyQ3h0LnBhcmVudCkge1xuICAgICAgICAgICAgICAgIC8vIFRPRE86XG4gICAgICAgICAgICAgICAgLy9lbCAgICAgICAgICAgPSBmaW5kSWZyYW1lQnlXaW5kb3coY3VyckN4dCk7XG4gICAgICAgICAgICAgICAgY3VyckN4dCAgICAgID0gY3VyckN4dC5wYXJlbnQ7XG4gICAgICAgICAgICAgICAgcmVzdWx0ICAgICAgID0gcmVzdWx0ID8/IHNjcm9sbFJlc3VsdC5zY3JvbGxXYXNQZXJmb3JtZWQ7XG4gICAgICAgICAgICAgICAgbWFyZ2luICAgICAgID0gc2Nyb2xsUmVzdWx0Lm1heFNjcm9sbE1hcmdpbjtcbiAgICAgICAgICAgICAgICBvcHRzLm9mZnNldFggPSBzY3JvbGxSZXN1bHQub2Zmc2V0WDtcbiAgICAgICAgICAgICAgICBvcHRzLm9mZnNldFkgPSBzY3JvbGxSZXN1bHQub2Zmc2V0WTtcbiAgICAgICAgICAgIH1cblxuICAgICAgICB9XG4gICAgICAgIHdoaWxlIChjdXJyQ3h0ICYmIGN1cnJDeHQgIT09IGN1cnJDeHQucGFyZW50KTtcblxuICAgICAgICByZXR1cm4gcmVzdWx0IGFzIGJvb2xlYW47XG4gICAgfSxcblxuICAgIGJyb3dzZXI6IHsgaXNDaHJvbWU6IHRydWUgfSxcblxuICAgIGZlYXR1cmVEZXRlY3Rpb246IHtcbiAgICAgICAgaXNUb3VjaERldmljZTogZmFsc2UsXG4gICAgfSxcblxuICAgIHV0aWxzOiB7XG4gICAgICAgIGV4dGVuZCAodGFyZ2V0OiBSZWNvcmQ8c3RyaW5nLCBhbnk+LCAuLi5hcmdzKTogUmVjb3JkPHN0cmluZywgYW55PiB7XG4gICAgICAgICAgICByZXR1cm4gT2JqZWN0LmFzc2lnbih0YXJnZXQsIC4uLmFyZ3MpO1xuICAgICAgICB9LFxuICAgIH0sXG5cbiAgICBjcmVhdGVFdmVudFNlcXVlbmNlLFxuXG4gICAgc2VuZFJlcXVlc3RUb0ZyYW1lOiAoKSA9PiB7IH0sXG5cbiAgICBnZXRFbGVtZW50RXhjZXB0VUk6IHBvc2l0aW9uVXRpbHMuZ2V0RWxlbWVudEZyb21Qb2ludCxcbiAgICBkb206ICAgICAgICAgICAgICAgIGRvbVV0aWxzLFxuICAgIHBvc2l0aW9uOiAgICAgICAgICAgcG9zaXRpb25VdGlscyxcbiAgICBzdHlsZTogICAgICAgICAgICAgIHN0eWxlVXRpbHMsXG4gICAgZXZlbnQ6ICAgICAgICAgICAgICBldmVudFV0aWxzLFxuXG4gICAgZW5zdXJlTW91c2VFdmVudEFmdGVyU2Nyb2xsOiAoKSA9PiBQcm9taXNlLnJlc29sdmUoKSxcblxuICAgIGF1dG9tYXRpb25zOiB7XG4gICAgICAgIGNsaWNrOiB7XG4gICAgICAgICAgICBjcmVhdGVNb3VzZUNsaWNrU3RyYXRlZ3ksXG4gICAgICAgIH0sXG5cbiAgICAgICAgX2Vuc3VyZVdpbmRvd0FuZEN1cnNvckZvckxlZ2FjeVRlc3RzICgpIHtcbiAgICAgICAgfSxcbiAgICB9LFxufSk7XG4iXX0=
|
|
@@ -22,7 +22,7 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
|
22
22
|
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
23
23
|
};
|
|
24
24
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
25
|
-
exports.isIframeWindow = exports.isDocumentElement = exports.getDocumentElement = exports.isNodeEqual = exports.isDomElement = exports.getScrollingElement = exports.isBodyElement = exports.isHtmlElement = exports.findIframeByWindow = exports.getIFrameByIndex = exports.getIframeByElement = void 0;
|
|
25
|
+
exports.getParents = exports.getParentNode = exports.getImgMapName = exports.containsElement = exports.getNodeText = exports.closest = exports.isIframeWindow = exports.isDocumentElement = exports.getDocumentElement = exports.isNodeEqual = exports.isDomElement = exports.getScrollingElement = exports.isImgElement = exports.isBodyElement = exports.isHtmlElement = exports.getTagName = exports.findIframeByWindow = exports.getIFrameByIndex = exports.getIframeByElement = void 0;
|
|
26
26
|
const execution_context_1 = __importDefault(require("../execution-context"));
|
|
27
27
|
const index_1 = require("./index");
|
|
28
28
|
const clientsManager = __importStar(require("../clients-manager"));
|
|
@@ -82,6 +82,10 @@ async function findIframeByWindow(context) {
|
|
|
82
82
|
return null;
|
|
83
83
|
}
|
|
84
84
|
exports.findIframeByWindow = findIframeByWindow;
|
|
85
|
+
function getTagName(node) {
|
|
86
|
+
return node.nodeName.toLowerCase();
|
|
87
|
+
}
|
|
88
|
+
exports.getTagName = getTagName;
|
|
85
89
|
function hasTagName(node, tagName) {
|
|
86
90
|
return node.nodeName.toLowerCase() === tagName.toLowerCase();
|
|
87
91
|
}
|
|
@@ -93,6 +97,10 @@ function isBodyElement(node) {
|
|
|
93
97
|
return hasTagName(node, 'body');
|
|
94
98
|
}
|
|
95
99
|
exports.isBodyElement = isBodyElement;
|
|
100
|
+
function isImgElement(node) {
|
|
101
|
+
return hasTagName(node, 'img');
|
|
102
|
+
}
|
|
103
|
+
exports.isImgElement = isImgElement;
|
|
96
104
|
async function getScrollingElement(node) {
|
|
97
105
|
const client = clientsManager.getClient();
|
|
98
106
|
const args = {
|
|
@@ -126,7 +134,7 @@ async function getDocumentElement(win) {
|
|
|
126
134
|
});
|
|
127
135
|
if (exceptionDetails)
|
|
128
136
|
throw exceptionDetails;
|
|
129
|
-
return index_1.describeNode(DOM, resultObj.
|
|
137
|
+
return index_1.describeNode(DOM, resultObj.objectId);
|
|
130
138
|
}
|
|
131
139
|
exports.getDocumentElement = getDocumentElement;
|
|
132
140
|
async function isDocumentElement(el) {
|
|
@@ -138,4 +146,87 @@ async function isIframeWindow() {
|
|
|
138
146
|
return false;
|
|
139
147
|
}
|
|
140
148
|
exports.isIframeWindow = isIframeWindow;
|
|
141
|
-
|
|
149
|
+
async function closest(el, selector) {
|
|
150
|
+
const { Runtime, DOM } = clientsManager.getClient();
|
|
151
|
+
const { exceptionDetails, result: resultObj } = await Runtime.callFunctionOn({
|
|
152
|
+
arguments: [{ objectId: el.objectId }, { value: selector }],
|
|
153
|
+
functionDeclaration: `function (el, selector) {
|
|
154
|
+
debugger;
|
|
155
|
+
return window["%proxyless%"].nativeMethods.closest.call(el, selector);
|
|
156
|
+
}`,
|
|
157
|
+
executionContextId: execution_context_1.default.getCurrentContextId(),
|
|
158
|
+
});
|
|
159
|
+
if (exceptionDetails)
|
|
160
|
+
throw exceptionDetails;
|
|
161
|
+
return resultObj.value ? index_1.describeNode(DOM, resultObj.value.objectId) : null;
|
|
162
|
+
}
|
|
163
|
+
exports.closest = closest;
|
|
164
|
+
async function getNodeText(el) {
|
|
165
|
+
const { Runtime } = clientsManager.getClient();
|
|
166
|
+
const { exceptionDetails, result: resultObj } = await Runtime.callFunctionOn({
|
|
167
|
+
arguments: [{ objectId: el.objectId }],
|
|
168
|
+
functionDeclaration: `function (el) {
|
|
169
|
+
return window["%proxyless%"].nativeMethods.nodeTextContentGetter.call(el);
|
|
170
|
+
}`,
|
|
171
|
+
executionContextId: execution_context_1.default.getCurrentContextId(),
|
|
172
|
+
});
|
|
173
|
+
if (exceptionDetails)
|
|
174
|
+
throw exceptionDetails;
|
|
175
|
+
return resultObj.value;
|
|
176
|
+
}
|
|
177
|
+
exports.getNodeText = getNodeText;
|
|
178
|
+
async function containsElement(el1, el2) {
|
|
179
|
+
const { Runtime } = clientsManager.getClient();
|
|
180
|
+
const { exceptionDetails, result: resultObj } = await Runtime.callFunctionOn({
|
|
181
|
+
arguments: [{ objectId: el1.objectId }, { objectId: el2.objectId }],
|
|
182
|
+
functionDeclaration: `function (el1, el2) {
|
|
183
|
+
do {
|
|
184
|
+
if (el2.parentNode === el1)
|
|
185
|
+
return true;
|
|
186
|
+
}
|
|
187
|
+
while(el2 = el2.parentNode);
|
|
188
|
+
return false;
|
|
189
|
+
}`,
|
|
190
|
+
executionContextId: execution_context_1.default.getCurrentContextId(),
|
|
191
|
+
});
|
|
192
|
+
if (exceptionDetails)
|
|
193
|
+
throw exceptionDetails;
|
|
194
|
+
return resultObj.value;
|
|
195
|
+
}
|
|
196
|
+
exports.containsElement = containsElement;
|
|
197
|
+
function getImgMapName(el) {
|
|
198
|
+
if (!el.attributes)
|
|
199
|
+
return '';
|
|
200
|
+
const useMapIndex = el.attributes.indexOf('usemap');
|
|
201
|
+
if (useMapIndex === -1)
|
|
202
|
+
return '';
|
|
203
|
+
return el.attributes[useMapIndex + 1].substring(1);
|
|
204
|
+
}
|
|
205
|
+
exports.getImgMapName = getImgMapName;
|
|
206
|
+
async function getParentNode({ objectId }) {
|
|
207
|
+
const { Runtime, DOM } = clientsManager.getClient();
|
|
208
|
+
const parent = await Runtime.callFunctionOn({
|
|
209
|
+
functionDeclaration: `function () {
|
|
210
|
+
const el = this.assignedSlot || this;
|
|
211
|
+
|
|
212
|
+
return this.parentNode || el.host;
|
|
213
|
+
}`,
|
|
214
|
+
objectId,
|
|
215
|
+
});
|
|
216
|
+
if (parent.result.value !== null && parent.result.objectId)
|
|
217
|
+
return index_1.describeNode(DOM, parent.result.objectId || '');
|
|
218
|
+
return null;
|
|
219
|
+
}
|
|
220
|
+
exports.getParentNode = getParentNode;
|
|
221
|
+
async function getParents(el) {
|
|
222
|
+
// TODO: check this method
|
|
223
|
+
const result = [];
|
|
224
|
+
let parent = await getParentNode(el);
|
|
225
|
+
while (parent) {
|
|
226
|
+
result.push(parent);
|
|
227
|
+
parent = await getParentNode(parent);
|
|
228
|
+
}
|
|
229
|
+
return result;
|
|
230
|
+
}
|
|
231
|
+
exports.getParents = getParents;
|
|
232
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dom-utils.js","sourceRoot":"","sources":["../../../../../../../../src/browser/provider/built-in/dedicated/chrome/cdp-client/utils/dom-utils.ts"],"names":[],"mappings":"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","sourcesContent":["import Protocol from 'devtools-protocol/types/protocol';\nimport ExecutionContext from '../execution-context';\nimport { describeNode } from './index';\nimport * as clientsManager from '../clients-manager';\nimport { ServerNode } from '../types';\n\nexport async function getIframeByElement ({ objectId }: ServerNode): Promise<ServerNode | null> {\n    const { Runtime, DOM } = clientsManager.getClient();\n\n    const frame = await Runtime.callFunctionOn({\n        functionDeclaration: `function () {\n            return this.ownerDocument.defaultView.frameElement\n        }`,\n        objectId,\n    });\n\n    if (frame.result.value !== null)\n        return describeNode(DOM, frame.result.objectId || '');\n\n    return null;\n}\n\nexport async function getIFrameByIndex (objectId: string | undefined, index: number): Promise<ServerNode | null> {\n    const { Runtime, DOM } = clientsManager.getClient();\n\n    const frame = await Runtime.callFunctionOn({\n        functionDeclaration: `function (index) {\n                return this[index];\n            }`,\n        objectId:  objectId,\n        arguments: [{ value: index }],\n    });\n\n    const frameObjectId = frame.result.objectId;\n\n    if (frameObjectId)\n        return describeNode(DOM, frameObjectId);\n\n    return null;\n}\n\nexport async function findIframeByWindow (context: ExecutionContext): Promise<ServerNode | null> {\n    const { Runtime } = clientsManager.getClient();\n\n    const expression = `\n        (function findIframes(parentDocument, result = []) {\n            if (!parentDocument)\n                return [];\n        \n            const children = parentDocument.querySelectorAll('iframe');\n        \n            for (const child of children) {\n                result.push(child, ...findIframes(child.contentDocument));\n            }\n        \n            return result;\n        })(document);\n   `;\n\n    const frames = await Runtime.evaluate({ expression });\n    let index    = 0;\n    let frame    = await getIFrameByIndex(frames.result.objectId, index);\n\n    while (frame) {\n        if (context.frameId === frame.frameId)\n            return frame;\n\n        index++;\n\n        frame = await getIFrameByIndex(frames.result.objectId, index);\n    }\n\n    return null;\n}\n\nexport function getTagName (node: ServerNode): string {\n    return node.nodeName.toLowerCase();\n}\n\nfunction hasTagName (node: ServerNode, tagName: string): boolean {\n    return node.nodeName.toLowerCase() === tagName.toLowerCase();\n}\n\nexport function isHtmlElement (node: ServerNode): boolean {\n    return hasTagName(node, 'html');\n}\n\nexport function isBodyElement (node: ServerNode): boolean {\n    return hasTagName(node, 'body');\n}\n\nexport function isImgElement (node: ServerNode): boolean {\n    return hasTagName(node, 'img');\n}\n\n\nexport async function getScrollingElement (node?: ServerNode): Promise<ServerNode> {\n    const client = clientsManager.getClient();\n\n    const args: Protocol.Runtime.CallFunctionOnRequest = {\n        functionDeclaration: `function () {\n            const doc = this !== window ? this.ownerDocument : document;\n            \n            return doc.scrollingElement;\n        }`,\n    };\n\n    if (node)\n        args.objectId = node.objectId;\n    else\n        args.executionContextId = ExecutionContext.top.ctxId;\n\n    const { result } = await client.Runtime.callFunctionOn(args);\n\n    return describeNode(client.DOM, result.objectId || '');\n}\n\nexport function isDomElement (node: ServerNode): boolean {\n    return node.nodeType === 1;\n}\n\nexport function isNodeEqual (el1: ServerNode, el2: ServerNode): boolean {\n    return el1.backendNodeId === el2.backendNodeId;\n}\n\nexport async function getDocumentElement (win: ExecutionContext): Promise<ServerNode> {\n    const { Runtime, DOM } = clientsManager.getClient();\n\n    const { exceptionDetails, result: resultObj } = await Runtime.evaluate({\n        expression: 'document.documentElement',\n        contextId:  win.ctxId,\n    });\n\n    if (exceptionDetails)\n        throw exceptionDetails;\n\n    return describeNode(DOM, resultObj.objectId as string);\n}\n\nexport async function isDocumentElement (el: ServerNode): Promise<boolean> {\n    const docEl = await getDocumentElement(ExecutionContext.current);\n\n    return isNodeEqual(el, docEl);\n}\n\nexport async function isIframeWindow (): Promise<boolean> {\n    return false;\n}\n\nexport async function closest (el: ServerNode, selector: string): Promise<ServerNode | null> {\n    const { Runtime, DOM } = clientsManager.getClient();\n\n    const { exceptionDetails, result: resultObj } = await Runtime.callFunctionOn({\n        arguments:           [{ objectId: el.objectId }, { value: selector }],\n        functionDeclaration: `function (el, selector) {\n            debugger;\n            return window[\"%proxyless%\"].nativeMethods.closest.call(el, selector);\n        }`,\n        executionContextId: ExecutionContext.getCurrentContextId(),\n    });\n\n    if (exceptionDetails)\n        throw exceptionDetails;\n\n    return resultObj.value ? describeNode(DOM, resultObj.value.objectId) : null;\n}\n\nexport async function getNodeText (el: ServerNode): Promise<string> {\n    const { Runtime } = clientsManager.getClient();\n\n    const { exceptionDetails, result: resultObj } = await Runtime.callFunctionOn({\n        arguments:           [{ objectId: el.objectId }],\n        functionDeclaration: `function (el) {\n            return window[\"%proxyless%\"].nativeMethods.nodeTextContentGetter.call(el);\n        }`,\n        executionContextId: ExecutionContext.getCurrentContextId(),\n    });\n\n    if (exceptionDetails)\n        throw exceptionDetails;\n\n    return resultObj.value;\n}\n\nexport async function containsElement (el1: ServerNode, el2: ServerNode): Promise<boolean> {\n    const { Runtime } = clientsManager.getClient();\n\n    const { exceptionDetails, result: resultObj } = await Runtime.callFunctionOn({\n        arguments:           [{ objectId: el1.objectId }, { objectId: el2.objectId }],\n        functionDeclaration: `function (el1, el2) {\n            do {\n                if (el2.parentNode === el1)\n                    return true;\n            }\n            while(el2 = el2.parentNode);\n            return false;\n        }`,\n        executionContextId: ExecutionContext.getCurrentContextId(),\n    });\n\n    if (exceptionDetails)\n        throw exceptionDetails;\n\n    return resultObj.value;\n}\n\nexport function getImgMapName (el: ServerNode): string {\n    if (!el.attributes)\n        return '';\n\n    const useMapIndex = el.attributes.indexOf('usemap');\n\n    if (useMapIndex === -1)\n        return '';\n\n    return el.attributes[useMapIndex + 1].substring(1);\n}\n\nexport async function getParentNode ({ objectId }: ServerNode): Promise<ServerNode | null> {\n    const { Runtime, DOM } = clientsManager.getClient();\n\n    const parent = await Runtime.callFunctionOn({\n        functionDeclaration: `function () {\n            const el = this.assignedSlot || this;\n\n            return this.parentNode || el.host;\n        }`,\n        objectId,\n    });\n\n    if (parent.result.value !== null && parent.result.objectId)\n        return describeNode(DOM, parent.result.objectId || '');\n\n    return null;\n}\n\nexport async function getParents (el: ServerNode): Promise<ServerNode[]> {\n    // TODO: check this method\n    const result = [];\n\n    let parent = await getParentNode(el);\n\n    while (parent) {\n        result.push(parent);\n\n        parent = await getParentNode(parent);\n    }\n\n    return result;\n}\n"]}
|
|
@@ -22,11 +22,12 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
|
22
22
|
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
23
23
|
};
|
|
24
24
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
25
|
-
exports.getWindowPosition = exports.getElementFromPoint = exports.getIframePointRelativeToParentFrame = exports.getIframeClientCoordinates = exports.containsOffset = exports.getOffsetPosition = exports.getClientPosition = void 0;
|
|
25
|
+
exports.offsetToClientCoords = exports.getWindowPosition = exports.getClientDimensions = exports.getElementRectangle = exports.getElementFromPoint = exports.getIframePointRelativeToParentFrame = exports.getIframeClientCoordinates = exports.containsOffset = exports.getOffsetPosition = exports.getClientPosition = void 0;
|
|
26
26
|
const axis_values_1 = __importDefault(require("../../../../../../../shared/utils/values/axis-values"));
|
|
27
27
|
const boundary_values_1 = __importDefault(require("../../../../../../../shared/utils/values/boundary-values"));
|
|
28
28
|
const dom_utils_1 = require("./dom-utils");
|
|
29
29
|
const clientsManager = __importStar(require("../clients-manager"));
|
|
30
|
+
const _1 = require("./");
|
|
30
31
|
const style_utils_1 = require("./style-utils");
|
|
31
32
|
async function getClientPosition(node) {
|
|
32
33
|
const boxModel = await style_utils_1.getBoxModel(node);
|
|
@@ -34,13 +35,13 @@ async function getClientPosition(node) {
|
|
|
34
35
|
}
|
|
35
36
|
exports.getClientPosition = getClientPosition;
|
|
36
37
|
async function getOffsetPosition(node) {
|
|
37
|
-
const dimensions = await
|
|
38
|
+
const dimensions = await getClientDimensions(node);
|
|
38
39
|
const { left, top } = await style_utils_1.getDocumentScroll(node);
|
|
39
40
|
return { left: dimensions.left + left, top: dimensions.top + top };
|
|
40
41
|
}
|
|
41
42
|
exports.getOffsetPosition = getOffsetPosition;
|
|
42
43
|
async function containsOffset(node, offsetX, offsetY) {
|
|
43
|
-
const dimensions = await
|
|
44
|
+
const dimensions = await getClientDimensions(node);
|
|
44
45
|
const properties = await style_utils_1.getProperties(node, 'scrollWidth', 'scrollHeight');
|
|
45
46
|
const width = Math.max(Number(properties.scrollWidth), dimensions.width);
|
|
46
47
|
const height = Math.max(Number(properties.scrollHeight), dimensions.height);
|
|
@@ -51,7 +52,7 @@ async function containsOffset(node, offsetX, offsetY) {
|
|
|
51
52
|
}
|
|
52
53
|
exports.containsOffset = containsOffset;
|
|
53
54
|
async function getIframeClientCoordinates(node) {
|
|
54
|
-
const dimensions = await
|
|
55
|
+
const dimensions = await getClientDimensions(node);
|
|
55
56
|
const [left, top, right, bottom] = [
|
|
56
57
|
dimensions.left + dimensions.border.left + dimensions.paddings.left,
|
|
57
58
|
dimensions.top + dimensions.border.top + dimensions.paddings.left,
|
|
@@ -65,7 +66,7 @@ async function getIframePointRelativeToParentFrame(iframePoint, context) {
|
|
|
65
66
|
const iframe = await dom_utils_1.findIframeByWindow(context);
|
|
66
67
|
if (!iframe)
|
|
67
68
|
return null;
|
|
68
|
-
const dimensions = await
|
|
69
|
+
const dimensions = await getClientDimensions(iframe);
|
|
69
70
|
const paddings = await style_utils_1.getElementPadding(iframe);
|
|
70
71
|
const left = dimensions.left + dimensions.border.left + paddings.left + iframePoint.x;
|
|
71
72
|
const top = dimensions.top + dimensions.border.top + paddings.top + iframePoint.y;
|
|
@@ -76,7 +77,9 @@ async function getElementFromPoint(point) {
|
|
|
76
77
|
const { DOM } = clientsManager.getClient();
|
|
77
78
|
try {
|
|
78
79
|
const { backendNodeId } = await DOM.getNodeForLocation({ x: point.x, y: point.y });
|
|
79
|
-
|
|
80
|
+
const result = await DOM.resolveNode({ backendNodeId });
|
|
81
|
+
if (result === null || result === void 0 ? void 0 : result.object.objectId)
|
|
82
|
+
return _1.describeNode(DOM, result.object.objectId.toString());
|
|
80
83
|
}
|
|
81
84
|
catch (_a) {
|
|
82
85
|
// NOTE: TODO: for some reason this methods throws error for correct `point` values
|
|
@@ -85,6 +88,29 @@ async function getElementFromPoint(point) {
|
|
|
85
88
|
return null;
|
|
86
89
|
}
|
|
87
90
|
exports.getElementFromPoint = getElementFromPoint;
|
|
91
|
+
async function getElementRectangle(node) {
|
|
92
|
+
const dimensions = await style_utils_1.getElementDimensions(node);
|
|
93
|
+
return {
|
|
94
|
+
height: dimensions.height,
|
|
95
|
+
left: dimensions.left,
|
|
96
|
+
top: dimensions.top,
|
|
97
|
+
width: dimensions.width,
|
|
98
|
+
};
|
|
99
|
+
}
|
|
100
|
+
exports.getElementRectangle = getElementRectangle;
|
|
101
|
+
async function getClientDimensions(node) {
|
|
102
|
+
const elementDimensions = await style_utils_1.getElementDimensions(node);
|
|
103
|
+
const parentFrame = await dom_utils_1.getIframeByElement(node);
|
|
104
|
+
if (parentFrame) {
|
|
105
|
+
const frameBoxModel = await style_utils_1.getBoxModel(parentFrame);
|
|
106
|
+
elementDimensions.left -= frameBoxModel.content[0];
|
|
107
|
+
elementDimensions.top -= frameBoxModel.content[1];
|
|
108
|
+
elementDimensions.bottom -= frameBoxModel.content[1];
|
|
109
|
+
elementDimensions.right -= frameBoxModel.content[0];
|
|
110
|
+
}
|
|
111
|
+
return elementDimensions;
|
|
112
|
+
}
|
|
113
|
+
exports.getClientDimensions = getClientDimensions;
|
|
88
114
|
async function getWindowPosition() {
|
|
89
115
|
const { Runtime } = clientsManager.getClient();
|
|
90
116
|
const args = {
|
|
@@ -98,4 +124,9 @@ async function getWindowPosition() {
|
|
|
98
124
|
return result.value;
|
|
99
125
|
}
|
|
100
126
|
exports.getWindowPosition = getWindowPosition;
|
|
101
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"position-utils.js","sourceRoot":"","sources":["../../../../../../../../src/browser/provider/built-in/dedicated/chrome/cdp-client/utils/position-utils.ts"],"names":[],"mappings":"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","sourcesContent":["import Protocol from 'devtools-protocol/types/protocol';\nimport ExecutionContext from '../execution-context';\nimport AxisValues, { AxisValuesData, LeftTopValues } from '../../../../../../../shared/utils/values/axis-values';\nimport BoundaryValues, { BoundaryValuesData } from '../../../../../../../shared/utils/values/boundary-values';\nimport { findIframeByWindow } from './dom-utils';\nimport * as clientsManager from '../clients-manager';\nimport { ServerNode } from '../types';\n\nimport {\n    getBoxModel,\n    getClientDimensions,\n    getDocumentScroll,\n    getElementPadding,\n    getProperties,\n} from './style-utils';\n\nexport async function getClientPosition (node: ServerNode): Promise<AxisValues<number>> {\n    const boxModel = await getBoxModel(node);\n\n    return new AxisValues<number>(boxModel.border[0], boxModel.border[1]);\n}\n\nexport async function getOffsetPosition (node: ServerNode): Promise<LeftTopValues<number>> {\n    const dimensions    = await getClientDimensions(node);\n    const { left, top } = await getDocumentScroll(node);\n\n    return { left: dimensions.left + left, top: dimensions.top + top };\n}\n\nexport async function containsOffset (node: ServerNode, offsetX: number, offsetY: number): Promise<boolean> {\n    const dimensions = await getClientDimensions(node);\n    const properties = await getProperties(node, 'scrollWidth', 'scrollHeight');\n\n    const width  = Math.max(Number(properties.scrollWidth), dimensions.width);\n    const height = Math.max(Number(properties.scrollHeight), dimensions.height);\n    const maxX   = dimensions.scrollbar.right + dimensions.border.left + dimensions.border.right + width;\n    const maxY   = dimensions.scrollbar.bottom + dimensions.border.top + dimensions.border.bottom + height;\n\n    return (typeof offsetX === 'undefined' || offsetX >= 0 && maxX >= offsetX) &&\n        (typeof offsetY === 'undefined' || offsetY >= 0 && maxY >= offsetY);\n}\n\nexport async function getIframeClientCoordinates (node: ServerNode): Promise<BoundaryValuesData> {\n    const dimensions = await getClientDimensions(node);\n\n    const [ left, top, right, bottom ] = [\n        dimensions.left + dimensions.border.left + dimensions.paddings.left,\n        dimensions.top + dimensions.border.top + dimensions.paddings.left,\n        dimensions.right - dimensions.border.right - dimensions.paddings.right,\n        dimensions.bottom - dimensions.border.bottom - dimensions.paddings.bottom,\n    ];\n\n    return new BoundaryValues(top, right, bottom, left);\n}\n\nexport async function getIframePointRelativeToParentFrame (iframePoint: AxisValues<number>, context: ExecutionContext): Promise<AxisValues<number> | null> {\n    const iframe = await findIframeByWindow(context);\n\n    if (!iframe)\n        return null;\n\n    const dimensions = await getClientDimensions(iframe);\n    const paddings   = await getElementPadding(iframe);\n\n    const left = dimensions.left + dimensions.border.left + paddings.left + iframePoint.x;\n    const top  = dimensions.top + dimensions.border.top + paddings.top + iframePoint.y;\n\n    return new AxisValues<number>(left, top);\n}\n\nexport async function getElementFromPoint (point: AxisValuesData<number>): Promise<Protocol.DOM.ResolveNodeResponse | null> {\n    const { DOM } = clientsManager.getClient();\n\n    try {\n        const { backendNodeId } = await DOM.getNodeForLocation({ x: point.x, y: point.y });\n\n        return DOM.resolveNode({ backendNodeId });\n    }\n    catch {\n        // NOTE: TODO: for some reason this methods throws error for correct `point` values\n        // always throws error for negative values\n    }\n\n    return null;\n}\n\nexport async function getWindowPosition (): Promise<AxisValues<number>> {\n    const { Runtime } = clientsManager.getClient();\n\n    const args: Protocol.Runtime.EvaluateRequest = {\n        expression: `({\n            x: window.screenLeft || window.screenX,\n            y: window.screenTop || window.screenY\n        })`,\n        returnByValue: true,\n    };\n\n    const { result } = await Runtime.evaluate(args);\n\n    return result.value;\n}\n"]}
|
|
127
|
+
// TODO: implement
|
|
128
|
+
async function offsetToClientCoords(point) {
|
|
129
|
+
return point;
|
|
130
|
+
}
|
|
131
|
+
exports.offsetToClientCoords = offsetToClientCoords;
|
|
132
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"position-utils.js","sourceRoot":"","sources":["../../../../../../../../src/browser/provider/built-in/dedicated/chrome/cdp-client/utils/position-utils.ts"],"names":[],"mappings":"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","sourcesContent":["import Protocol from 'devtools-protocol/types/protocol';\nimport ExecutionContext from '../execution-context';\nimport AxisValues, { AxisValuesData, LeftTopValues } from '../../../../../../../shared/utils/values/axis-values';\nimport BoundaryValues, { BoundaryValuesData } from '../../../../../../../shared/utils/values/boundary-values';\nimport { findIframeByWindow, getIframeByElement } from './dom-utils';\nimport * as clientsManager from '../clients-manager';\nimport { PositionDimensions, ServerNode } from '../types';\nimport { describeNode } from './';\n\nimport {\n    getBoxModel,\n    getDocumentScroll,\n    getElementPadding,\n    getElementDimensions,\n    getProperties,\n} from './style-utils';\n\nimport { ElementRectangle } from '../../../../../../../client/core/utils/shared/types';\n\n\nexport async function getClientPosition (node: ServerNode): Promise<AxisValues<number>> {\n    const boxModel = await getBoxModel(node);\n\n    return new AxisValues<number>(boxModel.border[0], boxModel.border[1]);\n}\n\nexport async function getOffsetPosition (node: ServerNode): Promise<LeftTopValues<number>> {\n    const dimensions    = await getClientDimensions(node);\n    const { left, top } = await getDocumentScroll(node);\n\n    return { left: dimensions.left + left, top: dimensions.top + top };\n}\n\nexport async function containsOffset (node: ServerNode, offsetX?: number, offsetY?: number): Promise<boolean> {\n    const dimensions = await getClientDimensions(node);\n    const properties = await getProperties(node, 'scrollWidth', 'scrollHeight');\n\n    const width  = Math.max(Number(properties.scrollWidth), dimensions.width);\n    const height = Math.max(Number(properties.scrollHeight), dimensions.height);\n    const maxX   = dimensions.scrollbar.right + dimensions.border.left + dimensions.border.right + width;\n    const maxY   = dimensions.scrollbar.bottom + dimensions.border.top + dimensions.border.bottom + height;\n\n    return (typeof offsetX === 'undefined' || offsetX >= 0 && maxX >= offsetX) &&\n        (typeof offsetY === 'undefined' || offsetY >= 0 && maxY >= offsetY);\n}\n\nexport async function getIframeClientCoordinates (node: ServerNode): Promise<BoundaryValuesData> {\n    const dimensions = await getClientDimensions(node);\n\n    const [ left, top, right, bottom ] = [\n        dimensions.left + dimensions.border.left + dimensions.paddings.left,\n        dimensions.top + dimensions.border.top + dimensions.paddings.left,\n        dimensions.right - dimensions.border.right - dimensions.paddings.right,\n        dimensions.bottom - dimensions.border.bottom - dimensions.paddings.bottom,\n    ];\n\n    return new BoundaryValues(top, right, bottom, left);\n}\n\nexport async function getIframePointRelativeToParentFrame (iframePoint: AxisValues<number>, context: ExecutionContext): Promise<AxisValues<number> | null> {\n    const iframe = await findIframeByWindow(context);\n\n    if (!iframe)\n        return null;\n\n    const dimensions = await getClientDimensions(iframe);\n    const paddings   = await getElementPadding(iframe);\n\n    const left = dimensions.left + dimensions.border.left + paddings.left + iframePoint.x;\n    const top  = dimensions.top + dimensions.border.top + paddings.top + iframePoint.y;\n\n    return new AxisValues<number>(left, top);\n}\n\nexport async function getElementFromPoint (point: AxisValuesData<number>): Promise<ServerNode | null> {\n    const { DOM } = clientsManager.getClient();\n\n    try {\n        const { backendNodeId } = await DOM.getNodeForLocation({ x: point.x, y: point.y });\n\n        const result = await DOM.resolveNode({ backendNodeId });\n\n        if (result?.object.objectId)\n            return describeNode(DOM, result.object.objectId.toString());\n    }\n    catch {\n        // NOTE: TODO: for some reason this methods throws error for correct `point` values\n        // always throws error for negative values\n    }\n\n    return null;\n}\n\nexport async function getElementRectangle (node: ServerNode): Promise<ElementRectangle> {\n    const dimensions = await getElementDimensions(node);\n\n    return {\n        height: dimensions.height,\n        left:   dimensions.left,\n        top:    dimensions.top,\n        width:  dimensions.width,\n    };\n}\n\nexport async function getClientDimensions (node: ServerNode): Promise<PositionDimensions> {\n    const elementDimensions = await getElementDimensions(node);\n    const parentFrame       = await getIframeByElement(node);\n\n    if (parentFrame) {\n        const frameBoxModel = await getBoxModel(parentFrame);\n\n        elementDimensions.left   -= frameBoxModel.content[0];\n        elementDimensions.top    -= frameBoxModel.content[1];\n        elementDimensions.bottom -= frameBoxModel.content[1];\n        elementDimensions.right  -= frameBoxModel.content[0];\n    }\n\n    return elementDimensions;\n}\n\nexport async function getWindowPosition (): Promise<AxisValues<number>> {\n    const { Runtime } = clientsManager.getClient();\n\n    const args: Protocol.Runtime.EvaluateRequest = {\n        expression: `({\n            x: window.screenLeft || window.screenX,\n            y: window.screenTop || window.screenY\n        })`,\n        returnByValue: true,\n    };\n\n    const { result } = await Runtime.evaluate(args);\n\n    return result.value;\n}\n\n// TODO: implement\nexport async function offsetToClientCoords (point: AxisValues<number>): Promise<AxisValues<number>> {\n    return point;\n}\n"]}
|
|
@@ -22,7 +22,7 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
|
22
22
|
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
23
23
|
};
|
|
24
24
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
25
|
-
exports.getDocumentScroll = exports.getWindowDimensions = exports.getElementScroll = exports.getElementPadding = exports.getBordersWidth = exports.
|
|
25
|
+
exports.getDocumentScroll = exports.getWindowDimensions = exports.hasScroll = exports.getElementScroll = exports.getElementPadding = exports.getBordersWidth = exports.getElementDimensions = exports.getBoxModel = exports.getScroll = exports.getProperties = exports.getStyleProperties = void 0;
|
|
26
26
|
const boundary_values_1 = __importDefault(require("../../../../../../../shared/utils/values/boundary-values"));
|
|
27
27
|
const dom_utils_1 = require("./dom-utils");
|
|
28
28
|
const clientsManager = __importStar(require("../clients-manager"));
|
|
@@ -108,19 +108,7 @@ async function getElementDimensions(node) {
|
|
|
108
108
|
width,
|
|
109
109
|
};
|
|
110
110
|
}
|
|
111
|
-
|
|
112
|
-
const elementDimensions = await getElementDimensions(node);
|
|
113
|
-
const parentFrame = await dom_utils_1.getIframeByElement(node);
|
|
114
|
-
if (parentFrame) {
|
|
115
|
-
const frameBoxModel = await getBoxModel(parentFrame);
|
|
116
|
-
elementDimensions.left -= frameBoxModel.content[0];
|
|
117
|
-
elementDimensions.top -= frameBoxModel.content[1];
|
|
118
|
-
elementDimensions.bottom -= frameBoxModel.content[1];
|
|
119
|
-
elementDimensions.right -= frameBoxModel.content[0];
|
|
120
|
-
}
|
|
121
|
-
return elementDimensions;
|
|
122
|
-
}
|
|
123
|
-
exports.getClientDimensions = getClientDimensions;
|
|
111
|
+
exports.getElementDimensions = getElementDimensions;
|
|
124
112
|
async function getBordersWidth(node) {
|
|
125
113
|
const dimensions = await getElementDimensions(node);
|
|
126
114
|
return dimensions.border;
|
|
@@ -134,6 +122,11 @@ async function getElementScroll(node) {
|
|
|
134
122
|
return getScroll(node);
|
|
135
123
|
}
|
|
136
124
|
exports.getElementScroll = getElementScroll;
|
|
125
|
+
async function hasScroll(node) {
|
|
126
|
+
const scroll = await getElementScroll(node);
|
|
127
|
+
return scroll.left > 0 || scroll.top > 0;
|
|
128
|
+
}
|
|
129
|
+
exports.hasScroll = hasScroll;
|
|
137
130
|
async function getWindowDimensions(executionContext) {
|
|
138
131
|
const { Runtime } = clientsManager.getClient();
|
|
139
132
|
const args = {
|
|
@@ -155,4 +148,4 @@ async function getDocumentScroll(node) {
|
|
|
155
148
|
return getElementScroll(document);
|
|
156
149
|
}
|
|
157
150
|
exports.getDocumentScroll = getDocumentScroll;
|
|
158
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"style-utils.js","sourceRoot":"","sources":["../../../../../../../../src/browser/provider/built-in/dedicated/chrome/cdp-client/utils/style-utils.ts"],"names":[],"mappings":"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","sourcesContent":["import { LeftTopValues } from '../../../../../../../shared/utils/values/axis-values';\nimport BoundaryValues, { BoundaryValuesData } from '../../../../../../../shared/utils/values/boundary-values';\nimport { Dictionary } from '../../../../../../../configuration/interfaces';\nimport Protocol from 'devtools-protocol/types/protocol';\nimport { getScrollingElement, getIframeByElement } from './dom-utils';\nimport ExecutionContext from '../execution-context';\nimport * as clientsManager from '../clients-manager';\nimport { ServerNode, PositionDimensions } from '../types';\n\nasync function getPadding (node: ServerNode): Promise<BoundaryValuesData> {\n    const client     = clientsManager.getClient();\n    const { nodeId } = await client.DOM.requestNode(node);\n    const style      = await getStyleProperties(nodeId, 'padding-right', 'padding-bottom', 'padding-left', 'padding-top');\n\n    const right  = parseInt(style['padding-right'], 10);\n    const bottom = parseInt(style['padding-bottom'], 10);\n    const left   = parseInt(style['padding-left'], 10);\n    const top    = parseInt(style['padding-top'], 10);\n\n    return new BoundaryValues(top, right, bottom, left);\n}\n\nexport async function getStyleProperties (nodeId: number, ...names: string[]): Promise<Dictionary<string>> {\n    const { CSS } = clientsManager.getClient();\n\n    const properties: Dictionary<string> = { };\n    const style                          = await CSS.getComputedStyleForNode({ nodeId });\n\n    style.computedStyle.filter(property => names.includes(property.name))\n        .forEach(property => {\n            properties[property.name] = property.value;\n        });\n\n    return properties;\n}\n\nexport async function getProperties (node: ServerNode, ...names: string[]): Promise<Dictionary<string>> {\n    const { Runtime } = clientsManager.getClient();\n\n    const properties: Dictionary<string> = { };\n    const { result }                     = await Runtime.getProperties(node);\n\n    result.filter(property => names.includes(property.name))\n        .forEach(property => {\n            properties[property.name] = property.value?.value;\n        });\n\n    return properties;\n}\n\nexport async function getScroll (node: ServerNode): Promise<LeftTopValues<number>> {\n    const { scrollLeft, scrollTop } = await getProperties(node, 'scrollLeft', 'scrollTop');\n\n    return { left: Number(scrollLeft), top: Number(scrollTop) };\n}\n\nexport async function getBoxModel (node: ServerNode): Promise<Protocol.DOM.BoxModel> {\n    const { DOM }  = clientsManager.getClient();\n    const boxModel = await DOM.getBoxModel({ objectId: node.objectId });\n\n    return boxModel.model;\n}\n\nasync function getElementDimensions (node: ServerNode): Promise<PositionDimensions> {\n    // NOTE: for some reason this method call is required for CSS.getComputedStyleForNode\n    // TODO: remove this line after the problem is clear\n    await clientsManager.getClient().DOM.getDocument({ });\n\n    const boxModel = await getBoxModel(node);\n    const scroll   = await getScroll(node);\n    const paddings = await getPadding(node);\n\n    const { width, height, border, padding, content } = boxModel;\n\n    const left   = Math.round(border[0]);\n    const top    = border[1];\n    const bottom = top + height;\n    const right  = left + width;\n\n    const borders = {\n        top:    padding[1] - border[1],\n        right:  border[4] - padding[4],\n        bottom: border[5] - padding[5],\n        left:   padding[0] - border[0],\n    };\n\n    const scrollbar = {\n        right:  Math.round(padding[2] - content[2] - paddings.right),\n        bottom: Math.round(padding[7] - content[7] - paddings.bottom),\n    };\n\n    return {\n        border: borders,\n        bottom,\n        height,\n        left,\n        right,\n        scroll: {\n            left: Math.round(Number(scroll.left)),\n            top:  Math.round(Number(scroll.top)),\n        },\n        scrollbar,\n        paddings,\n        top,\n        width,\n    };\n}\n\nexport async function getClientDimensions (node: ServerNode): Promise<PositionDimensions> {\n    const elementDimensions = await getElementDimensions(node);\n    const parentFrame       = await getIframeByElement(node);\n\n    if (parentFrame) {\n        const frameBoxModel = await getBoxModel(parentFrame);\n\n        elementDimensions.left   -= frameBoxModel.content[0];\n        elementDimensions.top    -= frameBoxModel.content[1];\n        elementDimensions.bottom -= frameBoxModel.content[1];\n        elementDimensions.right  -= frameBoxModel.content[0];\n    }\n\n    return elementDimensions;\n}\n\nexport async function getBordersWidth (node: ServerNode): Promise<BoundaryValuesData> {\n    const dimensions = await getElementDimensions(node);\n\n    return dimensions.border;\n}\n\nexport async function getElementPadding (node: ServerNode): Promise<BoundaryValuesData> {\n    return getPadding(node);\n}\n\nexport async function getElementScroll (node: ServerNode): Promise<LeftTopValues<number>> {\n    return getScroll(node);\n}\n\nexport async function getWindowDimensions (executionContext?: ExecutionContext): Promise<BoundaryValues> {\n    const { Runtime } = clientsManager.getClient();\n\n    const args: Protocol.Runtime.EvaluateRequest = {\n        expression: `({\n            width: document.documentElement.clientWidth,\n            height: document.documentElement.clientHeight\n        })`,\n        returnByValue: true,\n    };\n\n    if (executionContext)\n        args.contextId = executionContext.ctxId;\n\n    const { result }        = await Runtime.evaluate(args);\n    const { width, height } = result.value;\n\n    return new BoundaryValues(0, width, height, 0);\n}\n\nexport async function getDocumentScroll (node: ServerNode): Promise<LeftTopValues<number>> {\n    const document = await getScrollingElement(node);\n\n    return getElementScroll(document);\n}\n"]}
|
|
151
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"style-utils.js","sourceRoot":"","sources":["../../../../../../../../src/browser/provider/built-in/dedicated/chrome/cdp-client/utils/style-utils.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;AACA,+GAA8G;AAG9G,2CAAkD;AAElD,mEAAqD;AAGrD,KAAK,UAAU,UAAU,CAAE,IAAgB;IACvC,MAAM,MAAM,GAAO,cAAc,CAAC,SAAS,EAAE,CAAC;IAC9C,MAAM,EAAE,MAAM,EAAE,GAAG,MAAM,MAAM,CAAC,GAAG,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC;IACtD,MAAM,KAAK,GAAQ,MAAM,kBAAkB,CAAC,MAAM,EAAE,eAAe,EAAE,gBAAgB,EAAE,cAAc,EAAE,aAAa,CAAC,CAAC;IAEtH,MAAM,KAAK,GAAI,QAAQ,CAAC,KAAK,CAAC,eAAe,CAAC,EAAE,EAAE,CAAC,CAAC;IACpD,MAAM,MAAM,GAAG,QAAQ,CAAC,KAAK,CAAC,gBAAgB,CAAC,EAAE,EAAE,CAAC,CAAC;IACrD,MAAM,IAAI,GAAK,QAAQ,CAAC,KAAK,CAAC,cAAc,CAAC,EAAE,EAAE,CAAC,CAAC;IACnD,MAAM,GAAG,GAAM,QAAQ,CAAC,KAAK,CAAC,aAAa,CAAC,EAAE,EAAE,CAAC,CAAC;IAElD,OAAO,IAAI,yBAAc,CAAC,GAAG,EAAE,KAAK,EAAE,MAAM,EAAE,IAAI,CAAC,CAAC;AACxD,CAAC;AAEM,KAAK,UAAU,kBAAkB,CAAE,MAAc,EAAE,GAAG,KAAe;IACxE,MAAM,EAAE,GAAG,EAAE,GAAG,cAAc,CAAC,SAAS,EAAE,CAAC;IAE3C,MAAM,UAAU,GAAuB,EAAG,CAAC;IAC3C,MAAM,KAAK,GAA4B,MAAM,GAAG,CAAC,uBAAuB,CAAC,EAAE,MAAM,EAAE,CAAC,CAAC;IAErF,KAAK,CAAC,aAAa,CAAC,MAAM,CAAC,QAAQ,CAAC,EAAE,CAAC,KAAK,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC;SAChE,OAAO,CAAC,QAAQ,CAAC,EAAE;QAChB,UAAU,CAAC,QAAQ,CAAC,IAAI,CAAC,GAAG,QAAQ,CAAC,KAAK,CAAC;IAC/C,CAAC,CAAC,CAAC;IAEP,OAAO,UAAU,CAAC;AACtB,CAAC;AAZD,gDAYC;AAEM,KAAK,UAAU,aAAa,CAAE,IAAgB,EAAE,GAAG,KAAe;IACrE,MAAM,EAAE,OAAO,EAAE,GAAG,cAAc,CAAC,SAAS,EAAE,CAAC;IAE/C,MAAM,UAAU,GAAuB,EAAG,CAAC;IAC3C,MAAM,EAAE,MAAM,EAAE,GAAuB,MAAM,OAAO,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC;IAEzE,MAAM,CAAC,MAAM,CAAC,QAAQ,CAAC,EAAE,CAAC,KAAK,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC;SACnD,OAAO,CAAC,QAAQ,CAAC,EAAE;;QAChB,UAAU,CAAC,QAAQ,CAAC,IAAI,CAAC,SAAG,QAAQ,CAAC,KAAK,0CAAE,KAAK,CAAC;IACtD,CAAC,CAAC,CAAC;IAEP,OAAO,UAAU,CAAC;AACtB,CAAC;AAZD,sCAYC;AAEM,KAAK,UAAU,SAAS,CAAE,IAAgB;IAC7C,MAAM,EAAE,UAAU,EAAE,SAAS,EAAE,GAAG,MAAM,aAAa,CAAC,IAAI,EAAE,YAAY,EAAE,WAAW,CAAC,CAAC;IAEvF,OAAO,EAAE,IAAI,EAAE,MAAM,CAAC,UAAU,CAAC,EAAE,GAAG,EAAE,MAAM,CAAC,SAAS,CAAC,EAAE,CAAC;AAChE,CAAC;AAJD,8BAIC;AAEM,KAAK,UAAU,WAAW,CAAE,IAAgB;IAC/C,MAAM,EAAE,GAAG,EAAE,GAAI,cAAc,CAAC,SAAS,EAAE,CAAC;IAC5C,MAAM,QAAQ,GAAG,MAAM,GAAG,CAAC,WAAW,CAAC,EAAE,QAAQ,EAAE,IAAI,CAAC,QAAQ,EAAE,CAAC,CAAC;IAEpE,OAAO,QAAQ,CAAC,KAAK,CAAC;AAC1B,CAAC;AALD,kCAKC;AAEM,KAAK,UAAU,oBAAoB,CAAE,IAAgB;IACxD,qFAAqF;IACrF,oDAAoD;IACpD,MAAM,cAAc,CAAC,SAAS,EAAE,CAAC,GAAG,CAAC,WAAW,CAAC,EAAG,CAAC,CAAC;IAEtD,MAAM,QAAQ,GAAG,MAAM,WAAW,CAAC,IAAI,CAAC,CAAC;IACzC,MAAM,MAAM,GAAK,MAAM,SAAS,CAAC,IAAI,CAAC,CAAC;IACvC,MAAM,QAAQ,GAAG,MAAM,UAAU,CAAC,IAAI,CAAC,CAAC;IAExC,MAAM,EAAE,KAAK,EAAE,MAAM,EAAE,MAAM,EAAE,OAAO,EAAE,OAAO,EAAE,GAAG,QAAQ,CAAC;IAE7D,MAAM,IAAI,GAAK,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC;IACrC,MAAM,GAAG,GAAM,MAAM,CAAC,CAAC,CAAC,CAAC;IACzB,MAAM,MAAM,GAAG,GAAG,GAAG,MAAM,CAAC;IAC5B,MAAM,KAAK,GAAI,IAAI,GAAG,KAAK,CAAC;IAE5B,MAAM,OAAO,GAAG;QACZ,GAAG,EAAK,OAAO,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC;QAC9B,KAAK,EAAG,MAAM,CAAC,CAAC,CAAC,GAAG,OAAO,CAAC,CAAC,CAAC;QAC9B,MAAM,EAAE,MAAM,CAAC,CAAC,CAAC,GAAG,OAAO,CAAC,CAAC,CAAC;QAC9B,IAAI,EAAI,OAAO,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC;KACjC,CAAC;IAEF,MAAM,SAAS,GAAG;QACd,KAAK,EAAG,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,GAAG,OAAO,CAAC,CAAC,CAAC,GAAG,QAAQ,CAAC,KAAK,CAAC;QAC5D,MAAM,EAAE,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,GAAG,OAAO,CAAC,CAAC,CAAC,GAAG,QAAQ,CAAC,MAAM,CAAC;KAChE,CAAC;IAEF,OAAO;QACH,MAAM,EAAE,OAAO;QACf,MAAM;QACN,MAAM;QACN,IAAI;QACJ,KAAK;QACL,MAAM,EAAE;YACJ,IAAI,EAAE,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC;YACrC,GAAG,EAAG,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC;SACvC;QACD,SAAS;QACT,QAAQ;QACR,GAAG;QACH,KAAK;KACR,CAAC;AACN,CAAC;AA3CD,oDA2CC;AAEM,KAAK,UAAU,eAAe,CAAE,IAAgB;IACnD,MAAM,UAAU,GAAG,MAAM,oBAAoB,CAAC,IAAI,CAAC,CAAC;IAEpD,OAAO,UAAU,CAAC,MAAM,CAAC;AAC7B,CAAC;AAJD,0CAIC;AAEM,KAAK,UAAU,iBAAiB,CAAE,IAAgB;IACrD,OAAO,UAAU,CAAC,IAAI,CAAC,CAAC;AAC5B,CAAC;AAFD,8CAEC;AAEM,KAAK,UAAU,gBAAgB,CAAE,IAAgB;IACpD,OAAO,SAAS,CAAC,IAAI,CAAC,CAAC;AAC3B,CAAC;AAFD,4CAEC;AAEM,KAAK,UAAU,SAAS,CAAE,IAAgB;IAC7C,MAAM,MAAM,GAAG,MAAM,gBAAgB,CAAC,IAAI,CAAC,CAAC;IAE5C,OAAO,MAAM,CAAC,IAAI,GAAG,CAAC,IAAI,MAAM,CAAC,GAAG,GAAG,CAAC,CAAC;AAC7C,CAAC;AAJD,8BAIC;AAEM,KAAK,UAAU,mBAAmB,CAAE,gBAAmC;IAC1E,MAAM,EAAE,OAAO,EAAE,GAAG,cAAc,CAAC,SAAS,EAAE,CAAC;IAE/C,MAAM,IAAI,GAAqC;QAC3C,UAAU,EAAE;;;WAGT;QACH,aAAa,EAAE,IAAI;KACtB,CAAC;IAEF,IAAI,gBAAgB;QAChB,IAAI,CAAC,SAAS,GAAG,gBAAgB,CAAC,KAAK,CAAC;IAE5C,MAAM,EAAE,MAAM,EAAE,GAAU,MAAM,OAAO,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC;IACvD,MAAM,EAAE,KAAK,EAAE,MAAM,EAAE,GAAG,MAAM,CAAC,KAAK,CAAC;IAEvC,OAAO,IAAI,yBAAc,CAAC,CAAC,EAAE,KAAK,EAAE,MAAM,EAAE,CAAC,CAAC,CAAC;AACnD,CAAC;AAlBD,kDAkBC;AAEM,KAAK,UAAU,iBAAiB,CAAE,IAAgB;IACrD,MAAM,QAAQ,GAAG,MAAM,+BAAmB,CAAC,IAAI,CAAC,CAAC;IAEjD,OAAO,gBAAgB,CAAC,QAAQ,CAAC,CAAC;AACtC,CAAC;AAJD,8CAIC","sourcesContent":["import { LeftTopValues } from '../../../../../../../shared/utils/values/axis-values';\nimport BoundaryValues, { BoundaryValuesData } from '../../../../../../../shared/utils/values/boundary-values';\nimport { Dictionary } from '../../../../../../../configuration/interfaces';\nimport Protocol from 'devtools-protocol/types/protocol';\nimport { getScrollingElement } from './dom-utils';\nimport ExecutionContext from '../execution-context';\nimport * as clientsManager from '../clients-manager';\nimport { ServerNode, PositionDimensions } from '../types';\n\nasync function getPadding (node: ServerNode): Promise<BoundaryValuesData> {\n    const client     = clientsManager.getClient();\n    const { nodeId } = await client.DOM.requestNode(node);\n    const style      = await getStyleProperties(nodeId, 'padding-right', 'padding-bottom', 'padding-left', 'padding-top');\n\n    const right  = parseInt(style['padding-right'], 10);\n    const bottom = parseInt(style['padding-bottom'], 10);\n    const left   = parseInt(style['padding-left'], 10);\n    const top    = parseInt(style['padding-top'], 10);\n\n    return new BoundaryValues(top, right, bottom, left);\n}\n\nexport async function getStyleProperties (nodeId: number, ...names: string[]): Promise<Dictionary<string>> {\n    const { CSS } = clientsManager.getClient();\n\n    const properties: Dictionary<string> = { };\n    const style                          = await CSS.getComputedStyleForNode({ nodeId });\n\n    style.computedStyle.filter(property => names.includes(property.name))\n        .forEach(property => {\n            properties[property.name] = property.value;\n        });\n\n    return properties;\n}\n\nexport async function getProperties (node: ServerNode, ...names: string[]): Promise<Dictionary<string>> {\n    const { Runtime } = clientsManager.getClient();\n\n    const properties: Dictionary<string> = { };\n    const { result }                     = await Runtime.getProperties(node);\n\n    result.filter(property => names.includes(property.name))\n        .forEach(property => {\n            properties[property.name] = property.value?.value;\n        });\n\n    return properties;\n}\n\nexport async function getScroll (node: ServerNode): Promise<LeftTopValues<number>> {\n    const { scrollLeft, scrollTop } = await getProperties(node, 'scrollLeft', 'scrollTop');\n\n    return { left: Number(scrollLeft), top: Number(scrollTop) };\n}\n\nexport async function getBoxModel (node: ServerNode): Promise<Protocol.DOM.BoxModel> {\n    const { DOM }  = clientsManager.getClient();\n    const boxModel = await DOM.getBoxModel({ objectId: node.objectId });\n\n    return boxModel.model;\n}\n\nexport async function getElementDimensions (node: ServerNode): Promise<PositionDimensions> {\n    // NOTE: for some reason this method call is required for CSS.getComputedStyleForNode\n    // TODO: remove this line after the problem is clear\n    await clientsManager.getClient().DOM.getDocument({ });\n\n    const boxModel = await getBoxModel(node);\n    const scroll   = await getScroll(node);\n    const paddings = await getPadding(node);\n\n    const { width, height, border, padding, content } = boxModel;\n\n    const left   = Math.round(border[0]);\n    const top    = border[1];\n    const bottom = top + height;\n    const right  = left + width;\n\n    const borders = {\n        top:    padding[1] - border[1],\n        right:  border[4] - padding[4],\n        bottom: border[5] - padding[5],\n        left:   padding[0] - border[0],\n    };\n\n    const scrollbar = {\n        right:  Math.round(padding[2] - content[2] - paddings.right),\n        bottom: Math.round(padding[7] - content[7] - paddings.bottom),\n    };\n\n    return {\n        border: borders,\n        bottom,\n        height,\n        left,\n        right,\n        scroll: {\n            left: Math.round(Number(scroll.left)),\n            top:  Math.round(Number(scroll.top)),\n        },\n        scrollbar,\n        paddings,\n        top,\n        width,\n    };\n}\n\nexport async function getBordersWidth (node: ServerNode): Promise<BoundaryValuesData> {\n    const dimensions = await getElementDimensions(node);\n\n    return dimensions.border;\n}\n\nexport async function getElementPadding (node: ServerNode): Promise<BoundaryValuesData> {\n    return getPadding(node);\n}\n\nexport async function getElementScroll (node: ServerNode): Promise<LeftTopValues<number>> {\n    return getScroll(node);\n}\n\nexport async function hasScroll (node: ServerNode): Promise<boolean> {\n    const scroll = await getElementScroll(node);\n\n    return scroll.left > 0 || scroll.top > 0;\n}\n\nexport async function getWindowDimensions (executionContext?: ExecutionContext): Promise<BoundaryValues> {\n    const { Runtime } = clientsManager.getClient();\n\n    const args: Protocol.Runtime.EvaluateRequest = {\n        expression: `({\n            width: document.documentElement.clientWidth,\n            height: document.documentElement.clientHeight\n        })`,\n        returnByValue: true,\n    };\n\n    if (executionContext)\n        args.contextId = executionContext.ctxId;\n\n    const { result }        = await Runtime.evaluate(args);\n    const { width, height } = result.value;\n\n    return new BoundaryValues(0, width, height, 0);\n}\n\nexport async function getDocumentScroll (node: ServerNode): Promise<LeftTopValues<number>> {\n    const document = await getScrollingElement(node);\n\n    return getElementScroll(document);\n}\n"]}
|