Proyectos de Subversion LeadersLinked - Antes de SPA

Rev

Rev 3072 | Rev 3680 | 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 { Link } from "react-router-dom";
import CryptoJSAesJson from "../../../../utils/crypto-js/cryptojs-aes-format";

const StyledCheck = styled.div`
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  img {
    width: 100px;
    margin-bottom: 1rem;
  }
  p {
    text-align: center;
  }
`;
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 Signup = (props) => {
  // props destructuging
  const { captchaKey, addNotification, aes } = props;

  // React Hook Form
  const { register, handleSubmit, setError, errors } = useForm();

  // states
  const [termsChecked, setTermsChecked] = useState(false);
  const [registered, setRegistered] = useState(false);
  const [isLoading, setIsLoading] = useState(false);

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

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

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

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

  const onSubmitHandler = async (data) => {
    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 (key === "confirmation" && value)
        return formData.append(key, CryptoJSAesJson.encrypt(value, aes));
      formData.append(key, value);
    });
    formData.append("captcha", reCaptchaToken.current);
    await axios.post("/signup", formData).then((response) => {
      const resData = response.data;
      if (resData.success) {
        // window.location.replace(resData.data);
        reCaptchaInstance.current.reset();
        signupExpiredCallbackHandler();
        setRegistered(true);
      } else {
        const resError = resData.data;
        if (resError.constructor.name === "Object") {
          Object.entries(resError).map(([key, value]) => {
            // if (key in getValues()) {
            setError(key, {
              type: "manual",
              message: Array.isArray(value) ? value[0] : value,
            });
            // }
          });
        } else {
          addNotification({
            style: "danger",
            msg: resError,
          });
        }
        reCaptchaInstance.current.reset();
        signupVerifyCallbackHandler();
      }
    })
      .catch(err => {
        ('>>: err > ', err)
        addNotification({
          style: "error",
          msg: 'Disculpe, ha ocurrido un error',
        });
      })
      .finally(() => {
        setIsLoading(false);
      });
  };

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

  if (registered) {
    return (
      <StyledCheck>
        <img src="/images/check.png" alt="check" />
        <p>
          Se ha registrado correctamente. Por favor, active la cuenta desde su
          correo
        </p>
        <Link to="/signin">
          <button id="btn-submit" className="sign_in_sec_button">
            Entrar
          </button>
        </Link>
      </StyledCheck>
    );
  }
  return (
    <React.Fragment>
      <h3>Registrarse</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",
                  })}
                  maxLength="64"
                  placeholder="Correo electrónico"
                />
                <i className="la la-envelope"></i>
              </div>
              {errors.email && (
                <FormErrorFeedback>{errors.email.message}</FormErrorFeedback>
              )}
            </div>

            {/* <!--sn-field end--> */}
          </div>

          <div className="col-lg-12 no-pdd">
            <div className="inputContainer">
              <div className="sn-field">
                <input
                  type="text"
                  name="first_name"
                  ref={register({
                    required: "Este campo es requerido",
                  })}
                  placeholder="Nombre"
                  maxLength="64"
                />
                <i className="la la-user"></i>
              </div>
              {errors.first_name && (
                <FormErrorFeedback>
                  {errors.first_name.message}
                </FormErrorFeedback>
              )}
            </div>
          </div>
          <div className="col-lg-12 no-pdd">
            <div className="inputContainer">
              <div className="sn-field">
                <input
                  type="text"
                  name="last_name"
                  maxLength="64"
                  ref={register({
                    required: "Este campo es requerido",
                  })}
                  placeholder="Apellido"
                />
                <i className="la la-user"></i>
              </div>
              {errors.last_name && (
                <FormErrorFeedback>
                  {errors.last_name.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="^(?=.*?[A-Z])(?=.*?[a-z])(?=.*?[0-9])(?=.*?[#?!@$^x%x*-]).{6,16}$"
                  title="La clave debe contener entre 6 y 16 caracteres, incluida una letra mayúscula, un número y un carácter especial #?!@$^%*-"
                  placeholder="Clave"
                  minLength="6"
                  maxLength="16"
                />
                <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="sn-field">
                <input
                  type="password"
                  name="confirmation"
                  ref={register({
                    required: "Este campo es requerido",
                  })}
                  pattern="^(?=.*?[A-Z])(?=.*?[a-z])(?=.*?[0-9])(?=.*?[#?!@$^x%x*-]).{6,16}$"
                  title="La clave debe contener entre 6 y 16 caracteres, incluida una letra mayúscula, un número y un carácter especial #?!@$^%*-"
                  placeholder="Confirme su clave"
                  minLength="6"
                  maxLength="16"
                />
                <i className="la la-lock"></i>
              </div>
              {errors.confirmation && (
                <FormErrorFeedback>
                  {errors.confirmation.message}
                </FormErrorFeedback>
              )}
            </div>
          </div>

          <div className="col-lg-12 no-pdd">
            <div className="inputContainer">
              <div className="checky-sec st2">
                <div className="sn-field fgt-sec">
                  <input
                    type="checkbox"
                    name="terms_and_conditions"
                    id="terms_and_conditions"
                    checked={termsChecked}
                    ref={register({
                      required: "Este campo es requerido",
                    })}
                    value="1"
                    readOnly
                  />
                  <label htmlFor="terms_and_conditions" onClick={() => setTermsChecked(!termsChecked)}>
                    <span></span>
                  </label>
                  <small onClick={() => setTermsChecked(!termsChecked)}>
                  Si, acepto los <a href="/terms-and-conditions">Términos y Condiciones.</a>
                  </small>
                </div>
                {/* <!--fgt-sec end--> */}
              </div>
              {errors.terms_and_conditions && (
                <FormErrorFeedback>
                  {errors.terms_and_conditions.message}
                </FormErrorFeedback>
              )}
            </div>
          </div>

          <div className="col-lg-12 no-pdd">
            <div className="sn-field">
              <Recaptcha
                sitekey={captchaKey}
                verifyCallback={signupVerifyCallbackHandler}
                verifyCallbackName="signupVerifyCallbackHandler"
                expiredCallback={signupExpiredCallbackHandler}
                expiredCallbackName="signupExpiredCallbackHandler"
                ref={reCaptchaInstance}
                render="explicit"
                onloadCallback={handleOnRecaptchaLoad}
                hl="es"
              />
            </div>
          </div>

          <div className="col-lg-12 no-pdd">
            <button
              type="submit"
              value="submit"
              id="btn-submit"
              disabled={!isVerified}
            >
              Registrarse
            </button>
          </div>
        </div>
        {/* <?php echo $this->form()->closeTag($form); ?> */}
      </form>
      {isLoading ? (
        <StyledSpinnerContainer>
          <Spinner />
        </StyledSpinnerContainer>
      ) : (
        ""
      )}
    </React.Fragment>
  );
};

export default Signup;