import React, { useState } from 'react'; import { useNavigate } from 'react-router-dom'; import { Button, Paper, TextField, Typography, IconButton, InputAdornment, } from '@mui/material'; import { Visibility, VisibilityOff } from '@mui/icons-material'; import { useForm } from 'react-hook-form'; import { useAppDispatch } from '../hooks'; import { setAdmin } from '../slices/auth/adminSlice'; import { useLoginAdminMutation } from '../slices/api/adminSlice'; import { showSnackbar } from '../slices/uiSlice'; import { isFetchBaseQueryError } from '../error'; import type { Credentials } from '../models'; import type { Data } from '../error'; function GuestLogin() { const dispatch = useAppDispatch(); const navigate = useNavigate(); const [login] = useLoginAdminMutation(); const [showPassword, setShowPassword] = useState(false); const { register, handleSubmit, formState: { errors }, } = useForm({ defaultValues: { username: '', password: '', }, }); const onSubmit = async (data: Credentials) => { try { dispatch(setAdmin(await login(data).unwrap())); navigate('/dashboard'); } catch (error) { if (isFetchBaseQueryError(error)) { dispatch( showSnackbar({ message: (error.data as Data).message, severity: 'error', }) ); } else { dispatch( showSnackbar({ message: 'No response', severity: 'error', }) ); } } }; const handleClickShowPassword = () => setShowPassword((show) => !show); return (
Admin Login {showPassword ? : } ), }} error={!!errors.password} helperText={errors.password?.message} required {...register('password', { required: 'This field is required' })} />
); } export default GuestLogin;