mirror of
https://github.com/emsesp/EMS-ESP32.git
synced 2025-12-07 00:09:51 +03:00
51 lines
1.3 KiB
TypeScript
51 lines
1.3 KiB
TypeScript
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;
|
|
}
|
|
};
|
|
|
|
type UpdateEntity<S> = (state: (prevState: Readonly<S>) => S) => void;
|
|
|
|
export const updateValue =
|
|
<S>(updateEntity: UpdateEntity<S>) =>
|
|
(event: React.ChangeEvent<HTMLInputElement>) => {
|
|
updateEntity((prevState) => ({
|
|
...prevState,
|
|
[event.target.name]: extractEventValue(event)
|
|
}));
|
|
};
|
|
|
|
export const updateValueDirty =
|
|
(origData: any, dirtyFlags: any, setDirtyFlags: any, updateDataValue: any) =>
|
|
(event: React.ChangeEvent<HTMLInputElement>) => {
|
|
const updated_value = extractEventValue(event);
|
|
const name = event.target.name;
|
|
|
|
updateDataValue((prevState) => ({
|
|
...prevState,
|
|
[name]: updated_value
|
|
}));
|
|
|
|
const arr: string[] = dirtyFlags;
|
|
|
|
if (origData[name] !== updated_value) {
|
|
if (!arr.includes(name)) {
|
|
arr.push(name);
|
|
}
|
|
} else {
|
|
const startIndex = arr.indexOf(name);
|
|
if (startIndex !== -1) {
|
|
arr.splice(startIndex, 1);
|
|
}
|
|
}
|
|
|
|
setDirtyFlags(arr);
|
|
};
|