Change the UI of all components and add stars for all mandatory fields. #370
| @ -99,15 +99,16 @@ const CheckCheckOutmodel = ({ modeldata, closeModal, handleSubmitForm }) => { | |||||||
| 
 | 
 | ||||||
|   return ( |   return ( | ||||||
|     <form className="row g-2" onSubmit={handleSubmit(onSubmit)}> |     <form className="row g-2" onSubmit={handleSubmit(onSubmit)}> | ||||||
|       <div className="col-12 col-md-12"> |       <div className="col-12 d-flex justify-content-center"> | ||||||
|         <label className="fs-5 text-dark text-center d-flex align-items-center flex-wrap"> |         <label className="fs-5 text-dark text-center"> | ||||||
|           {modeldata?.checkInTime && !modeldata?.checkOutTime |           {modeldata?.checkInTime && !modeldata?.checkOutTime | ||||||
|             ? "Check-out :" |             ? "Check-out :" | ||||||
|             : "Check-in :"} |             : "Check-in :"} | ||||||
|         </label> |         </label> | ||||||
|       </div> |       </div> | ||||||
| 
 | 
 | ||||||
|       <div className="col-6 col-md-6 "> | 
 | ||||||
|  |       <div className="col-6 col-md-6 text-start"> | ||||||
|         <label className="form-label" htmlFor="checkInDate"> |         <label className="form-label" htmlFor="checkInDate"> | ||||||
|           {modeldata?.checkInTime && !modeldata?.checkOutTime |           {modeldata?.checkInTime && !modeldata?.checkOutTime | ||||||
|             ? "Check-out Date" |             ? "Check-out Date" | ||||||
| @ -126,7 +127,7 @@ const CheckCheckOutmodel = ({ modeldata, closeModal, handleSubmitForm }) => { | |||||||
|         /> |         /> | ||||||
|       </div> |       </div> | ||||||
| 
 | 
 | ||||||
|       <div className="col-6 col-md-6"> |       <div className="col-6 col-md-6 text-start"> | ||||||
|         <TimePicker |         <TimePicker | ||||||
|           label="Choose a time" |           label="Choose a time" | ||||||
|           onChange={(e) => setValue("markTime", e)} |           onChange={(e) => setValue("markTime", e)} | ||||||
| @ -139,7 +140,7 @@ const CheckCheckOutmodel = ({ modeldata, closeModal, handleSubmitForm }) => { | |||||||
|         )} |         )} | ||||||
|       </div> |       </div> | ||||||
| 
 | 
 | ||||||
|       <div className="col-12 col-md-12"> |       <div className="col-12 col-md-12 text-start"> | ||||||
|         <label className="form-label" htmlFor="description"> |         <label className="form-label" htmlFor="description"> | ||||||
|           Description |           Description | ||||||
|         </label> |         </label> | ||||||
| @ -155,19 +156,19 @@ const CheckCheckOutmodel = ({ modeldata, closeModal, handleSubmitForm }) => { | |||||||
|         )} |         )} | ||||||
|       </div> |       </div> | ||||||
| 
 | 
 | ||||||
|       <div className="col-12 text-center"> |       <div className="col-12 text-end mt-4"> | ||||||
|         <button type="submit" className="btn btn-sm btn-primary me-3"> |  | ||||||
|           {isLoading ? "Please Wait..." : "Submit"} |  | ||||||
|         </button> |  | ||||||
|         <button |         <button | ||||||
|           type="reset" |           type="reset" | ||||||
|           className="btn btn-sm btn-label-secondary" |           className="btn btn-sm btn-label-secondary me-2" | ||||||
|           data-bs-dismiss="modal" |           data-bs-dismiss="modal" | ||||||
|           aria-label="Close" |           aria-label="Close" | ||||||
|           onClick={() => closeModal()} |           onClick={() => closeModal()} | ||||||
|         > |         > | ||||||
|           Cancel |           Cancel | ||||||
|         </button> |         </button> | ||||||
|  |         <button type="submit" className="btn btn-sm btn-primary"> | ||||||
|  |           {isLoading ? "Please Wait..." : "Submit"} | ||||||
|  |         </button> | ||||||
|       </div> |       </div> | ||||||
|     </form> |     </form> | ||||||
|   ); |   ); | ||||||
|  | |||||||
| @ -185,21 +185,22 @@ export const ReportTask = ({ report, closeModal }) => { | |||||||
|             )} |             )} | ||||||
|           </div> |           </div> | ||||||
|         </div> |         </div> | ||||||
|         <div className="col-12 text-center my-2"> |         <div className="col-12 text-end my-2 mt-4"> | ||||||
|           <button type="submit" className="btn btn-sm btn-primary me-3" disabled={isPending}> |  | ||||||
|             {isPending ? "Please wait" : "Submit Report"} |  | ||||||
|           </button> |  | ||||||
|           <button |           <button | ||||||
|             type="button" |             type="button" | ||||||
|             className="btn btn-sm btn-label-secondary" |             className="btn btn-sm btn-label-secondary me-3" | ||||||
|             onClick={handleClose} |             onClick={handleClose} | ||||||
|             disabled={isPending} |             disabled={isPending} | ||||||
|           > |           > | ||||||
|             Cancel |             Cancel | ||||||
|           </button> |           </button> | ||||||
|  |           <button type="submit" className="btn btn-sm btn-primary" disabled={isPending}> | ||||||
|  |             {isPending ? "Please wait" : "Submit Report"} | ||||||
|  |           </button> | ||||||
|  | 
 | ||||||
|         </div> |         </div> | ||||||
|       </form> |       </form> | ||||||
|     </div> |     </div> | ||||||
|   ); |   ); | ||||||
| }; | }; | ||||||
|  export default ReportTask; | export default ReportTask; | ||||||
| @ -10,6 +10,7 @@ import { getBgClassFromHash } from "../../utils/projectStatus"; | |||||||
| import { cacheData, getCachedData } from "../../slices/apiDataManager"; | import { cacheData, getCachedData } from "../../slices/apiDataManager"; | ||||||
| import ImagePreview from "../common/ImagePreview"; | import ImagePreview from "../common/ImagePreview"; | ||||||
| import { useAuditStatus, useSubmitTaskComment } from "../../hooks/useTasks"; | import { useAuditStatus, useSubmitTaskComment } from "../../hooks/useTasks"; | ||||||
|  | import Label from "../common/Label"; | ||||||
| 
 | 
 | ||||||
