diff --git a/CHANGELOG.md b/CHANGELOG.md index c761e47a5d..b6e903ec5b 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -15,6 +15,7 @@ If you're using Nunjucks, you can now add classes to the character count compone - [Pull request #1676: Fix skip link component focus style with global styles enabled](https://github.com/alphagov/govuk-frontend/pull/1676). - [Pull request #1670: Make width-container margins more targetted to avoid specificity issues](https://github.com/alphagov/govuk-frontend/pull/1670). - [Pull request #1655: Ensure components use public `govuk-media-query` mixin](https://github.com/alphagov/govuk-frontend/pull/1655). +- [Pull request #1648: Update checkboxes and radio buttons to include item hint classes on item hint](https://github.com/alphagov/govuk-frontend/pull/1648) - [Pull request #1638: Check component item arrays are not empty before outputting markup](https://github.com/alphagov/govuk-frontend/pull/1638). ## 3.4.0 (Feature release) diff --git a/src/govuk/components/checkboxes/__snapshots__/template.test.js.snap b/src/govuk/components/checkboxes/__snapshots__/template.test.js.snap index 05d968c651..335be1d806 100644 --- a/src/govuk/components/checkboxes/__snapshots__/template.test.js.snap +++ b/src/govuk/components/checkboxes/__snapshots__/template.test.js.snap @@ -47,6 +47,17 @@ exports[`Checkboxes when they include a hint renders the hint 1`] = ` > If you have dual nationality, select all options that are relevant to you. + + Hint for british option here + + + Hint for other option here + `; exports[`Checkboxes when they include an error message renders the error message 1`] = ` diff --git a/src/govuk/components/checkboxes/checkboxes.yaml b/src/govuk/components/checkboxes/checkboxes.yaml index aff1facee9..dd3bfe3b99 100644 --- a/src/govuk/components/checkboxes/checkboxes.yaml +++ b/src/govuk/components/checkboxes/checkboxes.yaml @@ -261,29 +261,6 @@ examples: - value: other text: Citizen of another country -- name: with all fieldset attributes - data: - idPrefix: example - name: example - fieldset: - classes: app-fieldset--custom-modifier - attributes: - data-attribute: value - data-second-attribute: second-value - legend: - text: What is your nationality? - hint: - text: If you have dual nationality, select all options that are relevant to you. - errorMessage: - text: Please select an option - items: - - value: british - text: British - - value: irish - text: Irish - - value: other - text: Citizen of another country - - name: with error message data: name: waste diff --git a/src/govuk/components/checkboxes/template.njk b/src/govuk/components/checkboxes/template.njk index 57df1cd760..6337207509 100644 --- a/src/govuk/components/checkboxes/template.njk +++ b/src/govuk/components/checkboxes/template.njk @@ -88,7 +88,7 @@ {% if hasHint %} {{ govukHint({ id: itemHintId, - classes: 'govuk-checkboxes__hint', + classes: 'govuk-checkboxes__hint' + (' ' + item.hint.classes if item.hint.classes), attributes: item.hint.attributes, html: item.hint.html, text: item.hint.text diff --git a/src/govuk/components/checkboxes/template.test.js b/src/govuk/components/checkboxes/template.test.js index 43e9155d86..b273908cee 100644 --- a/src/govuk/components/checkboxes/template.test.js +++ b/src/govuk/components/checkboxes/template.test.js @@ -560,7 +560,12 @@ describe('Checkboxes', () => { describe('when they include an error message', () => { it('renders the error message', () => { - const $ = render('checkboxes', examples['with all fieldset attributes']) + const $ = render('checkboxes', { + name: 'example', + errorMessage: { + text: 'Please select an option' + } + }) expect(htmlWithClassName($, '.govuk-error-message')).toMatchSnapshot() }) @@ -667,13 +672,50 @@ describe('Checkboxes', () => { describe('when they include a hint', () => { it('renders the hint', () => { - const $ = render('checkboxes', examples['with all fieldset attributes']) + const $ = render('checkboxes', { + name: 'example', + hint: { + text: 'If you have dual nationality, select all options that are relevant to you.' + }, + items: [ + { + value: 'british', + text: 'British', + hint: { + text: 'Hint for british option here' + } + }, + { + value: 'irish', + text: 'Irish' + }, + { + hint: { + text: 'Hint for other option here', + classes: 'app-checkboxes__hint-other', + attributes: { + 'data-test-attribute': true + } + } + } + ] + }) expect(htmlWithClassName($, '.govuk-hint')).toMatchSnapshot() }) it('associates the fieldset as "described by" the hint', () => { - const $ = render('checkboxes', examples['with all fieldset attributes']) + const $ = render('checkboxes', { + name: 'example', + fieldset: { + legend: { + text: 'What is your nationality?' + } + }, + hint: { + text: 'If you have dual nationality, select all options that are relevant to you.' + } + }) const $fieldset = $('.govuk-fieldset') const $hint = $('.govuk-hint') @@ -687,11 +729,19 @@ describe('Checkboxes', () => { it('associates the fieldset as "described by" the hint and parent fieldset', () => { const describedById = 'some-id' - const params = examples['with all fieldset attributes'] - params.fieldset.describedBy = describedById - - const $ = render('checkboxes', params) + const $ = render('checkboxes', { + name: 'example', + fieldset: { + describedBy: describedById, + legend: { + text: 'What is your nationality?' + } + }, + hint: { + text: 'If you have dual nationality, select all options that are relevant to you.' + } + }) const $fieldset = $('.govuk-fieldset') const $hint = $('.govuk-hint') @@ -700,13 +750,25 @@ describe('Checkboxes', () => { ) expect($fieldset.attr('aria-describedby')).toMatch(hintId) - delete params.fieldset.describedBy }) }) describe('when they include both a hint and an error message', () => { it('associates the fieldset as described by both the hint and the error message', () => { - const $ = render('checkboxes', examples['with all fieldset attributes']) + const $ = render('checkboxes', { + name: 'example', + errorMessage: { + text: 'Please select an option' + }, + fieldset: { + legend: { + text: 'What is your nationality?' + } + }, + hint: { + text: 'If you have dual nationality, select all options that are relevant to you.' + } + }) const $fieldset = $('.govuk-fieldset') const errorMessageId = $('.govuk-error-message').attr('id') @@ -722,11 +784,22 @@ describe('Checkboxes', () => { it('associates the fieldset as described by the hint, error message and parent fieldset', () => { const describedById = 'some-id' - const params = examples['with all fieldset attributes'] - params.fieldset.describedBy = describedById - - const $ = render('checkboxes', params) + const $ = render('checkboxes', { + name: 'example', + errorMessage: { + text: 'Please select an option' + }, + fieldset: { + describedBy: describedById, + legend: { + text: 'What is your nationality?' + } + }, + hint: { + text: 'If you have dual nationality, select all options that are relevant to you.' + } + }) const $fieldset = $('.govuk-fieldset') const errorMessageId = $('.govuk-error-message').attr('id') @@ -738,14 +811,18 @@ describe('Checkboxes', () => { expect($fieldset.attr('aria-describedby')) .toMatch(combinedIds) - - delete params.fieldset.describedBy }) }) describe('nested dependant components', () => { it('have correct nesting order', () => { - const $ = render('checkboxes', examples['with all fieldset attributes']) + const $ = render('checkboxes', { + fieldset: { + legend: { + text: 'What is your nationality?' + } + } + }) const $component = $('.govuk-form-group > .govuk-fieldset > .govuk-checkboxes') expect($component.length).toBeTruthy() @@ -777,7 +854,25 @@ describe('Checkboxes', () => { }) it('passes through fieldset params without breaking', () => { - const $ = render('checkboxes', examples['with all fieldset attributes']) + const $ = render('checkboxes', { + name: 'example', + errorMessage: { + text: 'Please select an option' + }, + fieldset: { + classes: 'app-fieldset--custom-modifier', + attributes: { + 'data-attribute': 'value', + 'data-second-attribute': 'second-value' + }, + legend: { + text: 'What is your nationality?' + } + }, + hint: { + text: 'If you have dual nationality, select all options that are relevant to you.' + } + }) expect(htmlWithClassName($, '.govuk-fieldset')).toMatchSnapshot() }) diff --git a/src/govuk/components/radios/__snapshots__/template.test.js.snap b/src/govuk/components/radios/__snapshots__/template.test.js.snap index 1de2bf559d..95579c11f4 100644 --- a/src/govuk/components/radios/__snapshots__/template.test.js.snap +++ b/src/govuk/components/radios/__snapshots__/template.test.js.snap @@ -47,6 +47,17 @@ exports[`Radios when they include a hint renders the hint 1`] = ` > This includes changing your last name or spelling your name differently. + + Hint for yes option here + + + Hint for no option here + `; exports[`Radios when they include an error message renders the error message 1`] = ` diff --git a/src/govuk/components/radios/radios.yaml b/src/govuk/components/radios/radios.yaml index 79a768a999..cb20166992 100644 --- a/src/govuk/components/radios/radios.yaml +++ b/src/govuk/components/radios/radios.yaml @@ -258,28 +258,6 @@ examples: text: No checked: true -- name: with all fieldset attributes - data: - idPrefix: example - name: example - errorMessage: - text: Please select an option - fieldset: - classes: app-fieldset--custom-modifier - attributes: - data-attribute: value - data-second-attribute: second-value - legend: - text: Have you changed your name? - hint: - text: This includes changing your last name or spelling your name differently. - items: - - value: yes - text: Yes - - value: no - text: No - checked: true - - name: with very long option text data: name: waste diff --git a/src/govuk/components/radios/template.njk b/src/govuk/components/radios/template.njk index da392c9cda..280ad806a5 100644 --- a/src/govuk/components/radios/template.njk +++ b/src/govuk/components/radios/template.njk @@ -82,7 +82,7 @@ {% if hasHint %} {{ govukHint({ id: itemHintId, - classes: 'govuk-radios__hint', + classes: 'govuk-radios__hint' + (' ' + item.hint.classes if item.hint.classes), attributes: item.hint.attributes, html: item.hint.html, text: item.hint.text diff --git a/src/govuk/components/radios/template.test.js b/src/govuk/components/radios/template.test.js index 31abdac333..5e58a051d1 100644 --- a/src/govuk/components/radios/template.test.js +++ b/src/govuk/components/radios/template.test.js @@ -535,13 +535,44 @@ describe('Radios', () => { describe('when they include a hint', () => { it('renders the hint', () => { - const $ = render('radios', examples['with all fieldset attributes']) + const $ = render('radios', { + name: 'example', + hint: { + text: 'This includes changing your last name or spelling your name differently.' + }, + items: [ + { + hint: { + text: 'Hint for yes option here' + } + }, + { + hint: { + classes: 'app-radios__hint-no', + text: 'Hint for no option here', + attributes: { + 'data-test-attribute': true + } + } + } + ] + }) expect(htmlWithClassName($, '.govuk-hint')).toMatchSnapshot() }) it('associates the fieldset as "described by" the hint', () => { - const $ = render('radios', examples['with all fieldset attributes']) + const $ = render('radios', { + name: 'example', + fieldset: { + legend: { + text: 'Have you changed your name?' + } + }, + hint: { + text: 'This includes changing your last name or spelling your name differently.' + } + }) const $fieldset = $('.govuk-fieldset') const $hint = $('.govuk-hint') @@ -555,11 +586,19 @@ describe('Radios', () => { it('associates the fieldset as "described by" the hint and parent fieldset', () => { const describedById = 'some-id' - const params = examples['with all fieldset attributes'] - - params.fieldset.describedBy = describedById - const $ = render('radios', params) + const $ = render('radios', { + name: 'example', + fieldset: { + describedBy: describedById, + legend: { + text: 'Have you changed your name?' + } + }, + hint: { + text: 'This includes changing your last name or spelling your name differently.' + } + }) const $fieldset = $('.govuk-fieldset') const $hint = $('.govuk-hint') @@ -568,13 +607,17 @@ describe('Radios', () => { ) expect($fieldset.attr('aria-describedby')).toMatch(hintId) - delete params.fieldset.describedBy }) }) describe('when they include an error message', () => { it('renders the error message', () => { - const $ = render('radios', examples['with all fieldset attributes']) + const $ = render('radios', { + name: 'example', + errorMessage: { + text: 'Please select an option' + } + }) expect(htmlWithClassName($, '.govuk-error-message')).toMatchSnapshot() }) @@ -666,7 +709,19 @@ describe('Radios', () => { describe('when they include both a hint and an error message', () => { it('associates the fieldset as described by both the hint and the error message', () => { - const $ = render('radios', examples['with all fieldset attributes']) + const $ = render('radios', { + errorMessage: { + text: 'Please select an option' + }, + fieldset: { + legend: { + text: 'Have you changed your name?' + } + }, + hint: { + text: 'This includes changing your last name or spelling your name differently.' + } + }) const $fieldset = $('.govuk-fieldset') const errorMessageId = $('.govuk-error-message').attr('id') @@ -682,11 +737,21 @@ describe('Radios', () => { it('associates the fieldset as described by the hint, error message and parent fieldset', () => { const describedById = 'some-id' - const params = examples['with all fieldset attributes'] - params.fieldset.describedBy = describedById - - const $ = render('radios', params) + const $ = render('radios', { + errorMessage: { + text: 'Please select an option' + }, + fieldset: { + describedBy: describedById, + legend: { + text: 'Have you changed your name?' + } + }, + hint: { + text: 'This includes changing your last name or spelling your name differently.' + } + }) const $fieldset = $('.govuk-fieldset') const errorMessageId = $('.govuk-error-message').attr('id') @@ -698,14 +763,18 @@ describe('Radios', () => { expect($fieldset.attr('aria-describedby')) .toMatch(combinedIds) - - delete params.fieldset.describedBy }) }) describe('nested dependant components', () => { it('have correct nesting order', () => { - const $ = render('radios', examples['with all fieldset attributes']) + const $ = render('radios', { + fieldset: { + legend: { + text: 'Have you changed your name?' + } + } + }) const $component = $('.govuk-form-group > .govuk-fieldset > .govuk-radios') expect($component.length).toBeTruthy() @@ -737,7 +806,25 @@ describe('Radios', () => { }) it('passes through fieldset params without breaking', () => { - const $ = render('radios', examples['with all fieldset attributes']) + const $ = render('radios', { + name: 'example', + errorMessage: { + text: 'Please select an option' + }, + fieldset: { + classes: 'app-fieldset--custom-modifier', + attributes: { + 'data-attribute': 'value', + 'data-second-attribute': 'second-value' + }, + legend: { + text: 'Have you changed your name?' + } + }, + hint: { + text: 'This includes changing your last name or spelling your name differently.' + } + }) expect(htmlWithClassName($, '.govuk-fieldset')).toMatchSnapshot() })