@applitools/driver 1.5.5 → 1.6.0

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/dist/driver.js CHANGED
@@ -122,10 +122,12 @@ class Driver {
122
122
  return (_b = (_a = this._driverInfo) === null || _a === void 0 ? void 0 : _a.isMobile) !== null && _b !== void 0 ? _b : false;
123
123
  }
124
124
  get isIOS() {
125
- return this.platformName === 'iOS';
125
+ var _a;
126
+ return ((_a = this.platformName) === null || _a === void 0 ? void 0 : _a.toLowerCase()) === 'ios';
126
127
  }
127
128
  get isAndroid() {
128
- return this.platformName === 'Android';
129
+ var _a;
130
+ return ((_a = this.platformName) === null || _a === void 0 ? void 0 : _a.toLowerCase()) === 'android';
129
131
  }
130
132
  get isIE() {
131
133
  return /(internet explorer|ie)/i.test(this.browserName);
@@ -376,11 +378,13 @@ class Driver {
376
378
  }
377
379
  return this.currentContext;
378
380
  }
379
- async normalizeRegion(region) {
381
+ async normalizeRegion(region, shouldIgnoreSafeRegion) {
380
382
  if (this.isWeb || !utils.types.has(this._driverInfo, ['viewportSize', 'statusBarHeight']))
381
383
  return region;
382
384
  const scaledRegion = this.isAndroid ? utils.geometry.scale(region, 1 / this.pixelRatio) : region;
383
- const safeRegion = this.isIOS ? utils.geometry.intersect(scaledRegion, this._driverInfo.safeArea) : scaledRegion;
385
+ const safeRegion = this.isIOS && !shouldIgnoreSafeRegion
386
+ ? utils.geometry.intersect(scaledRegion, this._driverInfo.safeArea)
387
+ : scaledRegion;
384
388
  const offsetRegion = utils.geometry.offsetNegative(safeRegion, { x: 0, y: this.statusBarHeight });
385
389
  if (offsetRegion.y < 0) {
386
390
  offsetRegion.height += offsetRegion.y;
package/dist/element.js CHANGED
@@ -106,7 +106,7 @@ class Element {
106
106
  return this;
107
107
  }
108
108
  }
109
- async getRegion() {
109
+ async getRegion(shouldIgnoreSafeRegion) {
110
110
  const region = await this.withRefresh(async () => {
111
111
  if (this.driver.isWeb) {
112
112
  this._logger.log('Extracting region of web element with selector', this.selector);
@@ -116,7 +116,7 @@ class Element {
116
116
  this._logger.log('Extracting region of native element with selector', this.selector);
117
117
  const region = await this._spec.getElementRegion(this.driver.target, this.target);
118
118
  this._logger.log('Extracted native region', region);
119
- return this.driver.normalizeRegion(region);
119
+ return this.driver.normalizeRegion(region, shouldIgnoreSafeRegion);
120
120
  }
121
121
  });
122
122
  this._logger.log('Extracted region', region);
package/dist/index.js CHANGED
@@ -6,10 +6,24 @@ var __createBinding = (this && this.__createBinding) || (Object.create ? (functi
6
6
  if (k2 === undefined) k2 = k;
7
7
  o[k2] = m[k];
8
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
+ });
9
14
  var __exportStar = (this && this.__exportStar) || function(m, exports) {
10
15
  for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
11
16
  };
17
+ var __importStar = (this && this.__importStar) || function (mod) {
18
+ if (mod && mod.__esModule) return mod;
19
+ var result = {};
20
+ if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
21
+ __setModuleDefault(result, mod);
22
+ return result;
23
+ };
12
24
  Object.defineProperty(exports, "__esModule", { value: true });
25
+ exports.specUtils = void 0;
13
26
  __exportStar(require("./driver"), exports);
14
27
  __exportStar(require("./context"), exports);
15
28
  __exportStar(require("./element"), exports);
29
+ exports.specUtils = __importStar(require("./spec-utils"));
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@applitools/driver",
3
- "version": "1.5.5",
3
+ "version": "1.6.0",
4
4
  "description": "Applitools universal framework wrapper",
5
5
  "keywords": [
6
6
  "applitools",
@@ -74,11 +74,11 @@
74
74
  },
75
75
  "dependencies": {
76
76
  "@applitools/snippets": "2.2.2",
77
- "@applitools/types": "1.2.2",
77
+ "@applitools/types": "1.3.0",
78
78
  "@applitools/utils": "1.2.13"
79
79
  },
80
80
  "devDependencies": {
81
- "@applitools/sdk-release-kit": "1.0.4",
81
+ "@applitools/bongo": "^2.0.0",
82
82
  "@types/mocha": "^9.0.0",
83
83
  "@types/node": "^16.3.3",
84
84
  "@typescript-eslint/eslint-plugin": "^4.28.3",
package/types/driver.d.ts CHANGED
@@ -50,7 +50,7 @@ export declare class Driver<TDriver, TContext, TElement, TSelector> {
50
50
  switchToMainContext(): Promise<Context<TDriver, TContext, TElement, TSelector>>;
51
51
  switchToParentContext(elevation?: number): Promise<Context<TDriver, TContext, TElement, TSelector>>;
52
52
  switchToChildContext(...references: ContextReference<TDriver, TContext, TElement, TSelector>[]): Promise<Context<TDriver, TContext, TElement, TSelector>>;
53
- normalizeRegion(region: types.Region): Promise<types.Region>;
53
+ normalizeRegion(region: types.Region, shouldIgnoreSafeRegion?: boolean): Promise<types.Region>;
54
54
  getRegionInViewport(context: Context<TDriver, TContext, TElement, TSelector>, region: types.Region): Promise<types.Region>;
55
55
  element(selector: types.Selector<TSelector>): Promise<Element<TDriver, TContext, TElement, TSelector>>;
56
56
  elements(selector: types.Selector<TSelector>): Promise<Element<TDriver, TContext, TElement, TSelector>[]>;
@@ -31,7 +31,7 @@ export declare class Element<TDriver, TContext, TElement, TSelector> {
31
31
  get isRef(): boolean;
32
32
  equals(element: Element<TDriver, TContext, TElement, TSelector> | TElement): Promise<boolean>;
33
33
  init(context: Context<TDriver, TContext, TElement, TSelector>): Promise<this>;
34
- getRegion(): Promise<types.Region>;
34
+ getRegion(shouldIgnoreSafeRegion?: boolean): Promise<types.Region>;
35
35
  getClientRegion(): Promise<types.Region>;
36
36
  getContentSize(): Promise<types.Size>;
37
37
  isScrollable(): Promise<boolean>;
package/types/index.d.ts CHANGED
@@ -1,3 +1,4 @@
1
1
  export * from './driver';
2
2
  export * from './context';
3
3
  export * from './element';
4
+ export * as specUtils from './spec-utils';