Compare commits
	
		
			7 Commits
		
	
	
		
			6f19196265
			...
			d1011fd5ec
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| d1011fd5ec | |||
| dcc6b80f12 | |||
| 6bf8fcf9a2 | |||
| 37620c78a1 | |||
| 49e3e0735e | |||
| 9306c12296 | |||
| e93c39f22f | 
| @ -200,7 +200,6 @@ const Dashboard = () => { | |||||||
| 
 | 
 | ||||||
|                 <div className="btn-group"> |                 <div className="btn-group"> | ||||||
|                   <button |                   <button | ||||||
|                     type="button" |  | ||||||
|                     className="btn btn-outline-primary btn-sm dropdown-toggle" |                     className="btn btn-outline-primary btn-sm dropdown-toggle" | ||||||
|                     type="button" |                     type="button" | ||||||
|                     data-bs-toggle="dropdown" |                     data-bs-toggle="dropdown" | ||||||
|  | |||||||
| @ -7,19 +7,19 @@ const EmployeeNav = ({ onPillClick, activePill }) => { | |||||||
|         <ul className="nav nav-pills flex-column flex-sm-row mb-6"> |         <ul className="nav nav-pills flex-column flex-sm-row mb-6"> | ||||||
|           <li className="nav-item"> |           <li className="nav-item"> | ||||||
|             <a |             <a | ||||||
|               className={`nav-link ${activePill === "account" ? "active" : ""}`} |               className={`nav-link py-1 px-2 small  ${activePill === "account" ? "active" : ""}`} | ||||||
|               href="#" |               href="#" | ||||||
|               onClick={(e) => { |               onClick={(e) => { | ||||||
|                 e.preventDefault(); // Prevent page reload |                 e.preventDefault(); // Prevent page reload | ||||||
|                 onPillClick("account"); |                 onPillClick("account"); | ||||||
|               }} |               }} | ||||||
|             > |             > | ||||||
|               <i className="bx bx-user bx-sm me-1_5"></i> Account |               <i className="bx bx-user bx-sm me-1_5"></i> Documents | ||||||
|             </a> |             </a> | ||||||
|           </li> |           </li> | ||||||
|           <li className="nav-item"> |           <li className="nav-item"> | ||||||
|             <a |             <a | ||||||
|               className={`nav-link ${activePill === "attendance" ? "active" : ""}`} |               className={`nav-link py-1 px-2 small ${activePill === "attendance" ? "active" : ""}`} | ||||||
|               href="#" |               href="#" | ||||||
|               onClick={(e) => { |               onClick={(e) => { | ||||||
|                 e.preventDefault(); // Prevent page reload |                 e.preventDefault(); // Prevent page reload | ||||||
| @ -31,7 +31,7 @@ const EmployeeNav = ({ onPillClick, activePill }) => { | |||||||
|           </li> |           </li> | ||||||
|           <li className="nav-item"> |           <li className="nav-item"> | ||||||
|             <a |             <a | ||||||
|               className={`nav-link ${activePill === "activities" ? "active" : ""}`} |               className={`nav-link py-1 px-2 small ${activePill === "activities" ? "active" : ""}`} | ||||||
|               href="#" |               href="#" | ||||||
|               onClick={(e) => { |               onClick={(e) => { | ||||||
|                 e.preventDefault(); // Prevent page reload |                 e.preventDefault(); // Prevent page reload | ||||||
|  | |||||||
| @ -6,9 +6,8 @@ import {changeMaster} from "../../slices/localVariablesSlice"; | |||||||
| import useMaster from "../../hooks/masterHook/useMaster"; | import useMaster from "../../hooks/masterHook/useMaster"; | ||||||
| import {useProfile} from "../../hooks/useProfile"; | import {useProfile} from "../../hooks/useProfile"; | ||||||
| import {useNavigate} from "react-router-dom"; | import {useNavigate} from "react-router-dom"; | ||||||
| 
 | import Avatar from "../../components/common/Avatar"; | ||||||
| const Header = () => | const Header = () =>{ | ||||||
| { |  | ||||||
|   const {profile} = useProfile() |   const {profile} = useProfile() | ||||||
|   const dispatch = useDispatch( changeMaster( "Job Role" ) ) |   const dispatch = useDispatch( changeMaster( "Job Role" ) ) | ||||||
|   const {data, loading} = useMaster() |   const {data, loading} = useMaster() | ||||||
| @ -88,11 +87,9 @@ const Header = () => | |||||||
|               data-bs-toggle="dropdown" |               data-bs-toggle="dropdown" | ||||||
|             > |             > | ||||||
|               <div className="avatar avatar-online"> |               <div className="avatar avatar-online"> | ||||||
|                 <img |                 <Avatar | ||||||
|                   src="../assets/img/avatars/00.jpg" |                   firstName={`${profile?.employeeInfo?.firstName}`} | ||||||
|                   className="w-px-40 h-auto rounded-circle" |                   lastName={`${profile?.employeeInfo?.lastName}`} | ||||||
|                   alt="avatar-image" |  | ||||||
|                   aria-label="Avatar Image" |  | ||||||
|                 /> |                 /> | ||||||
|               </div> |               </div> | ||||||
|             </a> |             </a> | ||||||
| @ -106,11 +103,9 @@ const Header = () => | |||||||
|                   <div className="d-flex"> |                   <div className="d-flex"> | ||||||
|                     <div className="flex-shrink-0 me-3"> |                     <div className="flex-shrink-0 me-3"> | ||||||
|                       <div className="avatar avatar-online"> |                       <div className="avatar avatar-online"> | ||||||
|                         <img |                         <Avatar | ||||||
|                           src="../assets/img/avatars/00.jpg" |                           firstName={`${profile?.employeeInfo?.firstName}`} | ||||||
|                           className="w-px-40 h-auto rounded-circle" |                           lastName={`${profile?.employeeInfo?.lastName}`} | ||||||
|                           alt="avatar-image" |  | ||||||
|                           aria-label="Avatar Image" |  | ||||||
|                         /> |                         /> | ||||||
|                       </div> |                       </div> | ||||||
|                     </div> |                     </div> | ||||||
|  | |||||||
| @ -1,6 +1,22 @@ | |||||||
| import React from "react"; | import React, { useState, useEffect } from "react"; | ||||||
|  | 
 | ||||||
|  | // A simple hash function to generate a deterministic value from the name | ||||||
|  | function hashString(str) { | ||||||
|  |   let hash = 0; | ||||||
|  |   for (let i = 0; i < str.length; i++) { | ||||||
|  |     const char = str.charCodeAt(i); | ||||||
|  |     hash = (hash << 5) - hash + char; | ||||||
|  |   } | ||||||
|  |   return hash; | ||||||
|  | } | ||||||
| 
 | 
 | ||||||
| const Avatar = ({ firstName, lastName, size='sm' }) => { | const Avatar = ({ firstName, lastName, size='sm' }) => { | ||||||
|  |   // Combine firstName and lastName to create a unique string for hashing | ||||||
|  |   const fullName = `${firstName} ${lastName}`; | ||||||
|  | 
 | ||||||
|  |   const [bgClass, setBgClass] = useState(""); | ||||||
|  | 
 | ||||||
|  |   // Function to generate the avatar text | ||||||
|   function generateAvatarText(firstName, lastName) { |   function generateAvatarText(firstName, lastName) { | ||||||
|     if (!firstName) return ""; |     if (!firstName) return ""; | ||||||
|     if (!lastName || lastName.trim() === "") { |     if (!lastName || lastName.trim() === "") { | ||||||
| @ -9,7 +25,8 @@ const Avatar = ({ firstName, lastName, size='sm' }) => { | |||||||
|     return `${firstName[0]}${lastName[0]}`.toUpperCase(); |     return `${firstName[0]}${lastName[0]}`.toUpperCase(); | ||||||
|   } |   } | ||||||
| 
 | 
 | ||||||
|   function getRandomBootstrapBgClass() { |   // Function to map the hash value to a Bootstrap background class | ||||||
|  |   function getBgClassFromHash(hash) { | ||||||
|     const bgClasses = [ |     const bgClasses = [ | ||||||
|       "bg-primary", |       "bg-primary", | ||||||
|       "bg-secondary", |       "bg-secondary", | ||||||
| @ -21,21 +38,27 @@ const Avatar = ({ firstName, lastName, size='sm' }) => { | |||||||
|       "text-light", |       "text-light", | ||||||
|     ]; |     ]; | ||||||
| 
 | 
 | ||||||
|     const randomIndex = Math.floor(Math.random() * bgClasses.length); |     // Use the hash value to pick a background color from the array | ||||||
|     return bgClasses[randomIndex]; |     const index = Math.abs(hash % bgClasses.length); | ||||||
|  |     return bgClasses[index]; | ||||||
|   } |   } | ||||||
|  | 
 | ||||||
|  |   useEffect(() => { | ||||||
|  |     // Generate the hash from the full name and map it to a background class | ||||||
|  |     const hash = hashString(fullName); | ||||||
|  |     setBgClass(getBgClassFromHash(hash)); | ||||||
|  |   }, [fullName]); // Re-run if the fullName changes | ||||||
|  | 
 | ||||||
|   return ( |   return ( | ||||||
|     <> |     <div className="avatar-wrapper p-1"> | ||||||
|       <div className="avatar-wrapper p-1"> |       <div className={`avatar avatar-${size} me-2`}> | ||||||
|         <div className={`avatar avatar-${size} me-2`}> |         <span | ||||||
|           <span |           className={`avatar-initial rounded-circle ${bgClass}`} | ||||||
|             className={`avatar-initial rounded-circle ${getRandomBootstrapBgClass()}`} |         > | ||||||
|           > |           {generateAvatarText(firstName, lastName)} | ||||||
|             {generateAvatarText(firstName, lastName)} |         </span> | ||||||
|           </span> |  | ||||||
|         </div> |  | ||||||
|       </div> |       </div> | ||||||
|     </> |     </div> | ||||||
|   ); |   ); | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -1,4 +1,4 @@ | |||||||
| import React,{useState,useEffect} from "react"; | import React, { useState, useEffect } from "react"; | ||||||
| import EmpProfile from "../../components/Employee/EmpProfile"; | import EmpProfile from "../../components/Employee/EmpProfile"; | ||||||
| import axios from "axios"; | import axios from "axios"; | ||||||
| import Breadcrumb from "../../components/common/Breadcrumb"; | import Breadcrumb from "../../components/common/Breadcrumb"; | ||||||
| @ -9,7 +9,8 @@ import { useEmployeeProfile, useEmployees, useEmployeesByProject } from "../../h | |||||||
| import { useSelector } from "react-redux"; | import { useSelector } from "react-redux"; | ||||||
| import EmployeeRepository from "../../repositories/EmployeeRepository"; | import EmployeeRepository from "../../repositories/EmployeeRepository"; | ||||||
| import { ComingSoonPage } from "../Misc/ComingSoonPage"; | import { ComingSoonPage } from "../Misc/ComingSoonPage"; | ||||||
| 
 | import { useNavigate } from "react-router-dom"; | ||||||
|  | import Avatar from "../../components/common/Avatar"; | ||||||
| const EmployeeProfile = () => { | const EmployeeProfile = () => { | ||||||
|   |   | ||||||
|   const projectID = useSelector((store)=>store.localVariables.projectId) |   const projectID = useSelector((store)=>store.localVariables.projectId) | ||||||
| @ -50,7 +51,7 @@ const EmployeeProfile = () => { | |||||||
|     } |     } | ||||||
|   }, [employeeId]); |   }, [employeeId]); | ||||||
| 
 | 
 | ||||||
| 
 |   const navigate = useNavigate(); | ||||||
|   const renderContent = () => { |   const renderContent = () => { | ||||||
|     if (loading) return <div>Loading</div>; |     if (loading) return <div>Loading</div>; | ||||||
|     switch (activePill) { |     switch (activePill) { | ||||||
| @ -102,74 +103,81 @@ const EmployeeProfile = () => { | |||||||
|         ]} |         ]} | ||||||
|       ></Breadcrumb> |       ></Breadcrumb> | ||||||
| 
 | 
 | ||||||
|    <div className="row"> |       <div className="row"> | ||||||
|       <div className="col-12 col-md-8 col-lg-4 order-1 order-lg-1"> |         <div className="col-12 col-md-8 col-lg-4 order-1 order-lg-1"> | ||||||
|         <div className="row"> |           <div className="row"> | ||||||
|           <div className="col-12 mb-4"> |             <div className="col-12 mb-4"> | ||||||
|             <div className="card"> |               <div className="card"> | ||||||
|               <div className="card-body"> |                 <div className="card-body"> | ||||||
|                 <div className="d-flex flex-row flex-lg-column"> |                   <div className="d-flex flex-row flex-lg-column"> | ||||||
|                   <div className="d-flex flex-column justify-content-center align-items-center text-center"> |                     <div className="d-flex flex-column justify-content-center align-items-center text-center"> | ||||||
|                     <img |                       <Avatar | ||||||
|                       src={`../../../public/img/avatars/${currentEmployee.gender}.jpg`} |                         firstName={`${currentEmployee?.firstName}`} | ||||||
|                       alt="user-avatar" |                         lastName={`${currentEmployee?.lastName}`} | ||||||
|                       className="d-block rounded" |                         size={"lg"} | ||||||
|                       height="100" |                       /> | ||||||
|                       width="100" |                       <div className="py-2"> | ||||||
|                       aria-label="Account image" |                         <p className="h6">{`${currentEmployee?.firstName} ${currentEmployee?.lastName}`}</p> | ||||||
|                       id="uploadedAvatar" |                       </div> | ||||||
|                     /> |  | ||||||
|                     <div className="py-2"> |  | ||||||
|                       <p className="h6">{`${currentEmployee?.firstName} ${currentEmployee?.lastName}`}</p> |  | ||||||
|                     </div> |                     </div> | ||||||
|                     <hr className="my-2" /> |                     <div className="w-100 d-flex flex-column justify-content-start"> | ||||||
|                   </div> |                       <div className="mt-3 w-100"> | ||||||
|                   <div className="w-100 d-flex flex-row flex-sm-column justify-content-sm-start justify-content-around"> |                         <h6 className="mb-2 text-muted text-start">Employee Info</h6> | ||||||
|                     <div className="text-wrap"> |                         <table className="table table-borderless mb-3"> | ||||||
|                       <small className="card-text text-uppercase text-muted small">Contacts</small> |                           <tbody> | ||||||
|                       <ul className="list-unstyled my-3 py-1"> |                             <tr> | ||||||
|                         |                               <td className="fw-medium text-start">Email:</td> | ||||||
|                         <li className="d-flex align-items-center mb-4"> |                               <td className="text-start">{currentEmployee?.email || <em>NA</em>}</td> | ||||||
|                           <i className="bx bx-phone"></i> |                             </tr> | ||||||
|                           <span className="fw-medium mx-2">Contact Number:</span> |                             <tr> | ||||||
|                           <span className={`${currentEmployee?.emergencyPhoneNumber ? "" : "text-muted"}`}> |                               <td className="fw-medium text-start">Phone Number:</td> | ||||||
|                             {currentEmployee?.emergencyPhoneNumber || <em>NA</em>} |                               <td className="text-start">{currentEmployee?.phoneNumber || <em>NA</em>}</td> | ||||||
|                           </span> |                             </tr> | ||||||
|                         </li> |                             <tr> | ||||||
|                         <li className="d-flex align-items-center mb-4 text-start"> |                               <td className="fw-medium text-start">Emergency Contact Person:</td> | ||||||
|                           <i className="bx bx-envelope"></i> |                               <td className="text-start">{currentEmployee?.emergencyContactPerson || <em>NA</em>}</td> | ||||||
|                           <span className="fw-medium mx-2">Email:</span> |                             </tr> | ||||||
|                           <span className={`text-break text-wrap ${currentEmployee?.email ? "" : "text-muted"}`}> |                             <tr> | ||||||
|                             {currentEmployee?.email || <em className="muted">NA</em>} |                               <td className="fw-medium text-start">Emergency Contact Number:</td> | ||||||
|                           </span> |                               <td className="text-start">{currentEmployee?.emergencyPhoneNumber || <em>NA</em>}</td> | ||||||
|                           </li> |                             </tr> | ||||||
|                           <li className="d-flex align-items-center mb-4"> | 
 | ||||||
|                           <i className="bx bx-user"></i> |                             <tr> | ||||||
|                           <span className="fw-medium mx-2">Contact Person:</span> |                               <td className="fw-medium text-start">Gender:</td> | ||||||
|                           <span className=""> |                               <td className="text-start">{currentEmployee?.gender || <em>NA</em>}</td> | ||||||
|                             {currentEmployee?.emergencyContactPerson} |                             </tr> | ||||||
|                           </span> |                             <tr> | ||||||
|                         </li> |                               <td className="fw-medium text-start">Birth Date:</td> | ||||||
|                         <li className="d-flex align-items-center  text-wrap "> |                               <td className="text-start">{currentEmployee?.birthDate ? new Date(currentEmployee.birthDate).toLocaleDateString() : <em>NA</em>}</td> | ||||||
|                         <i className="bx bx-flag"></i> |                             </tr> | ||||||
|                          <span className="fw-medium mx-2">Address:</span> | 
 | ||||||
|                           | 
 | ||||||
|                         </li> |                             <tr> | ||||||
|                         <li className="d-flex align-items-start test-start mb-2"> |                               <td className="fw-medium text-start">Joining Date:</td> | ||||||
|                           <span className={`${currentEmployee?.permanentAddress ? "" : "ms-4"}`}> |                               <td className="text-start">{currentEmployee?.joiningDate ? new Date(currentEmployee.joiningDate).toLocaleDateString() : <em>NA</em>}</td> | ||||||
|                           {currentEmployee?.permanentAddress} |                             </tr> | ||||||
|                           </span> |                             <tr> | ||||||
|                         </li> |                               <td className="fw-medium text-start">Job Role:</td> | ||||||
|                         |                               <td className="text-start">{currentEmployee?.jobRole || <em>NA</em>}</td> | ||||||
|                       </ul> |                             </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> | ||||||
|             </div> |             </div> | ||||||
|           </div> |           </div> | ||||||
|         </div> |         </div> | ||||||
|       </div> |  | ||||||
| 
 | 
 | ||||||
|       <div className="col-12 col-lg-8 order-2 order-lg-2 mb-4"> |       <div className="col-12 col-lg-8 order-2 order-lg-2 mb-4"> | ||||||
|         <div className="row"> |         <div className="row"> | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user