Proyectos de Subversion LeadersLinked - Antes de SPA

Rev

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