Proyectos de Subversion LeadersLinked - Antes de SPA

Rev

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