Proyectos de Subversion LeadersLinked - Antes de SPA

Rev

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

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