Improve accessibility of sign-up progress indicator (#38252)

This commit is contained in:
diondiondion 2026-03-17 13:44:40 +01:00 committed by GitHub
parent 5f36c482d2
commit 75c4ff35d2
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
4 changed files with 50 additions and 24 deletions

View File

@ -1257,31 +1257,44 @@ code {
}
.progress-tracker {
--circle-size: 30px;
display: flex;
align-items: center;
padding-bottom: 30px;
margin-bottom: 30px;
li {
flex: 0 0 auto;
position: relative;
}
.separator {
height: 2px;
background: var(--color-border-primary);
flex: 1 1 auto;
--connector-color: var(--color-border-primary);
--connector-thickness: 2px;
&.completed {
background: var(--color-text-brand);
--connector-color: var(--color-bg-brand-base);
}
&:not(:last-child) {
flex-grow: 1;
// Connector line between circles
&::after {
content: '';
display: block;
position: absolute;
inset-inline: var(--circle-size) 0;
background-color: var(--connector-color);
height: 2px;
top: calc((var(--circle-size) - var(--connector-thickness)) / 2);
}
}
}
.circle {
box-sizing: border-box;
position: relative;
width: 30px;
height: 30px;
width: var(--circle-size);
height: var(--circle-size);
border-radius: 50%;
border: 2px solid var(--color-border-primary);
flex: 0 0 auto;
@ -1302,8 +1315,9 @@ code {
padding-top: 10px;
text-align: center;
width: 100px;
left: 50%;
transform: translateX(-50%);
// Center-align the label with the circle
transform: translateX(-33.3333%);
}
li:first-child .label {
@ -1320,15 +1334,15 @@ code {
transform: none;
}
.active .circle {
border-color: var(--color-text-brand);
[aria-current='step'] .circle {
border-color: var(--color-bg-brand-base);
&::before {
content: '';
width: 10px;
height: 10px;
border-radius: 50%;
background: var(--color-text-brand);
background: var(--color-bg-brand-base);
position: absolute;
left: 50%;
top: 50%;
@ -1337,8 +1351,9 @@ code {
}
.completed .circle {
border-color: var(--color-text-brand);
background: var(--color-text-brand);
color: var(--color-text-on-brand-base);
background: var(--color-bg-brand-base);
border-color: var(--color-bg-brand-base);
}
}

View File

@ -1,26 +1,35 @@
- progress_index = { rules: 0, details: 1, confirm: 2, confirmed: 3, completed: 4 }[stage.to_sym]
%ol.progress-tracker
%li{ class: progress_index.positive? ? 'completed' : 'active' }
%ol.progress-tracker{ role: 'list', 'aria-label': t('auth.progress.list') }
%li{
class: progress_index.positive? ? 'completed' : nil,
'aria-current': progress_index.zero? ? 'step' : nil
}
.circle
- if progress_index.positive?
= check_icon
.label= t('auth.progress.rules')
%li.separator{ class: progress_index.positive? ? 'completed' : nil }
%li{ class: [progress_index > 1 && 'completed', progress_index == 1 && 'active'] }
%li{
class: progress_index > 1 && 'completed',
'aria-current': progress_index == 1 ? 'step' : nil
}
.circle
- if progress_index > 1
= check_icon
.label= t('auth.progress.details')
%li.separator{ class: progress_index > 1 ? 'completed' : nil }
%li{ class: [progress_index > 2 && 'completed', progress_index == 2 && 'active'] }
%li{
class: progress_index > 2 && 'completed',
'aria-current': progress_index == 2 ? 'step' : nil
}
.circle
- if progress_index > 2
= check_icon
.label= t('auth.progress.confirm')
- if approved_registrations?
%li.separator{ class: progress_index > 2 ? 'completed' : nil }
%li{ class: [progress_index > 3 && 'completed', progress_index == 3 && 'active'] }
%li{
class: progress_index > 3 && 'completed',
'aria-current': progress_index == 3 ? 'step' : nil
}
.circle
- if progress_index > 3
= check_icon

View File

@ -1279,6 +1279,7 @@ en-GB:
progress:
confirm: Confirm email
details: Your details
list: Sign up progress
review: Our review
rules: Accept rules
providers:

View File

@ -1279,6 +1279,7 @@ en:
progress:
confirm: Confirm email
details: Your details
list: Sign up progress
review: Our review
rules: Accept rules
providers: