-
Notifications
You must be signed in to change notification settings - Fork 5
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Move code for accessible autocomplete component into app
This component was removed in version 18 of govuk_publishing_components alphagov/govuk_publishing_components#1038 We need to move the code into the app so that we can update govuk_publishing_components and other dependencies. https://trello.com/c/egaF1kjo/3110-replace-accessible-autocomplete-for-content-data-admin
- Loading branch information
1 parent
a8baf6a
commit dc107d2
Showing
10 changed files
with
365 additions
and
3 deletions.
There are no files selected for viewing
78 changes: 78 additions & 0 deletions
78
app/assets/javascripts/components/accessible-autocomplete.js
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,78 @@ | ||
/* eslint-env jquery */ | ||
/* global accessibleAutocomplete */ | ||
|
||
window.GOVUK = window.GOVUK || {} | ||
window.GOVUK.Modules = window.GOVUK.Modules || {}; | ||
|
||
(function (Modules) { | ||
'use strict' | ||
|
||
Modules.AccessibleAutocomplete = function () { | ||
var $selectElem | ||
|
||
this.start = function ($element) { | ||
$selectElem = $element.find('select') | ||
|
||
var configOptions = { | ||
selectElement: document.getElementById($selectElem.attr('id')), | ||
showAllValues: true, | ||
confirmOnBlur: true, | ||
preserveNullOptions: true, // https://github.com/alphagov/accessible-autocomplete#null-options | ||
defaultValue: '' | ||
} | ||
|
||
configOptions.onConfirm = this.onConfirm | ||
|
||
new accessibleAutocomplete.enhanceSelectElement(configOptions) // eslint-disable-line no-new, new-cap | ||
// attach the onConfirm function to data attr, to call it in finder-frontend when clearing facet tags | ||
$selectElem.data('onconfirm', this.onConfirm) | ||
} | ||
|
||
this.onConfirm = function (label, value, removeDropDown) { | ||
function escapeHTML (str) { | ||
return new window.Option(str).innerHTML | ||
} | ||
|
||
if ($selectElem.data('track-category') !== undefined && $selectElem.data('track-action') !== undefined) { | ||
track($selectElem.data('track-category'), $selectElem.data('track-action'), label, $selectElem.data('track-options')) | ||
} | ||
// This is to compensate for the fact that the accessible-autocomplete library will not | ||
// update the hidden select if the onConfirm function is supplied | ||
// https://github.com/alphagov/accessible-autocomplete/issues/322 | ||
if (typeof label !== 'undefined') { | ||
if (typeof value === 'undefined') { | ||
value = $selectElem.children('option').filter(function () { return $(this).html() === escapeHTML(label) }).val() | ||
} | ||
|
||
if (typeof value !== 'undefined') { | ||
var $option = $selectElem.find('option[value=\'' + value + '\']') | ||
// if removeDropDown we are clearing the selection from outside the component | ||
var selectState = typeof removeDropDown === 'undefined' | ||
$option.prop('selected', selectState) | ||
$selectElem.change() | ||
} | ||
|
||
// used to clear the autocomplete when clicking on a facet tag in finder-frontend | ||
// very brittle but menu visibility is determined by autocomplete after this function is called | ||
// setting autocomplete val to '' causes menu to appear, we don't want that, this solves it | ||
// ideally will rewrite autocomplete to have better hooks in future | ||
if (removeDropDown) { | ||
$selectElem.closest('.app-c-accessible-autocomplete').addClass('app-c-accessible-autocomplete--hide-menu') | ||
setTimeout(function () { | ||
$('.autocomplete__menu').remove() // this element is recreated every time the user starts typing | ||
$selectElem.closest('.app-c-accessible-autocomplete').removeClass('app-c-accessible-autocomplete--hide-menu') | ||
}, 100) | ||
} | ||
} | ||
} | ||
|
||
function track (category, action, label, options) { | ||
if (window.GOVUK.analytics && window.GOVUK.analytics.trackEvent) { | ||
options = options || {} | ||
options.label = label | ||
|
||
window.GOVUK.analytics.trackEvent(category, action, options) | ||
} | ||
} | ||
} | ||
})(window.GOVUK.Modules) |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
33 changes: 33 additions & 0 deletions
33
app/assets/stylesheets/components/_accessible-autocomplete.scss
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,33 @@ | ||
.app-c-accessible-autocomplete { | ||
.autocomplete__input { | ||
z-index: 1; | ||
} | ||
|
||
.autocomplete__dropdown-arrow-down { | ||
z-index: 0; | ||
} | ||
|
||
.autocomplete__option { | ||
@include govuk-font(19); | ||
} | ||
|
||
.js-enabled { | ||
display: none; | ||
} | ||
|
||
.autocomplete__list .autocomplete__option { | ||
padding: 5px 6px; | ||
|
||
&:before { | ||
position: relative; | ||
top: 3px; | ||
padding-top: 2px; | ||
} | ||
} | ||
} | ||
|
||
.app-c-accessible-autocomplete--hide-menu { | ||
.autocomplete__menu { | ||
display: none; | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,26 @@ | ||
<% | ||
id ||= "autocomplete-#{SecureRandom.hex(4)}" | ||
label ||= nil | ||
data_attributes ||= nil | ||
options ||= [] | ||
selected_option ||= nil | ||
|
||
classes = %w(app-c-accessible-autocomplete govuk-form-group) | ||
%> | ||
<% if label && options.any? %> | ||
<%= tag.div class: classes, data: { module: "accessible-autocomplete" } do %> | ||
<%= | ||
render "govuk_publishing_components/components/label", { | ||
html_for: id | ||
}.merge(label.symbolize_keys) | ||
%> | ||
<%= | ||
select_tag( | ||
id, | ||
options_for_select(options, selected_option), | ||
class: "govuk-select", | ||
data: data_attributes | ||
) | ||
%> | ||
<% end %> | ||
<% end %> |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,41 @@ | ||
name: Accessible autocomplete | ||
description: An autocomplete component, built to be accessible. | ||
body: | | ||
This component uses the [Accessible Autocomplete](https://github.com/alphagov/accessible-autocomplete) code to create an accessible autocomplete element. The autocomplete is created with the `showAllValues` | ||
option set to `true` and the `confirmOnBlur` option set to `false` (see [Autocomplete examples](https://alphagov.github.io/accessible-autocomplete/examples) here). It also depends upon the | ||
[label component](https://github.com/component-guide/label). | ||
If Javascript is disabled, the component appears as a select box, so the user can still select an option. | ||
accessibility_criteria: | | ||
[Accessibility acceptance criteria](https://github.com/alphagov/accessible-autocomplete/blob/master/accessibility-criteria.md) | ||
examples: | ||
default: | ||
data: | ||
label: | ||
text: 'Countries' | ||
options: [['', ''], ['France', 'fr'], ['Germany', 'de'], ['Sweden', 'se'], ['Switzerland', 'ch'], ['United Kingdom', 'gb'], ['United States', 'us'], ['The Separate Customs Territory of Taiwan, Penghu, Kinmen, and Matsu (Chinese Taipei)', 'tw']] | ||
with_unique_identifier: | ||
data: | ||
id: 'unique-autocomplete' | ||
label: | ||
text: 'Countries' | ||
options: [['', ''], ['France', 'fr'], ['Germany', 'de'], ['Sweden', 'se'], ['Switzerland', 'ch'], ['United Kingdom', 'gb'], ['United States', 'us']] | ||
with_selected_option_chosen: | ||
data: | ||
id: 'selected-option-chosen-autocomplete' | ||
label: | ||
text: 'Countries' | ||
options: [['', ''], ['France', 'fr'], ['Germany', 'de'], ['Sweden', 'se'], ['Switzerland', 'ch'], ['United Kingdom', 'gb'], ['United States', 'us']] | ||
selected_option: ['United Kingdom', 'gb'] | ||
with_tracking_enabled: | ||
description: | | ||
This example shows tracking enabled on an autocomplete. Tracking will be enabled automatically when `track_category` and `track_action` are specified in `data_attributes`. | ||
data: | ||
id: 'tracking-enabled-autocomplete' | ||
label: | ||
text: 'Countries' | ||
options: [['', ''], ['France', 'fr'], ['Germany', 'de'], ['Sweden', 'se'], ['Switzerland', 'ch'], ['United Kingdom', 'gb'], ['United States', 'us']] | ||
data_attributes: | ||
track_category: 'chosen_category' | ||
track_action: 'chosen_action' | ||
track_option: | ||
custom_dimension: 'your_custom_dimension' |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,54 @@ | ||
require "rails_helper" | ||
|
||
RSpec.describe "AccessibleAutocomplete", type: :view do | ||
it "renders select element" do | ||
render_component( | ||
id: "basic-autocomplete", | ||
label: { text: "Countries" }, | ||
options: [["United Kingdom", "gb"], ["United States", "us"]], | ||
) | ||
|
||
assert_select ".govuk-label", text: "Countries", for: "basic-autocomplete" | ||
assert_select "select#basic-autocomplete" | ||
assert_select "select#basic-autocomplete option[value=gb]" | ||
assert_select "select#basic-autocomplete option[value=gb]", text: "United Kingdom" | ||
assert_select "select#basic-autocomplete option[value=us]" | ||
assert_select "select#basic-autocomplete option[value=us]", text: "United States" | ||
end | ||
|
||
it "renders select element with selected value" do | ||
render_component( | ||
id: "basic-autocomplete", | ||
label: { text: "Countries" }, | ||
options: [["United Kingdom", "gb"], ["United States", "us"]], | ||
selected_option: ["United States", "us"], | ||
) | ||
|
||
assert_select ".govuk-label", text: "Countries", for: "basic-autocomplete" | ||
assert_select "select#basic-autocomplete" | ||
assert_select "select#basic-autocomplete option[value=gb]" | ||
assert_select "select#basic-autocomplete option[value=us][selected]" | ||
end | ||
|
||
it "does not render when no data is specified" do | ||
assert_empty render_component({}) | ||
end | ||
|
||
it "does not render when no label is specified" do | ||
assert_empty render_component( | ||
id: "basic-autocomplete", | ||
options: [["United Kingdom", "gb"], ["United States", "us"]], | ||
) | ||
end | ||
|
||
it "does not render when no options are specified" do | ||
assert_empty render_component( | ||
id: "basic-autocomplete", | ||
label: { text: "Countries" }, | ||
) | ||
end | ||
|
||
def render_component(locals) | ||
render partial: "components/accessible_autocomplete", locals: | ||
end | ||
end |
Oops, something went wrong.