appium-uiautomator2-driver 1.73.0 → 2.0.1

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.
@@ -9,16 +9,16 @@ exports.default = void 0;
9
9
 
10
10
  require("source-map-support/register");
11
11
 
12
- var _appiumSupport = require("appium-support");
12
+ var _support = require("@appium/support");
13
13
 
14
14
  var _lodash = _interopRequireDefault(require("lodash"));
15
15
 
16
- var _appiumBaseDriver = require("appium-base-driver");
16
+ var _baseDriver = require("@appium/base-driver");
17
17
 
18
18
  const commands = {};
19
19
 
20
20
  function toOrigin(element) {
21
- return element ? _appiumSupport.util.wrapElement(_appiumSupport.util.unwrapElement(element)) : undefined;
21
+ return element ? _support.util.wrapElement(_support.util.unwrapElement(element)) : undefined;
22
22
  }
23
23
 
24
24
  function toPoint(x, y) {
@@ -193,10 +193,10 @@ commands.mobileScrollBackTo = async function (opts = {}) {
193
193
  } = opts;
194
194
 
195
195
  if (!elementId || !elementToId) {
196
- throw new _appiumBaseDriver.errors.InvalidArgumentError(`Both elementId and elementToId arguments must be provided`);
196
+ throw new _baseDriver.errors.InvalidArgumentError(`Both elementId and elementToId arguments must be provided`);
197
197
  }
198
198
 
199
- return await this.uiautomator2.jwproxy.command(`/appium/element/${_appiumSupport.util.unwrapElement(elementId)}/scroll_to/${_appiumSupport.util.unwrapElement(elementToId)}`, 'POST', {});
199
+ return await this.uiautomator2.jwproxy.command(`/appium/element/${_support.util.unwrapElement(elementId)}/scroll_to/${_support.util.unwrapElement(elementToId)}`, 'POST', {});
200
200
  };
201
201
 
