|
|
|
@@ -1,11 +1,11 @@
|
|
|
|
|
import React, { FC, useState, useEffect } from "react";
|
|
|
|
|
import NairaBag from "../../assets/images/dashboard/naira-bag.png";
|
|
|
|
|
import { Button, Icons } from "../";
|
|
|
|
|
import { useSelector } from "react-redux";
|
|
|
|
|
import PendingList from "../paginated-list/PendingList";
|
|
|
|
|
import { PendingTableList } from "../../core/models";
|
|
|
|
|
import { NewDateTimeFormatter } from "../../lib/NewDateTimeFormatter";
|
|
|
|
|
import { getUserPendingLoanList } from "../../core/apiRequest";
|
|
|
|
|
import React, { FC, useState, useEffect } from 'react';
|
|
|
|
|
import NairaBag from '../../assets/images/dashboard/naira-bag.png';
|
|
|
|
|
import { Button, Icons } from '../';
|
|
|
|
|
import { useSelector } from 'react-redux';
|
|
|
|
|
import PendingList from '../paginated-list/PendingList';
|
|
|
|
|
import { PendingTableList } from '../../core/models';
|
|
|
|
|
import { NewDateTimeFormatter } from '../../lib/NewDateTimeFormatter';
|
|
|
|
|
import { getUserPendingLoanList } from '../../core/apiRequest';
|
|
|
|
|
|
|
|
|
|
export interface DashBoardCardProps {
|
|
|
|
|
title?: string;
|
|
|
|
@@ -55,7 +55,7 @@ export const DashBoardCard: React.FC<DashBoardCardProps> = ({
|
|
|
|
|
)}
|
|
|
|
|
{desc && (
|
|
|
|
|
<p className={`text-lg text-left ${descClass && descClass}`}>
|
|
|
|
|
{desc}{" "}
|
|
|
|
|
{desc}{' '}
|
|
|
|
|
{descSpan && (
|
|
|
|
|
<span className={`${descSpanClass && descSpanClass}`}>
|
|
|
|
|
{descSpan}
|
|
|
|
@@ -73,117 +73,137 @@ export const DashBoardCard: React.FC<DashBoardCardProps> = ({
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
interface DashboardHomeIntroProps {
|
|
|
|
|
handleNextStep:(value:{})=>any
|
|
|
|
|
step?:number|string
|
|
|
|
|
handleNextStep: (value: {}) => any;
|
|
|
|
|
step?: number | string;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
const DashboardHomeIntro: FC<DashboardHomeIntroProps> = ({ handleNextStep, step }) => {
|
|
|
|
|
const { userDetails } = useSelector((state:any) => state?.userDetails); // CHECKS IF USER Details are avaliable
|
|
|
|
|
const DashboardHomeIntro: FC<DashboardHomeIntroProps> = ({
|
|
|
|
|
handleNextStep,
|
|
|
|
|
step,
|
|
|
|
|
}) => {
|
|
|
|
|
const { userDetails } = useSelector((state: any) => state?.userDetails); // CHECKS IF USER Details are avaliable
|
|
|
|
|
|
|
|
|
|
const [userLoanList, setUserLoanList] = useState<{loading:boolean, data:PendingTableList}>({loading: true, data:[]})
|
|
|
|
|
const [userLoanList, setUserLoanList] = useState<{
|
|
|
|
|
loading: boolean;
|
|
|
|
|
data: PendingTableList;
|
|
|
|
|
}>({ loading: true, data: [] });
|
|
|
|
|
|
|
|
|
|
useEffect(()=>{
|
|
|
|
|
let token = localStorage.getItem('token')
|
|
|
|
|
let uid = localStorage.getItem('uid')
|
|
|
|
|
if(!token || !uid){
|
|
|
|
|
return
|
|
|
|
|
useEffect(() => {
|
|
|
|
|
let token = localStorage.getItem('token');
|
|
|
|
|
let uid = localStorage.getItem('uid');
|
|
|
|
|
if (!token || !uid) {
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
getUserPendingLoanList(uid).then(res => {
|
|
|
|
|
console.log('RES', res)
|
|
|
|
|
console.log('RES', userLoanList)
|
|
|
|
|
if(!res || !res.data.loans){
|
|
|
|
|
setUserLoanList({loading:false, data:[]})
|
|
|
|
|
return
|
|
|
|
|
}
|
|
|
|
|
setUserLoanList({loading:false, data:res?.data?.loans})
|
|
|
|
|
}).catch(err => {
|
|
|
|
|
console.log(err)
|
|
|
|
|
setUserLoanList({loading:false, data:[]})
|
|
|
|
|
})
|
|
|
|
|
},[])
|
|
|
|
|
getUserPendingLoanList(uid)
|
|
|
|
|
.then((res) => {
|
|
|
|
|
console.log('RES', res);
|
|
|
|
|
console.log('RES', userLoanList);
|
|
|
|
|
if (!res || !res.data.loans) {
|
|
|
|
|
setUserLoanList({ loading: false, data: [] });
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
setUserLoanList({ loading: false, data: res?.data?.loans });
|
|
|
|
|
})
|
|
|
|
|
.catch((err) => {
|
|
|
|
|
console.log(err);
|
|
|
|
|
setUserLoanList({ loading: false, data: [] });
|
|
|
|
|
});
|
|
|
|
|
}, []);
|
|
|
|
|
|
|
|
|
|
return (
|
|
|
|
|
<div className='w-full'>
|
|
|
|
|
{step == 1 ?
|
|
|
|
|
<>
|
|
|
|
|
<h1 className="font-bold my-5 text-2xl">Hello, {userDetails.firstname}</h1>
|
|
|
|
|
<div className="group w-full lg:w-[27.8125rem] h-[12.75rem] mt-7 ">
|
|
|
|
|
<DashBoardCard
|
|
|
|
|
cardClass="bg-[#5C2684] relative"
|
|
|
|
|
desc="Begin your application and get up to "
|
|
|
|
|
descSpan="5 million naira loan."
|
|
|
|
|
descClass="leading-[1.5625rem] text-lg text-white"
|
|
|
|
|
descSpanClass="font-bold"
|
|
|
|
|
btnTitle="Apply here"
|
|
|
|
|
btnTextClass="w-[11.125rem] h-[2.8125rem] flex justify-center item-center btn-W text-[#FBB700]"
|
|
|
|
|
image={NairaBag}
|
|
|
|
|
imgClass="translate-y-4 -rotate-6"
|
|
|
|
|
onClick={()=>handleNextStep({})}
|
|
|
|
|
<div className="w-full">
|
|
|
|
|
{step == 1 ? (
|
|
|
|
|
<>
|
|
|
|
|
<h1 className="font-bold my-5 text-2xl">
|
|
|
|
|
Hello, {userDetails.firstname}
|
|
|
|
|
</h1>
|
|
|
|
|
<div className="group w-full lg:w-[27.8125rem] h-[12.75rem] mt-7 ">
|
|
|
|
|
<DashBoardCard
|
|
|
|
|
cardClass="bg-[#5C2684] relative"
|
|
|
|
|
desc="Begin your application and get up to "
|
|
|
|
|
descSpan="5 million naira loan."
|
|
|
|
|
descClass="leading-[1.5625rem] text-lg text-white"
|
|
|
|
|
descSpanClass="font-bold"
|
|
|
|
|
btnTitle="Apply here"
|
|
|
|
|
btnTextClass="w-[11.125rem] h-[2.8125rem] flex justify-center item-center btn-W text-[#FBB700]"
|
|
|
|
|
image={NairaBag}
|
|
|
|
|
imgClass="translate-y-4 -rotate-6"
|
|
|
|
|
onClick={() => handleNextStep({})}
|
|
|
|
|
/>
|
|
|
|
|
</div>
|
|
|
|
|
</>
|
|
|
|
|
:
|
|
|
|
|
<>
|
|
|
|
|
<h1 className="font-bold my-5 text-2xl">Welcome Back, {userDetails.firstname}</h1>
|
|
|
|
|
<div className="group w-full lg:w-[27.8125rem] h-[12.75rem] mt-7 ">
|
|
|
|
|
<DashBoardCard
|
|
|
|
|
cardClass="bg-[#5C2684] relative"
|
|
|
|
|
desc="Your loan application has been reviewed and accepted, please confirm for disbursement."
|
|
|
|
|
// descSpan="5 million naira loan."
|
|
|
|
|
descClass="leading-[1.5625rem] text-lg text-white"
|
|
|
|
|
// descSpanClass="font-bold"
|
|
|
|
|
btnTitle="View and accept"
|
|
|
|
|
btnTextClass="w-[11.125rem] h-[2.8125rem] flex justify-center item-center btn-W text-[#FBB700]"
|
|
|
|
|
image={NairaBag}
|
|
|
|
|
imgClass="translate-y-4 -rotate-6"
|
|
|
|
|
// onClick={handleNextStep}
|
|
|
|
|
</div>
|
|
|
|
|
</>
|
|
|
|
|
) : (
|
|
|
|
|
<>
|
|
|
|
|
<h1 className="font-bold my-5 text-2xl">
|
|
|
|
|
Welcome Back, {userDetails.firstname}
|
|
|
|
|
</h1>
|
|
|
|
|
<div className="group w-full lg:w-[27.8125rem] h-[12.75rem] mt-7 ">
|
|
|
|
|
<DashBoardCard
|
|
|
|
|
cardClass="bg-[#5C2684] relative"
|
|
|
|
|
desc="Your loan application has been reviewed and accepted, please confirm for disbursement."
|
|
|
|
|
// descSpan="5 million naira loan."
|
|
|
|
|
descClass="leading-[1.5625rem] text-lg text-white"
|
|
|
|
|
// descSpanClass="font-bold"
|
|
|
|
|
btnTitle="View and accept"
|
|
|
|
|
btnTextClass="w-[11.125rem] h-[2.8125rem] flex justify-center item-center btn-W text-[#FBB700]"
|
|
|
|
|
image={NairaBag}
|
|
|
|
|
imgClass="translate-y-4 -rotate-6"
|
|
|
|
|
// onClick={handleNextStep}
|
|
|
|
|
/>
|
|
|
|
|
</div>
|
|
|
|
|
</>
|
|
|
|
|
}
|
|
|
|
|
{userLoanList.loading ?
|
|
|
|
|
null
|
|
|
|
|
:
|
|
|
|
|
<div className='mt-5 w-full'>
|
|
|
|
|
<PendingList
|
|
|
|
|
data={userLoanList.data}
|
|
|
|
|
itemsPerPage={5}
|
|
|
|
|
tableTitle='Current Applications'
|
|
|
|
|
>
|
|
|
|
|
{(data:any)=>(
|
|
|
|
|
<div className="w-full p-4 rounded-lg shadow-lg bg-white overflow-x-auto min-h-[250px] max-h-[450px]">
|
|
|
|
|
<table className="w-full table-auto">
|
|
|
|
|
<thead>
|
|
|
|
|
<tr className='text-left border-b-2'>
|
|
|
|
|
<th className='px-1 py-4'>Date</th>
|
|
|
|
|
<th className='px-1 py-4 text-right'>Amount</th>
|
|
|
|
|
<th className='px-1 py-4 text-center'>Payment Term</th>
|
|
|
|
|
<th className='px-1 py-4 text-center'>Status</th>
|
|
|
|
|
<th className='px-1 py-4'>Action</th>
|
|
|
|
|
</tr>
|
|
|
|
|
</thead>
|
|
|
|
|
<tbody>
|
|
|
|
|
{data.map((item:any, index:any) =>(
|
|
|
|
|
<tr key={index || item} className='even:bg-slate-100'>
|
|
|
|
|
<td className='px-1 py-2'>{NewDateTimeFormatter(item?.added)}</td>
|
|
|
|
|
<td className='px-1 py-2 text-right'>{item?.loan_amount}</td>
|
|
|
|
|
<td className='px-1 py-2 text-center'>{item?.payment_month}</td>
|
|
|
|
|
<td className='px-1 py-2 text-center'>{item?.status}</td>
|
|
|
|
|
<td className='px-1 py-2'>
|
|
|
|
|
<button className='px-2 py-1 border-2 border-black flex gap-2 items-center'>
|
|
|
|
|
View
|
|
|
|
|
<Icons name='arrow-right' />
|
|
|
|
|
</button>
|
|
|
|
|
</td>
|
|
|
|
|
</div>
|
|
|
|
|
</>
|
|
|
|
|
)}
|
|
|
|
|
{userLoanList.loading ? null : (
|
|
|
|
|
<div className="mt-5 w-full">
|
|
|
|
|
<PendingList
|
|
|
|
|
data={userLoanList.data}
|
|
|
|
|
itemsPerPage={5}
|
|
|
|
|
tableTitle="Current Applications"
|
|
|
|
|
>
|
|
|
|
|
{(data: any) => (
|
|
|
|
|
<div className="w-full p-4 rounded-lg shadow-lg bg-white overflow-x-auto min-h-[250px] max-h-[450px]">
|
|
|
|
|
<table className="text-[12px] sm:text-base w-full table-auto">
|
|
|
|
|
<thead>
|
|
|
|
|
<tr className="text-left border-b-2">
|
|
|
|
|
<th className="px-1 py-4">Date</th>
|
|
|
|
|
<th className="px-1 py-4 text-right">Amount</th>
|
|
|
|
|
<th className="px-1 py-4 text-center min-w-[110px]">
|
|
|
|
|
Payment Term
|
|
|
|
|
</th>
|
|
|
|
|
<th className="px-1 py-4 text-center">Status</th>
|
|
|
|
|
<th className="px-1 py-4 text-right">Action</th>
|
|
|
|
|
</tr>
|
|
|
|
|
))}
|
|
|
|
|
</tbody>
|
|
|
|
|
</table>
|
|
|
|
|
</div>
|
|
|
|
|
)}
|
|
|
|
|
</PendingList>
|
|
|
|
|
</div>
|
|
|
|
|
}
|
|
|
|
|
</thead>
|
|
|
|
|
<tbody>
|
|
|
|
|
{data.map((item: any, index: any) => (
|
|
|
|
|
<tr key={index || item} className="even:bg-slate-100">
|
|
|
|
|
<td className="px-1 py-2">
|
|
|
|
|
{NewDateTimeFormatter(item?.added)}
|
|
|
|
|
</td>
|
|
|
|
|
<td className="px-1 py-2 text-right">
|
|
|
|
|
{item?.loan_amount}
|
|
|
|
|
</td>
|
|
|
|
|
<td className="px-1 py-2 text-center">
|
|
|
|
|
{item?.payment_month}
|
|
|
|
|
</td>
|
|
|
|
|
<td className="px-1 py-2 text-center">
|
|
|
|
|
{item?.status}
|
|
|
|
|
</td>
|
|
|
|
|
<td className="px-1 py-2 text-right">
|
|
|
|
|
<button className="px-2 py-1 border-2 border-black">
|
|
|
|
|
View
|
|
|
|
|
<Icons name="arrow-right" />
|
|
|
|
|
</button>
|
|
|
|
|
</td>
|
|
|
|
|
</tr>
|
|
|
|
|
))}
|
|
|
|
|
</tbody>
|
|
|
|
|
</table>
|
|
|
|
|
</div>
|
|
|
|
|
)}
|
|
|
|
|
</PendingList>
|
|
|
|
|
</div>
|
|
|
|
|
)}
|
|
|
|
|
</div>
|
|
|
|
|
);
|
|
|
|
|
};
|
|
|
|
|