UNPKG

@bianic-ui/utils

Version:

Common utilties and types for Bianic UI

79 lines (70 loc) 3.35 kB
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