|
@@ -1,10 +1,11 @@
|
1
|
1
|
import * as React from 'react';
|
2
|
2
|
import toast, { Toaster } from 'react-hot-toast';
|
3
|
|
-import { useNavigate } from 'react-router-dom'
|
|
3
|
+import { Navigate, useNavigate } from 'react-router-dom'
|
4
|
4
|
import jwt_decode from "jwt-decode";
|
5
|
|
-import { useDispatch } from "react-redux";
|
|
5
|
+import { useDispatch , useSelector } from "react-redux";
|
6
|
6
|
|
7
|
7
|
import { setToken } from '../Slices/tokenSlice'
|
|
8
|
+import { setProfile, setRole } from '../Slices/userSlice.js'
|
8
|
9
|
|
9
|
10
|
import {
|
10
|
11
|
Paper, Box, Grid, Typography, TextField, Button, Avatar,
|
|
@@ -15,7 +16,6 @@ import { createTheme, ThemeProvider } from '@mui/material/styles';
|
15
|
16
|
|
16
|
17
|
import PersonIcon from '@mui/icons-material/Person';
|
17
|
18
|
import { Copyright } from '../Components/Footer.js'
|
18
|
|
-import useAuth from '../Auth/useAuth';
|
19
|
19
|
|
20
|
20
|
import { useFormik } from 'formik';
|
21
|
21
|
import * as Yup from 'yup';
|
|
@@ -37,12 +37,18 @@ const theme = createTheme();
|
37
|
37
|
|
38
|
38
|
export function LoginCs() {
|
39
|
39
|
|
40
|
|
- let auth = useAuth();
|
41
|
|
- let navigate = useNavigate()
|
42
|
|
-
|
43
|
40
|
const [open, setOpen] = React.useState(false);
|
44
|
41
|
const dispatch = useDispatch();
|
45
|
42
|
const handleClose = () => false
|
|
43
|
+ const navigate = useNavigate();
|
|
44
|
+ let token = useSelector((state) => state.token.token)
|
|
45
|
+
|
|
46
|
+ React.useEffect(() => {
|
|
47
|
+ if(token){
|
|
48
|
+ navigate('/user/home')
|
|
49
|
+ }
|
|
50
|
+ }, [token, navigate])
|
|
51
|
+
|
46
|
52
|
|
47
|
53
|
const formik = useFormik({
|
48
|
54
|
initialValues: {
|
|
@@ -52,14 +58,11 @@ export function LoginCs() {
|
52
|
58
|
validationSchema: LoginSchema,
|
53
|
59
|
onSubmit: async (values) => {
|
54
|
60
|
|
55
|
|
- //
|
56
|
|
- // QW5hbGlzdGEgZGUgY29tcHJhcw==
|
57
|
|
- //
|
58
|
|
-
|
59
|
61
|
let { email, password } = values
|
60
|
62
|
setOpen(true)
|
61
|
63
|
|
62
|
|
- let request = new Service(`/user?user=${email}&password=${password}&typeusr=iscandidato`)
|
|
64
|
+ let url = `/user?user=${email}&password=${password}&typeusr=iscandidato`
|
|
65
|
+ let request = new Service(url);
|
63
|
66
|
request
|
64
|
67
|
.post({})
|
65
|
68
|
.then(response => {
|
|
@@ -68,30 +71,26 @@ export function LoginCs() {
|
68
|
71
|
let { token, nombre, apelidos, id: pass_id } = response;
|
69
|
72
|
toast.success(`Bienvenido ${nombre} ${apelidos}!!`)
|
70
|
73
|
token = token.replace("Bearer ", "")
|
71
|
|
- // console.log(token);
|
72
|
|
-
|
73
|
|
- // let { exp } = jwt_decode(token);
|
|
74
|
+ let { exp } = jwt_decode(token);
|
74
|
75
|
let body_token = jwt_decode(token);
|
75
|
76
|
body_token['pass'] = password;
|
76
|
77
|
body_token['passid'] = pass_id;
|
77
|
|
- console.log("BODY TOKEN: ", body_token)
|
78
|
|
- dispatch(setToken(token))
|
79
|
|
- // let timestamp = exp * 1000;
|
80
|
|
- // let restante = timestamp - Date.now();
|
81
|
78
|
|
82
|
|
- // setTimeout(() => alert("Token Expirado"), restante)
|
83
|
|
- auth.setProfile({
|
|
79
|
+ let timestamp = exp * 1000;
|
|
80
|
+ let exp_in = timestamp - Date.now();
|
|
81
|
+ let profile = {
|
84
|
82
|
email,
|
85
|
83
|
password,
|
86
|
84
|
passid: pass_id,
|
87
|
85
|
pass: password,
|
88
|
86
|
assingid: 'ok'
|
89
|
|
- })
|
90
|
|
- auth.setRole(body_token)
|
91
|
|
-
|
|
87
|
+ }
|
|
88
|
+ setTimeout(() => alert("Token Expirado"), exp_in)
|
92
|
89
|
setTimeout(() => {
|
93
|
90
|
setOpen(false)
|
94
|
|
- auth.login(token)
|
|
91
|
+ dispatch(setRole(body_token))
|
|
92
|
+ dispatch(setProfile(profile))
|
|
93
|
+ dispatch(setToken({ token : token, exp : exp_in }))
|
95
|
94
|
}, 2000)
|
96
|
95
|
|
97
|
96
|
})
|
|
@@ -104,12 +103,6 @@ export function LoginCs() {
|
104
|
103
|
},
|
105
|
104
|
});
|
106
|
105
|
|
107
|
|
- React.useEffect(() => {
|
108
|
|
- if (auth.isLogged()) {
|
109
|
|
- return navigate('/user/home')
|
110
|
|
- }
|
111
|
|
- }, [auth, navigate])
|
112
|
|
-
|
113
|
106
|
return (
|
114
|
107
|
<ThemeProvider theme={theme}>
|
115
|
108
|
<Grid container component="main" sx={{ height: '100vh' }}>
|
|
@@ -192,6 +185,3 @@ export function LoginCs() {
|
192
|
185
|
|
193
|
186
|
);
|
194
|
187
|
}
|
195
|
|
-
|
196
|
|
-
|
197
|
|
-// export default connect(mapStateToProps, mapDispatchToProps)(LoginCs);
|