Skip to content

Commit

Permalink
fix: associate labels with autosuggest input
Browse files Browse the repository at this point in the history
  • Loading branch information
brian-smith-tcril committed Nov 28, 2023
1 parent 3698605 commit 852889f
Show file tree
Hide file tree
Showing 3 changed files with 64 additions and 29 deletions.
16 changes: 11 additions & 5 deletions src/Form/FormAutosuggest.jsx
Original file line number Diff line number Diff line change
Expand Up @@ -6,7 +6,7 @@ import { v4 as uuidv4 } from 'uuid';
import { useIntl } from 'react-intl';
import { KeyboardArrowUp, KeyboardArrowDown } from '../../icons';
import Icon from '../Icon';
import FormGroup from './FormGroup';
import { FormGroupContextProvider, useFormGroupContext } from './FormGroupContext';
import FormControl from './FormControl';
import FormControlFeedback from './FormControlFeedback';
import IconButton from '../IconButton';
Expand Down Expand Up @@ -239,12 +239,18 @@ function FormAutosuggest({
setDisplayValue(e.target.value);
};

const { getControlProps } = useFormGroupContext();
const controlProps = getControlProps(props);

return (
<div className="pgn__form-autosuggest__wrapper" ref={parentRef}>
<div aria-live="assertive" className="sr-only" data-testid="autosuggest-screen-reader-options-count">
{`${state.dropDownItems.length} options found`}
</div>
<FormGroup isInvalid={!!state.errorMessage}>
<FormGroupContextProvider
controlId={controlProps.id}
isInvalid={!!state.errorMessage}
>
<FormControl
ref={formControlRef}
aria-expanded={(state.dropDownItems.length > 0).toString()}
Expand All @@ -259,7 +265,7 @@ function FormAutosuggest({
onClick={handleClick}
trailingElement={iconToggle}
data-testid="autosuggest-textbox-input"
{...props}
{...controlProps}
/>

{helpMessage && !state.errorMessage && (
Expand All @@ -269,11 +275,11 @@ function FormAutosuggest({
)}

{state.errorMessage && (
<FormControlFeedback type="invalid" feedback-for={props.name}>
<FormControlFeedback type="invalid" feedback-for={controlProps.name}>
{errorMessageText}
</FormControlFeedback>
)}
</FormGroup>
</FormGroupContextProvider>

<ul
id="pgn__form-autosuggest__dropdown-box"
Expand Down
56 changes: 32 additions & 24 deletions src/Form/form-autosuggest.mdx
Original file line number Diff line number Diff line change
Expand Up @@ -22,21 +22,25 @@ Form auto-suggest enables users to manually select or type to find matching opti
const [selected, setSelected] = useState('');

return (
<Form.Autosuggest
floatingLabel="Programming language"
aria-label="form autosuggest"
helpMessage="Select language"
errorMessageText="Error, no selected value"
value={selected}
onSelected={(value) => setSelected(value)}
>
<Form.AutosuggestOption>JavaScript</Form.AutosuggestOption>
<Form.AutosuggestOption>Python</Form.AutosuggestOption>
<Form.AutosuggestOption>Rube</Form.AutosuggestOption>
<Form.AutosuggestOption onClick={(e) => alert(e.currentTarget.getAttribute('data-value'))}>
Option with custom onClick
</Form.AutosuggestOption>
</Form.Autosuggest>
<Form.Group>
<Form.Label>
<h4>Programming language</h4>
</Form.Label>
<Form.Autosuggest
aria-label="form autosuggest"
helpMessage="Select language"
errorMessageText="Error, no selected value"
value={selected}
onSelected={(value) => setSelected(value)}
>
<Form.AutosuggestOption>JavaScript</Form.AutosuggestOption>
<Form.AutosuggestOption>Python</Form.AutosuggestOption>
<Form.AutosuggestOption>Rube</Form.AutosuggestOption>
<Form.AutosuggestOption onClick={(e) => alert(e.currentTarget.getAttribute('data-value'))}>
Option with custom onClick
</Form.AutosuggestOption>
</Form.Autosuggest>
</Form.Group>
);
}
```
Expand Down Expand Up @@ -97,15 +101,19 @@ Form auto-suggest enables users to manually select or type to find matching opti
};

return (
<Form.Autosuggest
isLoading={showLoading}
placeholder="This is placeholder"
floatingLabel="This is floating label"
screenReaderText="Loading..."
onChange={searchCoffee}
>
{data.map((item, index) => <Form.AutosuggestOption key={index}>{item.title}</Form.AutosuggestOption>)}
</Form.Autosuggest>
<Form.Group>
<Form.Label>
<h4>Café API</h4>
</Form.Label>
<Form.Autosuggest
isLoading={showLoading}
placeholder="This is placeholder"
screenReaderText="Loading..."
onChange={searchCoffee}
>
{data.map((item, index) => <Form.AutosuggestOption key={index}>{item.title}</Form.AutosuggestOption>)}
</Form.Autosuggest>
</Form.Group>
);
}
```
21 changes: 21 additions & 0 deletions src/Form/tests/FormAutosuggest.test.jsx
Original file line number Diff line number Diff line change
Expand Up @@ -6,6 +6,8 @@ import userEvent from '@testing-library/user-event';
import { IntlProvider } from 'react-intl';
import FormAutosuggest from '../FormAutosuggest';
import FormAutosuggestOption from '../FormAutosuggestOption';
import FormGroup from '../FormGroup';
import FormLabel from '../FormLabel';

function FormAutosuggestWrapper(props) {
return (
Expand All @@ -31,6 +33,19 @@ function FormAutosuggestTestComponent(props) {
);
}

function FormAutosuggestLabelTestComponent() {
return (
<FormGroup>
<FormLabel data-testid="autosuggest-label">
<h3>Label</h3>
</FormLabel>
<FormAutosuggestWrapper>
<FormAutosuggestOption>Option</FormAutosuggestOption>
</FormAutosuggestWrapper>
</FormGroup>
);
}

FormAutosuggestTestComponent.defaultProps = {
onSelected: jest.fn(),
onClick: jest.fn(),
Expand Down Expand Up @@ -112,6 +127,12 @@ describe('render behavior', () => {

expect(getByText('3 options found')).toBeInTheDocument();
});

it('associates labels with the input textbox', () => {
const { getByTestId } = render(<FormAutosuggestLabelTestComponent />);

expect(getByTestId('autosuggest-label').getAttribute('for')).toEqual(getByTestId('autosuggest-textbox-input').getAttribute('id'));
});
});

describe('controlled behavior', () => {
Expand Down

0 comments on commit 852889f

Please sign in to comment.