mirror of
https://github.com/emsesp/EMS-ESP32.git
synced 2025-12-07 00:09:51 +03:00
24 lines
683 B
TypeScript
24 lines
683 B
TypeScript
type UpdateEntity<S> = (state: (prevState: Readonly<S>) => S) => void;
|
|
|
|
export const numberValue = (value: number) => (isNaN(value) ? '' : value.toString());
|
|
|
|
export const extractEventValue = (event: React.ChangeEvent<HTMLInputElement>) => {
|
|
switch (event.target.type) {
|
|
case 'number':
|
|
return event.target.valueAsNumber;
|
|
case 'checkbox':
|
|
return event.target.checked;
|
|
default:
|
|
return event.target.value;
|
|
}
|
|
};
|
|
|
|
export const updateValue =
|
|
<S>(updateEntity: UpdateEntity<S>) =>
|
|
(event: React.ChangeEvent<HTMLInputElement>) => {
|
|
updateEntity((prevState) => ({
|
|
...prevState,
|
|
[event.target.name]: extractEventValue(event)
|
|
}));
|
|
};
|