forked from nightwatchjs/nightwatch
-
Notifications
You must be signed in to change notification settings - Fork 0
/
findElementByText.js
43 lines (38 loc) · 1.6 KB
/
findElementByText.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
const LocateStrategy = require('../../element/strategy.js');
const FindElement = require('./findElement.js');
/**
* Returns an element's first child. The child element will be returned as web element JSON object (with an added .getId() convenience method).
*
*
* @example
* module.exports = {
* 'demo Test': function(browser) {
* const resultElement = await browser.getFirstElementChild('.features-container');
*
* console.log('last child element Id:', resultElement.getId());
* },
*
* @syntax browser.getFirstElementChild(selector, callback)
* @syntax browser.getFirstElementChild(selector)
* @param {string} [using] The locator strategy to use. See [W3C Webdriver - locator strategies](https://www.w3.org/TR/webdriver/#locator-strategies)
* @param {string|object} selector The selector (CSS/Xpath) used to locate the element. Can either be a string or an object which specifies [element properties](https://nightwatchjs.org/guide#element-properties).
* @param {function} callback Callback function which is called with the result value.
* @method getFirstElementChild
* @since 2.0.0
* @moreinfo developer.mozilla.org/en-US/docs/Web/API/Element/firstElementChild
* @api protocol.elements
*/
class FindElementByText extends FindElement {
get selector() {
if (this.args[1] && this.args[1].exact === true) {
return `//${this.__selector}[text()='${this.args[0]}']`;
}
return `//${this.__selector}[contains(text(), '${this.args[0]}')]`;
}
setStrategy() {
this.__strategy = LocateStrategy.XPATH;
return this;
}
setStrategyFromArgs() {}
}
module.exports = FindElementByText;