Proyectos de Subversion LeadersLinked - Antes de SPA

Rev

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

/* eslint-disable react/prop-types */
import React from "react";
import { useRef, useState, useEffect } from "react";
import { useForm } from "react-hook-form";
import styled from "styled-components";
import { axios } from "../../../../utils";
import FormErrorFeedback from "../../../../shared/form-error-feedback/FormErrorFeedback";
import Recaptcha from "react-recaptcha";
import Spinner from "../../../../shared/loading-spinner/Spinner";
import cryptoJsAesJson from "../../../../utils/crypto-js/cryptojs-aes-format";

const StyledSpinnerContainer = styled.div`
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  background: rgba(255, 255, 255, 0.4);
  display: flex;
  justify-content: center;
  align-items: center;
  z-index: 300;
`;

const Login = ({
  captchaKey,
  addNotification,
  facebookOauth,
  twitterOauth,
  googleOauth,
  aes,
  defaultNetwork
}) => {

  const {
    register,
    handleSubmit,
    errors,
    setError,
    getValues,
    setValue,
  } = useForm({ mode: 'onBlur' });

  // Recaptcha
  const reCaptchaToken = useRef("");
  const [isVerified, setIsVerified] = useState(false);
  const reCaptchaInstance = useRef();

  // states
  const [rememberChecked, setRememberChecked] = useState(false);
  const [isLoading, setIsLoading] = useState(false);

  useEffect(() => {
    reCaptchaInstance.current.reset();
  }, []);

  const onSubmitHandler = async (data, event) => {
    // setIsLoading(true);
    const formData = new FormData();
    Object.entries(data).map(([key, value]) => {
      if (key === "email" && value)
        return formData.append(key, cryptoJsAesJson.encrypt(value, aes));
      if (key === "password" && value)
        return formData.append(key, cryptoJsAesJson.encrypt(value, aes));
      if (value) formData.append(key, value);
    });
    formData.append("captcha", reCaptchaToken.current);
    await axios
      .post("/signin", formData)
      .then(({ data: response }) => {
        const { success, data } = response
        if (!success) {
          if (data.constructor.name === "Object") {
            Object.entries(data).map(([key, value]) => {
              if (key in getValues()) {
                setError(key, {
                  type: "manual",
                  message: Array.isArray(value) ? value[0] : value,
                });
              }
            });
            return
          }
          addNotification({
            style: "danger",
            msg: data,
          });
          return
        }
        window.location.replace(data);
        event.target.reset();
      })
      .catch((err) => console.log(`Error: ${err}`))
      .finally(() => setIsLoading(false))
    reCaptchaInstance.current.reset();
    loginExpiredCallbackHandler();
    // setIsLoading(false);
    setValue("password", "");
  };

  const loginVerifyCallbackHandler = (response) => {
    reCaptchaToken.current = response;
    setIsVerified(true);
  };

  const loginExpiredCallbackHandler = () => {
    reCaptchaToken.current = "";
    setIsVerified(false);
  };

  const handleOnRecaptchaLoad = () => {
    reCaptchaToken.current = "";
  };

  const getRedirectUrl = async (endpoint) => {
    try {
      const res = await axios.get(endpoint)
      if (res.data && res.data.data) {
        window.location.href = res.data.data
      }
    } catch (error) {
      ('>>: error > ', error)
    }
  }
  return (
    <React.Fragment>
      <h3>Entrar</h3>
      <form onSubmit={handleSubmit(onSubmitHandler)}>
        <div className="row">
          <div className="col-lg-12 no-pdd">
            <div className="inputContainer">
              <div className="sn-field">
                <input
                  type="email"
                  name="email"
                  ref={register({
                    required: "Este campo es requerido",
                    pattern: {
                      value: /^[\w-.]+@([\w-]+\.)+[\w-]{2,4}$/i,
                      message: "Debe ser una dirección de correo electrónico valida"
                    }
                  })}
                  placeholder="Correo electrónico"
                  maxLength="64"
                />
                <i className="la la-envelope" />
              </div>
              {errors.email &&
                <FormErrorFeedback>{errors.email.message}</FormErrorFeedback>
              }
            </div>
          </div>
          <div className="col-lg-12 no-pdd">
            <div className="inputContainer">
              <div className="sn-field">
                <input
                  type="password"
                  name="password"
                  ref={register({
                    required: "Este campo es requerido",
                    pattern: {
                      value: /^(?=.*?[A-Z])(?=.*?[a-z])(?=.*?[0-9])(?=.*?[#?!@$^x%x*-]).{6,16}$/i,
                      message: 'Debe contener entre 6 y 16 caracteres, incluida una letra mayúscula, un número y un carácter especial #?!@$^%*-'
                    }
                  })}
                  placeholder="Clave"
                />
                <i className="la la-lock"></i>
              </div>
              {errors.password && (
                <FormErrorFeedback>{errors.password.message}</FormErrorFeedback>
              )}
            </div>
          </div>

          <div className="col-lg-12 no-pdd">
            <div className="inputContainer">
              <div className="checky-sec">
                <div className="fgt-sec">
                  <input
                    type="checkbox"
                    name="remember"
                    id="remember"
                    checked={rememberChecked}
                    ref={register}
                    value="1"
                    readOnly
                  />
                  <label onClick={() => setRememberChecked(!rememberChecked)}>
                    <span></span>
                  </label>
                  <small onClick={() => setRememberChecked(!rememberChecked)}>
                    Recuerdame
                  </small>
                </div>
              </div>
            </div>
          </div>

          <div className="col-lg-12 no-pdd">
            <div className="sn-field">
              <Recaptcha
                sitekey={captchaKey}
                verifyCallback={loginVerifyCallbackHandler}
                verifyCallbackName="loginVerifyCallbackHandler"
                expiredCallback={loginExpiredCallbackHandler}
                expiredCallbackName="loginExpiredCallbackHandler"
                ref={reCaptchaInstance}
                render="explicit"
                onloadCallback={handleOnRecaptchaLoad}
                hl="es"
              />
            </div>
          </div>
          <div className="col-lg-12 no-pdd"></div>
          <div className="col-lg-12 no-pdd">
            <button
              type="submit"
              value="submit"
              id="btn-submit"
              disabled={!isVerified}
            >
              Entrar
            </button>
          </div>
        </div>
      </form>
      {Boolean(defaultNetwork === 'y') &&
        <div className="login-resources">
          <h4>Entrar usando su red social</h4>
          <ul>
            <li>
              <a onClick={() => getRedirectUrl(facebookOauth)}
                title=""
                className="cursor-pointer fb text-white">
                <i className="fa fa-facebook"></i> FACEBOOK
              </a>
            </li>
            <li>
              <a
                onClick={() => getRedirectUrl(twitterOauth)}
                title=""
                className="cursor-pointer tw btn-connect-social-media text-white"
              >
                <i className="fa fa-twitter"></i> TWITTER
              </a>
            </li>
            <li
              className="bg-secondary"
            >
              <a
                onClick={() => getRedirectUrl(googleOauth)}
                title=""
                className="cursor-pointer go btn-connect-social-media text-white"
              >
                <i className="fa fa-google"></i> GOOGLE
              </a>
            </li>
          </ul>
        </div>
      }
      {isLoading ? (
        <StyledSpinnerContainer>
          <Spinner />
        </StyledSpinnerContainer>
      ) : (
        ""
      )}
    </React.Fragment>
  );
};

export default Login;