expose cleanStatus field

This commit is contained in:
2025-05-02 12:52:57 +05:30
parent 81ae4e9875
commit 4153bd2412
3 changed files with 99 additions and 95 deletions

View File

@@ -1,16 +1,16 @@
import { orgModel } from "../organization/organization.schema";
import { getFilterObject, getSortObject, PageQueryParams } from "../pagination";
import { userModel } from "../user/user.schema";
import { generateId } from "../utils/id";
import { orgModel } from '../organization/organization.schema';
import { getFilterObject, getSortObject, PageQueryParams } from '../pagination';
import { userModel } from '../user/user.schema';
import { generateId } from '../utils/id';
import {
CreatePermitInput,
permitFields,
permitModel,
UpdatePermitInput,
} from "./permit.schema";
import { ChangeEvent, dbEvents } from "../realtime";
import { permitPipeline } from "../utils/pipeline";
import { AuthenticatedUser } from "../auth";
} from './permit.schema';
import { ChangeEvent, dbEvents } from '../realtime';
import { permitPipeline } from '../utils/pipeline';
import { AuthenticatedUser } from '../auth';
export async function createPermit(
input: CreatePermitInput,
@@ -32,13 +32,13 @@ export async function createPermit(
});
dbEvents.emit(
"change",
'change',
{
type: "insert",
collection: "permits",
type: 'insert',
collection: 'permits',
document: permit,
} as ChangeEvent,
["permit:read"]
['permit:read']
);
return permit;
@@ -51,8 +51,8 @@ export async function getPermit(permitId: string, tenantId: string) {
})
//.populate({ path: "county", select: "pid name avatar" })
//.populate({ path: "client", select: "pid name avatar" })
.populate({ path: "assignedTo", select: "pid name avatar" })
.populate({ path: "createdBy", 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) {
@@ -67,10 +67,10 @@ export async function listPermits(params: PageQueryParams, tenantId: string) {
},
{
$lookup: {
from: "users",
localField: "assignedTo",
foreignField: "_id",
as: "assignedRec",
from: 'users',
localField: 'assignedTo',
foreignField: '_id',
as: 'assignedRec',
},
},
{
@@ -82,6 +82,7 @@ export async function listPermits(params: PageQueryParams, tenantId: string) {
stage: 1,
status: 1,
manualStatus: 1,
cleanStatus: 1,
utility: 1,
link: 1,
address: 1,
@@ -111,12 +112,12 @@ export async function listPermits(params: PageQueryParams, tenantId: string) {
statusUpdated: 1,
assignedTo: {
$let: {
vars: { assigned: { $arrayElemAt: ["$assignedRec", 0] } },
vars: { assigned: { $arrayElemAt: ['$assignedRec', 0] } },
in: {
_id: "$$assigned._id",
pid: "$$assigned.pid",
name: "$$assigned.name",
avatar: "$$assigned.avatar",
_id: '$$assigned._id',
pid: '$$assigned.pid',
name: '$$assigned.name',
avatar: '$$assigned.avatar',
},
},
},
@@ -124,7 +125,7 @@ export async function listPermits(params: PageQueryParams, tenantId: string) {
},
{
$facet: {
metadata: [{ $count: "count" }],
metadata: [{ $count: 'count' }],
data: [
{ $sort: sortObj },
{ $skip: (page - 1) * pageSize },
@@ -160,20 +161,20 @@ export async function updatePermit(
{ ...input, lastUpdateDate: new Date() },
{ new: true }
)
.populate({ path: "county", select: "pid name avatar" })
.populate({ path: "client", select: "pid name avatar" })
.populate({ path: "assignedTo", select: "pid name avatar" })
.populate({ path: "createdBy", select: "pid name avatar" });
.populate({ path: 'county', select: 'pid name avatar' })
.populate({ path: 'client', select: 'pid name avatar' })
.populate({ path: 'assignedTo', select: 'pid name avatar' })
.populate({ path: 'createdBy', select: 'pid name avatar' });
if (updatePermitResult) {
dbEvents.emit(
"change",
'change',
{
type: "update",
collection: "permits",
type: 'update',
collection: 'permits',
document: updatePermitResult,
} as ChangeEvent,
["permit:read"]
['permit:read']
);
}
@@ -186,15 +187,15 @@ export async function deletePermit(permitId: string, tenantId: string) {
});
dbEvents.emit(
"change",
'change',
{
type: "delete",
collection: "permits",
type: 'delete',
collection: 'permits',
document: {
pid: permitId,
},
} as ChangeEvent,
["permit:read"]
['permit:read']
);
return res;
@@ -209,7 +210,7 @@ export async function searchPermit(params: PageQueryParams, tenantId: string) {
if (!params.searchToken)
return { permits: [], metadata: { count: 0, page, pageSize } };
const regex = new RegExp(params.searchToken, "i");
const regex = new RegExp(params.searchToken, 'i');
const permitsList = await permitModel.aggregate([
{
@@ -220,16 +221,16 @@ export async function searchPermit(params: PageQueryParams, tenantId: string) {
$or: [
{ permitNumber: { $regex: regex } },
{ link: { $regex: regex } },
{ "address.full_address": { $regex: regex } },
{ 'address.full_address': { $regex: regex } },
],
},
},
{
$lookup: {
from: "users",
localField: "assignedTo",
foreignField: "_id",
as: "assignedRec",
from: 'users',
localField: 'assignedTo',
foreignField: '_id',
as: 'assignedRec',
},
},
{
@@ -241,6 +242,7 @@ export async function searchPermit(params: PageQueryParams, tenantId: string) {
stage: 1,
status: 1,
manualStatus: 1,
cleanStatus: 1,
utility: 1,
link: 1,
address: 1,
@@ -270,12 +272,12 @@ export async function searchPermit(params: PageQueryParams, tenantId: string) {
statusUpdated: 1,
assignedTo: {
$let: {
vars: { assigned: { $arrayElemAt: ["$assignedRec", 0] } },
vars: { assigned: { $arrayElemAt: ['$assignedRec', 0] } },
in: {
_id: "$$assigned._id",
pid: "$$assigned.pid",
name: "$$assigned.name",
avatar: "$$assigned.avatar",
_id: '$$assigned._id',
pid: '$$assigned.pid',
name: '$$assigned.name',
avatar: '$$assigned.avatar',
},
},
},
@@ -283,7 +285,7 @@ export async function searchPermit(params: PageQueryParams, tenantId: string) {
},
{
$facet: {
metadata: [{ $count: "count" }],
metadata: [{ $count: 'count' }],
data: [
{ $sort: sortObj },
{ $skip: (page - 1) * pageSize },
@@ -310,12 +312,12 @@ export async function getUniqueValuesPermit(field: string, tenenatId: string) {
let values = await permitModel.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 (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) {