|
|
|
@ -10,29 +10,51 @@ const fastify = require("fastify")({
|
|
|
|
|
});
|
|
|
|
|
const { Counter} = require('../models/User')
|
|
|
|
|
|
|
|
|
|
const {Department, Desgination} = require('../models/Department')
|
|
|
|
|
const generateDepartmentId = async (prefix) => {
|
|
|
|
|
const result = await Counter.findOneAndUpdate(
|
|
|
|
|
{ _id: 'department_id' },
|
|
|
|
|
const {Department, Desgination, City, Deparments} = require('../models/Department')
|
|
|
|
|
// const generateDepartmentId = async (prefix) => {
|
|
|
|
|
// const result = await Counter.findOneAndUpdate(
|
|
|
|
|
// { _id: 'department_id' },
|
|
|
|
|
// { $inc: { seq: 1 } },
|
|
|
|
|
// { upsert: true, new: true }
|
|
|
|
|
// );
|
|
|
|
|
// return `AW${prefix}${result.seq}`;
|
|
|
|
|
// };
|
|
|
|
|
|
|
|
|
|
const generateCityId = async () => {
|
|
|
|
|
var result = await Counter.findOneAndUpdate(
|
|
|
|
|
{ _id: 'customer_id' },
|
|
|
|
|
{ $inc: { seq: 1 } },
|
|
|
|
|
{ upsert: true, new: true }
|
|
|
|
|
);
|
|
|
|
|
return `AW${prefix}${result.seq}`;
|
|
|
|
|
|
|
|
|
|
return result.seq;
|
|
|
|
|
};
|
|
|
|
|
const generateDesginationId = async (prefix) => {
|
|
|
|
|
// const generateDesginationId = async (prefix) => {
|
|
|
|
|
// const result = await Counter.findOneAndUpdate(
|
|
|
|
|
// { _id: 'desgination_id' },
|
|
|
|
|
// { $inc: { seq: 1 } },
|
|
|
|
|
// { upsert: true, new: true }
|
|
|
|
|
// );
|
|
|
|
|
// return `AW${prefix}${result.seq}`;
|
|
|
|
|
// };
|
|
|
|
|
|
|
|
|
|
const generateDepartmentId = async (city, departmentName) => {
|
|
|
|
|
const cityPrefix = city.substring(0, 2).toUpperCase(); // Extract first two letters of city
|
|
|
|
|
const departmentPrefix = departmentName.substring(0, 2).toUpperCase(); // Extract first two letters of departmentName
|
|
|
|
|
|
|
|
|
|
const result = await Counter.findOneAndUpdate(
|
|
|
|
|
{ _id: 'desgination_id' },
|
|
|
|
|
{ $inc: { seq: 1 } },
|
|
|
|
|
{ upsert: true, new: true }
|
|
|
|
|
);
|
|
|
|
|
return `AW${prefix}${result.seq}`;
|
|
|
|
|
|
|
|
|
|
return `AW${cityPrefix}${departmentPrefix}${result.seq}`; // Generate ID
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
exports.addDepartment = async (request, reply) => {
|
|
|
|
|
exports.addCity = async (request, reply) => {
|
|
|
|
|
try {
|
|
|
|
|
const {
|
|
|
|
|
departmentName,
|
|
|
|
|
phone,
|
|
|
|
|
officeName,
|
|
|
|
|
location,
|
|
|
|
@ -48,18 +70,18 @@ const generateDepartmentId = async (prefix) => {
|
|
|
|
|
} = request.body;
|
|
|
|
|
|
|
|
|
|
// Generate departmentId based on departmentName
|
|
|
|
|
const prefix = departmentName.substring(0, 2).toUpperCase(); // Extract first two letters and convert to uppercase
|
|
|
|
|
const departmentId = await generateDepartmentId(prefix);
|
|
|
|
|
// const prefix = departmentName.substring(0, 2).toUpperCase(); // Extract first two letters and convert to uppercase
|
|
|
|
|
const cityId = await generateCityId();
|
|
|
|
|
|
|
|
|
|
// Check for existing department
|
|
|
|
|
const existingStore = await Department.findOne({ departmentId });
|
|
|
|
|
const existingStore = await City.findOne({ cityId });
|
|
|
|
|
if (existingStore) {
|
|
|
|
|
return reply.status(400).send({ message: 'Department is already registered' });
|
|
|
|
|
return reply.status(400).send({ message: 'City is already registered' });
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// Create new department
|
|
|
|
|
const department = new Department({
|
|
|
|
|
departmentId,
|
|
|
|
|
const citys = new City({
|
|
|
|
|
cityId,
|
|
|
|
|
phone,
|
|
|
|
|
officeName,
|
|
|
|
|
location,
|
|
|
|
@ -70,49 +92,49 @@ const generateDepartmentId = async (prefix) => {
|
|
|
|
|
zone,
|
|
|
|
|
country,
|
|
|
|
|
pincode,
|
|
|
|
|
departmentName,
|
|
|
|
|
// departmentName,
|
|
|
|
|
createdBy,
|
|
|
|
|
updatedBy,
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
await department.save();
|
|
|
|
|
await citys.save();
|
|
|
|
|
|
|
|
|
|
reply.send({ department, message: 'Account Created Successfully' });
|
|
|
|
|
reply.send({ citys, message: 'Account Created Successfully' });
|
|
|
|
|
} catch (err) {
|
|
|
|
|
reply.status(500).send({ message: err.message });
|
|
|
|
|
}
|
|
|
|
|
};
|
|
|
|
|
exports.getSinledepartmentData = async (req, reply) => {
|
|
|
|
|
try {
|
|
|
|
|
const { departmentId } = req.params;
|
|
|
|
|
|
|
|
|
|
const department = await Department.findOne({ departmentId: departmentId });
|
|
|
|
|
|
|
|
|
|
if (!department) {
|
|
|
|
|
return reply.code(404).send({
|
|
|
|
|
success: false,
|
|
|
|
|
message: 'Department not found.'
|
|
|
|
|
});
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
reply.code(200).send({
|
|
|
|
|
success: true,
|
|
|
|
|
message: 'Department data retrieved successfully.',
|
|
|
|
|
data: department
|
|
|
|
|
});
|
|
|
|
|
} catch (error) {
|
|
|
|
|
console.error('Error fetching department data:', error);
|
|
|
|
|
reply.code(500).send({
|
|
|
|
|
success: false,
|
|
|
|
|
message: 'Failed to retrieve department data.',
|
|
|
|
|
error: error.message,
|
|
|
|
|
});
|
|
|
|
|
}
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
exports.getalldepartmants = async (req, reply) => {
|
|
|
|
|
// exports.getSinledepartmentData = async (req, reply) => {
|
|
|
|
|
// try {
|
|
|
|
|
// const { departmentId } = req.params;
|
|
|
|
|
|
|
|
|
|
// const department = await Department.findOne({ departmentId: departmentId });
|
|
|
|
|
|
|
|
|
|
// if (!department) {
|
|
|
|
|
// return reply.code(404).send({
|
|
|
|
|
// success: false,
|
|
|
|
|
// message: 'Department not found.'
|
|
|
|
|
// });
|
|
|
|
|
// }
|
|
|
|
|
|
|
|
|
|
// reply.code(200).send({
|
|
|
|
|
// success: true,
|
|
|
|
|
// message: 'Department data retrieved successfully.',
|
|
|
|
|
// data: department
|
|
|
|
|
// });
|
|
|
|
|
// } catch (error) {
|
|
|
|
|
// console.error('Error fetching department data:', error);
|
|
|
|
|
// reply.code(500).send({
|
|
|
|
|
// success: false,
|
|
|
|
|
// message: 'Failed to retrieve department data.',
|
|
|
|
|
// error: error.message,
|
|
|
|
|
// });
|
|
|
|
|
// }
|
|
|
|
|
// };
|
|
|
|
|
|
|
|
|
|
exports.getallcities = async (req, reply) => {
|
|
|
|
|
try {
|
|
|
|
|
await Department.find()
|
|
|
|
|
await City.find()
|
|
|
|
|
.exec()
|
|
|
|
|
.then((docs) => {
|
|
|
|
|
reply.send({ status_code: 200, data: docs, count: docs.length });
|
|
|
|
@ -127,38 +149,38 @@ const generateDepartmentId = async (prefix) => {
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
exports.getAllDepartmentsParticularFields = async (req, reply) => {
|
|
|
|
|
// exports.getAllDepartmentsParticularFields = async (req, reply) => {
|
|
|
|
|
// try {
|
|
|
|
|
// const departments = await Department.find().exec();
|
|
|
|
|
|
|
|
|
|
// // Grouping the data
|
|
|
|
|
// const result = {
|
|
|
|
|
// cities: [...new Set(departments.map((doc) => doc.city))],
|
|
|
|
|
// zones: [...new Set(departments.map((doc) => doc.zone))],
|
|
|
|
|
// pincodes: [...new Set(departments.map((doc) => doc.pincode))],
|
|
|
|
|
// departments: [...new Set(departments.map((doc) => doc.departmentName))],
|
|
|
|
|
// states: [...new Set(departments.map((doc) => doc.state))],
|
|
|
|
|
// countries: [...new Set(departments.map((doc) => doc.country))],
|
|
|
|
|
// };
|
|
|
|
|
|
|
|
|
|
// // Sending the response
|
|
|
|
|
// reply.send({
|
|
|
|
|
// status_code: 200,
|
|
|
|
|
// data: result,
|
|
|
|
|
// count: departments.length,
|
|
|
|
|
// });
|
|
|
|
|
// } catch (err) {
|
|
|
|
|
// console.error(err);
|
|
|
|
|
// reply.send({ error: err.message });
|
|
|
|
|
// }
|
|
|
|
|
// };
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
exports.deletecityInfo = async (req, reply) => {
|
|
|
|
|
try {
|
|
|
|
|
const departments = await Department.find().exec();
|
|
|
|
|
|
|
|
|
|
// Grouping the data
|
|
|
|
|
const result = {
|
|
|
|
|
cities: [...new Set(departments.map((doc) => doc.city))],
|
|
|
|
|
zones: [...new Set(departments.map((doc) => doc.zone))],
|
|
|
|
|
pincodes: [...new Set(departments.map((doc) => doc.pincode))],
|
|
|
|
|
departments: [...new Set(departments.map((doc) => doc.departmentName))],
|
|
|
|
|
states: [...new Set(departments.map((doc) => doc.state))],
|
|
|
|
|
countries: [...new Set(departments.map((doc) => doc.country))],
|
|
|
|
|
};
|
|
|
|
|
const cityId = req.params.cityId;
|
|
|
|
|
|
|
|
|
|
// Sending the response
|
|
|
|
|
reply.send({
|
|
|
|
|
status_code: 200,
|
|
|
|
|
data: result,
|
|
|
|
|
count: departments.length,
|
|
|
|
|
});
|
|
|
|
|
} catch (err) {
|
|
|
|
|
console.error(err);
|
|
|
|
|
reply.send({ error: err.message });
|
|
|
|
|
}
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
exports.deletedepartmentInfo = async (req, reply) => {
|
|
|
|
|
try {
|
|
|
|
|
const departmentId = req.params.departmentId;
|
|
|
|
|
|
|
|
|
|
const department = await Department.findOneAndDelete({ departmentId:departmentId });
|
|
|
|
|
const department = await City.findOneAndDelete({ cityId:cityId });
|
|
|
|
|
|
|
|
|
|
reply.send({ status_code: 200, message: 'Delete Sucessfully', department});
|
|
|
|
|
} catch (err) {
|
|
|
|
@ -167,9 +189,9 @@ exports.getAllDepartmentsParticularFields = async (req, reply) => {
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
exports.editdepartment = async (request, reply) => {
|
|
|
|
|
exports.editcity = async (request, reply) => {
|
|
|
|
|
try {
|
|
|
|
|
const { departmentId } = request.params;
|
|
|
|
|
const { cityId } = request.params;
|
|
|
|
|
const {
|
|
|
|
|
|
|
|
|
|
// phone,
|
|
|
|
@ -180,14 +202,14 @@ exports.getAllDepartmentsParticularFields = async (req, reply) => {
|
|
|
|
|
address1,
|
|
|
|
|
address2,
|
|
|
|
|
pincode,
|
|
|
|
|
departmentName
|
|
|
|
|
// departmentName
|
|
|
|
|
|
|
|
|
|
} = request.body;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
const existing = await Department.findOne({ departmentId });
|
|
|
|
|
const existing = await City.findOne({ cityId });
|
|
|
|
|
if (!existing) {
|
|
|
|
|
return reply.status(404).send({ message: 'Department not found' });
|
|
|
|
|
return reply.status(404).send({ message: 'City not found' });
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// const phoneExists = await Department.findOne({ phone, departmentId: { $ne: departmentId } });
|
|
|
|
@ -201,7 +223,7 @@ exports.getAllDepartmentsParticularFields = async (req, reply) => {
|
|
|
|
|
existing.state = state || existing.state;
|
|
|
|
|
existing.country = country || existing.country;
|
|
|
|
|
existing.zone = zone || existing.zone;
|
|
|
|
|
existing.departmentName = departmentName || existing.departmentName;
|
|
|
|
|
// existing.departmentName = departmentName || existing.departmentName;
|
|
|
|
|
existing.pincode = pincode || existing.pincode;
|
|
|
|
|
|
|
|
|
|
existing.address1 = address1 || existing.address1;
|
|
|
|
@ -211,17 +233,88 @@ exports.getAllDepartmentsParticularFields = async (req, reply) => {
|
|
|
|
|
|
|
|
|
|
await existing.save();
|
|
|
|
|
|
|
|
|
|
reply.send({ message: 'Department user updated successfully' });
|
|
|
|
|
reply.send({ message: 'City user updated successfully' });
|
|
|
|
|
} catch (err) {
|
|
|
|
|
reply.status(500).send({ message: err.message });
|
|
|
|
|
}
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
exports.addDesgination = async (request, reply) => {
|
|
|
|
|
// exports.addDesgination = async (request, reply) => {
|
|
|
|
|
// try {
|
|
|
|
|
// const {
|
|
|
|
|
// phone,
|
|
|
|
|
// city,
|
|
|
|
|
// firstName,
|
|
|
|
|
// lastName,
|
|
|
|
|
// departmentName,
|
|
|
|
|
// reportingManager,
|
|
|
|
|
// email,
|
|
|
|
|
// state,
|
|
|
|
|
// password,
|
|
|
|
|
// country,
|
|
|
|
|
// zone,
|
|
|
|
|
// address1,
|
|
|
|
|
// address2,
|
|
|
|
|
// pincode,
|
|
|
|
|
// desginationName,
|
|
|
|
|
// location,
|
|
|
|
|
// createdBy,
|
|
|
|
|
// updatedBy,
|
|
|
|
|
// } = request.body;
|
|
|
|
|
|
|
|
|
|
// // Generate desginationId based on desginationName
|
|
|
|
|
// const prefix = departmentName.substring(0, 2).toUpperCase();
|
|
|
|
|
// const desginationId = await generateDesginationId(prefix);
|
|
|
|
|
|
|
|
|
|
// // Check if the phone is already registered
|
|
|
|
|
// const existingStore = await Desgination.findOne({ phone });
|
|
|
|
|
// if (existingStore) {
|
|
|
|
|
// return reply.status(400).send({ message: 'Phone is already registered' });
|
|
|
|
|
// }
|
|
|
|
|
|
|
|
|
|
// // Hash the password
|
|
|
|
|
// const hashedPassword = await bcrypt.hash(password, 10);
|
|
|
|
|
|
|
|
|
|
// // Create a new designation
|
|
|
|
|
// const desgination = new Desgination({
|
|
|
|
|
// desginationId,
|
|
|
|
|
// city,
|
|
|
|
|
// firstName,
|
|
|
|
|
// lastName,
|
|
|
|
|
// email,
|
|
|
|
|
// reportingManager,
|
|
|
|
|
// departmentName,
|
|
|
|
|
// phone,
|
|
|
|
|
// address1,
|
|
|
|
|
// address2,
|
|
|
|
|
// services: { password: { bcrypt: hashedPassword } },
|
|
|
|
|
// state,
|
|
|
|
|
// zone,
|
|
|
|
|
// country,
|
|
|
|
|
// pincode,
|
|
|
|
|
// desginationName,
|
|
|
|
|
// location,
|
|
|
|
|
// createdBy,
|
|
|
|
|
// updatedBy,
|
|
|
|
|
// });
|
|
|
|
|
|
|
|
|
|
// await desgination.save();
|
|
|
|
|
|
|
|
|
|
// reply.send({ desgination, message: 'Account Created Successfully' });
|
|
|
|
|
// } catch (err) {
|
|
|
|
|
// reply.status(500).send({ message: err.message });
|
|
|
|
|
// }
|
|
|
|
|
// };
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
exports.addDepartment = async (request, reply) => {
|
|
|
|
|
try {
|
|
|
|
|
const {
|
|
|
|
|
phone,
|
|
|
|
|
alternativeContactNumber,
|
|
|
|
|
gender,
|
|
|
|
|
personalEmail,
|
|
|
|
|
city,
|
|
|
|
|
firstName,
|
|
|
|
|
lastName,
|
|
|
|
@ -241,12 +334,11 @@ exports.getAllDepartmentsParticularFields = async (req, reply) => {
|
|
|
|
|
updatedBy,
|
|
|
|
|
} = request.body;
|
|
|
|
|
|
|
|
|
|
// Generate desginationId based on desginationName
|
|
|
|
|
const prefix = departmentName.substring(0, 2).toUpperCase();
|
|
|
|
|
const desginationId = await generateDesginationId(prefix);
|
|
|
|
|
// Generate desginationId
|
|
|
|
|
const departmentId = await generateDepartmentId(city, departmentName);
|
|
|
|
|
|
|
|
|
|
// Check if the phone is already registered
|
|
|
|
|
const existingStore = await Desgination.findOne({ phone });
|
|
|
|
|
const existingStore = await Deparments.findOne({ phone });
|
|
|
|
|
if (existingStore) {
|
|
|
|
|
return reply.status(400).send({ message: 'Phone is already registered' });
|
|
|
|
|
}
|
|
|
|
@ -255,12 +347,15 @@ exports.getAllDepartmentsParticularFields = async (req, reply) => {
|
|
|
|
|
const hashedPassword = await bcrypt.hash(password, 10);
|
|
|
|
|
|
|
|
|
|
// Create a new designation
|
|
|
|
|
const desgination = new Desgination({
|
|
|
|
|
desginationId,
|
|
|
|
|
const department = new Deparments({
|
|
|
|
|
departmentId,
|
|
|
|
|
alternativeContactNumber,
|
|
|
|
|
gender,
|
|
|
|
|
city,
|
|
|
|
|
firstName,
|
|
|
|
|
lastName,
|
|
|
|
|
email,
|
|
|
|
|
personalEmail,
|
|
|
|
|
reportingManager,
|
|
|
|
|
departmentName,
|
|
|
|
|
phone,
|
|
|
|
@ -277,19 +372,19 @@ exports.getAllDepartmentsParticularFields = async (req, reply) => {
|
|
|
|
|
updatedBy,
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
await desgination.save();
|
|
|
|
|
await department.save();
|
|
|
|
|
|
|
|
|
|
reply.send({ desgination, message: 'Account Created Successfully' });
|
|
|
|
|
reply.send({ department, message: 'Account Created Successfully' });
|
|
|
|
|
} catch (err) {
|
|
|
|
|
reply.status(500).send({ message: err.message });
|
|
|
|
|
}
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
exports.getSinledesginationData = async (req, reply) => {
|
|
|
|
|
exports.getSinledepartmentData = async (req, reply) => {
|
|
|
|
|
try {
|
|
|
|
|
const { desginationId } = req.params;
|
|
|
|
|
const { departmentId } = req.params;
|
|
|
|
|
|
|
|
|
|
const department = await Desgination.findOne({ desginationId: desginationId });
|
|
|
|
|
const department = await Deparments.findOne({ departmentId: departmentId });
|
|
|
|
|
|
|
|
|
|
if (!department) {
|
|
|
|
|
return reply.code(404).send({
|
|
|
|
@ -313,9 +408,9 @@ exports.getAllDepartmentsParticularFields = async (req, reply) => {
|
|
|
|
|
}
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
exports.getalldesgination = async (req, reply) => {
|
|
|
|
|
exports.getalldepartments = async (req, reply) => {
|
|
|
|
|
try {
|
|
|
|
|
await Desgination.find()
|
|
|
|
|
await Deparments.find()
|
|
|
|
|
.exec()
|
|
|
|
|
.then((docs) => {
|
|
|
|
|
reply.send({ status_code: 200, data: docs, count: docs.length });
|
|
|
|
@ -329,11 +424,11 @@ exports.getAllDepartmentsParticularFields = async (req, reply) => {
|
|
|
|
|
}
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
exports.deletedesginationInfo = async (req, reply) => {
|
|
|
|
|
exports.deletedepartmentInfo = async (req, reply) => {
|
|
|
|
|
try {
|
|
|
|
|
const desginationId = req.params.desginationId;
|
|
|
|
|
const departmentId = req.params.departmentId;
|
|
|
|
|
|
|
|
|
|
const department = await Desgination.findOneAndDelete({ desginationId:desginationId });
|
|
|
|
|
const department = await Deparments.findOneAndDelete({ departmentId:departmentId });
|
|
|
|
|
|
|
|
|
|
reply.send({ status_code: 200, message: 'Delete Sucessfully', department});
|
|
|
|
|
} catch (err) {
|
|
|
|
@ -342,12 +437,15 @@ exports.getAllDepartmentsParticularFields = async (req, reply) => {
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
exports.editdesgination = async (request, reply) => {
|
|
|
|
|
exports.editdepartment = async (request, reply) => {
|
|
|
|
|
try {
|
|
|
|
|
const { desginationId } = request.params;
|
|
|
|
|
const { departmentId } = request.params;
|
|
|
|
|
const {
|
|
|
|
|
|
|
|
|
|
phone,
|
|
|
|
|
alternativeContactNumber,
|
|
|
|
|
gender,
|
|
|
|
|
personalEmail,
|
|
|
|
|
city,
|
|
|
|
|
firstName,
|
|
|
|
|
lastName,
|
|
|
|
@ -365,18 +463,21 @@ exports.getAllDepartmentsParticularFields = async (req, reply) => {
|
|
|
|
|
} = request.body;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
const existing = await Desgination.findOne({ desginationId });
|
|
|
|
|
const existing = await Deparments.findOne({ departmentId });
|
|
|
|
|
if (!existing) {
|
|
|
|
|
return reply.status(404).send({ message: 'Designation not found' });
|
|
|
|
|
return reply.status(404).send({ message: 'Department not found' });
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
const phoneExists = await Desgination.findOne({ phone, desginationId: { $ne: desginationId } });
|
|
|
|
|
const phoneExists = await Deparments.findOne({ phone, departmentId: { $ne: departmentId } });
|
|
|
|
|
if (phoneExists) {
|
|
|
|
|
return reply.status(400).send({ message: 'Phone is already registered to another user' });
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
existing.phone = phone || existing.phone;
|
|
|
|
|
existing.alternativeContactNumber = alternativeContactNumber || existing.alternativeContactNumber;
|
|
|
|
|
existing.personalEmail = personalEmail || existing.personalEmail;
|
|
|
|
|
existing.gender = gender || existing.gender;
|
|
|
|
|
existing.city = city || existing.city;
|
|
|
|
|
existing.state = state || existing.state;
|
|
|
|
|
existing.country = country || existing.country;
|
|
|
|
@ -396,36 +497,86 @@ exports.getAllDepartmentsParticularFields = async (req, reply) => {
|
|
|
|
|
|
|
|
|
|
await existing.save();
|
|
|
|
|
|
|
|
|
|
reply.send({ message: 'Designation user updated successfully' });
|
|
|
|
|
reply.send({ message: 'Department user updated successfully' });
|
|
|
|
|
} catch (err) {
|
|
|
|
|
reply.status(500).send({ message: err.message });
|
|
|
|
|
}
|
|
|
|
|
};
|
|
|
|
|
exports.getAllDesignationsParticularFields = async (req, reply) => {
|
|
|
|
|
// exports.getAllDesignationsParticularFields = async (req, reply) => {
|
|
|
|
|
// try {
|
|
|
|
|
// const departments = await Desgination.find().exec();
|
|
|
|
|
|
|
|
|
|
// // Grouping the data
|
|
|
|
|
// const result = {
|
|
|
|
|
// cities: [...new Set(departments.map((doc) => doc.city))],
|
|
|
|
|
// zones: [...new Set(departments.map((doc) => doc.zone))],
|
|
|
|
|
// pincodes: [...new Set(departments.map((doc) => doc.pincode))],
|
|
|
|
|
// departments: [...new Set(departments.map((doc) => doc.departmentName))],
|
|
|
|
|
// states: [...new Set(departments.map((doc) => doc.state))],
|
|
|
|
|
// countries: [...new Set(departments.map((doc) => doc.country))],
|
|
|
|
|
// designations: [...new Set(departments.map((doc) => doc.desginationName))],
|
|
|
|
|
// reportingMangers: [...new Set(departments.map((doc) => doc.reportingManager))],
|
|
|
|
|
|
|
|
|
|
// };
|
|
|
|
|
|
|
|
|
|
// // Sending the response
|
|
|
|
|
// reply.send({
|
|
|
|
|
// status_code: 200,
|
|
|
|
|
// data: result,
|
|
|
|
|
// count: departments.length,
|
|
|
|
|
// });
|
|
|
|
|
// } catch (err) {
|
|
|
|
|
// console.error(err);
|
|
|
|
|
// reply.send({ error: err.message });
|
|
|
|
|
// }
|
|
|
|
|
// };
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
const getLocationsByCityAndZone = async (city, zone) => {
|
|
|
|
|
try {
|
|
|
|
|
const departments = await Desgination.find().exec();
|
|
|
|
|
|
|
|
|
|
// Grouping the data
|
|
|
|
|
const result = {
|
|
|
|
|
cities: [...new Set(departments.map((doc) => doc.city))],
|
|
|
|
|
zones: [...new Set(departments.map((doc) => doc.zone))],
|
|
|
|
|
pincodes: [...new Set(departments.map((doc) => doc.pincode))],
|
|
|
|
|
departments: [...new Set(departments.map((doc) => doc.departmentName))],
|
|
|
|
|
states: [...new Set(departments.map((doc) => doc.state))],
|
|
|
|
|
countries: [...new Set(departments.map((doc) => doc.country))],
|
|
|
|
|
designations: [...new Set(departments.map((doc) => doc.desginationName))],
|
|
|
|
|
reportingMangers: [...new Set(departments.map((doc) => doc.reportingManager))],
|
|
|
|
|
const result = await City.aggregate([
|
|
|
|
|
{
|
|
|
|
|
$match: {
|
|
|
|
|
city: city, // Match documents with the same city
|
|
|
|
|
zone: zone, // Match documents with the same zone
|
|
|
|
|
},
|
|
|
|
|
},
|
|
|
|
|
{
|
|
|
|
|
$group: {
|
|
|
|
|
_id: { city: "$city", zone: "$zone" }, // Group by city and zone
|
|
|
|
|
locations: { $push: "$location" }, // Collect all location arrays
|
|
|
|
|
},
|
|
|
|
|
},
|
|
|
|
|
{
|
|
|
|
|
$project: {
|
|
|
|
|
_id: 0, // Exclude the _id field
|
|
|
|
|
city: "$_id.city",
|
|
|
|
|
zone: "$_id.zone",
|
|
|
|
|
locations: {
|
|
|
|
|
$reduce: {
|
|
|
|
|
input: "$locations",
|
|
|
|
|
initialValue: [],
|
|
|
|
|
in: { $concatArrays: ["$$value", "$$this"] }, // Flatten the location arrays
|
|
|
|
|
},
|
|
|
|
|
},
|
|
|
|
|
},
|
|
|
|
|
},
|
|
|
|
|
]);
|
|
|
|
|
|
|
|
|
|
return result;
|
|
|
|
|
} catch (err) {
|
|
|
|
|
console.error(err);
|
|
|
|
|
throw new Error("Error fetching locations.");
|
|
|
|
|
}
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
// Sending the response
|
|
|
|
|
reply.send({
|
|
|
|
|
status_code: 200,
|
|
|
|
|
data: result,
|
|
|
|
|
count: departments.length,
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
exports.getZonebasedLocations = async (req, reply) => {
|
|
|
|
|
try {
|
|
|
|
|
const { city, zone } = req.query;
|
|
|
|
|
const locations = await getLocationsByCityAndZone(city, zone);
|
|
|
|
|
reply.send({ status_code: 200, data: locations });
|
|
|
|
|
} catch (err) {
|
|
|
|
|
console.error(err);
|
|
|
|
|
reply.send({ error: err.message });
|
|
|
|
|
reply.status(500).send({ message: err.message });
|
|
|
|
|
}
|
|
|
|
|
};
|