Proyectos de Subversion LeadersLinked - Antes de SPA

Rev

Rev 3764 | Rev 4420 | Ir a la última revisión | | Comparar con el anterior | Ultima modificación | Ver Log |

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