From dbc7a4c4be647baf91424193360e34b4db50f89e Mon Sep 17 00:00:00 2001
From: Liz Daly <50752284+lookupdaily@users.noreply.github.com>
Date: Thu, 7 Sep 2023 17:12:56 +0100
Subject: [PATCH] Add default value to autocomplete input
Adding the accessible autocomplete element meant that when completing a text search from the home page (non-js route) the input value is no longer populated when the search page is loaded. We have added a default value on init autocomplete.
There is a known issue with autocomplete (https://github.com/alphagov/accessible-autocomplete/issues/424), that setting a default value results in a suggestion with the text 'undefined'. This is bedause the default value is treated as a selected item, even though it is likely to be a partial search term, and is a string instead of an Aucomplete empty object. The workaround for this is to check if the result is a string when setting the custom template.
---
.../Pages/Shared/_SearchForm.cshtml | 2 +-
.../assets/javascripts/autocomplete.js | 44 ++++++++++++-------
2 files changed, 30 insertions(+), 16 deletions(-)
diff --git a/DfE.FindInformationAcademiesTrusts/Pages/Shared/_SearchForm.cshtml b/DfE.FindInformationAcademiesTrusts/Pages/Shared/_SearchForm.cshtml
index d6157a15d..2fa8b5008 100644
--- a/DfE.FindInformationAcademiesTrusts/Pages/Shared/_SearchForm.cshtml
+++ b/DfE.FindInformationAcademiesTrusts/Pages/Shared/_SearchForm.cshtml
@@ -28,6 +28,6 @@
diff --git a/DfE.FindInformationAcademiesTrusts/assets/javascripts/autocomplete.js b/DfE.FindInformationAcademiesTrusts/assets/javascripts/autocomplete.js
index 35d9ba2a5..d934ca7cb 100644
--- a/DfE.FindInformationAcademiesTrusts/assets/javascripts/autocomplete.js
+++ b/DfE.FindInformationAcademiesTrusts/assets/javascripts/autocomplete.js
@@ -1,37 +1,51 @@
import accessibleAutocomplete from 'accessible-autocomplete'
export class Autocomplete {
- loadTrustSearch = async (inputId) => {
+ suggest = async (query, populateResults) => {
let loading = false
+ if (query && !loading) {
+ loading = true
+ const response = await fetch(`/search?handler=populateautocomplete&keywords=${query}`)
+ const results = await response.json()
+ populateResults(results)
+ loading = false
+ }
+ }
+
+ getName = (result) => {
+ // This check for a string is related to a known issue in autocomplete when setting a default value https://github.com/alphagov/accessible-autocomplete/issues/424
+ if (result && typeof (result) !== 'string') return result && result.name
+ return result
+ }
+
+ getHint = (result) => {
+ const hintText = this.getName(result)
+ if (result?.address) {
+ return `${hintText}${result.address}`
+ }
+ return hintText
+ }
+
+ loadTrustSearch = async (inputId, defaultValue) => {
const autocompleteTemplate = document.getElementById(`${inputId}-js-autocomplete-template`)
const autocompleteTemplateContents = autocompleteTemplate.content.cloneNode(true)
const elementToReplace = document.getElementById(`${inputId}-no-js-search-container`)
elementToReplace.replaceWith(autocompleteTemplateContents)
- async function suggest (query, populateResults) {
- if (query && !loading) {
- loading = true
- const response = await fetch(`/search?handler=populateautocomplete&keywords=${query}`)
- const results = await response.json()
- populateResults(results)
- loading = false
- }
- }
-
accessibleAutocomplete({
+ defaultValue,
element: document.getElementById(`${inputId}-autocomplete-container`),
id: inputId,
name: 'keywords',
- source: suggest,
+ source: this.suggest,
autoselect: false,
confirmOnBlur: false,
- showNoOptionsFound: false,
displayMenu: 'overlay',
minLength: 3,
templates: {
- inputValue: function (r) { return r && r.name },
- suggestion: function (r) { return r && `${r.name}${r.address}` }
+ inputValue: r => this.getName(r),
+ suggestion: r => this.getHint(r)
},
onConfirm: (selected) => {
if (selected) {