feat(server): wip printing financial reports

This commit is contained in:
Ahmed Bouhuolia
2024-02-10 22:20:54 +02:00
parent ecaf8c99bb
commit 9395ef094a
36 changed files with 738 additions and 6 deletions

View File

@@ -8,6 +8,7 @@ import {
import { SalesByItemsReportService } from './SalesByItemsService';
import { SalesByItemsTableInjectable } from './SalesByItemsTableInjectable';
import { SalesByItemsExport } from './SalesByItemsExport';
import { SalesByItemsPdfInjectable } from './SalesByItemsPdfInjectable';
@Service()
export class SalesByItemsApplication {
@@ -20,6 +21,9 @@ export class SalesByItemsApplication {
@Inject()
private salesByItemsExport: SalesByItemsExport;
@Inject()
private salesByItemsPdf: SalesByItemsPdfInjectable;
/**
* Retrieves the sales by items report in json format.
* @param {number} tenantId
@@ -71,4 +75,17 @@ export class SalesByItemsApplication {
): Promise<Buffer> {
return this.salesByItemsExport.xlsx(tenantId, filter);
}
/**
* Retrieves the sales by items in pdf format.
* @param {number} tenantId
* @param {ISalesByItemsReportQuery} query
* @returns {Promise<Buffer>}
*/
public pdf(
tenantId: number,
query: ISalesByItemsReportQuery
): Promise<Buffer> {
return this.salesByItemsPdf.pdf(tenantId, query);
}
}

View File

@@ -0,0 +1,34 @@
import { Inject, Service } from 'typedi';
import { ISalesByItemsReportQuery } from '@/interfaces';
import { SalesByItemsTableInjectable } from './SalesByItemsTableInjectable';
import { TableSheetPdf } from '../TableSheetPdf';
@Service()
export class SalesByItemsPdfInjectable {
@Inject()
private salesByItemsTable: SalesByItemsTableInjectable;
@Inject()
private tableSheetPdf: TableSheetPdf;
/**
* Retrieves the sales by items sheet in pdf format.
* @param {number} tenantId
* @param {number} query
* @returns {Promise<IBalanceSheetTable>}
*/
public async pdf(
tenantId: number,
query: ISalesByItemsReportQuery
): Promise<Buffer> {
const table = await this.salesByItemsTable.table(tenantId, query);
const sheetName = 'Sales By Items';
return this.tableSheetPdf.convertToPdf(
tenantId,
table.table,
sheetName,
table.meta.baseCurrency
);
}
}