element3
Version:
A Component Library for Vue3
131 lines (115 loc) • 2.92 kB
JavaScript
// eslint-disable-next-line no-use-before-define
var aria = aria || {}
aria.Utils = aria.Utils || {}
/**
* @desc Set focus on descendant nodes until the first focusable element is
* found.
* @param element
* DOM node for which to find the first focusable descendant.
* @returns
* true if a focusable element is found and focus is set.
*/
aria.Utils.focusFirstDescendant = function (element) {
for (var i = 0; i < element.childNodes.length; i++) {
var child = element.childNodes[i]
if (
aria.Utils.attemptFocus(child) ||
aria.Utils.focusFirstDescendant(child)
) {
return true
}
}
return false
}
/**
* @desc Find the last descendant node that is focusable.
* @param element
* DOM node for which to find the last focusable descendant.
* @returns
* true if a focusable element is found and focus is set.
*/
aria.Utils.focusLastDescendant = function (element) {
for (var i = element.childNodes.length - 1; i >= 0; i--) {
var child = element.childNodes[i]
if (
aria.Utils.attemptFocus(child) ||
aria.Utils.focusLastDescendant(child)
) {
return true
}
}
return false
}
/**
* @desc Set Attempt to set focus on the current node.
* @param element
* The node to attempt to focus on.
* @returns
* true if element is focused.
*/
aria.Utils.attemptFocus = function (element) {
if (!aria.Utils.isFocusable(element)) {
return false
}
aria.Utils.IgnoreUtilFocusChanges = true
if (element && element.focus) {
element.focus()
}
aria.Utils.IgnoreUtilFocusChanges = false
return document.activeElement === element
}
aria.Utils.isFocusable = function (element) {
if (
element.tabIndex > 0 ||
(element.tabIndex === 0 && element.getAttribute('tabIndex') !== null)
) {
return true
}
if (element.disabled) {
return false
}
switch (element.nodeName) {
case 'A':
return !!element.href && element.rel !== 'ignore'
case 'INPUT':
return element.type !== 'hidden' && element.type !== 'file'
case 'BUTTON':
case 'SELECT':
case 'TEXTAREA':
return true
default:
return false
}
}
/**
* 触发一个事件
* mouseenter, mouseleave, mouseover, keyup, change, click 等
* @param {Element} elm
* @param {String} name
* @param {*} opts
*/
aria.Utils.triggerEvent = function (elm, name, ...opts) {
let eventName
if (/^mouse|click/.test(name)) {
eventName = 'MouseEvents'
} else if (/^key/.test(name)) {
eventName = 'KeyboardEvent'
} else {
eventName = 'HTMLEvents'
}
const evt = document.createEvent(eventName)
evt.initEvent(name, ...opts)
elm.dispatchEvent ? elm.dispatchEvent(evt) : elm.fireEvent('on' + name, evt)
return elm
}
aria.Utils.keys = {
tab: 9,
enter: 13,
space: 32,
left: 37,
up: 38,
right: 39,
down: 40,
esc: 27
}
export default aria.Utils