import React from 'react'; import { useNavigate } from 'react-router-dom'; import { Button, Paper, TextField, Typography } from '@mui/material'; import { useForm } from 'react-hook-form'; import { useAppDispatch } from '../hooks'; import { setGuest } from '../slices/auth/guestSlice'; import { useLoginGuestMutation } from '../slices/api/guestSlice'; import { showSnackbar } from '../slices/uiSlice'; import { isFetchBaseQueryError } from '../error'; import type { Data } from '../error'; import type { Name } from '../models'; function GuestLogin() { const dispatch = useAppDispatch(); const navigate = useNavigate(); const [login] = useLoginGuestMutation(); const { register, handleSubmit, formState: { errors }, } = useForm({ defaultValues: { firstName: '', lastName: '', }, }); const onSubmit = async (data: Name) => { try { dispatch(setGuest(await login(data).unwrap())); navigate('/rsvp'); } catch (error) { if (isFetchBaseQueryError(error)) { dispatch( showSnackbar({ message: (error.data as Data).message, severity: 'error', }) ); } else { dispatch( showSnackbar({ message: 'No response', severity: 'error', }) ); } } }; return (
Guest Login
); } export default GuestLogin;