devextreme
Version:
HTML5 JavaScript Component Suite for Responsive Web Development
47 lines (45 loc) • 1.74 kB
JavaScript
/**
* DevExtreme (esm/ui/widget/selectors.js)
* Version: 24.2.6
* Build date: Mon Mar 17 2025
*
* Copyright (c) 2012 - 2025 Developer Express Inc. ALL RIGHTS RESERVED
* Read about DevExtreme licensing here: https://js.devexpress.com/Licensing/
*/
import $ from "../../core/renderer";
import domAdapter from "../../core/dom_adapter";
const focusableFn = function(element, tabIndex) {
if (!visible(element)) {
return false
}
const nodeName = element.nodeName.toLowerCase();
const isTabIndexNotNaN = !isNaN(tabIndex);
const isDisabled = element.disabled;
const isDefaultFocus = /^(input|select|textarea|button|object|iframe)$/.test(nodeName);
const isHyperlink = "a" === nodeName;
let isFocusable;
const isContentEditable = element.isContentEditable;
if (isDefaultFocus || isContentEditable) {
isFocusable = !isDisabled
} else if (isHyperlink) {
isFocusable = element.href || isTabIndexNotNaN
} else {
isFocusable = isTabIndexNotNaN
}
return isFocusable
};
function visible(element) {
const $element = $(element);
return $element.is(":visible") && "hidden" !== $element.css("visibility") && "hidden" !== $element.parents().css("visibility")
}
export const focusable = function(index, element) {
return focusableFn(element, $(element).attr("tabIndex"))
};
export const tabbable = function(index, element) {
const tabIndex = $(element).attr("tabIndex");
return (isNaN(tabIndex) || tabIndex >= 0) && focusableFn(element, tabIndex)
};
export const focused = function($element) {
const element = $($element).get(0);
return domAdapter.getActiveElement(element) === element
};