@bianic-ui/utils
Version:
Common utilties and types for Bianic UI
79 lines (70 loc) • 3.35 kB
JavaScript
import { isFocusable, isTabbable, isHTMLElement } from "./tabbable";
var focusableElList = ["input:not([disabled])", "select:not([disabled])", "textarea:not([disabled])", "embed", "iframe", "object", "a[href]", "area[href]", "button:not([disabled])", "[tabindex]", "audio[controls]", "video[controls]", "*[tabindex]:not([aria-disabled])", "*[contenteditable]"];
var focusableElSelector = focusableElList.join();
export var isRightClick = event => event.button != 0;
export function getAllFocusable(container) {
var focusableEls = Array.from(container.querySelectorAll(focusableElSelector));
focusableEls.unshift(container);
return focusableEls.filter(isFocusable).filter(el => window.getComputedStyle(el).display !== "none");
}
export function getFirstFocusable(container) {
var allFocusable = getAllFocusable(container);
return allFocusable.length ? allFocusable[0] : null;
}
export function getAllTabbable(container, fallbackToFocusable) {
var allFocusable = Array.from(container.querySelectorAll(focusableElSelector));
var allTabbable = allFocusable.filter(isTabbable);
if (isTabbable(container)) {
allTabbable.unshift(container);
}
if (!allTabbable.length && fallbackToFocusable) {
return allFocusable;
}
return allTabbable;
}
export function getFirstTabbableIn(container, fallbackToFocusable) {
var [first] = getAllTabbable(container, fallbackToFocusable);
return first || null;
}
export function getLastTabbableIn(container, fallbackToFocusable) {
var allTabbable = getAllTabbable(container, fallbackToFocusable);
return allTabbable[allTabbable.length - 1] || null;
}
export function getNextTabbable(container, fallbackToFocusable) {
var allFocusable = getAllFocusable(container);
var index = allFocusable.indexOf(document.activeElement);
var slice = allFocusable.slice(index + 1);
return slice.find(isTabbable) || allFocusable.find(isTabbable) || (fallbackToFocusable ? slice[0] : null);
}
export function getPreviousTabbable(container, fallbackToFocusable) {
var allFocusable = getAllFocusable(container).reverse();
var index = allFocusable.indexOf(document.activeElement);
var slice = allFocusable.slice(index + 1);
return slice.find(isTabbable) || allFocusable.find(isTabbable) || (fallbackToFocusable ? slice[0] : null);
}
export function focusNextTabbable(container, fallbackToFocusable) {
var nextTabbable = getNextTabbable(container, fallbackToFocusable);
if (nextTabbable && isHTMLElement(nextTabbable)) {
nextTabbable.focus();
}
}
export function focusPreviousTabbable(container, fallbackToFocusable) {
var previousTabbable = getPreviousTabbable(container, fallbackToFocusable);
if (previousTabbable && isHTMLElement(previousTabbable)) {
previousTabbable.focus();
}
}
function matches(element, selectors) {
if ("matches" in element) return element.matches(selectors);
if ("msMatchesSelector" in element) return element.msMatchesSelector(selectors);
return element.webkitMatchesSelector(selectors);
}
export function closest(element, selectors) {
if ("closest" in element) return element.closest(selectors);
do {
if (matches(element, selectors)) return element;
element = element.parentElement || element.parentNode;
} while (element !== null && element.nodeType === 1);
return null;
}
//# sourceMappingURL=dom-query.js.map