"Action" Buttons Should Not Be Visible to Users Without Required Rights in Teams Pages #203
| @ -25,14 +25,14 @@ const Teams = ({ project }) => { | |||||||
|   const [filteredEmployees, setFilteredEmployees] = useState([]); |   const [filteredEmployees, setFilteredEmployees] = useState([]); | ||||||
|   const [removingEmployeeId, setRemovingEmployeeId] = useState(null); |   const [removingEmployeeId, setRemovingEmployeeId] = useState(null); | ||||||
|   const [assignedLoading, setAssignedLoading] = useState(false); |   const [assignedLoading, setAssignedLoading] = useState(false); | ||||||
|   const [ employeeLodaing, setEmployeeLoading ] = useState( false ); |   const [employeeLodaing, setEmployeeLoading] = useState(false); | ||||||
|   const [ activeEmployee, setActiveEmployee ] = useState( true ) |   const [activeEmployee, setActiveEmployee] = useState(true) | ||||||
|   const [deleteEmployee,setDeleteEmplyee] = useState(null) |   const [deleteEmployee, setDeleteEmplyee] = useState(null) | ||||||
| 
 | 
 | ||||||
|   const navigate = useNavigate(); |   const navigate = useNavigate(); | ||||||
| 
 | 
 | ||||||
|   const HasAssignUserPermission = useHasUserPermission( ASSIGN_TO_PROJECT ); |   const HasAssignUserPermission = useHasUserPermission(ASSIGN_TO_PROJECT); | ||||||
|   const[IsDeleteModal,setIsDeleteModal] = useState(false) |   const [IsDeleteModal, setIsDeleteModal] = useState(false) | ||||||
| 
 | 
 | ||||||
|   const fetchEmployees = async () => { |   const fetchEmployees = async () => { | ||||||
|     try { |     try { | ||||||
| @ -42,7 +42,7 @@ const Teams = ({ project }) => { | |||||||
|       ProjectRepository.getProjectAllocation(project.id) |       ProjectRepository.getProjectAllocation(project.id) | ||||||
|         .then((response) => { |         .then((response) => { | ||||||
|           setEmployees(response.data); |           setEmployees(response.data); | ||||||
|           setFilteredEmployees( response.data.filter( ( emp ) => emp.isActive ) ); |           setFilteredEmployees(response.data.filter((emp) => emp.isActive)); | ||||||
|           setEmployeeLoading(false); |           setEmployeeLoading(false); | ||||||
|         }) |         }) | ||||||
|         .catch((error) => { |         .catch((error) => { | ||||||
| @ -54,24 +54,23 @@ const Teams = ({ project }) => { | |||||||
|     } |     } | ||||||
|   }; |   }; | ||||||
| 
 | 
 | ||||||
|   const submitAllocations = (items,added) => { |   const submitAllocations = (items, added) => { | ||||||
|     ProjectRepository.manageProjectAllocation(items) |     ProjectRepository.manageProjectAllocation(items) | ||||||
|       .then((response) => { |       .then((response) => { | ||||||
|         fetchEmployees(); |         fetchEmployees(); | ||||||
|         if ( added ) |         if (added) { | ||||||
|         { |  | ||||||
|           showToast("Employee Assigned Successfully", "success"); |           showToast("Employee Assigned Successfully", "success"); | ||||||
|         }else{ |         } else { | ||||||
|           showToast("Removed Employee Successfully", "success"); |           showToast("Removed Employee Successfully", "success"); | ||||||
|         } |         } | ||||||
|         setRemovingEmployeeId(null); |         setRemovingEmployeeId(null); | ||||||
|         setAssignedLoading( false ); |         setAssignedLoading(false); | ||||||
|         setDeleteEmplyee( null ) |         setDeleteEmplyee(null) | ||||||
|         closeDeleteModal() |         closeDeleteModal() | ||||||
|       }) |       }) | ||||||
|       .catch((error) => { |       .catch((error) => { | ||||||
|         const message = error.response.data.message || error.message || "Error Occured during Api Call"; |         const message = error.response.data.message || error.message || "Error Occured during Api Call"; | ||||||
|         showToast( message, "error" ); |         showToast(message, "error"); | ||||||
|         closeDeleteModal() |         closeDeleteModal() | ||||||
|       }); |       }); | ||||||
|   }; |   }; | ||||||
| @ -85,30 +84,30 @@ const Teams = ({ project }) => { | |||||||
|         projectId: project.id, |         projectId: project.id, | ||||||
|         status: false, |         status: false, | ||||||
|       }, |       }, | ||||||
|     ] ,false); |     ], false); | ||||||
| 
 | 
 | ||||||
|   }; |   }; | ||||||
| 
 | 
 | ||||||
