From ac88e6e1909d306c797a6361c0ec953cb104f0ca Mon Sep 17 00:00:00 2001 From: Sam Potts Date: Sun, 2 Jun 2019 23:16:29 +1000 Subject: Demo clean up --- demo/src/js/tab-focus.js | 31 +++++++++++++++++++++++++++++++ 1 file changed, 31 insertions(+) create mode 100644 demo/src/js/tab-focus.js (limited to 'demo/src/js/tab-focus.js') diff --git a/demo/src/js/tab-focus.js b/demo/src/js/tab-focus.js new file mode 100644 index 00000000..c1602cf0 --- /dev/null +++ b/demo/src/js/tab-focus.js @@ -0,0 +1,31 @@ +// Setup tab focus +const container = document.getElementById('container'); +const tabClassName = 'tab-focus'; + +// Remove class on blur +document.addEventListener('focusout', event => { + if (!event.target.classList || container.contains(event.target)) { + return; + } + + event.target.classList.remove(tabClassName); +}); + +// Add classname to tabbed elements +document.addEventListener('keydown', event => { + if (event.keyCode !== 9) { + return; + } + + // Delay the adding of classname until the focus has changed + // This event fires before the focusin event + setTimeout(() => { + const focused = document.activeElement; + + if (!focused || !focused.classList || container.contains(focused)) { + return; + } + + focused.classList.add(tabClassName); + }, 10); +}); -- cgit v1.2.3