226 lines
7.4 KiB
React
226 lines
7.4 KiB
React
import React, { useEffect, useState } from "react";
|
|
import { toast } from "react-toastify";
|
|
import usersService from "../../services/UsersService";
|
|
import InputCom from "../Helpers/Inputs/InputCom";
|
|
import LoadingSpinner from "../Spinners/LoadingSpinner";
|
|
|
|
import { Form, Formik } from "formik";
|
|
import * as Yup from "yup";
|
|
import ReferralTable from "../MyWallet/WalletComponent/ReferralTable";
|
|
|
|
const validationSchema = Yup.object().shape({
|
|
ref_email: Yup.string()
|
|
.email("Wrong email format")
|
|
.min(3, "Minimum 3 characters")
|
|
.max(50, "Maximum 50 characters")
|
|
.required("Email is required"),
|
|
ref_firstname: Yup.string()
|
|
.min(3, "Minimum 3 characters")
|
|
.max(25, "Maximum 25 characters")
|
|
.required("Firstname is required"),
|
|
ref_lastname: Yup.string()
|
|
.min(3, "Minimum 3 characters")
|
|
.max(25, "Maximum 25 characters")
|
|
.required("Lastname is required"),
|
|
});
|
|
|
|
const initialValues = {
|
|
ref_firstname: "",
|
|
ref_lastname: "",
|
|
ref_email: "",
|
|
};
|
|
|
|
function ReferralDisplay() {
|
|
const apiCall = new usersService(); // GET API CALL
|
|
|
|
let [refHistoryReload, setRefHistoryReload] = useState(false); // Determines when referral history reloads
|
|
|
|
// STATE TO HOLD REFERRAL HISTORY
|
|
let [referralList, setReferralList] = useState({
|
|
loading: true,
|
|
error: false,
|
|
data: [],
|
|
});
|
|
|
|
let [error, setError] = useState({
|
|
message: "",
|
|
loading: false,
|
|
status: false,
|
|
}); // for displaying error message on the page
|
|
|
|
//function to call referral history API
|
|
const allReferrals = () => {
|
|
setReferralList({
|
|
loading: true,
|
|
error: false,
|
|
data: [],
|
|
});
|
|
apiCall
|
|
.getReferralHx()
|
|
.then((res) => {
|
|
setReferralList((prev) => {
|
|
return { ...prev, loading: false, data: [...res.data.result_list] };
|
|
});
|
|
})
|
|
.catch((error) => {
|
|
setReferralList((prev) => ({ ...prev, loading: false, error: true }));
|
|
});
|
|
};
|
|
|
|
//FUNCTION TO SEND REFERRAL MESSAGE
|
|
const sendReferralMsg = (postData) => {
|
|
apiCall
|
|
.sendReferralMsg(postData)
|
|
.then((res) => {
|
|
if (res.data.internal_return < 0) {
|
|
setError({
|
|
message: res.data.status,
|
|
loading: false,
|
|
status: false,
|
|
});
|
|
return;
|
|
} else {
|
|
toast.success(res.data.status | "Message Sent!");
|
|
setError({ message: "", loading: false, status: true });
|
|
setRefHistoryReload((prev) => !prev);
|
|
}
|
|
})
|
|
.catch((error) => {
|
|
setError({
|
|
message: "Opps! an error occured, try again later",
|
|
loading: false,
|
|
status: false,
|
|
});
|
|
});
|
|
};
|
|
|
|
//FUNCTION TO HANDLE SUBMIT
|
|
const handleSubmit = (values, helpers) => {
|
|
setError({ message: "", loading: true, status: false });
|
|
sendReferralMsg({...values}); // FUNCTION TO SEND REFERRAL MESSAGE
|
|
};
|
|
|
|
useEffect(() => {
|
|
allReferrals();
|
|
}, [refHistoryReload]);
|
|
|
|
return (
|
|
<div className="content-wrapper w-full lg:flex xl:space-x-8 bottomMargin">
|
|
<div className="lg:w-2/2 w-full mb-10 lg:mb-0">
|
|
<div className="sm:flex justify-between items-center mb-6">
|
|
<div className="mb-5 sm:mb-0">
|
|
<h1 className="text-26 font-bold inline-flex gap-3 text-dark-gray dark:text-white items-center">
|
|
<span>Refer a Friend</span>
|
|
</h1>
|
|
</div>
|
|
</div>
|
|
|
|
<div className="referral w-full md:p-8 p-4 bg-white dark:bg-dark-white rounded-2xl shadow">
|
|
<h2 className="mb-4 text-slate-900 dark:text-white text-xl lg:text-2xl font-medium">
|
|
Send Referral
|
|
</h2>
|
|
<Formik
|
|
initialValues={initialValues}
|
|
validationSchema={validationSchema}
|
|
onSubmit={handleSubmit}
|
|
>
|
|
{(props) => (
|
|
<Form className="referral-info">
|
|
<div className="block md:mb-6 md:flex gap-10">
|
|
{/* Firstname */}
|
|
<div className="field w-full mb-6 md:mb-0">
|
|
<InputCom
|
|
fieldClass="px-6"
|
|
label="Firstname"
|
|
type="text"
|
|
name="ref_firstname"
|
|
placeholder="Firstname"
|
|
value={props.values.ref_firstname}
|
|
inputHandler={props.handleChange}
|
|
blurHandler={props.handleBlur}
|
|
/>
|
|
{props.errors.ref_firstname &&
|
|
props.touched.ref_firstname && (
|
|
<p className="text-sm text-red-500">
|
|
{props.errors.ref_firstname}
|
|
</p>
|
|
)}
|
|
</div>
|
|
|
|
{/* Lastname */}
|
|
<div className="field w-full mb-6 md:mb-0">
|
|
<InputCom
|
|
fieldClass="px-6"
|
|
label="Lastname"
|
|
type="text"
|
|
name="ref_lastname"
|
|
placeholder="Lastname"
|
|
value={props.values.ref_lastname}
|
|
inputHandler={props.handleChange}
|
|
blurHandler={props.handleBlur}
|
|
/>
|
|
{props.errors.ref_lastname &&
|
|
props.touched.ref_lastname && (
|
|
<p className="text-sm text-red-500">
|
|
{props.errors.ref_lastname}
|
|
</p>
|
|
)}
|
|
</div>
|
|
</div>
|
|
|
|
<div className="field w-full mb-6">
|
|
<InputCom
|
|
fieldClass="px-6"
|
|
label="Email"
|
|
type="text"
|
|
name="ref_email"
|
|
placeholder="Email"
|
|
value={props.values.ref_email}
|
|
inputHandler={props.handleChange}
|
|
blurHandler={props.handleBlur}
|
|
/>
|
|
{props.errors.ref_email && props.touched.ref_email && (
|
|
<p className="text-sm text-red-500">
|
|
{props.errors.ref_email}
|
|
</p>
|
|
)}
|
|
</div>
|
|
|
|
<hr />
|
|
{error.message != "" && (
|
|
<p className="text-base text-red-500 py-2">{error.message}</p>
|
|
)}
|
|
<div className="referral-btn flex justify-end items-center py-4 border-b-4">
|
|
{error.loading ? (
|
|
<LoadingSpinner size="6" color="sky-blue" />
|
|
) : (
|
|
<button
|
|
type="submit"
|
|
className="px-2 h-11 flex justify-center items-center btn-gradient text-base rounded-full text-white"
|
|
>
|
|
Send Message
|
|
</button>
|
|
)}
|
|
</div>
|
|
</Form>
|
|
)}
|
|
</Formik>
|
|
</div>
|
|
|
|
<div className="w-full md:p-8 p-4 bg-white dark:bg-dark-white rounded-2xl shadow">
|
|
<h2 className="mb-2 text-slate-900 dark:text-white text-xl lg:text-2xl font-medium">
|
|
Referral List
|
|
</h2>
|
|
{referralList.loading ? (
|
|
<LoadingSpinner size="32" color="sky-blue" />
|
|
) : (
|
|
<ReferralTable history={referralList} />
|
|
)}
|
|
</div>
|
|
</div>
|
|
</div>
|
|
);
|
|
}
|
|
|
|
export default ReferralDisplay;
|