From fc61dceddf7ac01d68a5f4bc5f33700d155296c3 Mon Sep 17 00:00:00 2001 From: Nicholas Ruffing Date: Sat, 2 Dec 2023 14:23:02 -0500 Subject: [PATCH] fix(theme-default): code group accessibility --- .../src/client/components/global/CodeGroup.ts | 55 ++++++++----------- .../components/global/CodeGroupItem.vue | 2 +- .../src/client/styles/code-group.scss | 15 ++--- .../theme-default/src/client/styles/vars.scss | 6 ++ 4 files changed, 34 insertions(+), 44 deletions(-) diff --git a/ecosystem/theme-default/src/client/components/global/CodeGroup.ts b/ecosystem/theme-default/src/client/components/global/CodeGroup.ts index 6b1ef6ee52..386d48badc 100644 --- a/ecosystem/theme-default/src/client/components/global/CodeGroup.ts +++ b/ecosystem/theme-default/src/client/components/global/CodeGroup.ts @@ -128,38 +128,29 @@ export const CodeGroup = defineComponent({ return h('div', { class: 'code-group' }, [ h( 'div', - { class: 'code-group__nav' }, - h( - 'ul', - { class: 'code-group__ul' }, - items.map((vnode, i) => { - const isActive = i === activeIndex.value - - return h( - 'li', - { class: 'code-group__li' }, - h( - 'button', - { - ref: (element) => { - if (element) { - tabRefs.value[i] = element as HTMLButtonElement - } - }, - class: { - 'code-group__nav-tab': true, - 'code-group__nav-tab-active': isActive, - }, - ariaPressed: isActive, - ariaExpanded: isActive, - onClick: () => (activeIndex.value = i), - onKeydown: (e) => keyboardHandler(e, i), - }, - vnode.props.title, - ), - ) - }), - ), + { class: 'code-group__nav', role: 'tablist' }, + items.map((vnode, i) => { + const isActive = i === activeIndex.value + return h( + 'button', + { + ref: (element) => { + if (element) { + tabRefs.value[i] = element as HTMLButtonElement + } + }, + class: { + 'code-group__nav-tab': true, + 'code-group__nav-tab-active': isActive, + }, + role: 'tab', + ariaSelected: isActive, + onClick: () => (activeIndex.value = i), + onKeydown: (e) => keyboardHandler(e, i), + }, + vnode.props.title, + ) + }), ), items, ]) diff --git a/ecosystem/theme-default/src/client/components/global/CodeGroupItem.vue b/ecosystem/theme-default/src/client/components/global/CodeGroupItem.vue index a6919300f1..4ecde4d753 100644 --- a/ecosystem/theme-default/src/client/components/global/CodeGroupItem.vue +++ b/ecosystem/theme-default/src/client/components/global/CodeGroupItem.vue @@ -20,7 +20,7 @@ defineProps({
diff --git a/ecosystem/theme-default/src/client/styles/code-group.scss b/ecosystem/theme-default/src/client/styles/code-group.scss index 02d0b3d74e..38d156ce7e 100644 --- a/ecosystem/theme-default/src/client/styles/code-group.scss +++ b/ecosystem/theme-default/src/client/styles/code-group.scss @@ -12,14 +12,7 @@ padding-top: 10px; border-top-left-radius: 6px; border-top-right-radius: 6px; - background-color: var(--code-bg-color); -} - -.code-group__ul { - margin: auto 0; - padding-left: 0; - display: inline-flex; - list-style: none; + background-color: var(--c-code-group-tab-bg); } .code-group__nav-tab { @@ -29,7 +22,7 @@ background-color: transparent; font-size: 0.85em; line-height: 1.4; - color: rgba(255, 255, 255, 0.9); + color: var(--c-code-group-tab-title); font-weight: 600; } @@ -38,11 +31,11 @@ } .code-group__nav-tab:focus-visible { - outline: 1px solid rgba(255, 255, 255, 0.9); + outline: 1px solid var(--c-code-group-tab-outline); } .code-group__nav-tab-active { - border-bottom: var(--c-brand) 1px solid; + border-bottom: var(--c-code-group-tab-active-border) 1px solid; } @media (max-width: $MQMobileNarrow) { diff --git a/ecosystem/theme-default/src/client/styles/vars.scss b/ecosystem/theme-default/src/client/styles/vars.scss index 1a98a067b6..9a07e99697 100644 --- a/ecosystem/theme-default/src/client/styles/vars.scss +++ b/ecosystem/theme-default/src/client/styles/vars.scss @@ -62,6 +62,12 @@ --c-badge-danger: #dc2626; --c-badge-danger-text: var(--c-bg); + // code group colors + --c-code-group-tab-title: rgba(255, 255, 255, 0.9); + --c-code-group-tab-bg: var(--code-bg-color); + --c-code-group-tab-outline: var(var(--c-code-group-tab-title)); + --c-code-group-tab-active-border: var(--c-brand); + // transition vars --t-color: 0.3s ease; --t-transform: 0.3s ease;