patches v1.3.3 #78
5 changed files with 52 additions and 8 deletions
|
@ -2,6 +2,7 @@ import { Request, Response } from "express";
|
||||||
import { PdfExport } from "../../../helpers/pdfExport";
|
import { PdfExport } from "../../../helpers/pdfExport";
|
||||||
import DynamicQueryBuilder from "../../../helpers/dynamicQueryBuilder";
|
import DynamicQueryBuilder from "../../../helpers/dynamicQueryBuilder";
|
||||||
import QueryStoreService from "../../../service/configuration/queryStoreService";
|
import QueryStoreService from "../../../service/configuration/queryStoreService";
|
||||||
|
import InternalException from "../../../exceptions/internalException";
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @description print list by query and template
|
* @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 headerHeight = req.body.headerHeight ?? null;
|
||||||
const footerHeight = req.body.footerHeight ?? null;
|
const footerHeight = req.body.footerHeight ?? null;
|
||||||
|
|
||||||
// \/ integrate into query builder execution via shortcut
|
let query = queryStore;
|
||||||
//await MemberService.getByRunningMembership();
|
if (queryStore != "member" && queryStore != "memberByRunningMembership") {
|
||||||
//await MemberService.getAll({ noLimit:true });
|
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({
|
let pdf = await PdfExport.renderFile({
|
||||||
title: title,
|
title: title,
|
||||||
|
@ -32,6 +39,7 @@ export async function printListByQueryAndTemplate(req: Request, res: Response):
|
||||||
saveToDisk: false,
|
saveToDisk: false,
|
||||||
data: {
|
data: {
|
||||||
today: new Date(),
|
today: new Date(),
|
||||||
|
list: data.rows,
|
||||||
},
|
},
|
||||||
customTemplate: {
|
customTemplate: {
|
||||||
headerId,
|
headerId,
|
||||||
|
|
|
@ -314,6 +314,13 @@ export default abstract class DynamicQueryBuilder {
|
||||||
count: number;
|
count: number;
|
||||||
}
|
}
|
||||||
> {
|
> {
|
||||||
|
if (query == "member") {
|
||||||
|
query = memberQuery;
|
||||||
|
}
|
||||||
|
if (query == "memberByRunningMembership") {
|
||||||
|
query = memberByRunningMembershipQuery;
|
||||||
|
}
|
||||||
|
|
||||||
if (typeof query == "string") {
|
if (typeof query == "string") {
|
||||||
const upperQuery = query.trim().toUpperCase();
|
const upperQuery = query.trim().toUpperCase();
|
||||||
if (!upperQuery.startsWith("SELECT") || /INSERT|UPDATE|DELETE|ALTER|DROP|CREATE|TRUNCATE/.test(upperQuery)) {
|
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
|
return await dataSource
|
||||||
.transaction(async (manager) => {
|
.transaction(async (manager) => {
|
||||||
data = await manager.query(query);
|
data = await manager.query(query.toString());
|
||||||
|
|
||||||
throw new Error("AllwaysRollbackQuery");
|
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" },
|
||||||
|
],
|
||||||
|
};
|
||||||
|
|
|
@ -41,6 +41,7 @@ export abstract class PdfExport {
|
||||||
}));
|
}));
|
||||||
} else {
|
} else {
|
||||||
({ header, footer, body, headerMargin, footerMargin } = await TemplateHelper.renderFileForCustom({
|
({ header, footer, body, headerMargin, footerMargin } = await TemplateHelper.renderFileForCustom({
|
||||||
|
module: template,
|
||||||
customTemplate,
|
customTemplate,
|
||||||
headerData: data,
|
headerData: data,
|
||||||
bodyData: data,
|
bodyData: data,
|
||||||
|
|
|
@ -81,12 +81,14 @@ export abstract class TemplateHelper {
|
||||||
}
|
}
|
||||||
|
|
||||||
static async renderFileForCustom({
|
static async renderFileForCustom({
|
||||||
|
module,
|
||||||
title = "pdf-export FF Admin",
|
title = "pdf-export FF Admin",
|
||||||
headerData = {},
|
headerData = {},
|
||||||
bodyData = {},
|
bodyData = {},
|
||||||
footerData = {},
|
footerData = {},
|
||||||
customTemplate,
|
customTemplate,
|
||||||
}: {
|
}: {
|
||||||
|
module: `${PermissionModule}` | `${PermissionModule}.${string}`;
|
||||||
title?: string;
|
title?: string;
|
||||||
headerData?: any;
|
headerData?: any;
|
||||||
bodyData?: any;
|
bodyData?: any;
|
||||||
|
@ -118,7 +120,7 @@ export abstract class TemplateHelper {
|
||||||
if (customTemplate.bodyId && typeof customTemplate.bodyId == "number") {
|
if (customTemplate.bodyId && typeof customTemplate.bodyId == "number") {
|
||||||
body = await this.getTemplateFromStore(customTemplate.bodyId);
|
body = await this.getTemplateFromStore(customTemplate.bodyId);
|
||||||
} else {
|
} else {
|
||||||
body = this.getTemplateFromFile(module + ".body");
|
body = this.getTemplateFromFile((customTemplate.bodyId || module) + ".body");
|
||||||
}
|
}
|
||||||
body = this.applyDataToTemplate(body, { title, ...bodyData });
|
body = this.applyDataToTemplate(body, { title, ...bodyData });
|
||||||
|
|
||||||
|
|
|
@ -3,7 +3,7 @@ import { printListByQueryAndTemplate } from "../../../controller/admin/club/list
|
||||||
|
|
||||||
var router = express.Router({ mergeParams: true });
|
var router = express.Router({ mergeParams: true });
|
||||||
|
|
||||||
router.get("/", async (req: Request, res: Response) => {
|
router.post("/", async (req: Request, res: Response) => {
|
||||||
await printListByQueryAndTemplate(req, res);
|
await printListByQueryAndTemplate(req, res);
|
||||||
});
|
});
|
||||||
|
|
||||||
|
|
Loading…
Add table
Reference in a new issue