(function(Modules) { "use strict"; let states = { 'initial': Hogan.compile(`
{{#categories}} {{/categories}}
`), 'choose': Hogan.compile(`
{{#choices}}
{{/choices}}
`), 'chosen': Hogan.compile(`
{{#choices}}
{{/choices}}
`) }; let focusSelected = function() { setTimeout( () => $('[type=radio]:checked').next('label').blur().trigger('focus').addClass('selected'), 50 ); }; Modules.RadioSelect = function() { this.start = function(component) { let $component = $(component); let render = (state, data) => { $component.html(states[state].render(data)); }; let choices = $('label', $component).toArray().map(function(element) { let $element = $(element); return { 'id': $element.attr('for'), 'label': $.trim($element.text()), 'value': $element.prev('input').attr('value') }; }); let categories = $component.data('categories').split(','); let name = $component.find('input').eq(0).attr('name'); $component .on('click', '.js-category-button', function(event) { event.preventDefault(); let wordsInDay = $(this).attr('value').split(' '); let day = wordsInDay[wordsInDay.length - 1].toLowerCase(); render('choose', { 'choices': choices.filter( element => element.label.toLowerCase().indexOf(day) > -1 ), 'name': name }); focusSelected(); }) .on('click', '.js-option', function(event) { // stop click being triggered by keyboard events if (!event.pageX) return true; event.preventDefault(); let value = $('input', this).attr('value'); render('chosen', { 'choices': choices.filter( element => element.value == value ), 'name': name }); focusSelected(); }) .on('keydown', 'input[type=radio]', function(event) { // intercept keypresses which aren’t enter or space if (event.which !== 13 && event.which !== 32) { return true; } event.preventDefault(); let value = $(this).attr('value'); render('chosen', { 'choices': choices.filter( element => element.value == value ), 'name': name }); focusSelected(); }) .on('click', '.js-reset-button', function(event) { event.preventDefault(); render('initial', { 'categories': categories, 'name': name }); focusSelected(); }); render('initial', { 'categories': categories, 'name': name }); $component.css({'height': 'auto'}); }; }; })(window.GOVUK.Modules);