|   const handleEmpAlicationFormSubmit = (allocaionObj) => { |   const handleEmpAlicationFormSubmit = (allocaionObj) => { | ||||||
|   let items = allocaionObj.map((item) => { |     let items = allocaionObj.map((item) => { | ||||||
|     return { |       return { | ||||||
|       empID: item.empID, |         empID: item.empID, | ||||||
|       jobRoleId: item.jobRoleId, |         jobRoleId: item.jobRoleId, | ||||||
|       projectId: project.id, |         projectId: project.id, | ||||||
|       status: true, |         status: true, | ||||||
|     }; |       }; | ||||||
|   }); |     }); | ||||||
| 
 | 
 | ||||||
|   submitAllocations(items, true); |     submitAllocations(items, true); | ||||||
| 
 | 
 | ||||||
|   // Force switch to active view after assignment |     // Force switch to active view after assignment | ||||||
|   setActiveEmployee(true); |     setActiveEmployee(true); | ||||||
|   setFilteredEmployees(employees.filter((emp) => emp.isActive)); |     setFilteredEmployees(employees.filter((emp) => emp.isActive)); | ||||||
| 
 | 
 | ||||||
|   // Also update dropdown select if needed |     // Also update dropdown select if needed | ||||||
|   const dropdown = document.querySelector('select[name="DataTables_Table_0_length"]'); |     const dropdown = document.querySelector('select[name="DataTables_Table_0_length"]'); | ||||||
|   if (dropdown) dropdown.value = "true"; |     if (dropdown) dropdown.value = "true"; | ||||||
| }; |   }; | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
|   const getRole = (jobRoleId) => { |   const getRole = (jobRoleId) => { | ||||||
| @ -140,8 +139,8 @@ const Teams = ({ project }) => { | |||||||
|   }; |   }; | ||||||
| 
 | 
 | ||||||
|   useEffect(() => { |   useEffect(() => { | ||||||
|   dispatch(changeMaster("Job Role")); |     dispatch(changeMaster("Job Role")); | ||||||
| }, [dispatch]); |   }, [dispatch]); | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
|   useEffect(() => { |   useEffect(() => { | ||||||
| @ -156,22 +155,20 @@ const Teams = ({ project }) => { | |||||||
| 
 | 
 | ||||||
|   const handleFilterEmployee = (e) => { |   const handleFilterEmployee = (e) => { | ||||||
|     const filterValue = e.target.value; |     const filterValue = e.target.value; | ||||||
|     if ( filterValue === "true" ) |     if (filterValue === "true") { | ||||||
|     { |  | ||||||
|       setActiveEmployee(true) |       setActiveEmployee(true) | ||||||
|       setFilteredEmployees(employees.filter((emp) => emp.isActive)); |       setFilteredEmployees(employees.filter((emp) => emp.isActive)); | ||||||
|     } else { |     } else { | ||||||
|       setFilteredEmployees( employees.filter( ( emp ) => !emp.isActive ) ); |       setFilteredEmployees(employees.filter((emp) => !emp.isActive)); | ||||||
|       setActiveEmployee(false) |       setActiveEmployee(false) | ||||||
|     } |     } | ||||||
|   }; |   }; | ||||||
| 
 | 
 | ||||||
|   const deleteModalOpen = (item) => |   const deleteModalOpen = (item) => { | ||||||
|   { |  | ||||||
|     setDeleteEmplyee(item) |     setDeleteEmplyee(item) | ||||||
|     setIsDeleteModal(true) |     setIsDeleteModal(true) | ||||||
|   } |   } | ||||||
|   const closeDeleteModal = ()=> setIsDeleteModal(false) |   const closeDeleteModal = () => setIsDeleteModal(false) | ||||||
| 
 | 
 | ||||||
|   return ( |   return ( | ||||||
|     <> |     <> | ||||||
| @ -194,7 +191,7 @@ const Teams = ({ project }) => { | |||||||
|       </div> |       </div> | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
|        {IsDeleteModal && ( |       {IsDeleteModal && ( | ||||||
|         <div |         <div | ||||||
|           className={`modal fade  ${IsDeleteModal ? "show" : ""}`} |           className={`modal fade  ${IsDeleteModal ? "show" : ""}`} | ||||||
|           tabIndex="-1" |           tabIndex="-1" | ||||||
| @ -243,9 +240,8 @@ const Teams = ({ project }) => { | |||||||
|               </div> |               </div> | ||||||
|               <button |               <button | ||||||
|                 type="button" |                 type="button" | ||||||
|                 className={`link-button btn-sm m-1 ${ |                 className={`link-button btn-sm m-1 ${HasAssignUserPermission ? "" : "d-none" | ||||||
|                   HasAssignUserPermission ? "" : "d-none" |                   }`} | ||||||
|                 }`} |  | ||||||
|                 data-bs-toggle="modal" |                 data-bs-toggle="modal" | ||||||
|                 data-bs-target="#user-model" |                 data-bs-target="#user-model" | ||||||
|               > |               > | ||||||
| @ -262,9 +258,10 @@ const Teams = ({ project }) => { | |||||||
|                   <tr> |                   <tr> | ||||||
|                     <th>Name</th> |                     <th>Name</th> | ||||||
|                     <th>Assigned Date</th> |                     <th>Assigned Date</th> | ||||||
|                {!activeEmployee && <th>Release Date</th>} |                     {!activeEmployee && <th>Release Date</th>} | ||||||
|                     <th>Project Role</th> |                     <th>Project Role</th> | ||||||
|                     <th>Actions</th> |                     {/* <th>Actions</th> */} | ||||||
|  |                     {HasAssignUserPermission && <th>Actions</th>} | ||||||
|                   </tr> |                   </tr> | ||||||
|                 </thead> |                 </thead> | ||||||
|                 <tbody className="table-border-bottom-0"> |                 <tbody className="table-border-bottom-0"> | ||||||
| @ -301,8 +298,8 @@ const Teams = ({ project }) => { | |||||||
|                         {!activeEmployee && <td> |                         {!activeEmployee && <td> | ||||||
|                           {item.reAllocationDate |                           {item.reAllocationDate | ||||||
|                             ? moment(item.reAllocationDate).format( |                             ? moment(item.reAllocationDate).format( | ||||||
|                                 "DD-MMM-YYYY" |                               "DD-MMM-YYYY" | ||||||
|                               ) |                             ) | ||||||
|                             : "Present"} |                             : "Present"} | ||||||
|                         </td>} |                         </td>} | ||||||
|                         <td> |                         <td> | ||||||
| @ -311,7 +308,7 @@ const Teams = ({ project }) => { | |||||||
|                           </span> |                           </span> | ||||||
|                         </td> |                         </td> | ||||||
|                         <td> |                         <td> | ||||||
|                           {item.isActive && ( |                           {item.isActive && HasAssignUserPermission && ( | ||||||
|                             <button |                             <button | ||||||
|                               aria-label="Delete" |                               aria-label="Delete" | ||||||
|                               type="button" |                               type="button" | ||||||
| @ -319,15 +316,12 @@ const Teams = ({ project }) => { | |||||||
|                               className="btn p-0 dropdown-toggle hide-arrow" |                               className="btn p-0 dropdown-toggle hide-arrow" | ||||||
|                               onClick={() => deleteModalOpen(item)} |                               onClick={() => deleteModalOpen(item)} | ||||||
|                             > |                             > | ||||||
|                               {" "} |  | ||||||
|                               {removingEmployeeId === item.id ? ( |                               {removingEmployeeId === item.id ? ( | ||||||
|                                 <div |                                 <div | ||||||
|                                   class="spinner-border spinner-border-sm text-primary" |                                   className="spinner-border spinner-border-sm text-primary" | ||||||
|                                   role="status" |                                   role="status" | ||||||
|                                 > |                                 > | ||||||
|                                   <span class="visually-hidden"> |                                   <span className="visually-hidden">Loading...</span> | ||||||
|                                     Loading... |  | ||||||
|                                   </span> |  | ||||||
|                                 </div> |                                 </div> | ||||||
|                               ) : ( |                               ) : ( | ||||||
|                                 <i className="bx bx-trash me-1 text-danger"></i> |                                 <i className="bx bx-trash me-1 text-danger"></i> | ||||||
| @ -336,6 +330,7 @@ const Teams = ({ project }) => { | |||||||
|                           )} |                           )} | ||||||
|                           {!item.isActive && <span>Not in project</span>} |                           {!item.isActive && <span>Not in project</span>} | ||||||
|                         </td> |                         </td> | ||||||
|  | 
 | ||||||
|                       </tr> |                       </tr> | ||||||
|                     ))} |                     ))} | ||||||
|                 </tbody> |                 </tbody> | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user