| const ReportTaskComments = ({ | const ReportTaskComments = ({ | ||||||
|   commentsData, |   commentsData, | ||||||
| @ -291,10 +292,10 @@ const ReportTaskComments = ({ | |||||||
|                     </p> |                     </p> | ||||||
|                   )} |                   )} | ||||||
|                 </div> |                 </div> | ||||||
|                 <div className="col-6 col-sm-4 text-center align-items-end m-0"> |                 <div className="col-6 col-sm-4 text-start align-items-end m-0"> | ||||||
|                   <label htmlFor="workStatus" className="form-label"> |                   <Label htmlFor="workStatus" className="form-label" required> | ||||||
|                     Audit Status |                     Audit Status | ||||||
|                   </label> |                   </Label> | ||||||
|                   <select |                   <select | ||||||
|                     id="workStatus" |                     id="workStatus" | ||||||
|                     className={`form-select form-select-sm`} |                     className={`form-select form-select-sm`} | ||||||
| @ -361,7 +362,7 @@ const ReportTaskComments = ({ | |||||||
|             <span> |             <span> | ||||||
|               <button |               <button | ||||||
|                 type="button" |                 type="button" | ||||||
|                 className="btn btn-sm btn-secondary" |                 className="btn btn-sm btn-label-secondary mt-5" | ||||||
|                 onClick={closeModal} |                 onClick={closeModal} | ||||||
|                 data-bs-dismiss="modal" |                 data-bs-dismiss="modal" | ||||||
|                 disabled={isPending} |                 disabled={isPending} | ||||||
| @ -370,7 +371,7 @@ const ReportTaskComments = ({ | |||||||
|               </button> |               </button> | ||||||
|               <button |               <button | ||||||
|                 type="submit" |                 type="submit" | ||||||
|                 className="btn btn-sm btn-primary ms-2" |                 className="btn btn-sm btn-primary ms-2 mt-5" | ||||||
|                 disabled={isPending} |                 disabled={isPending} | ||||||
|               > |               > | ||||||
|                 {isPending |                 {isPending | ||||||
|  | |||||||
| @ -23,6 +23,7 @@ import { useProjects } from "../../hooks/useProjects"; | |||||||
| import SelectMultiple from "../common/SelectMultiple"; | import SelectMultiple from "../common/SelectMultiple"; | ||||||
| import { ContactSchema } from "./DirectorySchema"; | import { ContactSchema } from "./DirectorySchema"; | ||||||
| import InputSuggestions from "../common/InputSuggestion"; | import InputSuggestions from "../common/InputSuggestion"; | ||||||
|  | import Label from "../common/Label"; | ||||||
| 
 | 
 | ||||||
| const ManageDirectory = ({ submitContact, onCLosed }) => { | const ManageDirectory = ({ submitContact, onCLosed }) => { | ||||||
|   const selectedMaster = useSelector( |   const selectedMaster = useSelector( | ||||||
| @ -171,11 +172,11 @@ const ManageDirectory = ({ submitContact, onCLosed }) => { | |||||||
|     <FormProvider {...methods}> |     <FormProvider {...methods}> | ||||||
|       <form className="p-2 p-sm-0" onSubmit={handleSubmit(onSubmit)}> |       <form className="p-2 p-sm-0" onSubmit={handleSubmit(onSubmit)}> | ||||||
|         <div className="d-flex justify-content-center align-items-center"> |         <div className="d-flex justify-content-center align-items-center"> | ||||||
|           <h6 className="m-0 fw-18"> Create New Contact</h6> |           <h5 className="m-0 fw-18"> Create New Contact</h5> | ||||||
|         </div> |         </div> | ||||||
|         <div className="row"> |         <div className="row"> | ||||||
|           <div className="col-md-6  text-start"> |           <div className="col-md-6  text-start"> | ||||||
|             <label className="form-label">Name</label> |             <Label className="form-label" required>Name</Label> | ||||||
|             <input |             <input | ||||||
|               className="form-control form-control-sm" |               className="form-control form-control-sm" | ||||||
|               {...register("name")} |               {...register("name")} | ||||||
| @ -186,7 +187,7 @@ const ManageDirectory = ({ submitContact, onCLosed }) => { | |||||||
|           </div> |           </div> | ||||||
| 
 | 
 | ||||||
|           <div className="col-md-6  text-start"> |           <div className="col-md-6  text-start"> | ||||||
|             <label className="form-label">Organization</label> |             <Label className="form-label" required>Organization</Label> | ||||||
|             <InputSuggestions |             <InputSuggestions | ||||||
|               organizationList={organizationList} |               organizationList={organizationList} | ||||||
|               value={getValues("organization") || ""} |               value={getValues("organization") || ""} | ||||||
| @ -197,7 +198,7 @@ const ManageDirectory = ({ submitContact, onCLosed }) => { | |||||||
|         </div> |         </div> | ||||||
|         <div className="row mt-1"> |         <div className="row mt-1"> | ||||||
|           <div className="col-md-6  text-start"> |           <div className="col-md-6  text-start"> | ||||||
|             <label className="form-label">Designation</label> |             <Label className="form-label" required>Designation</Label> | ||||||
|             <input |             <input | ||||||
|               className="form-control form-control-sm" |               className="form-control form-control-sm" | ||||||
|               {...register("designation")} |               {...register("designation")} | ||||||
| @ -431,7 +432,7 @@ const ManageDirectory = ({ submitContact, onCLosed }) => { | |||||||
|         </div> |         </div> | ||||||
|         <div className="row"> |         <div className="row"> | ||||||
|           <div className="col-md-12 mt-1 text-start"> |           <div className="col-md-12 mt-1 text-start"> | ||||||
|             <label className="form-label ">Select Bucket</label> |             <Label className="form-label" required>Select Bucket</Label> | ||||||
| 
 | 
 | ||||||
|             <ul className="d-flex flex-wrap px-1 list-unstyled  mb-0"> |             <ul className="d-flex flex-wrap px-1 list-unstyled  mb-0"> | ||||||
|               {bucketsLoaging && <p>Loading...</p>} |               {bucketsLoaging && <p>Loading...</p>} | ||||||
| @ -475,8 +476,8 @@ const ManageDirectory = ({ submitContact, onCLosed }) => { | |||||||
|           /> |           /> | ||||||
|         </div> |         </div> | ||||||
| 
 | 
 | ||||||
|         <div className="col-12 text-start"> |         <div className="col-12 text-start mt-1"> | ||||||
|           <label className="form-label">Description</label> |           <Label className="form-label" required>Description</Label> | ||||||
|           <textarea |           <textarea | ||||||
|             className="form-control form-control-sm" |             className="form-control form-control-sm" | ||||||
|             rows="2" |             rows="2" | ||||||
| @ -487,10 +488,7 @@ const ManageDirectory = ({ submitContact, onCLosed }) => { | |||||||
|           )} |           )} | ||||||
|         </div> |         </div> | ||||||
| 
 | 
 | ||||||
|         <div className="d-flex justify-content-center gap-1 py-2"> |         <div className="d-flex justify-content-end gap-2 py-2 mt-3"> | ||||||
|           <button className="btn btn-sm btn-primary" type="submit"> |  | ||||||
|             {IsSubmitting ? "Please Wait..." : "Submit"} |  | ||||||
|           </button> |  | ||||||
|           <button |           <button | ||||||
|             className="btn btn-sm btn-secondary" |             className="btn btn-sm btn-secondary" | ||||||
|             type="button" |             type="button" | ||||||
| @ -498,6 +496,10 @@ const ManageDirectory = ({ submitContact, onCLosed }) => { | |||||||
|           > |           > | ||||||
|             Cancel |             Cancel | ||||||
|           </button> |           </button> | ||||||
|  |           <button className="btn btn-sm btn-primary" type="submit"> | ||||||
|  |             {IsSubmitting ? "Please Wait..." : "Submit"} | ||||||
|  |           </button> | ||||||
|  |            | ||||||
|         </div> |         </div> | ||||||
|       </form> |       </form> | ||||||
|     </FormProvider> |     </FormProvider> | ||||||
|  | |||||||
| @ -23,6 +23,7 @@ import { useProjects } from "../../hooks/useProjects"; | |||||||
| import SelectMultiple from "../common/SelectMultiple"; | import SelectMultiple from "../common/SelectMultiple"; | ||||||
| import { ContactSchema } from "./DirectorySchema"; | import { ContactSchema } from "./DirectorySchema"; | ||||||
| import InputSuggestions from "../common/InputSuggestion"; | import InputSuggestions from "../common/InputSuggestion"; | ||||||
|  | import Label from "../common/Label"; | ||||||
| 
 | 
 | ||||||
| const UpdateContact = ({ submitContact, existingContact, onCLosed }) => { | const UpdateContact = ({ submitContact, existingContact, onCLosed }) => { | ||||||
|   const selectedMaster = useSelector( |   const selectedMaster = useSelector( | ||||||
| @ -208,7 +209,7 @@ const UpdateContact = ({ submitContact, existingContact, onCLosed }) => { | |||||||
|     <FormProvider {...methods}> |     <FormProvider {...methods}> | ||||||
|       <form className="p-2 p-sm-0" onSubmit={handleSubmit(onSubmit)}> |       <form className="p-2 p-sm-0" onSubmit={handleSubmit(onSubmit)}> | ||||||
|         <div className="d-flex justify-content-center align-items-center"> |         <div className="d-flex justify-content-center align-items-center"> | ||||||
|           <h6 className="m-0 fw-18"> Update Contact</h6> |           <h5 className="m-0 fw-18"> Update Contact</h5> | ||||||
|         </div> |         </div> | ||||||
|         <div className="row"> |         <div className="row"> | ||||||
|           <div className="col-md-6  text-start"> |           <div className="col-md-6  text-start"> | ||||||
| @ -239,7 +240,7 @@ const UpdateContact = ({ submitContact, existingContact, onCLosed }) => { | |||||||
|         </div> |         </div> | ||||||
|         <div className="row mt-1"> |         <div className="row mt-1"> | ||||||
|           <div className="col-md-6  text-start"> |           <div className="col-md-6  text-start"> | ||||||
|             <label className="form-label">Designation</label> |             <Label className="form-label" required>Designation</Label> | ||||||
|             <input |             <input | ||||||
|               className="form-control form-control-sm" |               className="form-control form-control-sm" | ||||||
|               {...register("designation")} |               {...register("designation")} | ||||||
| @ -529,22 +530,22 @@ const UpdateContact = ({ submitContact, existingContact, onCLosed }) => { | |||||||
|           )} |           )} | ||||||
|         </div> |         </div> | ||||||
| 
 | 
 | ||||||
|         <div className="d-flex justify-content-center gap-1 py-2"> |         <div className="d-flex justify-content-end gap-2 py-0 mt-4">          | ||||||
|           <button |           <button | ||||||
|             className="btn btn-sm btn-primary" |             className="btn btn-sm btn-label-secondary" | ||||||
|             type="submit" |  | ||||||
|             disabled={IsSubmitting} |  | ||||||
|           > |  | ||||||
|             {IsSubmitting ? "Please Wait..." : "Update"} |  | ||||||
|           </button> |  | ||||||
|           <button |  | ||||||
|             className="btn btn-sm btn-secondary" |  | ||||||
|             type="button" |             type="button" | ||||||
|             onClick={handleClosed} |             onClick={handleClosed} | ||||||
|             disabled={IsSubmitting} |             disabled={IsSubmitting} | ||||||
|           > |           > | ||||||
|             Cancel |             Cancel | ||||||
|           </button> |           </button> | ||||||
|  |            <button | ||||||
|  |             className="btn btn-sm btn-primary" | ||||||
|  |             type="submit" | ||||||
|  |             disabled={IsSubmitting} | ||||||
|  |           > | ||||||
|  |             {IsSubmitting ? "Please Wait..." : "Update"} | ||||||
|  |           </button> | ||||||
|         </div> |         </div> | ||||||
|       </form> |       </form> | ||||||
|     </FormProvider> |     </FormProvider> | ||||||
|  | |||||||
| @ -17,6 +17,7 @@ import { | |||||||
| } from "../../slices/apiDataManager"; | } from "../../slices/apiDataManager"; | ||||||
| import { clearApiCacheKey } from "../../slices/apiCacheSlice"; | import { clearApiCacheKey } from "../../slices/apiCacheSlice"; | ||||||
| import { useMutation } from "@tanstack/react-query"; | import { useMutation } from "@tanstack/react-query"; | ||||||
|  | import Label from "../common/Label"; | ||||||
| 
 | 
 | ||||||
| const mobileNumberRegex = /^[0-9]\d{9}$/; | const mobileNumberRegex = /^[0-9]\d{9}$/; | ||||||
| 
 | 
 | ||||||
| @ -220,10 +221,10 @@ const ManageEmployee = ({ employeeId, onClosed, IsAllEmployee }) => { | |||||||
|   return ( |   return ( | ||||||
|     <> |     <> | ||||||
|       <form onSubmit={handleSubmit(onSubmit)} className="p-sm-0 p-2"> |       <form onSubmit={handleSubmit(onSubmit)} className="p-sm-0 p-2"> | ||||||
|         <div className="text-center"><p className="fs-6 fw-semibold"> {employee ? "Update Employee" : "Create Employee"}</p> </div> |         <div className="text-center"><p className="fs-5 fw-semibold"> {employee ? "Update Employee" : "Create Employee"}</p> </div> | ||||||
|         <div className="row mb-3"> |         <div className="row mb-3"> | ||||||
|           <div className="col-sm-4"> |           <div className="col-sm-4"> | ||||||
|             <div className="form-text text-start">First Name</div> |             <Label className="form-text text-start" required>First Name</Label> | ||||||
|             <input |             <input | ||||||
|               type="text" |               type="text" | ||||||
|               name="firstName" |               name="firstName" | ||||||
| @ -272,7 +273,7 @@ const ManageEmployee = ({ employeeId, onClosed, IsAllEmployee }) => { | |||||||
|           </div> |           </div> | ||||||
| 
 | 
 | ||||||
|           <div className="col-sm-4"> |           <div className="col-sm-4"> | ||||||
|             <div className="form-text text-start">Last Name</div> |             <Label className="form-text text-start" required>Last Name</Label> | ||||||
|             <input |             <input | ||||||
|               type="text" |               type="text" | ||||||
|               {...register("lastName", { |               {...register("lastName", { | ||||||
| @ -319,7 +320,7 @@ const ManageEmployee = ({ employeeId, onClosed, IsAllEmployee }) => { | |||||||
|             )} |             )} | ||||||
|           </div> |           </div> | ||||||
|           <div className="col-sm-6"> |           <div className="col-sm-6"> | ||||||
|             <div className="form-text text-start">Phone Number</div> |             <Label className="form-text text-start" required>Phone Number</Label> | ||||||
|             <input |             <input | ||||||
|               type="text" |               type="text" | ||||||
|               keyboardType="numeric" |               keyboardType="numeric" | ||||||
| @ -343,7 +344,7 @@ const ManageEmployee = ({ employeeId, onClosed, IsAllEmployee }) => { | |||||||
|         <div className="row mb-3"></div> |         <div className="row mb-3"></div> | ||||||
|         <div className="row mb-3"> |         <div className="row mb-3"> | ||||||
|           <div className="col-sm-4"> |           <div className="col-sm-4"> | ||||||
|             <div className="form-text text-start">Gender</div> |             <Label className="form-text text-start" required>Gender</Label> | ||||||
| 
 | 
 | ||||||
|             <div className="input-group"> |             <div className="input-group"> | ||||||
|               <select |               <select | ||||||
| @ -370,7 +371,7 @@ const ManageEmployee = ({ employeeId, onClosed, IsAllEmployee }) => { | |||||||
|             )} |             )} | ||||||
|           </div> |           </div> | ||||||
|           <div className="col-sm-4"> |           <div className="col-sm-4"> | ||||||
|             <div className="form-text text-start">Birth Date</div> |             <Label className="form-text text-start" required>Birth Date</Label> | ||||||
| 
 | 
 | ||||||
|             <div className="input-group"> |             <div className="input-group"> | ||||||
|               <input |               <input | ||||||
| @ -390,7 +391,7 @@ const ManageEmployee = ({ employeeId, onClosed, IsAllEmployee }) => { | |||||||
|             )} |             )} | ||||||
|           </div> |           </div> | ||||||
|           <div className="col-sm-4"> |           <div className="col-sm-4"> | ||||||
|             <div className="form-text text-start">Joining Date</div> |             <Label className="form-text text-start" required>Joining Date</Label> | ||||||
| 
 | 
 | ||||||
|             <div className="input-group"> |             <div className="input-group"> | ||||||
|               <input |               <input | ||||||
| @ -412,7 +413,7 @@ const ManageEmployee = ({ employeeId, onClosed, IsAllEmployee }) => { | |||||||
|         </div> |         </div> | ||||||
|         <div className="row mb-3"> |         <div className="row mb-3"> | ||||||
|           <div className="col-sm-6"> |           <div className="col-sm-6"> | ||||||
|             <div className="form-text text-start">Current Address</div> |             <Label className="form-text text-start" required>Current Address</Label> | ||||||
| 
 | 
 | ||||||
|             <textarea |             <textarea | ||||||
|               id="currentAddress" |               id="currentAddress" | ||||||
| @ -444,9 +445,9 @@ const ManageEmployee = ({ employeeId, onClosed, IsAllEmployee }) => { | |||||||
|             )} |             )} | ||||||
|           </div> |           </div> | ||||||
|           <div className="col-sm-6"> |           <div className="col-sm-6"> | ||||||
|             <div className="form-text text-start"> |             <Label className="form-text text-start" required> | ||||||
|               Permanent Address |               Permanent Address | ||||||
|             </div> |             </Label> | ||||||
| 
 | 
 | ||||||
|             <textarea |             <textarea | ||||||
|               id="permanentAddress" |               id="permanentAddress" | ||||||
| @ -484,7 +485,7 @@ const ManageEmployee = ({ employeeId, onClosed, IsAllEmployee }) => { | |||||||
|         </div> |         </div> | ||||||
|         <div className="row mb-3"> |         <div className="row mb-3"> | ||||||
|           <div className="col-sm-4"> |           <div className="col-sm-4"> | ||||||
|             <div className="form-text text-start">Official Designation</div> |             <Label className="form-text text-start" required>Official Designation</Label> | ||||||
|             <div className="input-group"> |             <div className="input-group"> | ||||||
|               <select |               <select | ||||||
|                 className="form-select form-select-sm" |                 className="form-select form-select-sm" | ||||||
| @ -514,9 +515,9 @@ const ManageEmployee = ({ employeeId, onClosed, IsAllEmployee }) => { | |||||||
|             )} |             )} | ||||||
|           </div> |           </div> | ||||||
|           <div className="col-sm-4"> |           <div className="col-sm-4"> | ||||||
|             <div className="form-text text-start"> |             <Label className="form-text text-start" required> | ||||||
|               Emergency Contact Person |               Emergency Contact Person | ||||||
|             </div> |             </Label> | ||||||
|             <input |             <input | ||||||
|               type="text" |               type="text" | ||||||
|               {...register("emergencyContactPerson")} |               {...register("emergencyContactPerson")} | ||||||
| @ -535,9 +536,9 @@ const ManageEmployee = ({ employeeId, onClosed, IsAllEmployee }) => { | |||||||
|             )} |             )} | ||||||
|           </div> |           </div> | ||||||
|           <div className="col-sm-4"> |           <div className="col-sm-4"> | ||||||
|             <div className="form-text text-start"> |             <Label className="form-text text-start" required> | ||||||
|               Emergency Phone Number |               Emergency Phone Number | ||||||
|             </div> |             </Label> | ||||||
|             <input |             <input | ||||||
|               type="text" |               type="text" | ||||||
|               {...register("emergencyPhoneNumber")} |               {...register("emergencyPhoneNumber")} | ||||||
| @ -606,8 +607,16 @@ const ManageEmployee = ({ employeeId, onClosed, IsAllEmployee }) => { | |||||||
|           </div> |           </div> | ||||||
|         )} |         )} | ||||||
| 
 | 
 | ||||||
|         <div className="row justify-content-start"> |         <div className="row text-end"> | ||||||
|           <div className="col-sm-12"> |           <div className="col-sm-12"> | ||||||
|  |             <button | ||||||
|  |               aria-label="manage employee" | ||||||
|  |               type="reset" | ||||||
|  |               className="btn btn-sm btn-label-secondary me-2" | ||||||
|  |               disabled={isPending} | ||||||
|  |             > | ||||||
|  |               Clear | ||||||
|  |             </button> | ||||||
|             <button |             <button | ||||||
|               aria-label="manage employee" |               aria-label="manage employee" | ||||||
|               type="submit" |               type="submit" | ||||||
| @ -621,14 +630,7 @@ const ManageEmployee = ({ employeeId, onClosed, IsAllEmployee }) => { | |||||||
|                   : "Create"} |                   : "Create"} | ||||||
|             </button> |             </button> | ||||||
| 
 | 
 | ||||||
|             <button | 
 | ||||||
|               aria-label="manage employee" |  | ||||||
|               type="reset" |  | ||||||
|               className="btn btn-sm btn-secondary ms-2" |  | ||||||
|               disabled={isPending} |  | ||||||
|             > |  | ||||||
|               Clear |  | ||||||
|             </button> |  | ||||||
|           </div> |           </div> | ||||||
|         </div> |         </div> | ||||||
|       </form> |       </form> | ||||||
|  | |||||||
| @ -114,7 +114,7 @@ const ManageRole = ( {employeeId, onClosed} ) => | |||||||
|   return ( |   return ( | ||||||
|             <form onSubmit={handleSubmit(onSubmit)}> |             <form onSubmit={handleSubmit(onSubmit)}> | ||||||
|               <div className="text-start mb-3"> |               <div className="text-start mb-3"> | ||||||
|                 <p className="lead">Select Roles</p> |                 <h5 className="lead">Select Roles :</h5> | ||||||
|               </div> |               </div> | ||||||
| 
 | 
 | ||||||
|               {isLoadingData ? ( |               {isLoadingData ? ( | ||||||
| @ -148,18 +148,18 @@ const ManageRole = ( {employeeId, onClosed} ) => | |||||||
|                 </div> |                 </div> | ||||||
|               )} |               )} | ||||||
| 
 | 
 | ||||||
|               <div className="text-center mt-3"> |               <div className="text-end mt-1">                 | ||||||
|                 <button type="submit" className="btn btn-sm btn-primary me-3" disabled={isLoading}> |  | ||||||
|                   {isLoading ? "Please Wait..." : "Submit"} |  | ||||||
|                 </button> |  | ||||||
|                 <button |                 <button | ||||||
|                   type="reset" |                   type="button" | ||||||
|                   className="btn btn-sm btn-label-secondary" |                   className="btn btn-sm btn-label-secondary me-2" | ||||||
|                   data-bs-dismiss="modal" |                   data-bs-dismiss="modal" | ||||||
|                   aria-label="Close" |                   aria-label="Close" | ||||||
|                 > |                 > | ||||||
|                   Cancel |                   Cancel | ||||||
|                 </button> |                 </button> | ||||||
|  |                 <button type="submit" className="btn btn-sm btn-primary" disabled={isLoading}> | ||||||
|  |                   {isLoading ? "Please Wait..." : "Submit"} | ||||||
|  |                 </button> | ||||||
|               </div> |               </div> | ||||||
|             </form> |             </form> | ||||||
|   ); |   ); | ||||||
|  | |||||||
| @ -27,6 +27,7 @@ import ExpenseSkeleton from "./ExpenseSkeleton"; | |||||||
| import moment from "moment"; | import moment from "moment"; | ||||||
| import DatePicker from "../common/DatePicker"; | import DatePicker from "../common/DatePicker"; | ||||||
| import ErrorPage from "../../pages/ErrorPage"; | import ErrorPage from "../../pages/ErrorPage"; | ||||||
|  | import Label from "../common/Label"; | ||||||
| 
 | 
 | ||||||
| const ManageExpense = ({ closeModal, expenseToEdit = null }) => { | const ManageExpense = ({ closeModal, expenseToEdit = null }) => { | ||||||
|   const { |   const { | ||||||
| @ -213,9 +214,9 @@ const ManageExpense = ({ closeModal, expenseToEdit = null }) => { | |||||||
|         {expenseToEdit ? "Update Expense " : "Create New Expense"} |         {expenseToEdit ? "Update Expense " : "Create New Expense"} | ||||||
|       </h5> |       </h5> | ||||||
|       <form id="expenseForm" onSubmit={handleSubmit(onSubmit)}> |       <form id="expenseForm" onSubmit={handleSubmit(onSubmit)}> | ||||||
|         <div className="row my-2"> |         <div className="row my-2 text-start"> | ||||||
|           <div className="col-md-6"> |           <div className="col-md-6"> | ||||||
|             <label className="form-label">Select Project</label> |             <Label className="form-label" required>Select Project</Label> | ||||||
|             <select |             <select | ||||||
|               className="form-select form-select-sm" |               className="form-select form-select-sm" | ||||||
|               {...register("projectId")} |               {...register("projectId")} | ||||||
| @ -237,9 +238,9 @@ const ManageExpense = ({ closeModal, expenseToEdit = null }) => { | |||||||
|           </div> |           </div> | ||||||
| 
 | 
 | ||||||
|           <div className="col-md-6"> |           <div className="col-md-6"> | ||||||
|             <label htmlFor="expensesTypeId" className="form-label"> |             <Label htmlFor="expensesTypeId" className="form-label" required> | ||||||
|               Expense Type |               Expense Type | ||||||
|             </label> |             </Label> | ||||||
|             <select |             <select | ||||||
|               className="form-select form-select-sm" |               className="form-select form-select-sm" | ||||||
|               id="expensesTypeId" |               id="expensesTypeId" | ||||||
| @ -266,11 +267,11 @@ const ManageExpense = ({ closeModal, expenseToEdit = null }) => { | |||||||
|           </div> |           </div> | ||||||
|         </div> |         </div> | ||||||
| 
 | 
 | ||||||
|         <div className="row my-2"> |         <div className="row my-2 text-start"> | ||||||
|           <div className="col-md-6"> |           <div className="col-md-6"> | ||||||
|             <label htmlFor="paymentModeId" className="form-label"> |             <Label htmlFor="paymentModeId" className="form-label" required> | ||||||
|               Payment Mode |               Payment Mode | ||||||
|             </label> |             </Label> | ||||||
|             <select |             <select | ||||||
|               className="form-select form-select-sm" |               className="form-select form-select-sm" | ||||||
|               id="paymentModeId" |               id="paymentModeId" | ||||||
| @ -297,9 +298,9 @@ const ManageExpense = ({ closeModal, expenseToEdit = null }) => { | |||||||
|           </div> |           </div> | ||||||
| 
 | 
 | ||||||
|           <div className="col-md-6"> |           <div className="col-md-6"> | ||||||
|             <label htmlFor="paidById" className="form-label "> |             <Label htmlFor="paidById" className="form-label" required> | ||||||
|               Paid By |               Paid By | ||||||
|             </label> |             </Label> | ||||||
|             <select |             <select | ||||||
|               className="form-select form-select-sm" |               className="form-select form-select-sm" | ||||||
|               id="paymentModeId" |               id="paymentModeId" | ||||||
| @ -325,11 +326,11 @@ const ManageExpense = ({ closeModal, expenseToEdit = null }) => { | |||||||
|           </div> |           </div> | ||||||
|         </div> |         </div> | ||||||
| 
 | 
 | ||||||
|         <div className="row my-2"> |         <div className="row my-2 text-start"> | ||||||
|           <div className="col-md-6"> |           <div className="col-md-6"> | ||||||
|             <label htmlFor="transactionDate" className="form-label "> |             <Label htmlFor="transactionDate" className="form-label" required> | ||||||
|               Transaction Date |               Transaction Date | ||||||
|             </label> |             </Label> | ||||||
|             <DatePicker name="transactionDate" control={control} /> |             <DatePicker name="transactionDate" control={control} /> | ||||||
| 
 | 
 | ||||||
|             {errors.transactionDate && ( |             {errors.transactionDate && ( | ||||||
| @ -340,9 +341,9 @@ const ManageExpense = ({ closeModal, expenseToEdit = null }) => { | |||||||
|           </div> |           </div> | ||||||
| 
 | 
 | ||||||
|           <div className="col-md-6"> |           <div className="col-md-6"> | ||||||
|             <label htmlFor="amount" className="form-label "> |             <Label htmlFor="amount" className="form-label" required> | ||||||
|               Amount |               Amount | ||||||
|             </label> |             </Label> | ||||||
|             <input |             <input | ||||||
|               type="number" |               type="number" | ||||||
|               id="amount" |               id="amount" | ||||||
| @ -358,11 +359,11 @@ const ManageExpense = ({ closeModal, expenseToEdit = null }) => { | |||||||
|           </div> |           </div> | ||||||
|         </div> |         </div> | ||||||
| 
 | 
 | ||||||
|         <div className="row my-2"> |         <div className="row my-2 text-start"> | ||||||
|           <div className="col-md-6"> |           <div className="col-md-6"> | ||||||
|             <label htmlFor="supplerName" className="form-label "> |             <Label htmlFor="supplerName" className="form-label" required> | ||||||
|               Supplier Name/Transporter Name/Other |               Supplier Name/Transporter Name/Other | ||||||
|             </label> |             </Label> | ||||||
|             <input |             <input | ||||||
|               type="text" |               type="text" | ||||||
|               id="supplerName" |               id="supplerName" | ||||||
| @ -377,9 +378,9 @@ const ManageExpense = ({ closeModal, expenseToEdit = null }) => { | |||||||
|           </div> |           </div> | ||||||
| 
 | 
 | ||||||
|           <div className="col-md-6"> |           <div className="col-md-6"> | ||||||
|             <label htmlFor="location" className="form-label "> |             <Label htmlFor="location" className="form-label" required> | ||||||
|               Location |               Location | ||||||
|             </label> |             </Label> | ||||||
|             <input |             <input | ||||||
|               type="text" |               type="text" | ||||||
|               id="location" |               id="location" | ||||||
| @ -391,7 +392,7 @@ const ManageExpense = ({ closeModal, expenseToEdit = null }) => { | |||||||
|             )} |             )} | ||||||
|           </div> |           </div> | ||||||
|         </div> |         </div> | ||||||
|         <div className="row my-2"> |         <div className="row my-2 text-start"> | ||||||
|           <div className="col-md-6"> |           <div className="col-md-6"> | ||||||
|             <label htmlFor="statusId" className="form-label "> |             <label htmlFor="statusId" className="form-label "> | ||||||
|               Transaction ID |               Transaction ID | ||||||
| @ -428,7 +429,7 @@ const ManageExpense = ({ closeModal, expenseToEdit = null }) => { | |||||||
|           </div> |           </div> | ||||||
| 
 | 
 | ||||||
|           {ExpenseType?.noOfPersonsRequired && ( |           {ExpenseType?.noOfPersonsRequired && ( | ||||||
|             <div className="col-md-6 mt-2"> |             <div className="col-md-6 mt-2 text-start"> | ||||||
|               <label className="form-label ">No. of Persons</label> |               <label className="form-label ">No. of Persons</label> | ||||||
|               <input |               <input | ||||||
|                 type="number" |                 type="number" | ||||||
| @ -446,9 +447,9 @@ const ManageExpense = ({ closeModal, expenseToEdit = null }) => { | |||||||
|           )} |           )} | ||||||
|         </div> |         </div> | ||||||
| 
 | 
 | ||||||
|         <div className="row my-2"> |         <div className="row my-2 text-start"> | ||||||
|           <div className="col-md-12"> |           <div className="col-md-12"> | ||||||
|             <label htmlFor="description" className="form-label ">Description</label> |             <Label htmlFor="description" className="form-label" required>Description</Label> | ||||||
|             <textarea |             <textarea | ||||||
|               id="description" |               id="description" | ||||||
|               className="form-control form-control-sm" |               className="form-control form-control-sm" | ||||||
| @ -463,16 +464,16 @@ const ManageExpense = ({ closeModal, expenseToEdit = null }) => { | |||||||
|           </div> |           </div> | ||||||
|         </div> |         </div> | ||||||
| 
 | 
 | ||||||
|         <div className="row my-2"> |         <div className="row my-2 text-start"> | ||||||
|           <div className="col-md-12"> |           <div className="col-md-12"> | ||||||
|             <label className="form-label ">Upload Bill </label> |             <Label className="form-label" required>Upload Bill </Label> | ||||||
| 
 | 
 | ||||||
|             <div |             <div | ||||||
|               className="border border-secondary border-dashed rounded p-4 text-center bg-textMuted position-relative" |               className="border border-secondary border-dashed rounded p-4 text-center bg-textMuted position-relative" | ||||||
|               style={{ cursor: "pointer" }} |               style={{ cursor: "pointer" }} | ||||||
|               onClick={() => document.getElementById("billAttachments").click()} |               onClick={() => document.getElementById("billAttachments").click()} | ||||||
|             > |             > | ||||||
|               <i className="bx bx-cloud-upload d-block bx-lg"></i> |               <i className="bx bx-cloud-upload d-block bx-lg"> </i> | ||||||
|               <span className="text-muted d-block"> |               <span className="text-muted d-block"> | ||||||
|                 Click to select or click here to browse |                 Click to select or click here to browse | ||||||
|               </span> |               </span> | ||||||
| @ -547,8 +548,16 @@ const ManageExpense = ({ closeModal, expenseToEdit = null }) => { | |||||||
|           </div> |           </div> | ||||||
|         </div> |         </div> | ||||||
| 
 | 
 | ||||||
|         <div className="d-flex justify-content-center gap-3"> |         <div className="d-flex justify-content-end gap-3"> | ||||||
|           {" "} |           {" "} | ||||||
|  |            <button | ||||||
|  |             type="reset" | ||||||
|  |             disabled={isPending || createPending} | ||||||
|  |             onClick={handleClose} | ||||||
|  |             className="btn btn-label-secondary btn-sm mt-3" | ||||||
|  |           > | ||||||
|  |             Cancel | ||||||
|  |           </button> | ||||||
|           <button |           <button | ||||||
|             type="submit" |             type="submit" | ||||||
|             className="btn btn-primary btn-sm mt-3" |             className="btn btn-primary btn-sm mt-3" | ||||||
| @ -560,14 +569,7 @@ const ManageExpense = ({ closeModal, expenseToEdit = null }) => { | |||||||
|               ? "Update" |               ? "Update" | ||||||
|               : "Submit"} |               : "Submit"} | ||||||
|           </button> |           </button> | ||||||
|           <button |           | ||||||
|             type="reset" |  | ||||||
|             disabled={isPending || createPending} |  | ||||||
|             onClick={handleClose} |  | ||||||
|             className="btn btn-secondary btn-sm mt-3" |  | ||||||
|           > |  | ||||||
|             Cancel |  | ||||||
|           </button> |  | ||||||
|         </div> |         </div> | ||||||
|       </form> |       </form> | ||||||
|     </div> |     </div> | ||||||
|  | |||||||
| @ -28,6 +28,7 @@ import EmployeeSearchInput from "../common/EmployeeSearchInput"; | |||||||
| import { z } from "zod"; | import { z } from "zod"; | ||||||
| import moment from "moment"; | import moment from "moment"; | ||||||
| import ExpenseStatusLogs from "./ExpenseStatusLogs"; | import ExpenseStatusLogs from "./ExpenseStatusLogs"; | ||||||
|  | import Label from "../common/Label"; | ||||||
| 
 | 
 | ||||||
| const ViewExpense = ({ ExpenseId }) => { | const ViewExpense = ({ ExpenseId }) => { | ||||||
|   const { data, isLoading, isError, error, isFetching } = useExpense(ExpenseId); |   const { data, isLoading, isError, error, isFetching } = useExpense(ExpenseId); | ||||||
| @ -418,7 +419,7 @@ const ViewExpense = ({ ExpenseId }) => { | |||||||
|             {((nextStatusWithPermission.length > 0 && !IsRejectedExpense) || |             {((nextStatusWithPermission.length > 0 && !IsRejectedExpense) || | ||||||
|               (IsRejectedExpense && isCreatedBy)) && ( |               (IsRejectedExpense && isCreatedBy)) && ( | ||||||
|               <> |               <> | ||||||
|                 <label className="form-label me-2 mb-0">Comment:</label> |                 <Label className="form-label me-2 mb-0" required>Comment</Label> | ||||||
|                 <textarea |                 <textarea | ||||||
|                   className="form-control form-control-sm" |                   className="form-control form-control-sm" | ||||||
|                   {...register("comment")} |                   {...register("comment")} | ||||||
| @ -434,13 +435,13 @@ const ViewExpense = ({ ExpenseId }) => { | |||||||
| 
 | 
 | ||||||
|             {nextStatusWithPermission?.length > 0 && |             {nextStatusWithPermission?.length > 0 && | ||||||
|               (!IsRejectedExpense || isCreatedBy) && ( |               (!IsRejectedExpense || isCreatedBy) && ( | ||||||
|                 <div className="text-center flex-wrap gap-2 my-2"> |                 <div className="text-end flex-wrap gap-2 my-2 mt-3"> | ||||||
|                   {nextStatusWithPermission.map((status, index) => ( |                   {nextStatusWithPermission.map((status, index) => ( | ||||||
|                     <button |                     <button | ||||||
|                       key={status.id || index} |                       key={status.id || index} | ||||||
|                       type="button" |                       type="button" | ||||||
|                       onClick={() => { |                       onClick={() => { | ||||||
|                         setClickedStatusId(status.id); |                       setClickedStatusId(status.id); | ||||||
|                         setValue("statusId", status.id); |                         setValue("statusId", status.id); | ||||||
|                         handleSubmit(onSubmit)(); |                         handleSubmit(onSubmit)(); | ||||||
|                       }} |                       }} | ||||||
|  | |||||||
| @ -12,6 +12,7 @@ import showToast from "../../services/toastService"; | |||||||
| import { useProjectDetails } from "../../hooks/useProjects"; | import { useProjectDetails } from "../../hooks/useProjects"; | ||||||
| import eventBus from "../../services/eventBus"; | import eventBus from "../../services/eventBus"; | ||||||
| import { useCreateTask } from "../../hooks/useTasks"; | import { useCreateTask } from "../../hooks/useTasks"; | ||||||
|  | import Label from "../common/Label"; | ||||||
| 
 | 
 | ||||||
| const AssignTask = ({ assignData, onClose, setAssigned }) => { | const AssignTask = ({ assignData, onClose, setAssigned }) => { | ||||||
|   const maxPlanned = |   const maxPlanned = | ||||||
| @ -261,8 +262,8 @@ const AssignTask = ({ assignData, onClose, setAssigned }) => { | |||||||
|                       <div className="dropdown position-relative d-inline-block"> |                       <div className="dropdown position-relative d-inline-block"> | ||||||
|                         <a |                         <a | ||||||
|                           className={`dropdown-toggle hide-arrow cursor-pointer ${selectedRoles.includes("all") || selectedRoles.length === 0 |                           className={`dropdown-toggle hide-arrow cursor-pointer ${selectedRoles.includes("all") || selectedRoles.length === 0 | ||||||
|                               ? "text-secondary" |                             ? "text-secondary" | ||||||
|                               : "text-primary" |                             : "text-primary" | ||||||
|                             }`} |                             }`} | ||||||
|                           data-bs-toggle="dropdown" |                           data-bs-toggle="dropdown" | ||||||
|                           role="button" |                           role="button" | ||||||
| @ -427,7 +428,7 @@ const AssignTask = ({ assignData, onClose, setAssigned }) => { | |||||||
|                     ) : ( |                     ) : ( | ||||||
|                       <div className="col-12"> |                       <div className="col-12"> | ||||||
|                         <p className="text-center"> |                         <p className="text-center"> | ||||||
|                             No employees found for the selected role. |                           No employees found for the selected role. | ||||||
|                         </p> |                         </p> | ||||||
|                       </div> |                       </div> | ||||||
|                     )} |                     )} | ||||||
| @ -502,8 +503,11 @@ const AssignTask = ({ assignData, onClose, setAssigned }) => { | |||||||
|               <div className="col-md text-start mx-0 px-0"> |               <div className="col-md text-start mx-0 px-0"> | ||||||
|                 <div className="form-check form-check-inline mt-2 px-1 mb-2 text-start"> |                 <div className="form-check form-check-inline mt-2 px-1 mb-2 text-start"> | ||||||
|                   <label className="text-dark d-flex align-items-center flex-wrap form-text"> |                   <label className="text-dark d-flex align-items-center flex-wrap form-text"> | ||||||
|                     <span>Target for Today</span>  |                     <Label htmlFor="targetToday" required className="me-1"> | ||||||
|                     <span style={{ marginLeft: "46px" }}>:</span> |                       Target for Today | ||||||
|  |                     </Label> | ||||||
|  | 
 | ||||||
|  |                     <span style={{ marginLeft: "37px" }}>:</span> | ||||||
|                   </label> |                   </label> | ||||||
|                 </div> |                 </div> | ||||||
|                 <div |                 <div | ||||||
| @ -533,12 +537,16 @@ const AssignTask = ({ assignData, onClose, setAssigned }) => { | |||||||
|                 )} |                 )} | ||||||
|               </div> |               </div> | ||||||
| 
 | 
 | ||||||
|               <label |               {/* <label | ||||||
|                 className="form-text fs-7 m-1 text-lg text-dark" |                 className="form-text fs-7 m-1 text-lg text-dark" | ||||||
|                 htmlFor="descriptionTextarea" // Changed htmlFor for better accessibility |                 htmlFor="descriptionTextarea" // Changed htmlFor for better accessibility | ||||||
|               > |               > | ||||||
|                 Description |                 Description | ||||||
|               </label> |               </label> */} | ||||||
|  |               <Label className="form-text fs-7 m-1 text-lg text-dark" | ||||||
|  |                 htmlFor="descriptionTextarea" required> | ||||||
|  |                 Description | ||||||
|  |               </Label> | ||||||
|               <Controller |               <Controller | ||||||
|                 name="description" |                 name="description" | ||||||
|                 control={control} |                 control={control} | ||||||
| @ -552,14 +560,7 @@ const AssignTask = ({ assignData, onClose, setAssigned }) => { | |||||||
|             </div> |             </div> | ||||||
| 
 | 
 | ||||||
|             {/* Submit and Cancel buttons */} |             {/* Submit and Cancel buttons */} | ||||||
|             <div className="col-12 d-flex justify-content-center align-items-center gap-sm-6 gap-8 text-center mt-1"> |             <div className="col-12 d-flex justify-content-end align-items-center gap-2 mt-6"> | ||||||
|               <button |  | ||||||
|                 type="submit" |  | ||||||
|                 className="btn btn-sm btn-primary " |  | ||||||
|                 disabled={isSubmitting || loading} |  | ||||||
|               > |  | ||||||
|                 {isSubmitting ? "Please Wait" : "Submit"} |  | ||||||
|               </button> |  | ||||||
|               <button |               <button | ||||||
|                 type="reset" |                 type="reset" | ||||||
|                 className="btn btn-sm btn-label-secondary" |                 className="btn btn-sm btn-label-secondary" | ||||||
| @ -570,7 +571,15 @@ const AssignTask = ({ assignData, onClose, setAssigned }) => { | |||||||
|               > |               > | ||||||
|                 Cancel |                 Cancel | ||||||
|               </button> |               </button> | ||||||
|  |               <button | ||||||
|  |                 type="submit" | ||||||
|  |                 className="btn btn-sm btn-primary" | ||||||
|  |                 disabled={isSubmitting || loading} | ||||||
|  |               > | ||||||
|  |                 {isSubmitting ? "Please Wait" : "Submit"} | ||||||
|  |               </button> | ||||||
|             </div> |             </div> | ||||||
|  | 
 | ||||||
|           </form> |           </form> | ||||||
|         </div> |         </div> | ||||||
|       </div> |       </div> | ||||||
|  | |||||||
| @ -7,6 +7,7 @@ import { getCachedData } from "../../../slices/apiDataManager"; | |||||||
| import showToast from "../../../services/toastService"; | import showToast from "../../../services/toastService"; | ||||||
| import { useManageProjectInfra } from "../../../hooks/useProjects"; | import { useManageProjectInfra } from "../../../hooks/useProjects"; | ||||||
| import useSelect from "../../common/useSelect"; | import useSelect from "../../common/useSelect"; | ||||||
|  | import Label from "../../common/Label"; | ||||||
| 
 | 
 | ||||||
| const buildingSchema = z.object({ | const buildingSchema = z.object({ | ||||||
|   Id: z.string().optional(), |   Id: z.string().optional(), | ||||||
| @ -100,7 +101,7 @@ const BuildingModel = ({ project, onClose, editingBuilding = null }) => { | |||||||
|   return ( |   return ( | ||||||
|     <form onSubmit={handleSubmit(onSubmitHandler)} className="row g-2"> |     <form onSubmit={handleSubmit(onSubmitHandler)} className="row g-2"> | ||||||
|       <h5 className="text-center mb-2">Manage Buildings </h5> |       <h5 className="text-center mb-2">Manage Buildings </h5> | ||||||
|       <div className="col-12"> |       <div className="col-12 text-start"> | ||||||
|         <label className="form-label">Select Building</label> |         <label className="form-label">Select Building</label> | ||||||
|         <select |         <select | ||||||
|           {...register("Id")} |           {...register("Id")} | ||||||
| @ -121,10 +122,10 @@ const BuildingModel = ({ project, onClose, editingBuilding = null }) => { | |||||||
|       </div> |       </div> | ||||||
| 
 | 
 | ||||||
|       {/* Name */} |       {/* Name */} | ||||||
|       <div className="col-12"> |       <div className="col-12 text-start"> | ||||||
|         <label className="form-label"> |         <Label className="form-label" required> | ||||||
|           {watchedId !== "0" ? "Rename Building Name" : "New Building Name"} |           {watchedId !== "0" ? "Rename Building Name" : "New Building Name"} | ||||||
|         </label> |         </Label> | ||||||
|         <input |         <input | ||||||
|           {...register("name")} |           {...register("name")} | ||||||
|           type="text" |           type="text" | ||||||
| @ -136,8 +137,8 @@ const BuildingModel = ({ project, onClose, editingBuilding = null }) => { | |||||||
|       </div> |       </div> | ||||||
| 
 | 
 | ||||||
|       {/* Description */} |       {/* Description */} | ||||||
|       <div className="col-12"> |       <div className="col-12 text-start"> | ||||||
|         <label className="form-label">Description</label> |         <Label className="form-label" required>Description</Label> | ||||||
|         <textarea |         <textarea | ||||||
|           {...register("description")} |           {...register("description")} | ||||||
|           rows="5" |           rows="5" | ||||||
| @ -149,10 +150,21 @@ const BuildingModel = ({ project, onClose, editingBuilding = null }) => { | |||||||
|         )} |         )} | ||||||
|       </div> |       </div> | ||||||
| 
 | 
 | ||||||
|       <div className="col-12 text-center"> |       <div className="col-12 text-end mt-5"> | ||||||
|  |         <button | ||||||
|  |           type="reset" | ||||||
|  |           className="btn btn-sm btn-label-secondary me-3" | ||||||
|  |           disabled={isPending} | ||||||
|  |           onClick={() => { | ||||||
|  |             onClose(); | ||||||
|  |             reset(); | ||||||
|  |           }} | ||||||
|  |         > | ||||||
|  |           Cancel | ||||||
|  |         </button> | ||||||
|         <button |         <button | ||||||
|           type="submit" |           type="submit" | ||||||
|           className="btn btn-sm btn-primary me-3" |           className="btn btn-sm btn-primary" | ||||||
|           disabled={isPending} |           disabled={isPending} | ||||||
|         > |         > | ||||||
|           {isPending |           {isPending | ||||||
| @ -162,17 +174,7 @@ const BuildingModel = ({ project, onClose, editingBuilding = null }) => { | |||||||
|             : "Add Building"} |             : "Add Building"} | ||||||
|         </button> |         </button> | ||||||
| 
 | 
 | ||||||
|         <button |          | ||||||
|           type="reset" |  | ||||||
|           className="btn btn-sm btn-label-secondary" |  | ||||||
|           disabled={isPending} |  | ||||||
|           onClick={() => { |  | ||||||
|             onClose(); |  | ||||||
|             reset(); |  | ||||||
|           }} |  | ||||||
|         > |  | ||||||
|           Cancel |  | ||||||
|         </button> |  | ||||||
|       </div> |       </div> | ||||||
|     </form> |     </form> | ||||||
|   ); |   ); | ||||||
|  | |||||||
| @ -134,7 +134,7 @@ useEffect(() => { | |||||||
|         <h5 className="mb-1">Manage Task</h5> |         <h5 className="mb-1">Manage Task</h5> | ||||||
|       </div> |       </div> | ||||||
| 
 | 
 | ||||||
|       <div className="row g-2"> |       <div className="row g-2 text-start"> | ||||||
|         <div className="col-12 col-md-6"> |         <div className="col-12 col-md-6"> | ||||||
|           <label className="form-label">Select Building</label> |           <label className="form-label">Select Building</label> | ||||||
|           <input |           <input | ||||||
| @ -154,7 +154,7 @@ useEffect(() => { | |||||||
|         </div> |         </div> | ||||||
|       </div> |       </div> | ||||||
| 
 | 
 | ||||||
|       <div className="col-12"> |       <div className="col-12 text-start"> | ||||||
|         <label className="form-label">Select Work Area</label> |         <label className="form-label">Select Work Area</label> | ||||||
|         <input |         <input | ||||||
|           className="form-control form-control-sm" |           className="form-control form-control-sm" | ||||||
| @ -163,7 +163,7 @@ useEffect(() => { | |||||||
|         /> |         /> | ||||||
|       </div> |       </div> | ||||||
| 
 | 
 | ||||||
|       <div className="col-12"> |       <div className="col-12 text-start"> | ||||||
|         <label className="form-label">Select Activity</label> |         <label className="form-label">Select Activity</label> | ||||||
|         <select |         <select | ||||||
|           {...register("activityID")} |           {...register("activityID")} | ||||||
| @ -185,7 +185,7 @@ useEffect(() => { | |||||||
|         )} |         )} | ||||||
|       </div> |       </div> | ||||||
| 
 | 
 | ||||||
|       <div className="col-12"> |       <div className="col-12 text-start"> | ||||||
|         <label className="form-label">Select Work Category</label> |         <label className="form-label">Select Work Category</label> | ||||||
|         <select |         <select | ||||||
|           {...register("workCategoryId")} |           {...register("workCategoryId")} | ||||||
| @ -207,7 +207,7 @@ useEffect(() => { | |||||||
|         )} |         )} | ||||||
|       </div> |       </div> | ||||||
| 
 | 
 | ||||||
|       <div className="col-5"> |       <div className="col-5 text-start"> | ||||||
|         <label className="form-label">Planned Work</label> |         <label className="form-label">Planned Work</label> | ||||||
|         <input |         <input | ||||||
|           {...register("plannedWork", { valueAsNumber: true })} |           {...register("plannedWork", { valueAsNumber: true })} | ||||||
| @ -219,7 +219,7 @@ useEffect(() => { | |||||||
|         )} |         )} | ||||||
|       </div> |       </div> | ||||||
| 
 | 
 | ||||||
|       <div className="col-5"> |       <div className="col-5 text-start"> | ||||||
|         <label className="form-label">Completed Work</label> |         <label className="form-label">Completed Work</label> | ||||||
|         <input |         <input | ||||||
|           {...register("completedWork", { valueAsNumber: true })} |           {...register("completedWork", { valueAsNumber: true })} | ||||||
| @ -232,7 +232,7 @@ useEffect(() => { | |||||||
|         )} |         )} | ||||||
|       </div> |       </div> | ||||||
| 
 | 
 | ||||||
|       <div className="col-2"> |       <div className="col-2 text-start"> | ||||||
|         <label className="form-label">Unit</label> |         <label className="form-label">Unit</label> | ||||||
|         <input |         <input | ||||||
|           className="form-control form-control-sm" |           className="form-control form-control-sm" | ||||||
| @ -241,7 +241,7 @@ useEffect(() => { | |||||||
|         /> |         /> | ||||||
|       </div> |       </div> | ||||||
| 
 | 
 | ||||||
|       <div className="col-12"> |       <div className="col-12 text-start"> | ||||||
|         <label className="form-label">Comment</label> |         <label className="form-label">Comment</label> | ||||||
|         <textarea {...register("comment")} rows="2" className="form-control" /> |         <textarea {...register("comment")} rows="2" className="form-control" /> | ||||||
|         {errors.comment && ( |         {errors.comment && ( | ||||||
| @ -249,22 +249,22 @@ useEffect(() => { | |||||||
|         )} |         )} | ||||||
|       </div> |       </div> | ||||||
| 
 | 
 | ||||||
|       <div className="col-12 text-center"> |       <div className="col-12 text-end mt-5"> | ||||||
|         <button |  | ||||||
|           type="submit" |  | ||||||
|           className="btn btn-sm btn-primary me-2" |  | ||||||
|           disabled={isPending} |  | ||||||
|         > |  | ||||||
|           {isPending ? "Please Wait..." : "Edit Task"} |  | ||||||
|         </button> |  | ||||||
|         <button |         <button | ||||||
|           type="button" |           type="button" | ||||||
|           className="btn btn-sm btn-label-secondary" |           className="btn btn-sm btn-label-secondary me-2" | ||||||
|           onClick={onClose} |           onClick={onClose} | ||||||
|           disabled={isPending} |           disabled={isPending} | ||||||
|         > |         > | ||||||
|           Cancel |           Cancel | ||||||
|         </button> |         </button> | ||||||
|  |         <button | ||||||
|  |           type="submit" | ||||||
|  |           className="btn btn-sm btn-primary" | ||||||
|  |           disabled={isPending} | ||||||
|  |         > | ||||||
|  |           {isPending ? "Please Wait..." : "Edit Task"} | ||||||
|  |         </button>         | ||||||
|       </div> |       </div> | ||||||
|     </form> |     </form> | ||||||
|   ); |   ); | ||||||
|  | |||||||
| @ -5,6 +5,7 @@ import { zodResolver } from "@hookform/resolvers/zod"; | |||||||
| import showToast from "../../../services/toastService"; | import showToast from "../../../services/toastService"; | ||||||
| import { useManageProjectInfra } from "../../../hooks/useProjects"; | import { useManageProjectInfra } from "../../../hooks/useProjects"; | ||||||
| import { useSelector } from "react-redux"; | import { useSelector } from "react-redux"; | ||||||
|  | import Label from "../../common/Label"; | ||||||
| 
 | 
 | ||||||
| // Schema | // Schema | ||||||
| const floorSchema = z.object({ | const floorSchema = z.object({ | ||||||
| @ -101,8 +102,8 @@ const FloorModel = ({ project, onClose, onSubmit }) => { | |||||||
|       <div className="text-center mb-1"> |       <div className="text-center mb-1"> | ||||||
|         <h5 className="mb-1">Manage Floor</h5> |         <h5 className="mb-1">Manage Floor</h5> | ||||||
|       </div> |       </div> | ||||||
|       <div className="col-12"> |       <div className="col-12 text-start"> | ||||||
|         <label className="form-label">Select Building</label> |         <Label className="form-label" required>Select Building</Label> | ||||||
|         <select |         <select | ||||||
|           {...register("buildingId")} |           {...register("buildingId")} | ||||||
|           className="form-select form-select-sm" |           className="form-select form-select-sm" | ||||||
| @ -126,7 +127,7 @@ const FloorModel = ({ project, onClose, onSubmit }) => { | |||||||
| 
 | 
 | ||||||
|       {watchBuildingId !== "0" && ( |       {watchBuildingId !== "0" && ( | ||||||
|         <> |         <> | ||||||
|           <div className="col-12"> |           <div className="col-12 text-start"> | ||||||
|             <label className="form-label">Select Floor</label> |             <label className="form-label">Select Floor</label> | ||||||
|             <select |             <select | ||||||
|               {...register("id")} |               {...register("id")} | ||||||
| @ -146,10 +147,10 @@ const FloorModel = ({ project, onClose, onSubmit }) => { | |||||||
|             </select> |             </select> | ||||||
|           </div> |           </div> | ||||||
| 
 | 
 | ||||||
|           <div className="col-12"> |           <div className="col-12 text-start"> | ||||||
|             <label className="form-label"> |             <Label className="form-label" required> | ||||||
|               {watchId !== "0" ? "Edit Floor Name" : "New Floor Name"} |               {watchId !== "0" ? "Edit Floor Name" : "New Floor Name"} | ||||||
|             </label> |             </Label> | ||||||
|             <input |             <input | ||||||
|               {...register("floorName")} |               {...register("floorName")} | ||||||
|               className="form-control form-control-sm" |               className="form-control form-control-sm" | ||||||
| @ -162,10 +163,18 @@ const FloorModel = ({ project, onClose, onSubmit }) => { | |||||||
|         </> |         </> | ||||||
|       )} |       )} | ||||||
| 
 | 
 | ||||||
|       <div className="col-12 text-center"> |       <div className="col-12 text-end mt-5"> | ||||||
|  |          <button | ||||||
|  |           type="button" | ||||||
|  |           className="btn btn-sm btn-label-secondary me-3" | ||||||
|  |           disabled={isPending} | ||||||
|  |           onClick={onClose} | ||||||
|  |         > | ||||||
|  |           Cancel | ||||||
|  |         </button> | ||||||
|         <button |         <button | ||||||
|           type="submit" |           type="submit" | ||||||
|           className="btn btn-sm btn-primary me-3" |           className="btn btn-sm btn-primary" | ||||||
|           disabled={isPending} |           disabled={isPending} | ||||||
|         > |         > | ||||||
|           {isPending |           {isPending | ||||||
| @ -174,14 +183,7 @@ const FloorModel = ({ project, onClose, onSubmit }) => { | |||||||
|             ? "Edit Floor" |             ? "Edit Floor" | ||||||
|             : "Add Floor"} |             : "Add Floor"} | ||||||
|         </button> |         </button> | ||||||
|         <button |         | ||||||
|           type="button" |  | ||||||
|           className="btn btn-sm btn-label-secondary" |  | ||||||
|           disabled={isPending} |  | ||||||
|           onClick={onClose} |  | ||||||
|         > |  | ||||||
|           Cancel |  | ||||||
|         </button> |  | ||||||
|       </div> |       </div> | ||||||
|     </form> |     </form> | ||||||
|   ); |   ); | ||||||
|  | |||||||
| @ -8,6 +8,7 @@ import { | |||||||
| } from "../../../hooks/masterHook/useMaster"; | } from "../../../hooks/masterHook/useMaster"; | ||||||
| import { useManageTask } from "../../../hooks/useProjects"; | import { useManageTask } from "../../../hooks/useProjects"; | ||||||
| import showToast from "../../../services/toastService"; | import showToast from "../../../services/toastService"; | ||||||
|  | import Label from "../../common/Label"; | ||||||
| 
 | 
 | ||||||
| const taskSchema = z.object({ | const taskSchema = z.object({ | ||||||
|   buildingID: z.string().min(1, "Building is required"), |   buildingID: z.string().min(1, "Building is required"), | ||||||
| @ -106,8 +107,8 @@ const TaskModel = ({ project, onSubmit, onClose }) => { | |||||||
|       <div className="text-center mb-1"> |       <div className="text-center mb-1"> | ||||||
|         <h5 className="mb-1">Manage Task</h5> |         <h5 className="mb-1">Manage Task</h5> | ||||||
|       </div> |       </div> | ||||||
|       <div className="col-6"> |       <div className="col-6 text-start"> | ||||||
|         <label className="form-label">Select Building</label> |         <Label className="form-label" required>Select Building</Label> | ||||||
|         <select |         <select | ||||||
|           className="form-select form-select-sm" |           className="form-select form-select-sm" | ||||||
|           {...register("buildingID")} |           {...register("buildingID")} | ||||||
| @ -128,8 +129,8 @@ const TaskModel = ({ project, onSubmit, onClose }) => { | |||||||
|       </div> |       </div> | ||||||
| 
 | 
 | ||||||
|       {selectedBuilding && ( |       {selectedBuilding && ( | ||||||
|         <div className="col-6"> |         <div className="col-6 text-start"> | ||||||
|           <label className="form-label">Select Floor</label> |           <Label className="form-label" required>Select Floor</Label> | ||||||
|           <select |           <select | ||||||
|             className="form-select form-select-sm" |             className="form-select form-select-sm" | ||||||
|             {...register("floorId")} |             {...register("floorId")} | ||||||
| @ -150,8 +151,8 @@ const TaskModel = ({ project, onSubmit, onClose }) => { | |||||||
|       )} |       )} | ||||||
| 
 | 
 | ||||||
|       {selectedFloor && ( |       {selectedFloor && ( | ||||||
|         <div className="col-12"> |         <div className="col-12 text-start"> | ||||||
|           <label className="form-label">Select Work Area</label> |           <Label className="form-label" required>Select Work Area</Label> | ||||||
|           <select |           <select | ||||||
|             className="form-select form-select-sm" |             className="form-select form-select-sm" | ||||||
|             {...register("workAreaId")} |             {...register("workAreaId")} | ||||||
| @ -172,8 +173,8 @@ const TaskModel = ({ project, onSubmit, onClose }) => { | |||||||
|       )} |       )} | ||||||
| 
 | 
 | ||||||
|       {selectedWorkArea && ( |       {selectedWorkArea && ( | ||||||
|         <div className="col-12"> |         <div className="col-12 text-start"> | ||||||
|           <label className="form-label">Select Activity</label> |           <Label className="form-label" required>Select Activity</Label> | ||||||
|           <select |           <select | ||||||
|             className="form-select form-select-sm" |             className="form-select form-select-sm" | ||||||
|             {...register("activityID")} |             {...register("activityID")} | ||||||
| @ -192,7 +193,7 @@ const TaskModel = ({ project, onSubmit, onClose }) => { | |||||||
|       )} |       )} | ||||||
| 
 | 
 | ||||||
|       {selectedWorkArea && ( |       {selectedWorkArea && ( | ||||||
|         <div className="col-12"> |         <div className="col-12 text-start"> | ||||||
|           <label className="form-label">Select Work Category</label> |           <label className="form-label">Select Work Category</label> | ||||||
|           <select |           <select | ||||||
|             className="form-select form-select-sm" |             className="form-select form-select-sm" | ||||||
| @ -212,8 +213,8 @@ const TaskModel = ({ project, onSubmit, onClose }) => { | |||||||
| 
 | 
 | ||||||
|       {selectedActivity && selectedCategory && ( |       {selectedActivity && selectedCategory && ( | ||||||
|         <> |         <> | ||||||
|           <div className="col-5"> |           <div className="col-5 text-start"> | ||||||
|             <label className="form-label">Planned Work</label> |             <Label className="form-label" required>Planned Work</Label> | ||||||
|             <input |             <input | ||||||
|               type="number" |               type="number" | ||||||
|               className="form-control form-control-sm" |               className="form-control form-control-sm" | ||||||
| @ -223,7 +224,7 @@ const TaskModel = ({ project, onSubmit, onClose }) => { | |||||||
|               <p className="danger-text">{errors.plannedWork.message}</p> |               <p className="danger-text">{errors.plannedWork.message}</p> | ||||||
|             )} |             )} | ||||||
|           </div> |           </div> | ||||||
|           <div className="col-5"> |           <div className="col-5 text-start"> | ||||||
|             <label className="form-label">Completed Work</label> |             <label className="form-label">Completed Work</label> | ||||||
|             <input |             <input | ||||||
|               type="number" |               type="number" | ||||||
| @ -234,7 +235,7 @@ const TaskModel = ({ project, onSubmit, onClose }) => { | |||||||
|               <p className="danger-text">{errors.completedWork.message}</p> |               <p className="danger-text">{errors.completedWork.message}</p> | ||||||
|             )} |             )} | ||||||
|           </div> |           </div> | ||||||
|           <div className="col-2"> |           <div className="col-2 text-start"> | ||||||
|             <label className="form-label">Unit</label> |             <label className="form-label">Unit</label> | ||||||
|             <input |             <input | ||||||
|               type="text" |               type="text" | ||||||
| @ -247,7 +248,7 @@ const TaskModel = ({ project, onSubmit, onClose }) => { | |||||||
|       )} |       )} | ||||||
| 
 | 
 | ||||||
|       {selectedActivity && selectedCategory && ( |       {selectedActivity && selectedCategory && ( | ||||||
|         <div className="col-12"> |         <div className="col-12 text-start"> | ||||||
|           <label className="form-label">Comment</label> |           <label className="form-label">Comment</label> | ||||||
|           <textarea |           <textarea | ||||||
|             className="form-control" |             className="form-control" | ||||||
| @ -260,21 +261,21 @@ const TaskModel = ({ project, onSubmit, onClose }) => { | |||||||
|         </div> |         </div> | ||||||
|       )} |       )} | ||||||
| 
 | 
 | ||||||
|       <div className="col-12 text-center"> |       <div className="col-12 text-end mt-5">         | ||||||
|         <button |  | ||||||
|           type="submit" |  | ||||||
|           className="btn btn-sm btn-primary me-3" |  | ||||||
|           disabled={isSubmitting} |  | ||||||
|         > |  | ||||||
|           {isSubmitting ? "Please Wait..." : "Add Task"} |  | ||||||
|         </button> |  | ||||||
|         <button |         <button | ||||||
|           type="button" |           type="button" | ||||||
|           className="btn btn-sm btn-label-secondary" |           className="btn btn-sm btn-label-secondary me-3" | ||||||
|           onClick={onClose} |           onClick={onClose} | ||||||
|         > |         > | ||||||
|           Cancel |           Cancel | ||||||
|         </button> |         </button> | ||||||
|  |         <button | ||||||
|  |           type="submit" | ||||||
|  |           className="btn btn-sm btn-primary" | ||||||
|  |           disabled={isSubmitting} | ||||||
|  |         > | ||||||
|  |           {isSubmitting ? "Please Wait..." : "Add Task"} | ||||||
|  |         </button> | ||||||
|       </div> |       </div> | ||||||
|     </form> |     </form> | ||||||
|   ); |   ); | ||||||
|  | |||||||
| @ -5,13 +5,14 @@ import { z } from "zod"; | |||||||
| import showToast from "../../../services/toastService"; | import showToast from "../../../services/toastService"; | ||||||
| import { useManageProjectInfra } from "../../../hooks/useProjects"; | import { useManageProjectInfra } from "../../../hooks/useProjects"; | ||||||
| import { useSelector } from "react-redux"; | import { useSelector } from "react-redux"; | ||||||
|  | import Label from "../../common/Label"; | ||||||
| 
 | 
 | ||||||
| const workAreaSchema = z.object({ | const workAreaSchema = z.object({ | ||||||
|   id: z.string().optional(), |   id: z.string().optional(), | ||||||
|   buildingId: z.string().refine((val) => val !== "0", { |   buildingId: z.string().refine((val) => val !== "0", { | ||||||
|   message: "Building is required", |     message: "Building is required", | ||||||
| }), |   }), | ||||||
|   floorId: z.string().refine((val)=>val !== "0",{message:"Floor is required"}), |   floorId: z.string().refine((val) => val !== "0", { message: "Floor is required" }), | ||||||
|   areaName: z.string().min(3, "Work Area Name must be at least 3 characters"), |   areaName: z.string().min(3, "Work Area Name must be at least 3 characters"), | ||||||
| }); | }); | ||||||
| 
 | 
 | ||||||
| @ -25,7 +26,7 @@ const defaultModel = { | |||||||
| const WorkAreaModel = ({ project, onSubmit, onClose }) => { | const WorkAreaModel = ({ project, onSubmit, onClose }) => { | ||||||
|   const [selectedBuilding, setSelectedBuilding] = useState(null); |   const [selectedBuilding, setSelectedBuilding] = useState(null); | ||||||
|   const [selectedFloor, setSelectedFloor] = useState(null); |   const [selectedFloor, setSelectedFloor] = useState(null); | ||||||
|  const selectedProject = useSelector((store)=>store.localVariables.projectId) |   const selectedProject = useSelector((store) => store.localVariables.projectId) | ||||||
|   const { |   const { | ||||||
|     register, |     register, | ||||||
|     handleSubmit, |     handleSubmit, | ||||||
| @ -84,8 +85,7 @@ const WorkAreaModel = ({ project, onSubmit, onClose }) => { | |||||||
|     reset(defaultModel); |     reset(defaultModel); | ||||||
|   }, []); |   }, []); | ||||||
| 
 | 
 | ||||||
|   const onSubmitForm = ( data ) => |   const onSubmitForm = (data) => { | ||||||
|   { |  | ||||||
|     const payload = { |     const payload = { | ||||||
|       id: data.id === "0" ? null : data.id, |       id: data.id === "0" ? null : data.id, | ||||||
|       areaName: data.areaName, |       areaName: data.areaName, | ||||||
| @ -108,51 +108,51 @@ const WorkAreaModel = ({ project, onSubmit, onClose }) => { | |||||||
|       <div className="text-center mb-1"> |       <div className="text-center mb-1"> | ||||||
|         <h5 className="mb-1">Manage Work Area</h5> |         <h5 className="mb-1">Manage Work Area</h5> | ||||||
|       </div> |       </div> | ||||||
|         <div className="col-12 col-sm-6"> |       <div className="col-12 col-sm-6 text-start"> | ||||||
|           <label className="form-label">Select Building</label> |         <Label className="form-label" required>Select Building</Label> | ||||||
|  |         <select | ||||||
|  |           {...register("buildingId")} | ||||||
|  |           className="form-select form-select-sm" | ||||||
|  |         > | ||||||
|  |           <option value="0">Select Building</option> | ||||||
|  |           {project?.map((b) => ( | ||||||
|  |             <option key={b.id} value={b.id}> | ||||||
|  |               {b.buildingName} | ||||||
|  |             </option> | ||||||
|  |           ))} | ||||||
|  |         </select> | ||||||
|  |         {errors.buildingId && ( | ||||||
|  |           <p className="danger-text">{errors.buildingId.message}</p> | ||||||
|  |         )} | ||||||
|  |       </div> | ||||||
|  | 
 | ||||||
|  |       {watchBuildingId !== "0" && ( | ||||||
|  |         <div className="col-12 col-sm-6 text-start"> | ||||||
|  |           <Label className="form-label" required>Select Floor</Label> | ||||||
|           <select |           <select | ||||||
|             {...register("buildingId")} |             {...register("floorId")} | ||||||
|             className="form-select form-select-sm" |             className="form-select form-select-sm" | ||||||
|           > |           > | ||||||
|             <option value="0">Select Building</option> |             <option value="0"> | ||||||
|             {project?.map((b) => ( |               {selectedBuilding?.floor?.length > 0 | ||||||
|               <option key={b.id} value={b.id}> |                 ? "NO Floor Found" | ||||||
|                 {b.buildingName} |                 : "Select Floor"} | ||||||
|  |             </option> | ||||||
|  | 
 | ||||||
|  |             {selectedBuilding?.floors?.map((f) => ( | ||||||
|  |               <option key={f.id} value={f.id}> | ||||||
|  |                 {f.floorName} | ||||||
|               </option> |               </option> | ||||||
|             ))} |             ))} | ||||||
|           </select> |           </select> | ||||||
|           {errors.buildingId && ( |           {errors.floorId && ( | ||||||
|             <p className="danger-text">{errors.buildingId.message}</p> |             <p className="danger-text">{errors.floorId.message}</p> | ||||||
|           )} |           )} | ||||||
|         </div> |         </div> | ||||||
| 
 |       )} | ||||||
|         {watchBuildingId !== "0" && ( |  | ||||||
|           <div className="col-12 col-sm-6"> |  | ||||||
|             <label className="form-label">Select Floor</label> |  | ||||||
|             <select |  | ||||||
|               {...register("floorId")} |  | ||||||
|               className="form-select form-select-sm" |  | ||||||
|             > |  | ||||||
|               <option value="0"> |  | ||||||
|                 {selectedBuilding?.floor?.length > 0 |  | ||||||
|                   ? "NO Floor Found" |  | ||||||
|                   : "Select Floor"} |  | ||||||
|               </option> |  | ||||||
| 
 |  | ||||||
|               {selectedBuilding?.floors?.map((f) => ( |  | ||||||
|                 <option key={f.id} value={f.id}> |  | ||||||
|                   {f.floorName} |  | ||||||
|                 </option> |  | ||||||
|               ))} |  | ||||||
|             </select> |  | ||||||
|             {errors.floorId && ( |  | ||||||
|               <p className="danger-text">{errors.floorId.message}</p> |  | ||||||
|             )} |  | ||||||
|           </div> |  | ||||||
|         )} |  | ||||||
|       {watchFloorId !== "0" && ( |       {watchFloorId !== "0" && ( | ||||||
|         <> |         <> | ||||||
|           <div className="col-12"> |           <div className="col-12 text-start"> | ||||||
|             <label className="form-label">Select Work Area</label> |             <label className="form-label">Select Work Area</label> | ||||||
|             <select |             <select | ||||||
|               {...register("id")} |               {...register("id")} | ||||||
| @ -169,12 +169,12 @@ const WorkAreaModel = ({ project, onSubmit, onClose }) => { | |||||||
|             </select> |             </select> | ||||||
|           </div> |           </div> | ||||||
| 
 | 
 | ||||||
|           <div className="col-12"> |           <div className="col-12 text-start"> | ||||||
|             <label className="form-label"> |             <Label className="form-label" required> | ||||||
|               {watchWorkAreaId === "0" |               {watchWorkAreaId === "0" | ||||||
|                 ? "Enter Work Area Name" |                 ? "Enter Work Area Name" | ||||||
|                 : "Edit Work Area Name"} |                 : "Edit Work Area Name"} | ||||||
|             </label> |             </Label> | ||||||
|             <input |             <input | ||||||
|               type="text" |               type="text" | ||||||
|               className="form-control form-control-sm" |               className="form-control form-control-sm" | ||||||
| @ -187,14 +187,15 @@ const WorkAreaModel = ({ project, onSubmit, onClose }) => { | |||||||
|           </div> |           </div> | ||||||
|         </> |         </> | ||||||
|       )} |       )} | ||||||
|        <div className="col-12 text-center"> |       <div className="col-12 text-end mt-5"> | ||||||
|             <button type="submit" className="btn btn-sm btn-primary me-3" disabled={isPending}> |         <button type="button" className="btn btn-sm btn-label-secondary me-3" disabled={isPending} onClick={onClose}> | ||||||
|               {isPending ? "Please Wait.." : watchWorkAreaId === "0" ? "Add Work Area" : "Update Work Area"} |           Cancel | ||||||
|             </button> |         </button> | ||||||
|             <button type="button" className="btn btn-sm btn-label-secondary" disabled={isPending} onClick={onClose}> |         <button type="submit" className="btn btn-sm btn-primary" disabled={isPending}> | ||||||
|               Cancel |           {isPending ? "Please Wait.." : watchWorkAreaId === "0" ? "Add Work Area" : "Update Work Area"} | ||||||
|             </button> |         </button> | ||||||
|           </div> |          | ||||||
|  |       </div> | ||||||
|     </form> |     </form> | ||||||
|   ); |   ); | ||||||
| }; | }; | ||||||
|  | |||||||
| @ -2,6 +2,7 @@ import React, { useEffect, useState } from "react"; | |||||||
| import { useForm, Controller } from "react-hook-form"; | import { useForm, Controller } from "react-hook-form"; | ||||||
| import { zodResolver } from "@hookform/resolvers/zod"; | import { zodResolver } from "@hookform/resolvers/zod"; | ||||||
| import { z } from "zod"; | import { z } from "zod"; | ||||||
|  | import Label from "../common/Label"; | ||||||
| 
 | 
 | ||||||
| const currentDate = new Date().toLocaleDateString('en-CA'); | const currentDate = new Date().toLocaleDateString('en-CA'); | ||||||
| const formatDate = (date) => { | const formatDate = (date) => { | ||||||
| @ -14,14 +15,14 @@ const formatDate = (date) => { | |||||||
|   } |   } | ||||||
|   return d.toLocaleDateString('en-CA'); |   return d.toLocaleDateString('en-CA'); | ||||||
| }; | }; | ||||||
| const ManageProjectInfo = ({ project, handleSubmitForm, onClose,isPending }) => { | const ManageProjectInfo = ({ project, handleSubmitForm, onClose, isPending }) => { | ||||||
|   const [CurrentProject, setCurrentProject] = useState(); |   const [CurrentProject, setCurrentProject] = useState(); | ||||||
|   const [addressLength, setAddressLength] = useState(0); |   const [addressLength, setAddressLength] = useState(0); | ||||||
|   const maxAddressLength = 500; |   const maxAddressLength = 500; | ||||||
| 
 | 
 | ||||||
| const ACTIVE_STATUS_ID = "b74da4c2-d07e-46f2-9919-e75e49b12731"; |   const ACTIVE_STATUS_ID = "b74da4c2-d07e-46f2-9919-e75e49b12731"; | ||||||
| const DEFAULT_EMPTY_STATUS_ID = "00000000-0000-0000-0000-000000000000"; |   const DEFAULT_EMPTY_STATUS_ID = "00000000-0000-0000-0000-000000000000"; | ||||||
|    | 
 | ||||||
|   const projectSchema = z |   const projectSchema = z | ||||||
|     .object({ |     .object({ | ||||||
|       ...(project?.id ? { id: z.string().optional() } : {}), |       ...(project?.id ? { id: z.string().optional() } : {}), | ||||||
| @ -93,15 +94,15 @@ const DEFAULT_EMPTY_STATUS_ID = "00000000-0000-0000-0000-000000000000"; | |||||||
|     reset( |     reset( | ||||||
|       project |       project | ||||||
|         ? { |         ? { | ||||||
|             id: project?.id || "", |           id: project?.id || "", | ||||||
|             name: project?.name || "", |           name: project?.name || "", | ||||||
|             shortName: project?.shortName || "", |           shortName: project?.shortName || "", | ||||||
|             contactPerson: project?.contactPerson || "", |           contactPerson: project?.contactPerson || "", | ||||||
|             projectAddress: project?.projectAddress || "", |           projectAddress: project?.projectAddress || "", | ||||||
|             startDate: formatDate(project?.startDate) || "", |           startDate: formatDate(project?.startDate) || "", | ||||||
|             endDate: formatDate(project?.endDate) || "", |           endDate: formatDate(project?.endDate) || "", | ||||||
|             projectStatusId: String(project?.projectStatus?.id) || "00000000-0000-0000-0000-000000000000", |           projectStatusId: String(project?.projectStatus?.id) || "00000000-0000-0000-0000-000000000000", | ||||||
|           } |         } | ||||||
|         : {} |         : {} | ||||||
|     ); |     ); | ||||||
|     setAddressLength(project?.projectAddress?.length || 0); |     setAddressLength(project?.projectAddress?.length || 0); | ||||||
| @ -115,9 +116,8 @@ const DEFAULT_EMPTY_STATUS_ID = "00000000-0000-0000-0000-000000000000"; | |||||||
| 
 | 
 | ||||||
|  */ |  */ | ||||||
| 
 | 
 | ||||||
|   const onSubmitForm = ( updatedProject ) => |   const onSubmitForm = (updatedProject) => { | ||||||
|   { | 
 | ||||||
|      |  | ||||||
|     handleSubmitForm(updatedProject); |     handleSubmitForm(updatedProject); | ||||||
|   }; |   }; | ||||||
| 
 | 
 | ||||||
| @ -137,197 +137,202 @@ const DEFAULT_EMPTY_STATUS_ID = "00000000-0000-0000-0000-000000000000"; | |||||||
| 
 | 
 | ||||||
|   return ( |   return ( | ||||||
| 
 | 
 | ||||||
|         <div className="p-sm-2 p-2"> |     <div className="p-sm-2 p-2"> | ||||||
|       |  | ||||||
|           <div className="text-center mb-2"> |  | ||||||
|             <h5 className="mb-2"> |  | ||||||
|               {project?.id ? "Edit Project" : "Create Project"} |  | ||||||
|             </h5> |  | ||||||
|           </div> |  | ||||||
|           <form className="row g-2" onSubmit={handleSubmit(onSubmitForm)}> |  | ||||||
|             <div className="col-12 col-md-12"> |  | ||||||
|               <label className="form-label" htmlFor="name"> |  | ||||||
|                 Project Name |  | ||||||
|               </label> |  | ||||||
|               <input |  | ||||||
|                 type="text" |  | ||||||
|                 id="name" |  | ||||||
|                 name="name" |  | ||||||
|                 className="form-control form-control-sm" |  | ||||||
|                 placeholder="Project Name" |  | ||||||
|                 {...register("name")} |  | ||||||
|               /> |  | ||||||
|               {errors.name && ( |  | ||||||
|                 <div |  | ||||||
|                   className="danger-text text-start" |  | ||||||
|                   style={{ fontSize: "12px" }} |  | ||||||
|                 > |  | ||||||
|                   {errors.name.message} |  | ||||||
|                 </div> |  | ||||||
|               )} |  | ||||||
|             </div> |  | ||||||
|             <div className="col-12 col-md-12"> |  | ||||||
|               <label className="form-label" htmlFor="shortName"> |  | ||||||
|                 Short Name |  | ||||||
|               </label> |  | ||||||
|               <input |  | ||||||
|                 type="text" |  | ||||||
|                 id="shortName" |  | ||||||
|                 name="shortName" |  | ||||||
|                 className="form-control form-control-sm" |  | ||||||
|                 placeholder="Short Name" |  | ||||||
|                 {...register("shortName")} |  | ||||||
|               /> |  | ||||||
|               {errors.shortName && ( |  | ||||||
|                 <div |  | ||||||
|                   className="danger-text text-start" |  | ||||||
|                   style={{ fontSize: "12px" }} |  | ||||||
|                 > |  | ||||||
|                   {errors.shortName.message} |  | ||||||
|                 </div> |  | ||||||
|               )} |  | ||||||
|             </div> |  | ||||||
|             <div className="col-12 col-md-12"> |  | ||||||
|               <label className="form-label" htmlFor="contactPerson"> |  | ||||||
|                 Contact Person |  | ||||||
|               </label> |  | ||||||
|               <input |  | ||||||
|                 type="text" |  | ||||||
|                 id="contactPerson" |  | ||||||
|                 name="contactPerson" |  | ||||||
|                 className="form-control form-control-sm" |  | ||||||
|                 placeholder="Contact Person" |  | ||||||
|                 maxLength={50} |  | ||||||
|                 {...register("contactPerson")} |  | ||||||
|               /> |  | ||||||
|               {errors.contactPerson && ( |  | ||||||
|                 <div |  | ||||||
|                   className="danger-text text-start" |  | ||||||
|                   style={{ fontSize: "12px" }} |  | ||||||
|                 > |  | ||||||
|                   {errors.contactPerson.message} |  | ||||||
|                 </div> |  | ||||||
|               )} |  | ||||||
|             </div> |  | ||||||
| 
 | 
 | ||||||
|             <div className="col-12 col-md-6"> |       <div className="text-center mb-2"> | ||||||
|               <label className="form-label" htmlFor="startDate"> |         <h5 className="mb-2"> | ||||||
|                 Start Date |           {project?.id ? "Edit Project" : "Create Project"} | ||||||
|               </label> |         </h5> | ||||||
|               <input |       </div> | ||||||
|                 className="form-control form-control-sm" |       <form className="row g-2 text-start" onSubmit={handleSubmit(onSubmitForm)}> | ||||||
|                 type="date" |         <div className="col-12 col-md-12"> | ||||||
|                 name="startDate" |           <Label htmlFor="name" required> | ||||||
|                 {...register("startDate")} |             Project Name | ||||||
|                 id="startDate" |           </Label> | ||||||
|               /> |           <input | ||||||
|               {errors.startDate && ( |             type="text" | ||||||
|                 <div |             id="name" | ||||||
|                   className="danger-text text-start" |             name="name" | ||||||
|                   style={{ fontSize: "12px" }} |             className="form-control form-control-sm" | ||||||
|                 > |             placeholder="Project Name" | ||||||
|                   {errors.startDate.message} |             {...register("name")} | ||||||
|                 </div> |           /> | ||||||
|               )} |           {errors.name && ( | ||||||
|  |             <div | ||||||
|  |               className="danger-text text-start" | ||||||
|  |               style={{ fontSize: "12px" }} | ||||||
|  |             > | ||||||
|  |               {errors.name.message} | ||||||
|             </div> |             </div> | ||||||
|             <div className="col-12 col-md-6"> |           )} | ||||||
|               <label className="form-label" htmlFor="endDate"> |  | ||||||
|                 End Date |  | ||||||
|               </label> |  | ||||||
|               <input |  | ||||||
|                 className="form-control form-control-sm" |  | ||||||
|                 type="date" |  | ||||||
|                 name="endDate" |  | ||||||
|                 {...register("endDate")} |  | ||||||
|                 id="endDate" |  | ||||||
|               /> |  | ||||||
|               {errors.endDate && ( |  | ||||||
|                 <div |  | ||||||
|                   className="danger-text text-start" |  | ||||||
|                   style={{ fontSize: "12px" }} |  | ||||||
|                 > |  | ||||||
|                   {errors.endDate.message} |  | ||||||
|                 </div> |  | ||||||
|               )} |  | ||||||
|             </div> |  | ||||||
|             <div className="col-12 col-md-6"> |  | ||||||
|               <label className="form-label" htmlFor="modalEditUserStatus"> |  | ||||||
|                 Status |  | ||||||
|               </label> |  | ||||||
|               <select |  | ||||||
|                 id="modalEditUserStatus" |  | ||||||
|                 name="modalEditUserStatus" |  | ||||||
|                 className="select2 form-select form-select-sm" |  | ||||||
|                 aria-label="Default select example" |  | ||||||
|                 {...register("projectStatusId", { |  | ||||||
|                   required: "Status is required", |  | ||||||
|                   valueAsNumber: false, |  | ||||||
|                 })} |  | ||||||
|               > |  | ||||||
|                 {/* <option disabled>Status</option> |  | ||||||
|                 <option value="b74da4c2-d07e-46f2-9919-e75e49b12731">Active</option> */} |  | ||||||
|                 <option value={ACTIVE_STATUS_ID}>Active</option> |  | ||||||
|                 <option value="603e994b-a27f-4e5d-a251-f3d69b0498ba">On Hold</option> |  | ||||||
| 
 |  | ||||||
|                 <option value="cdad86aa-8a56-4ff4-b633-9c629057dfef">In Progress</option> |  | ||||||
|                 <option value="ef1c356e-0fe0-42df-a5d3-8daee355492d">Inactive</option> |  | ||||||
| 
 |  | ||||||
|                 <option value="33deaef9-9af1-4f2a-b443-681ea0d04f81">Completed</option> |  | ||||||
|               </select> |  | ||||||
|               {errors.projectStatusId && ( |  | ||||||
|                 <div |  | ||||||
|                   className="danger-text text-start" |  | ||||||
|                   style={{ fontSize: "12px" }} |  | ||||||
|                 > |  | ||||||
|                   {errors.projectStatusId.message} |  | ||||||
|                 </div> |  | ||||||
|               )} |  | ||||||
|             </div> |  | ||||||
| 
 |  | ||||||
|             <div className="col-12 col-md-12"> |  | ||||||
|               <label className="form-label" htmlFor="projectAddress"> |  | ||||||
|                 Project Address |  | ||||||
|               </label> |  | ||||||
|               <div className="input-group"> |  | ||||||
|                 <textarea |  | ||||||
|                   id="projectAddress" |  | ||||||
|                   name="projectAddress" |  | ||||||
|                   className="form-control" |  | ||||||
|                   maxLength={maxAddressLength} |  | ||||||
|                   {...register("projectAddress")} |  | ||||||
|                   onChange={(e) => { |  | ||||||
|                     setAddressLength(e.target.value.length); |  | ||||||
|                   }} |  | ||||||
|                 /> |  | ||||||
|               </div> |  | ||||||
|               <div className="text-end" style={{ fontSize: "12px" }}> |  | ||||||
|                 {maxAddressLength - addressLength} characters left |  | ||||||
|               </div> |  | ||||||
|               {errors.projectAddress && ( |  | ||||||
|                 <div |  | ||||||
|                   className="danger-text text-start" |  | ||||||
|                   style={{ fontSize: "12px" }} |  | ||||||
|                 > |  | ||||||
|                   {errors.projectAddress.message} |  | ||||||
|                 </div> |  | ||||||
|               )} |  | ||||||
|             </div> |  | ||||||
|             <div className="col-12 text-center"> |  | ||||||
|               <button type="submit" className="btn btn-sm btn-primary me-3" disabled={isPending}> |  | ||||||
|                 {isPending ? "Please Wait..." : project?.id ? "Update" : "Submit"} |  | ||||||
|               </button> |  | ||||||
|               <button |  | ||||||
|                 type="button" |  | ||||||
|                 className="btn btn-sm btn-label-secondary" |  | ||||||
|                 onClick={handleCancel} |  | ||||||
|                 aria-label="Close" |  | ||||||
|                 disabled={isPending} |  | ||||||
|               > |  | ||||||
|                 Cancel |  | ||||||
|               </button> |  | ||||||
|             </div> |  | ||||||
|           </form> |  | ||||||
|         </div> |         </div> | ||||||
|  |         <div className="col-12 col-md-12"> | ||||||
|  |           <label className="form-label" htmlFor="shortName"> | ||||||
|  |             Short Name | ||||||
|  |           </label> | ||||||
|  |           <input | ||||||
|  |             type="text" | ||||||
|  |             id="shortName" | ||||||
|  |             name="shortName" | ||||||
|  |             className="form-control form-control-sm" | ||||||
|  |             placeholder="Short Name" | ||||||
|  |             {...register("shortName")} | ||||||
|  |           /> | ||||||
|  |           {errors.shortName && ( | ||||||
|  |             <div | ||||||
|  |               className="danger-text text-start" | ||||||
|  |               style={{ fontSize: "12px" }} | ||||||
|  |             > | ||||||
|  |               {errors.shortName.message} | ||||||
|  |             </div> | ||||||
|  |           )} | ||||||
|  |         </div> | ||||||
|  |         <div className="col-12 col-md-12"> | ||||||
|  |           <Label htmlFor="contactPerson" required> | ||||||
|  |             Contact Person | ||||||
|  |           </Label> | ||||||
|  |           <input | ||||||
|  |             type="text" | ||||||
|  |             id="contactPerson" | ||||||
|  |             name="contactPerson" | ||||||
|  |             className="form-control form-control-sm" | ||||||
|  |             placeholder="Contact Person" | ||||||
|  |             maxLength={50} | ||||||
|  |             {...register("contactPerson")} | ||||||
|  |           /> | ||||||
|  |           {errors.contactPerson && ( | ||||||
|  |             <div | ||||||
|  |               className="danger-text text-start" | ||||||
|  |               style={{ fontSize: "12px" }} | ||||||
|  |             > | ||||||
|  |               {errors.contactPerson.message} | ||||||
|  |             </div> | ||||||
|  |           )} | ||||||
|  |         </div> | ||||||
|  | 
 | ||||||
|  |         <div className="col-12 col-md-6"> | ||||||
|  |           <label className="form-label" htmlFor="startDate"> | ||||||
|  |             Start Date | ||||||
|  |           </label> | ||||||
|  |           <input | ||||||
|  |             className="form-control form-control-sm" | ||||||
|  |             type="date" | ||||||
|  |             name="startDate" | ||||||
|  |             {...register("startDate")} | ||||||
|  |             id="startDate" | ||||||
|  |           /> | ||||||
|  |           {errors.startDate && ( | ||||||
|  |             <div | ||||||
|  |               className="danger-text text-start" | ||||||
|  |               style={{ fontSize: "12px" }} | ||||||
|  |             > | ||||||
|  |               {errors.startDate.message} | ||||||
|  |             </div> | ||||||
|  |           )} | ||||||
|  |         </div> | ||||||
|  |         <div className="col-12 col-md-6"> | ||||||
|  |           <label className="form-label" htmlFor="endDate"> | ||||||
|  |             End Date | ||||||
|  |           </label> | ||||||
|  |           <input | ||||||
|  |             className="form-control form-control-sm" | ||||||
|  |             type="date" | ||||||
|  |             name="endDate" | ||||||
|  |             {...register("endDate")} | ||||||
|  |             id="endDate" | ||||||
|  |           /> | ||||||
|  |           {errors.endDate && ( | ||||||
|  |             <div | ||||||
|  |               className="danger-text text-start" | ||||||
|  |               style={{ fontSize: "12px" }} | ||||||
|  |             > | ||||||
|  |               {errors.endDate.message} | ||||||
|  |             </div> | ||||||
|  |           )} | ||||||
|  |         </div> | ||||||
|  |         <div className="col-12 col-md-6"> | ||||||
|  |           <label className="form-label" htmlFor="modalEditUserStatus"> | ||||||
|  |             Status | ||||||
|  |           </label> | ||||||
|  |           <select | ||||||
|  |             id="modalEditUserStatus" | ||||||
|  |             name="modalEditUserStatus" | ||||||
|  |             className="select2 form-select form-select-sm" | ||||||
|  |             aria-label="Default select example" | ||||||
|  |             {...register("projectStatusId", { | ||||||
|  |               required: "Status is required", | ||||||
|  |               valueAsNumber: false, | ||||||
|  |             })} | ||||||
|  |           > | ||||||
|  |             {/* <option disabled>Status</option> | ||||||
|  |                 <option value="b74da4c2-d07e-46f2-9919-e75e49b12731">Active</option> */} | ||||||
|  |             <option value={ACTIVE_STATUS_ID}>Active</option> | ||||||
|  |             <option value="603e994b-a27f-4e5d-a251-f3d69b0498ba">On Hold</option> | ||||||
|  | 
 | ||||||
|  |             <option value="cdad86aa-8a56-4ff4-b633-9c629057dfef">In Progress</option> | ||||||
|  |             <option value="ef1c356e-0fe0-42df-a5d3-8daee355492d">Inactive</option> | ||||||
|  | 
 | ||||||
|  |             <option value="33deaef9-9af1-4f2a-b443-681ea0d04f81">Completed</option> | ||||||
|  |           </select> | ||||||
|  |           {errors.projectStatusId && ( | ||||||
|  |             <div | ||||||
|  |               className="danger-text text-start" | ||||||
|  |               style={{ fontSize: "12px" }} | ||||||
|  |             > | ||||||
|  |               {errors.projectStatusId.message} | ||||||
|  |             </div> | ||||||
|  |           )} | ||||||
|  |         </div> | ||||||
|  | 
 | ||||||
|  |         <div className="col-12 col-md-12"> | ||||||
|  |           <Label htmlFor="projectAddress" required> | ||||||
|  |             Project Address | ||||||
|  |           </Label> | ||||||
|  |           <div className="input-group"> | ||||||
|  |             <textarea | ||||||
|  |               id="projectAddress" | ||||||
|  |               name="projectAddress" | ||||||
|  |               className="form-control" | ||||||
|  |               maxLength={maxAddressLength} | ||||||
|  |               {...register("projectAddress")} | ||||||
|  |               onChange={(e) => { | ||||||
|  |                 setAddressLength(e.target.value.length); | ||||||
|  |               }} | ||||||
|  |             /> | ||||||
|  |           </div> | ||||||
|  |           <div className="text-end" style={{ fontSize: "12px" }}> | ||||||
|  |             {maxAddressLength - addressLength} characters left | ||||||
|  |           </div> | ||||||
|  |           {errors.projectAddress && ( | ||||||
|  |             <div | ||||||
|  |               className="danger-text text-start" | ||||||
|  |               style={{ fontSize: "12px" }} | ||||||
|  |             > | ||||||
|  |               {errors.projectAddress.message} | ||||||
|  |             </div> | ||||||
|  |           )} | ||||||
|  |         </div> | ||||||
|  |         <div className="col-12 text-end mt-4"> | ||||||
|  |           <button | ||||||
|  |             type="button" | ||||||
|  |             className="btn btn-label-secondary btn-sm me-2" | ||||||
|  |             onClick={handleCancel} | ||||||
|  |             aria-label="Close" | ||||||
|  |             disabled={isPending} | ||||||
|  |           > | ||||||
|  |             Cancel | ||||||
|  |           </button> | ||||||
|  |           <button | ||||||
|  |             type="submit" | ||||||
|  |             className="btn btn-primary btn-sm" | ||||||
|  |             disabled={isPending} | ||||||
|  |           > | ||||||
|  |             {isPending ? "Please Wait..." : project?.id ? "Update" : "Submit"} | ||||||
|  |           </button> | ||||||
|  |         </div> | ||||||
|  | 
 | ||||||
|  |       </form> | ||||||
|  |     </div> | ||||||
|   ); |   ); | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -118,22 +118,22 @@ const MapUsers = ({ | |||||||
|         <div className="modal-content"> |         <div className="modal-content"> | ||||||
|           <div className="modal-header text-center"> |           <div className="modal-header text-center"> | ||||||
|             <button type="button" className="btn-close" data-bs-dismiss="modal" aria-label="Close"> |             <button type="button" className="btn-close" data-bs-dismiss="modal" aria-label="Close"> | ||||||
|           </button> |             </button> | ||||||
|           </div> |           </div> | ||||||
|           <p className="m-0 fw-semibold fs-5">Assign Employee</p> |           <p className="m-0 fw-semibold fs-5">Assign Employee</p> | ||||||
| 
 | 
 | ||||||
|           <div className="px-4 mt-4 col-md-4 text-start"> |           <div className="px-4 mt-4 col-md-4 text-start"> | ||||||
|             {(filteredData.length > 0 || |             {(filteredData.length > 0 || | ||||||
|               allocationEmployeesData.length > 0) && ( |               allocationEmployeesData.length > 0) && ( | ||||||
|               <div className="input-group input-group-sm mb-2"> |                 <div className="input-group input-group-sm mb-2"> | ||||||
|                 <input |                   <input | ||||||
|                   type="search" |                     type="search" | ||||||
|                   className="form-control" |                     className="form-control" | ||||||
|                   placeholder="Search employees..." |                     placeholder="Search employees..." | ||||||
|                   onChange={(e) => setSearchQuery(e.target.value)} |                     onChange={(e) => setSearchQuery(e.target.value)} | ||||||
|                 /> |                   /> | ||||||
|               </div> |                 </div> | ||||||
|             )} |               )} | ||||||
| 
 | 
 | ||||||
|             <p className="mb-0 small text-muted fw-semibold">Select Employee</p> |             <p className="mb-0 small text-muted fw-semibold">Select Employee</p> | ||||||
|           </div> |           </div> | ||||||
| @ -183,24 +183,24 @@ const MapUsers = ({ | |||||||
|               </tbody> |               </tbody> | ||||||
|             </table> |             </table> | ||||||
|           </div> |           </div> | ||||||
|           <div className="modal-footer"> |           <div className="modal-footer mt-5 d-flex justify-content-end gap-0"> | ||||||
|             {(filteredData.length > 0 || |  | ||||||
|               allocationEmployeesData.length > 0) && ( |  | ||||||
|               <button className="btn btn-sm btn-success" onClick={handleSubmit}> |  | ||||||
|                 {assignedLoading ? "Please Wait..." : "Assign to Project"} |  | ||||||
|               </button> |  | ||||||
|             )} |  | ||||||
| 
 |  | ||||||
|             <button |             <button | ||||||
|               type="button" |               type="button" | ||||||
|               className="btn btn-sm btn-secondary" |               className="btn btn-sm btn-label-secondary" | ||||||
|               data-dismiss="modal" |               data-dismiss="modal" | ||||||
|               aria-label="Close" |               aria-label="Close" | ||||||
|               onClick={onClose} |               onClick={onClose} | ||||||
|             > |             > | ||||||
|               Cancel |               Cancel | ||||||
|             </button> |             </button> | ||||||
|  | 
 | ||||||
|  |             {(filteredData.length > 0 || allocationEmployeesData.length > 0) && ( | ||||||
|  |               <button className="btn btn-sm btn-primary" onClick={handleSubmit}> | ||||||
|  |                 {assignedLoading ? "Please Wait..." : "Assign to Project"} | ||||||
|  |               </button> | ||||||
|  |             )} | ||||||
|           </div> |           </div> | ||||||
|  | 
 | ||||||
|         </div> |         </div> | ||||||
|       </div> |       </div> | ||||||
|     </> |     </> | ||||||
|  | |||||||
| @ -24,7 +24,7 @@ const ContactInfro = ({ onNext }) => { | |||||||
|     } |     } | ||||||
|   }; |   }; | ||||||
|   return ( |   return ( | ||||||
|     <div className="row g-6"> |     <div className="row g-6 text-start"> | ||||||
|       <div className="col-sm-6"> |       <div className="col-sm-6"> | ||||||
|         <Label htmlFor="firstName" required> |         <Label htmlFor="firstName" required> | ||||||
|           First Name |           First Name | ||||||
|  | |||||||
| @ -56,7 +56,7 @@ const OrganizationInfo = ({ onNext, onPrev, onSubmitTenant }) => { | |||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
|   return ( |   return ( | ||||||
|     <div className="row g-2"> |     <div className="row g-2 text-start"> | ||||||
|       <div className="col-sm-6"> |       <div className="col-sm-6"> | ||||||
|         <Label htmlFor="organizationName" required> |         <Label htmlFor="organizationName" required> | ||||||
|           Organization Name |           Organization Name | ||||||
| @ -217,10 +217,10 @@ const OrganizationInfo = ({ onNext, onPrev, onSubmitTenant }) => { | |||||||
|         /> |         /> | ||||||
|       </div> |       </div> | ||||||
| 
 | 
 | ||||||
|       <div className="d-flex justify-content-between mt-3"> |       <div className="d-flex justify-content-end mt-3"> | ||||||
|         <button |         <button | ||||||
|           type="button" |           type="button" | ||||||
|           className="btn btn-sm btn-secondary" |           className="btn btn-sm btn-secondary me-3" | ||||||
|           onClick={onPrev} |           onClick={onPrev} | ||||||
|           disabled={isPending} |           disabled={isPending} | ||||||
|         > |         > | ||||||
|  | |||||||
| @ -233,7 +233,7 @@ const SubScription = ({ onSubmitSubScription, onNext }) => { | |||||||
|             </div> |             </div> | ||||||
|           )} |           )} | ||||||
| 
 | 
 | ||||||
|           <div className="d-flex text-center mt-4"> |           <div className="d-flex text-end mt-4"> | ||||||
|             <button |             <button | ||||||
|               onClick={handleSubscriptionSubmit} |               onClick={handleSubscriptionSubmit} | ||||||
|               className="btn btn-sm btn-primary" |               className="btn btn-sm btn-primary" | ||||||
|  | |||||||
| @ -1,5 +1,6 @@ | |||||||
| import { useFormContext, useWatch } from "react-hook-form"; | import { useFormContext, useWatch } from "react-hook-form"; | ||||||
| import React, { useEffect, useState } from "react"; | import React, { useEffect, useState } from "react"; | ||||||
|  | import Label from "./Label"; | ||||||
| 
 | 
 | ||||||
| const TagInput = ({ | const TagInput = ({ | ||||||
|   label = "Tags", |   label = "Tags", | ||||||
| @ -108,9 +109,9 @@ useEffect(() => { | |||||||
| 
 | 
 | ||||||
|   return ( |   return ( | ||||||
|     <> |     <> | ||||||
|       <label htmlFor={name} className="form-label"> |       <Label htmlFor={name} className="form-label" required> | ||||||
|         {label} |         {label} | ||||||
|       </label> |       </Label> | ||||||
| 
 | 
 | ||||||
|       <div |       <div | ||||||
|         className="form-control form-control-sm p-1" |         className="form-control form-control-sm p-1" | ||||||
|  | |||||||
| @ -1,4 +1,4 @@ | |||||||
| import React, { useState, useEffect,useCallback } from "react"; | import React, { useState, useEffect, useCallback } from "react"; | ||||||
| import { useFieldArray, useForm } from "react-hook-form"; | import { useFieldArray, useForm } from "react-hook-form"; | ||||||
| import { z } from "zod"; | import { z } from "zod"; | ||||||
| import { zodResolver } from "@hookform/resolvers/zod"; | import { zodResolver } from "@hookform/resolvers/zod"; | ||||||
| @ -7,7 +7,8 @@ import { MasterRespository } from "../../repositories/MastersRepository"; | |||||||
| import { clearApiCacheKey } from "../../slices/apiCacheSlice"; | import { clearApiCacheKey } from "../../slices/apiCacheSlice"; | ||||||
| import { getCachedData, cacheData } from "../../slices/apiDataManager"; | import { getCachedData, cacheData } from "../../slices/apiDataManager"; | ||||||
| import showToast from "../../services/toastService"; | import showToast from "../../services/toastService"; | ||||||
| import {useCreateActivity} from "../../hooks/masterHook/useMaster"; | import { useCreateActivity } from "../../hooks/masterHook/useMaster"; | ||||||
|  | import Label from "../common/Label"; | ||||||
| 
 | 
 | ||||||
| const schema = z.object({ | const schema = z.object({ | ||||||
|   activityName: z.string().min(1, { message: "Activity Name is required" }), |   activityName: z.string().min(1, { message: "Activity Name is required" }), | ||||||
| @ -24,74 +25,74 @@ const schema = z.object({ | |||||||
| }); | }); | ||||||
| 
 | 
 | ||||||
| const CreateActivity = ({ onClose }) => { | const CreateActivity = ({ onClose }) => { | ||||||
| const maxDescriptionLength = 255; |   const maxDescriptionLength = 255; | ||||||
| const { mutate: createActivity, isPending: isLoading } = useCreateActivity(() => onClose?.()); |   const { mutate: createActivity, isPending: isLoading } = useCreateActivity(() => onClose?.()); | ||||||
| 
 | 
 | ||||||
| const { |   const { | ||||||
|   register, |     register, | ||||||
|   handleSubmit, |     handleSubmit, | ||||||
|   control, |     control, | ||||||
|   setValue, |     setValue, | ||||||
|   clearErrors, |     clearErrors, | ||||||
|   setError, |     setError, | ||||||
|   getValues, |     getValues, | ||||||
|   reset, |     reset, | ||||||
|   formState: { errors }, |     formState: { errors }, | ||||||
| } = useForm({ |   } = useForm({ | ||||||
|   resolver: zodResolver(schema), |     resolver: zodResolver(schema), | ||||||
|   defaultValues: { |     defaultValues: { | ||||||
|     activityName: "", |       activityName: "", | ||||||
|     unitOfMeasurement: "", |       unitOfMeasurement: "", | ||||||
|     checkList: [], |       checkList: [], | ||||||
|   }, |     }, | ||||||
| }); |   }); | ||||||
| 
 | 
 | ||||||
| const { |   const { | ||||||
|   fields: checkListItems, |     fields: checkListItems, | ||||||
|   append, |     append, | ||||||
|   remove, |     remove, | ||||||
| } = useFieldArray({ |   } = useFieldArray({ | ||||||
|   control, |     control, | ||||||
|   name: "checkList", |     name: "checkList", | ||||||
| }); |   }); | ||||||
| 
 | 
 | ||||||
| const addChecklistItem = useCallback(() => { |   const addChecklistItem = useCallback(() => { | ||||||
|   const values = getValues("checkList"); |     const values = getValues("checkList"); | ||||||
|   const lastIndex = checkListItems.length - 1; |     const lastIndex = checkListItems.length - 1; | ||||||
| 
 | 
 | ||||||
|   if ( |     if ( | ||||||
|     checkListItems.length > 0 && |       checkListItems.length > 0 && | ||||||
|     (!values?.[lastIndex] || values[lastIndex].description.trim() === "") |       (!values?.[lastIndex] || values[lastIndex].description.trim() === "") | ||||||
|   ) { |     ) { | ||||||
|     setError(`checkList.${lastIndex}.description`, { |       setError(`checkList.${lastIndex}.description`, { | ||||||
|       type: "manual", |         type: "manual", | ||||||
|       message: "Please fill this checklist item before adding another.", |         message: "Please fill this checklist item before adding another.", | ||||||
|     }); |       }); | ||||||
|     return; |       return; | ||||||
|   } |     } | ||||||
| 
 | 
 | ||||||
|   clearErrors(`checkList.${lastIndex}.description`); |     clearErrors(`checkList.${lastIndex}.description`); | ||||||
|   append({ id: null, description: "", isMandatory: false }); |     append({ id: null, description: "", isMandatory: false }); | ||||||
| }, [checkListItems, getValues, append, setError, clearErrors]); |   }, [checkListItems, getValues, append, setError, clearErrors]); | ||||||
| 
 | 
 | ||||||
| const removeChecklistItem = useCallback((index) => { |   const removeChecklistItem = useCallback((index) => { | ||||||
|   remove(index); |     remove(index); | ||||||
| }, [remove]); |   }, [remove]); | ||||||
| 
 | 
 | ||||||
| const handleChecklistChange = useCallback((index, value) => { |   const handleChecklistChange = useCallback((index, value) => { | ||||||
|   setValue(`checkList.${index}`, value); |     setValue(`checkList.${index}`, value); | ||||||
| }, [setValue]); |   }, [setValue]); | ||||||
| 
 | 
 | ||||||
| const onSubmit = (formData) => { |   const onSubmit = (formData) => { | ||||||
|   createActivity(formData); |     createActivity(formData); | ||||||
| }; |   }; | ||||||
|   // const onSubmit = (data) => { |   // const onSubmit = (data) => { | ||||||
|   //   setIsLoading(true); |   //   setIsLoading(true); | ||||||
| 
 | 
 | ||||||
|   //   MasterRespository.createActivity(data) |   //   MasterRespository.createActivity(data) | ||||||
|   //     .then( ( resp ) => |   //     .then( ( resp ) => | ||||||
|   //     { |   //     { | ||||||
|          | 
 | ||||||
|   //       const cachedData = getCachedData("Activity"); |   //       const cachedData = getCachedData("Activity"); | ||||||
|   //       const updatedData = [ ...cachedData, resp?.data ]; |   //       const updatedData = [ ...cachedData, resp?.data ]; | ||||||
|   //       cacheData("Activity", updatedData); |   //       cacheData("Activity", updatedData); | ||||||
| @ -104,42 +105,40 @@ const onSubmit = (formData) => { | |||||||
|   //       setIsLoading(false); |   //       setIsLoading(false); | ||||||
|   //     }); |   //     }); | ||||||
|   // }; |   // }; | ||||||
| const handleClose = useCallback(() => { |   const handleClose = useCallback(() => { | ||||||
|   reset(); |     reset(); | ||||||
|   onClose(); |     onClose(); | ||||||
| }, [reset, onClose]); |   }, [reset, onClose]); | ||||||
| 
 | 
 | ||||||
| useEffect(() => { |   useEffect(() => { | ||||||
|   const tooltipTriggerList = Array.from(document.querySelectorAll('[data-bs-toggle="tooltip"]')); |     const tooltipTriggerList = Array.from(document.querySelectorAll('[data-bs-toggle="tooltip"]')); | ||||||
|   tooltipTriggerList.forEach((el) => new bootstrap.Tooltip(el)); |     tooltipTriggerList.forEach((el) => new bootstrap.Tooltip(el)); | ||||||
| }, []); |   }, []); | ||||||
| 
 | 
 | ||||||
|   return ( |   return ( | ||||||
|     <form onSubmit={handleSubmit(onSubmit)}> |     <form onSubmit={handleSubmit(onSubmit)}> | ||||||
|       {/* <h6>Create Activity</h6> */} |       {/* <h6>Create Activity</h6> */} | ||||||
|       <div className="row"> |       <div className="row"> | ||||||
|         <div className="col-6"> |         <div className="col-6 text-start"> | ||||||
|           <label className="form-label">Activity</label> |           <Label className="form-label" required>Activity</Label> | ||||||
|           <input |           <input | ||||||
|             type="text" |             type="text" | ||||||
|             {...register("activityName")} |             {...register("activityName")} | ||||||
|             className={`form-control form-control-sm ${ |             className={`form-control form-control-sm ${errors.activityName ? "is-invalid" : "" | ||||||
|               errors.activityName ? "is-invalid" : "" |               }`} | ||||||
|             }`} |  | ||||||
|           /> |           /> | ||||||
|           {errors.activityName && ( |           {errors.activityName && ( | ||||||
|             <p className="danger-text">{errors.activityName.message}</p> |             <p className="danger-text">{errors.activityName.message}</p> | ||||||
|           )} |           )} | ||||||
|         </div> |         </div> | ||||||
| 
 | 
 | ||||||
|         <div className="col-6"> |         <div className="col-6 text-start"> | ||||||
|           <label className="form-label">Measurement</label> |           <Label className="form-label" required>Measurement</Label> | ||||||
|           <input |           <input | ||||||
|             type="text" |             type="text" | ||||||
|             {...register("unitOfMeasurement")} |             {...register("unitOfMeasurement")} | ||||||
|             className={`form-control form-control-sm ${ |             className={`form-control form-control-sm ${errors.unitOfMeasurement ? "is-invalid" : "" | ||||||
|               errors.unitOfMeasurement ? "is-invalid" : "" |               }`} | ||||||
|             }`} |  | ||||||
|           /> |           /> | ||||||
|           {errors.unitOfMeasurement && ( |           {errors.unitOfMeasurement && ( | ||||||
|             <p className="danger-text">{errors.unitOfMeasurement.message}</p> |             <p className="danger-text">{errors.unitOfMeasurement.message}</p> | ||||||
| @ -147,68 +146,68 @@ useEffect(() => { | |||||||
|         </div> |         </div> | ||||||
| 
 | 
 | ||||||
|         <div className="col-md-12 text-start mt-1"> |         <div className="col-md-12 text-start mt-1"> | ||||||
|           <p className="py-1 my-0">{checkListItems.length > 0 ? "Check List" : "Add Check List" }</p> |           <p className="py-1 my-0">{checkListItems.length > 0 ? "Check List" : "Add Check List"}</p> | ||||||
|           {checkListItems.length > 0 && ( |           {checkListItems.length > 0 && ( | ||||||
|           <table className="table mt-1  border-0"> |             <table className="table mt-1  border-0"> | ||||||
|             <thead className="py-0 my-0 table-border-top-0"> |               <thead className="py-0 my-0 table-border-top-0"> | ||||||
|               <tr className="py-1"> |                 <tr className="py-1"> | ||||||
|                 <th colSpan={2} className="py-1"> |                   <th colSpan={2} className="py-1"> | ||||||
|                   <small>Name</small> |                     <small>Name</small> | ||||||
|                 </th> |                   </th> | ||||||
|                 <th colSpan={2} className="py-1 text-center"> |                   <th colSpan={2} className="py-1 text-center"> | ||||||
|                   <small>Is Mandatory</small> |                     <small>Is Mandatory</small> | ||||||
|                 </th> |                   </th> | ||||||
|                 <th className="text-center py-1">Action</th> |                   <th className="text-center py-1">Action</th> | ||||||
|               </tr> |  | ||||||
|             </thead> |  | ||||||
|             <tbody className="table-border-bottom-0 "> |  | ||||||
|               {checkListItems.map((item, index) => ( |  | ||||||
|                 <tr key={index} className="border-top-0"> |  | ||||||
|                   <td colSpan={2} className="border-top-0 border-0"> |  | ||||||
|                     <input |  | ||||||
|                       className="d-none" |  | ||||||
|                       {...register(`checkList.${index}.id`)} |  | ||||||
|                     ></input> |  | ||||||
|                     <input |  | ||||||
|                       {...register(`checkList.${index}.description`)} |  | ||||||
|                       className="form-control form-control-sm" |  | ||||||
|                       placeholder={`Checklist item ${index + 1}`} |  | ||||||
|                       onChange={(e) => |  | ||||||
|                         handleChecklistChange(index, e.target.value) |  | ||||||
|                       } |  | ||||||
|                     /> |  | ||||||
|                     {errors.checkList?.[index]?.description && ( |  | ||||||
|                       <small |  | ||||||
|                         style={{ fontSize: "10px" }} |  | ||||||
|                         className="danger-text" |  | ||||||
|                       > |  | ||||||
|                         {errors.checkList[index]?.description?.message} |  | ||||||
|                       </small> |  | ||||||
|                     )} |  | ||||||
|                   </td> |  | ||||||
|                   <td colSpan={2} className="text-center border-0"> |  | ||||||
|                     <input |  | ||||||
|                       className="form-check-input" |  | ||||||
|                       type="checkbox" |  | ||||||
|                       {...register(`checkList.${index}.isMandatory`)} |  | ||||||
|                       defaultChecked={item.isMandatory} |  | ||||||
|                     /> |  | ||||||
|                   </td> |  | ||||||
|                   <td className="text-center border-0"> |  | ||||||
|                     <button |  | ||||||
|                       type="button" |  | ||||||
|                       onClick={() => removeChecklistItem(index)} |  | ||||||
|                       className="btn btn-xs btn-icon btn-text-secondary" |  | ||||||
|                     > |  | ||||||
|                       <i className="bx bxs-minus-circle text-danger"  data-bs-toggle="tooltip" |  | ||||||
|                 title="Remove Check" |  | ||||||
|                 data-bs-original-title="Remove check"></i> |  | ||||||
|                     </button> |  | ||||||
|                   </td> |  | ||||||
|                 </tr> |                 </tr> | ||||||
|               ))} |               </thead> | ||||||
|             </tbody> |               <tbody className="table-border-bottom-0 "> | ||||||
|           </table> |                 {checkListItems.map((item, index) => ( | ||||||
|  |                   <tr key={index} className="border-top-0"> | ||||||
|  |                     <td colSpan={2} className="border-top-0 border-0"> | ||||||
|  |                       <input | ||||||
|  |                         className="d-none" | ||||||
|  |                         {...register(`checkList.${index}.id`)} | ||||||
|  |                       ></input> | ||||||
|  |                       <input | ||||||
|  |                         {...register(`checkList.${index}.description`)} | ||||||
|  |                         className="form-control form-control-sm" | ||||||
|  |                         placeholder={`Checklist item ${index + 1}`} | ||||||
|  |                         onChange={(e) => | ||||||
|  |                           handleChecklistChange(index, e.target.value) | ||||||
|  |                         } | ||||||
|  |                       /> | ||||||
|  |                       {errors.checkList?.[index]?.description && ( | ||||||
|  |                         <small | ||||||
|  |                           style={{ fontSize: "10px" }} | ||||||
|  |                           className="danger-text" | ||||||
|  |                         > | ||||||
|  |                           {errors.checkList[index]?.description?.message} | ||||||
|  |                         </small> | ||||||
|  |                       )} | ||||||
|  |                     </td> | ||||||
|  |                     <td colSpan={2} className="text-center border-0"> | ||||||
|  |                       <input | ||||||
|  |                         className="form-check-input" | ||||||
|  |                         type="checkbox" | ||||||
|  |                         {...register(`checkList.${index}.isMandatory`)} | ||||||
|  |                         defaultChecked={item.isMandatory} | ||||||
|  |                       /> | ||||||
|  |                     </td> | ||||||
|  |                     <td className="text-center border-0"> | ||||||
|  |                       <button | ||||||
|  |                         type="button" | ||||||
|  |                         onClick={() => removeChecklistItem(index)} | ||||||
|  |                         className="btn btn-xs btn-icon btn-text-secondary" | ||||||
|  |                       > | ||||||
|  |                         <i className="bx bxs-minus-circle text-danger" data-bs-toggle="tooltip" | ||||||
|  |                           title="Remove Check" | ||||||
|  |                           data-bs-original-title="Remove check"></i> | ||||||
|  |                       </button> | ||||||
|  |                     </td> | ||||||
|  |                   </tr> | ||||||
|  |                 ))} | ||||||
|  |               </tbody> | ||||||
|  |             </table> | ||||||
|           )} |           )} | ||||||
|           <button |           <button | ||||||
|             type="button" |             type="button" | ||||||
| @ -216,22 +215,23 @@ useEffect(() => { | |||||||
|             onClick={addChecklistItem} |             onClick={addChecklistItem} | ||||||
|           > |           > | ||||||
|             <i className="bx bx-plus-circle" data-bs-toggle="tooltip" |             <i className="bx bx-plus-circle" data-bs-toggle="tooltip" | ||||||
|                 title="Add Check" |               title="Add Check" | ||||||
|                 data-bs-original-title="Add check" ></i> |               data-bs-original-title="Add check" ></i> | ||||||
|           </button> |           </button> | ||||||
|         </div> |         </div> | ||||||
| 
 | 
 | ||||||
|         <div className="col-12 text-center mt-3"> |         <div className="col-12 text-end mt-3"> | ||||||
|           <button type="submit" className="btn btn-sm btn-primary me-3"> |  | ||||||
|             {isLoading ? "Please Wait" : "Submit"} |  | ||||||
|           </button> |  | ||||||
|           <button |           <button | ||||||
|             type="reset" |             type="reset" | ||||||
|             className="btn btn-sm btn-label-secondary" |             className="btn btn-sm btn-label-secondary me-3" | ||||||
|             onClick={handleClose} |             onClick={handleClose} | ||||||
|           > |           > | ||||||
|             Cancel |             Cancel | ||||||
|           </button> |           </button> | ||||||
|  |           <button type="submit" className="btn btn-sm btn-primary"> | ||||||
|  |             {isLoading ? "Please Wait" : "Submit"} | ||||||
|  |           </button> | ||||||
|  | 
 | ||||||
|         </div> |         </div> | ||||||
|       </div> |       </div> | ||||||
|     </form> |     </form> | ||||||
|  | |||||||
| @ -7,6 +7,7 @@ import { clearApiCacheKey } from '../../slices/apiCacheSlice'; | |||||||
| import { getCachedData,cacheData } from '../../slices/apiDataManager'; | import { getCachedData,cacheData } from '../../slices/apiDataManager'; | ||||||
| import showToast from '../../services/toastService'; | import showToast from '../../services/toastService'; | ||||||
| import {useCreateContactCategory} from '../../hooks/masterHook/useMaster'; | import {useCreateContactCategory} from '../../hooks/masterHook/useMaster'; | ||||||
|  | import Label from '../common/Label'; | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| const schema = z.object({ | const schema = z.object({ | ||||||
| @ -65,16 +66,16 @@ useEffect(() => { | |||||||
|   |   | ||||||
|   return (<> |   return (<> | ||||||
|     <form  className="row g-2" onSubmit={handleSubmit(onSubmit)}> |     <form  className="row g-2" onSubmit={handleSubmit(onSubmit)}> | ||||||
|         <div className="col-12 col-md-12"> |         <div className="col-12 col-md-12 text-start"> | ||||||
|           <label className="form-label">Category Name</label> |           <Label className="form-label" required>Category Name</Label> | ||||||
|           <input type="text"  |           <input type="text"  | ||||||
|            {...register("name")}  |            {...register("name")}  | ||||||
|              className={`form-control ${errors.name ? 'is-invalids' : ''}`} |              className={`form-control ${errors.name ? 'is-invalids' : ''}`} | ||||||
|           /> |           /> | ||||||
|           {errors.name && <p className="text-danger">{errors.name.message}</p>} |           {errors.name && <p className="text-danger">{errors.name.message}</p>} | ||||||
|         </div>  |         </div>  | ||||||
|         <div className="col-12 col-md-12"> |         <div className="col-12 col-md-12 text-start"> | ||||||
|           <label className="form-label" htmlFor="description">Description</label> |           <Label className="form-label" htmlFor="description" required>Description</Label> | ||||||
|         <textarea |         <textarea | ||||||
|           rows="3" |           rows="3" | ||||||
|           {...register("description")} |           {...register("description")} | ||||||
| @ -92,18 +93,19 @@ useEffect(() => { | |||||||
|           )} |           )} | ||||||
|         </div> |         </div> | ||||||
| 
 | 
 | ||||||
|         <div className="col-12 text-center"> |         <div className="col-12 text-end"> | ||||||
|         <button type="submit" className="btn btn-sm btn-primary me-3">            |           <button | ||||||
|          {isLoading? "Please Wait...":"Submit"}        |  | ||||||
|         </button> |  | ||||||
|         <button |  | ||||||
|           type="reset" |           type="reset" | ||||||
|           className="btn btn-sm btn-label-secondary " |           className="btn btn-sm btn-label-secondary me-3" | ||||||
|           data-bs-dismiss="modal" |           data-bs-dismiss="modal" | ||||||
|           aria-label="Close" |           aria-label="Close" | ||||||
|         > |         > | ||||||
|           Cancel |           Cancel | ||||||
|         </button> |         </button> | ||||||
|  |         <button type="submit" className="btn btn-sm btn-primary">            | ||||||
|  |          {isLoading? "Please Wait...":"Submit"}        | ||||||
|  |         </button> | ||||||
|  |          | ||||||
|       </div> |       </div> | ||||||
|       |       | ||||||
|     </form> |     </form> | ||||||
|  | |||||||
| @ -7,6 +7,7 @@ import { clearApiCacheKey } from '../../slices/apiCacheSlice'; | |||||||
| import { getCachedData,cacheData } from '../../slices/apiDataManager'; | import { getCachedData,cacheData } from '../../slices/apiDataManager'; | ||||||
| import showToast from '../../services/toastService'; | import showToast from '../../services/toastService'; | ||||||
| import {useCreateContactTag} from '../../hooks/masterHook/useMaster'; | import {useCreateContactTag} from '../../hooks/masterHook/useMaster'; | ||||||
|  | import Label from '../common/Label'; | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| const schema = z.object({ | const schema = z.object({ | ||||||
| @ -65,16 +66,16 @@ useEffect(() => { | |||||||
|    |    | ||||||
|   return (<> |   return (<> | ||||||
|     <form  className="row g-2" onSubmit={handleSubmit(onSubmit)}> |     <form  className="row g-2" onSubmit={handleSubmit(onSubmit)}> | ||||||
|         <div className="col-12 col-md-12"> |         <div className="col-12 col-md-12 text-start"> | ||||||
|           <label className="form-label">Tag Name</label> |           <Label className="form-label" required>Tag Name</Label> | ||||||
|           <input type="text"  |           <input type="text"  | ||||||
|            {...register("name")}  |            {...register("name")}  | ||||||
|              className={`form-control ${errors.name ? 'is-invalids' : ''}`} |              className={`form-control ${errors.name ? 'is-invalids' : ''}`} | ||||||
|           /> |           /> | ||||||
|           {errors.name && <p className="text-danger">{errors.name.message}</p>} |           {errors.name && <p className="text-danger">{errors.name.message}</p>} | ||||||
|         </div>  |         </div>  | ||||||
|         <div className="col-12 col-md-12"> |         <div className="col-12 col-md-12 text-start"> | ||||||
|           <label className="form-label" htmlFor="description">Description</label> |           <Label className="form-label" htmlFor="description" required>Description</Label> | ||||||
|         <textarea |         <textarea | ||||||
|           rows="3" |           rows="3" | ||||||
|           {...register("description")} |           {...register("description")} | ||||||
| @ -92,18 +93,19 @@ useEffect(() => { | |||||||
|           )} |           )} | ||||||
|         </div> |         </div> | ||||||
| 
 | 
 | ||||||
|         <div className="col-12 text-center"> |         <div className="col-12 text-end"> | ||||||
|         <button type="submit" className="btn btn-sm btn-primary me-3">            |            <button | ||||||
|          {isLoading? "Please Wait...":"Submit"}        |  | ||||||
|         </button> |  | ||||||
|         <button |  | ||||||
|           type="reset" |           type="reset" | ||||||
|           className="btn btn-sm btn-label-secondary " |           className="btn btn-sm btn-label-secondary me-3" | ||||||
|           data-bs-dismiss="modal" |           data-bs-dismiss="modal" | ||||||
|           aria-label="Close" |           aria-label="Close" | ||||||
|         > |         > | ||||||
|           Cancel |           Cancel | ||||||
|         </button> |         </button> | ||||||
|  |         <button type="submit" className="btn btn-sm btn-primary">            | ||||||
|  |          {isLoading? "Please Wait...":"Submit"}        | ||||||
|  |         </button> | ||||||
|  |         | ||||||
|       </div> |       </div> | ||||||
|       |       | ||||||
|     </form> |     </form> | ||||||
|  | |||||||
| @ -7,6 +7,7 @@ import { clearApiCacheKey } from '../../slices/apiCacheSlice'; | |||||||
| import { getCachedData,cacheData } from '../../slices/apiDataManager'; | import { getCachedData,cacheData } from '../../slices/apiDataManager'; | ||||||
| import showToast from '../../services/toastService'; | import showToast from '../../services/toastService'; | ||||||
| import {useCreateJobRole} from '../../hooks/masterHook/useMaster'; | import {useCreateJobRole} from '../../hooks/masterHook/useMaster'; | ||||||
|  | import Label from '../common/Label'; | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| const schema = z.object({ | const schema = z.object({ | ||||||
| @ -91,16 +92,16 @@ const CreateJobRole = ({onClose}) => { | |||||||
|       {/* <div className="col-12 col-md-12"> |       {/* <div className="col-12 col-md-12"> | ||||||
|         <label className="fs-5 text-dark text-center d-flex align-items-center justify-content-center flex-wrap">Create Job Role</label> |         <label className="fs-5 text-dark text-center d-flex align-items-center justify-content-center flex-wrap">Create Job Role</label> | ||||||
|       </div> */} |       </div> */} | ||||||
|         <div className="col-12 col-md-12"> |         <div className="col-12 col-md-12 text-start"> | ||||||
|           <label className="form-label">Role</label> |           <Label className="form-label" required>Role</Label> | ||||||
|           <input type="text"  |           <input type="text"  | ||||||
|            {...register("role")}  |            {...register("role")}  | ||||||
|              className={`form-control ${errors.role ? 'is-invalids' : ''}`} |              className={`form-control ${errors.role ? 'is-invalids' : ''}`} | ||||||
|           /> |           /> | ||||||
|           {errors.role && <p className="text-danger">{errors.role.message}</p>} |           {errors.role && <p className="text-danger">{errors.role.message}</p>} | ||||||
|         </div>  |         </div>  | ||||||
|         <div className="col-12 col-md-12"> |         <div className="col-12 col-md-12 text-start"> | ||||||
|           <label className="form-label" htmlFor="description">Description</label> |           <Label className="form-label" htmlFor="description" required>Description</Label> | ||||||
|         <textarea |         <textarea | ||||||
|           rows="3" |           rows="3" | ||||||
|           {...register("description")} |           {...register("description")} | ||||||
| @ -118,18 +119,19 @@ const CreateJobRole = ({onClose}) => { | |||||||
|           )} |           )} | ||||||
|         </div> |         </div> | ||||||
| 
 | 
 | ||||||
|         <div className="col-12 text-center"> |         <div className="col-12 text-end"> | ||||||
|         <button type="submit" className="btn btn-sm btn-primary me-3">            |            <button | ||||||
|          {isLoading? "Please Wait...":"Submit"}        |  | ||||||
|         </button> |  | ||||||
|         <button |  | ||||||
|           type="reset" |           type="reset" | ||||||
|           className="btn btn-sm btn-label-secondary " |           className="btn btn-sm btn-label-secondary me-3" | ||||||
|           data-bs-dismiss="modal" |           data-bs-dismiss="modal" | ||||||
|           aria-label="Close" |           aria-label="Close" | ||||||
|         > |         > | ||||||
|           Cancel |           Cancel | ||||||
|         </button> |         </button> | ||||||
|  |         <button type="submit" className="btn btn-sm btn-primary">            | ||||||
|  |          {isLoading? "Please Wait...":"Submit"}        | ||||||
|  |         </button> | ||||||
|  |         | ||||||
|       </div> |       </div> | ||||||
|       |       | ||||||
|     </form> |     </form> | ||||||
|  | |||||||
| @ -8,6 +8,7 @@ import { MasterRespository } from "../../repositories/MastersRepository"; | |||||||
| import { cacheData, getCachedData } from "../../slices/apiDataManager"; | import { cacheData, getCachedData } from "../../slices/apiDataManager"; | ||||||
| import showToast from "../../services/toastService"; | import showToast from "../../services/toastService"; | ||||||
| import { useCreateApplicationRole } from "../../hooks/masterHook/useMaster"; | import { useCreateApplicationRole } from "../../hooks/masterHook/useMaster"; | ||||||
|  | import Label from "../common/Label"; | ||||||
| 
 | 
 | ||||||
| const schema = z.object({ | const schema = z.object({ | ||||||
|   role: z.string().min(1, { message: "Role is required" }), |   role: z.string().min(1, { message: "Role is required" }), | ||||||
| @ -109,8 +110,8 @@ const CreateRole = ({ modalType, onClose }) => { | |||||||
|         <label className="fs-5 text-dark text-center d-flex align-items-center justify-content-center flex-wrap">Create Application Role</label> |         <label className="fs-5 text-dark text-center d-flex align-items-center justify-content-center flex-wrap">Create Application Role</label> | ||||||
| 
 | 
 | ||||||
|       </div> */} |       </div> */} | ||||||
|       <div className="col-12 col-md-12"> |       <div className="col-12 col-md-12 text-start"> | ||||||
|         <label className="form-label">Role</label> |         <Label className="form-label" required>Role</Label> | ||||||
|         <input |         <input | ||||||
|           type="text" |           type="text" | ||||||
|           {...register("role")} |           {...register("role")} | ||||||
| @ -119,10 +120,10 @@ const CreateRole = ({ modalType, onClose }) => { | |||||||
|         {errors.role && <p className="text-danger">{errors.role.message}</p>} |         {errors.role && <p className="text-danger">{errors.role.message}</p>} | ||||||
|       </div> |       </div> | ||||||
| 
 | 
 | ||||||
|       <div className="col-12 col-md-12"> |       <div className="col-12 col-md-12 text-start"> | ||||||
|         <label className="form-label" htmlFor="description"> |         <Label className="form-label" htmlFor="description" required> | ||||||
|           Description |           Description | ||||||
|         </label> |         </Label> | ||||||
|         <textarea |         <textarea | ||||||
|           rows="3" |           rows="3" | ||||||
|           {...register("description")} |           {...register("description")} | ||||||
| @ -228,18 +229,19 @@ const CreateRole = ({ modalType, onClose }) => { | |||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
|       {masterFeatures && ( |       {masterFeatures && ( | ||||||
|         <div className="col-12 text-center"> |         <div className="col-12 text-end"> | ||||||
|           <button type="submit" className="btn btn-sm btn-primary me-3"> |            <button | ||||||
|             {isLoading ? "Please Wait..." : "Submit"} |  | ||||||
|           </button> |  | ||||||
|           <button |  | ||||||
|             type="reset" |             type="reset" | ||||||
|             className="btn btn-sm btn-label-secondary" |             className="btn btn-sm btn-label-secondary me-3" | ||||||
|             data-bs-dismiss="modal" |             data-bs-dismiss="modal" | ||||||
|             aria-label="Close" |             aria-label="Close" | ||||||
|           > |           > | ||||||
|             Cancel |             Cancel | ||||||
|           </button> |           </button> | ||||||
|  |           <button type="submit" className="btn btn-sm btn-primary"> | ||||||
|  |             {isLoading ? "Please Wait..." : "Submit"} | ||||||
|  |           </button> | ||||||
|  |           | ||||||
|         </div> |         </div> | ||||||
|       )} |       )} | ||||||
|     </form> |     </form> | ||||||
|  | |||||||
| @ -7,6 +7,7 @@ import { clearApiCacheKey } from '../../slices/apiCacheSlice'; | |||||||
| import { getCachedData,cacheData } from '../../slices/apiDataManager'; | import { getCachedData,cacheData } from '../../slices/apiDataManager'; | ||||||
| import showToast from '../../services/toastService'; | import showToast from '../../services/toastService'; | ||||||
| import {useCreateWorkCategory} from '../../hooks/masterHook/useMaster'; | import {useCreateWorkCategory} from '../../hooks/masterHook/useMaster'; | ||||||
|  | import Label from '../common/Label'; | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| const schema = z.object({ | const schema = z.object({ | ||||||
| @ -77,20 +78,20 @@ useEffect(() => { | |||||||
|   |   | ||||||
|   return (<> |   return (<> | ||||||
|     <form  className="row g-2" onSubmit={handleSubmit(onSubmit)}> |     <form  className="row g-2" onSubmit={handleSubmit(onSubmit)}> | ||||||
|       <div className="col-12 col-md-12"> |       {/* <div className="col-12 col-md-12"> | ||||||
|         <label className="fs-5 text-dark text-center d-flex align-items-center justify-content-center flex-wrap">Create Work Category</label>         |         <label className="fs-5 text-dark text-center d-flex align-items-center justify-content-center flex-wrap">Create Work Category</label>         | ||||||
|       </div> |       </div> */} | ||||||
|        |        | ||||||
|         <div className="col-12 col-md-12"> |         <div className="col-12 col-md-12 text-start"> | ||||||
|           <label className="form-label">Category Name</label> |           <Label className="form-label" required>Category Name</Label> | ||||||
|           <input type="text"  |           <input type="text"  | ||||||
|            {...register("name")}  |            {...register("name")}  | ||||||
|              className={`form-control ${errors.name ? 'is-invalids' : ''}`} |              className={`form-control ${errors.name ? 'is-invalids' : ''}`} | ||||||
|           /> |           /> | ||||||
|           {errors.name && <p className="text-danger">{errors.name.message}</p>} |           {errors.name && <p className="text-danger">{errors.name.message}</p>} | ||||||
|         </div>  |         </div>  | ||||||
|         <div className="col-12 col-md-12"> |         <div className="col-12 col-md-12 text-start"> | ||||||
|           <label className="form-label" htmlFor="description">Description</label> |           <Label className="form-label" htmlFor="description" required>Description</Label> | ||||||
|         <textarea |         <textarea | ||||||
|           rows="3" |           rows="3" | ||||||
|           {...register("description")} |           {...register("description")} | ||||||
| @ -108,18 +109,19 @@ useEffect(() => { | |||||||
|           )} |           )} | ||||||
|         </div> |         </div> | ||||||
| 
 | 
 | ||||||
|         <div className="col-12 text-center"> |         <div className="col-12 text-end"> | ||||||
|         <button type="submit" className="btn btn-sm btn-primary me-3">            |            <button | ||||||
|          {isLoading? "Please Wait...":"Submit"}        |  | ||||||
|         </button> |  | ||||||
|         <button |  | ||||||
|           type="reset" |           type="reset" | ||||||
|           className="btn btn-sm btn-label-secondary " |           className="btn btn-sm btn-label-secondary me-3" | ||||||
|           data-bs-dismiss="modal" |           data-bs-dismiss="modal" | ||||||
|           aria-label="Close" |           aria-label="Close" | ||||||
|         > |         > | ||||||
|           Cancel |           Cancel | ||||||
|         </button> |         </button> | ||||||
|  |         <button type="submit" className="btn btn-sm btn-primary">            | ||||||
|  |          {isLoading? "Please Wait...":"Submit"}        | ||||||
|  |         </button> | ||||||
|  |         | ||||||
|       </div> |       </div> | ||||||
|       |       | ||||||
|     </form> |     </form> | ||||||
|  | |||||||
| @ -2,10 +2,11 @@ import React, { useEffect, useState } from "react"; | |||||||
| import { useForm, useFieldArray } from "react-hook-form"; | import { useForm, useFieldArray } from "react-hook-form"; | ||||||
| import { z } from "zod"; | import { z } from "zod"; | ||||||
| import { zodResolver } from "@hookform/resolvers/zod"; | import { zodResolver } from "@hookform/resolvers/zod"; | ||||||
| import {MasterRespository} from "../../repositories/MastersRepository"; | import { MasterRespository } from "../../repositories/MastersRepository"; | ||||||
| import showToast from "../../services/toastService"; | import showToast from "../../services/toastService"; | ||||||
| import {getCachedData,cacheData} from "../../slices/apiDataManager"; | import { getCachedData, cacheData } from "../../slices/apiDataManager"; | ||||||
| import {useUpdateActivity} from "../../hooks/masterHook/useMaster"; | import { useUpdateActivity } from "../../hooks/masterHook/useMaster"; | ||||||
|  | import Label from "../common/Label"; | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| const schema = z.object({ | const schema = z.object({ | ||||||
| @ -26,88 +27,88 @@ const schema = z.object({ | |||||||
| const UpdateActivity = ({ activityData, onClose }) => { | const UpdateActivity = ({ activityData, onClose }) => { | ||||||
|   const { mutate: updateActivity, isPending: isLoading } = useUpdateActivity(() => onClose?.()); |   const { mutate: updateActivity, isPending: isLoading } = useUpdateActivity(() => onClose?.()); | ||||||
| 
 | 
 | ||||||
| const { |   const { | ||||||
|   register, |     register, | ||||||
|   handleSubmit, |     handleSubmit, | ||||||
|   control, |     control, | ||||||
|   setValue, |     setValue, | ||||||
|   reset, |     reset, | ||||||
|   setError, |     setError, | ||||||
|   clearErrors, |     clearErrors, | ||||||
|   getValues, |     getValues, | ||||||
|   formState: { errors }, |     formState: { errors }, | ||||||
| } = useForm({ |   } = useForm({ | ||||||
|   resolver: zodResolver(schema), |     resolver: zodResolver(schema), | ||||||
|   defaultValues: { |     defaultValues: { | ||||||
|     id: activityData?.id, |       id: activityData?.id, | ||||||
|     activityName: activityData?.activityName, |       activityName: activityData?.activityName, | ||||||
|     unitOfMeasurement: activityData?.unitOfMeasurement, |       unitOfMeasurement: activityData?.unitOfMeasurement, | ||||||
|     checkList: activityData?.checkLists || [], |       checkList: activityData?.checkLists || [], | ||||||
|   }, |     }, | ||||||
| }); |   }); | ||||||
| 
 | 
 | ||||||
| const { fields: checkListItems, append, remove } = useFieldArray({ |   const { fields: checkListItems, append, remove } = useFieldArray({ | ||||||
|   control, |     control, | ||||||
|   name: "checkList", |     name: "checkList", | ||||||
| }); |   }); | ||||||
| 
 | 
 | ||||||
| useEffect(() => { |   useEffect(() => { | ||||||
|   if (activityData) { |     if (activityData) { | ||||||
|     reset({ |       reset({ | ||||||
|       id: activityData.id, |         id: activityData.id, | ||||||
|       activityName: activityData.activityName, |         activityName: activityData.activityName, | ||||||
|       unitOfMeasurement: activityData.unitOfMeasurement, |         unitOfMeasurement: activityData.unitOfMeasurement, | ||||||
|       checkList: activityData.checkLists || [], |         checkList: activityData.checkLists || [], | ||||||
|     }); |       }); | ||||||
|   } |     } | ||||||
| }, [activityData, reset]); |   }, [activityData, reset]); | ||||||
| 
 | 
 | ||||||
| const addChecklistItem = () => { |   const addChecklistItem = () => { | ||||||
|   const values = getValues("checkList"); |     const values = getValues("checkList"); | ||||||
|   const lastIndex = checkListItems.length - 1; |     const lastIndex = checkListItems.length - 1; | ||||||
| 
 | 
 | ||||||
|   if ( |     if ( | ||||||
|     checkListItems.length > 0 && |       checkListItems.length > 0 && | ||||||
|     (!values?.[lastIndex] || values[lastIndex].description.trim() === "") |       (!values?.[lastIndex] || values[lastIndex].description.trim() === "") | ||||||
|   ) { |     ) { | ||||||
|     setError(`checkList.${lastIndex}.description`, { |       setError(`checkList.${lastIndex}.description`, { | ||||||
|       type: "manual", |         type: "manual", | ||||||
|       message: "Please fill this checklist item before adding another.", |         message: "Please fill this checklist item before adding another.", | ||||||
|     }); |       }); | ||||||
|     return; |       return; | ||||||
|   } |     } | ||||||
| 
 | 
 | ||||||
|   clearErrors(`checkList.${lastIndex}.description`); |     clearErrors(`checkList.${lastIndex}.description`); | ||||||
|   append({ id: null, description: "", isMandatory: false }); |     append({ id: null, description: "", isMandatory: false }); | ||||||
| }; |  | ||||||
| 
 |  | ||||||
| const removeChecklistItem = (index) => { |  | ||||||
|   remove(index); |  | ||||||
| }; |  | ||||||
| 
 |  | ||||||
| const handleChecklistChange = (index, value) => { |  | ||||||
|   setValue(`checkList.${index}`, value); |  | ||||||
| }; |  | ||||||
| 
 |  | ||||||
| const onSubmit = (formData) => { |  | ||||||
|   const payload = { ...formData, id: activityData.id }; |  | ||||||
|   updateActivity({ id: activityData.id, payload }); |  | ||||||
|   }; |   }; | ||||||
| // const onSubmit = async(data) => { | 
 | ||||||
|  |   const removeChecklistItem = (index) => { | ||||||
|  |     remove(index); | ||||||
|  |   }; | ||||||
|  | 
 | ||||||
|  |   const handleChecklistChange = (index, value) => { | ||||||
|  |     setValue(`checkList.${index}`, value); | ||||||
|  |   }; | ||||||
|  | 
 | ||||||
|  |   const onSubmit = (formData) => { | ||||||
|  |     const payload = { ...formData, id: activityData.id }; | ||||||
|  |     updateActivity({ id: activityData.id, payload }); | ||||||
|  |   }; | ||||||
|  |   // const onSubmit = async(data) => { | ||||||
|   //   setIsLoading(true); |   //   setIsLoading(true); | ||||||
|    | 
 | ||||||
|   //   const Activity = {...data, id:activityData.id} |   //   const Activity = {...data, id:activityData.id} | ||||||
|   //   try |   //   try | ||||||
|   //   { |   //   { | ||||||
|   //     const response = await MasterRespository.updateActivity( activityData?.id, Activity ); |   //     const response = await MasterRespository.updateActivity( activityData?.id, Activity ); | ||||||
|   //     const updatedActivity = response.data; |   //     const updatedActivity = response.data; | ||||||
|   //     const cachedData = getCachedData("Activity") |   //     const cachedData = getCachedData("Activity") | ||||||
|    | 
 | ||||||
|   //     if (cachedData) { |   //     if (cachedData) { | ||||||
|   //       const updatedActivities = cachedData.map((activity) => |   //       const updatedActivities = cachedData.map((activity) => | ||||||
|   //         activity.id === updatedActivity.id ? { ...activity, ...updatedActivity } : activity |   //         activity.id === updatedActivity.id ? { ...activity, ...updatedActivity } : activity | ||||||
|   //       ); |   //       ); | ||||||
|    | 
 | ||||||
|   //       cacheData( "Activity", updatedActivities ); |   //       cacheData( "Activity", updatedActivities ); | ||||||
|   //       onClose() |   //       onClose() | ||||||
|   //     } |   //     } | ||||||
| @ -121,18 +122,18 @@ const onSubmit = (formData) => { | |||||||
|   //   } |   //   } | ||||||
|   // }; |   // }; | ||||||
| 
 | 
 | ||||||
| useEffect(() => { |   useEffect(() => { | ||||||
|   const tooltipTriggerList = Array.from(document.querySelectorAll('[data-bs-toggle="tooltip"]')); |     const tooltipTriggerList = Array.from(document.querySelectorAll('[data-bs-toggle="tooltip"]')); | ||||||
|   tooltipTriggerList.forEach((el) => new bootstrap.Tooltip(el)); |     tooltipTriggerList.forEach((el) => new bootstrap.Tooltip(el)); | ||||||
| }, []); |   }, []); | ||||||
| 
 | 
 | ||||||
|   return ( |   return ( | ||||||
|     <form onSubmit={handleSubmit(onSubmit)}> |     <form onSubmit={handleSubmit(onSubmit)}> | ||||||
|       {/* <h6>Update Activity</h6> */} |       {/* <h6>Update Activity</h6> */} | ||||||
|       <div className="row"> |       <div className="row"> | ||||||
|         {/* Activity Name */} |         {/* Activity Name */} | ||||||
|         <div className="col-md-6"> |         <div className="col-md-6 text-start"> | ||||||
|           <label  className="form-label">Activity Name</label> |           <Label className="form-label" required>Activity Name</Label> | ||||||
|           <input |           <input | ||||||
|             type="text" |             type="text" | ||||||
|             {...register("activityName")} |             {...register("activityName")} | ||||||
| @ -144,8 +145,8 @@ useEffect(() => { | |||||||
|         </div> |         </div> | ||||||
| 
 | 
 | ||||||
|         {/* Unit of Measurement */} |         {/* Unit of Measurement */} | ||||||
|         <div className="col-md-6"> |         <div className="col-md-6 text-start"> | ||||||
|           <label  className="form-label">Measurement</label> |           <Label className="form-label" required>Measurement</Label> | ||||||
|           <input |           <input | ||||||
|             type="text" |             type="text" | ||||||
|             {...register("unitOfMeasurement")} |             {...register("unitOfMeasurement")} | ||||||
| @ -160,93 +161,94 @@ useEffect(() => { | |||||||
|         <div className="col-md-12 text-start mt-1"> |         <div className="col-md-12 text-start mt-1"> | ||||||
|           <p className="py-1 my-0">{checkListItems.length > 0 ? "Check List" : "Add Check List"}</p> |           <p className="py-1 my-0">{checkListItems.length > 0 ? "Check List" : "Add Check List"}</p> | ||||||
|           {checkListItems.length > 0 && ( |           {checkListItems.length > 0 && ( | ||||||
|              <table className="table mt-1  border-0"> |             <table className="table mt-1  border-0"> | ||||||
|              <thead className="py-0 my-0 table-border-top-0"> |               <thead className="py-0 my-0 table-border-top-0"> | ||||||
|                  <tr className="py-1"> |                 <tr className="py-1"> | ||||||
|                    <th colSpan={2} className="py-1"> |                   <th colSpan={2} className="py-1"> | ||||||
|                      <small>Name</small> |                     <small>Name</small> | ||||||
|                    </th> |                   </th> | ||||||
|                    <th colSpan={2} className="py-1 text-center"> |                   <th colSpan={2} className="py-1 text-center"> | ||||||
|                      <small>Is Mandatory</small> |                     <small>Is Mandatory</small> | ||||||
|                    </th> |                   </th> | ||||||
|                    <th className="text-center py-1">Action</th> |                   <th className="text-center py-1">Action</th> | ||||||
|                  </tr> |                 </tr> | ||||||
|                </thead> |               </thead> | ||||||
|                <tbody> |               <tbody> | ||||||
|                {checkListItems.map((item, index) => ( |                 {checkListItems.map((item, index) => ( | ||||||
|                    <tr key={item.id} className="border-top-0"> |                   <tr key={item.id} className="border-top-0"> | ||||||
|                      <td colSpan={2} className=" border-0"> |                     <td colSpan={2} className=" border-0"> | ||||||
|                        <input |                       <input | ||||||
|                          className="d-none" |                         className="d-none" | ||||||
|                          {...register(`checkList.${index}.id`)} |                         {...register(`checkList.${index}.id`)} | ||||||
|                        ></input> |                       ></input> | ||||||
|                        <input |                       <input | ||||||
|                          {...register(`checkList.${index}.description`)} |                         {...register(`checkList.${index}.description`)} | ||||||
|                          className="form-control form-control-sm" |                         className="form-control form-control-sm" | ||||||
|                          placeholder={`Checklist item ${index + 1}`} |                         placeholder={`Checklist item ${index + 1}`} | ||||||
|                          onChange={(e) => |                         onChange={(e) => | ||||||
|                            handleChecklistChange(index, e.target.value) |                           handleChecklistChange(index, e.target.value) | ||||||
|                          } |                         } | ||||||
|                        /> |                       /> | ||||||
|                        {errors.checkList?.[index]?.description && ( |                       {errors.checkList?.[index]?.description && ( | ||||||
|                          <small |                         <small | ||||||
|                            style={{ fontSize: "10px" }} |                           style={{ fontSize: "10px" }} | ||||||
|                            className="danger-text" |                           className="danger-text" | ||||||
|                          > |                         > | ||||||
|                            {errors.checkList[index]?.description?.message} |                           {errors.checkList[index]?.description?.message} | ||||||
|                          </small> |                         </small> | ||||||
|                        )} |                       )} | ||||||
|                      </td> |                     </td> | ||||||
|                      <td colSpan={2} className="text-center border-0"> |                     <td colSpan={2} className="text-center border-0"> | ||||||
|                        <input |                       <input | ||||||
|                          className="form-check-input" |                         className="form-check-input" | ||||||
|                          type="checkbox" |                         type="checkbox" | ||||||
|                          {...register(`checkList.${index}.isMandatory`)} |                         {...register(`checkList.${index}.isMandatory`)} | ||||||
|                          defaultChecked={item.isMandatory} |                         defaultChecked={item.isMandatory} | ||||||
|                        /> |                       /> | ||||||
|                      </td> |                     </td> | ||||||
|                      <td className="text-center border-0"> |                     <td className="text-center border-0"> | ||||||
|                        <button |                       <button | ||||||
|                          type="button" |                         type="button" | ||||||
|                          onClick={() => removeChecklistItem(index)} |                         onClick={() => removeChecklistItem(index)} | ||||||
|                        className="btn btn-xs btn-icon btn-text-secondary" |                         className="btn btn-xs btn-icon btn-text-secondary" | ||||||
|                         | 
 | ||||||
|                        > |                       > | ||||||
|                          <i className="bx bxs-minus-circle text-danger"data-bs-toggle="tooltip" |                         <i className="bx bxs-minus-circle text-danger" data-bs-toggle="tooltip" | ||||||
|                 title="Add Check" |                           title="Add Check" | ||||||
|                 data-bs-original-title="Add check"  ></i> |                           data-bs-original-title="Add check"  ></i> | ||||||
|                        </button> |                       </button> | ||||||
|                      </td> |                     </td> | ||||||
|                    </tr> |                   </tr> | ||||||
|                  ))} |                 ))} | ||||||
|                </tbody> |               </tbody> | ||||||
|              </table> |             </table> | ||||||
|           )} |           )} | ||||||
|           | 
 | ||||||
| 
 | 
 | ||||||
|           <button |           <button | ||||||
|              type="button" |             type="button" | ||||||
|             className="btn btn-xs btn-primary mt-2" |             className="btn btn-xs btn-primary mt-2" | ||||||
|             onClick={addChecklistItem} |             onClick={addChecklistItem} | ||||||
|           > |           > | ||||||
|          <i className="bx bx-plus-circle" data-bs-toggle="tooltip" |             <i className="bx bx-plus-circle" data-bs-toggle="tooltip" | ||||||
|                 title="Add Check" |               title="Add Check" | ||||||
|                 data-bs-original-title="Add check" ></i> |               data-bs-original-title="Add check" ></i> | ||||||
|           </button> |           </button> | ||||||
|         </div> |         </div> | ||||||
| 
 | 
 | ||||||
|         {/* Submit / Cancel */} |         {/* Submit / Cancel */} | ||||||
|         <div className="col-12 text-center mt-3"> |         <div className="col-12 text-end mt-3"> | ||||||
|           <button type="submit" className="btn btn-sm btn-primary me-3"> |  | ||||||
|             {isLoading ? "Please Wait" : "Submit"} |  | ||||||
|           </button> |  | ||||||
|           <button |           <button | ||||||
|             type="button" |             type="button" | ||||||
|             className="btn btn-sm btn-label-secondary" |             className="btn btn-sm btn-label-secondary me-3" | ||||||
|             onClick={onClose} |             onClick={onClose} | ||||||
|           > |           > | ||||||
|             Cancel |             Cancel | ||||||
|           </button> |           </button> | ||||||
|  |           <button type="submit" className="btn btn-sm btn-primary"> | ||||||
|  |             {isLoading ? "Please Wait" : "Submit"} | ||||||
|  |           </button> | ||||||
|  | 
 | ||||||
|         </div> |         </div> | ||||||
|       </div> |       </div> | ||||||
|     </form> |     </form> | ||||||
|  | |||||||
| @ -7,6 +7,7 @@ import { clearApiCacheKey } from '../../slices/apiCacheSlice'; | |||||||
| import { getCachedData,cacheData } from '../../slices/apiDataManager'; | import { getCachedData,cacheData } from '../../slices/apiDataManager'; | ||||||
| import showToast from '../../services/toastService'; | import showToast from '../../services/toastService'; | ||||||
| import {useUpdateContactCategory} from '../../hooks/masterHook/useMaster'; | import {useUpdateContactCategory} from '../../hooks/masterHook/useMaster'; | ||||||
|  | import Label from '../common/Label'; | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| const schema = z.object({ | const schema = z.object({ | ||||||
| @ -84,16 +85,16 @@ useEffect(() => { | |||||||
|     |     | ||||||
|   return (<> |   return (<> | ||||||
|     <form  className="row g-2" onSubmit={handleSubmit(onSubmit)}> |     <form  className="row g-2" onSubmit={handleSubmit(onSubmit)}> | ||||||
|         <div className="col-12 col-md-12"> |         <div className="col-12 col-md-12 text-start"> | ||||||
|           <label className="form-label">Category Name</label> |           <Label className="form-label" required>Category Name</Label> | ||||||
|           <input type="text"  |           <input type="text"  | ||||||
|            {...register("name")}  |            {...register("name")}  | ||||||
|              className={`form-control ${errors.name ? 'is-invalids' : ''}`} |              className={`form-control ${errors.name ? 'is-invalids' : ''}`} | ||||||
|           /> |           /> | ||||||
|           {errors.name && <p className="text-danger">{errors.name.message}</p>} |           {errors.name && <p className="text-danger">{errors.name.message}</p>} | ||||||
|         </div>  |         </div>  | ||||||
|         <div className="col-12 col-md-12"> |         <div className="col-12 col-md-12 text-start"> | ||||||
|           <label className="form-label" htmlFor="description">Description</label> |           <Label className="form-label" htmlFor="description" required>Description</Label> | ||||||
|         <textarea |         <textarea | ||||||
|           rows="3" |           rows="3" | ||||||
|           {...register("description")} |           {...register("description")} | ||||||
| @ -111,18 +112,19 @@ useEffect(() => { | |||||||
|           )} |           )} | ||||||
|         </div> |         </div> | ||||||
| 
 | 
 | ||||||
|         <div className="col-12 text-center"> |         <div className="col-12 text-end"> | ||||||
|         <button type="submit" className="btn btn-sm btn-primary me-3">            |            <button | ||||||
|          {isLoading? "Please Wait...":"Submit"}        |  | ||||||
|         </button> |  | ||||||
|         <button |  | ||||||
|           type="button" |           type="button" | ||||||
|           className="btn btn-sm btn-label-secondary " |           className="btn btn-sm btn-label-secondary me-3" | ||||||
|           data-bs-dismiss="modal" |           data-bs-dismiss="modal" | ||||||
|           aria-label="Close" |           aria-label="Close" | ||||||
|         > |         > | ||||||
|           Cancel |           Cancel | ||||||
|         </button> |         </button> | ||||||
|  |         <button type="submit" className="btn btn-sm btn-primary">            | ||||||
|  |          {isLoading? "Please Wait...":"Submit"}        | ||||||
|  |         </button> | ||||||
|  |         | ||||||
|       </div> |       </div> | ||||||
|       |       | ||||||
|     </form> |     </form> | ||||||
|  | |||||||
| @ -7,6 +7,7 @@ import { clearApiCacheKey } from '../../slices/apiCacheSlice'; | |||||||
| import { getCachedData,cacheData } from '../../slices/apiDataManager'; | import { getCachedData,cacheData } from '../../slices/apiDataManager'; | ||||||
| import showToast from '../../services/toastService'; | import showToast from '../../services/toastService'; | ||||||
| import {useUpdateContactTag} from '../../hooks/masterHook/useMaster'; | import {useUpdateContactTag} from '../../hooks/masterHook/useMaster'; | ||||||
|  | import Label from '../common/Label'; | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| const schema = z.object({ | const schema = z.object({ | ||||||
| @ -84,16 +85,16 @@ useEffect(() => { | |||||||
|     |     | ||||||
|   return (<> |   return (<> | ||||||
|     <form  className="row g-2" onSubmit={handleSubmit(onSubmit)}> |     <form  className="row g-2" onSubmit={handleSubmit(onSubmit)}> | ||||||
|         <div className="col-12 col-md-12"> |         <div className="col-12 col-md-12 text-start"> | ||||||
|           <label className="form-label">Tag Name</label> |           <Label className="form-label" required>Tag Name</Label> | ||||||
|           <input type="text"  |           <input type="text"  | ||||||
|            {...register("name")}  |            {...register("name")}  | ||||||
|              className={`form-control ${errors.name ? 'is-invalids' : ''}`} |              className={`form-control ${errors.name ? 'is-invalids' : ''}`} | ||||||
|           /> |           /> | ||||||
|           {errors.name && <p className="text-danger">{errors.name.message}</p>} |           {errors.name && <p className="text-danger">{errors.name.message}</p>} | ||||||
|         </div>  |         </div>  | ||||||
|         <div className="col-12 col-md-12"> |         <div className="col-12 col-md-12 text-start"> | ||||||
|           <label className="form-label" htmlFor="description">Description</label> |           <Label className="form-label" htmlFor="description" required>Description</Label> | ||||||
|         <textarea |         <textarea | ||||||
|           rows="3" |           rows="3" | ||||||
|           {...register("description")} |           {...register("description")} | ||||||
| @ -111,18 +112,19 @@ useEffect(() => { | |||||||
|           )} |           )} | ||||||
|         </div> |         </div> | ||||||
| 
 | 
 | ||||||
|         <div className="col-12 text-center"> |         <div className="col-12 text-end"> | ||||||
|         <button type="submit" className="btn btn-sm btn-primary me-3">            |           <button | ||||||
|          {isLoading? "Please Wait...":"Submit"}        |  | ||||||
|         </button> |  | ||||||
|         <button |  | ||||||
|           type="button" |           type="button" | ||||||
|           className="btn btn-sm btn-label-secondary " |           className="btn btn-sm btn-label-secondary me-3" | ||||||
|           data-bs-dismiss="modal" |           data-bs-dismiss="modal" | ||||||
|           aria-label="Close" |           aria-label="Close" | ||||||
|         > |         > | ||||||
|           Cancel |           Cancel | ||||||
|         </button> |         </button> | ||||||
|  |         <button type="submit" className="btn btn-sm btn-primary ">            | ||||||
|  |          {isLoading? "Please Wait...":"Submit"}        | ||||||
|  |         </button> | ||||||
|  |          | ||||||
|       </div> |       </div> | ||||||
|       |       | ||||||
|     </form> |     </form> | ||||||
|  | |||||||
| @ -6,6 +6,7 @@ import { MasterRespository } from '../../repositories/MastersRepository'; | |||||||
| import { cacheData,getCachedData } from '../../slices/apiDataManager'; | import { cacheData,getCachedData } from '../../slices/apiDataManager'; | ||||||
| import showToast from '../../services/toastService'; | import showToast from '../../services/toastService'; | ||||||
| import {useUpdateJobRole} from '../../hooks/masterHook/useMaster'; | import {useUpdateJobRole} from '../../hooks/masterHook/useMaster'; | ||||||
|  | import Label from '../common/Label'; | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| @ -99,16 +100,16 @@ const [descriptionLength, setDescriptionLength] = useState(data?.description?.le | |||||||
|       {/* <div className="col-12 col-md-12"> |       {/* <div className="col-12 col-md-12"> | ||||||
|         <label className="fs-5 text-dark text-center d-flex align-items-center justify-content-center flex-wrap">Edit Job Role</label>         |         <label className="fs-5 text-dark text-center d-flex align-items-center justify-content-center flex-wrap">Edit Job Role</label>         | ||||||
|       </div> */} |       </div> */} | ||||||
|         <div className="col-12 col-md-12"> |         <div className="col-12 col-md-12 text-start"> | ||||||
|           <label className="form-label">Role</label> |           <Label className="form-label" required>Role</Label> | ||||||
|           <input type="text"  |           <input type="text"  | ||||||
|            {...register("role")}  |            {...register("role")}  | ||||||
|              className={`form-control ${errors.role ? 'is-invalids' : ''}`} |              className={`form-control ${errors.role ? 'is-invalids' : ''}`} | ||||||
|           /> |           /> | ||||||
|           {errors.role && <p className="text-danger">{errors.role.message}</p>} |           {errors.role && <p className="text-danger">{errors.role.message}</p>} | ||||||
|         </div>  |         </div>  | ||||||
|         <div className="col-12 col-md-12"> |         <div className="col-12 col-md-12 text-start"> | ||||||
|           <label className="form-label" htmlFor="description">Description</label> |           <Label className="form-label" htmlFor="description" required>Description</Label> | ||||||
|         <textarea |         <textarea | ||||||
|           rows="3" |           rows="3" | ||||||
|           {...register("description")} |           {...register("description")} | ||||||
| @ -127,18 +128,19 @@ const [descriptionLength, setDescriptionLength] = useState(data?.description?.le | |||||||
| 
 | 
 | ||||||
|         </div> |         </div> | ||||||
| 
 | 
 | ||||||
|         <div className="col-12 text-center"> |         <div className="col-12 text-end"> | ||||||
|         <button type="submit" className="btn btn-sm btn-primary me-3">            |           <button | ||||||
|          {isLoading? "Please Wait...":"Submit"}        |  | ||||||
|         </button> |  | ||||||
|         <button |  | ||||||
|           type="button" |           type="button" | ||||||
|           className="btn btn-sm btn-label-secondary" |           className="btn btn-sm btn-label-secondary me-3" | ||||||
|           data-bs-dismiss="modal" |           data-bs-dismiss="modal" | ||||||
|           aria-label="Close" |           aria-label="Close" | ||||||
|         > |         > | ||||||
|           Cancel |           Cancel | ||||||
|         </button> |         </button> | ||||||
|  |         <button type="submit" className="btn btn-sm btn-primary">            | ||||||
|  |          {isLoading? "Please Wait...":"Submit"}        | ||||||
|  |         </button> | ||||||
|  |          | ||||||
|       </div> |       </div> | ||||||
|       |       | ||||||
|     </form> |     </form> | ||||||
|  | |||||||
| @ -8,6 +8,7 @@ import { MasterRespository } from "../../repositories/MastersRepository"; | |||||||
| import { cacheData, getCachedData } from "../../slices/apiDataManager"; | import { cacheData, getCachedData } from "../../slices/apiDataManager"; | ||||||
| import showToast from "../../services/toastService"; | import showToast from "../../services/toastService"; | ||||||
| import { useUpdateApplicationRole } from "../../hooks/masterHook/useMaster"; | import { useUpdateApplicationRole } from "../../hooks/masterHook/useMaster"; | ||||||
|  | import Label from "../common/Label"; | ||||||
| 
 | 
 | ||||||
| const updateSchema = z.object({ | const updateSchema = z.object({ | ||||||
|   role: z.string().min(1, { message: "Role is required" }), |   role: z.string().min(1, { message: "Role is required" }), | ||||||
| @ -162,8 +163,8 @@ const EditMaster = ({ master, onClose }) => { | |||||||
|   return ( |   return ( | ||||||
| 
 | 
 | ||||||
|     <form className="row g-2 " onSubmit={handleSubmit(onSubmit)}> |     <form className="row g-2 " onSubmit={handleSubmit(onSubmit)}> | ||||||
|       <div className="col-12 col-md-12"> |       <div className="col-12 col-md-12 text-start"> | ||||||
|         <label className="form-label">Role</label> |         <Label className="form-label" required>Role</Label> | ||||||
|         <input type="text" |         <input type="text" | ||||||
|           {...register("role")} |           {...register("role")} | ||||||
|           className={`form-control ${errors.role ? 'is-invalid' : ''}`} |           className={`form-control ${errors.role ? 'is-invalid' : ''}`} | ||||||
| @ -171,8 +172,8 @@ const EditMaster = ({ master, onClose }) => { | |||||||
|         {errors.role && <p className="text-danger">{errors.role.message}</p>} |         {errors.role && <p className="text-danger">{errors.role.message}</p>} | ||||||
|       </div> |       </div> | ||||||
| 
 | 
 | ||||||
|       <div className="col-12 col-md-12"> |       <div className="col-12 col-md-12 text-start"> | ||||||
|         <label className="form-label" htmlFor="description">Description</label> |         <Label className="form-label" htmlFor="description" required>Description</Label> | ||||||
|         <textarea |         <textarea | ||||||
|           rows="3" |           rows="3" | ||||||
|           {...register("description")} |           {...register("description")} | ||||||
| @ -190,101 +191,102 @@ const EditMaster = ({ master, onClose }) => { | |||||||
|         )} |         )} | ||||||
|       </div> |       </div> | ||||||
| 
 | 
 | ||||||
|      <div className="col-12 text-start"> |       <div className="col-12 text-start"> | ||||||
|   {/* Scrollable Container with Border */} |         {/* Scrollable Container with Border */} | ||||||
|   <div |         <div | ||||||
|     className="border rounded p-3" |           className="border rounded p-3" | ||||||
|     style={{ |           style={{ | ||||||
|       maxHeight: "350px", |             maxHeight: "350px", | ||||||
|       overflowY: "auto", |             overflowY: "auto", | ||||||
|       overflowX: "hidden", // Prevent horizontal scrollbar |             overflowX: "hidden", // Prevent horizontal scrollbar | ||||||
|       paddingRight: "10px", |             paddingRight: "10px", | ||||||
|     }} |           }} | ||||||
|   > |         > | ||||||
|     {masterFeatures.map((feature, featureIndex) => ( |           {masterFeatures.map((feature, featureIndex) => ( | ||||||
|       <div key={feature.id} className="mb-3"> |             <div key={feature.id} className="mb-3"> | ||||||
|         {/* Feature Group Title */} |               {/* Feature Group Title */} | ||||||
|         <div className="fw-semibold mb-2">{feature.name}</div> |               <div className="fw-semibold mb-2">{feature.name}</div> | ||||||
| 
 | 
 | ||||||
|         {/* Permissions Grid */} |               {/* Permissions Grid */} | ||||||
|         <div className="row"> |               <div className="row"> | ||||||
|           {feature.featurePermissions.map((perm, permIndex) => { |                 {feature.featurePermissions.map((perm, permIndex) => { | ||||||
|             const refIndex = featureIndex * 10 + permIndex; |                   const refIndex = featureIndex * 10 + permIndex; | ||||||
|             return ( |                   return ( | ||||||
|               <div |                     <div | ||||||
|                 key={perm.id} |                       key={perm.id} | ||||||
|                 className="col-12 col-sm-6 col-md-4 mb-3 d-flex align-items-start" |                       className="col-12 col-sm-6 col-md-4 mb-3 d-flex align-items-start" | ||||||
|               > |  | ||||||
|                 <label |  | ||||||
|                   className="form-check-label d-flex align-items-center" |  | ||||||
|                   htmlFor={perm.id} |  | ||||||
|                 > |  | ||||||
|                   <input |  | ||||||
|                     type="checkbox" |  | ||||||
|                     className="form-check-input me-2" |  | ||||||
|                     id={perm.id} |  | ||||||
|                     {...register(`permissions.${perm.id}`, { |  | ||||||
|                       value: initialPermissions[perm.id] || false, |  | ||||||
|                     })} |  | ||||||
|                   /> |  | ||||||
|                   {perm.name} |  | ||||||
|                 </label> |  | ||||||
| 
 |  | ||||||
|                 {/* Info Icon */} |  | ||||||
|                 <div style={{ display: "flex", alignItems: "center" }}> |  | ||||||
|                   <div |  | ||||||
|                     ref={(el) => (popoverRefs.current[refIndex] = el)} |  | ||||||
|                     tabIndex="0" |  | ||||||
|                     className="d-flex align-items-center justify-content-center" |  | ||||||
|                     data-bs-toggle="popover" |  | ||||||
|                     data-bs-trigger="focus" |  | ||||||
|                     data-bs-placement="right" |  | ||||||
|                     data-bs-html="true" |  | ||||||
|                     data-bs-content={`<div class="border border-secondary rounded custom-popover p-2 px-3">${perm.description}</div>`} |  | ||||||
|                   > |  | ||||||
|                       |  | ||||||
|                     <svg |  | ||||||
|                       xmlns="http://www.w3.org/2000/svg" |  | ||||||
|                       width="13" |  | ||||||
|                       height="13" |  | ||||||
|                       fill="currentColor" |  | ||||||
|                       className="bi bi-info-circle" |  | ||||||
|                       viewBox="0 0 16 16" |  | ||||||
|                     > |                     > | ||||||
|                       <path d="M8 15A7 7 0 1 1 8 1a7 7 0 0 1 0 14zm0 1A8 8 0 1 0 8 0a8 8 0 0 0 0 16z" /> |                       <label | ||||||
|                       <path d="m8.93 6.588-2.29.287-.082.38.45.083c.294.07.352.176.288.469l-.738 3.468c-.194.897.105 1.319.547 1.11l1.91-2.011c.241-.256.384-.592.287-.984-.172-.439-.58-.827-1.13-.967a.664.664 0 0 1-.58-.309l-.15-.241-.002-.002zM8 4c-.535 0-.943.372-.943.836 0 .464.408.836.943.836.535 0 .943-.372.943-.836 0-.464-.408-.836-.943-.836z" /> |                         className="form-check-label d-flex align-items-center" | ||||||
|                     </svg> |                         htmlFor={perm.id} | ||||||
|                   </div> |                       > | ||||||
|                 </div> |                         <input | ||||||
|  |                           type="checkbox" | ||||||
|  |                           className="form-check-input me-2" | ||||||
|  |                           id={perm.id} | ||||||
|  |                           {...register(`permissions.${perm.id}`, { | ||||||
|  |                             value: initialPermissions[perm.id] || false, | ||||||
|  |                           })} | ||||||
|  |                         /> | ||||||
|  |                         {perm.name} | ||||||
|  |                       </label> | ||||||
|  | 
 | ||||||
|  |                       {/* Info Icon */} | ||||||
|  |                       <div style={{ display: "flex", alignItems: "center" }}> | ||||||
|  |                         <div | ||||||
|  |                           ref={(el) => (popoverRefs.current[refIndex] = el)} | ||||||
|  |                           tabIndex="0" | ||||||
|  |                           className="d-flex align-items-center justify-content-center" | ||||||
|  |                           data-bs-toggle="popover" | ||||||
|  |                           data-bs-trigger="focus" | ||||||
|  |                           data-bs-placement="right" | ||||||
|  |                           data-bs-html="true" | ||||||
|  |                           data-bs-content={`<div class="border border-secondary rounded custom-popover p-2 px-3">${perm.description}</div>`} | ||||||
|  |                         > | ||||||
|  |                             | ||||||
|  |                           <svg | ||||||
|  |                             xmlns="http://www.w3.org/2000/svg" | ||||||
|  |                             width="13" | ||||||
|  |                             height="13" | ||||||
|  |                             fill="currentColor" | ||||||
|  |                             className="bi bi-info-circle" | ||||||
|  |                             viewBox="0 0 16 16" | ||||||
|  |                           > | ||||||
|  |                             <path d="M8 15A7 7 0 1 1 8 1a7 7 0 0 1 0 14zm0 1A8 8 0 1 0 8 0a8 8 0 0 0 0 16z" /> | ||||||
|  |                             <path d="m8.93 6.588-2.29.287-.082.38.45.083c.294.07.352.176.288.469l-.738 3.468c-.194.897.105 1.319.547 1.11l1.91-2.011c.241-.256.384-.592.287-.984-.172-.439-.58-.827-1.13-.967a.664.664 0 0 1-.58-.309l-.15-.241-.002-.002zM8 4c-.535 0-.943.372-.943.836 0 .464.408.836.943.836.535 0 .943-.372.943-.836 0-.464-.408-.836-.943-.836z" /> | ||||||
|  |                           </svg> | ||||||
|  |                         </div> | ||||||
|  |                       </div> | ||||||
|  |                     </div> | ||||||
|  |                   ); | ||||||
|  |                 })} | ||||||
|               </div> |               </div> | ||||||
|             ); | 
 | ||||||
|           })} |               <hr className="my-2" /> | ||||||
|  |             </div> | ||||||
|  |           ))} | ||||||
|         </div> |         </div> | ||||||
| 
 | 
 | ||||||
|         <hr className="my-2" /> |         {/* Error Display */} | ||||||
|  |         {errors.permissions && ( | ||||||
|  |           <p className="text-danger">{errors.permissions.message}</p> | ||||||
|  |         )} | ||||||
|       </div> |       </div> | ||||||
|     ))} |  | ||||||
|   </div> |  | ||||||
| 
 |  | ||||||
|   {/* Error Display */} |  | ||||||
|   {errors.permissions && ( |  | ||||||
|     <p className="text-danger">{errors.permissions.message}</p> |  | ||||||
|   )} |  | ||||||
| </div> |  | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
|       <div className="col-12 text-center"> |       <div className="col-12 text-end"> | ||||||
|         <button type="submit" className="btn btn-sm btn-primary me-3"> {isLoading ? "Please Wait..." : "Submit"}</button> |  | ||||||
|         <button |         <button | ||||||
|           type="button" |           type="button" | ||||||
|           className="btn btn-sm btn-label-secondary" |           className="btn btn-sm btn-label-secondary me-3" | ||||||
|           data-bs-dismiss="modal" |           data-bs-dismiss="modal" | ||||||
|           aria-label="Close" |           aria-label="Close" | ||||||
|         > |         > | ||||||
|           Cancel |           Cancel | ||||||
|         </button> |         </button> | ||||||
|  |         <button type="submit" className="btn btn-sm btn-primary"> {isLoading ? "Please Wait..." : "Submit"}</button> | ||||||
|  | 
 | ||||||
|       </div> |       </div> | ||||||
| 
 | 
 | ||||||
|     </form> |     </form> | ||||||
|  | |||||||
| @ -6,6 +6,7 @@ import { | |||||||
|   useCreateExpenseType, |   useCreateExpenseType, | ||||||
|   useUpdateExpenseType, |   useUpdateExpenseType, | ||||||
| } from "../../hooks/masterHook/useMaster"; | } from "../../hooks/masterHook/useMaster"; | ||||||
|  | import Label from "../common/Label"; | ||||||
| 
 | 
 | ||||||
| const ExpnseSchema = z.object({ | const ExpnseSchema = z.object({ | ||||||
|   name: z.string().min(1, { message: "Name is required" }), |   name: z.string().min(1, { message: "Name is required" }), | ||||||
| @ -52,8 +53,8 @@ const ManageExpenseType = ({ data = null, onClose }) => { | |||||||
|   }, [data]); |   }, [data]); | ||||||
|   return ( |   return ( | ||||||
|     <form className="row g-2" onSubmit={handleSubmit(onSubmit)}> |     <form className="row g-2" onSubmit={handleSubmit(onSubmit)}> | ||||||
|       <div className="col-12 col-md-12"> |       <div className="col-12 col-md-12 text-start"> | ||||||
|         <label className="form-label">Expesne Type Name</label> |         <Label className="form-label" required>Expesne Type Name</Label> | ||||||
|         <input |         <input | ||||||
|           type="text" |           type="text" | ||||||
|           {...register("name")} |           {...register("name")} | ||||||
| @ -61,10 +62,10 @@ const ManageExpenseType = ({ data = null, onClose }) => { | |||||||
|         /> |         /> | ||||||
|         {errors.name && <p className="danger-text">{errors.name.message}</p>} |         {errors.name && <p className="danger-text">{errors.name.message}</p>} | ||||||
|       </div> |       </div> | ||||||
|       <div className="col-12 col-md-12"> |       <div className="col-12 col-md-12 text-start"> | ||||||
|         <label className="form-label" htmlFor="description"> |         <Label className="form-label" htmlFor="description" required> | ||||||
|           Description |           Description | ||||||
|         </label> |         </Label> | ||||||
|         <textarea |         <textarea | ||||||
|           rows="3" |           rows="3" | ||||||
|           {...register("description")} |           {...register("description")} | ||||||
| @ -83,10 +84,20 @@ const ManageExpenseType = ({ data = null, onClose }) => { | |||||||
|           {...register("noOfPersonsRequired")} |           {...register("noOfPersonsRequired")} | ||||||
|         /> |         /> | ||||||
|       </div> |       </div> | ||||||
|       <div className="col-12 text-center"> |       <div className="col-12 text-end"> | ||||||
|  |         <button | ||||||
|  |           type="reset" | ||||||
|  |           className="btn btn-sm btn-label-secondary me-3" | ||||||
|  |           data-bs-dismiss="modal" | ||||||
|  |           aria-label="Close" | ||||||
|  |           disabled={isPending || isPendingUpdate} | ||||||
|  |           onClick={()=>onClose()} | ||||||
|  |         > | ||||||
|  |           Cancel | ||||||
|  |         </button> | ||||||
|         <button |         <button | ||||||
|           type="submit" |           type="submit" | ||||||
|           className="btn btn-sm btn-primary me-3" |           className="btn btn-sm btn-primary" | ||||||
|           disabled={isPending || isPendingUpdate} |           disabled={isPending || isPendingUpdate} | ||||||
|         > |         > | ||||||
|           {isPending || isPendingUpdate |           {isPending || isPendingUpdate | ||||||
| @ -95,16 +106,7 @@ const ManageExpenseType = ({ data = null, onClose }) => { | |||||||
|             ? "Update" |             ? "Update" | ||||||
|             : "Submit"} |             : "Submit"} | ||||||
|         </button> |         </button> | ||||||
|         <button |          | ||||||
|           type="reset" |  | ||||||
|           className="btn btn-sm btn-label-secondary " |  | ||||||
|           data-bs-dismiss="modal" |  | ||||||
|           aria-label="Close" |  | ||||||
|           disabled={isPending || isPendingUpdate} |  | ||||||
|           onClick={()=>onClose()} |  | ||||||
|         > |  | ||||||
|           Cancel |  | ||||||
|         </button> |  | ||||||
|       </div> |       </div> | ||||||
|     </form> |     </form> | ||||||
|   ); |   ); | ||||||
|  | |||||||
| @ -3,6 +3,7 @@ import { useForm } from "react-hook-form"; | |||||||
| import { z } from "zod"; | import { z } from "zod"; | ||||||
| import { zodResolver } from "@hookform/resolvers/zod"; | import { zodResolver } from "@hookform/resolvers/zod"; | ||||||
| import { useCreatePaymentMode, useUpdatePaymentMode } from "../../hooks/masterHook/useMaster"; | import { useCreatePaymentMode, useUpdatePaymentMode } from "../../hooks/masterHook/useMaster"; | ||||||
|  | import Label from "../common/Label"; | ||||||
| 
 | 
 | ||||||
| const ExpnseSchema = z.object({ | const ExpnseSchema = z.object({ | ||||||
|   name: z.string().min(1, { message: "Name is required" }), |   name: z.string().min(1, { message: "Name is required" }), | ||||||
| @ -46,8 +47,8 @@ const ManagePaymentMode = ({ data = null, onClose }) => { | |||||||
| 
 | 
 | ||||||
|   return ( |   return ( | ||||||
|     <form className="row g-2" onSubmit={handleSubmit(onSubmit)}> |     <form className="row g-2" onSubmit={handleSubmit(onSubmit)}> | ||||||
|       <div className="col-12 col-md-12"> |       <div className="col-12 col-md-12 text-start"> | ||||||
|         <label className="form-label">Payment Mode Name</label> |         <Label className="form-label" required>Payment Mode Name</Label> | ||||||
|         <input |         <input | ||||||
|           type="text" |           type="text" | ||||||
|           {...register("name")} |           {...register("name")} | ||||||
| @ -55,10 +56,10 @@ const ManagePaymentMode = ({ data = null, onClose }) => { | |||||||
|         /> |         /> | ||||||
|         {errors.name && <p className="danger-text">{errors.name.message}</p>} |         {errors.name && <p className="danger-text">{errors.name.message}</p>} | ||||||
|       </div> |       </div> | ||||||
|       <div className="col-12 col-md-12"> |       <div className="col-12 col-md-12 text-start"> | ||||||
|         <label className="form-label" htmlFor="description"> |         <Label className="form-label" htmlFor="description" required> | ||||||
|           Description |           Description | ||||||
|         </label> |         </Label> | ||||||
|         <textarea |         <textarea | ||||||
|           rows="3" |           rows="3" | ||||||
|           {...register("description")} |           {...register("description")} | ||||||
| @ -70,23 +71,24 @@ const ManagePaymentMode = ({ data = null, onClose }) => { | |||||||
|         )} |         )} | ||||||
|       </div> |       </div> | ||||||
| 
 | 
 | ||||||
|       <div className="col-12 text-center"> |       <div className="col-12 text-end"> | ||||||
|         <button |  | ||||||
|           type="submit" |  | ||||||
|           className="btn btn-sm btn-primary me-3" |  | ||||||
|           disabled={isPending || Updating} |  | ||||||
|         > |  | ||||||
|           {isPending || Updating? "Please Wait..." : Updating ? "Update" : "Submit"} |  | ||||||
|         </button> |  | ||||||
|         <button |         <button | ||||||
|           type="reset" |           type="reset" | ||||||
|           className="btn btn-sm btn-label-secondary " |           className="btn btn-sm btn-label-secondary me-3" | ||||||
|           data-bs-dismiss="modal" |           data-bs-dismiss="modal" | ||||||
|           aria-label="Close" |           aria-label="Close" | ||||||
|           disabled={isPending || Updating} |           disabled={isPending || Updating} | ||||||
|         > |         > | ||||||
|           Cancel |           Cancel | ||||||
|         </button> |         </button> | ||||||
|  |         <button | ||||||
|  |           type="submit" | ||||||
|  |           className="btn btn-sm btn-primary" | ||||||
|  |           disabled={isPending || Updating} | ||||||
|  |         > | ||||||
|  |           {isPending || Updating? "Please Wait..." : Updating ? "Update" : "Submit"} | ||||||
|  |         </button> | ||||||
|  |          | ||||||
|       </div> |       </div> | ||||||
|     </form> |     </form> | ||||||
|   ); |   ); | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user