Compare commits

...

6 Commits

Author SHA1 Message Date
victorAnumudu e4d161c0a9 updated base url 2025-04-24 12:10:31 +01:00
ameye f3b09a0ea2 Merge branch 'login-endpoint-resolved' of DigiFi/digifi-FirstOffice into master 2025-04-23 01:59:43 +00:00
victorAnumudu 321122258a added key to map function 2025-04-22 19:12:08 +01:00
victorAnumudu fc9925a837 loans API added 2025-04-22 19:03:02 +01:00
victorAnumudu 239b912585 login resolved 2025-04-22 17:34:40 +01:00
tokslaw db2fe102f8 Merge branch 'unresolved-package-removal' of DigiFi/digifi-FirstOffice into master 2025-04-17 12:33:14 +00:00
9 changed files with 43 additions and 30 deletions
+1 -1
View File
@@ -6,7 +6,7 @@ TWITTER_URL=https://twitter.com
INSTAGRAM_URL=https://www.instagram.com INSTAGRAM_URL=https://www.instagram.com
# BACKEND END POINTS # BACKEND END POINTS
REACT_APP_MAIN_API='http://backoffice-apidev.simbrellang.net:14700' REACT_APP_MAIN_API='https://backoffice-apidev.simbrellang.net'
# ENQUIRIES CONTACTS # ENQUIRIES CONTACTS
VITE_CALL_ENDPOINT='09099000000' VITE_CALL_ENDPOINT='09099000000'
+1 -1
View File
@@ -6,7 +6,7 @@ VITE_TWITTER_URL=https://twitter.com
VITE_INSTAGRAM_URL=https://www.instagram.com VITE_INSTAGRAM_URL=https://www.instagram.com
# BACKEND END POINTS # BACKEND END POINTS
REACT_APP_MAIN_API='http://backoffice-apidev.simbrellang.net:14700' REACT_APP_MAIN_API='https://backoffice-apidev.simbrellang.net'
# ENQUIRIES CONTACTS # ENQUIRIES CONTACTS
VITE_CALL_ENDPOINT='09099000000' VITE_CALL_ENDPOINT='09099000000'
+1 -1
View File
@@ -6,7 +6,7 @@ TWITTER_URL=https://twitter.com
INSTAGRAM_URL=https://www.instagram.com INSTAGRAM_URL=https://www.instagram.com
# BACKEND END POINTS # BACKEND END POINTS
REACT_APP_MAIN_API='http://backoffice-apidev.simbrellang.net:14700' REACT_APP_MAIN_API='https://backoffice-apidev.simbrellang.net'
# ENQUIRIES CONTACTS # ENQUIRIES CONTACTS
VITE_CALL_ENDPOINT='09099000000' VITE_CALL_ENDPOINT='09099000000'
+2 -1
View File
@@ -23,8 +23,9 @@ function App() {
queries: { queries: {
refetchOnWindowFocus: false, refetchOnWindowFocus: false,
retry: 3, retry: 3,
staleTime: 300000 //5 mins
// refetchOnMount: false, // refetchOnMount: false,
staleTime: Infinity // can also be a number in millisecond // staleTime: Infinity // can also be a number in millisecond
}, },
}, },
}) })
+1 -1
View File
@@ -14,7 +14,7 @@ export default function HomeCom() {
const {data, isFetching, isError, error} = useQuery({ const {data, isFetching, isError, error} = useQuery({
queryKey: queryKeys.dashboard, queryKey: queryKeys.dashboard,
queryFn: () => getDashData() queryFn: () => getDashData(),
}) })
const dashData = data?.data // DASHBOARD DATA const dashData = data?.data // DASHBOARD DATA
@@ -32,7 +32,7 @@ export default function DashboardAside() {
let hasSubLinks = (link.subLinks && link.subLinks.length > 0) ? true : false let hasSubLinks = (link.subLinks && link.subLinks.length > 0) ? true : false
if(active && !hasSubLinks){ if(active && !hasSubLinks){
return ( return (
<div key={index}> <div key={link.name}>
<AsideLink to={link.to} name={link.name} icon={link.icon} /> <AsideLink to={link.to} name={link.name} icon={link.icon} />
</div> </div>
) )
@@ -49,7 +49,7 @@ export default function DashboardAside() {
} }
}) })
return ( return (
<div key={index} className="w-full"> <div key={link.name} className="w-full">
{link.title && {link.title &&
<h1 className="px-4 py-2 text-sm sm:text-sm text-slate-500 dark:text-white font-semibold uppercase mt-3 mb-1 border-b border-slate-500 dark:border-white">{link.title}</h1> <h1 className="px-4 py-2 text-sm sm:text-sm text-slate-500 dark:text-white font-semibold uppercase mt-3 mb-1 border-b border-slate-500 dark:border-white">{link.title}</h1>
} }
@@ -60,8 +60,8 @@ export default function DashboardAside() {
let hasSubLinks = (subItem.subLinks && subItem.subLinks.length > 0) ? true : false let hasSubLinks = (subItem.subLinks && subItem.subLinks.length > 0) ? true : false
if(active && !hasSubLinks){ if(active && !hasSubLinks){
return ( return (
<div key={index}> <div key={subItem.name}>
<AsideLink key={index} to={subItem.to} name={subItem.name} icon={subItem.icon} /> <AsideLink to={subItem.to} name={subItem.name} icon={subItem.icon} />
</div> </div>
) )
}else if(active && hasSubLinks){ }else if(active && hasSubLinks){
@@ -71,7 +71,7 @@ export default function DashboardAside() {
} }
}) })
return( return(
<AsideLinkWithSubLinks name={subItem.name} icon={subItem.icon} isOpen={subLinkList.includes(pathname)}> <AsideLinkWithSubLinks key={subItem.name} name={subItem.name} icon={subItem.icon} isOpen={subLinkList.includes(pathname)}>
<> <>
{subItem.subLinks.map((item, index)=>{ {subItem.subLinks.map((item, index)=>{
let active = item.status == 1 ? true : false let active = item.status == 1 ? true : false
+21 -19
View File
@@ -1,6 +1,5 @@
import React from 'react' import React from 'react'
import { useQuery } from "@tanstack/react-query"; import { useQuery } from "@tanstack/react-query";
import {Link} from 'react-router-dom'
import BreadcrumbCom from '../breadcrumb/BreadcrumbCom' import BreadcrumbCom from '../breadcrumb/BreadcrumbCom'
import TableWrapper from '../tableWrapper/TableWrapper' import TableWrapper from '../tableWrapper/TableWrapper'
@@ -8,18 +7,21 @@ import Icons from '../Icons'
import Avatar from '../../assets/user_avatar.jpg' import Avatar from '../../assets/user_avatar.jpg'
import queryKeys from '../../services/queryKeys' import queryKeys from '../../services/queryKeys'
import { selectLoan } from '../../services/siteServices' import { getLoans } from '../../services/siteServices'
import getDateFromDateString from '../../helpers/GetDateFromDateString'; import getDateFromDateString from '../../helpers/GetDateFromDateString';
import formatNumber from '../../helpers/formatNumber'
import getTimeFromDateString from '../../helpers/GetTimeFromDateString'; import getTimeFromDateString from '../../helpers/GetTimeFromDateString';
export default function LoansCom() { export default function LoansCom() {
const {data, isFetching, isError, error} = useQuery({ const {data:allLoans, isFetching, isError, error} = useQuery({
queryKey: queryKeys.select_loan, queryKey: queryKeys.loans,
queryFn: () => selectLoan() queryFn: () => getLoans()
}) })
const selectUsers = data?.data?.result_data?.data // APPLY LOAN LIST const loans = allLoans?.data?.loans // LOANS LIST
const loansCount = allLoans?.data?.count // LOANS LIST COUNT
// console.log('LOANS', loans)
return ( return (
<div className='w-full flex flex-col gap-8'> <div className='w-full flex flex-col gap-8'>
@@ -33,19 +35,19 @@ export default function LoansCom() {
: isError ? : isError ?
<p className='text-red-500'>{error.message}</p> <p className='text-red-500'>{error.message}</p>
: :
<TableWrapper data={selectUsers} itemsPerPage={15}> <TableWrapper data={loans} itemsPerPage={15}>
{({ data }) => ( {({ data }) => (
<> <>
<table className="py-2 w-full text-sm"> <table className="table-auto py-2 w-full text-sm">
<thead className="py-2 text-sm text-slate-500 text-left"> <thead className="py-2 text-sm text-slate-500 text-left">
<tr> <tr>
<th scope="col" className="px-2 py-2"> <th scope="col" className="px-2 py-2">
Name Name
</th> </th>
<th scope="col" className="px-2"> <th scope="col" className="px-2 text-right">
Loan Loan Amount
</th> </th>
<th scope="col" className="px-2"> <th scope="col" className="px-2 text-right">
Added Added
</th> </th>
<th scope="col" className="px-2 text-right"> <th scope="col" className="px-2 text-right">
@@ -55,25 +57,25 @@ export default function LoansCom() {
</thead> </thead>
<tbody> <tbody>
{(data && data.length > 0) ? data?.map((item, index) => ( {(data && data.length > 0) ? data?.map((item, index) => (
<tr className="py-2 border-t border-dashed border-slate-300"> <tr key={index} className="py-2 border-t border-dashed border-slate-300">
<td className="px-2 py-2"> <td className="px-2 py-2">
<div className='w-full min-w-48 flex items-center gap-2 whitespace-nowrap'> <div className='w-full min-w-48 flex items-center gap-2 whitespace-nowrap'>
<img className="w-10 h-10 rounded-md" src={Avatar} alt="Jese image" /> <img className="w-10 h-10 rounded-md" src={Avatar} alt="Jese image" />
<div className="text-left"> <div className="text-left">
<div className="text-base font-semibold">{item?.name || ''}</div> <div className="text-base font-semibold">{item?.account_id || ''}</div>
<div className="font-normal text-gray-500">{item?.bvn}</div> <div className="font-normal text-gray-500">{item?.customer_id}</div>
</div> </div>
</div> </div>
</td> </td>
<td className="px-2"> <td className="px-2">
<div className="text-left"> <div className="text-right">
<div className="text-base font-semibold">{item?.loan}</div> {/* <div className="text-base font-semibold">{formatNumber(item?.initial_loan_amount)}</div> */}
<div className="font-normal text-gray-500">{item?.description}</div> <div className="font-normal text-gray-500">{formatNumber(item?.initial_loan_amount)}</div>
</div> </div>
</td> </td>
<td className="px-2"> <td className="px-2">
<div className="text-left"> <div className="text-right">
<div className="font-normal text-gray-500">{getDateFromDateString(item?.added)} {getTimeFromDateString(item?.added)}</div> <div className="font-normal text-gray-500">{getDateFromDateString(item?.created_at)}</div>
</div> </div>
</td> </td>
<td className="px-2 text-right"> <td className="px-2 text-right">
+1
View File
@@ -1,5 +1,6 @@
const queryKeys = { const queryKeys = {
dashboard: ['dashboard'], dashboard: ['dashboard'],
loans: ['loans'],
apply_loan: ['apply'], apply_loan: ['apply'],
select_loan: ['select-loan'], select_loan: ['select-loan'],
approved_loan: ['approved-loan'], approved_loan: ['approved-loan'],
+10 -1
View File
@@ -8,7 +8,7 @@ axios.interceptors.request.use(
"Access-Control-Allow-Origin": "*", "Access-Control-Allow-Origin": "*",
// "Access-Control-Expose-Headers": "Access-Control-Allow-Origin", // "Access-Control-Expose-Headers": "Access-Control-Allow-Origin",
// "Access-Control-Allow-Headers": "Origin, X-API-KEY, X-Requested-With, Content-Type, Accept, Access-Control-Request-Method, Access-Control-Allow-Headers, Authorization, observe, enctype, Content-Length, X-Csrf-Token", // "Access-Control-Allow-Headers": "Origin, X-API-KEY, X-Requested-With, Content-Type, Accept, Access-Control-Request-Method, Access-Control-Allow-Headers, Authorization, observe, enctype, Content-Length, X-Csrf-Token",
"Content-Type": "application/json;charset=UTF-8", // "Content-Type": "application/json;charset=UTF-8",
'Authorization': (localStorage && localStorage.getItem('token')) ? `Bearer ${localStorage.getItem('token')}` : '' 'Authorization': (localStorage && localStorage.getItem('token')) ? `Bearer ${localStorage.getItem('token')}` : ''
}; };
// config.headers['Authorization'] = `Bearer ${localStorage.getItem('token')}`; // config.headers['Authorization'] = `Bearer ${localStorage.getItem('token')}`;
@@ -56,6 +56,15 @@ export const getDashData = (reqData) => {
return getAuxEnd(`/dashboard`, postData) return getAuxEnd(`/dashboard`, postData)
} }
// FUNCTION TO GET APPLIED LOANS TABLE
export const getLoans = (reqData) => {
const postData = { ...reqData }
return getAuxEnd(`/loans`, postData)
}
// FUNCTION TO GET APPLIED LOANS TABLE // FUNCTION TO GET APPLIED LOANS TABLE
export const applyLoan = (reqData) => { export const applyLoan = (reqData) => {
const postData = { ...reqData } const postData = { ...reqData }