mirror of
https://github.com/GSA/notifications-admin.git
synced 2026-05-05 08:31:00 -04:00
Merge pull request #3673 from alphagov/remove-page-title-hack-from-autofocus
Don't prefix with the page title when focusing on load
This commit is contained in:
@@ -4,26 +4,14 @@
|
||||
Modules.Autofocus = function() {
|
||||
this.start = function(component) {
|
||||
var $component = $(component),
|
||||
forceFocus = $component.data('forceFocus'),
|
||||
labelText = $('label[for="' + $component.attr('id') + '"]').eq(0).text().trim(),
|
||||
clearAriaLabel = evt => {
|
||||
$component.removeAttr('aria-label');
|
||||
$component.off('blur', clearAriaLabel);
|
||||
};
|
||||
forceFocus = $component.data('forceFocus');
|
||||
|
||||
// if the page loads with a scroll position, we can't assume the item to focus onload
|
||||
// is still where users intend to start
|
||||
if (($(window).scrollTop() > 0) && !forceFocus) { return; }
|
||||
|
||||
// screenreaders announce the page title when a new page loads
|
||||
// this will be lost when focus is moved to our form control so add it to the label instead
|
||||
$component.attr('aria-label', document.title + ' - ' + labelText);
|
||||
|
||||
$component.filter('input, textarea, select').eq(0).trigger('focus');
|
||||
|
||||
// the page title prefix is only needed on page load so remove once focus has shifted
|
||||
$component.on('blur', clearAriaLabel);
|
||||
|
||||
};
|
||||
};
|
||||
|
||||
|
||||
Reference in New Issue
Block a user