202
202
  commands.mobileScroll = async function (opts = {}) {
@@ -209,7 +209,7 @@ commands.mobileScroll = async function (opts = {}) {
209
209
  } = opts;
210
210
 
211
211
  if (!strategy || !selector) {
212
- throw new _appiumBaseDriver.errors.InvalidArgumentError(`Both strategy and selector arguments must be provided`);
212
+ throw new _baseDriver.errors.InvalidArgumentError(`Both strategy and selector arguments must be provided`);
213
213
  }
214
214
 
215
215
  return await this.uiautomator2.jwproxy.command('/touch/scroll', 'POST', {
@@ -226,4 +226,4 @@ var _default = commands;
226
226
  exports.default = _default;require('source-map-support').install();
227
227
 
228
228
 
229
- //# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["lib/commands/gestures.js"],"names":["commands","toOrigin","element","util","wrapElement","unwrapElement","undefined","toPoint","x","y","_","isFinite","toRect","left","top","width","height","some","v","mobileClickGesture","opts","elementId","uiautomator2","jwproxy","command","origin","offset","mobileLongClickGesture","duration","mobileDoubleClickGesture","mobileDragGesture","startX","startY","endX","endY","speed","start","end","mobileFlingGesture","direction","area","mobilePinchCloseGesture","percent","mobilePinchOpenGesture","mobileSwipeGesture","mobileScrollGesture","mobileScrollBackTo","elementToId","errors","InvalidArgumentError","mobileScroll","strategy","selector","maxSwipes","params"],"mappings":"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","sourcesContent":["import { util } from 'appium-support';\nimport _ from 'lodash';\nimport { errors } from 'appium-base-driver';\n\nconst commands = {};\n\n\nfunction toOrigin (element) {\n  return element ? util.wrapElement(util.unwrapElement(element)) : undefined;\n}\n\nfunction toPoint (x, y) {\n  return _.isFinite(x) && _.isFinite(y) ? {x, y} : undefined;\n}\n\nfunction toRect (left, top, width, height) {\n  return [left, top, width, height].some((v) => !_.isFinite(v))\n    ? undefined\n    : {left, top, width, height};\n}\n\n/**\n * @typedef {Object} ClickOptions\n * @property {?string} elementId - The id of the element to be clicked.\n * If the element is missing then both click offset coordinates must be provided.\n * If both the element id and offset are provided then the coordinates\n * are parsed as relative offsets from the top left corner of the element.\n * @property {?number} x - The x coordinate to click on\n * @property {?number} y - The y coordinate to click on\n */\n\n/**\n * Performs a simple click/tap gesture\n *\n * @param {?ClickOptions} opts\n * @throws {Error} if provided options are not valid\n */\ncommands.mobileClickGesture = async function mobileClickGesture (opts = {}) {\n  const {\n    elementId,\n    x, y,\n  } = opts;\n  return await this.uiautomator2.jwproxy.command('/appium/gestures/click', 'POST', {\n    origin: toOrigin(elementId),\n    offset: toPoint(x, y),\n  });\n};\n\n/**\n * @typedef {Object} LongClickOptions\n * @property {?string} elementId - The id of the element to be clicked.\n * If the element is missing then both click offset coordinates must be provided.\n * If both the element id and offset are provided then the coordinates\n * are parsed as relative offsets from the top left corner of the element.\n * @property {?number} x - The x coordinate to click on\n * @property {?number} y - The y coordinate to click on\n * @property {?number} duration [500] - Click duration in milliseconds.\n * The value must not be negative\n */\n\n/**\n * Performs a click that lasts for the given duration\n *\n * @param {?LongClickOptions} opts\n * @throws {Error} if provided options are not valid\n */\ncommands.mobileLongClickGesture = async function mobileLongClickGesture (opts = {}) {\n  const {\n    elementId,\n    x, y,\n    duration,\n  } = opts;\n  return await this.uiautomator2.jwproxy.command('/appium/gestures/long_click', 'POST', {\n    origin: toOrigin(elementId),\n    offset: toPoint(x, y),\n    duration,\n  });\n};\n\n/**\n * @typedef {Object} DoubleClickOptions\n * @property {?string} elementId - The id of the element to be double clicked.\n * If the element is missing then both click offset coordinates must be provided.\n * If both the element id and offset are provided then the coordinates\n * are parsed as relative offsets from the top left corner of the element.\n * @property {?number} x - The x coordinate to double click on\n * @property {?number} y - The y coordinate to double click on\n */\n\n/**\n * Performs a click that lasts for the given duration\n *\n * @param {?DoubleClickOptions} opts\n * @throws {Error} if provided options are not valid\n */\ncommands.mobileDoubleClickGesture = async function mobileDoubleClickGesture (opts = {}) {\n  const {\n    elementId,\n    x, y,\n  } = opts;\n  return await this.uiautomator2.jwproxy.command('/appium/gestures/double_click', 'POST', {\n    origin: toOrigin(elementId),\n    offset: toPoint(x, y),\n  });\n};\n\n/**\n * @typedef {Object} DragOptions\n * @property {?string} elementId - The id of the element to be dragged.\n * If the element id is missing then the start coordinates must be provided.\n * If both the element id and the start coordinates are provided then these\n * coordinates are considered as offsets from the top left element corner.\n * @property {?number} startX - The x coordinate where the dragging starts\n * @property {?number} startY - The y coordinate where the dragging starts\n * @property {!number} endX - The x coordinate where the dragging ends\n * @property {!number} endY - The y coordinate where the dragging ends\n * @property {?number} speed [2500 * displayDensity] - The speed at which to perform\n * this gesture in pixels per second. The value must not be negative\n */\n\n/**\n * Drags this object to the specified location.\n *\n * @param {?DragOptions} opts\n * @throws {Error} if provided options are not valid\n */\ncommands.mobileDragGesture = async function mobileDragGesture (opts = {}) {\n  const {\n    elementId,\n    startX, startY,\n    endX, endY,\n    speed,\n  } = opts;\n  return await this.uiautomator2.jwproxy.command('/appium/gestures/drag', 'POST', {\n    origin: toOrigin(elementId),\n    start: toPoint(startX, startY),\n    end: toPoint(endX, endY),\n    speed,\n  });\n};\n\n/**\n * @typedef {Object} FlingOptions\n * @property {?string} elementId - The id of the element to be flinged.\n * If the element id is missing then fling bounding area must be provided.\n * If both the element id and the fling bounding area are provided then this\n * area is effectively ignored.\n * @property {?number} left - The left coordinate of the fling bounding area\n * @property {?number} top - The top coordinate of the fling bounding area\n * @property {?number} width - The width of the fling bounding area\n * @property {?number} height - The height of the fling bounding area\n * @property {!string} direction - Direction of the fling.\n * Acceptable values are: `up`, `down`, `left` and `right` (case insensitive)\n * @property {?number} speed [7500 * displayDensity] - The speed at which to perform this\n * gesture in pixels per second. The value must be greater than the minimum fling\n * velocity for the given view (50 by default)\n */\n\n/**\n * Drags to the specified location.\n *\n * @param {?FlingOptions} opts\n * @throws {Error} if provided options are not valid\n * @returns {boolean} True if the object can still scroll in the given direction.\n */\ncommands.mobileFlingGesture = async function mobileFlingGesture (opts = {}) {\n  const {\n    elementId,\n    left, top, width, height,\n    direction,\n    speed,\n  } = opts;\n  return await this.uiautomator2.jwproxy.command('/appium/gestures/fling', 'POST', {\n    origin: toOrigin(elementId),\n    area: toRect(left, top, width, height),\n    direction,\n    speed,\n  });\n};\n\n/**\n * @typedef {Object} PinchOptions\n * @property {?string} elementId - The id of the element to be pinched.\n * If the element id is missing then pinch bounding area must be provided.\n * If both the element id and the pinch bounding area are provided then the\n * area is effectively ignored.\n * @property {?number} left - The left coordinate of the pinch bounding area\n * @property {?number} top - The top coordinate of the pinch bounding area\n * @property {?number} width - The width of the pinch bounding area\n * @property {?number} height - The height of the pinch bounding area\n * @property {!number} percent - The size of the pinch as a percentage of the pinch area size.\n * Valid values must be float numbers in range 0..1, where 1.0 is 100%\n * @property {?number} speed [2500 * displayDensity] - The speed at which to perform\n * this gesture in pixels per second. The value must not be negative\n */\n\n/**\n * Performs a pinch close gesture.\n *\n * @param {?PinchOptions} opts\n * @throws {Error} if provided options are not valid\n */\ncommands.mobilePinchCloseGesture = async function mobilePinchCloseGesture (opts = {}) {\n  const {\n    elementId,\n    left, top, width, height,\n    percent,\n    speed,\n  } = opts;\n  return await this.uiautomator2.jwproxy.command('/appium/gestures/pinch_close', 'POST', {\n    origin: toOrigin(elementId),\n    area: toRect(left, top, width, height),\n    percent,\n    speed,\n  });\n};\n\n/**\n * Performs a pinch open gesture.\n *\n * @param {?PinchOptions} opts\n * @throws {Error} if provided options are not valid\n */\ncommands.mobilePinchOpenGesture = async function mobilePinchOpenGesture (opts = {}) {\n  const {\n    elementId,\n    left, top, width, height,\n    percent,\n    speed,\n  } = opts;\n  return await this.uiautomator2.jwproxy.command('/appium/gestures/pinch_open', 'POST', {\n    origin: toOrigin(elementId),\n    area: toRect(left, top, width, height),\n    percent,\n    speed,\n  });\n};\n\n/**\n * @typedef {Object} SwipeOptions\n * @property {?string} elementId - The id of the element to be swiped.\n * If the element id is missing then swipe bounding area must be provided.\n * If both the element id and the swipe bounding area are provided then the\n * area is effectively ignored.\n * @property {?number} left - The left coordinate of the swipe bounding area\n * @property {?number} top - The top coordinate of the swipe bounding area\n * @property {?number} width - The width of the swipe bounding area\n * @property {?number} height - The height of the swipe bounding area\n * @property {!string} direction - Direction of the swipe.\n * Acceptable values are: `up`, `down`, `left` and `right` (case insensitive)\n * @property {!number} percent - The size of the swipe as a percentage of the swipe area size.\n * Valid values must be float numbers in range 0..1, where 1.0 is 100%\n * @property {?number} speed [5000 * displayDensity] - The speed at which to perform this\n * gesture in pixels per second. The value must not be negative\n */\n\n/**\n * Performs a swipe gesture.\n *\n * @param {?SwipeOptions} opts\n * @throws {Error} if provided options are not valid\n */\ncommands.mobileSwipeGesture = async function mobileSwipeGesture (opts = {}) {\n  const {\n    elementId,\n    left, top, width, height,\n    direction,\n    percent,\n    speed,\n  } = opts;\n  return await this.uiautomator2.jwproxy.command('/appium/gestures/swipe', 'POST', {\n    origin: toOrigin(elementId),\n    area: toRect(left, top, width, height),\n    direction,\n    percent,\n    speed,\n  });\n};\n\n/**\n * @typedef {Object} ScrollOptions\n * @property {?string} elementId - The id of the element to be scrolled.\n * If the element id is missing then scroll bounding area must be provided.\n * If both the element id and the scroll bounding area are provided then this\n * area is effectively ignored.\n * @property {?number} left - The left coordinate of the scroll bounding area\n * @property {?number} top - The top coordinate of the scroll bounding area\n * @property {?number} width - The width of the scroll bounding area\n * @property {?number} height - The height of the scroll bounding area\n * @property {!string} direction - Direction of the scroll.\n * Acceptable values are: `up`, `down`, `left` and `right` (case insensitive)\n * @property {!number} percent - The size of the scroll as a percentage of the scrolling area size.\n * Valid values must be float numbers greater than zero, where 1.0 is 100%\n * @property {?number} speed [5000 * displayDensity] - The speed at which to perform this gesture\n * in pixels per second. The value must not be negative\n */\n\n/**\n * Performs a scroll gesture.\n *\n * @param {?ScrollOptions} opts\n * @throws {Error} if provided options are not valid\n * @returns {boolean} True if the object can still scroll in the given direction.\n */\ncommands.mobileScrollGesture = async function mobileScrollGesture (opts = {}) {\n  const {\n    elementId,\n    left, top, width, height,\n    direction,\n    percent,\n    speed,\n  } = opts;\n  return await this.uiautomator2.jwproxy.command('/appium/gestures/scroll', 'POST', {\n    origin: toOrigin(elementId),\n    area: toRect(left, top, width, height),\n    direction,\n    percent,\n    speed,\n  });\n};\n\n/**\n * @typedef {Object} ScrollElementToElementOpts\n * @property {string} elementId The identifier of the scrollable element,\n * which is going to be scrolled. It is required this element\n * is a valid scrollable container and it was located by `-android uiautomator`\n * strategy.\n * @property {string} elementToId The identifier of the item, which belongs\n * to the scrollable element above, and which should become visible after\n * the scrolling operation is finished. It is required this element\n * was located by `-android uiautomator` strategy.\n */\n\n/**\n * Scrolls the given scrollable element `elementId` until `elementToId`\n * becomes visible. This function returns immediately if the `elementToId`\n * is already visible in the view port. Otherwise it would scroll\n * to the very beginning of the scrollable control and tries to reach the destination element\n * by scrolling its parent to the end step by step. The scroll direction (vertical or horizontal)\n * is detected automatically.\n *\n * @param {ScrollElementToElementOpts} opts\n * @throws {Error} if the scrolling operation cannot be performed\n */\ncommands.mobileScrollBackTo = async function (opts = {}) {\n  const {elementId, elementToId} = opts;\n  if (!elementId || !elementToId) {\n    throw new errors.InvalidArgumentError(`Both elementId and elementToId arguments must be provided`);\n  }\n  return await this.uiautomator2.jwproxy.command(\n    `/appium/element/${util.unwrapElement(elementId)}/scroll_to/${util.unwrapElement(elementToId)}`, 'POST', {});\n};\n\n/**\n * @typedef {Object} ScrollOpts\n * @property {?string} elementId The identifier of an element. It is required this element\n * is a valid scrollable container and it was located by `-android uiautomator`\n * strategy. If this property is not provided then the first currently available scrollable view\n * is selected for the interaction.\n * @property {!string} strategy The following strategies are supported:\n * - `accessibility id` (UiSelector().description)\n * - `class name` (UiSelector().className)\n * - `-android uiautomator` (UiSelector)\n * @property {!string} selector The corresponding lookup value for the given\n * strategy.\n * @property {?number} maxSwipes The maximum number of swipes to perform\n * on the target scrollable view in order to reach the destination element.\n * In case this value is unset then it would be retrieved from the scrollable\n * element itself (vua `getMaxSearchSwipes()` property).\n */\n\n/**\n * Scrolls the given scrollable element until the element identified\n * by `strategy` and `selector` becomes visible. This function returns immediately if the\n * destination element is already visible in the view port. Otherwise it would scroll\n * to the very beginning of the scrollable control and tries to reach the destination element\n * by scrolling its parent to the end step by step. The scroll direction (vertical or horizontal)\n * is detected automatically.\n *\n * @param {ScrollOpts} opts\n * @throws {Error} if the scrolling operation cannot be performed\n */\ncommands.mobileScroll = async function (opts = {}) {\n  const {\n    element, elementId, // `element` is deprecated, use `elementId` instead\n    strategy, selector, maxSwipes\n  } = opts;\n  if (!strategy || !selector) {\n    throw new errors.InvalidArgumentError(`Both strategy and selector arguments must be provided`);\n  }\n  return await this.uiautomator2.jwproxy.command('/touch/scroll', 'POST', {\n    origin: toOrigin(elementId || element),\n    params: {strategy, selector, maxSwipes},\n  });\n};\n\nexport default commands;\n"],"file":"lib/commands/gestures.js","sourceRoot":"../../.."}
229
+ //# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["lib/commands/gestures.js"],"names":["commands","toOrigin","element","util","wrapElement","unwrapElement","undefined","toPoint","x","y","_","isFinite","toRect","left","top","width","height","some","v","mobileClickGesture","opts","elementId","uiautomator2","jwproxy","command","origin","offset","mobileLongClickGesture","duration","mobileDoubleClickGesture","mobileDragGesture","startX","startY","endX","endY","speed","start","end","mobileFlingGesture","direction","area","mobilePinchCloseGesture","percent","mobilePinchOpenGesture","mobileSwipeGesture","mobileScrollGesture","mobileScrollBackTo","elementToId","errors","InvalidArgumentError","mobileScroll","strategy","selector","maxSwipes","params"],"mappings":"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","sourcesContent":["import { util } from '@appium/support';\nimport _ from 'lodash';\nimport { errors } from '@appium/base-driver';\n\nconst commands = {};\n\n\nfunction toOrigin (element) {\n  return element ? util.wrapElement(util.unwrapElement(element)) : undefined;\n}\n\nfunction toPoint (x, y) {\n  return _.isFinite(x) && _.isFinite(y) ? {x, y} : undefined;\n}\n\nfunction toRect (left, top, width, height) {\n  return [left, top, width, height].some((v) => !_.isFinite(v))\n    ? undefined\n    : {left, top, width, height};\n}\n\n/**\n * @typedef {Object} ClickOptions\n * @property {?string} elementId - The id of the element to be clicked.\n * If the element is missing then both click offset coordinates must be provided.\n * If both the element id and offset are provided then the coordinates\n * are parsed as relative offsets from the top left corner of the element.\n * @property {?number} x - The x coordinate to click on\n * @property {?number} y - The y coordinate to click on\n */\n\n/**\n * Performs a simple click/tap gesture\n *\n * @param {?ClickOptions} opts\n * @throws {Error} if provided options are not valid\n */\ncommands.mobileClickGesture = async function mobileClickGesture (opts = {}) {\n  const {\n    elementId,\n    x, y,\n  } = opts;\n  return await this.uiautomator2.jwproxy.command('/appium/gestures/click', 'POST', {\n    origin: toOrigin(elementId),\n    offset: toPoint(x, y),\n  });\n};\n\n/**\n * @typedef {Object} LongClickOptions\n * @property {?string} elementId - The id of the element to be clicked.\n * If the element is missing then both click offset coordinates must be provided.\n * If both the element id and offset are provided then the coordinates\n * are parsed as relative offsets from the top left corner of the element.\n * @property {?number} x - The x coordinate to click on\n * @property {?number} y - The y coordinate to click on\n * @property {?number} duration [500] - Click duration in milliseconds.\n * The value must not be negative\n */\n\n/**\n * Performs a click that lasts for the given duration\n *\n * @param {?LongClickOptions} opts\n * @throws {Error} if provided options are not valid\n */\ncommands.mobileLongClickGesture = async function mobileLongClickGesture (opts = {}) {\n  const {\n    elementId,\n    x, y,\n    duration,\n  } = opts;\n  return await this.uiautomator2.jwproxy.command('/appium/gestures/long_click', 'POST', {\n    origin: toOrigin(elementId),\n    offset: toPoint(x, y),\n    duration,\n  });\n};\n\n/**\n * @typedef {Object} DoubleClickOptions\n * @property {?string} elementId - The id of the element to be double clicked.\n * If the element is missing then both click offset coordinates must be provided.\n * If both the element id and offset are provided then the coordinates\n * are parsed as relative offsets from the top left corner of the element.\n * @property {?number} x - The x coordinate to double click on\n * @property {?number} y - The y coordinate to double click on\n */\n\n/**\n * Performs a click that lasts for the given duration\n *\n * @param {?DoubleClickOptions} opts\n * @throws {Error} if provided options are not valid\n */\ncommands.mobileDoubleClickGesture = async function mobileDoubleClickGesture (opts = {}) {\n  const {\n    elementId,\n    x, y,\n  } = opts;\n  return await this.uiautomator2.jwproxy.command('/appium/gestures/double_click', 'POST', {\n    origin: toOrigin(elementId),\n    offset: toPoint(x, y),\n  });\n};\n\n/**\n * @typedef {Object} DragOptions\n * @property {?string} elementId - The id of the element to be dragged.\n * If the element id is missing then the start coordinates must be provided.\n * If both the element id and the start coordinates are provided then these\n * coordinates are considered as offsets from the top left element corner.\n * @property {?number} startX - The x coordinate where the dragging starts\n * @property {?number} startY - The y coordinate where the dragging starts\n * @property {!number} endX - The x coordinate where the dragging ends\n * @property {!number} endY - The y coordinate where the dragging ends\n * @property {?number} speed [2500 * displayDensity] - The speed at which to perform\n * this gesture in pixels per second. The value must not be negative\n */\n\n/**\n * Drags this object to the specified location.\n *\n * @param {?DragOptions} opts\n * @throws {Error} if provided options are not valid\n */\ncommands.mobileDragGesture = async function mobileDragGesture (opts = {}) {\n  const {\n    elementId,\n    startX, startY,\n    endX, endY,\n    speed,\n  } = opts;\n  return await this.uiautomator2.jwproxy.command('/appium/gestures/drag', 'POST', {\n    origin: toOrigin(elementId),\n    start: toPoint(startX, startY),\n    end: toPoint(endX, endY),\n    speed,\n  });\n};\n\n/**\n * @typedef {Object} FlingOptions\n * @property {?string} elementId - The id of the element to be flinged.\n * If the element id is missing then fling bounding area must be provided.\n * If both the element id and the fling bounding area are provided then this\n * area is effectively ignored.\n * @property {?number} left - The left coordinate of the fling bounding area\n * @property {?number} top - The top coordinate of the fling bounding area\n * @property {?number} width - The width of the fling bounding area\n * @property {?number} height - The height of the fling bounding area\n * @property {!string} direction - Direction of the fling.\n * Acceptable values are: `up`, `down`, `left` and `right` (case insensitive)\n * @property {?number} speed [7500 * displayDensity] - The speed at which to perform this\n * gesture in pixels per second. The value must be greater than the minimum fling\n * velocity for the given view (50 by default)\n */\n\n/**\n * Drags to the specified location.\n *\n * @param {?FlingOptions} opts\n * @throws {Error} if provided options are not valid\n * @returns {boolean} True if the object can still scroll in the given direction.\n */\ncommands.mobileFlingGesture = async function mobileFlingGesture (opts = {}) {\n  const {\n    elementId,\n    left, top, width, height,\n    direction,\n    speed,\n  } = opts;\n  return await this.uiautomator2.jwproxy.command('/appium/gestures/fling', 'POST', {\n    origin: toOrigin(elementId),\n    area: toRect(left, top, width, height),\n    direction,\n    speed,\n  });\n};\n\n/**\n * @typedef {Object} PinchOptions\n * @property {?string} elementId - The id of the element to be pinched.\n * If the element id is missing then pinch bounding area must be provided.\n * If both the element id and the pinch bounding area are provided then the\n * area is effectively ignored.\n * @property {?number} left - The left coordinate of the pinch bounding area\n * @property {?number} top - The top coordinate of the pinch bounding area\n * @property {?number} width - The width of the pinch bounding area\n * @property {?number} height - The height of the pinch bounding area\n * @property {!number} percent - The size of the pinch as a percentage of the pinch area size.\n * Valid values must be float numbers in range 0..1, where 1.0 is 100%\n * @property {?number} speed [2500 * displayDensity] - The speed at which to perform\n * this gesture in pixels per second. The value must not be negative\n */\n\n/**\n * Performs a pinch close gesture.\n *\n * @param {?PinchOptions} opts\n * @throws {Error} if provided options are not valid\n */\ncommands.mobilePinchCloseGesture = async function mobilePinchCloseGesture (opts = {}) {\n  const {\n    elementId,\n    left, top, width, height,\n    percent,\n    speed,\n  } = opts;\n  return await this.uiautomator2.jwproxy.command('/appium/gestures/pinch_close', 'POST', {\n    origin: toOrigin(elementId),\n    area: toRect(left, top, width, height),\n    percent,\n    speed,\n  });\n};\n\n/**\n * Performs a pinch open gesture.\n *\n * @param {?PinchOptions} opts\n * @throws {Error} if provided options are not valid\n */\ncommands.mobilePinchOpenGesture = async function mobilePinchOpenGesture (opts = {}) {\n  const {\n    elementId,\n    left, top, width, height,\n    percent,\n    speed,\n  } = opts;\n  return await this.uiautomator2.jwproxy.command('/appium/gestures/pinch_open', 'POST', {\n    origin: toOrigin(elementId),\n    area: toRect(left, top, width, height),\n    percent,\n    speed,\n  });\n};\n\n/**\n * @typedef {Object} SwipeOptions\n * @property {?string} elementId - The id of the element to be swiped.\n * If the element id is missing then swipe bounding area must be provided.\n * If both the element id and the swipe bounding area are provided then the\n * area is effectively ignored.\n * @property {?number} left - The left coordinate of the swipe bounding area\n * @property {?number} top - The top coordinate of the swipe bounding area\n * @property {?number} width - The width of the swipe bounding area\n * @property {?number} height - The height of the swipe bounding area\n * @property {!string} direction - Direction of the swipe.\n * Acceptable values are: `up`, `down`, `left` and `right` (case insensitive)\n * @property {!number} percent - The size of the swipe as a percentage of the swipe area size.\n * Valid values must be float numbers in range 0..1, where 1.0 is 100%\n * @property {?number} speed [5000 * displayDensity] - The speed at which to perform this\n * gesture in pixels per second. The value must not be negative\n */\n\n/**\n * Performs a swipe gesture.\n *\n * @param {?SwipeOptions} opts\n * @throws {Error} if provided options are not valid\n */\ncommands.mobileSwipeGesture = async function mobileSwipeGesture (opts = {}) {\n  const {\n    elementId,\n    left, top, width, height,\n    direction,\n    percent,\n    speed,\n  } = opts;\n  return await this.uiautomator2.jwproxy.command('/appium/gestures/swipe', 'POST', {\n    origin: toOrigin(elementId),\n    area: toRect(left, top, width, height),\n    direction,\n    percent,\n    speed,\n  });\n};\n\n/**\n * @typedef {Object} ScrollOptions\n * @property {?string} elementId - The id of the element to be scrolled.\n * If the element id is missing then scroll bounding area must be provided.\n * If both the element id and the scroll bounding area are provided then this\n * area is effectively ignored.\n * @property {?number} left - The left coordinate of the scroll bounding area\n * @property {?number} top - The top coordinate of the scroll bounding area\n * @property {?number} width - The width of the scroll bounding area\n * @property {?number} height - The height of the scroll bounding area\n * @property {!string} direction - Direction of the scroll.\n * Acceptable values are: `up`, `down`, `left` and `right` (case insensitive)\n * @property {!number} percent - The size of the scroll as a percentage of the scrolling area size.\n * Valid values must be float numbers greater than zero, where 1.0 is 100%\n * @property {?number} speed [5000 * displayDensity] - The speed at which to perform this gesture\n * in pixels per second. The value must not be negative\n */\n\n/**\n * Performs a scroll gesture.\n *\n * @param {?ScrollOptions} opts\n * @throws {Error} if provided options are not valid\n * @returns {boolean} True if the object can still scroll in the given direction.\n */\ncommands.mobileScrollGesture = async function mobileScrollGesture (opts = {}) {\n  const {\n    elementId,\n    left, top, width, height,\n    direction,\n    percent,\n    speed,\n  } = opts;\n  return await this.uiautomator2.jwproxy.command('/appium/gestures/scroll', 'POST', {\n    origin: toOrigin(elementId),\n    area: toRect(left, top, width, height),\n    direction,\n    percent,\n    speed,\n  });\n};\n\n/**\n * @typedef {Object} ScrollElementToElementOpts\n * @property {string} elementId The identifier of the scrollable element,\n * which is going to be scrolled. It is required this element\n * is a valid scrollable container and it was located by `-android uiautomator`\n * strategy.\n * @property {string} elementToId The identifier of the item, which belongs\n * to the scrollable element above, and which should become visible after\n * the scrolling operation is finished. It is required this element\n * was located by `-android uiautomator` strategy.\n */\n\n/**\n * Scrolls the given scrollable element `elementId` until `elementToId`\n * becomes visible. This function returns immediately if the `elementToId`\n * is already visible in the view port. Otherwise it would scroll\n * to the very beginning of the scrollable control and tries to reach the destination element\n * by scrolling its parent to the end step by step. The scroll direction (vertical or horizontal)\n * is detected automatically.\n *\n * @param {ScrollElementToElementOpts} opts\n * @throws {Error} if the scrolling operation cannot be performed\n */\ncommands.mobileScrollBackTo = async function (opts = {}) {\n  const {elementId, elementToId} = opts;\n  if (!elementId || !elementToId) {\n    throw new errors.InvalidArgumentError(`Both elementId and elementToId arguments must be provided`);\n  }\n  return await this.uiautomator2.jwproxy.command(\n    `/appium/element/${util.unwrapElement(elementId)}/scroll_to/${util.unwrapElement(elementToId)}`, 'POST', {});\n};\n\n/**\n * @typedef {Object} ScrollOpts\n * @property {?string} elementId The identifier of an element. It is required this element\n * is a valid scrollable container and it was located by `-android uiautomator`\n * strategy. If this property is not provided then the first currently available scrollable view\n * is selected for the interaction.\n * @property {!string} strategy The following strategies are supported:\n * - `accessibility id` (UiSelector().description)\n * - `class name` (UiSelector().className)\n * - `-android uiautomator` (UiSelector)\n * @property {!string} selector The corresponding lookup value for the given\n * strategy.\n * @property {?number} maxSwipes The maximum number of swipes to perform\n * on the target scrollable view in order to reach the destination element.\n * In case this value is unset then it would be retrieved from the scrollable\n * element itself (vua `getMaxSearchSwipes()` property).\n */\n\n/**\n * Scrolls the given scrollable element until the element identified\n * by `strategy` and `selector` becomes visible. This function returns immediately if the\n * destination element is already visible in the view port. Otherwise it would scroll\n * to the very beginning of the scrollable control and tries to reach the destination element\n * by scrolling its parent to the end step by step. The scroll direction (vertical or horizontal)\n * is detected automatically.\n *\n * @param {ScrollOpts} opts\n * @throws {Error} if the scrolling operation cannot be performed\n */\ncommands.mobileScroll = async function (opts = {}) {\n  const {\n    element, elementId, // `element` is deprecated, use `elementId` instead\n    strategy, selector, maxSwipes\n  } = opts;\n  if (!strategy || !selector) {\n    throw new errors.InvalidArgumentError(`Both strategy and selector arguments must be provided`);\n  }\n  return await this.uiautomator2.jwproxy.command('/touch/scroll', 'POST', {\n    origin: toOrigin(elementId || element),\n    params: {strategy, selector, maxSwipes},\n  });\n};\n\nexport default commands;\n"],"file":"lib/commands/gestures.js","sourceRoot":"../../.."}
@@ -7,7 +7,7 @@ exports.default = exports.commands = void 0;
7
7
 
8
8
  require("source-map-support/register");
9
9
 
10
- var _appiumSupport = require("appium-support");
10
+ var _support = require("@appium/support");
11
11
 
12
12
  let extensions = {},
13
13
  commands = {};
@@ -27,7 +27,7 @@ commands.getDevicePixelRatio = async function () {
27
27
  commands.getViewportScreenshot = async function () {
28
28
  const screenshot = await this.getScreenshot();
29
29
  const rect = await this.getViewPortRect();
30
- return await _appiumSupport.imageUtil.cropBase64Image(screenshot, rect);
30
+ return await _support.imageUtil.cropBase64Image(screenshot, rect);
31
31
  };
32
32
 
33
33
  commands.getViewPortRect = async function () {
@@ -46,4 +46,4 @@ var _default = extensions;
46
46
  exports.default = _default;require('source-map-support').install();
47
47
 
48
48
 
49
- //# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImxpYi9jb21tYW5kcy92aWV3cG9ydC5qcyJdLCJuYW1lcyI6WyJleHRlbnNpb25zIiwiY29tbWFuZHMiLCJnZXRTdGF0dXNCYXJIZWlnaHQiLCJzdGF0dXNCYXIiLCJ1aWF1dG9tYXRvcjIiLCJqd3Byb3h5IiwiY29tbWFuZCIsImdldERldmljZVBpeGVsUmF0aW8iLCJnZXRWaWV3cG9ydFNjcmVlbnNob3QiLCJzY3JlZW5zaG90IiwiZ2V0U2NyZWVuc2hvdCIsInJlY3QiLCJnZXRWaWV3UG9ydFJlY3QiLCJpbWFnZVV0aWwiLCJjcm9wQmFzZTY0SW1hZ2UiLCJ3aW5kb3dTaXplIiwiZ2V0V2luZG93U2l6ZSIsInN0YXR1c0JhckhlaWdodCIsImxlZnQiLCJ0b3AiLCJ3aWR0aCIsImhlaWdodCIsIk9iamVjdCIsImFzc2lnbiJdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7O0FBQUE7O0FBR0EsSUFBSUEsVUFBVSxHQUFHLEVBQWpCO0FBQUEsSUFBcUJDLFFBQVEsR0FBRyxFQUFoQzs7O0FBR0FBLFFBQVEsQ0FBQ0Msa0JBQVQsR0FBOEIsa0JBQWtCO0FBQzlDLFFBQU07QUFBQ0MsSUFBQUE7QUFBRCxNQUFjLE1BQU0sS0FBS0MsWUFBTCxDQUFrQkMsT0FBbEIsQ0FBMEJDLE9BQTFCLENBQW1DLDRCQUFuQyxFQUFnRSxLQUFoRSxFQUF1RSxFQUF2RSxDQUExQjtBQUNBLFNBQU9ILFNBQVA7QUFDRCxDQUhEOztBQU1BRixRQUFRLENBQUNNLG1CQUFULEdBQStCLGtCQUFrQjtBQUMvQyxTQUFPLE1BQU0sS0FBS0gsWUFBTCxDQUFrQkMsT0FBbEIsQ0FBMEJDLE9BQTFCLENBQWtDLDRCQUFsQyxFQUFnRSxLQUFoRSxFQUF1RSxFQUF2RSxDQUFiO0FBQ0QsQ0FGRDs7QUFJQUwsUUFBUSxDQUFDTyxxQkFBVCxHQUFpQyxrQkFBa0I7QUFDakQsUUFBTUMsVUFBVSxHQUFHLE1BQU0sS0FBS0MsYUFBTCxFQUF6QjtBQUNBLFFBQU1DLElBQUksR0FBRyxNQUFNLEtBQUtDLGVBQUwsRUFBbkI7QUFDQSxTQUFPLE1BQU1DLHlCQUFVQyxlQUFWLENBQTBCTCxVQUExQixFQUFzQ0UsSUFBdEMsQ0FBYjtBQUNELENBSkQ7O0FBTUFWLFFBQVEsQ0FBQ1csZUFBVCxHQUEyQixrQkFBa0I7QUFDM0MsUUFBTUcsVUFBVSxHQUFHLE1BQU0sS0FBS0MsYUFBTCxFQUF6QjtBQUNBLFFBQU1DLGVBQWUsR0FBRyxNQUFNLEtBQUtmLGtCQUFMLEVBQTlCO0FBR0EsU0FBTztBQUNMZ0IsSUFBQUEsSUFBSSxFQUFFLENBREQ7QUFFTEMsSUFBQUEsR0FBRyxFQUFFRixlQUZBO0FBR0xHLElBQUFBLEtBQUssRUFBRUwsVUFBVSxDQUFDSyxLQUhiO0FBSUxDLElBQUFBLE1BQU0sRUFBRU4sVUFBVSxDQUFDTSxNQUFYLEdBQW9CSjtBQUp2QixHQUFQO0FBTUQsQ0FYRDs7QUFhQUssTUFBTSxDQUFDQyxNQUFQLENBQWN2QixVQUFkLEVBQTBCQyxRQUExQjtlQUVlRCxVIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgaW1hZ2VVdGlsIH0gZnJvbSAnYXBwaXVtLXN1cHBvcnQnO1xuXG5cbmxldCBleHRlbnNpb25zID0ge30sIGNvbW1hbmRzID0ge307XG5cbi8vIG1lbW9pemVkIGluIGNvbnN0cnVjdG9yXG5jb21tYW5kcy5nZXRTdGF0dXNCYXJIZWlnaHQgPSBhc3luYyBmdW5jdGlvbiAoKSB7XG4gIGNvbnN0IHtzdGF0dXNCYXJ9ID0gYXdhaXQgdGhpcy51aWF1dG9tYXRvcjIuandwcm94eS5jb21tYW5kKGAvYXBwaXVtL2RldmljZS9zeXN0ZW1fYmFyc2AsICdHRVQnLCB7fSk7XG4gIHJldHVybiBzdGF0dXNCYXI7XG59O1xuXG4vLyBtZW1vaXplZCBpbiBjb25zdHJ1Y3RvclxuY29tbWFuZHMuZ2V0RGV2aWNlUGl4ZWxSYXRpbyA9IGFzeW5jIGZ1bmN0aW9uICgpIHtcbiAgcmV0dXJuIGF3YWl0IHRoaXMudWlhdXRvbWF0b3IyLmp3cHJveHkuY29tbWFuZCgnL2FwcGl1bS9kZXZpY2UvcGl4ZWxfcmF0aW8nLCAnR0VUJywge30pO1xufTtcblxuY29tbWFuZHMuZ2V0Vmlld3BvcnRTY3JlZW5zaG90ID0gYXN5bmMgZnVuY3Rpb24gKCkge1xuICBjb25zdCBzY3JlZW5zaG90ID0gYXdhaXQgdGhpcy5nZXRTY3JlZW5zaG90KCk7XG4gIGNvbnN0IHJlY3QgPSBhd2FpdCB0aGlzLmdldFZpZXdQb3J0UmVjdCgpO1xuICByZXR1cm4gYXdhaXQgaW1hZ2VVdGlsLmNyb3BCYXNlNjRJbWFnZShzY3JlZW5zaG90LCByZWN0KTtcbn07XG5cbmNvbW1hbmRzLmdldFZpZXdQb3J0UmVjdCA9IGFzeW5jIGZ1bmN0aW9uICgpIHtcbiAgY29uc3Qgd2luZG93U2l6ZSA9IGF3YWl0IHRoaXMuZ2V0V2luZG93U2l6ZSgpO1xuICBjb25zdCBzdGF0dXNCYXJIZWlnaHQgPSBhd2FpdCB0aGlzLmdldFN0YXR1c0JhckhlaWdodCgpO1xuICAvLyBhbmRyb2lkIHJldHVybnMgdGhlIHVwc2NhbGVkIHdpbmRvdyBzaXplLCBzbyB0byBnZXQgdGhlIHRydWUgc2l6ZSBvZiB0aGVcbiAgLy8gcmVjdCB3ZSBoYXZlIHRvIGRvd25zY2FsZVxuICByZXR1cm4ge1xuICAgIGxlZnQ6IDAsXG4gICAgdG9wOiBzdGF0dXNCYXJIZWlnaHQsXG4gICAgd2lkdGg6IHdpbmRvd1NpemUud2lkdGgsXG4gICAgaGVpZ2h0OiB3aW5kb3dTaXplLmhlaWdodCAtIHN0YXR1c0JhckhlaWdodFxuICB9O1xufTtcblxuT2JqZWN0LmFzc2lnbihleHRlbnNpb25zLCBjb21tYW5kcyk7XG5leHBvcnQgeyBjb21tYW5kcyB9O1xuZXhwb3J0IGRlZmF1bHQgZXh0ZW5zaW9ucztcbiJdLCJmaWxlIjoibGliL2NvbW1hbmRzL3ZpZXdwb3J0LmpzIiwic291cmNlUm9vdCI6Ii4uLy4uLy4uIn0=
49
+ //# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImxpYi9jb21tYW5kcy92aWV3cG9ydC5qcyJdLCJuYW1lcyI6WyJleHRlbnNpb25zIiwiY29tbWFuZHMiLCJnZXRTdGF0dXNCYXJIZWlnaHQiLCJzdGF0dXNCYXIiLCJ1aWF1dG9tYXRvcjIiLCJqd3Byb3h5IiwiY29tbWFuZCIsImdldERldmljZVBpeGVsUmF0aW8iLCJnZXRWaWV3cG9ydFNjcmVlbnNob3QiLCJzY3JlZW5zaG90IiwiZ2V0U2NyZWVuc2hvdCIsInJlY3QiLCJnZXRWaWV3UG9ydFJlY3QiLCJpbWFnZVV0aWwiLCJjcm9wQmFzZTY0SW1hZ2UiLCJ3aW5kb3dTaXplIiwiZ2V0V2luZG93U2l6ZSIsInN0YXR1c0JhckhlaWdodCIsImxlZnQiLCJ0b3AiLCJ3aWR0aCIsImhlaWdodCIsIk9iamVjdCIsImFzc2lnbiJdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7O0FBQUE7O0FBR0EsSUFBSUEsVUFBVSxHQUFHLEVBQWpCO0FBQUEsSUFBcUJDLFFBQVEsR0FBRyxFQUFoQzs7O0FBR0FBLFFBQVEsQ0FBQ0Msa0JBQVQsR0FBOEIsa0JBQWtCO0FBQzlDLFFBQU07QUFBQ0MsSUFBQUE7QUFBRCxNQUFjLE1BQU0sS0FBS0MsWUFBTCxDQUFrQkMsT0FBbEIsQ0FBMEJDLE9BQTFCLENBQW1DLDRCQUFuQyxFQUFnRSxLQUFoRSxFQUF1RSxFQUF2RSxDQUExQjtBQUNBLFNBQU9ILFNBQVA7QUFDRCxDQUhEOztBQU1BRixRQUFRLENBQUNNLG1CQUFULEdBQStCLGtCQUFrQjtBQUMvQyxTQUFPLE1BQU0sS0FBS0gsWUFBTCxDQUFrQkMsT0FBbEIsQ0FBMEJDLE9BQTFCLENBQWtDLDRCQUFsQyxFQUFnRSxLQUFoRSxFQUF1RSxFQUF2RSxDQUFiO0FBQ0QsQ0FGRDs7QUFJQUwsUUFBUSxDQUFDTyxxQkFBVCxHQUFpQyxrQkFBa0I7QUFDakQsUUFBTUMsVUFBVSxHQUFHLE1BQU0sS0FBS0MsYUFBTCxFQUF6QjtBQUNBLFFBQU1DLElBQUksR0FBRyxNQUFNLEtBQUtDLGVBQUwsRUFBbkI7QUFDQSxTQUFPLE1BQU1DLG1CQUFVQyxlQUFWLENBQTBCTCxVQUExQixFQUFzQ0UsSUFBdEMsQ0FBYjtBQUNELENBSkQ7O0FBTUFWLFFBQVEsQ0FBQ1csZUFBVCxHQUEyQixrQkFBa0I7QUFDM0MsUUFBTUcsVUFBVSxHQUFHLE1BQU0sS0FBS0MsYUFBTCxFQUF6QjtBQUNBLFFBQU1DLGVBQWUsR0FBRyxNQUFNLEtBQUtmLGtCQUFMLEVBQTlCO0FBR0EsU0FBTztBQUNMZ0IsSUFBQUEsSUFBSSxFQUFFLENBREQ7QUFFTEMsSUFBQUEsR0FBRyxFQUFFRixlQUZBO0FBR0xHLElBQUFBLEtBQUssRUFBRUwsVUFBVSxDQUFDSyxLQUhiO0FBSUxDLElBQUFBLE1BQU0sRUFBRU4sVUFBVSxDQUFDTSxNQUFYLEdBQW9CSjtBQUp2QixHQUFQO0FBTUQsQ0FYRDs7QUFhQUssTUFBTSxDQUFDQyxNQUFQLENBQWN2QixVQUFkLEVBQTBCQyxRQUExQjtlQUVlRCxVIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgaW1hZ2VVdGlsIH0gZnJvbSAnQGFwcGl1bS9zdXBwb3J0JztcblxuXG5sZXQgZXh0ZW5zaW9ucyA9IHt9LCBjb21tYW5kcyA9IHt9O1xuXG4vLyBtZW1vaXplZCBpbiBjb25zdHJ1Y3RvclxuY29tbWFuZHMuZ2V0U3RhdHVzQmFySGVpZ2h0ID0gYXN5bmMgZnVuY3Rpb24gKCkge1xuICBjb25zdCB7c3RhdHVzQmFyfSA9IGF3YWl0IHRoaXMudWlhdXRvbWF0b3IyLmp3cHJveHkuY29tbWFuZChgL2FwcGl1bS9kZXZpY2Uvc3lzdGVtX2JhcnNgLCAnR0VUJywge30pO1xuICByZXR1cm4gc3RhdHVzQmFyO1xufTtcblxuLy8gbWVtb2l6ZWQgaW4gY29uc3RydWN0b3JcbmNvbW1hbmRzLmdldERldmljZVBpeGVsUmF0aW8gPSBhc3luYyBmdW5jdGlvbiAoKSB7XG4gIHJldHVybiBhd2FpdCB0aGlzLnVpYXV0b21hdG9yMi5qd3Byb3h5LmNvbW1hbmQoJy9hcHBpdW0vZGV2aWNlL3BpeGVsX3JhdGlvJywgJ0dFVCcsIHt9KTtcbn07XG5cbmNvbW1hbmRzLmdldFZpZXdwb3J0U2NyZWVuc2hvdCA9IGFzeW5jIGZ1bmN0aW9uICgpIHtcbiAgY29uc3Qgc2NyZWVuc2hvdCA9IGF3YWl0IHRoaXMuZ2V0U2NyZWVuc2hvdCgpO1xuICBjb25zdCByZWN0ID0gYXdhaXQgdGhpcy5nZXRWaWV3UG9ydFJlY3QoKTtcbiAgcmV0dXJuIGF3YWl0IGltYWdlVXRpbC5jcm9wQmFzZTY0SW1hZ2Uoc2NyZWVuc2hvdCwgcmVjdCk7XG59O1xuXG5jb21tYW5kcy5nZXRWaWV3UG9ydFJlY3QgPSBhc3luYyBmdW5jdGlvbiAoKSB7XG4gIGNvbnN0IHdpbmRvd1NpemUgPSBhd2FpdCB0aGlzLmdldFdpbmRvd1NpemUoKTtcbiAgY29uc3Qgc3RhdHVzQmFySGVpZ2h0ID0gYXdhaXQgdGhpcy5nZXRTdGF0dXNCYXJIZWlnaHQoKTtcbiAgLy8gYW5kcm9pZCByZXR1cm5zIHRoZSB1cHNjYWxlZCB3aW5kb3cgc2l6ZSwgc28gdG8gZ2V0IHRoZSB0cnVlIHNpemUgb2YgdGhlXG4gIC8vIHJlY3Qgd2UgaGF2ZSB0byBkb3duc2NhbGVcbiAgcmV0dXJuIHtcbiAgICBsZWZ0OiAwLFxuICAgIHRvcDogc3RhdHVzQmFySGVpZ2h0LFxuICAgIHdpZHRoOiB3aW5kb3dTaXplLndpZHRoLFxuICAgIGhlaWdodDogd2luZG93U2l6ZS5oZWlnaHQgLSBzdGF0dXNCYXJIZWlnaHRcbiAgfTtcbn07XG5cbk9iamVjdC5hc3NpZ24oZXh0ZW5zaW9ucywgY29tbWFuZHMpO1xuZXhwb3J0IHsgY29tbWFuZHMgfTtcbmV4cG9ydCBkZWZhdWx0IGV4dGVuc2lvbnM7XG4iXSwiZmlsZSI6ImxpYi9jb21tYW5kcy92aWV3cG9ydC5qcyIsInNvdXJjZVJvb3QiOiIuLi8uLi8uLiJ9
@@ -11,9 +11,8 @@ var _cssSelectorParser = require("css-selector-parser");
11
11
 
12
12
  var _lodash = require("lodash");
13
13
 
14
- var _appiumBaseDriver = require("appium-base-driver");
14
+ var _baseDriver = require("@appium/base-driver");
15
15
 
16
- const CssConverter = {};
17
16
  const parser = new _cssSelectorParser.CssSelectorParser();
18
17
  parser.registerSelectorPseudos('has');
19
18
  parser.registerNestingOperators('>', '+', '~');
@@ -69,165 +68,173 @@ function getWordMatcherRegex(word) {
69
68
  return `\\b(\\w*${(0, _lodash.escapeRegExp)(word)}\\w*)\\b`;
70
69
  }
71
70
 
72
- function formatIdLocator(locator) {
73
- return ID_LOCATOR_PATTERN.test(locator) ? locator : `android:id/${locator}`;
74
- }
71
+ class CssConverter {
72
+ constructor(selector, pkg) {
73
+ this.selector = selector;
74
+ this.pkg = pkg;
75
+ }
75
76
 
76
- function parseAttr(cssAttr) {
77
- if (cssAttr.valueType && cssAttr.valueType !== 'string') {
78
- throw new Error(`'${cssAttr.name}=${cssAttr.value}' is an invalid attribute. ` + `Only 'string' and empty attribute types are supported. Found '${cssAttr.valueType}'`);
77
+ formatIdLocator(locator) {
78
+ return ID_LOCATOR_PATTERN.test(locator) ? locator : `${this.pkg || 'android'}:id/${locator}`;
79
79
  }
80
80
 
81
- const attrName = assertGetAttrName(cssAttr);
82
- const methodName = toSnakeCase(attrName);
81
+ parseAttr(cssAttr) {
82
+ if (cssAttr.valueType && cssAttr.valueType !== 'string') {
83
+ throw new Error(`'${cssAttr.name}=${cssAttr.value}' is an invalid attribute. ` + `Only 'string' and empty attribute types are supported. Found '${cssAttr.valueType}'`);
84
+ }
83
85
 
84
- if (!STR_ATTRS.includes(attrName) && !BOOLEAN_ATTRS.includes(attrName)) {
85
- throw new Error(`'${attrName}' is not supported. Supported attributes are ` + `'${[...STR_ATTRS, ...BOOLEAN_ATTRS].join(', ')}'`);
86
- }
86
+ const attrName = assertGetAttrName(cssAttr);
87
+ const methodName = toSnakeCase(attrName);
87
88
 
88
- if (BOOLEAN_ATTRS.includes(attrName)) {
89
- return `.${methodName}(${assertGetBool(cssAttr)})`;
90
- }
89
+ if (!STR_ATTRS.includes(attrName) && !BOOLEAN_ATTRS.includes(attrName)) {
90
+ throw new Error(`'${attrName}' is not supported. Supported attributes are ` + `'${[...STR_ATTRS, ...BOOLEAN_ATTRS].join(', ')}'`);
91
+ }
91
92
 
92
- let value = cssAttr.value || '';
93
+ if (BOOLEAN_ATTRS.includes(attrName)) {
94
+ return `.${methodName}(${assertGetBool(cssAttr)})`;
95
+ }
93
96
 
94
- if (attrName === RESOURCE_ID) {
95
- value = formatIdLocator(value);
96
- }
97
+ let value = cssAttr.value || '';
97
98
 
98
- if (value === '') {
99
- return `.${methodName}Matches("")`;
100
- }
99
+ if (attrName === RESOURCE_ID) {
100
+ value = this.formatIdLocator(value);
101
+ }
101
102
 
102
- switch (cssAttr.operator) {
103
- case '=':
104
- return `.${methodName}("${value}")`;
103
+ if (value === '') {
104
+ return `.${methodName}Matches("")`;
105
+ }
105
106
 
106
- case '*=':
107
- if (['description', 'text'].includes(attrName)) {
108
- return `.${methodName}Contains("${value}")`;
109
- }
107
+ switch (cssAttr.operator) {
108
+ case '=':
109
+ return `.${methodName}("${value}")`;
110
110
 
111
- return `.${methodName}Matches("${(0, _lodash.escapeRegExp)(value)}")`;
111
+ case '*=':
112
+ if (['description', 'text'].includes(attrName)) {
113
+ return `.${methodName}Contains("${value}")`;
114
+ }
112
115
 
113
- case '^=':
114
- if (['description', 'text'].includes(attrName)) {
115
- return `.${methodName}StartsWith("${value}")`;
116
- }
116
+ return `.${methodName}Matches("${(0, _lodash.escapeRegExp)(value)}")`;
117
117
 
118
- return `.${methodName}Matches("^${(0, _lodash.escapeRegExp)(value)}")`;
118
+ case '^=':
119
+ if (['description', 'text'].includes(attrName)) {
120
+ return `.${methodName}StartsWith("${value}")`;
121
+ }
119
122
 
120
- case '$=':
121
- return `.${methodName}Matches("${(0, _lodash.escapeRegExp)(value)}$")`;
123
+ return `.${methodName}Matches("^${(0, _lodash.escapeRegExp)(value)}")`;
122
124
 
123
- case '~=':
124
- return `.${methodName}Matches("${getWordMatcherRegex(value)}")`;
125
+ case '$=':
126
+ return `.${methodName}Matches("${(0, _lodash.escapeRegExp)(value)}$")`;
125
127
 
126
- default:
127
- throw new Error(`Unsupported CSS attribute operator '${cssAttr.operator}'. ` + ` '=', '*=', '^=', '$=' and '~=' are supported.`);
128
- }
129
- }
128
+ case '~=':
129
+ return `.${methodName}Matches("${getWordMatcherRegex(value)}")`;
130
130
 
131
- function parsePseudo(cssPseudo) {
132
- if (cssPseudo.valueType && cssPseudo.valueType !== 'string') {
133
- throw new Error(`'${cssPseudo.name}=${cssPseudo.value}'. ` + `Unsupported css pseudo class value type: '${cssPseudo.valueType}'. Only 'string' type or empty is supported.`);
131
+ default:
132
+ throw new Error(`Unsupported CSS attribute operator '${cssAttr.operator}'. ` + ` '=', '*=', '^=', '$=' and '~=' are supported.`);
133
+ }
134
134
  }
135
135
 
136
- const pseudoName = assertGetAttrName(cssPseudo);
136
+ parsePseudo(cssPseudo) {
137
+ if (cssPseudo.valueType && cssPseudo.valueType !== 'string') {
138
+ throw new Error(`'${cssPseudo.name}=${cssPseudo.value}'. ` + `Unsupported css pseudo class value type: '${cssPseudo.valueType}'. Only 'string' type or empty is supported.`);
139
+ }
137
140
 
138
- if (BOOLEAN_ATTRS.includes(pseudoName)) {
139
- return `.${toSnakeCase(pseudoName)}(${assertGetBool(cssPseudo)})`;
140
- }
141
+ const pseudoName = assertGetAttrName(cssPseudo);
141
142
 
142
- if (NUMERIC_ATTRS.includes(pseudoName)) {
143
- return `.${pseudoName}(${cssPseudo.value})`;
143
+ if (BOOLEAN_ATTRS.includes(pseudoName)) {
144
+ return `.${toSnakeCase(pseudoName)}(${assertGetBool(cssPseudo)})`;
145
+ }
146
+
147
+ if (NUMERIC_ATTRS.includes(pseudoName)) {
148
+ return `.${pseudoName}(${cssPseudo.value})`;
149
+ }
144
150
  }
145
- }
146
151
 
147
- function parseCssRule(cssRule) {
148
- const {
149
- nestingOperator
150
- } = cssRule;
152
+ parseCssRule(cssRule) {
153
+ const {
154
+ nestingOperator
155
+ } = cssRule;
151
156
 
152
- if (nestingOperator && nestingOperator !== ' ') {
153
- throw new Error(`'${nestingOperator}' is not a supported combinator. ` + `Only child combinator (>) and descendant combinator are supported.`);
154
- }
157
+ if (nestingOperator && nestingOperator !== ' ') {
158
+ throw new Error(`'${nestingOperator}' is not a supported combinator. ` + `Only child combinator (>) and descendant combinator are supported.`);
159
+ }
155
160
 
156
- let uiAutomatorSelector = 'new UiSelector()';
161
+ let uiAutomatorSelector = 'new UiSelector()';
157
162
 
158
- if (cssRule.tagName && cssRule.tagName !== '*') {
159
- let androidClass = [cssRule.tagName];
163
+ if (cssRule.tagName && cssRule.tagName !== '*') {
164
+ let androidClass = [cssRule.tagName];
160
165
 
161
- if (cssRule.classNames) {
162
- for (const cssClassNames of cssRule.classNames) {
163
- androidClass.push(cssClassNames);
166
+ if (cssRule.classNames) {
167
+ for (const cssClassNames of cssRule.classNames) {
168
+ androidClass.push(cssClassNames);
169
+ }
170
+
171
+ uiAutomatorSelector += `.className("${androidClass.join('.')}")`;
172
+ } else {
173
+ uiAutomatorSelector += `.classNameMatches("${cssRule.tagName}")`;
164
174
  }
175
+ } else if (cssRule.classNames) {
176
+ uiAutomatorSelector += `.classNameMatches("${cssRule.classNames.join('\\.')}")`;
177
+ }
165
178
 
166
- uiAutomatorSelector += `.className("${androidClass.join('.')}")`;
167
- } else {
168
- uiAutomatorSelector += `.classNameMatches("${cssRule.tagName}")`;
179
+ if (cssRule.id) {
180
+ uiAutomatorSelector += `.resourceId("${this.formatIdLocator(cssRule.id)}")`;
169
181
  }
170
- } else if (cssRule.classNames) {
171
- uiAutomatorSelector += `.classNameMatches("${cssRule.classNames.join('\\.')}")`;
172
- }
173
182
 
174
- if (cssRule.id) {
175
- uiAutomatorSelector += `.resourceId("${formatIdLocator(cssRule.id)}")`;
176
- }
183
+ if (cssRule.attrs) {
184
+ for (const attr of cssRule.attrs) {
185
+ uiAutomatorSelector += this.parseAttr(attr);
186
+ }
187
+ }
177
188
 
178
- if (cssRule.attrs) {
179
- for (const attr of cssRule.attrs) {
180
- uiAutomatorSelector += parseAttr(attr);
189
+ if (cssRule.pseudos) {
190
+ for (const pseudo of cssRule.pseudos) {
191
+ uiAutomatorSelector += this.parsePseudo(pseudo);
192
+ }
181
193
  }
182
- }
183
194
 
184
- if (cssRule.pseudos) {
185
- for (const pseudo of cssRule.pseudos) {
186
- uiAutomatorSelector += parsePseudo(pseudo);
195
+ if (cssRule.rule) {
196
+ uiAutomatorSelector += `.childSelector(${this.parseCssRule(cssRule.rule)})`;
187
197
  }
188
- }
189
198
 
190
- if (cssRule.rule) {
191
- uiAutomatorSelector += `.childSelector(${parseCssRule(cssRule.rule)})`;
199
+ return uiAutomatorSelector;
192
200
  }
193
201
 
194
- return uiAutomatorSelector;
195
- }
196
-
197
- function parseCssObject(css) {
198
- switch (css.type) {
199
- case 'rule':
200
- return parseCssRule(css);
202
+ parseCssObject(css) {
203
+ switch (css.type) {
204
+ case 'rule':
205
+ return this.parseCssRule(css);
201
206
 
202
- case 'ruleSet':
203
- return parseCssObject(css.rule);
207
+ case 'ruleSet':
208
+ return this.parseCssObject(css.rule);
204
209
 
205
- case 'selectors':
206
- return css.selectors.map(selector => parseCssObject(selector)).join('; ');
210
+ case 'selectors':
211
+ return css.selectors.map(selector => this.parseCssObject(selector)).join('; ');
207
212
 
208
- default:
209
- throw new Error(`UiAutomator does not support '${css.type}' css. Only supports 'rule', 'ruleSet', 'selectors' `);
213
+ default:
214
+ throw new Error(`UiAutomator does not support '${css.type}' css. Only supports 'rule', 'ruleSet', 'selectors' `);
215
+ }
210
216
  }
211
- }
212
217
 
213
- CssConverter.toUiAutomatorSelector = function toUiAutomatorSelector(cssSelector) {
214
- let cssObj;
218
+ toUiAutomatorSelector() {
219
+ let cssObj;
215
220
 
216
- try {
217
- cssObj = parser.parse(cssSelector);
218
- } catch (e) {
219
- throw new _appiumBaseDriver.errors.InvalidSelectorError(`Invalid CSS selector '${cssSelector}'. Reason: '${e}'`);
220
- }
221
+ try {
222
+ cssObj = parser.parse(this.selector);
223
+ } catch (e) {
224
+ throw new _baseDriver.errors.InvalidSelectorError(`Invalid CSS selector '${this.selector}'. Reason: '${e}'`);
225
+ }
221
226
 
222
- try {
223
- return parseCssObject(cssObj);
224
- } catch (e) {
225
- throw new _appiumBaseDriver.errors.InvalidSelectorError(`Unsupported CSS selector '${cssSelector}'. Reason: '${e}'`);
227
+ try {
228
+ return this.parseCssObject(cssObj);
229
+ } catch (e) {
230
+ throw new _baseDriver.errors.InvalidSelectorError(`Unsupported CSS selector '${this.selector}'. Reason: '${e}'`);
231
+ }
226
232
  }
227
- };
233
+
234
+ }
228
235
 
229
236
  var _default = CssConverter;
230
237
  exports.default = _default;require('source-map-support').install();
231
238
 
232
239
 
233
- //# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["lib/css-converter.js"],"names":["CssConverter","parser","CssSelectorParser","registerSelectorPseudos","registerNestingOperators","registerAttrEqualityMods","enableSubstitutes","RESOURCE_ID","ID_LOCATOR_PATTERN","BOOLEAN_ATTRS","NUMERIC_ATTRS","STR_ATTRS","ALL_ATTRS","ATTRIBUTE_ALIASES","toSnakeCase","str","tokens","split","map","charAt","toUpperCase","slice","toLowerCase","out","join","assertGetBool","css","val","value","includes","Error","name","assertGetAttrName","attrName","officialAttr","aliasAttrs","getWordMatcherRegex","word","formatIdLocator","locator","test","parseAttr","cssAttr","valueType","methodName","operator","parsePseudo","cssPseudo","pseudoName","parseCssRule","cssRule","nestingOperator","uiAutomatorSelector","tagName","androidClass","classNames","cssClassNames","push","id","attrs","attr","pseudos","pseudo","rule","parseCssObject","type","selectors","selector","toUiAutomatorSelector","cssSelector","cssObj","parse","e","errors","InvalidSelectorError"],"mappings":"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","sourcesContent":["import { CssSelectorParser } from 'css-selector-parser';\nimport { escapeRegExp } from 'lodash';\nimport { errors } from 'appium-base-driver';\n\nconst CssConverter = {};\n\nconst parser = new CssSelectorParser();\nparser.registerSelectorPseudos('has');\nparser.registerNestingOperators('>', '+', '~');\nparser.registerAttrEqualityMods('^', '$', '*', '~');\nparser.enableSubstitutes();\n\nconst RESOURCE_ID = 'resource-id';\nconst ID_LOCATOR_PATTERN = /^[a-zA-Z_][a-zA-Z0-9._]*:id\\/[\\S]+$/;\n\nconst BOOLEAN_ATTRS = [\n  'checkable', 'checked', 'clickable', 'enabled', 'focusable',\n  'focused', 'long-clickable', 'scrollable', 'selected',\n];\n\nconst NUMERIC_ATTRS = [\n  'index', 'instance',\n];\n\nconst STR_ATTRS = [\n  'description', RESOURCE_ID, 'text', 'class-name', 'package-name'\n];\n\nconst ALL_ATTRS = [\n  ...BOOLEAN_ATTRS,\n  ...NUMERIC_ATTRS,\n  ...STR_ATTRS,\n];\n\nconst ATTRIBUTE_ALIASES = [\n  [RESOURCE_ID, ['id']],\n  ['description', [\n    'content-description', 'content-desc',\n    'desc', 'accessibility-id',\n  ]],\n  ['index', ['nth-child']],\n];\n\n/**\n * Convert hyphen separated word to snake case\n *\n * @param {string} str\n * @returns {string} The hyphen separated word translated to snake case\n */\nfunction toSnakeCase (str) {\n  if (!str) {\n    return '';\n  }\n  const tokens = str.split('-').map((str) => str.charAt(0).toUpperCase() + str.slice(1).toLowerCase());\n  const out = tokens.join('');\n  return out.charAt(0).toLowerCase() + out.slice(1);\n}\n\n/**\n * @typedef {Object} CssNameValueObject\n * @property {?name} name The name of the CSS object\n * @property {?string} value The value of the CSS object\n */\n\n/**\n * Get the boolean from a CSS object. If empty, return true. If not true/false/empty, throw exception\n *\n * @param {CssNameValueObject} css A CSS object that has 'name' and 'value'\n * @returns {string} Either 'true' or 'false'. If value is empty, return 'true'\n */\nfunction assertGetBool (css) {\n  const val = css.value?.toLowerCase() || 'true'; // an omitted boolean attribute means 'true' (e.g.: input[checked] means checked is true)\n  if (['true', 'false'].includes(val)) {\n    return val;\n  }\n  throw new Error(`'${css.name}' must be true, false or empty. Found '${css.value}'`);\n}\n\n/**\n * Get the canonical form of a CSS attribute name\n *\n * Converts to lowercase and if an attribute name is an alias for something else, return\n * what it is an alias for\n *\n * @param {Object} css CSS object\n * @returns {string} The canonical attribute name\n */\nfunction assertGetAttrName (css) {\n  const attrName = css.name.toLowerCase();\n\n  // Check if it's supported and if it is, return it\n  if (ALL_ATTRS.includes(attrName)) {\n    return attrName.toLowerCase();\n  }\n\n  // If attrName is an alias for something else, return that\n  for (const [officialAttr, aliasAttrs] of ATTRIBUTE_ALIASES) {\n    if (aliasAttrs.includes(attrName)) {\n      return officialAttr;\n    }\n  }\n  throw new Error(`'${attrName}' is not a valid attribute. ` +\n    `Supported attributes are '${ALL_ATTRS.join(', ')}'`);\n}\n\n/**\n * Get a regex that matches a whole word. For the ~= CSS attribute selector.\n *\n * @param {string} word\n * @returns {string} A regex \"word\" matcher\n */\nfunction getWordMatcherRegex (word) {\n  return `\\\\b(\\\\w*${escapeRegExp(word)}\\\\w*)\\\\b`;\n}\n\n/**\n * Add android:id/ to beginning of string if it's not there already\n *\n * @param {string} locator The initial locator\n * @returns {string} String with `android:id/` prepended (if it wasn't already)\n */\nfunction formatIdLocator (locator) {\n  return ID_LOCATOR_PATTERN.test(locator) ? locator : `android:id/${locator}`;\n}\n\n/**\n * @typedef {Object} CssAttr\n * @property {?string} valueType Type of attribute (must be string or empty)\n * @property {?string} value Value of the attribute\n * @property {?string} operator The operator between value and value type (=, *=, , ^=, $=)\n */\n\n/**\n * Convert a CSS attribute into a UiSelector method call\n *\n * @param {CssAttr} cssAttr CSS attribute object\n * @returns {string} CSS attribute parsed as UiSelector\n */\nfunction parseAttr (cssAttr) {\n  if (cssAttr.valueType && cssAttr.valueType !== 'string') {\n    throw new Error(`'${cssAttr.name}=${cssAttr.value}' is an invalid attribute. ` +\n      `Only 'string' and empty attribute types are supported. Found '${cssAttr.valueType}'`);\n  }\n  const attrName = assertGetAttrName(cssAttr);\n  const methodName = toSnakeCase(attrName);\n\n  // Validate that it's a supported attribute\n  if (!STR_ATTRS.includes(attrName) && !BOOLEAN_ATTRS.includes(attrName)) {\n    throw new Error(`'${attrName}' is not supported. Supported attributes are ` +\n      `'${[...STR_ATTRS, ...BOOLEAN_ATTRS].join(', ')}'`);\n  }\n\n  // Parse boolean, if it's a boolean attribute\n  if (BOOLEAN_ATTRS.includes(attrName)) {\n    return `.${methodName}(${assertGetBool(cssAttr)})`;\n  }\n\n  // Otherwise parse as string\n  let value = cssAttr.value || '';\n  if (attrName === RESOURCE_ID) {\n    value = formatIdLocator(value);\n  }\n  if (value === '') {\n    return `.${methodName}Matches(\"\")`;\n  }\n\n  switch (cssAttr.operator) {\n    case '=':\n      return `.${methodName}(\"${value}\")`;\n    case '*=':\n      if (['description', 'text'].includes(attrName)) {\n        return `.${methodName}Contains(\"${value}\")`;\n      }\n      return `.${methodName}Matches(\"${escapeRegExp(value)}\")`;\n    case '^=':\n      if (['description', 'text'].includes(attrName)) {\n        return `.${methodName}StartsWith(\"${value}\")`;\n      }\n      return `.${methodName}Matches(\"^${escapeRegExp(value)}\")`;\n    case '$=':\n      return `.${methodName}Matches(\"${escapeRegExp(value)}$\")`;\n    case '~=':\n      return `.${methodName}Matches(\"${getWordMatcherRegex(value)}\")`;\n    default:\n      // Unreachable, but adding error in case a new CSS attribute is added.\n      throw new Error(`Unsupported CSS attribute operator '${cssAttr.operator}'. ` +\n        ` '=', '*=', '^=', '$=' and '~=' are supported.`);\n  }\n}\n\n/**\n * @typedef {Object} CssPseudo\n * @property {?string} valueType The type of CSS pseudo selector (https://www.npmjs.com/package/css-selector-parser for reference)\n * @property {?string} name The name of the pseudo selector\n * @property {?string} value The value of the pseudo selector\n */\n\n/**\n * Convert a CSS pseudo class to a UiSelector\n *\n * @param {CssPseudo} cssPseudo CSS Pseudo class\n * @returns {string} Pseudo selector parsed as UiSelector\n */\nfunction parsePseudo (cssPseudo) {\n  if (cssPseudo.valueType && cssPseudo.valueType !== 'string') {\n    throw new Error(`'${cssPseudo.name}=${cssPseudo.value}'. ` +\n      `Unsupported css pseudo class value type: '${cssPseudo.valueType}'. Only 'string' type or empty is supported.`);\n  }\n\n  const pseudoName = assertGetAttrName(cssPseudo);\n\n  if (BOOLEAN_ATTRS.includes(pseudoName)) {\n    return `.${toSnakeCase(pseudoName)}(${assertGetBool(cssPseudo)})`;\n  }\n\n  if (NUMERIC_ATTRS.includes(pseudoName)) {\n    return `.${pseudoName}(${cssPseudo.value})`;\n  }\n}\n\n/**\n * @typedef {Object} CssRule\n * @property {?string} nestingOperator The nesting operator (aka: combinator https://developer.mozilla.org/en-US/docs/Web/CSS/CSS_Selectors)\n * @property {?string} tagName The tag name (aka: type selector https://developer.mozilla.org/en-US/docs/Web/CSS/Type_selectors)\n * @property {?string[]} classNames An array of CSS class names\n * @property {?CssAttr[]} attrs An array of CSS attributes\n * @property {?CssPseudo[]} attrs An array of CSS pseudos\n * @property {?string} id CSS identifier\n * @property {?CssRule} rule A descendant of this CSS rule\n */\n\n/**\n * Convert a CSS rule to a UiSelector\n * @param {CssRule} cssRule CSS rule definition\n */\nfunction parseCssRule (cssRule) {\n  const { nestingOperator } = cssRule;\n  if (nestingOperator && nestingOperator !== ' ') {\n    throw new Error(`'${nestingOperator}' is not a supported combinator. ` +\n      `Only child combinator (>) and descendant combinator are supported.`);\n  }\n\n  let uiAutomatorSelector = 'new UiSelector()';\n  if (cssRule.tagName && cssRule.tagName !== '*') {\n    let androidClass = [cssRule.tagName];\n    if (cssRule.classNames) {\n      for (const cssClassNames of cssRule.classNames) {\n        androidClass.push(cssClassNames);\n      }\n      uiAutomatorSelector += `.className(\"${androidClass.join('.')}\")`;\n    } else {\n      uiAutomatorSelector += `.classNameMatches(\"${cssRule.tagName}\")`;\n    }\n  } else if (cssRule.classNames) {\n    uiAutomatorSelector += `.classNameMatches(\"${cssRule.classNames.join('\\\\.')}\")`;\n  }\n  if (cssRule.id) {\n    uiAutomatorSelector += `.resourceId(\"${formatIdLocator(cssRule.id)}\")`;\n  }\n  if (cssRule.attrs) {\n    for (const attr of cssRule.attrs) {\n      uiAutomatorSelector += parseAttr(attr);\n    }\n  }\n  if (cssRule.pseudos) {\n    for (const pseudo of cssRule.pseudos) {\n      uiAutomatorSelector += parsePseudo(pseudo);\n    }\n  }\n  if (cssRule.rule) {\n    uiAutomatorSelector += `.childSelector(${parseCssRule(cssRule.rule)})`;\n  }\n  return uiAutomatorSelector;\n}\n\n/**\n * @typedef {Object} CssObject\n * @property {?string} type Type of CSS object. 'rule', 'ruleset' or 'selectors'\n */\n\n/**\n * Convert CSS object to UiAutomator2 selector\n * @param {CssObject} css CSS object\n * @returns {string} The CSS object parsed as a UiSelector\n */\nfunction parseCssObject (css) {\n  switch (css.type) {\n    case 'rule':\n      return parseCssRule(css);\n    case 'ruleSet':\n      return parseCssObject(css.rule);\n    case 'selectors':\n      return css.selectors.map((selector) => parseCssObject(selector)).join('; ');\n\n    default:\n      // This is never reachable, but if it ever is do this.\n      throw new Error(`UiAutomator does not support '${css.type}' css. Only supports 'rule', 'ruleSet', 'selectors' `);\n  }\n}\n\n/**\n * Convert a CSS selector to a UiAutomator2 selector\n * @param {string} cssSelector CSS Selector\n * @returns {string} The CSS selector converted to a UiSelector\n */\nCssConverter.toUiAutomatorSelector = function toUiAutomatorSelector (cssSelector) {\n  let cssObj;\n  try {\n    cssObj = parser.parse(cssSelector);\n  } catch (e) {\n    throw new errors.InvalidSelectorError(`Invalid CSS selector '${cssSelector}'. Reason: '${e}'`);\n  }\n  try {\n    return parseCssObject(cssObj);\n  } catch (e) {\n    throw new errors.InvalidSelectorError(`Unsupported CSS selector '${cssSelector}'. Reason: '${e}'`);\n  }\n};\n\nexport default CssConverter;"],"file":"lib/css-converter.js","sourceRoot":"../.."}
240
+ //# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["lib/css-converter.js"],"names":["parser","CssSelectorParser","registerSelectorPseudos","registerNestingOperators","registerAttrEqualityMods","enableSubstitutes","RESOURCE_ID","ID_LOCATOR_PATTERN","BOOLEAN_ATTRS","NUMERIC_ATTRS","STR_ATTRS","ALL_ATTRS","ATTRIBUTE_ALIASES","toSnakeCase","str","tokens","split","map","charAt","toUpperCase","slice","toLowerCase","out","join","assertGetBool","css","val","value","includes","Error","name","assertGetAttrName","attrName","officialAttr","aliasAttrs","getWordMatcherRegex","word","CssConverter","constructor","selector","pkg","formatIdLocator","locator","test","parseAttr","cssAttr","valueType","methodName","operator","parsePseudo","cssPseudo","pseudoName","parseCssRule","cssRule","nestingOperator","uiAutomatorSelector","tagName","androidClass","classNames","cssClassNames","push","id","attrs","attr","pseudos","pseudo","rule","parseCssObject","type","selectors","toUiAutomatorSelector","cssObj","parse","e","errors","InvalidSelectorError"],"mappings":"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","sourcesContent":["import { CssSelectorParser } from 'css-selector-parser';\nimport { escapeRegExp } from 'lodash';\nimport { errors } from '@appium/base-driver';\n\nconst parser = new CssSelectorParser();\nparser.registerSelectorPseudos('has');\nparser.registerNestingOperators('>', '+', '~');\nparser.registerAttrEqualityMods('^', '$', '*', '~');\nparser.enableSubstitutes();\n\nconst RESOURCE_ID = 'resource-id';\nconst ID_LOCATOR_PATTERN = /^[a-zA-Z_][a-zA-Z0-9._]*:id\\/[\\S]+$/;\n\nconst BOOLEAN_ATTRS = [\n  'checkable', 'checked', 'clickable', 'enabled', 'focusable',\n  'focused', 'long-clickable', 'scrollable', 'selected',\n];\n\nconst NUMERIC_ATTRS = [\n  'index', 'instance',\n];\n\nconst STR_ATTRS = [\n  'description', RESOURCE_ID, 'text', 'class-name', 'package-name'\n];\n\nconst ALL_ATTRS = [\n  ...BOOLEAN_ATTRS,\n  ...NUMERIC_ATTRS,\n  ...STR_ATTRS,\n];\n\nconst ATTRIBUTE_ALIASES = [\n  [RESOURCE_ID, ['id']],\n  ['description', [\n    'content-description', 'content-desc',\n    'desc', 'accessibility-id',\n  ]],\n  ['index', ['nth-child']],\n];\n\n/**\n * Convert hyphen separated word to snake case\n *\n * @param {string} str\n * @returns {string} The hyphen separated word translated to snake case\n */\nfunction toSnakeCase (str) {\n  if (!str) {\n    return '';\n  }\n  const tokens = str.split('-').map((str) => str.charAt(0).toUpperCase() + str.slice(1).toLowerCase());\n  const out = tokens.join('');\n  return out.charAt(0).toLowerCase() + out.slice(1);\n}\n\n/**\n * @typedef {Object} CssNameValueObject\n * @property {?name} name The name of the CSS object\n * @property {?string} value The value of the CSS object\n */\n\n/**\n * Get the boolean from a CSS object. If empty, return true. If not true/false/empty, throw exception\n *\n * @param {CssNameValueObject} css A CSS object that has 'name' and 'value'\n * @returns {string} Either 'true' or 'false'. If value is empty, return 'true'\n */\nfunction assertGetBool (css) {\n  const val = css.value?.toLowerCase() || 'true'; // an omitted boolean attribute means 'true' (e.g.: input[checked] means checked is true)\n  if (['true', 'false'].includes(val)) {\n    return val;\n  }\n  throw new Error(`'${css.name}' must be true, false or empty. Found '${css.value}'`);\n}\n\n/**\n * Get the canonical form of a CSS attribute name\n *\n * Converts to lowercase and if an attribute name is an alias for something else, return\n * what it is an alias for\n *\n * @param {Object} css CSS object\n * @returns {string} The canonical attribute name\n */\nfunction assertGetAttrName (css) {\n  const attrName = css.name.toLowerCase();\n\n  // Check if it's supported and if it is, return it\n  if (ALL_ATTRS.includes(attrName)) {\n    return attrName.toLowerCase();\n  }\n\n  // If attrName is an alias for something else, return that\n  for (const [officialAttr, aliasAttrs] of ATTRIBUTE_ALIASES) {\n    if (aliasAttrs.includes(attrName)) {\n      return officialAttr;\n    }\n  }\n  throw new Error(`'${attrName}' is not a valid attribute. ` +\n    `Supported attributes are '${ALL_ATTRS.join(', ')}'`);\n}\n\n/**\n * Get a regex that matches a whole word. For the ~= CSS attribute selector.\n *\n * @param {string} word\n * @returns {string} A regex \"word\" matcher\n */\nfunction getWordMatcherRegex (word) {\n  return `\\\\b(\\\\w*${escapeRegExp(word)}\\\\w*)\\\\b`;\n}\n\n/**\n * @typedef {Object} CssAttr\n * @property {?string} valueType Type of attribute (must be string or empty)\n * @property {?string} value Value of the attribute\n * @property {?string} operator The operator between value and value type (=, *=, , ^=, $=)\n */\n\n/**\n * @typedef {Object} CssRule\n * @property {?string} nestingOperator The nesting operator (aka: combinator https://developer.mozilla.org/en-US/docs/Web/CSS/CSS_Selectors)\n * @property {?string} tagName The tag name (aka: type selector https://developer.mozilla.org/en-US/docs/Web/CSS/Type_selectors)\n * @property {?string[]} classNames An array of CSS class names\n * @property {?CssAttr[]} attrs An array of CSS attributes\n * @property {?CssPseudo[]} attrs An array of CSS pseudos\n * @property {?string} id CSS identifier\n * @property {?CssRule} rule A descendant of this CSS rule\n */\n\n/**\n * @typedef {Object} CssObject\n * @property {?string} type Type of CSS object. 'rule', 'ruleset' or 'selectors'\n */\n\n/**\n * @typedef {Object} CssPseudo\n * @property {?string} valueType The type of CSS pseudo selector (https://www.npmjs.com/package/css-selector-parser for reference)\n * @property {?string} name The name of the pseudo selector\n * @property {?string} value The value of the pseudo selector\n */\n\nclass CssConverter {\n\n  constructor (selector, pkg) {\n    this.selector = selector;\n    this.pkg = pkg;\n  }\n\n  /**\n   * Add `<pkgName>:id/` prefix to beginning of string if it's not there already\n   *\n   * @param {string} locator The initial locator\n   * @returns {string} String with `<pkgName>:id/` prepended (if it wasn't already)\n   */\n  formatIdLocator (locator) {\n    return ID_LOCATOR_PATTERN.test(locator)\n      ? locator\n      : `${this.pkg || 'android'}:id/${locator}`;\n  }\n\n  /**\n   * Convert a CSS attribute into a UiSelector method call\n   *\n   * @param {CssAttr} cssAttr CSS attribute object\n   * @returns {string} CSS attribute parsed as UiSelector\n   */\n  parseAttr (cssAttr) {\n    if (cssAttr.valueType && cssAttr.valueType !== 'string') {\n      throw new Error(`'${cssAttr.name}=${cssAttr.value}' is an invalid attribute. ` +\n        `Only 'string' and empty attribute types are supported. Found '${cssAttr.valueType}'`);\n    }\n    const attrName = assertGetAttrName(cssAttr);\n    const methodName = toSnakeCase(attrName);\n\n    // Validate that it's a supported attribute\n    if (!STR_ATTRS.includes(attrName) && !BOOLEAN_ATTRS.includes(attrName)) {\n      throw new Error(`'${attrName}' is not supported. Supported attributes are ` +\n        `'${[...STR_ATTRS, ...BOOLEAN_ATTRS].join(', ')}'`);\n    }\n\n    // Parse boolean, if it's a boolean attribute\n    if (BOOLEAN_ATTRS.includes(attrName)) {\n      return `.${methodName}(${assertGetBool(cssAttr)})`;\n    }\n\n    // Otherwise parse as string\n    let value = cssAttr.value || '';\n    if (attrName === RESOURCE_ID) {\n      value = this.formatIdLocator(value);\n    }\n    if (value === '') {\n      return `.${methodName}Matches(\"\")`;\n    }\n\n    switch (cssAttr.operator) {\n      case '=':\n        return `.${methodName}(\"${value}\")`;\n      case '*=':\n        if (['description', 'text'].includes(attrName)) {\n          return `.${methodName}Contains(\"${value}\")`;\n        }\n        return `.${methodName}Matches(\"${escapeRegExp(value)}\")`;\n      case '^=':\n        if (['description', 'text'].includes(attrName)) {\n          return `.${methodName}StartsWith(\"${value}\")`;\n        }\n        return `.${methodName}Matches(\"^${escapeRegExp(value)}\")`;\n      case '$=':\n        return `.${methodName}Matches(\"${escapeRegExp(value)}$\")`;\n      case '~=':\n        return `.${methodName}Matches(\"${getWordMatcherRegex(value)}\")`;\n      default:\n        // Unreachable, but adding error in case a new CSS attribute is added.\n        throw new Error(`Unsupported CSS attribute operator '${cssAttr.operator}'. ` +\n          ` '=', '*=', '^=', '$=' and '~=' are supported.`);\n    }\n  }\n\n  /**\n   * Convert a CSS pseudo class to a UiSelector\n   *\n   * @param {CssPseudo} cssPseudo CSS Pseudo class\n   * @returns {string} Pseudo selector parsed as UiSelector\n   */\n  parsePseudo (cssPseudo) {\n    if (cssPseudo.valueType && cssPseudo.valueType !== 'string') {\n      throw new Error(`'${cssPseudo.name}=${cssPseudo.value}'. ` +\n        `Unsupported css pseudo class value type: '${cssPseudo.valueType}'. Only 'string' type or empty is supported.`);\n    }\n\n    const pseudoName = assertGetAttrName(cssPseudo);\n\n    if (BOOLEAN_ATTRS.includes(pseudoName)) {\n      return `.${toSnakeCase(pseudoName)}(${assertGetBool(cssPseudo)})`;\n    }\n\n    if (NUMERIC_ATTRS.includes(pseudoName)) {\n      return `.${pseudoName}(${cssPseudo.value})`;\n    }\n  }\n\n  /**\n   * Convert a CSS rule to a UiSelector\n   * @param {CssRule} cssRule CSS rule definition\n   */\n  parseCssRule (cssRule) {\n    const { nestingOperator } = cssRule;\n    if (nestingOperator && nestingOperator !== ' ') {\n      throw new Error(`'${nestingOperator}' is not a supported combinator. ` +\n        `Only child combinator (>) and descendant combinator are supported.`);\n    }\n\n    let uiAutomatorSelector = 'new UiSelector()';\n    if (cssRule.tagName && cssRule.tagName !== '*') {\n      let androidClass = [cssRule.tagName];\n      if (cssRule.classNames) {\n        for (const cssClassNames of cssRule.classNames) {\n          androidClass.push(cssClassNames);\n        }\n        uiAutomatorSelector += `.className(\"${androidClass.join('.')}\")`;\n      } else {\n        uiAutomatorSelector += `.classNameMatches(\"${cssRule.tagName}\")`;\n      }\n    } else if (cssRule.classNames) {\n      uiAutomatorSelector += `.classNameMatches(\"${cssRule.classNames.join('\\\\.')}\")`;\n    }\n    if (cssRule.id) {\n      uiAutomatorSelector += `.resourceId(\"${this.formatIdLocator(cssRule.id)}\")`;\n    }\n    if (cssRule.attrs) {\n      for (const attr of cssRule.attrs) {\n        uiAutomatorSelector += this.parseAttr(attr);\n      }\n    }\n    if (cssRule.pseudos) {\n      for (const pseudo of cssRule.pseudos) {\n        uiAutomatorSelector += this.parsePseudo(pseudo);\n      }\n    }\n    if (cssRule.rule) {\n      uiAutomatorSelector += `.childSelector(${this.parseCssRule(cssRule.rule)})`;\n    }\n    return uiAutomatorSelector;\n  }\n\n  /**\n   * Convert CSS object to UiAutomator2 selector\n   * @param {CssObject} css CSS object\n   * @returns {string} The CSS object parsed as a UiSelector\n   */\n  parseCssObject (css) {\n    switch (css.type) {\n      case 'rule':\n        return this.parseCssRule(css);\n      case 'ruleSet':\n        return this.parseCssObject(css.rule);\n      case 'selectors':\n        return css.selectors.map((selector) => this.parseCssObject(selector)).join('; ');\n\n      default:\n        // This is never reachable, but if it ever is do this.\n        throw new Error(`UiAutomator does not support '${css.type}' css. Only supports 'rule', 'ruleSet', 'selectors' `);\n    }\n  }\n\n  /**\n   * Convert a CSS selector to a UiAutomator2 selector\n   *\n   * @returns {string} The CSS selector converted to a UiSelector\n   */\n  toUiAutomatorSelector () {\n    let cssObj;\n    try {\n      cssObj = parser.parse(this.selector);\n    } catch (e) {\n      throw new errors.InvalidSelectorError(`Invalid CSS selector '${this.selector}'. Reason: '${e}'`);\n    }\n    try {\n      return this.parseCssObject(cssObj);\n    } catch (e) {\n      throw new errors.InvalidSelectorError(`Unsupported CSS selector '${this.selector}'. Reason: '${e}'`);\n    }\n  }\n}\n\nexport default CssConverter;"],"file":"lib/css-converter.js","sourceRoot":"../.."}