From 6426f451eea0eaa50f6f439b845a774bd39a5b84 Mon Sep 17 00:00:00 2001 From: Sabrina Bongiovanni Date: Tue, 19 Sep 2023 15:33:50 +0200 Subject: [PATCH] fix: accessibility for selectInput --- RELEASE.md | 1 + src/components/ItaliaTheme/Search/Search.jsx | 7 ++++++- src/components/SelectInput/SelectInput.jsx | 6 +++++- 3 files changed, 12 insertions(+), 2 deletions(-) diff --git a/RELEASE.md b/RELEASE.md index 1a154b4d6..fab9f6b7d 100644 --- a/RELEASE.md +++ b/RELEASE.md @@ -40,6 +40,7 @@ - Blocco info: Colori dentro editor di testo sistemati (bottoni draftJS) - I link nella modulistica mostrano la remoteUrl +- Sistemata accessibilità per il menu a tendina "Ordina Per" nella pagina di ricerca ## Versione 7.20.4 (13/09/2023) diff --git a/src/components/ItaliaTheme/Search/Search.jsx b/src/components/ItaliaTheme/Search/Search.jsx index f9ff08da6..07a89cbb3 100644 --- a/src/components/ItaliaTheme/Search/Search.jsx +++ b/src/components/ItaliaTheme/Search/Search.jsx @@ -643,9 +643,14 @@ const Search = () => { sortOnOptions.filter((o) => o.value === sortOn)[0] } label={intl.formatMessage(messages.orderBy)} - placeholder={intl.formatMessage(messages.orderBy)} + placeholder={ + sortOnOptions.find((o) => o.value === sortOn).label + } onChange={(opt) => setSortOn(opt.value)} options={sortOnOptions} + defaultValue={sortOnOptions.find( + (o) => o.value === 'relevance', + )} /> diff --git a/src/components/SelectInput/SelectInput.jsx b/src/components/SelectInput/SelectInput.jsx index 1c81e4739..2a72054fa 100644 --- a/src/components/SelectInput/SelectInput.jsx +++ b/src/components/SelectInput/SelectInput.jsx @@ -299,6 +299,7 @@ const SelectInput = ({ options, components = {}, reactSelect, + defaultValue, }) => { const intl = useIntl(); const Select = reactSelect.default; @@ -319,6 +320,7 @@ const SelectInput = ({ }} id={id} value={value} + defaultValue={defaultValue} onChange={onChange} options={options} placeholder={placeholder} @@ -326,7 +328,9 @@ const SelectInput = ({ isSearchable={isSearchable} isMulti={isMulti} isClearable={isClearable} - aria-label={placeholder} + aria-label={label} + aria-live="polite" + aria-labelledby={id} ariaLiveMessages={getSelectAriaLiveMessages(intl)} noOptionsMessage={() => intl.formatMessage(messages.select_noOptionsMessage)