feat: add tagging alerts and sorting on tags

This commit is contained in:
2025-08-19 08:03:44 +05:30
parent 17a63f67a5
commit caea0e60e6
20 changed files with 260 additions and 49 deletions

View File

@@ -115,7 +115,7 @@ export async function ctaskRoutes(fastify: FastifyInstance) {
const { field } = req.params as { field: string };
try {
const uniqueValues = await getUniqueFields(field, "task", req.user);
const uniqueValues = await getUniqueFields(field, "ctasks", req.user);
return res.code(200).send(uniqueValues);
} catch (err) {
return err;

View File

@@ -28,6 +28,7 @@ const taskSchema = new mongoose.Schema({
type: mongoose.Types.ObjectId,
ref: "user",
},
taggedUsers: Array,
});
export const taskFields = Object.keys(taskSchema.paths).filter(

View File

@@ -37,6 +37,7 @@ export async function createTask(
content: input.note,
},
task.pid,
"ctasks",
user
);
}
@@ -80,6 +81,25 @@ export async function listTasks(
const sortObj = getSortObject(params, taskFields);
const filterObj = getFilterObject(params) || [];
let taggedFilter = [];
if (sortObj.taggedUsers) {
taggedFilter = [
{
$addFields: {
taggedUsers: {
$filter: {
input: "$taggedUsers",
as: "user",
cond: { $eq: ["$$user.userId", user.userId] },
},
},
},
},
{ $match: { "taggedUsers.0": { $exists: true } } },
{ $sort: { "taggedUsers.taggedAt": sortObj.taggedUsers } },
];
}
const taskList = await taskModel.aggregate([
{
$match: {
@@ -90,6 +110,7 @@ export async function listTasks(
],
},
},
...taggedFilter,
{
$lookup: {
from: "users",