Commit 086b8039 by Ari Rizzitano

[survey] fix a11y issues in table and aria-label markup (TNL-6360, TNL-6359)

avoid numeral-prefixed id attributes; bump to v1.2.5

[template] avoid potential invalid id attribute

[template] forgot to update default label

v1.2.5

dodge a few more numeral-prefixed ids

Added compiled translations

more descriptive labels for survey answers

fix survey a11y test

add col scope to answer heading

add headers to survey td elements

change aria-labelledby to aria-label for radio buttons

fix survey a11y test
parent 67933f1e
...@@ -9,13 +9,13 @@ ...@@ -9,13 +9,13 @@
<tr> <tr>
<td></td> <td></td>
{% for answer, label in answers %} {% for answer, label in answers %}
<th id="poll-{{block_id}}-{{answer}}" class="survey-answer">{{label}}</th> <th id="poll-{{block_id}}-{{answer}}" class="survey-answer" scope="col">{{label}}</th>
{% endfor %} {% endfor %}
</tr> </tr>
</thead> </thead>
{% for key, question in questions %} {% for key, question in questions %}
<tr class="survey-row" role="group" aria-labelledby="poll-{{block_id}}-{{key}}"> <tr class="survey-row" role="group" aria-labelledby="poll-{{block_id}}-{{key}}">
<th id="poll-{{block_id}}-{{key}}" class="survey-question"> <th id="poll-{{block_id}}-{{key}}" class="survey-question" scope="row">
{% if question.img %} {% if question.img %}
<div class="poll-image-td"> <div class="poll-image-td">
<img src="{{question.img}}" alt="{{question.img_alt|default_if_none:''}}"/> <img src="{{question.img}}" alt="{{question.img_alt|default_if_none:''}}"/>
...@@ -24,12 +24,16 @@ ...@@ -24,12 +24,16 @@
{{question.label|safe}} {{question.label|safe}}
</th> </th>
{% for answer, label in answers %} {% for answer, label in answers %}
<td class="survey-option"> <td class="survey-option" headers="poll-{{block_id}}-{{key}} poll-{{block_id}}-{{answer}}">
<label> <label>
<input type="radio" <input type="radio"
name="{{key}}" name="{{key}}"
value="{{answer}}"{% if question.choice == answer %} checked{% endif %} value="{{answer}}"{% if question.choice == answer %} checked{% endif %}
aria-labelledby="poll-{{block_id}}-{{answer}}" {% if question.img_alt %}
aria-label="{{question.img_alt}} {{label}}"
{% else %}
aria-label="{{question.label|striptags}} {{label}}"
{% endif %}
/> />
</label> </label>
</td> </td>
......
...@@ -44,7 +44,7 @@ def package_data(pkg, roots): ...@@ -44,7 +44,7 @@ def package_data(pkg, roots):
setup( setup(
name='xblock-poll', name='xblock-poll',
version='1.2.5', version='1.2.6',
description='An XBlock for polling users.', description='An XBlock for polling users.',
packages=[ packages=[
'poll', 'poll',
......
...@@ -176,17 +176,17 @@ class TestSurveyFunctions(PollBaseTest): ...@@ -176,17 +176,17 @@ class TestSurveyFunctions(PollBaseTest):
self.go_to_page('Survey Functions') self.go_to_page('Survey Functions')
questions = self.browser.find_elements_by_css_selector('.survey-question') questions = self.browser.find_elements_by_css_selector('.survey-question')
answers = self.browser.find_elements_by_css_selector('.survey-answer') answers = self.browser.find_elements_by_css_selector('.survey-answer')
question_ids = [question.get_attribute('id') for question in questions] question_text = [question.text for question in questions]
answer_ids = [answer.get_attribute('id') for answer in answers] answer_text = [answer.text for answer in answers]
rows = self.browser.find_elements_by_css_selector('.survey-row') rows = self.browser.find_elements_by_css_selector('.survey-row')
self.assertEqual(len(rows), len(questions)) self.assertEqual(len(rows), len(questions))
for i, row in enumerate(rows): for i, row in enumerate(rows):
self.assertEqual(row.get_attribute('role'), 'group') self.assertEqual(row.get_attribute('role'), 'group')
self.assertEqual(row.get_attribute('aria-labelledby'), question_ids[i])
options = row.find_elements_by_css_selector('.survey-option input') options = row.find_elements_by_css_selector('.survey-option input')
self.assertEqual(len(options), len(answers)) self.assertEqual(len(options), len(answers))
for j, option in enumerate(options): for j, option in enumerate(options):
self.assertEqual(option.get_attribute('aria-labelledby'), answer_ids[j]) self.assertIn(answer_text[j], option.get_attribute('aria-label'))
self.assertIn(question_text[i], option.get_attribute('aria-label'))
def fill_survey(self, assert_submit=False): def fill_survey(self, assert_submit=False):
""" """
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment