add unique value route to permits

This commit is contained in:
2025-01-31 18:57:13 +05:30
parent da06598503
commit 93e0183eb3
4 changed files with 82 additions and 3 deletions

View File

@@ -4,6 +4,7 @@ import {
createPermit, createPermit,
deletePermit, deletePermit,
getPermit, getPermit,
getUniqueValues,
listPermits, listPermits,
updatePermit, updatePermit,
} from "./permit.service"; } from "./permit.service";
@@ -90,3 +91,17 @@ export async function deletePermitHandler(
return err; return err;
} }
} }
export async function getUniqueFieldValues(
req: FastifyRequest,
res: FastifyReply
) {
const { field } = req.params as { field: string };
try {
const uniqueValues = await getUniqueValues(field, req.user.tenantId);
return res.code(200).send(uniqueValues);
} catch (err) {
return err;
}
}

View File

@@ -3,6 +3,7 @@ import {
createPermitHandler, createPermitHandler,
deletePermitHandler, deletePermitHandler,
getPermitHandler, getPermitHandler,
getUniqueFieldValues,
listPermitsHandler, listPermitsHandler,
updatePermitHandler, updatePermitHandler,
} from "./permit.controller"; } from "./permit.controller";
@@ -81,5 +82,20 @@ export async function permitRoutes(fastify: FastifyInstance) {
deletePermitHandler deletePermitHandler
); );
fastify.get(
"/fields/:field",
{
schema: {
params: {
type: "object",
properties: { field: { type: "string" } },
},
},
config: { requiredClaims: ["permit:read"] },
preHandler: [fastify.authorize],
},
getUniqueFieldValues
);
fastify.addHook("onSend", hideFields("permits")); fastify.addHook("onSend", hideFields("permits"));
} }

View File

@@ -43,7 +43,10 @@ const permitSchema = new mongoose.Schema({
inspections: Object, inspections: Object,
createdAt: Date, createdAt: Date,
updatedAt: Date, updatedAt: Date,
createdBy: String, createdBy: {
type: mongoose.Types.ObjectId,
ref: "user",
},
}).index({ tenantId: 1, permitNumber: 1 }, { unique: true }); }).index({ tenantId: 1, permitNumber: 1 }, { unique: true });
export const permitFields = Object.keys(permitSchema.paths).filter( export const permitFields = Object.keys(permitSchema.paths).filter(

View File

@@ -1,4 +1,7 @@
import mongoose from "mongoose";
import { orgModel } from "../organization/organization.schema";
import { getFilterObject, getSortObject, PageQueryParams } from "../pagination"; import { getFilterObject, getSortObject, PageQueryParams } from "../pagination";
import { userModel } from "../user/user.schema";
import { generateId } from "../utils/id"; import { generateId } from "../utils/id";
import { import {
CreatePermitInput, CreatePermitInput,
@@ -24,7 +27,8 @@ export async function getPermit(permitId: string, tenantId: string) {
}) })
.populate({ path: "county", select: "pid name avatar" }) .populate({ path: "county", select: "pid name avatar" })
.populate({ path: "client", select: "pid name avatar" }) .populate({ path: "client", select: "pid name avatar" })
.populate({ path: "assignedTo", select: "pid name avatar" }); .populate({ path: "assignedTo", select: "pid name avatar" })
.populate({ path: "createdBy", select: "pid name avatar" });
} }
export async function listPermits(params: PageQueryParams, tenantId: string) { export async function listPermits(params: PageQueryParams, tenantId: string) {
@@ -61,6 +65,14 @@ export async function listPermits(params: PageQueryParams, tenantId: string) {
as: "assignedRec", as: "assignedRec",
}, },
}, },
{
$lookup: {
from: "users",
localField: "createdBy",
foreignField: "_id",
as: "createdRec",
},
},
{ {
$project: { $project: {
_id: 1, _id: 1,
@@ -104,6 +116,17 @@ export async function listPermits(params: PageQueryParams, tenantId: string) {
}, },
}, },
}, },
createdBy: {
$let: {
vars: { created: { $arrayElemAt: ["$createdRec", 0] } },
in: {
_id: "$$created._id",
pid: "$$created.pid",
name: "$$created.name",
avatar: "$$created.avatar",
},
},
},
}, },
}, },
{ {
@@ -146,7 +169,8 @@ export async function updatePermit(
) )
.populate({ path: "county", select: "pid name avatar" }) .populate({ path: "county", select: "pid name avatar" })
.populate({ path: "client", select: "pid name avatar" }) .populate({ path: "client", select: "pid name avatar" })
.populate({ path: "assignedTo", select: "pid name avatar" }); .populate({ path: "assignedTo", select: "pid name avatar" })
.populate({ path: "createdBy", select: "pid name avatar" });
return updatePermitResult; return updatePermitResult;
} }
@@ -156,3 +180,24 @@ export async function deletePermit(permitId: string, tenantId: string) {
$and: [{ tenantId: tenantId }, { pid: permitId }], $and: [{ tenantId: tenantId }, { pid: permitId }],
}); });
} }
export async function getUniqueValues(field: string, tenenatId: string) {
let values = await permitModel.distinct(field, { tenantId: tenenatId });
let matchedValues = [];
if (field === "client" || field === "county") {
matchedValues = await orgModel.find().where("_id").in(values).exec();
} else if (field === "assignedTo") {
matchedValues = await userModel.find().where("_id").in(values).exec();
}
if (matchedValues.length > 0) {
const newValues = {};
for (const item of matchedValues) {
newValues[item.id] = item.name;
}
return newValues;
}
return values;
}