|  |  | @ -81,7 +81,9 @@ const generateDepartmentId = async (city, departmentName) => { | 
			
		
	
		
		
			
				
					
					|  |  |  |    |  |  |  |    | 
			
		
	
		
		
			
				
					
					|  |  |  |       // Generate departmentId based on departmentName
 |  |  |  |       // Generate departmentId based on departmentName
 | 
			
		
	
		
		
			
				
					
					|  |  |  |     //   const prefix = departmentName.substring(0, 2).toUpperCase(); // Extract first two letters and convert to uppercase
 |  |  |  |     //   const prefix = departmentName.substring(0, 2).toUpperCase(); // Extract first two letters and convert to uppercase
 | 
			
		
	
		
		
			
				
					
					|  |  |  |        const cityId = await generateCityId(); |  |  |  |        const c_id = await generateCityId(); | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |        const cityId = `AWCI${c_id}`; | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  |    |  |  |  |    | 
			
		
	
		
		
			
				
					
					|  |  |  |       // Check for existing department
 |  |  |  |       // Check for existing department
 | 
			
		
	
		
		
			
				
					
					|  |  |  |       const existingStore = await City.findOne({ cityId }); |  |  |  |       const existingStore = await City.findOne({ cityId }); | 
			
		
	
	
		
		
			
				
					|  |  | @ -953,12 +955,16 @@ exports.getZonebasedLocations = async (req, reply) => { | 
			
		
	
		
		
			
				
					
					|  |  |  |   //   }
 |  |  |  |   //   }
 | 
			
		
	
		
		
			
				
					
					|  |  |  |   // };
 |  |  |  |   // };
 | 
			
		
	
		
		
			
				
					
					|  |  |  |    |  |  |  |    | 
			
		
	
		
		
			
				
					
					|  |  |  |   const getDepartmentsByName = async (departmentName, city) => { |  |  |  | // Updated helper function that accepts all three parameters
 | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  | const getDepartmentsByName = async (officeName, city, departmentName) => {  | 
			
		
	
		
		
			
				
					
					|  |  |  |   try { |  |  |  |   try { | 
			
		
	
		
		
			
				
					
					|  |  |  |       const trimmedDepartment = departmentName.trim(); |  |  |  |     // Trim all parameters
 | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |     const trimmedOfficeName = officeName.trim(); | 
			
		
	
		
		
			
				
					
					|  |  |  |     const trimmedCity = city.trim(); |  |  |  |     const trimmedCity = city.trim(); | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |     const trimmedDepartment = departmentName.trim(); | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  |     const query = { |  |  |  |     const query = { | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |       officeName: { $regex: trimmedOfficeName, $options: "i" }, | 
			
		
	
		
		
			
				
					
					|  |  |  |       departmentName: { $regex: trimmedDepartment, $options: "i" }, |  |  |  |       departmentName: { $regex: trimmedDepartment, $options: "i" }, | 
			
		
	
		
		
			
				
					
					|  |  |  |       city: { $regex: trimmedCity, $options: "i" } |  |  |  |       city: { $regex: trimmedCity, $options: "i" } | 
			
		
	
		
		
			
				
					
					|  |  |  |     }; |  |  |  |     }; | 
			
		
	
	
		
		
			
				
					|  |  | @ -973,7 +979,7 @@ exports.getZonebasedLocations = async (req, reply) => { | 
			
		
	
		
		
			
				
					
					|  |  |  |     console.error("Error fetching department data:", err); |  |  |  |     console.error("Error fetching department data:", err); | 
			
		
	
		
		
			
				
					
					|  |  |  |     throw new Error("Error fetching department data."); |  |  |  |     throw new Error("Error fetching department data."); | 
			
		
	
		
		
			
				
					
					|  |  |  |   } |  |  |  |   } | 
			
		
	
		
		
			
				
					
					|  |  |  |   }; |  |  |  | }; | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  |   // API Route
 |  |  |  |   // API Route
 | 
			
		
	
	
		
		
			
				
					|  |  | @ -981,19 +987,21 @@ exports.getZonebasedLocations = async (req, reply) => { | 
			
		
	
		
		
			
				
					
					|  |  |  |     try { |  |  |  |     try { | 
			
		
	
		
		
			
				
					
					|  |  |  |       console.log("Request Params:", req.params); // Debugging log
 |  |  |  |       console.log("Request Params:", req.params); // Debugging log
 | 
			
		
	
		
		
			
				
					
					|  |  |  |    |  |  |  |    | 
			
		
	
		
		
			
				
					
					|  |  |  |       let { departmentName, city } = req.params; |  |  |  |       let { departmentName, city, officeName } = req.params; | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					|  |  |  |    |  |  |  |    | 
			
		
	
		
		
			
				
					
					|  |  |  |       if (!departmentName || !city) { |  |  |  |       if (!departmentName || !city || !officeName) { | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  |  |         return reply.status(400).send({ message: "Department Name and City are required." }); |  |  |  |         return reply.status(400).send({ message: "Department Name, City, and Office Name are required." }); | 
			
				
				
			
		
	
		
		
	
		
		
	
		
		
			
				
					
					|  |  |  |       } |  |  |  |       } | 
			
		
	
		
		
			
				
					
					|  |  |  |    |  |  |  |    | 
			
		
	
		
		
			
				
					
					|  |  |  |       departmentName = departmentName.trim(); |  |  |  |       departmentName = departmentName.trim(); | 
			
		
	
		
		
			
				
					
					|  |  |  |       city = city.trim(); |  |  |  |       city = city.trim(); | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |       officeName = officeName.trim(); | 
			
		
	
		
		
			
				
					
					|  |  |  |    |  |  |  |    | 
			
		
	
		
		
			
				
					
					|  |  |  |       const departments = await getDepartmentsByName(departmentName, city); |  |  |  |       // Note the order: officeName, city, departmentName
 | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |       const departments = await getDepartmentsByName(officeName, city, departmentName); | 
			
		
	
		
		
			
				
					
					|  |  |  |    |  |  |  |    | 
			
		
	
		
		
			
				
					
					|  |  |  |       if (departments.length === 0) { |  |  |  |       if (departments.length === 0) { | 
			
		
	
		
		
			
				
					
					|  |  |  |         return reply.status(404).send({ message: "No departments found for the specified name and city." }); |  |  |  |         return reply.status(404).send({ message: "No departments found for the specified parameters." }); | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					|  |  |  |       } |  |  |  |       } | 
			
		
	
		
		
			
				
					
					|  |  |  |    |  |  |  |    | 
			
		
	
		
		
			
				
					
					|  |  |  |       reply.send({ status_code: 200, data: departments }); |  |  |  |       reply.send({ status_code: 200, data: departments }); | 
			
		
	
	
		
		
			
				
					|  |  | @ -1079,3 +1087,47 @@ exports.getZonebasedLocations = async (req, reply) => { | 
			
		
	
		
		
			
				
					
					|  |  |  |     } |  |  |  |     } | 
			
		
	
		
		
			
				
					
					|  |  |  |   }; |  |  |  |   }; | 
			
		
	
		
		
			
				
					
					|  |  |  |    |  |  |  |    | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |   // Helper function to fetch department names by city
 | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |   const getDepartmentNamesByCity = async (city) => { | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |     try { | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |       const trimmedCity = city.trim(); | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |        | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |       // Allow for extra whitespace before or after the city value in the database
 | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |       const query = { | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |         city: { $regex: `^\\s*${trimmedCity}\\s*$`, $options: "i" } | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |       }; | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |       console.log("MongoDB Query:", JSON.stringify(query, null, 2)); | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |        | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |       const result = await Deparments.find(query) | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |         .select("departmentName -_id") | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |         .lean(); | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |        | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |       return result.map(doc => doc.departmentName); | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |     } catch (error) { | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |       console.error("Error fetching departments by city:", error); | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |       throw new Error("Error fetching departments by city."); | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |     } | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |   }; | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |    | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  | // API route handler
 | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  | exports.getDepartmentsByCity = async (req, reply) => { | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |   try { | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |     const { city } = req.params; | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |     if (!city || city.trim() === "") { | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |       return reply.status(400).send({ message: "City is required." }); | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |     } | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |      | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |     const departmentNames = await getDepartmentNamesByCity(city); | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |      | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |     if (departmentNames.length === 0) { | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |       return reply.status(404).send({ message: "No departments found for the specified city." }); | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |     } | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |      | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |     reply.send({ status_code: 200, data: departmentNames }); | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |   } catch (error) { | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |     console.error("API Error:", error); | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |     reply.status(500).send({ message: error.message }); | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |   } | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  | }; | 
			
		
	
	
		
		
			
				
					|  |  | 
 |