system queries + custom template selection

This commit is contained in:
Julian Krauser 2025-03-19 15:19:03 +01:00
parent a085de6e2f
commit f8a5183f1a
5 changed files with 52 additions and 8 deletions

View file

@ -2,6 +2,7 @@ import { Request, Response } from "express";
import { PdfExport } from "../../../helpers/pdfExport";
import DynamicQueryBuilder from "../../../helpers/dynamicQueryBuilder";
import QueryStoreService from "../../../service/configuration/queryStoreService";
import InternalException from "../../../exceptions/internalException";
/**
* @description print list by query and template
@ -18,13 +19,19 @@ export async function printListByQueryAndTemplate(req: Request, res: Response):
const headerHeight = req.body.headerHeight ?? null;
const footerHeight = req.body.footerHeight ?? null;
// \/ integrate into query builder execution via shortcut
//await MemberService.getByRunningMembership();
//await MemberService.getAll({ noLimit:true });
let query = queryStore;
if (queryStore != "member" && queryStore != "memberByRunningMembership") {
query = (await QueryStoreService.getById(queryStore)).query;
}
let query = (await QueryStoreService.getById(queryStore)).query;
let data = await DynamicQueryBuilder.executeQuery({
query: query.startsWith("{") ? JSON.parse(query) : query,
noLimit: true,
});
await DynamicQueryBuilder.executeQuery({ query, noLimit: true });
if (data.stats == "error") {
throw new InternalException("Failed executing Query");
}
let pdf = await PdfExport.renderFile({
title: title,
@ -32,6 +39,7 @@ export async function printListByQueryAndTemplate(req: Request, res: Response):
saveToDisk: false,
data: {
today: new Date(),
list: data.rows,
},
customTemplate: {
headerId,

View file

@ -314,6 +314,13 @@ export default abstract class DynamicQueryBuilder {
count: number;
}
> {
if (query == "member") {
query = memberQuery;
}
if (query == "memberByRunningMembership") {
query = memberByRunningMembershipQuery;
}
if (typeof query == "string") {
const upperQuery = query.trim().toUpperCase();
if (!upperQuery.startsWith("SELECT") || /INSERT|UPDATE|DELETE|ALTER|DROP|CREATE|TRUNCATE/.test(upperQuery)) {
@ -330,7 +337,7 @@ export default abstract class DynamicQueryBuilder {
return await dataSource
.transaction(async (manager) => {
data = await manager.query(query);
data = await manager.query(query.toString());
throw new Error("AllwaysRollbackQuery");
})
@ -382,3 +389,29 @@ export default abstract class DynamicQueryBuilder {
}
}
}
const memberQuery: DynamicQueryStructure = {
select: "*",
table: "member",
orderBy: [
{ column: "lastname", order: "ASC" },
{ column: "firstname", order: "ASC" },
],
};
const memberByRunningMembershipQuery: DynamicQueryStructure = {
select: "*",
table: "member",
join: [
{
select: "*",
table: "membership",
where: [{ structureType: "condition", concat: "_", operation: "null", column: "end", value: "" }],
foreignColumn: "memberships",
},
],
orderBy: [
{ column: "lastname", order: "ASC" },
{ column: "firstname", order: "ASC" },
],
};

View file

@ -41,6 +41,7 @@ export abstract class PdfExport {
}));
} else {
({ header, footer, body, headerMargin, footerMargin } = await TemplateHelper.renderFileForCustom({
module: template,
customTemplate,
headerData: data,
bodyData: data,

View file

@ -81,12 +81,14 @@ export abstract class TemplateHelper {
}
static async renderFileForCustom({
module,
title = "pdf-export FF Admin",
headerData = {},
bodyData = {},
footerData = {},
customTemplate,
}: {
module: `${PermissionModule}` | `${PermissionModule}.${string}`;
title?: string;
headerData?: any;
bodyData?: any;
@ -118,7 +120,7 @@ export abstract class TemplateHelper {
if (customTemplate.bodyId && typeof customTemplate.bodyId == "number") {
body = await this.getTemplateFromStore(customTemplate.bodyId);
} else {
body = this.getTemplateFromFile(module + ".body");
body = this.getTemplateFromFile((customTemplate.bodyId || module) + ".body");
}
body = this.applyDataToTemplate(body, { title, ...bodyData });

View file

@ -3,7 +3,7 @@ import { printListByQueryAndTemplate } from "../../../controller/admin/club/list
var router = express.Router({ mergeParams: true });
router.get("/", async (req: Request, res: Response) => {
router.post("/", async (req: Request, res: Response) => {
await printListByQueryAndTemplate(req, res);
});