Proyectos de Subversion LeadersLinked - Antes de SPA

Rev

Rev 6511 | Ir a la última revisión | | 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 { useForm } from 'react-hook-form'
4
import { useSelector } from 'react-redux'
5
import { addNotification } from '../../../redux/notification/notification.actions'
6
import Recaptcha from 'react-recaptcha'
7
import cryptoJsAesJson from '../../../utils/crypto-js/cryptojs-aes-format'
8
 
9
import Spinner from '../../../components/UI/Spinner'
10
import FormErrorFeedback from '../../../components/UI/FormErrorFeedback'
11
 
12
const Login = ({
13
  facebookOauth = '/signin/facebook',
14
  twitterOauth = '/signin/twitter',
15
  googleOauth = '/signin/google',
16
}) => {
17
  const { site_key, aes, defaultNetwork } = useSelector(({ auth }) => auth)
18
  const [rememberChecked, setRememberChecked] = useState(false)
19
  const [isLoading, setIsLoading] = useState(false)
20
  const [isVerified, setIsVerified] = useState(false)
21
 
22
  const reCaptchaToken = useRef('')
23
  const reCaptchaInstance = useRef()
24
 
25
  const { register, handleSubmit, errors, setError, getValues, setValue } =
26
    useForm({ mode: 'onBlur' })
27
 
28
  useEffect(() => {
29
    reCaptchaInstance.current?.reset()
30
  }, [])
31
 
32
  const onSubmitHandler = async (data, event) => {
33
    const formData = new FormData()
34
    Object.entries(data).map(([key, value]) => {
35
      if (key === 'email' && value)
36
        return formData.append(key, cryptoJsAesJson.encrypt(value, aes))
37
      if (key === 'password' && value)
38
        return formData.append(key, cryptoJsAesJson.encrypt(value, aes))
39
      if (value) formData.append(key, value)
40
    })
41
    formData.append('captcha', reCaptchaToken.current)
42
    await axios
43
      .post('/signin', formData)
44
      .then(({ data: response }) => {
45
        const { success, data } = response
46
        if (!success) {
47
          if (data.constructor.name === 'Object') {
48
            Object.entries(data).map(([key, value]) => {
49
              if (key in getValues()) {
50
                setError(key, {
51
                  type: 'manual',
52
                  message: Array.isArray(value) ? value[0] : value,
53
                })
54
              }
55
            })
56
            return
57
          }
58
          addNotification({ style: 'danger', msg: data })
59
          return
60
        }
61
 
62
        window.location.replace(data)
63
        event.target.reset()
64
      })
65
      .catch((err) => console.log(`Error: ${err}`))
66
      .finally(() => setIsLoading(false))
67
 
68
    reCaptchaInstance.current.reset()
69
    loginExpiredCallbackHandler()
70
    setValue('password', '')
71
  }
72
 
73
  const loginVerifyCallbackHandler = (response) => {
74
    reCaptchaToken.current = response
75
    setIsVerified(true)
76
  }
77
 
78
  const loginExpiredCallbackHandler = () => {
79
    reCaptchaToken.current = ''
80
    setIsVerified(false)
81
  }
82
 
83
  const handleOnRecaptchaLoad = () => {
84
    reCaptchaToken.current = ''
85
  }
86
 
87
  const getRedirectUrl = async (endpoint) => {
88
    try {
89
      const res = await axios.get(endpoint)
90
      if (res.data && res.data.data) {
91
        window.location.href = res.data.data
92
      }
93
    } catch (error) {
94
      console.log('>>: error > ', error)
95
    }
96
  }
97
 
98
  return (
99
    <>
100
      <h3>Entrar</h3>
101
      <form onSubmit={handleSubmit(onSubmitHandler)}>
102
        <div className="inputContainer">
103
          <div className="sn-field">
104
            <input
105
              type="email"
106
              name="email"
107
              ref={register({
108
                required: 'Este campo es requerido',
109
                pattern: {
110
                  value: /^[\w-.]+@([\w-]+\.)+[\w-]{2,4}$/i,
111
                  message:
112
                    'Debe ser una dirección de correo electrónico valida',
113
                },
114
              })}
115
              placeholder="Correo electrónico"
116
              maxLength="64"
117
            />
118
            <i className="la la-envelope" />
119
          </div>
120
          {errors.email && (
121
            <FormErrorFeedback>{errors.email.message}</FormErrorFeedback>
122
          )}
123
        </div>
124
        <div className="inputContainer">
125
          <div className="sn-field">
126
            <input
127
              type="password"
128
              name="password"
129
              ref={register({
130
                required: 'Este campo es requerido',
131
                pattern: {
132
                  value:
133
                    /^(?=.*?[A-Z])(?=.*?[a-z])(?=.*?[0-9])(?=.*?[#?!@$^x%x*-]).{6,16}$/i,
134
                  message:
135
                    'Debe contener entre 6 y 16 caracteres, incluida una letra mayúscula, un número y un carácter especial #?!@$^%*-',
136
                },
137
              })}
138
              placeholder="Clave"
139
            />
140
            <i className="la la-lock"></i>
141
          </div>
142
          {errors.password && (
143
            <FormErrorFeedback>{errors.password.message}</FormErrorFeedback>
144
          )}
145
        </div>
146
        <div className="checky-sec">
147
          <div className="fgt-sec">
148
            <input
149
              type="checkbox"
150
              name="remember"
151
              id="remember"
152
              checked={rememberChecked}
153
              ref={register}
154
              value="1"
155
              readOnly
156
            />
157
            <label onClick={() => setRememberChecked(!rememberChecked)}>
158
              <span></span>
159
            </label>
160
            <small onClick={() => setRememberChecked(!rememberChecked)}>
161
              Recuerdame
162
            </small>
163
          </div>
164
        </div>
165
        <div className="sn-field">
166
          <Recaptcha
167
            sitekey={site_key}
168
            verifyCallback={loginVerifyCallbackHandler}
169
            verifyCallbackName="loginVerifyCallbackHandler"
170
            expiredCallback={loginExpiredCallbackHandler}
171
            expiredCallbackName="loginExpiredCallbackHandler"
172
            ref={reCaptchaInstance}
173
            render="explicit"
174
            onloadCallback={handleOnRecaptchaLoad}
175
            hl="es"
176
          />
177
        </div>
178
        <button
179
          type="submit"
180
          value="submit"
181
          id="btn-submit"
182
          disabled={!isVerified}
183
        >
184
          Entrar
185
        </button>
186
      </form>
187
      {defaultNetwork && (
188
        <div className="login-resources">
189
          <h4>Entrar usando su red social</h4>
190
          <ul>
191
            <li>
192
              <a
193
                onClick={() => getRedirectUrl(facebookOauth)}
194
                className="cursor-pointer fb text-white"
195
                title=""
196
              >
197
                <i className="fa fa-facebook"></i> FACEBOOK
198
              </a>
199
            </li>
200
            <li>
201
              <a
202
                onClick={() => getRedirectUrl(twitterOauth)}
203
                className="cursor-pointer tw btn-connect-social-media text-white"
204
                title=""
205
              >
206
                <i className="fa fa-twitter"></i> TWITTER
207
              </a>
208
            </li>
209
            <li className="bg-secondary">
210
              <a
211
                onClick={() => getRedirectUrl(googleOauth)}
212
                className="cursor-pointer go btn-connect-social-media text-white"
213
                title=""
214
              >
215
                <i className="fa fa-google"></i> GOOGLE
216
              </a>
217
            </li>
218
          </ul>
219
        </div>
220
      )}
221
      {isLoading && <Spinner />}
222
    </>
223
  )
224
}
225
 
226
export default Login