Skip to content

Commit

Permalink
fix: use currentTarget in FormAutosuggest component to get select…
Browse files Browse the repository at this point in the history
…ed option (#2304)
  • Loading branch information
viktorrusakov authored May 16, 2023
1 parent 4983576 commit 8988f11
Show file tree
Hide file tree
Showing 4 changed files with 25 additions and 46 deletions.
2 changes: 1 addition & 1 deletion package.json
Original file line number Diff line number Diff line change
Expand Up @@ -25,7 +25,7 @@
"commit": "commit",
"debug-test": "node --inspect-brk node_modules/.bin/jest --runInBand --coverage",
"stylelint": "stylelint \"src/**/*.scss\" \"scss/**/*.scss\" \"www/src/**/*.scss\" --config .stylelintrc.json",
"lint": "npm run stylelint && eslint --ext .js --ext .jsx --ext .ts --ext .tsx && npm run lint --workspaces --if-present",
"lint": "npm run stylelint && eslint --ext .js --ext .jsx --ext .ts --ext .tsx . && npm run lint --workspaces --if-present",
"prepublishOnly": "npm run build",
"semantic-release": "semantic-release",
"snapshot": "jest --updateSnapshot",
Expand Down
49 changes: 16 additions & 33 deletions src/Form/FormAutosuggest.jsx
Original file line number Diff line number Diff line change
Expand Up @@ -38,25 +38,17 @@ function FormAutosuggest({
dropDownItems: [],
});

const setValue = (itemValue, optValue) => {
if (value === itemValue) { return; }
const handleItemClick = (e, onClick) => {
const clickedValue = e.currentTarget.value;

if (onSelected) { onSelected(itemValue); }

if (optValue !== state.displayValue) {
setState(prevState => ({
...prevState,
displayValue: optValue,
}));
if (onSelected && clickedValue !== value) {
onSelected(clickedValue);
}
};

const handleItemClick = (e, optValue, onClick) => {
setValue(e.target.value, optValue);

setState(prevState => ({
...prevState,
dropDownItems: '',
dropDownItems: [],
displayValue: clickedValue,
}));

setIsMenuClosed(true);
Expand All @@ -71,14 +63,12 @@ function FormAutosuggest({
// eslint-disable-next-line no-shadow
const { children, onClick, ...rest } = child.props;

const modifiedOpt = React.cloneElement(child, {
return React.cloneElement(child, {
...rest,
children,
value: children,
onClick: (e) => handleItemClick(e, children, onClick),
onClick: (e) => handleItemClick(e, onClick),
});

return modifiedOpt;
});

if (strToFind.length > 0) {
Expand Down Expand Up @@ -125,7 +115,7 @@ function FormAutosuggest({
if (parentRef.current && !parentRef.current.contains(e.target) && state.dropDownItems.length > 0) {
setState(prevState => ({
...prevState,
dropDownItems: '',
dropDownItems: [],
errorMessage: !state.displayValue ? errorMessageText : '',
}));

Expand All @@ -139,7 +129,7 @@ function FormAutosuggest({

setState(prevState => ({
...prevState,
dropDownItems: '',
dropDownItems: [],
errorMessage: !state.displayValue ? errorMessageText : '',
}));

Expand All @@ -158,7 +148,7 @@ function FormAutosuggest({
});

useEffect(() => {
if (value !== state.displayValue) {
if (value || value === '') {
setState(prevState => ({
...prevState,
displayValue: value,
Expand All @@ -176,17 +166,10 @@ function FormAutosuggest({
const normalized = itemValue.toLowerCase();
const opt = optValue.find((o) => o.toLowerCase() === normalized);

if (opt) {
setState(prevState => ({
...prevState,
displayValue: opt,
}));
} else {
setState(prevState => ({
...prevState,
displayValue: itemValue,
}));
}
setState(prevState => ({
...prevState,
displayValue: opt || itemValue,
}));
};

const handleClick = (e) => {
Expand Down Expand Up @@ -220,7 +203,7 @@ function FormAutosuggest({
} else {
setState(prevState => ({
...prevState,
dropDownItems: '',
dropDownItems: [],
errorMessageText,
}));

Expand Down
18 changes: 7 additions & 11 deletions src/Form/form-autosuggest.mdx
Original file line number Diff line number Diff line change
Expand Up @@ -19,23 +19,21 @@ Form auto-suggest enables users to manually select or type to find matching opti

```jsx live
() => {
const [selected, setSelected] = useState({ title: '' });
const [selected, setSelected] = useState('');

return (
<Form.Autosuggest
floatingLabel="Programming language"
aria-label="form autosuggest"
helpMessage="Select language"
errorMessageText="Error, no selected value"
value={selected.title}
onSelected={
(value) => setSelected(prevState => ({ selected: { ...prevState.selected, title: 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.target.value)}>
<Form.AutosuggestOption onClick={(e) => alert(e.currentTarget.value)}>
Option with custom onClick
</Form.AutosuggestOption>
</Form.Autosuggest>
Expand All @@ -47,18 +45,16 @@ Form auto-suggest enables users to manually select or type to find matching opti

```jsx live
() => {
const [selected, setSelected] = useState({ title: '' });
const [selected, setSelected] = useState('');

return (
<Form.Autosuggest
placeholder="Type 'T'"
aria-label="form autosuggest"
errorMessageText="Error, no selected value"
helpMessage="Select language"
value={selected.title}
onSelected={
(value) => setSelected(prevState => ({ selected: { ...prevState.selected, title: value } }))
}
value={selected}
onSelected={(value) => setSelected(value)}
>
<Form.AutosuggestOption>PHP</Form.AutosuggestOption>
<Form.AutosuggestOption>Java</Form.AutosuggestOption>
Expand Down
2 changes: 1 addition & 1 deletion src/Modal/AlertModal.jsx
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,7 @@ import PropTypes from 'prop-types';
import classNames from 'classnames';

import { requiredWhenNot } from '../utils/propTypes';
import { Icon } from '..';
import Icon from '../Icon';
import ModalDialog from './ModalDialog';

function AlertModal({
Expand Down

0 comments on commit 8988f11

Please sign in to comment.