From d375a6d4576d0fb6e525d10d9ba493ea624b04a5 Mon Sep 17 00:00:00 2001 From: Asko Soukka Date: Sat, 17 Aug 2024 19:39:35 +0300 Subject: [PATCH] Add arrow key navigation for tabs; Autoselect tab on arrow key navigation; Fix tab to stop only once in tablist --- .../static/sphinxcontrib-httpexample.js | 30 ++++++++++++++----- 1 file changed, 22 insertions(+), 8 deletions(-) diff --git a/src/sphinxcontrib/httpexample/static/sphinxcontrib-httpexample.js b/src/sphinxcontrib/httpexample/static/sphinxcontrib-httpexample.js index 39e271c..f28cfbb 100644 --- a/src/sphinxcontrib/httpexample/static/sphinxcontrib-httpexample.js +++ b/src/sphinxcontrib/httpexample/static/sphinxcontrib-httpexample.js @@ -18,7 +18,7 @@ document.addEventListener("DOMContentLoaded", function() { } // Process each caption element - captions.forEach(function(caption) { + captions.forEach(function(caption, index) { var orphan, block = !!caption.parentElement.id ? caption.parentElement : caption.parentElement.parentElement; block.setAttribute('role', 'tabpanel'); block.setAttribute('tabindex', '0'); @@ -32,16 +32,20 @@ document.addEventListener("DOMContentLoaded", function() { // Click event for captions caption.addEventListener('click', function() { - // Deselect other captions captions.forEach(function(otherCaption) { - otherCaption.setAttribute('aria-selected', 'false'); - otherCaption.classList.remove('selected'); + if (caption === otherCaption) { + // Select the clicked caption + caption.setAttribute('aria-selected', 'true'); + caption.classList.add('selected'); + otherCaption.setAttribute('tabindex', '0'); + } else { + // Deselect other captions + otherCaption.setAttribute('aria-selected', 'false'); + otherCaption.setAttribute('tabindex', '-1'); + otherCaption.classList.remove('selected'); + } }); - // Select the clicked caption - caption.setAttribute('aria-selected', 'true'); - caption.classList.add('selected'); - // Hide other blocks and show the selected one blocks.forEach(function(otherBlock) { if (otherBlock !== block) { @@ -57,6 +61,16 @@ document.addEventListener("DOMContentLoaded", function() { caption.addEventListener('keydown', function(event) { if (event.code === 'Space' || event.code === 'Enter') { caption.click(); + } else if (event.code === 'ArrowRight') { + // Move focus to the next tab + var nextIndex = (index + 1) % captions.length; + captions[nextIndex].focus(); + captions[nextIndex].click(); + } else if (event.code === 'ArrowLeft') { + // Move focus to the previous tab + var prevIndex = (index - 1 + captions.length) % captions.length; + captions[prevIndex].focus(); + captions[prevIndex].click(); } });