Proyectos de Subversion LeadersLinked - Antes de SPA

Rev

Rev 4420 | Rev 5697 | 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,
4420 stevensc 32
  defaultNetwork
3681 stevensc 33
}) => {
1 www 34
 
35
  const {
36
    register,
37
    handleSubmit,
38
    errors,
39
    setError,
40
    getValues,
41
    setValue,
3670 stevensc 42
  } = useForm({ mode: 'onBlur' });
1 www 43
 
44
  // Recaptcha
45
  const reCaptchaToken = useRef("");
46
  const [isVerified, setIsVerified] = useState(false);
47
  const reCaptchaInstance = useRef();
48
 
49
  // states
50
  const [rememberChecked, setRememberChecked] = useState(false);
51
  const [isLoading, setIsLoading] = useState(false);
52
 
53
  useEffect(() => {
54
    reCaptchaInstance.current.reset();
55
  }, []);
56
 
57
  const onSubmitHandler = async (data, event) => {
58
    // setIsLoading(true);
59
    const formData = new FormData();
60
    Object.entries(data).map(([key, value]) => {
61
      if (key === "email" && value)
658 steven 62
        return formData.append(key, cryptoJsAesJson.encrypt(value, aes));
1 www 63
      if (key === "password" && value)
658 steven 64
        return formData.append(key, cryptoJsAesJson.encrypt(value, aes));
1 www 65
      if (value) formData.append(key, value);
66
    });
67
    formData.append("captcha", reCaptchaToken.current);
68
    await axios
69
      .post("/signin", formData)
3764 stevensc 70
      .then(({ data: response }) => {
71
        const { success, data } = response
3765 stevensc 72
        if (!success) {
3764 stevensc 73
          if (data.constructor.name === "Object") {
74
            Object.entries(data).map(([key, value]) => {
1 www 75
              if (key in getValues()) {
76
                setError(key, {
77
                  type: "manual",
78
                  message: Array.isArray(value) ? value[0] : value,
79
                });
80
              }
81
            });
3764 stevensc 82
            return
1 www 83
          }
3764 stevensc 84
          addNotification({
85
            style: "danger",
86
            msg: data,
87
          });
88
          return
1 www 89
        }
3764 stevensc 90
        window.location.replace(data);
91
        event.target.reset();
1 www 92
      })
3681 stevensc 93
      .catch((err) => console.log(`Error: ${err}`))
94
      .finally(() => setIsLoading(false))
1 www 95
    reCaptchaInstance.current.reset();
96
    loginExpiredCallbackHandler();
97
    // setIsLoading(false);
98
    setValue("password", "");
99
  };
100
 
101
  const loginVerifyCallbackHandler = (response) => {
102
    reCaptchaToken.current = response;
103
    setIsVerified(true);
104
  };
105
 
106
  const loginExpiredCallbackHandler = () => {
107
    reCaptchaToken.current = "";
108
    setIsVerified(false);
109
  };
3764 stevensc 110
 
1 www 111
  const handleOnRecaptchaLoad = () => {
112
    reCaptchaToken.current = "";
113
  };
114
 
115
  const getRedirectUrl = async (endpoint) => {
116
    try {
117
      const res = await axios.get(endpoint)
2719 stevensc 118
      if (res.data && res.data.data) {
1 www 119
        window.location.href = res.data.data
120
      }
121
    } catch (error) {
2719 stevensc 122
      ('>>: error > ', error)
1 www 123
    }
124
  }
125
  return (
126
    <React.Fragment>
127
      <h3>Entrar</h3>
128
      <form onSubmit={handleSubmit(onSubmitHandler)}>
129
        <div className="row">
130
          <div className="col-lg-12 no-pdd">
131
            <div className="inputContainer">
132
              <div className="sn-field">
133
                <input
134
                  type="email"
135
                  name="email"
136
                  ref={register({
3677 stevensc 137
                    required: "Este campo es requerido",
3676 stevensc 138
                    pattern: {
139
                      value: /^[\w-.]+@([\w-]+\.)+[\w-]{2,4}$/i,
3677 stevensc 140
                      message: "Debe ser una dirección de correo electrónico valida"
3676 stevensc 141
                    }
1 www 142
                  })}
143
                  placeholder="Correo electrónico"
144
                  maxLength="64"
145
                />
3672 stevensc 146
                <i className="la la-envelope" />
1 www 147
              </div>
3672 stevensc 148
              {errors.email &&
1 www 149
                <FormErrorFeedback>{errors.email.message}</FormErrorFeedback>
3672 stevensc 150
              }
1 www 151
            </div>
152
          </div>
153
          <div className="col-lg-12 no-pdd">
154
            <div className="inputContainer">
155
              <div className="sn-field">
156
                <input
157
                  type="password"
158
                  name="password"
159
                  ref={register({
3677 stevensc 160
                    required: "Este campo es requerido",
161
                    pattern: {
3679 stevensc 162
                      value: /^(?=.*?[A-Z])(?=.*?[a-z])(?=.*?[0-9])(?=.*?[#?!@$^x%x*-]).{6,16}$/i,
3677 stevensc 163
                      message: 'Debe contener entre 6 y 16 caracteres, incluida una letra mayúscula, un número y un carácter especial #?!@$^%*-'
164
                    }
1 www 165
                  })}
166
                  placeholder="Clave"
167
                />
168
                <i className="la la-lock"></i>
169
              </div>
170
              {errors.password && (
171
                <FormErrorFeedback>{errors.password.message}</FormErrorFeedback>
172
              )}
173
            </div>
174
          </div>
175
 
176
          <div className="col-lg-12 no-pdd">
177
            <div className="inputContainer">
178
              <div className="checky-sec">
179
                <div className="fgt-sec">
180
                  <input
181
                    type="checkbox"
182
                    name="remember"
183
                    id="remember"
184
                    checked={rememberChecked}
185
                    ref={register}
186
                    value="1"
187
                    readOnly
188
                  />
3670 stevensc 189
                  <label onClick={() => setRememberChecked(!rememberChecked)}>
1 www 190
                    <span></span>
191
                  </label>
192
                  <small onClick={() => setRememberChecked(!rememberChecked)}>
193
                    Recuerdame
194
                  </small>
195
                </div>
196
              </div>
197
            </div>
198
          </div>
199
 
200
          <div className="col-lg-12 no-pdd">
2719 stevensc 201
            <div className="sn-field">
1 www 202
              <Recaptcha
203
                sitekey={captchaKey}
204
                verifyCallback={loginVerifyCallbackHandler}
205
                verifyCallbackName="loginVerifyCallbackHandler"
206
                expiredCallback={loginExpiredCallbackHandler}
207
                expiredCallbackName="loginExpiredCallbackHandler"
208
                ref={reCaptchaInstance}
209
                render="explicit"
210
                onloadCallback={handleOnRecaptchaLoad}
211
                hl="es"
212
              />
213
            </div>
214
          </div>
215
          <div className="col-lg-12 no-pdd"></div>
216
          <div className="col-lg-12 no-pdd">
217
            <button
218
              type="submit"
219
              value="submit"
220
              id="btn-submit"
221
              disabled={!isVerified}
222
            >
223
              Entrar
224
            </button>
225
          </div>
226
        </div>
227
      </form>
4421 stevensc 228
      {Boolean(defaultNetwork === 'y') &&
4420 stevensc 229
        <div className="login-resources">
230
          <h4>Entrar usando su red social</h4>
231
          <ul>
232
            <li>
233
              <a onClick={() => getRedirectUrl(facebookOauth)}
234
                title=""
235
                className="cursor-pointer fb text-white">
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"
1 www 244
              >
4420 stevensc 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>
1 www 261
      }
262
      {isLoading ? (
263
        <StyledSpinnerContainer>
264
          <Spinner />
265
        </StyledSpinnerContainer>
266
      ) : (
267
        ""
268
      )}
269
    </React.Fragment>
270
  );
271
};
272
 
273
export default Login;