Skip to content

Commit

Permalink
fix(select a11y): handle remaining TODO comments & rename internal co…
Browse files Browse the repository at this point in the history
…mponents
  • Loading branch information
Mohammer5 committed Nov 28, 2024
1 parent cca9228 commit 0dc3760
Show file tree
Hide file tree
Showing 61 changed files with 585 additions and 707 deletions.
4 changes: 2 additions & 2 deletions collections/forms/i18n/en.pot
Original file line number Diff line number Diff line change
Expand Up @@ -5,8 +5,8 @@ msgstr ""
"Content-Type: text/plain; charset=utf-8\n"
"Content-Transfer-Encoding: 8bit\n"
"Plural-Forms: nplurals=2; plural=(n != 1)\n"
"POT-Creation-Date: 2024-11-19T08:12:09.695Z\n"
"PO-Revision-Date: 2024-11-19T08:12:09.696Z\n"
"POT-Creation-Date: 2024-11-28T02:02:47.011Z\n"
"PO-Revision-Date: 2024-11-28T02:02:47.011Z\n"

msgid "Upload file"
msgstr "Upload file"
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -28,6 +28,7 @@ export const SingleSelectA11yFieldFF = ({
return (
<SingleSelectA11yField
{...rest}
name={input.name}
error={hasError(meta, error)}
valid={isValid(meta, valid, showValidStatus)}
loading={isLoading(meta, loading, showLoadingStatus)}
Expand All @@ -41,9 +42,6 @@ export const SingleSelectA11yFieldFF = ({
}

SingleSelectA11yFieldFF.propTypes = {
/** necessary for IDs that are required for accessibility **/
idPrefix: PropTypes.string.isRequired,

/** `input` props received from Final Form `Field` */
input: inputPropType.isRequired,

Expand Down Expand Up @@ -72,10 +70,6 @@ SingleSelectA11yFieldFF.propTypes = {
/** Whether a clear button should be displayed or not **/
clearable: PropTypes.bool,

/** Allows to override what's rendered inside the `button[role="option"]`.
* Can be overriden on an individual option basis **/
customOption: PropTypes.elementType,

/** A value for a `data-test` attribute on the root element **/
dataTest: PropTypes.string,

Expand Down Expand Up @@ -121,6 +115,10 @@ SingleSelectA11yFieldFF.propTypes = {
/** String that will be displayed when the select is being filtered but the options array is empty **/
noMatchText: requiredIf((props) => props.filterable, PropTypes.string),

/** Allows to override what's rendered inside the `button[role="option"]`.
* Can be overriden on an individual option basis **/
optionComponent: PropTypes.elementType,

/** For a11y: How aggressively the user should be updated about changes in options **/
optionUpdateStrategy: PropTypes.oneOf(['off', 'polite', 'assertive']),

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -61,8 +61,7 @@ export const Default = () => (
<Field
required
component={SingleSelectA11yFieldFF}
idPrefix="story"
name="agree"
name="story"
label="Do you agree?"
options={options}
validate={hasValue}
Expand All @@ -72,8 +71,7 @@ export const Default = () => (
export const InitialValue = () => (
<Field
component={SingleSelectA11yFieldFF}
idPrefix="story"
name="agree"
name="story"
label="Do you agree?"
options={options}
initialValue="4"
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -16,8 +16,7 @@ describe('<SingleSelectA11yFieldFF/>', () => {
<form onSubmit={formRenderProps.handleSubmit}>
<Field
component={SingleSelectA11yFieldFF}
idPrefix="story"
name="selectName"
name="story"
label="Label text"
options={[
{ value: '', label: 'None' },
Expand Down Expand Up @@ -56,8 +55,7 @@ describe('<SingleSelectA11yFieldFF/>', () => {
<Field
required
component={SingleSelectA11yFieldFF}
idPrefix="story"
name="selectName"
name="story"
label="Label text"
validate={hasValue}
options={[
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -12,14 +12,14 @@ export function SingleSelectA11yField(props) {
disabled,
error,
helpText,
idPrefix,
label,
name,
required,
valid,
validationText,
warning,
} = props
const labelId = `${idPrefix}-label`
const labelId = `${name}-label`

return (
<Field
Expand All @@ -41,12 +41,12 @@ export function SingleSelectA11yField(props) {
}

SingleSelectA11yField.propTypes = {
/** necessary for IDs that are required for accessibility **/
idPrefix: PropTypes.string.isRequired,

/** Label displayed above the input **/
label: PropTypes.string.isRequired,

/** necessary for IDs that are required for accessibility **/
name: PropTypes.string.isRequired,

/** An array of options **/
options: PropTypes.arrayOf(optionProp).isRequired,

Expand All @@ -65,10 +65,6 @@ SingleSelectA11yField.propTypes = {
/** Whether a clear button should be displayed or not **/
clearable: PropTypes.bool,

/** Allows to override what's rendered inside the `button[role="option"]`.
* Can be overriden on an individual option basis **/
customOption: PropTypes.elementType,

/** A value for a `data-test` attribute on the root element **/
dataTest: PropTypes.string,

Expand Down Expand Up @@ -114,6 +110,10 @@ SingleSelectA11yField.propTypes = {
/** String that will be displayed when the select is being filtered but the options array is empty **/
noMatchText: requiredIf((props) => props.filterable, PropTypes.string),

/** Allows to override what's rendered inside the `button[role="option"]`.
* Can be overriden on an individual option basis **/
optionComponent: PropTypes.elementType,

/** For a11y: How aggressively the user should be updated about changes in options **/
optionUpdateStrategy: PropTypes.oneOf(['off', 'polite', 'assertive']),

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -40,7 +40,7 @@ export const Default = () => {

return (
<SingleSelectA11yField
idPrefix="a11y"
name="a11y"
label="This is the label"
value={value}
valueLabel={valueLabel}
Expand All @@ -58,7 +58,7 @@ export const WithHelpText = () => {

return (
<SingleSelectA11yField
idPrefix="a11y"
name="a11y"
label="This is the label"
helpText="This is the help text"
value={value}
Expand All @@ -78,7 +78,7 @@ export const StatusValid = () => {
return (
<SingleSelectA11yField
valid
idPrefix="a11y"
name="a11y"
label="This is the label"
value={value}
valueLabel={valueLabel}
Expand All @@ -98,7 +98,7 @@ export const StatusWarning = () => {
return (
<SingleSelectA11yField
warning
idPrefix="a11y"
name="a11y"
label="This is the label"
value={value}
valueLabel={valueLabel}
Expand All @@ -118,7 +118,7 @@ export const StatusError = () => {
return (
<SingleSelectA11yField
error
idPrefix="a11y"
name="a11y"
label="This is the label"
value={value}
valueLabel={valueLabel}
Expand All @@ -138,7 +138,7 @@ export const StatusDisabled = () => {
return (
<SingleSelectA11yField
disabled
idPrefix="a11y"
name="a11y"
label="This is the label"
value={value}
valueLabel={valueLabel}
Expand All @@ -157,7 +157,7 @@ export const Required = () => {
return (
<SingleSelectA11yField
required
idPrefix="a11y"
name="a11y"
label="This is the label"
value={value}
valueLabel={valueLabel}
Expand All @@ -176,7 +176,7 @@ export const InputWidth = () => {
return (
<div style={{ width: 200 }}>
<SingleSelectA11yField
idPrefix="a11y"
name="a11y"
label="A very long label indeed, well at least longer than the input field to show how it looks and works and stuff"
value={value}
valueLabel={valueLabel}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -21,7 +21,7 @@ describe('<SingleSelectA11yField />', () => {

it('should forward props to the SingleSelectA11y component', () => {
const options = []
const customOption = () => null
const optionComponent = () => null
const onChange = () => null
const onBlur = () => null
const onEndReached = () => null
Expand All @@ -32,14 +32,14 @@ describe('<SingleSelectA11yField />', () => {
<SingleSelectA11yField
label="Label text"
// Props that'll be passed to SingleSelectA11y
idPrefix="foo"
name="foo"
options={options}
onChange={onChange}
autoFocus={false}
className=""
clearText=""
clearable={false}
customOption={customOption}
optionComponent={optionComponent}
dataTest=""
dense={false}
disabled={false}
Expand Down Expand Up @@ -67,15 +67,15 @@ describe('<SingleSelectA11yField />', () => {
/>
)

expect(SingleSelectA11y.mock.calls[0][0].idPrefix).toBe('foo')
expect(SingleSelectA11y.mock.calls[0][0].name).toBe('foo')
expect(SingleSelectA11y.mock.calls[0][0].options).toBe(options)
expect(SingleSelectA11y.mock.calls[0][0].onChange).toBe(onChange)
expect(SingleSelectA11y.mock.calls[0][0].autoFocus).toBe(false)
expect(SingleSelectA11y.mock.calls[0][0].className).toBe('')
expect(SingleSelectA11y.mock.calls[0][0].clearText).toBe('')
expect(SingleSelectA11y.mock.calls[0][0].clearable).toBe(false)
expect(SingleSelectA11y.mock.calls[0][0].customOption).toBe(
customOption
expect(SingleSelectA11y.mock.calls[0][0].optionComponent).toBe(
optionComponent
)
expect(SingleSelectA11y.mock.calls[0][0].dataTest).toBe('')
expect(SingleSelectA11y.mock.calls[0][0].dense).toBe(false)
Expand Down Expand Up @@ -122,7 +122,7 @@ describe('<SingleSelectA11yField />', () => {
validationText="Validation text"
valid={true}
// Props required by SingleSelectA11y
idPrefix="foo"
name="foo"
options={[]}
onChange={() => null}
/>
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,10 @@ import { SingleSelectA11y } from '../single-select-a11y.js'
import { fiveOptions } from './options.js'

export const DefaultPosition = () => {
const [value, setValue] = useState('anc_1st_visit')
const [selected, setSelected] = useState({
label: 'ANC 1st visit',
value: 'anc_1st_visit',
})

return (
<div
Expand All @@ -23,16 +26,9 @@ export const DefaultPosition = () => {
}}
>
<SingleSelectA11y
idPrefix="a11y"
value={value}
valueLabel={
value
? fiveOptions.find(
(option) => option.value === value
).label
: ''
}
onChange={(nextValue) => setValue(nextValue)}
name="a11y"
selected={selected}
onChange={setSelected}
options={fiveOptions}
/>
</div>
Expand Down
13 changes: 4 additions & 9 deletions components/select/src/single-select-a11y/__stories__/Dense.js
Original file line number Diff line number Diff line change
Expand Up @@ -3,19 +3,14 @@ import { SingleSelectA11y } from '../single-select-a11y.js'
import { fiveOptions } from './options.js'

export const Dense = () => {
const [value, setValue] = useState('')
const [selected, setSelected] = useState(null)

return (
<SingleSelectA11y
dense
idPrefix="a11y"
value={value}
valueLabel={
value
? fiveOptions.find((option) => option.value === value).label
: ''
}
onChange={(nextValue) => setValue(nextValue)}
name="a11y"
selected={selected}
onChange={setSelected}
options={fiveOptions}
/>
)
Expand Down
14 changes: 4 additions & 10 deletions components/select/src/single-select-a11y/__stories__/Empty.js
Original file line number Diff line number Diff line change
@@ -1,20 +1,14 @@
import React, { useState } from 'react'
import { SingleSelectA11y } from '../single-select-a11y.js'
import { options } from './options.js'

export const Empty = () => {
const [value, setValue] = useState('')
const [selected, setSelected] = useState(null)

return (
<SingleSelectA11y
idPrefix="a11y"
value={value}
valueLabel={
value
? options.find((option) => option.value === value).label
: ''
}
onChange={(nextValue) => setValue(nextValue)}
name="a11y"
selected={selected}
onChange={setSelected}
options={[]}
/>
)
Expand Down
Original file line number Diff line number Diff line change
@@ -1,9 +1,8 @@
import React, { useState } from 'react'
import { SingleSelectA11y } from '../single-select-a11y.js'
import { options } from './options.js'

export const EmptyWithEmptyNode = () => {
const [value, setValue] = useState('')
const [selected, setSelected] = useState(null)
const emptyNode = (
<div
style={{
Expand All @@ -18,14 +17,9 @@ export const EmptyWithEmptyNode = () => {

return (
<SingleSelectA11y
idPrefix="a11y"
value={value}
valueLabel={
value
? options.find((option) => option.value === value).label
: ''
}
onChange={(nextValue) => setValue(nextValue)}
name="a11y"
selected={selected}
onChange={setSelected}
options={[]}
empty={emptyNode}
/>
Expand Down
Loading

0 comments on commit 0dc3760

Please sign in to comment.