|
|
@@ -1,10 +1,11 @@
|
|
|
import * as React from 'react';
|
|
|
import toast, { Toaster } from 'react-hot-toast';
|
|
|
-import { useNavigate } from 'react-router-dom'
|
|
|
+import { Navigate, useNavigate } from 'react-router-dom'
|
|
|
import jwt_decode from "jwt-decode";
|
|
|
-import { useDispatch } from "react-redux";
|
|
|
+import { useDispatch , useSelector } from "react-redux";
|
|
|
|
|
|
import { setToken } from '../Slices/tokenSlice'
|
|
|
+import { setProfile, setRole } from '../Slices/userSlice.js'
|
|
|
|
|
|
import {
|
|
|
Paper, Box, Grid, Typography, TextField, Button, Avatar,
|
|
|
@@ -15,7 +16,6 @@ import { createTheme, ThemeProvider } from '@mui/material/styles';
|
|
|
|
|
|
import PersonIcon from '@mui/icons-material/Person';
|
|
|
import { Copyright } from '../Components/Footer.js'
|
|
|
-import useAuth from '../Auth/useAuth';
|
|
|
|
|
|
import { useFormik } from 'formik';
|
|
|
import * as Yup from 'yup';
|
|
|
@@ -37,12 +37,18 @@ const theme = createTheme();
|
|
|
|
|
|
export function LoginCs() {
|
|
|
|
|
|
- let auth = useAuth();
|
|
|
- let navigate = useNavigate()
|
|
|
-
|
|
|
const [open, setOpen] = React.useState(false);
|
|
|
const dispatch = useDispatch();
|
|
|
const handleClose = () => false
|
|
|
+ const navigate = useNavigate();
|
|
|
+ let token = useSelector((state) => state.token.token)
|
|
|
+
|
|
|
+ React.useEffect(() => {
|
|
|
+ if(token){
|
|
|
+ navigate('/user/home')
|
|
|
+ }
|
|
|
+ }, [token, navigate])
|
|
|
+
|
|
|
|
|
|
const formik = useFormik({
|
|
|
initialValues: {
|
|
|
@@ -52,14 +58,11 @@ export function LoginCs() {
|
|
|
validationSchema: LoginSchema,
|
|
|
onSubmit: async (values) => {
|
|
|
|
|
|
- //
|
|
|
- // QW5hbGlzdGEgZGUgY29tcHJhcw==
|
|
|
- //
|
|
|
-
|
|
|
let { email, password } = values
|
|
|
setOpen(true)
|
|
|
|
|
|
- let request = new Service(`/user?user=${email}&password=${password}&typeusr=iscandidato`)
|
|
|
+ let url = `/user?user=${email}&password=${password}&typeusr=iscandidato`
|
|
|
+ let request = new Service(url);
|
|
|
request
|
|
|
.post({})
|
|
|
.then(response => {
|
|
|
@@ -68,30 +71,26 @@ export function LoginCs() {
|
|
|
let { token, nombre, apelidos, id: pass_id } = response;
|
|
|
toast.success(`Bienvenido ${nombre} ${apelidos}!!`)
|
|
|
token = token.replace("Bearer ", "")
|
|
|
- // console.log(token);
|
|
|
-
|
|
|
- // let { exp } = jwt_decode(token);
|
|
|
+ let { exp } = jwt_decode(token);
|
|
|
let body_token = jwt_decode(token);
|
|
|
body_token['pass'] = password;
|
|
|
body_token['passid'] = pass_id;
|
|
|
- console.log("BODY TOKEN: ", body_token)
|
|
|
- dispatch(setToken(token))
|
|
|
- // let timestamp = exp * 1000;
|
|
|
- // let restante = timestamp - Date.now();
|
|
|
|
|
|
- // setTimeout(() => alert("Token Expirado"), restante)
|
|
|
- auth.setProfile({
|
|
|
+ let timestamp = exp * 1000;
|
|
|
+ let exp_in = timestamp - Date.now();
|
|
|
+ let profile = {
|
|
|
email,
|
|
|
password,
|
|
|
passid: pass_id,
|
|
|
pass: password,
|
|
|
assingid: 'ok'
|
|
|
- })
|
|
|
- auth.setRole(body_token)
|
|
|
-
|
|
|
+ }
|
|
|
+ setTimeout(() => alert("Token Expirado"), exp_in)
|
|
|
setTimeout(() => {
|
|
|
setOpen(false)
|
|
|
- auth.login(token)
|
|
|
+ dispatch(setRole(body_token))
|
|
|
+ dispatch(setProfile(profile))
|
|
|
+ dispatch(setToken({ token : token, exp : exp_in }))
|
|
|
}, 2000)
|
|
|
|
|
|
})
|
|
|
@@ -104,12 +103,6 @@ export function LoginCs() {
|
|
|
},
|
|
|
});
|
|
|
|
|
|
- React.useEffect(() => {
|
|
|
- if (auth.isLogged()) {
|
|
|
- return navigate('/user/home')
|
|
|
- }
|
|
|
- }, [auth, navigate])
|
|
|
-
|
|
|
return (
|
|
|
<ThemeProvider theme={theme}>
|
|
|
<Grid container component="main" sx={{ height: '100vh' }}>
|
|
|
@@ -192,6 +185,3 @@ export function LoginCs() {
|
|
|
|
|
|
);
|
|
|
}
|
|
|
-
|
|
|
-
|
|
|
-// export default connect(mapStateToProps, mapDispatchToProps)(LoginCs);
|