unique values route for processed permits

This commit is contained in:
2025-03-13 14:47:25 +05:30
parent bcab406908
commit 9d6bd67383
2 changed files with 61 additions and 1 deletions

View File

@@ -1,4 +1,6 @@
import { orgModel } from "../organization/organization.schema";
import { getFilterObject, getSortObject, PageQueryParams } from "../pagination";
import { userModel } from "../user/user.schema";
import { processedFields, processedModel } from "./processed.schema";
export async function listProcessedPermits(
@@ -114,3 +116,29 @@ export async function listProcessedPermits(
},
};
}
export async function getUniqueValuesProcessed(
field: string,
tenenatId: string
) {
let values = await processedModel.distinct(field, { tenantId: tenenatId });
let matchedValues = [];
if (field === "county.name") {
matchedValues = await orgModel.find().where("name").in(values).exec();
} else if (field === "client") {
matchedValues = await orgModel.find().where("_id").in(values).exec();
} else if (field === "assignedTo") {
matchedValues = await userModel.find().where("name").in(values).exec();
}
if (matchedValues.length > 0) {
const newValues = {};
for (const item of matchedValues) {
newValues[item.id] = item.name;
}
return newValues;
}
return values;
}