From 0c26543cdbabcbcbdedfbb19961cc0bf855ddc85 Mon Sep 17 00:00:00 2001 From: Kim Nguyen Date: Tue, 29 Oct 2024 13:28:40 -0400 Subject: [PATCH] Provide screen reader alerts for resource form. --- admin/themes/default/javascripts/elements.js | 21 ++++++++++++++++++-- application/views/helpers/ElementForm.php | 5 ++++- 2 files changed, 23 insertions(+), 3 deletions(-) diff --git a/admin/themes/default/javascripts/elements.js b/admin/themes/default/javascripts/elements.js index c1e9e21e47..3abcf1736c 100644 --- a/admin/themes/default/javascripts/elements.js +++ b/admin/themes/default/javascripts/elements.js @@ -53,10 +53,20 @@ Omeka.Elements = {}; }); fieldDiv.html(response); fieldDiv.trigger('omeka:elementformload'); - } + fieldDiv.find('.add-element').focus(); + setTimeout(() => { + Omeka.Elements.alertElementChange('element-' + elementId, fieldDiv); + }, 2000); + } }); }; + Omeka.Elements.alertElementChange = function (elementId, fieldDiv) { + var alertsDiv = $('#' + elementId + '-alerts'); + var rowCount = fieldDiv.find('.input-block').length; + alertsDiv.find('span.count').text(rowCount); + } + /** * Set up add/remove element buttons for ElementText inputs. * @@ -93,7 +103,7 @@ Omeka.Elements = {}; context.find(addSelector).click(function (event) { event.preventDefault(); var fieldDiv = $(this).parents(fieldSelector); - + Omeka.Elements.elementFormRequest(fieldDiv, {add: '1'}, elementFormPartialUrl, recordType, recordId); }); @@ -101,6 +111,8 @@ Omeka.Elements = {}; context.find(removeSelector).click(function (event) { event.preventDefault(); var removeButton = $(this); + var fieldDiv = $(this).parents(fieldSelector); + var elementId = fieldDiv.attr('id'); // Don't delete the last input block for an element. if (removeButton.parents(fieldSelector).find(inputBlockSelector).length === 1) { @@ -117,6 +129,11 @@ Omeka.Elements = {}; }); inputBlock.remove(); + fieldDiv.find('textarea').last().focus(); + setTimeout(() => { + Omeka.Elements.alertElementChange(elementId, fieldDiv); + }, 2000); + // Hide remove buttons for fields with one input. $(fieldSelector).each(function () { var removeButtons = $(this).find(removeSelector); diff --git a/application/views/helpers/ElementForm.php b/application/views/helpers/ElementForm.php index cc3ef5bf5c..cc2178baa6 100644 --- a/application/views/helpers/ElementForm.php +++ b/application/views/helpers/ElementForm.php @@ -87,7 +87,10 @@ public function elementForm(Element $element, Omeka_Record_AbstractRecord $recor } // Compose html for element form - $html = $divWrap ? '
' : ''; + $html = '
'; + $html .= __('Number of rows in "%s":', $components['label']) . '1'; + $html .= '
'; + $html .= $divWrap ? '
' : ''; $html .= '
'; $html .= $components['label'];