Vaibhav_Task-#89 #29
| @ -21,7 +21,8 @@ const ManageProjectInfo = ( {project,handleSubmitForm, onClose} ) => | |||||||
|   |   | ||||||
|   const [CurrentProject,setCurrentProject] = useState() |   const [CurrentProject,setCurrentProject] = useState() | ||||||
|   const [ isloading, setLoading ] = useState( false ) |   const [ isloading, setLoading ] = useState( false ) | ||||||
|    |   const [addressLength, setAddressLength] = useState(0); | ||||||
|  |   const maxAddressLength = 500; | ||||||
| 
 | 
 | ||||||
|   const projectSchema = z.object( { |   const projectSchema = z.object( { | ||||||
|     ...(project?.id ? { id: z.number().optional() } : {}), |     ...(project?.id ? { id: z.number().optional() } : {}), | ||||||
| @ -79,7 +80,9 @@ const ManageProjectInfo = ( {project,handleSubmitForm, onClose} ) => | |||||||
|         projectStatusId:  String(project.projectStatusId) || "0" , |         projectStatusId:  String(project.projectStatusId) || "0" , | ||||||
|     |     | ||||||
|       } :{} |       } :{} | ||||||
|  |        | ||||||
|     ) |     ) | ||||||
|  |     setAddressLength(project?.projectAddress?.length || 0);  | ||||||
|   },[project,reset,]) |   },[project,reset,]) | ||||||
| 
 | 
 | ||||||
|    |    | ||||||
| @ -205,16 +208,20 @@ const ManageProjectInfo = ( {project,handleSubmitForm, onClose} ) => | |||||||
|               </label> |               </label> | ||||||
|               <div className="input-group"> |               <div className="input-group"> | ||||||
|                 <textarea |                 <textarea | ||||||
|                   type="text" |  | ||||||
|                   id="projectAddress" |                   id="projectAddress" | ||||||
|                   name="projectAddress" |                   name="projectAddress" | ||||||
|                   className="form-control" |                   className="form-control" | ||||||
|  |                   maxLength={maxAddressLength} | ||||||
|                   {...register("projectAddress")} |                   {...register("projectAddress")} | ||||||
|                    |                   onChange={(e) => { | ||||||
|  |                     setAddressLength(e.target.value.length); | ||||||
|  |                   }} | ||||||
|                 /> |                 /> | ||||||
|               </div> |               </div> | ||||||
|  |               <div className="text-end" style={{ fontSize: "12px" }}> | ||||||
|  |                 {maxAddressLength - addressLength} characters remaining | ||||||
|  |               </div> | ||||||
|               {errors.projectAddress && <div className="danger-text text-start" style={{fontSize:"12px"}}>{errors.projectAddress.message}</div>} |               {errors.projectAddress && <div className="danger-text text-start" style={{fontSize:"12px"}}>{errors.projectAddress.message}</div>} | ||||||
| 
 |  | ||||||
|             </div> |             </div> | ||||||
|             <div className="col-12 text-center"> |             <div className="col-12 text-center"> | ||||||
|               <button type="submit" className="btn btn-sm btn-primary me-3" > |               <button type="submit" className="btn btn-sm btn-primary me-3" > | ||||||
|  | |||||||
| @ -68,9 +68,13 @@ const EditJobRole = ({data,onClose}) => { | |||||||
|       reset({ |       reset({ | ||||||
|         role: data?.name, |         role: data?.name, | ||||||
|         description: data?.description |         description: data?.description | ||||||
|       }) |       }); | ||||||
|  |       setDescriptionLength(data?.description?.length || 0); | ||||||
|  |     }, [data, reset]); | ||||||
|  |      | ||||||
|  |   const [descriptionLength, setDescriptionLength] = useState(data?.description?.length || 0); | ||||||
|  |   const maxDescriptionLength = 255; | ||||||
| 
 | 
 | ||||||
|     },[data,reset]) |  | ||||||
|       |       | ||||||
|   return (<> |   return (<> | ||||||
|     <form  className="row g-2" onSubmit={handleSubmit(onSubmit)}> |     <form  className="row g-2" onSubmit={handleSubmit(onSubmit)}> | ||||||
| @ -88,10 +92,18 @@ const EditJobRole = ({data,onClose}) => { | |||||||
|           rows="3" |           rows="3" | ||||||
|           {...register("description")} |           {...register("description")} | ||||||
|           className={`form-control ${errors.description ? 'is-invalids' : ''}`} |           className={`form-control ${errors.description ? 'is-invalids' : ''}`} | ||||||
|  |           onChange={(e) => { | ||||||
|  |             setDescriptionLength(e.target.value.length); | ||||||
|  |             register("description").onChange(e); | ||||||
|  |           }} | ||||||
|         ></textarea> |         ></textarea> | ||||||
|  |         <div className="text-end small text-muted"> | ||||||
|  |           {maxDescriptionLength - descriptionLength} characters left | ||||||
|  |         </div> | ||||||
|         {errors.description && ( |         {errors.description && ( | ||||||
|           <p className="text-danger">{errors.description.message}</p> |           <p className="text-danger">{errors.description.message}</p> | ||||||
|         )} |         )} | ||||||
|  | 
 | ||||||
|         </div> |         </div> | ||||||
| 
 | 
 | ||||||
|         <div className="col-12 text-center"> |         <div className="col-12 text-center"> | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user