Files
worklenz/worklenz-backend/src/controllers/task-list-columns-controller.ts
chamikaJ 8825b0410a init
2025-04-17 18:28:54 +05:30

41 lines
1.5 KiB
TypeScript

import db from "../config/db";
import HandleExceptions from "../decorators/handle-exceptions";
import {IWorkLenzRequest} from "../interfaces/worklenz-request";
import {IWorkLenzResponse} from "../interfaces/worklenz-response";
import {ServerResponse} from "../models/server-response";
import WorklenzControllerBase from "./worklenz-controller-base";
export default class TaskListColumnsController extends WorklenzControllerBase {
@HandleExceptions()
public static async getProjectTaskListColumns(req: IWorkLenzRequest, res: IWorkLenzResponse): Promise<IWorkLenzResponse> {
const q = `
SELECT name,
key,
index,
pinned,
(SELECT phase_label FROM projects WHERE id = $1) AS phase_label
FROM project_task_list_cols
WHERE project_id = $1
ORDER BY index;
`;
const result = await db.query(q, [req.params.id]);
const phase = result.rows.find(phase => phase.key === "PHASE");
if (phase)
phase.name = phase.phase_label;
return res.status(200).send(new ServerResponse(true, result.rows));
}
@HandleExceptions()
public static async toggleColumn(req: IWorkLenzRequest, res: IWorkLenzResponse): Promise<IWorkLenzResponse> {
const q = `UPDATE project_task_list_cols
SET pinned = $3
WHERE project_id = $1
AND key = $2 RETURNING *;`;
const result = await db.query(q, [req.params.id, req.body.key, !!req.body.pinned]);
const [data] = result.rows;
return res.status(200).send(new ServerResponse(true, data));
}
}