I’m looking how to trigger onChange function when an option is already selected and clicked by the user to deselect it, it’s like multiselect.
you can select an option and deselect it by clicking on it a second time.
this is what i’ve already tried.
everything is working when there is more than 1 option selected, but not when there is only one option selected.
const handleChangeGroup = (selectedItems) => {
const groups = [];
for (let i = 0; i < selectedItems.length; i++) {
if (groupArray.includes(selectedItems[i].value)) {
if (groupArray.length === 0) {
setGroupArray([]);
} else {
var newArray = groupArray.filter(
(value) => value != selectedItems[i].value
);
setGroupArray(newArray);
}
} else {
groups.push(selectedItems[i].value);
setGroupArray(groupArray.concat(groups));
}
}
};
<select
multiple={true}
value={groupArray}
onChange={(event) =>
handleChangeGroup(event.target.selectedOptions)
}>
{data[selectType] !== undefined
? Object.keys(data[selectType]).map((group, index) => (
<option value={group} key={group}>
{group}
</option>
))
: null}
</select>