Proyectos de Subversion LeadersLinked - Antes de SPA

Rev

Rev 6510 | | Comparar con el anterior | Ultima modificación | Ver Log |

Rev Autor Línea Nro. Línea
6509 stevensc 1
import React, { useRef, useState, useEffect } from 'react'
2
import { axios } from '../../../utils'
3
import { Link } from 'react-router-dom'
4
import { useForm } from 'react-hook-form'
6511 stevensc 5
import { useDispatch, useSelector } from 'react-redux'
6509 stevensc 6
import { addNotification } from '../../../redux/notification/notification.actions'
7
import styled from 'styled-components'
8
import Recaptcha from 'react-recaptcha'
9
import CryptoJSAesJson from '../../../utils/crypto-js/cryptojs-aes-format'
10
 
11
import Spinner from '../../UI/Spinner'
12
import FormErrorFeedback from '../../UI/FormErrorFeedback'
13
 
14
const StyledCheck = styled.div`
15
  display: flex;
16
  flex-direction: column;
17
  justify-content: center;
18
  align-items: center;
19
  img {
20
    width: 100px;
21
    margin-bottom: 1rem;
22
  }
23
  p {
24
    text-align: center;
25
  }
26
`
27
const StyledSpinnerContainer = styled.div`
28
  position: absolute;
29
  left: 0;
30
  top: 0;
31
  width: 100%;
32
  height: 100%;
33
  background: rgba(255, 255, 255, 0.4);
34
  display: flex;
35
  justify-content: center;
36
  align-items: center;
37
  z-index: 300;
38
`
39
const ForgotPassword = () => {
40
  const { site_key, aes } = useSelector(({ auth }) => auth)
41
  const [forgotSent, setForgotSent] = useState(false)
42
  const [isLoading, setIsLoading] = useState(false)
43
  const [isVerified, setIsVerified] = useState(false)
44
 
45
  const reCaptchaToken = useRef('')
6511 stevensc 46
  const reCaptchaInstance = useRef(null)
6509 stevensc 47
 
6511 stevensc 48
  const dispatch = useDispatch()
49
 
6509 stevensc 50
  const { register, handleSubmit, setError, errors } = useForm({ mode: 'all' })
51
 
52
  const forgotPasswordVerifyCallbackHandler = (response) => {
53
    if (response) {
54
      reCaptchaToken.current = response
55
      setIsVerified(true)
56
    }
57
  }
58
 
59
  const forgotPasswordExpiredCallbackHandler = () => {
60
    reCaptchaToken.current = ''
61
    setIsVerified(false)
62
  }
63
 
64
  const onSubmitHandler = async (data) => {
65
    setIsLoading(true)
66
 
67
    const formData = new FormData()
68
    Object.entries(data).map(([key, value]) => {
69
      if (key === 'email' && value) {
70
        formData.append(key, CryptoJSAesJson.encrypt(value, aes))
71
        return
72
      }
73
 
74
      formData.append(key, value)
75
    })
76
    formData.append('captcha', reCaptchaToken.current)
77
 
78
    await axios
79
      .post('/forgot-password', formData)
80
      .then(({ data: response }) => {
81
        const { success, data } = response
82
        if (!success) {
83
          const resError = data
84
 
85
          if (typeof resError === 'object') {
86
            Object.entries(resError).map(([key, value]) => {
87
              setError(key, {
88
                message: Array.isArray(value) ? value[0] : value,
89
              })
90
            })
91
            return
92
          }
93
 
6511 stevensc 94
          dispatch(addNotification({ style: 'danger', msg: resError }))
6509 stevensc 95
        }
6511 stevensc 96
 
6509 stevensc 97
        reCaptchaInstance.current.reset()
98
        forgotPasswordExpiredCallbackHandler()
99
        setForgotSent(true)
100
        reCaptchaInstance.current.reset()
101
        loginExpiredCallbackHandler()
102
      })
6511 stevensc 103
      .catch((err) => {
104
        dispatch(
105
          addNotification({
106
            style: 'danger',
107
            msg: 'Disculpe, ha ocurrido un error',
108
          })
109
        )
110
        console.log(`Error: ${err}`)
111
        throw new Error(err)
112
      })
6509 stevensc 113
      .finally(() => setIsLoading(false))
114
  }
115
 
116
  const handleOnRecaptchaLoad = () => {
117
    reCaptchaToken.current = ''
118
  }
119
 
120
  const loginExpiredCallbackHandler = () => {
121
    reCaptchaToken.current = ''
122
    setIsVerified(false)
123
  }
124
 
125
  useEffect(() => {
126
    reCaptchaInstance.current?.reset()
127
  }, [])
128
 
129
  if (forgotSent) {
130
    return (
131
      <StyledCheck>
132
        <img src="/images/check.png" alt="check" />
133
        <p>El enlace de recuperación fue enviado a su correo electrónico</p>
134
        <Link to="/signin">
135
          <button id="btn-submit" className="sign_in_sec_button">
136
            Entrar
137
          </button>
138
        </Link>
139
      </StyledCheck>
140
    )
141
  }
142
 
143
  return (
6510 stevensc 144
    <>
6509 stevensc 145
      <h3>Olvide mi Clave</h3>
146
      <form onSubmit={handleSubmit(onSubmitHandler)}>
6510 stevensc 147
        <div className="inputContainer">
148
          <div className="sn-field">
149
            <input
150
              type="email"
151
              name="email"
152
              placeholder="Correo electrónico"
153
              ref={register({
154
                required: 'Este campo es requerido',
155
                pattern: {
156
                  value: /^[\w-.]+@([\w-]+\.)+[\w-]{2,4}$/i,
157
                  message:
158
                    'Debe ser una dirección de correo electrónico valida',
159
                },
160
              })}
161
            />
162
            <i className="la la-envelope" />
6509 stevensc 163
          </div>
6510 stevensc 164
          {errors.email && (
165
            <FormErrorFeedback>{errors.email.message}</FormErrorFeedback>
166
          )}
167
        </div>
168
        <div className="inputContainer">
169
          <div className="sn-field">
170
            <Recaptcha
171
              sitekey={site_key}
172
              verifyCallback={forgotPasswordVerifyCallbackHandler}
173
              verifyCallbackName="forgotPasswordVerifyCallbackHandler"
174
              expiredCallback={forgotPasswordExpiredCallbackHandler}
175
              expiredCallbackName="forgotPasswordExpiredCallbackHandler"
176
              ref={reCaptchaInstance}
177
              render="explicit"
178
              onloadCallback={handleOnRecaptchaLoad}
179
              hl="es"
180
            />
6509 stevensc 181
          </div>
182
        </div>
6510 stevensc 183
        <button type="submit" value="submit" disabled={!isVerified}>
184
          Nueva Clave
185
        </button>
6509 stevensc 186
      </form>
187
      {isLoading && (
188
        <StyledSpinnerContainer>
189
          <Spinner />
190
        </StyledSpinnerContainer>
191
      )}
6510 stevensc 192
    </>
6509 stevensc 193
  )
194
}
195
 
196
export default ForgotPassword