Edit Crud, add loaders during authentication

Took 2 hours 49 minutes
This commit is contained in:
Lucàs
2023-03-26 17:02:24 +02:00
parent 668e092dd3
commit 5cc56e46ec
16 changed files with 3319 additions and 154 deletions
+9 -4
View File
@@ -16,6 +16,7 @@ import {LoginData} from '@/models/form/LoginData';
export default function LoginForm() {
const router = useRouter();
const [loginData, setLoginData] = useState(new LoginData());
const [isLoading, setIsLoading] = useState(false);
const [invalidInput, setInvalidInput] = useState(false);
const buttonWidth = {base: '100%', md: 'unset'};
@@ -26,11 +27,15 @@ export default function LoginForm() {
};
const handleSubmit = async () => {
await signIn('credentials',
{...loginData, redirect: false}).then((res) => {
setIsLoading(true)
signIn('credentials', {...loginData, redirect: false})
.then((res: unknown) => {
const {ok: connexionSuccess} = res as SignInResponse;
if (!connexionSuccess) setInvalidInput(true);
if (!connexionSuccess) {
setIsLoading(false);
setInvalidInput(true);
}
else router.push('/dashboard');
});
};
@@ -76,7 +81,7 @@ export default function LoginForm() {
justifyContent={'space-between'}>
<Button onClick={() => router.push('/')}
w={buttonWidth}>Retour</Button>
<Button onClick={handleSubmit}
<Button isLoading={isLoading} onClick={handleSubmit}
w={buttonWidth} colorScheme="purple">Connexion</Button>
</Flex>
</Container>
+20 -15
View File
@@ -9,12 +9,13 @@ import {
} from '@chakra-ui/react';
import {useRouter} from 'next/router';
import {useState} from 'react';
import {RegisterData} from '@/models/form/RegisterData';
import {signIn, SignInResponse} from 'next-auth/react';
import {RegisterData} from '@/models/form/RegisterData';
export default function RegisterForm() {
const router = useRouter();
const [registerData, setRegisterData] = useState(new RegisterData());
const [isLoading, setIsLoading] = useState(false);
const [invalidInput, setInvalidInput] = useState(false);
const buttonWidth = {base: '100%', md: 'unset'};
@@ -28,31 +29,34 @@ export default function RegisterForm() {
let {email, firstName, lastName, password, confirmPassword} = registerData;
if (password !== confirmPassword) setInvalidInput(true);
fetch('/api/user', {
method: 'PUT',
const options = {
method: 'POST',
headers: {'Content-Type': 'application/json'},
body: JSON.stringify({email, firstName, lastName, password}),
}).then(() => {
};
setIsLoading(true);
fetch('/api/users', options).then(() => {
signIn('credentials', {email, password, redirect: false})
.then((res) => {
const {ok: connexionSuccess} = res as SignInResponse;
// TODO If success -> goto interactive form else login
router.push( connexionSuccess ? "/" : "/login");
});
.then((res: unknown) => {
const {ok: connexionSuccess} = res as SignInResponse;
// TODO If success -> goto interactive form else login
router.push(connexionSuccess ? '/' : '/login');
});
}).catch(() => {
setIsLoading(false);
setInvalidInput(true);
setRegisterData({...registerData, password: '', confirmPassword: ''});
});
};
return (
<Box flexBasis={"100%"}>
<Box flexBasis={'100%'}>
<Container>
<Heading textAlign={"center"} size={"2xl"}>Inscription</Heading>
<Heading textAlign={'center'} size={'2xl'}>Inscription</Heading>
<Flex mt={"100px"} mb={'1rem'} gap={5}>
<Flex mt={'100px'} mb={'1rem'} gap={5}>
{/*Prénom*/}
<FormControl>
<FormLabel>Prénom</FormLabel>
@@ -119,8 +123,9 @@ export default function RegisterForm() {
<Flex mt={'50px'} w={'100%'} justify={'space-between'} gap={5}>
<Button onClick={() => router.push('/')} w={buttonWidth}>Retour</Button>
<Button onClick={handleSubmit} w={buttonWidth} colorScheme="purple">Je
<Button onClick={() => router.push('/')}
w={buttonWidth}>Retour</Button>
<Button isLoading={isLoading} onClick={handleSubmit} w={buttonWidth} colorScheme="purple">Je
m&apos;inscris</Button>
</Flex>
</Container>