mirror of
https://github.com/emsesp/EMS-ESP32.git
synced 2025-12-06 07:49:52 +03:00
108 lines
3.3 KiB
TypeScript
108 lines
3.3 KiB
TypeScript
import CancelIcon from '@mui/icons-material/Cancel';
|
|
import PersonAddIcon from '@mui/icons-material/PersonAdd';
|
|
import SaveIcon from '@mui/icons-material/Save';
|
|
|
|
import { Button, Checkbox, Dialog, DialogActions, DialogContent, DialogTitle } from '@mui/material';
|
|
import { useState, useEffect } from 'react';
|
|
import type Schema from 'async-validator';
|
|
import type { ValidateFieldsError } from 'async-validator';
|
|
import type { FC } from 'react';
|
|
|
|
import type { UserType } from 'types';
|
|
import { dialogStyle } from 'CustomTheme';
|
|
import { BlockFormControlLabel, ValidatedPasswordField, ValidatedTextField } from 'components';
|
|
import { useI18nContext } from 'i18n/i18n-react';
|
|
import { updateValue } from 'utils';
|
|
import { validate } from 'validators';
|
|
|
|
interface UserFormProps {
|
|
creating: boolean;
|
|
validator: Schema;
|
|
|
|
user?: UserType;
|
|
setUser: React.Dispatch<React.SetStateAction<UserType | undefined>>;
|
|
|
|
onDoneEditing: () => void;
|
|
onCancelEditing: () => void;
|
|
}
|
|
|
|
const User: FC<UserFormProps> = ({ creating, validator, user, setUser, onDoneEditing, onCancelEditing }) => {
|
|
const { LL } = useI18nContext();
|
|
|
|
const updateFormValue = updateValue(setUser);
|
|
const [fieldErrors, setFieldErrors] = useState<ValidateFieldsError>();
|
|
const open = !!user;
|
|
|
|
useEffect(() => {
|
|
if (open) {
|
|
setFieldErrors(undefined);
|
|
}
|
|
}, [open]);
|
|
|
|
const validateAndDone = async () => {
|
|
if (user) {
|
|
try {
|
|
setFieldErrors(undefined);
|
|
await validate(validator, user);
|
|
onDoneEditing();
|
|
} catch (errors: any) {
|
|
setFieldErrors(errors);
|
|
}
|
|
}
|
|
};
|
|
|
|
return (
|
|
<Dialog sx={dialogStyle} onClose={onCancelEditing} open={!!user} fullWidth maxWidth="sm">
|
|
{user && (
|
|
<>
|
|
<DialogTitle id="user-form-dialog-title">
|
|
{creating ? LL.ADD(1) : LL.MODIFY()} {LL.USER(1)}
|
|
</DialogTitle>
|
|
<DialogContent dividers>
|
|
<ValidatedTextField
|
|
fieldErrors={fieldErrors}
|
|
name="username"
|
|
label={LL.USERNAME(1)}
|
|
fullWidth
|
|
variant="outlined"
|
|
value={user.username}
|
|
disabled={!creating}
|
|
onChange={updateFormValue}
|
|
margin="normal"
|
|
/>
|
|
<ValidatedPasswordField
|
|
fieldErrors={fieldErrors}
|
|
name="password"
|
|
label={LL.PASSWORD()}
|
|
fullWidth
|
|
variant="outlined"
|
|
value={user.password}
|
|
onChange={updateFormValue}
|
|
margin="normal"
|
|
/>
|
|
<BlockFormControlLabel
|
|
control={<Checkbox name="admin" checked={user.admin} onChange={updateFormValue} />}
|
|
label={LL.IS_ADMIN(1)}
|
|
/>
|
|
</DialogContent>
|
|
<DialogActions>
|
|
<Button startIcon={<CancelIcon />} variant="outlined" onClick={onCancelEditing} color="secondary">
|
|
{LL.CANCEL()}
|
|
</Button>
|
|
<Button
|
|
startIcon={creating ? <PersonAddIcon /> : <SaveIcon />}
|
|
variant="outlined"
|
|
onClick={validateAndDone}
|
|
color="primary"
|
|
>
|
|
{creating ? LL.ADD(0) : LL.UPDATE()}
|
|
</Button>
|
|
</DialogActions>
|
|
</>
|
|
)}
|
|
</Dialog>
|
|
);
|
|
};
|
|
|
|
export default User;
|