user header name added
This commit is contained in:
@@ -38,8 +38,8 @@ export default function Login() {
|
|||||||
const {token} = res?.data?.data
|
const {token} = res?.data?.data
|
||||||
if(token){
|
if(token){
|
||||||
localStorage.setItem('token', token)
|
localStorage.setItem('token', token)
|
||||||
const data = {token}
|
// const data = {token}
|
||||||
dispatch(updateUserDetails({ ...data }));
|
// dispatch(updateUserDetails({ ...data }));
|
||||||
navigate('/dash') // later add redux to dispatch state
|
navigate('/dash') // later add redux to dispatch state
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -7,6 +7,7 @@ import Layout from '../layout/Layout'
|
|||||||
import siteLinks from '../../links/siteLinks'
|
import siteLinks from '../../links/siteLinks'
|
||||||
|
|
||||||
import debounceFunction from '../../utils/debounceFunction'
|
import debounceFunction from '../../utils/debounceFunction'
|
||||||
|
import { accountDashboard } from '../../services/services';
|
||||||
|
|
||||||
|
|
||||||
export default function UserExist() {
|
export default function UserExist() {
|
||||||
@@ -19,9 +20,9 @@ export default function UserExist() {
|
|||||||
|
|
||||||
const [lastActivityTime, setLastActivityTime] = useState(Date.now()); // HOLDS THE INITIAL TIME USER LOGS IN
|
const [lastActivityTime, setLastActivityTime] = useState(Date.now()); // HOLDS THE INITIAL TIME USER LOGS IN
|
||||||
|
|
||||||
const { userDetails: { token }} = useSelector((state) => state?.userDetails); // CHECKS IF USER Details are avaliable, to determine if user is active
|
const { userDetails: { lastname }} = useSelector((state) => state?.userDetails); // CHECKS IF USER Details are avaliable, to determine if user is active
|
||||||
|
|
||||||
let loggedIn = token ? true : false; // variable to determine if user is logged in
|
let loggedIn = lastname ? true : false; // variable to determine if user is logged in
|
||||||
// console.log('loggedIn', loggedIn)
|
// console.log('loggedIn', loggedIn)
|
||||||
|
|
||||||
// Function to log the user out
|
// Function to log the user out
|
||||||
@@ -57,25 +58,40 @@ export default function UserExist() {
|
|||||||
})
|
})
|
||||||
}
|
}
|
||||||
},[lastActivityTime])
|
},[lastActivityTime])
|
||||||
|
|
||||||
|
|
||||||
useEffect(()=>{
|
useEffect(()=>{
|
||||||
let token = localStorage.getItem('token')
|
let token = localStorage.getItem('token')
|
||||||
const timer = setTimeout(()=>{
|
if(!token){
|
||||||
if(token && loggedIn){
|
return navigate(siteLinks.login)
|
||||||
setLoading(false)
|
}
|
||||||
}else if(token && !loggedIn){
|
|
||||||
const data = {token}
|
accountDashboard().then(res => {
|
||||||
dispatch(updateUserDetails({ ...data }));
|
const {dash_data} = res?.data
|
||||||
setLoading(false)
|
setLoading(false)
|
||||||
// dispatch(updateUserDetails({ ...res.data }));
|
dispatch(updateUserDetails({ ...dash_data }));
|
||||||
}else{
|
}).catch(err => {
|
||||||
navigate('auth/login')
|
navigate(siteLinks.login)
|
||||||
}
|
})
|
||||||
},1000)
|
|
||||||
|
|
||||||
return () => clearTimeout(timer)
|
|
||||||
},[])
|
},[])
|
||||||
|
|
||||||
|
|
||||||
|
// useEffect(()=>{
|
||||||
|
// let token = localStorage.getItem('token')
|
||||||
|
// const timer = setTimeout(()=>{
|
||||||
|
// if(token && loggedIn){
|
||||||
|
// setLoading(false)
|
||||||
|
// }else if(token && !loggedIn){
|
||||||
|
// const data = {token}
|
||||||
|
// dispatch(updateUserDetails({ ...data }));
|
||||||
|
// setLoading(false)
|
||||||
|
// // dispatch(updateUserDetails({ ...res.data }));
|
||||||
|
// }else{
|
||||||
|
// navigate('auth/login')
|
||||||
|
// }
|
||||||
|
// },1000)
|
||||||
|
|
||||||
|
// return () => clearTimeout(timer)
|
||||||
|
// },[])
|
||||||
|
|
||||||
return (
|
return (
|
||||||
<>
|
<>
|
||||||
|
|||||||
@@ -1,40 +1,40 @@
|
|||||||
import React from "react";
|
import React from "react";
|
||||||
import BreadcrumbComBS from "../breadcrumb/BreadcrumbComBS";
|
import BreadcrumbComBS from "../breadcrumb/BreadcrumbComBS";
|
||||||
import { useQuery } from "@tanstack/react-query";
|
// import { useQuery } from "@tanstack/react-query";
|
||||||
import { accountDashboard } from "../../services/services";
|
// import { accountDashboard } from "../../services/services";
|
||||||
import queryKeys from "../../services/queryKeys";
|
// import queryKeys from "../../services/queryKeys";
|
||||||
import MainLoaderBS from "../loaders/MainLoaderBS";
|
// import MainLoaderBS from "../loaders/MainLoaderBS";
|
||||||
|
|
||||||
|
|
||||||
export default function HomeSections(){
|
export default function HomeSections(){
|
||||||
|
|
||||||
const {data:dashData, isFetching, isError} = useQuery({
|
// const {data:dashData, isFetching, isError} = useQuery({
|
||||||
queryKey: queryKeys.dashboard,
|
// queryKey: queryKeys.dashboard,
|
||||||
queryFn: async () => await accountDashboard()
|
// queryFn: async () => await accountDashboard()
|
||||||
})
|
// })
|
||||||
|
|
||||||
if(isFetching){
|
// if(isFetching){
|
||||||
return(
|
// return(
|
||||||
<>
|
// <>
|
||||||
{/* <MainLoaderBS /> */}
|
// {/* <MainLoaderBS /> */}
|
||||||
<div className="row">
|
// <div className="row">
|
||||||
<div className="col-12">
|
// <div className="col-12">
|
||||||
<p className='text-success'>Loading...</p>
|
// <p className='text-success'>Loading...</p>
|
||||||
</div>
|
// </div>
|
||||||
</div>
|
// </div>
|
||||||
</>
|
// </>
|
||||||
)
|
// )
|
||||||
}
|
// }
|
||||||
|
|
||||||
if(isError){
|
// if(isError){
|
||||||
return (
|
// return (
|
||||||
<div className="row">
|
// <div className="row">
|
||||||
<div className="col-12">
|
// <div className="col-12">
|
||||||
<p className='text-danger'>Error occured! Please refresh to continue</p>
|
// <p className='text-danger'>Error occured! Please refresh to continue</p>
|
||||||
</div>
|
// </div>
|
||||||
</div>
|
// </div>
|
||||||
)
|
// )
|
||||||
}
|
// }
|
||||||
|
|
||||||
return <>
|
return <>
|
||||||
{/* <div className="row">
|
{/* <div className="row">
|
||||||
|
|||||||
@@ -1,10 +1,14 @@
|
|||||||
import React from "react";
|
import React from "react";
|
||||||
import getImage from "../../../utils/getImage";
|
import getImage from "../../../utils/getImage";
|
||||||
import { useNavigate } from "react-router-dom";
|
import { useNavigate } from "react-router-dom";
|
||||||
|
import { useSelector } from "react-redux";
|
||||||
|
import siteLinks from "../../../links/siteLinks";
|
||||||
|
|
||||||
|
|
||||||
export default function UserHeader(){
|
export default function UserHeader(){
|
||||||
|
|
||||||
|
const { userDetails } = useSelector((state) => state?.userDetails); // CHECKS IF USER Details are avaliable, to determine if user is active
|
||||||
|
|
||||||
const toggleSidebar = (e) => {
|
const toggleSidebar = (e) => {
|
||||||
e.preventDefault()
|
e.preventDefault()
|
||||||
document.body.classList.toggle('sidebar-toggled')
|
document.body.classList.toggle('sidebar-toggled')
|
||||||
@@ -23,7 +27,7 @@ export default function UserHeader(){
|
|||||||
|
|
||||||
const logout = () => {
|
const logout = () => {
|
||||||
localStorage.clear()
|
localStorage.clear()
|
||||||
navigate('/login', {replace: true})
|
navigate(siteLinks.login, {replace: true})
|
||||||
}
|
}
|
||||||
|
|
||||||
return (
|
return (
|
||||||
@@ -42,20 +46,21 @@ export default function UserHeader(){
|
|||||||
<i className="ti ti-align-left"></i>
|
<i className="ti ti-align-left"></i>
|
||||||
</button>
|
</button>
|
||||||
<div className="collapse navbar-collapse" id="navbarSupportedContent">
|
<div className="collapse navbar-collapse" id="navbarSupportedContent">
|
||||||
<div className="navigation d-flex">
|
<div className="navigation d-flex align-items-center">
|
||||||
{/* <ul className="navbar-nav nav-left">
|
<ul className="navbar-nav nav-left">
|
||||||
<li className="nav-item">
|
<h4 className="text-info pt-1">{userDetails?.account_name}</h4>
|
||||||
|
{/* <li className="nav-item">
|
||||||
<a href="#" className="nav-link sidebar-toggle">
|
<a href="#" className="nav-link sidebar-toggle">
|
||||||
<i className="ti ti-align-right"></i>
|
<i className="ti ti-align-right"></i>
|
||||||
</a>
|
</a>
|
||||||
</li>
|
</li> */}
|
||||||
|
|
||||||
<li className="nav-item full-screen d-none d-lg-block" id="btnFullscreen">
|
{/* <li className="nav-item full-screen d-none d-lg-block" id="btnFullscreen">
|
||||||
<a href="#" className="nav-link expand">
|
<a href="#" className="nav-link expand">
|
||||||
<i className="icon-size-fullscreen"></i>
|
<i className="icon-size-fullscreen"></i>
|
||||||
</a>
|
</a>
|
||||||
</li>
|
</li> */}
|
||||||
</ul> */}
|
</ul>
|
||||||
|
|
||||||
<ul className="navbar-nav nav-right ml-auto">
|
<ul className="navbar-nav nav-right ml-auto">
|
||||||
{/* <li className="nav-item dropdown">
|
{/* <li className="nav-item dropdown">
|
||||||
@@ -285,8 +290,8 @@ export default function UserHeader(){
|
|||||||
<div className="bg-gradient px-4 py-3">
|
<div className="bg-gradient px-4 py-3">
|
||||||
<div className="d-flex align-items-center justify-content-between">
|
<div className="d-flex align-items-center justify-content-between">
|
||||||
<div className="mr-1">
|
<div className="mr-1">
|
||||||
<h4 className="text-white mb-0">Alice Williams</h4>
|
<h5 className="text-white mb-0">{userDetails?.firstname} {userDetails?.lastname}</h5>
|
||||||
<small className="text-white">Henry@example.com</small>
|
<small className="text-white">{userDetails.email}</small>
|
||||||
</div>
|
</div>
|
||||||
<a href="#" onClick={logout} className="text-white font-20 tooltip-wrapper" data-toggle="tooltip"
|
<a href="#" onClick={logout} className="text-white font-20 tooltip-wrapper" data-toggle="tooltip"
|
||||||
data-placement="top" title="" data-original-title="Logout"> <i
|
data-placement="top" title="" data-original-title="Logout"> <i
|
||||||
|
|||||||
Reference in New Issue
Block a user