Автозаполнение пользовательского интерфейса материала onChange не обновляет значение
Я создал общий компонент раскрывающегося меню, используя (Material-Ui Autocomplete), поэтому я могу использовать его там, где мне нужно. Но я столкнулся с проблемой, автозаполнение не обновляет значение при "изменении"
Запись
Я переходил по разным ссылкам, но не смог получить правильного ответа. У меня немного другой сценарий. Я создал общий компонент раскрывающегося меню и при необходимости использую его внутри других компонентов.
Вот код компонента выпадающего меню
import React, { memo, useEffect } from "react";
import TextField from "@material-ui/core/TextField";
import Autocomplete from "@material-ui/lab/Autocomplete";
import CircularProgress from "@material-ui/core/CircularProgress";
import { useDispatch } from "react-redux";
interface IAsyncDropDownMenu {
title: string;
id?: string;
loadData: Function;
onSelect(value: any): void;
fieldError: {
error: false,
label: "",
helperText: "",
validateInput: false,
};
}
interface IOptionTypes {
id: number;
name: string;
}
const AsyncDropDownMenu: React.FC<IAsyncDropDownMenu> = memo(
({
title,
id = "asynchronous-dropdown-menu",
loadData,
onSelect,
fieldError,
}) => {
const [open, setOpen] = React.useState(false);
const [options, setOptions] = React.useState<IOptionTypes[]>([]);
const loading = open && options.length === 0;
const [selectedOption, setSelectedOption] = React.useState<any>({
id: 0,
name: "",
});
const dispatch = useDispatch();
const seletOption = (value: any) => {
onSelect(value);
};
useEffect(() => {
let active = true;
if (!loading) {
return undefined;
}
(async () => {
const data = await dispatch(loadData());
if (active) {
setOptions(data);
}
})();
return () => {
active = false;
};
}, [loading]);
useEffect(() => {
if (!open) {
setOptions([]);
}
}, [open]);
return (
<Autocomplete
id={id}
open={open}
onOpen={() => {
setOpen(true);
}}
onClose={() => {
setOpen(false);
}}
onChange={(event, value) => seletOption(value)}
getOptionSelected={(option, value) => option.name === value.name}
getOptionLabel={(option) => option.name}
options={options}
loading={loading}
renderInput={(params) => (
<TextField
{...params}
label={title}
helperText={fieldError.helperText}
error={fieldError.error}
InputProps={{
...params.InputProps,
endAdornment: (
<>
{loading ? (
<CircularProgress color="inherit" size={20} />
) : null}
{params.InputProps.endAdornment}
</>
),
}}
/>
)}
/>
);
}
);
export { AsyncDropDownMenu };
Вот код компонента, в котором я использую компонент раскрывающегося меню
const ProductSubCategory: React.FC = () => {
const classes = CommonStyle();
const subCatList=[];
const dispatch = useDispatch();
//#region error states and function
const [selectedOption, setSelectedOption] = React.useState({
id: 0,
name: "",
});
const [categoryError, setCategoryError] = React.useState({
error: false,
label: "",
helperText: "",
validateInput: false,
});
const onError = (action: Function, message: string = "Required field") => {
action({
error: true,
label: "required",
helperText: message,
validateInput: true,
});
};
//#endregion
const onselect = (value: any) => {
if (categoryError.validateInput) {
setCategoryError({
error: false,
label: "",
helperText: "",
validateInput: false,
});
}
setSelectedOption(value);
};
//#region grid columns
const columns = [
{
title: "Category",
render: (rowData: ITemp) => {
return rowData.categories ? rowData.categories.name : "";
},
field: "category",
lookup: {},
editComponent: (props: any) => (
<AsyncDropDownMenu
title="Category"
loadData={loadCategories}
onSelect={onselect}
fieldError={categoryError}
></AsyncDropDownMenu>
),
},
];
//#endregion
//#region validate input data
const onValidate = (
data: any,
reject: Function,
resolve: Function,
action: Function,
isUpdate: boolean,
oldData: any
) => {
if (Object.keys(data).length === 0 && selectedOption.id === 0) {
onError(setNameError);
onError(setCategoryError);
reject();
} else if (selectedOption.id === 0) {
onError(setCategoryError);
reject();
} else {
if (isUpdate) {
if (data !== oldData) dispatch(action(data, reject, resolve));
else reject();
} else {
dispatch(action(data, reject, resolve));
}
}
};
//#endregion
return (
<div>
<CustomMatrialTable
title="Product Sub Categories"
isLoading={isLoading}
col={columns}
data={subCatList}
></CustomMatrialTable>
</div>
);
};
export { ProductSubCategory };
В прилагаемом изображении показана проблема, с которой я столкнулся. Значение раскрывающегося списка не обновляется при выборе