Files
enviPy-bayer/static/js/ketcher2/node_modules/webdriverio/lib/protocol/elementIdElement.js
2025-06-23 20:13:54 +02:00

62 lines
2.1 KiB
JavaScript

/**
*
* Search for an element on the page, starting from an element.
* The located element will be returned as a WebElement JSON object.
* The table below lists the locator strategies that each server should support.
* Each locator must return the first matching element located in the DOM.
*
* @param {String} ID ID of a WebElement JSON object to route the command to
* @param {String} selector selector to query the element
* @return {String} A WebElement JSON object for the located element.
*
* @see https://w3c.github.io/webdriver/webdriver-spec.html#find-element-from-element
* @type protocol
*
*/
import { ProtocolError } from '../utils/ErrorHandler'
import findStrategy from '../helpers/findElementStrategy'
export default function elementIdElement (id, selector) {
if (typeof id !== 'string' && typeof id !== 'number') {
throw new ProtocolError('number or type of arguments don\'t agree with elementIdElement protocol command')
}
let found = findStrategy(selector, true)
return this.requestHandler.create(`/session/:sessionId/element/${id}/element`, {
using: found.using,
value: found.value
}).then((result) => {
result.selector = selector
/**
* W3C webdriver protocol has changed element identifier from `ELEMENT` to
* `element-6066-11e4-a52e-4f735466cecf`. Let's make sure both identifier
* are supported.
*/
const elemValue = result.value.ELEMENT || result.value['element-6066-11e4-a52e-4f735466cecf']
result.value = {
ELEMENT: elemValue,
'element-6066-11e4-a52e-4f735466cecf': elemValue
}
return result
}, (e) => {
let result = e.seleniumStack
/**
* if error is not NoSuchElement throw it
*/
if (!result || result.type !== 'NoSuchElement') {
throw e
}
result.state = 'failure'
result.sessionId = this.requestHandler.sessionID
result.value = null
result.selector = selector
delete result.orgStatusMessage
return result
})
}