-
Notifications
You must be signed in to change notification settings - Fork 791
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
feat(qsa, flatten-tree): abstract Node and Element apis in virtual tr…
…ee (#1562) * feat(qsa, flatten-tree): abstract Node and Element apis in virtual tree * create VirtualNode constructor function and tests * make VirtualNode a class, happy path * fix non-supported IE11 .remove() * typecheck propertly * convert new code to use vNode cache function rather than property * rename node to vNode * change back to getters * fix tests
- Loading branch information
Showing
5 changed files
with
381 additions
and
182 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,85 @@ | ||
const whitespaceRegex = /[\t\r\n\f]/g; | ||
|
||
// class is unused in the file... | ||
// eslint-disable-next-line no-unused-vars | ||
class VirtualNode { | ||
/** | ||
* Wrap the real node and provide list of the flattened children | ||
* | ||
* @param node {Node} - the node in question | ||
* @param shadowId {String} - the ID of the shadow DOM to which this node belongs | ||
*/ | ||
constructor(node, shadowId) { | ||
this.shadowId = shadowId; | ||
this.children = []; | ||
this.actualNode = node; | ||
|
||
this._isHidden = null; // will be populated by axe.utils.isHidden | ||
this._cache = {}; | ||
|
||
// abstract Node and Element APIs so we can run axe in DOM-less | ||
// environments. these are static properties in the assumption | ||
// that axe does not change any of them while it runs. | ||
this.elementNodeType = node.nodeType; | ||
this.elementNodeName = node.nodeName.toLowerCase(); | ||
this.elementId = node.id; | ||
|
||
if (axe._cache.get('nodeMap')) { | ||
axe._cache.get('nodeMap').set(node, this); | ||
} | ||
} | ||
|
||
/** | ||
* Determine if the actualNode has the given class name. | ||
* @see https://j11y.io/jquery/#v=2.0.3&fn=jQuery.fn.hasClass | ||
* @param {String} className - The class to check for. | ||
* @return {Boolean} True if the actualNode has the given class, false otherwise. | ||
*/ | ||
hasClass(className) { | ||
if (typeof this.actualNode.className !== 'string') { | ||
return false; | ||
} | ||
|
||
let selector = ' ' + className + ' '; | ||
return ( | ||
(' ' + this.actualNode.className + ' ') | ||
.replace(whitespaceRegex, ' ') | ||
.indexOf(selector) >= 0 | ||
); | ||
} | ||
|
||
/** | ||
* Get the value of the given attribute name. | ||
* @param {String} attrName - The name of the attribute. | ||
* @returns {String|null} The value of the attribute or null if the attribute does not exist | ||
*/ | ||
attr(attrName) { | ||
if (typeof this.actualNode.getAttribute !== 'function') { | ||
return null; | ||
} | ||
|
||
return this.actualNode.getAttribute(attrName); | ||
} | ||
|
||
/** | ||
* Determine if the element is focusable and cache the result. | ||
* @return {Boolean} True if the element is focusable, false otherwise. | ||
*/ | ||
get isFocusable() { | ||
if (!this._cache.hasOwnProperty('isFocusable')) { | ||
this._cache.isFocusable = axe.commons.dom.isFocusable(this.actualNode); | ||
} | ||
return this._cache.isFocusable; | ||
} | ||
|
||
/** | ||
* Return the list of tabbable elements for this element and cache the result. | ||
* @returns {VirtualNode[]} | ||
*/ | ||
get tabbableElements() { | ||
if (!this._cache.hasOwnProperty('tabbableElements')) { | ||
this._cache.tabbableElements = axe.commons.dom.getTabbableElements(this); | ||
} | ||
return this._cache.tabbableElements; | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.