199 lines
7.1 KiB
JavaScript
199 lines
7.1 KiB
JavaScript
import React, { useState, useEffect } from "react";
|
|
import EmpProfile from "../../components/Employee/EmpProfile";
|
|
import axios from "axios";
|
|
import Breadcrumb from "../../components/common/Breadcrumb";
|
|
import EmployeeNav from "../../components/Employee/EmployeeNav";
|
|
import { useSearchParams,useParams } from "react-router-dom";
|
|
import { getCachedData } from "../../slices/apiDataManager";
|
|
import { useEmployeeProfile, useEmployees, useEmployeesByProject } from "../../hooks/useEmployees";
|
|
import { useSelector } from "react-redux";
|
|
import EmployeeRepository from "../../repositories/EmployeeRepository";
|
|
import { ComingSoonPage } from "../Misc/ComingSoonPage";
|
|
import { useNavigate } from "react-router-dom";
|
|
import Avatar from "../../components/common/Avatar";
|
|
import AttendancesEmployeeRecords from "./AttendancesEmployeeRecords";
|
|
const EmployeeProfile = () => {
|
|
|
|
const projectID = useSelector((store)=>store.localVariables.projectId)
|
|
const {employeeId} = useParams();
|
|
// const {employee,loading} = useEmployeeProfile(employeeId)
|
|
const [loading,setLoading] = useState(true)
|
|
|
|
const [SearchParams] = useSearchParams()
|
|
const tab = SearchParams.get( "for" )
|
|
const [activePill, setActivePill] = useState(tab);
|
|
const[currentEmployee,setCurrentEmployee] = useState()
|
|
|
|
|
|
const handlePillClick = (pillKey) => {
|
|
setActivePill(pillKey);
|
|
};
|
|
|
|
const fetchEmployeeProfile = async( employeeID ) =>
|
|
{
|
|
try
|
|
{
|
|
const resp = await EmployeeRepository.getEmployeeProfile( employeeID )
|
|
setCurrentEmployee( resp.data )
|
|
setLoading(false)
|
|
|
|
} catch ( err )
|
|
{
|
|
setLoading(false)
|
|
|
|
}
|
|
}
|
|
|
|
useEffect(() => {
|
|
if ( employeeId )
|
|
{
|
|
fetchEmployeeProfile(employeeId)
|
|
}
|
|
}, [employeeId]);
|
|
|
|
const navigate = useNavigate();
|
|
const renderContent = () => {
|
|
if (loading) return <div>Loading</div>;
|
|
switch (activePill) {
|
|
case "attendance": {
|
|
return (
|
|
<>
|
|
<AttendancesEmployeeRecords employee={employeeId } />
|
|
|
|
</>
|
|
);
|
|
}
|
|
case "dcoument": {
|
|
return (
|
|
<>
|
|
<ComingSoonPage/>
|
|
</>
|
|
);
|
|
break;
|
|
}
|
|
case "activities": {
|
|
return (
|
|
<>
|
|
<ComingSoonPage/>
|
|
</>
|
|
);
|
|
break;
|
|
}
|
|
|
|
default:
|
|
return <>
|
|
<ComingSoonPage/>
|
|
</>;
|
|
}
|
|
};
|
|
|
|
|
|
|
|
if (loading) {
|
|
return <div>Loading...</div>;
|
|
}
|
|
|
|
|
|
return (
|
|
<div className="container-xxl flex-grow-1 container-p-y">
|
|
<Breadcrumb
|
|
data={[
|
|
{ label: "Home", link: "/dashboard" },
|
|
{ label: "Employees", link: "/employees" },
|
|
{ label: "Profile", link: null },
|
|
]}
|
|
></Breadcrumb>
|
|
|
|
<div className="row">
|
|
<div className="col-12 col-md-8 col-lg-4 order-1 order-lg-1">
|
|
<div className="row">
|
|
<div className="col-12 mb-4">
|
|
<div className="card">
|
|
<div className="card-body">
|
|
<div className="d-flex flex-row flex-lg-column">
|
|
<div className="d-flex flex-column justify-content-center align-items-center text-center">
|
|
<Avatar
|
|
firstName={`${currentEmployee?.firstName}`}
|
|
lastName={`${currentEmployee?.lastName}`}
|
|
size={"lg"}
|
|
/>
|
|
<div className="py-2">
|
|
<p className="h6">{`${currentEmployee?.firstName} ${currentEmployee?.lastName}`}</p>
|
|
</div>
|
|
</div>
|
|
<div className="w-100 d-flex flex-column justify-content-start">
|
|
<div className="mt-3 w-100">
|
|
<h6 className="mb-2 text-muted text-start">Employee Info</h6>
|
|
<table className="table table-borderless mb-3">
|
|
<tbody>
|
|
<tr>
|
|
<td className="fw-medium text-start">Email:</td>
|
|
<td className="text-start">{currentEmployee?.email || <em>NA</em>}</td>
|
|
</tr>
|
|
<tr>
|
|
<td className="fw-medium text-start">Phone Number:</td>
|
|
<td className="text-start">{currentEmployee?.phoneNumber || <em>NA</em>}</td>
|
|
</tr>
|
|
<tr>
|
|
<td className="fw-medium text-start">Emergency Contact Person:</td>
|
|
<td className="text-start">{currentEmployee?.emergencyContactPerson || <em>NA</em>}</td>
|
|
</tr>
|
|
<tr>
|
|
<td className="fw-medium text-start">Emergency Contact Number:</td>
|
|
<td className="text-start">{currentEmployee?.emergencyPhoneNumber || <em>NA</em>}</td>
|
|
</tr>
|
|
|
|
<tr>
|
|
<td className="fw-medium text-start">Gender:</td>
|
|
<td className="text-start">{currentEmployee?.gender || <em>NA</em>}</td>
|
|
</tr>
|
|
<tr>
|
|
<td className="fw-medium text-start">Birth Date:</td>
|
|
<td className="text-start">{currentEmployee?.birthDate ? new Date(currentEmployee.birthDate).toLocaleDateString() : <em>NA</em>}</td>
|
|
</tr>
|
|
|
|
|
|
<tr>
|
|
<td className="fw-medium text-start">Joining Date:</td>
|
|
<td className="text-start">{currentEmployee?.joiningDate ? new Date(currentEmployee.joiningDate).toLocaleDateString() : <em>NA</em>}</td>
|
|
</tr>
|
|
<tr>
|
|
<td className="fw-medium text-start">Job Role:</td>
|
|
<td className="text-start">{currentEmployee?.jobRole || <em>NA</em>}</td>
|
|
</tr>
|
|
<tr>
|
|
<td className="fw-medium text-start">Address:</td>
|
|
<td className="text-start">{currentEmployee?.currentAddress || <em>NA</em>}</td>
|
|
</tr>
|
|
</tbody>
|
|
</table>
|
|
</div>
|
|
<button className="btn btn-primary btn-block" onClick={() => navigate(`/employee/manage/${currentEmployee?.id}`)}>
|
|
Edit Profile
|
|
</button>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
|
|
<div className="col-12 col-lg-8 order-2 order-lg-2 mb-4">
|
|
<div className="row">
|
|
<EmployeeNav onPillClick={handlePillClick} activePill={activePill} />
|
|
</div>
|
|
<div className="card">
|
|
<div className="row row-bordered g-0">
|
|
{renderContent()}
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
);
|
|
};
|
|
|
|
export default EmployeeProfile;
|