@sachin9822/reports-lib 0.0.165 → 0.0.167

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -66,6 +66,7 @@ export class AccountingReportComponent {
66
66
  { headerName: 'Settlement Rate', field: 'settlementRate', tooltipField: 'settlementRate', cellClass: 'ag-right-aligned-cell' },
67
67
  ];
68
68
  this.gridApis = [];
69
+ this.gridColumnApis = [];
69
70
  this.ezremitUser = false;
70
71
  this.originalGroupEntries = [];
71
72
  }
@@ -84,8 +85,14 @@ export class AccountingReportComponent {
84
85
  this.reportService.getAccountingReport(finalReq).subscribe(data => {
85
86
  this.accountingReportModel = data;
86
87
  this.loadingState = ComponentLoadingStates.Complete;
88
+ console.log(this.accountingReportModel);
87
89
  this.accountingReportModel.accountingReportByBranchGroups.forEach(group => {
88
- group.accountingReportEntriesList = group.accountingReportEntriesList.map(entry => ({
90
+ group.sendTransactions.entries = group.sendTransactions.entries.map(entry => ({
91
+ ...entry,
92
+ businessDate: formatDate(entry.businessDate, 'dd/MM/yyyy', 'en-US'),
93
+ transactionDateAndTime: formatDate(entry.transactionDateAndTime, 'dd/MM/yyyy hh:mm a', 'en-US'),
94
+ }));
95
+ group.receiveTransactions.entries = group.receiveTransactions.entries.map(entry => ({
89
96
  ...entry,
90
97
  businessDate: formatDate(entry.businessDate, 'dd/MM/yyyy', 'en-US'),
91
98
  transactionDateAndTime: formatDate(entry.transactionDateAndTime, 'dd/MM/yyyy hh:mm a', 'en-US'),
@@ -93,7 +100,8 @@ export class AccountingReportComponent {
93
100
  });
94
101
  this.accountingReportModel = data;
95
102
  this.noDataFound = Object.keys(this.accountingReportModel.accountingReportByBranchGroups).length == 0 ? true : false;
96
- this.paginationArray = new Array(Object.keys(this.accountingReportModel).length).fill(15);
103
+ const branchCount = this.accountingReportModel.accountingReportByBranchGroups.length;
104
+ this.paginationArray = new Array(branchCount * 2).fill(15);
97
105
  this.reportUser = this.accountingReportModel.reportUser;
98
106
  this.reportTime = formatDate(new Date(), 'dd/MM/yyyy hh:mm a', 'en-US');
99
107
  this.reportPeriod = `${formatDate(finalReq.startDate, 'dd/MM/yyyy', 'en-US')} - ${formatDate(finalReq.endDate, 'dd/MM/yyyy', 'en-US')}`;
@@ -108,7 +116,14 @@ export class AccountingReportComponent {
108
116
  // Deep copy to preserve original data for search
109
117
  this.originalGroupEntries = this.accountingReportModel.accountingReportByBranchGroups.map(group => ({
110
118
  ...group,
111
- accountingReportEntriesList: [...group.accountingReportEntriesList]
119
+ sendTransactions: {
120
+ ...group.sendTransactions,
121
+ entries: [...group.sendTransactions.entries]
122
+ },
123
+ receiveTransactions: {
124
+ ...group.receiveTransactions,
125
+ entries: [...group.receiveTransactions.entries]
126
+ }
112
127
  }));
113
128
  }, error => {
114
129
  console.log(error);
@@ -142,47 +157,46 @@ export class AccountingReportComponent {
142
157
  if (!this.accountingReportModel?.accountingReportByBranchGroups)
143
158
  return;
144
159
  this.accountingReportModel.accountingReportByBranchGroups.forEach((group, index) => {
145
- const originalEntries = this.originalGroupEntries[index]?.accountingReportEntriesList || [];
160
+ const originalSendEntries = this.originalGroupEntries[index]?.sendTransactions.entries || [];
161
+ const originalReceiveEntries = this.originalGroupEntries[index]?.receiveTransactions.entries || [];
146
162
  if (search) {
147
- // Filter entries based on search text
148
- group.accountingReportEntriesList = originalEntries.filter(entry => Object.values(entry).some(value => normalize(value).includes(search)));
163
+ group.sendTransactions.entries = originalSendEntries.filter(entry => Object.values(entry).some(value => normalize(value).includes(search)));
164
+ group.receiveTransactions.entries = originalReceiveEntries.filter(entry => Object.values(entry).some(value => normalize(value).includes(search)));
149
165
  }
150
166
  else {
151
- // Restore original entries
152
- group.accountingReportEntriesList = [...originalEntries];
167
+ group.sendTransactions.entries = [...originalSendEntries];
168
+ group.receiveTransactions.entries = [...originalReceiveEntries];
153
169
  }
154
- const gridApi = this.gridApis[index];
155
- if (gridApi) {
156
- gridApi.setRowData(group.accountingReportEntriesList);
157
- // Reset pagination to page 1
158
- if (gridApi.paginationGoToFirstPage) {
159
- gridApi.paginationGoToFirstPage();
170
+ // Reset both grids
171
+ [group.sendTransactions.entries, group.receiveTransactions.entries].forEach((entries, idx) => {
172
+ const gridApi = this.gridApis[index * 2 + idx]; // keep separate ids for grids
173
+ if (gridApi) {
174
+ gridApi.setRowData(entries);
175
+ if (gridApi.paginationGoToFirstPage)
176
+ gridApi.paginationGoToFirstPage();
177
+ if (gridApi.paginationSetPageSize)
178
+ gridApi.paginationSetPageSize(this.pageSize);
160
179
  }
161
- // Optional: reset selected page size if you have dynamic pageSize
162
- if (gridApi.paginationSetPageSize) {
163
- gridApi.paginationSetPageSize(this.pageSize);
164
- }
165
- }
180
+ });
166
181
  });
167
182
  }
168
183
  onGridReady(params, id) {
169
- // this.gridAPi = params.api;
170
- this.gridColumnApi = params.columnApi;
171
184
  this.gridApis[id] = params.api;
172
- // Auto size all columns after grid data is loaded
173
- setTimeout(() => this.autoSizeAllColumns(), 100);
185
+ this.gridColumnApis[id] = params.columnApi; // keep per grid
186
+ setTimeout(() => this.autoSizeAllColumns(id), 100);
174
187
  }
175
- onGridSizeChanged(params) {
176
- this.autoSizeAllColumns();
188
+ onGridSizeChanged(params, id) {
189
+ this.autoSizeAllColumns(id);
177
190
  }
178
- autoSizeAllColumns(skipHeader = false) {
179
- if (!this.gridColumnApi)
191
+ autoSizeAllColumns(id, skipHeader = false) {
192
+ const columnApi = this.gridColumnApis[id];
193
+ if (!columnApi)
180
194
  return;
181
195
  const allColumnIds = [];
182
- this.gridColumnApi.getColumns().forEach((column) => {
196
+ columnApi.getColumns().forEach((column) => {
183
197
  allColumnIds.push(column.getId());
184
198
  });
185
- this.gridColumnApi.autoSizeColumns(allColumnIds, skipHeader);
199
+ columnApi.autoSizeColumns(allColumnIds, skipHeader);
186
200
  }
187
201
  formatNumber(params) {
188
202
  if (params.value == null)
@@ -198,7 +212,6 @@ export class AccountingReportComponent {
198
212
  return;
199
213
  const title = 'Accounting Report';
200
214
  const fileName = 'Accounting-Report.pdf';
201
- // Metadata
202
215
  const metadata = [
203
216
  ['Report User:', this.reportUser],
204
217
  ['Report Time:', this.reportTime],
@@ -228,33 +241,35 @@ export class AccountingReportComponent {
228
241
  doc.text(value ?? '', 15 + labelWidth, y);
229
242
  });
230
243
  currentY += metadata.length * 7 + 5;
231
- // Groups
232
- this.accountingReportModel.accountingReportByBranchGroups.forEach((group, index) => {
233
- // if (index > 0) doc.addPage();
244
+ // Branches
245
+ this.accountingReportModel.accountingReportByBranchGroups.forEach(group => {
234
246
  doc.setFontSize(10);
235
247
  doc.setFont('helvetica', 'bold');
236
248
  const branchText = `Branch (Name & Code): ${group.branchNameAndCode}`;
237
249
  doc.text(branchText, 15, currentY);
238
- // measure width of branch text
239
- const branchWidth = doc.getTextWidth(branchText);
240
- // add small gap (e.g., 10mm) before printing subgroup
241
- doc.text(`Sub Group: ${group.subGroupColumn}`, 15 + branchWidth + 10, currentY);
242
- currentY += 5;
243
- // Table
244
- const { headers, rows } = this.prepareAccountingTable(group.accountingReportEntriesList);
245
- doc.autoTable({
246
- head: [headers],
247
- body: rows,
248
- startY: currentY,
249
- theme: 'grid',
250
- headStyles: {
251
- fillColor: [220, 220, 220], textColor: 0,
252
- fontStyle: 'bold', fontSize: 9, halign: 'center',
253
- },
254
- bodyStyles: { fontSize: 8, fillColor: [255, 255, 255], textColor: [0, 0, 0] },
255
- styles: { cellPadding: 2, overflow: 'linebreak', minCellHeight: 6 },
250
+ currentY += 7;
251
+ // Loop subgroups (Send + Receive)
252
+ [group.sendTransactions, group.receiveTransactions].forEach(subGroup => {
253
+ if (!subGroup.entries?.length)
254
+ return;
255
+ doc.setFont('helvetica', 'bold');
256
+ doc.text(`Sub Group: ${subGroup.subGroupName}`, 15, currentY);
257
+ currentY += 5;
258
+ const { headers, rows } = this.prepareAccountingTable(subGroup.entries);
259
+ doc.autoTable({
260
+ head: [headers],
261
+ body: rows,
262
+ startY: currentY,
263
+ theme: 'grid',
264
+ headStyles: {
265
+ fillColor: [220, 220, 220], textColor: 0,
266
+ fontStyle: 'bold', fontSize: 9, halign: 'center',
267
+ },
268
+ bodyStyles: { fontSize: 8, fillColor: [255, 255, 255], textColor: [0, 0, 0] },
269
+ styles: { cellPadding: 2, overflow: 'linebreak', minCellHeight: 6 },
270
+ });
271
+ currentY = doc.lastAutoTable.finalY + 10;
256
272
  });
257
- currentY = doc.lastAutoTable.finalY + 10; // move cursor after table
258
273
  });
259
274
  doc.save(fileName);
260
275
  }
@@ -264,29 +279,25 @@ export class AccountingReportComponent {
264
279
  const title = 'Accounting Report';
265
280
  const fileName = 'Accounting-Report.xlsx';
266
281
  const workbook = new ExcelJS.Workbook();
267
- const worksheet = workbook.addWorksheet('Accounting Report'); // ✅ single sheet
282
+ const worksheet = workbook.addWorksheet('Accounting Report');
268
283
  let currentRow = 1;
269
- // ✅ Add logo
284
+ // Logo
270
285
  if (this.exportService.logoBase64) {
271
286
  const base64Data = this.exportService.logoBase64.replace(/^data:image\/\w+;base64,/, '');
272
287
  const imageId = workbook.addImage({
273
288
  base64: base64Data,
274
289
  extension: 'png',
275
290
  });
276
- worksheet.addImage(imageId, {
277
- tl: { col: 0, row: 0 },
278
- ext: { width: 145, height: 66 },
279
- editAs: 'oneCell',
280
- });
291
+ worksheet.addImage(imageId, { tl: { col: 0, row: 0 }, ext: { width: 145, height: 66 }, editAs: 'oneCell' });
281
292
  }
282
- // Title
293
+ // Title
283
294
  const titleRow = worksheet.getRow(currentRow);
284
- titleRow.getCell(6).value = title; // Column F
295
+ titleRow.getCell(6).value = title;
285
296
  titleRow.getCell(6).font = { bold: true, size: 16 };
286
297
  titleRow.getCell(6).alignment = { vertical: 'middle', horizontal: 'left' };
287
298
  worksheet.mergeCells(`F${currentRow}:J${currentRow}`);
288
299
  currentRow += 3;
289
- // Metadata
300
+ // Metadata
290
301
  const metadata = [
291
302
  ['Report User', this.reportUser],
292
303
  ['Report Time', this.reportTime],
@@ -303,62 +314,71 @@ export class AccountingReportComponent {
303
314
  });
304
315
  worksheet.addRow([]);
305
316
  currentRow++;
306
- // ✅ Loop through all groups in one sheet
307
- this.accountingReportModel.accountingReportByBranchGroups.forEach((group) => {
308
- // Branch + SubGroup on same line
317
+ // Branches
318
+ this.accountingReportModel.accountingReportByBranchGroups.forEach(group => {
309
319
  const branchRow = worksheet.getRow(currentRow++);
310
320
  branchRow.getCell(1).value = {
311
321
  richText: [
312
322
  { text: 'Branch (Name & Code): ', font: { bold: true } },
313
- { text: group.branchNameAndCode ?? '', font: { bold: false } },
314
- { text: ' Sub Group: ', font: { bold: true } },
315
- { text: group.subGroupColumn ?? '', font: { bold: false } }
323
+ { text: group.branchNameAndCode ?? '', font: { bold: false } }
316
324
  ]
317
325
  };
318
326
  worksheet.addRow([]);
319
327
  currentRow++;
320
- // Table headers
321
- const { headers, rows } = this.prepareAccountingTable(group.accountingReportEntriesList);
322
- const headerRow = worksheet.getRow(currentRow++);
323
- headers.forEach((header, i) => {
324
- const cell = headerRow.getCell(i + 1);
325
- cell.value = header;
326
- cell.font = { bold: true };
327
- cell.fill = { type: 'pattern', pattern: 'solid', fgColor: { argb: 'D9D9D9' } };
328
- cell.alignment = { vertical: 'middle', horizontal: 'center' };
329
- cell.border = {
330
- top: { style: 'thin' }, bottom: { style: 'thin' },
331
- left: { style: 'thin' }, right: { style: 'thin' }
328
+ // Loop subgroups
329
+ [group.sendTransactions, group.receiveTransactions].forEach(subGroup => {
330
+ if (!subGroup.entries?.length)
331
+ return;
332
+ const subGroupRow = worksheet.getRow(currentRow++);
333
+ subGroupRow.getCell(1).value = {
334
+ richText: [
335
+ { text: 'Sub Group: ', font: { bold: true } },
336
+ { text: subGroup.subGroupName ?? '', font: { bold: false } }
337
+ ]
332
338
  };
333
- });
334
- // Table rows
335
- rows.forEach(r => {
336
- const row = worksheet.getRow(currentRow++);
337
- r.forEach((val, i) => {
338
- const cell = row.getCell(i + 1);
339
- cell.value = val;
340
- cell.border = {
341
- top: { style: 'thin' }, bottom: { style: 'thin' },
342
- left: { style: 'thin' }, right: { style: 'thin' }
343
- };
339
+ worksheet.addRow([]);
340
+ currentRow++;
341
+ // Headers
342
+ const { headers, rows } = this.prepareAccountingTable(subGroup.entries);
343
+ const headerRow = worksheet.getRow(currentRow++);
344
+ headers.forEach((header, i) => {
345
+ const cell = headerRow.getCell(i + 1);
346
+ cell.value = header;
347
+ cell.font = { bold: true };
348
+ cell.fill = { type: 'pattern', pattern: 'solid', fgColor: { argb: 'D9D9D9' } };
349
+ cell.alignment = { vertical: 'middle', horizontal: 'center' };
350
+ cell.border = { top: { style: 'thin' }, bottom: { style: 'thin' }, left: { style: 'thin' }, right: { style: 'thin' } };
351
+ });
352
+ // Rows
353
+ rows.forEach(r => {
354
+ const row = worksheet.getRow(currentRow++);
355
+ r.forEach((val, i) => {
356
+ const cell = row.getCell(i + 1);
357
+ cell.value = val;
358
+ cell.border = { top: { style: 'thin' }, bottom: { style: 'thin' }, left: { style: 'thin' }, right: { style: 'thin' } };
359
+ });
344
360
  });
361
+ worksheet.addRow([]);
362
+ currentRow++;
345
363
  });
346
- worksheet.addRow([]);
347
- currentRow++;
348
364
  });
349
- // Auto column widths (after all groups processed)
350
- const allHeaders = this.prepareAccountingTable(this.accountingReportModel.accountingReportByBranchGroups[0]?.accountingReportEntriesList || []).headers;
365
+ // 🔹 Auto-adjust column widths (including Sr No)
366
+ const allHeaders = ['Sr No', ...this.columnDefs.map(c => c.headerName)];
351
367
  allHeaders.forEach((header, i) => {
352
- let maxLength = header.length;
368
+ let maxLength = header.length; // start with header length
353
369
  this.accountingReportModel.accountingReportByBranchGroups.forEach(group => {
354
- group.accountingReportEntriesList.forEach(r => {
355
- const val = r[i] ? r[i].toString() : '';
356
- maxLength = Math.max(maxLength, val.length);
370
+ [group.sendTransactions, group.receiveTransactions].forEach(subGroup => {
371
+ subGroup.entries.forEach(entry => {
372
+ // Sr No column (i = 0) is just numbers
373
+ let val = i === 0 ? (subGroup.entries.indexOf(entry) + 1).toString() : (entry[this.columnDefs[i - 1]?.field] ?? '');
374
+ const len = val.toString().length;
375
+ if (len > maxLength)
376
+ maxLength = len;
377
+ });
357
378
  });
358
379
  });
359
- worksheet.getColumn(i + 1).width = maxLength + 2;
380
+ worksheet.getColumn(i + 1).width = maxLength + 5; // padding
360
381
  });
361
- // ✅ Save
362
382
  workbook.xlsx.writeBuffer().then(buffer => {
363
383
  const blob = new Blob([buffer], {
364
384
  type: 'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet'
@@ -369,6 +389,9 @@ export class AccountingReportComponent {
369
389
  prepareAccountingTable(data) {
370
390
  const currencyFields = ['amountPaid', 'serviceFee', 'tax', 'principleSendAmount', 'clientSettlementInSCcy'];
371
391
  const headers = ['Sr No', ...this.columnDefs.map(c => c.headerName)];
392
+ if (!data || data.length === 0) {
393
+ return { headers, rows: [] }; // ✅ return headers only, empty rows
394
+ }
372
395
  const rows = data.map((row, i) => {
373
396
  return [
374
397
  i + 1,
@@ -391,7 +414,6 @@ export class AccountingReportComponent {
391
414
  return;
392
415
  const fileName = 'Accounting-Report.csv';
393
416
  const rows = [];
394
- // Metadata
395
417
  rows.push('Report Title: Accounting Report');
396
418
  rows.push('');
397
419
  rows.push(`Report User: ${this.reportUser}`);
@@ -400,24 +422,34 @@ export class AccountingReportComponent {
400
422
  rows.push(`Company: Xpress Money`);
401
423
  rows.push('');
402
424
  this.accountingReportModel.accountingReportByBranchGroups.forEach(group => {
403
- rows.push(`Branch (Name & Code): ${group.branchNameAndCode} Sub Group: ${group.subGroupColumn}`);
404
- rows.push(this.columnDefs.map(col => `"${col.headerName}"`).join(','));
405
- group.accountingReportEntriesList.forEach(entry => {
406
- const row = this.columnDefs.map(col => {
407
- const val = entry[col.field];
408
- if (val == null)
409
- return '';
410
- if (['amountPaid', 'serviceFee', 'tax', 'principleSendAmount', 'clientSettlementInSCcy'].includes(col.field)) {
411
- return parseFloat(val).toFixed(3);
412
- }
413
- if (col.field === 'settlementRate') {
414
- return parseFloat(val).toFixed(8);
415
- }
416
- return `"${val}"`;
417
- }).join(',');
418
- rows.push(row);
425
+ rows.push(`Branch (Name & Code): ${group.branchNameAndCode}`);
426
+ [group.sendTransactions, group.receiveTransactions].forEach(subGroup => {
427
+ if (!subGroup.entries?.length)
428
+ return;
429
+ rows.push(`Sub Group: ${subGroup.subGroupName}`);
430
+ // 🔹 Add "Sr No" at the beginning of headers
431
+ rows.push(['"Sr No"', ...this.columnDefs.map(col => `"${col.headerName}"`)].join(','));
432
+ subGroup.entries.forEach((entry, idx) => {
433
+ // 🔹 Add serial number at start of each row
434
+ const row = [
435
+ (idx + 1).toString(),
436
+ ...this.columnDefs.map(col => {
437
+ const val = entry[col.field];
438
+ if (val == null)
439
+ return '';
440
+ if (['amountPaid', 'serviceFee', 'tax', 'principleSendAmount', 'clientSettlementInSCcy'].includes(col.field)) {
441
+ return parseFloat(val).toFixed(3);
442
+ }
443
+ if (col.field === 'settlementRate') {
444
+ return parseFloat(val).toFixed(8);
445
+ }
446
+ return `"${val}"`;
447
+ })
448
+ ].join(',');
449
+ rows.push(row);
450
+ });
451
+ rows.push('');
419
452
  });
420
- rows.push('');
421
453
  });
422
454
  const blob = new Blob([rows.join('\n')], { type: 'text/csv;charset=utf-8;' });
423
455
  const link = document.createElement('a');
@@ -445,9 +477,9 @@ export class AccountingReportComponent {
445
477
  }
446
478
  }
447
479
  AccountingReportComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: AccountingReportComponent, deps: [{ token: i1.ReportService }, { token: i2.ExportService }], target: i0.ɵɵFactoryTarget.Component });
448
- AccountingReportComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: AccountingReportComponent, selector: "lib-accounting-report", ngImport: i0, template: "<lib-search-filter [ReportName]=\"ReportName\" (searchClicked)=\"getReport($event)\"></lib-search-filter>\r\n\r\n<app-loader class=\"\" *ngIf=\"loadingState == ComponentLoadingState.Loading\"></app-loader>\r\n\r\n<div *ngIf=\"accountingReportModel!=undefined\">\r\n\r\n <lib-metadata [reportName]=\"ReportName\" [showmetaDataOne]=\"true\" [showmetaDataTwo]=\"true\" [metaDataOne]=\"leftData\"\r\n [metaDataTwo]=\"rightData\" (exportEvent)=\"handleExport($event)\" (searchEvent)=\"onSearch($event)\"></lib-metadata>\r\n\r\n <ngb-accordion #acc=\"ngbAccordion\" [closeOthers]=\"false\" [activeIds]=\"'panel-0'\">\r\n <ng-container *ngFor=\"let group of accountingReportModel?.accountingReportByBranchGroups; let i = index\">\r\n <ngb-panel [id]=\"'panel-' + i\">\r\n\r\n <ng-template ngbPanelTitle>\r\n <label class=\"title-stack line-1\">\r\n {{ group.branchNameAndCode }} \u2192 {{ group.subGroupColumn }}\r\n </label>\r\n </ng-template>\r\n\r\n <ng-template ngbPanelContent>\r\n <div style=\"position: relative;\">\r\n <lib-page-size-selector [totalEntries]=\"group.accountingReportEntriesList.length\" [defaultSize]=\"'15'\"\r\n [gridApi]=\"gridApis[i]\">\r\n </lib-page-size-selector>\r\n\r\n <ag-grid-angular class=\"ag-theme-alpine compact-grid grid-size\" style=\"width: 100%;height: 370px;\"\r\n [columnDefs]=\"columnDefs\" [defaultColDef]=\"defaultColDef\" [rowData]=\"group.accountingReportEntriesList\"\r\n [rowHeight]=\"20\" [headerHeight]=\"24\" [pagination]=\"true\" [paginationPageSize]=\"paginationArray[i]\"\r\n (gridReady)=\"onGridReady($event,i)\" (gridSizeChanged)=\"onGridSizeChanged($event)\">\r\n </ag-grid-angular>\r\n </div>\r\n </ng-template>\r\n </ngb-panel>\r\n </ng-container>\r\n </ngb-accordion>\r\n\r\n</div>\r\n\r\n<div class=\"alert alert-warning mt-3\" *ngIf=\"noDataFound && loadingState!=ComponentLoadingState.Loading\">\r\n No Data Found\r\n</div>", styles: [".transaction-grid ::ng-deep .ag-header{background-color:#f9f9f9;font-weight:600;font-size:10px;color:#000;border-right:1px solid #e0e0e0}:host ::ng-deep .ag-header-cell{padding:2px!important;align-items:center!important;justify-content:center!important;border-right:1px solid #e0e0e0;white-space:normal!important;word-break:normal!important;overflow-wrap:break-word!important;text-align:center!important;height:auto!important}::ng-deep .ag-header-cell-label{display:flex!important;justify-content:center!important;align-items:center!important;width:100%;text-align:center!important}::ng-deep .ag-header-cell-text{text-align:center!important;width:100%!important;display:flex!important;justify-content:center!important}.transaction-grid ::ng-deep .ag-row{border-bottom:1px solid #e0e0e0}.transaction-grid ::ng-deep .ag-cell{font-size:9px;white-space:normal!important;word-break:keep-all!important;overflow-wrap:anywhere;line-height:1.4;padding:4px!important;color:#000;font-weight:500;border-right:.5px solid #e0e0e0;align-content:center;user-select:text!important;-webkit-user-select:text!important;-moz-user-select:text!important;-ms-user-select:text!important;cursor:text}::ng-deep .ag-cell-label-container{padding:0!important}.ag-theme-alpine{--ag-header-font-size: 10px;--ag-font-size: 10px;--ag-header-background-color: #fdfdfd;--ag-header-foreground-color: rgb(0, 0, 0)}::ng-deep .ag-paging-panel{height:30px!important}::ng-deep .compact-grid .ag-cell{cursor:default!important;border-right:1px solid #e0e0e0;padding:2px 3px!important;font-size:9px!important;display:flex!important;align-items:center!important}::ng-deep .compact-grid .ag-cell-value{cursor:text!important;font-size:9px!important;padding:0 3px 0 2px!important}::ng-deep .compact-grid .ag-right-aligned-cell{text-align:right!important;justify-content:flex-end!important;text-overflow:ellipsis}.grid-size{width:100%!important;font-weight:500!important;height:390px!important}::ng-deep .ag-root{-webkit-user-select:text!important;user-select:text!important}::ng-deep .ag-cell{-webkit-user-select:text!important;user-select:text!important}.margin-bottom-30{margin-bottom:30px}::ng-deep .accordion-button{display:flex;align-items:flex-start;width:100%;min-height:30px;background-color:#e7f1ff;border:0}.title-stack{display:flex;flex-direction:column;line-height:1.2}.line-1{font-weight:600}::ng-deep .accordion-button.collapsed{color:#0c63e4!important;background-color:#f4f7fc!important}::ng-deep .accordion-button{color:#052c65!important;background-color:#f4f7fc!important}::ng-deep .accordion-item{margin-bottom:10px}::ng-deep .accordion-item{border-radius:0!important;margin-bottom:10px}::ng-deep .accordion-button{border-radius:0!important;font-size:13px!important}::ng-deep .accordion-collapse{border-radius:0!important}::ng-deep .accordion-body{border-radius:0!important}::ng-deep .accordion-item{border:1px solid #b0bac5!important}::ng-deep .accordion-item{border:1px solid #b0bac5;border-radius:0;margin-bottom:10px}::ng-deep .accordion-button{border:none;background-color:#e7f1ff;box-shadow:none}::ng-deep .accordion-button.collapsed{border-bottom:none!important}::ng-deep .accordion-button:not(.collapsed){background-color:#fff;border-bottom:none!important}::ng-deep .accordion-body{border-top:1px solid #b0bac5}:host ::ng-deep .my-2{margin-bottom:10px!important}label{margin-bottom:0!important}::ng-deep .card-header .btn-link{font-size:13px!important;color:#0c63e4!important}\n"], dependencies: [{ kind: "component", type: i3.AgGridAngular, selector: "ag-grid-angular", inputs: ["gridOptions", "modules", "statusBar", "sideBar", "suppressContextMenu", "preventDefaultOnContextMenu", "allowContextMenuWithControlKey", "suppressMenuHide", "enableBrowserTooltips", "tooltipShowDelay", "tooltipHideDelay", "tooltipMouseTrack", "popupParent", "copyHeadersToClipboard", "copyGroupHeadersToClipboard", "clipboardDelimiter", "suppressCopyRowsToClipboard", "suppressCopySingleCellRanges", "suppressLastEmptyLineOnPaste", "suppressClipboardPaste", "suppressClipboardApi", "columnDefs", "defaultColDef", "defaultColGroupDef", "columnTypes", "maintainColumnOrder", "suppressFieldDotNotation", "deltaColumnMode", "applyColumnDefOrder", "immutableColumns", "suppressSetColumnStateEvents", "suppressColumnStateEvents", "colWidth", "minColWidth", "maxColWidth", "headerHeight", "groupHeaderHeight", "floatingFiltersHeight", "pivotHeaderHeight", "pivotGroupHeaderHeight", "allowDragFromColumnsToolPanel", "suppressMovableColumns", "suppressColumnMoveAnimation", "suppressDragLeaveHidesColumns", "suppressRowGroupHidesColumns", "colResizeDefault", "suppressAutoSize", "autoSizePadding", "skipHeaderOnAutoSize", "components", "frameworkComponents", "editType", "singleClickEdit", "suppressClickEdit", "readOnlyEdit", "stopEditingWhenCellsLoseFocus", "enterMovesDown", "enterMovesDownAfterEdit", "enableCellEditingOnBackspace", "undoRedoCellEditing", "undoRedoCellEditingLimit", "stopEditingWhenGridLosesFocus", "defaultCsvExportParams", "suppressCsvExport", "defaultExcelExportParams", "suppressExcelExport", "excelStyles", "defaultExportParams", "quickFilterText", "cacheQuickFilter", "excludeChildrenWhenTreeDataFiltering", "enableCharts", "chartThemes", "customChartThemes", "chartThemeOverrides", "enableChartToolPanelsButton", "chartToolPanelsDef", "loadingCellRenderer", "loadingCellRendererFramework", "loadingCellRendererParams", "loadingCellRendererSelector", "localeText", "masterDetail", "keepDetailRows", "keepDetailRowsCount", "detailCellRenderer", "detailCellRendererFramework", "detailCellRendererParams", "detailRowHeight", "detailRowAutoHeight", "context", "alignedGrids", "tabIndex", "rowBuffer", "valueCache", "valueCacheNeverExpires", "enableCellExpressions", "suppressParentsInRowNodes", "suppressTouch", "suppressFocusAfterRefresh", "suppressAsyncEvents", "suppressBrowserResizeObserver", "suppressPropertyNamesCheck", "suppressChangeDetection", "debug", "overlayLoadingTemplate", "loadingOverlayComponent", "loadingOverlayComponentFramework", "loadingOverlayComponentParams", "suppressLoadingOverlay", "overlayNoRowsTemplate", "noRowsOverlayComponent", "noRowsOverlayComponentFramework", "noRowsOverlayComponentParams", "suppressNoRowsOverlay", "pagination", "paginationPageSize", "paginationAutoPageSize", "paginateChildRows", "suppressPaginationPanel", "pivotMode", "pivotPanelShow", "pivotColumnGroupTotals", "pivotRowTotals", "pivotSuppressAutoColumn", "suppressExpandablePivotGroups", "functionsReadOnly", "aggFuncs", "suppressAggFuncInHeader", "suppressAggAtRootLevel", "aggregateOnlyChangedColumns", "suppressAggFilteredOnly", "removePivotHeaderRowWhenSingleValueColumn", "animateRows", "enableCellChangeFlash", "cellFlashDelay", "cellFadeDelay", "allowShowChangeAfterFilter", "domLayout", "ensureDomOrder", "enableRtl", "suppressColumnVirtualisation", "suppressMaxRenderedRowRestriction", "suppressRowVirtualisation", "rowDragManaged", "suppressRowDrag", "suppressMoveWhenRowDragging", "rowDragEntireRow", "rowDragMultiRow", "rowDragText", "fullWidthCellRenderer", "fullWidthCellRendererFramework", "fullWidthCellRendererParams", "embedFullWidthRows", "deprecatedEmbedFullWidthRows", "groupDisplayType", "groupDefaultExpanded", "autoGroupColumnDef", "groupMaintainOrder", "groupSelectsChildren", "groupAggFiltering", "groupIncludeFooter", "groupIncludeTotalFooter", "groupSuppressBlankHeader", "groupSelectsFiltered", "showOpenedGroup", "groupRemoveSingleChildren", "groupRemoveLowestSingleChildren", "groupHideOpenParents", "rowGroupPanelShow", "groupRowRenderer", "groupRowRendererFramework", "groupRowRendererParams", "suppressMakeColumnVisibleAfterUnGroup", "treeData", "rowGroupPanelSuppressSort", "groupRowsSticky", "groupRowInnerRenderer", "groupRowInnerRendererFramework", "groupMultiAutoColumn", "groupUseEntireRow", "groupSuppressAutoColumn", "rememberGroupStateWhenNewData", "pinnedTopRowData", "pinnedBottomRowData", "rowModelType", "rowData", "immutableData", "asyncTransactionWaitMillis", "suppressModelUpdateAfterUpdateTransaction", "deltaRowDataMode", "batchUpdateWaitMillis", "datasource", "cacheOverflowSize", "infiniteInitialRowCount", "serverSideInitialRowCount", "serverSideStoreType", "serverSideInfiniteScroll", "cacheBlockSize", "maxBlocksInCache", "maxConcurrentDatasourceRequests", "blockLoadDebounceMillis", "purgeClosedRowNodes", "serverSideDatasource", "serverSideSortAllLevels", "serverSideFilterAllLevels", "serverSideSortOnServer", "serverSideFilterOnServer", "serverSideSortingAlwaysResets", "serverSideFilteringAlwaysResets", "suppressEnterpriseResetOnNewColumns", "viewportDatasource", "viewportRowModelPageSize", "viewportRowModelBufferSize", "alwaysShowHorizontalScroll", "alwaysShowVerticalScroll", "debounceVerticalScrollbar", "suppressHorizontalScroll", "suppressScrollOnNewData", "suppressScrollWhenPopupsAreOpen", "suppressAnimationFrame", "suppressMiddleClickScrolls", "suppressPreventDefaultOnMouseWheel", "scrollbarWidth", "rowSelection", "rowMultiSelectWithClick", "suppressRowDeselection", "suppressRowClickSelection", "suppressCellSelection", "suppressCellFocus", "suppressMultiRangeSelection", "enableCellTextSelection", "enableRangeSelection", "enableRangeHandle", "enableFillHandle", "fillHandleDirection", "suppressClearOnFillReduction", "sortingOrder", "accentedSort", "unSortIcon", "suppressMultiSort", "alwaysMultiSort", "multiSortKey", "suppressMaintainUnsortedOrder", "icons", "rowHeight", "rowStyle", "rowClass", "rowClassRules", "suppressRowHoverHighlight", "suppressRowTransform", "columnHoverHighlight", "deltaSort", "treeDataDisplayType", "angularCompileRows", "angularCompileFilters", "functionsPassive", "enableGroupEdit", "getContextMenuItems", "getMainMenuItems", "postProcessPopup", "processCellForClipboard", "processHeaderForClipboard", "processGroupHeaderForClipboard", "processCellFromClipboard", "sendToClipboard", "processDataFromClipboard", "isExternalFilterPresent", "doesExternalFilterPass", "getChartToolbarItems", "createChartContainer", "navigateToNextHeader", "tabToNextHeader", "navigateToNextCell", "tabToNextCell", "suppressKeyboardEvent", "localeTextFunc", "getLocaleText", "getDocument", "paginationNumberFormatter", "groupRowAggNodes", "getGroupRowAgg", "isGroupOpenByDefault", "initialGroupOrderComparator", "defaultGroupOrderComparator", "processSecondaryColDef", "processSecondaryColGroupDef", "processPivotResultColDef", "processPivotResultColGroupDef", "getDataPath", "defaultGroupSortComparator", "getChildCount", "getServerSideGroupLevelParams", "getServerSideStoreParams", "isServerSideGroupOpenByDefault", "isApplyServerSideTransaction", "isServerSideGroup", "getServerSideGroupKey", "getBusinessKeyForNode", "getRowNodeId", "getRowId", "resetRowDataOnUpdate", "processRowPostCreate", "isRowSelectable", "isRowMaster", "fillOperation", "postSort", "postSortRows", "getRowStyle", "getRowClass", "getRowHeight", "isFullWidthCell", "isFullWidthRow"], outputs: ["toolPanelVisibleChanged", "toolPanelSizeChanged", "pasteStart", "pasteEnd", "columnVisible", "columnPinned", "columnResized", "columnMoved", "columnValueChanged", "columnPivotModeChanged", "columnPivotChanged", "columnGroupOpened", "newColumnsLoaded", "gridColumnsChanged", "displayedColumnsChanged", "virtualColumnsChanged", "columnEverythingChanged", "componentStateChanged", "cellValueChanged", "cellEditRequest", "rowValueChanged", "cellEditingStarted", "cellEditingStopped", "rowEditingStarted", "rowEditingStopped", "filterOpened", "filterChanged", "filterModified", "chartCreated", "chartRangeSelectionChanged", "chartOptionsChanged", "chartDestroyed", "cellKeyDown", "cellKeyPress", "gridReady", "firstDataRendered", "gridSizeChanged", "modelUpdated", "virtualRowRemoved", "viewportChanged", "bodyScroll", "bodyScrollEnd", "dragStarted", "dragStopped", "paginationChanged", "rowDragEnter", "rowDragMove", "rowDragLeave", "rowDragEnd", "columnRowGroupChanged", "rowGroupOpened", "expandOrCollapseAll", "pinnedRowDataChanged", "rowDataChanged", "rowDataUpdated", "asyncTransactionsFlushed", "cellClicked", "cellDoubleClicked", "cellFocused", "cellMouseOver", "cellMouseOut", "cellMouseDown", "rowClicked", "rowDoubleClicked", "rowSelected", "selectionChanged", "cellContextMenu", "rangeSelectionChanged", "sortChanged", "columnRowGroupChangeRequest", "columnPivotChangeRequest", "columnValueChangeRequest", "columnAggFuncChangeRequest"] }, { kind: "directive", type: i4.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i5.PageSizeSelectorComponent, selector: "lib-page-size-selector", inputs: ["pageSizeArray", "defaultSize", "totalEntries", "gridApi"] }, { kind: "component", type: i6.MetadataComponent, selector: "lib-metadata", inputs: ["metaDataOne", "metaDataTwo", "showmetaDataOne", "showmetaDataTwo", "reportName"], outputs: ["searchEvent", "exportEvent"] }, { kind: "component", type: i7.NgbAccordion, selector: "ngb-accordion", inputs: ["animation", "activeIds", "closeOthers", "destroyOnHide", "type"], outputs: ["panelChange", "shown", "hidden"], exportAs: ["ngbAccordion"] }, { kind: "directive", type: i7.NgbPanel, selector: "ngb-panel", inputs: ["disabled", "id", "title", "type", "cardClass"], outputs: ["shown", "hidden"] }, { kind: "directive", type: i7.NgbPanelTitle, selector: "ng-template[ngbPanelTitle]" }, { kind: "directive", type: i7.NgbPanelContent, selector: "ng-template[ngbPanelContent]" }, { kind: "component", type: i8.LoaderComponent, selector: "app-loader" }, { kind: "component", type: i9.SearchFilterComponent, selector: "lib-search-filter", inputs: ["ReportName"], outputs: ["searchClicked"] }] });
480
+ AccountingReportComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: AccountingReportComponent, selector: "lib-accounting-report", ngImport: i0, template: "<lib-search-filter [ReportName]=\"ReportName\" (searchClicked)=\"getReport($event)\"></lib-search-filter>\r\n\r\n<app-loader class=\"\" *ngIf=\"loadingState == ComponentLoadingState.Loading\"></app-loader>\r\n\r\n<div *ngIf=\"accountingReportModel!=undefined && accountingReportModel.accountingReportByBranchGroups?.length\">\r\n\r\n <lib-metadata [reportName]=\"ReportName\" [showmetaDataOne]=\"true\" [showmetaDataTwo]=\"true\" [metaDataOne]=\"leftData\"\r\n [metaDataTwo]=\"rightData\" (exportEvent)=\"handleExport($event)\" (searchEvent)=\"onSearch($event)\"></lib-metadata>\r\n\r\n <ngb-accordion #acc=\"ngbAccordion\" [closeOthers]=\"false\" [activeIds]=\"'panel-0'\">\r\n <ng-container *ngFor=\"let group of accountingReportModel?.accountingReportByBranchGroups; let i = index\">\r\n <ngb-panel [id]=\"'panel-' + i\">\r\n <ng-template ngbPanelTitle>\r\n <label class=\"title-stack line-1\">\r\n {{ group.branchNameAndCode }}\r\n </label>\r\n </ng-template>\r\n\r\n <ng-template ngbPanelContent>\r\n <!-- Send Transactions -->\r\n <div *ngIf=\"group.sendTransactions.entries.length\">\r\n <h6 class=\"subgroupcolumn\">{{ group.sendTransactions.subGroupName }}</h6>\r\n <div style=\"position: relative;\">\r\n <lib-page-size-selector [totalEntries]=\"group.sendTransactions.entries.length\" [defaultSize]=\"'15'\"\r\n [gridApi]=\"gridApis[i * 2]\">\r\n </lib-page-size-selector>\r\n\r\n <ag-grid-angular class=\"ag-theme-alpine compact-grid grid-size\" style=\"width: 100%; height: 370px;\"\r\n [columnDefs]=\"columnDefs\" [defaultColDef]=\"defaultColDef\" [rowData]=\"group.sendTransactions.entries\"\r\n [rowHeight]=\"20\" [headerHeight]=\"24\" [pagination]=\"true\" [paginationPageSize]=\"paginationArray[i]\"\r\n (gridReady)=\"onGridReady($event, i * 2)\" (gridSizeChanged)=\"onGridSizeChanged($event, i * 2)\">\r\n </ag-grid-angular>\r\n </div>\r\n </div>\r\n\r\n <!-- Receive Transactions -->\r\n <div *ngIf=\"group.receiveTransactions.entries.length\" class=\"mt-3\">\r\n <h6 class=\"subgroupcolumn\">{{ group.receiveTransactions.subGroupName }}</h6>\r\n <div style=\"position: relative;\">\r\n <lib-page-size-selector [totalEntries]=\"group.receiveTransactions.entries.length\" [defaultSize]=\"'15'\"\r\n [gridApi]=\"gridApis[i * 2 + 1]\">\r\n </lib-page-size-selector>\r\n\r\n <ag-grid-angular class=\"ag-theme-alpine compact-grid grid-size\" style=\"width: 100%; height: 370px;\"\r\n [columnDefs]=\"columnDefs\" [defaultColDef]=\"defaultColDef\" [rowData]=\"group.receiveTransactions.entries\"\r\n [rowHeight]=\"20\" [headerHeight]=\"24\" [pagination]=\"true\" [paginationPageSize]=\"paginationArray[i]\"\r\n (gridReady)=\"onGridReady($event, i * 2 + 1)\" (gridSizeChanged)=\"onGridSizeChanged($event, i * 2)\">\r\n </ag-grid-angular>\r\n </div>\r\n </div>\r\n </ng-template>\r\n </ngb-panel>\r\n </ng-container>\r\n </ngb-accordion>\r\n\r\n\r\n</div>\r\n\r\n<div class=\"alert alert-warning mt-3\" *ngIf=\"noDataFound && loadingState!=ComponentLoadingState.Loading\">\r\n No Data found matching your search criteria.\r\n</div>", styles: [".transaction-grid ::ng-deep .ag-header{background-color:#f9f9f9;font-weight:600;font-size:10px;color:#000;border-right:1px solid #e0e0e0}:host ::ng-deep .ag-header-cell{padding:2px!important;align-items:center!important;justify-content:center!important;border-right:1px solid #e0e0e0;white-space:normal!important;word-break:normal!important;overflow-wrap:break-word!important;text-align:center!important;height:auto!important}::ng-deep .ag-header-cell-label{display:flex!important;justify-content:center!important;align-items:center!important;width:100%;text-align:center!important}::ng-deep .ag-header-cell-text{text-align:center!important;width:100%!important;display:flex!important;justify-content:center!important}.transaction-grid ::ng-deep .ag-row{border-bottom:1px solid #e0e0e0}.transaction-grid ::ng-deep .ag-cell{font-size:9px;white-space:normal!important;word-break:keep-all!important;overflow-wrap:anywhere;line-height:1.4;padding:4px!important;color:#000;font-weight:500;border-right:.5px solid #e0e0e0;align-content:center;user-select:text!important;-webkit-user-select:text!important;-moz-user-select:text!important;-ms-user-select:text!important;cursor:text}::ng-deep .ag-cell-label-container{padding:0!important}.ag-theme-alpine{--ag-header-font-size: 10px;--ag-font-size: 10px;--ag-header-background-color: #fdfdfd;--ag-header-foreground-color: rgb(0, 0, 0)}::ng-deep .ag-paging-panel{height:30px!important}::ng-deep .compact-grid .ag-cell{cursor:default!important;border-right:1px solid #e0e0e0;padding:2px 3px!important;font-size:9px!important;display:flex!important;align-items:center!important}::ng-deep .compact-grid .ag-cell-value{cursor:text!important;font-size:9px!important;padding:0 3px 0 2px!important}::ng-deep .compact-grid .ag-right-aligned-cell{text-align:right!important;justify-content:flex-end!important;text-overflow:ellipsis}.grid-size{width:100%!important;font-weight:500!important;height:390px!important}::ng-deep .ag-root{-webkit-user-select:text!important;user-select:text!important}::ng-deep .ag-cell{-webkit-user-select:text!important;user-select:text!important}.margin-bottom-30{margin-bottom:30px}::ng-deep .accordion-button{display:flex;align-items:flex-start;width:100%;min-height:30px;background-color:#e7f1ff;border:0}.title-stack{display:flex;flex-direction:column;line-height:1.2}.line-1{font-weight:600}::ng-deep .accordion-button.collapsed{color:#0c63e4!important;background-color:#f4f7fc!important}::ng-deep .accordion-button{color:#052c65!important;background-color:#f4f7fc!important}::ng-deep .accordion-item{margin-bottom:10px}::ng-deep .accordion-item{border-radius:0!important;margin-bottom:10px}::ng-deep .accordion-button{border-radius:0!important;font-size:13px!important}::ng-deep .accordion-collapse{border-radius:0!important}::ng-deep .accordion-body{border-radius:0!important}::ng-deep .accordion-item{border:1px solid #b0bac5!important}::ng-deep .accordion-item{border:1px solid #b0bac5;border-radius:0;margin-bottom:10px}::ng-deep .accordion-button{border:none;background-color:#e7f1ff;box-shadow:none}::ng-deep .accordion-button.collapsed{border-bottom:none!important}::ng-deep .accordion-button:not(.collapsed){background-color:#fff;border-bottom:none!important}::ng-deep .accordion-body{border-top:1px solid #b0bac5}:host ::ng-deep .my-2{margin-bottom:10px!important}label{margin-bottom:0!important}::ng-deep .card-header .btn-link{font-size:13px!important;color:#0c63e4!important}.subgroupcolumn{font-family:Open Sans!important;font-size:13px!important;color:#052c65!important;font-weight:700!important}\n"], dependencies: [{ kind: "component", type: i3.AgGridAngular, selector: "ag-grid-angular", inputs: ["gridOptions", "modules", "statusBar", "sideBar", "suppressContextMenu", "preventDefaultOnContextMenu", "allowContextMenuWithControlKey", "suppressMenuHide", "enableBrowserTooltips", "tooltipShowDelay", "tooltipHideDelay", "tooltipMouseTrack", "popupParent", "copyHeadersToClipboard", "copyGroupHeadersToClipboard", "clipboardDelimiter", "suppressCopyRowsToClipboard", "suppressCopySingleCellRanges", "suppressLastEmptyLineOnPaste", "suppressClipboardPaste", "suppressClipboardApi", "columnDefs", "defaultColDef", "defaultColGroupDef", "columnTypes", "maintainColumnOrder", "suppressFieldDotNotation", "deltaColumnMode", "applyColumnDefOrder", "immutableColumns", "suppressSetColumnStateEvents", "suppressColumnStateEvents", "colWidth", "minColWidth", "maxColWidth", "headerHeight", "groupHeaderHeight", "floatingFiltersHeight", "pivotHeaderHeight", "pivotGroupHeaderHeight", "allowDragFromColumnsToolPanel", "suppressMovableColumns", "suppressColumnMoveAnimation", "suppressDragLeaveHidesColumns", "suppressRowGroupHidesColumns", "colResizeDefault", "suppressAutoSize", "autoSizePadding", "skipHeaderOnAutoSize", "components", "frameworkComponents", "editType", "singleClickEdit", "suppressClickEdit", "readOnlyEdit", "stopEditingWhenCellsLoseFocus", "enterMovesDown", "enterMovesDownAfterEdit", "enableCellEditingOnBackspace", "undoRedoCellEditing", "undoRedoCellEditingLimit", "stopEditingWhenGridLosesFocus", "defaultCsvExportParams", "suppressCsvExport", "defaultExcelExportParams", "suppressExcelExport", "excelStyles", "defaultExportParams", "quickFilterText", "cacheQuickFilter", "excludeChildrenWhenTreeDataFiltering", "enableCharts", "chartThemes", "customChartThemes", "chartThemeOverrides", "enableChartToolPanelsButton", "chartToolPanelsDef", "loadingCellRenderer", "loadingCellRendererFramework", "loadingCellRendererParams", "loadingCellRendererSelector", "localeText", "masterDetail", "keepDetailRows", "keepDetailRowsCount", "detailCellRenderer", "detailCellRendererFramework", "detailCellRendererParams", "detailRowHeight", "detailRowAutoHeight", "context", "alignedGrids", "tabIndex", "rowBuffer", "valueCache", "valueCacheNeverExpires", "enableCellExpressions", "suppressParentsInRowNodes", "suppressTouch", "suppressFocusAfterRefresh", "suppressAsyncEvents", "suppressBrowserResizeObserver", "suppressPropertyNamesCheck", "suppressChangeDetection", "debug", "overlayLoadingTemplate", "loadingOverlayComponent", "loadingOverlayComponentFramework", "loadingOverlayComponentParams", "suppressLoadingOverlay", "overlayNoRowsTemplate", "noRowsOverlayComponent", "noRowsOverlayComponentFramework", "noRowsOverlayComponentParams", "suppressNoRowsOverlay", "pagination", "paginationPageSize", "paginationAutoPageSize", "paginateChildRows", "suppressPaginationPanel", "pivotMode", "pivotPanelShow", "pivotColumnGroupTotals", "pivotRowTotals", "pivotSuppressAutoColumn", "suppressExpandablePivotGroups", "functionsReadOnly", "aggFuncs", "suppressAggFuncInHeader", "suppressAggAtRootLevel", "aggregateOnlyChangedColumns", "suppressAggFilteredOnly", "removePivotHeaderRowWhenSingleValueColumn", "animateRows", "enableCellChangeFlash", "cellFlashDelay", "cellFadeDelay", "allowShowChangeAfterFilter", "domLayout", "ensureDomOrder", "enableRtl", "suppressColumnVirtualisation", "suppressMaxRenderedRowRestriction", "suppressRowVirtualisation", "rowDragManaged", "suppressRowDrag", "suppressMoveWhenRowDragging", "rowDragEntireRow", "rowDragMultiRow", "rowDragText", "fullWidthCellRenderer", "fullWidthCellRendererFramework", "fullWidthCellRendererParams", "embedFullWidthRows", "deprecatedEmbedFullWidthRows", "groupDisplayType", "groupDefaultExpanded", "autoGroupColumnDef", "groupMaintainOrder", "groupSelectsChildren", "groupAggFiltering", "groupIncludeFooter", "groupIncludeTotalFooter", "groupSuppressBlankHeader", "groupSelectsFiltered", "showOpenedGroup", "groupRemoveSingleChildren", "groupRemoveLowestSingleChildren", "groupHideOpenParents", "rowGroupPanelShow", "groupRowRenderer", "groupRowRendererFramework", "groupRowRendererParams", "suppressMakeColumnVisibleAfterUnGroup", "treeData", "rowGroupPanelSuppressSort", "groupRowsSticky", "groupRowInnerRenderer", "groupRowInnerRendererFramework", "groupMultiAutoColumn", "groupUseEntireRow", "groupSuppressAutoColumn", "rememberGroupStateWhenNewData", "pinnedTopRowData", "pinnedBottomRowData", "rowModelType", "rowData", "immutableData", "asyncTransactionWaitMillis", "suppressModelUpdateAfterUpdateTransaction", "deltaRowDataMode", "batchUpdateWaitMillis", "datasource", "cacheOverflowSize", "infiniteInitialRowCount", "serverSideInitialRowCount", "serverSideStoreType", "serverSideInfiniteScroll", "cacheBlockSize", "maxBlocksInCache", "maxConcurrentDatasourceRequests", "blockLoadDebounceMillis", "purgeClosedRowNodes", "serverSideDatasource", "serverSideSortAllLevels", "serverSideFilterAllLevels", "serverSideSortOnServer", "serverSideFilterOnServer", "serverSideSortingAlwaysResets", "serverSideFilteringAlwaysResets", "suppressEnterpriseResetOnNewColumns", "viewportDatasource", "viewportRowModelPageSize", "viewportRowModelBufferSize", "alwaysShowHorizontalScroll", "alwaysShowVerticalScroll", "debounceVerticalScrollbar", "suppressHorizontalScroll", "suppressScrollOnNewData", "suppressScrollWhenPopupsAreOpen", "suppressAnimationFrame", "suppressMiddleClickScrolls", "suppressPreventDefaultOnMouseWheel", "scrollbarWidth", "rowSelection", "rowMultiSelectWithClick", "suppressRowDeselection", "suppressRowClickSelection", "suppressCellSelection", "suppressCellFocus", "suppressMultiRangeSelection", "enableCellTextSelection", "enableRangeSelection", "enableRangeHandle", "enableFillHandle", "fillHandleDirection", "suppressClearOnFillReduction", "sortingOrder", "accentedSort", "unSortIcon", "suppressMultiSort", "alwaysMultiSort", "multiSortKey", "suppressMaintainUnsortedOrder", "icons", "rowHeight", "rowStyle", "rowClass", "rowClassRules", "suppressRowHoverHighlight", "suppressRowTransform", "columnHoverHighlight", "deltaSort", "treeDataDisplayType", "angularCompileRows", "angularCompileFilters", "functionsPassive", "enableGroupEdit", "getContextMenuItems", "getMainMenuItems", "postProcessPopup", "processCellForClipboard", "processHeaderForClipboard", "processGroupHeaderForClipboard", "processCellFromClipboard", "sendToClipboard", "processDataFromClipboard", "isExternalFilterPresent", "doesExternalFilterPass", "getChartToolbarItems", "createChartContainer", "navigateToNextHeader", "tabToNextHeader", "navigateToNextCell", "tabToNextCell", "suppressKeyboardEvent", "localeTextFunc", "getLocaleText", "getDocument", "paginationNumberFormatter", "groupRowAggNodes", "getGroupRowAgg", "isGroupOpenByDefault", "initialGroupOrderComparator", "defaultGroupOrderComparator", "processSecondaryColDef", "processSecondaryColGroupDef", "processPivotResultColDef", "processPivotResultColGroupDef", "getDataPath", "defaultGroupSortComparator", "getChildCount", "getServerSideGroupLevelParams", "getServerSideStoreParams", "isServerSideGroupOpenByDefault", "isApplyServerSideTransaction", "isServerSideGroup", "getServerSideGroupKey", "getBusinessKeyForNode", "getRowNodeId", "getRowId", "resetRowDataOnUpdate", "processRowPostCreate", "isRowSelectable", "isRowMaster", "fillOperation", "postSort", "postSortRows", "getRowStyle", "getRowClass", "getRowHeight", "isFullWidthCell", "isFullWidthRow"], outputs: ["toolPanelVisibleChanged", "toolPanelSizeChanged", "pasteStart", "pasteEnd", "columnVisible", "columnPinned", "columnResized", "columnMoved", "columnValueChanged", "columnPivotModeChanged", "columnPivotChanged", "columnGroupOpened", "newColumnsLoaded", "gridColumnsChanged", "displayedColumnsChanged", "virtualColumnsChanged", "columnEverythingChanged", "componentStateChanged", "cellValueChanged", "cellEditRequest", "rowValueChanged", "cellEditingStarted", "cellEditingStopped", "rowEditingStarted", "rowEditingStopped", "filterOpened", "filterChanged", "filterModified", "chartCreated", "chartRangeSelectionChanged", "chartOptionsChanged", "chartDestroyed", "cellKeyDown", "cellKeyPress", "gridReady", "firstDataRendered", "gridSizeChanged", "modelUpdated", "virtualRowRemoved", "viewportChanged", "bodyScroll", "bodyScrollEnd", "dragStarted", "dragStopped", "paginationChanged", "rowDragEnter", "rowDragMove", "rowDragLeave", "rowDragEnd", "columnRowGroupChanged", "rowGroupOpened", "expandOrCollapseAll", "pinnedRowDataChanged", "rowDataChanged", "rowDataUpdated", "asyncTransactionsFlushed", "cellClicked", "cellDoubleClicked", "cellFocused", "cellMouseOver", "cellMouseOut", "cellMouseDown", "rowClicked", "rowDoubleClicked", "rowSelected", "selectionChanged", "cellContextMenu", "rangeSelectionChanged", "sortChanged", "columnRowGroupChangeRequest", "columnPivotChangeRequest", "columnValueChangeRequest", "columnAggFuncChangeRequest"] }, { kind: "directive", type: i4.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i5.PageSizeSelectorComponent, selector: "lib-page-size-selector", inputs: ["pageSizeArray", "defaultSize", "totalEntries", "gridApi"] }, { kind: "component", type: i6.MetadataComponent, selector: "lib-metadata", inputs: ["metaDataOne", "metaDataTwo", "showmetaDataOne", "showmetaDataTwo", "reportName"], outputs: ["searchEvent", "exportEvent"] }, { kind: "component", type: i7.NgbAccordion, selector: "ngb-accordion", inputs: ["animation", "activeIds", "closeOthers", "destroyOnHide", "type"], outputs: ["panelChange", "shown", "hidden"], exportAs: ["ngbAccordion"] }, { kind: "directive", type: i7.NgbPanel, selector: "ngb-panel", inputs: ["disabled", "id", "title", "type", "cardClass"], outputs: ["shown", "hidden"] }, { kind: "directive", type: i7.NgbPanelTitle, selector: "ng-template[ngbPanelTitle]" }, { kind: "directive", type: i7.NgbPanelContent, selector: "ng-template[ngbPanelContent]" }, { kind: "component", type: i8.LoaderComponent, selector: "app-loader" }, { kind: "component", type: i9.SearchFilterComponent, selector: "lib-search-filter", inputs: ["ReportName"], outputs: ["searchClicked"] }] });
449
481
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: AccountingReportComponent, decorators: [{
450
482
  type: Component,
451
- args: [{ selector: 'lib-accounting-report', template: "<lib-search-filter [ReportName]=\"ReportName\" (searchClicked)=\"getReport($event)\"></lib-search-filter>\r\n\r\n<app-loader class=\"\" *ngIf=\"loadingState == ComponentLoadingState.Loading\"></app-loader>\r\n\r\n<div *ngIf=\"accountingReportModel!=undefined\">\r\n\r\n <lib-metadata [reportName]=\"ReportName\" [showmetaDataOne]=\"true\" [showmetaDataTwo]=\"true\" [metaDataOne]=\"leftData\"\r\n [metaDataTwo]=\"rightData\" (exportEvent)=\"handleExport($event)\" (searchEvent)=\"onSearch($event)\"></lib-metadata>\r\n\r\n <ngb-accordion #acc=\"ngbAccordion\" [closeOthers]=\"false\" [activeIds]=\"'panel-0'\">\r\n <ng-container *ngFor=\"let group of accountingReportModel?.accountingReportByBranchGroups; let i = index\">\r\n <ngb-panel [id]=\"'panel-' + i\">\r\n\r\n <ng-template ngbPanelTitle>\r\n <label class=\"title-stack line-1\">\r\n {{ group.branchNameAndCode }} \u2192 {{ group.subGroupColumn }}\r\n </label>\r\n </ng-template>\r\n\r\n <ng-template ngbPanelContent>\r\n <div style=\"position: relative;\">\r\n <lib-page-size-selector [totalEntries]=\"group.accountingReportEntriesList.length\" [defaultSize]=\"'15'\"\r\n [gridApi]=\"gridApis[i]\">\r\n </lib-page-size-selector>\r\n\r\n <ag-grid-angular class=\"ag-theme-alpine compact-grid grid-size\" style=\"width: 100%;height: 370px;\"\r\n [columnDefs]=\"columnDefs\" [defaultColDef]=\"defaultColDef\" [rowData]=\"group.accountingReportEntriesList\"\r\n [rowHeight]=\"20\" [headerHeight]=\"24\" [pagination]=\"true\" [paginationPageSize]=\"paginationArray[i]\"\r\n (gridReady)=\"onGridReady($event,i)\" (gridSizeChanged)=\"onGridSizeChanged($event)\">\r\n </ag-grid-angular>\r\n </div>\r\n </ng-template>\r\n </ngb-panel>\r\n </ng-container>\r\n </ngb-accordion>\r\n\r\n</div>\r\n\r\n<div class=\"alert alert-warning mt-3\" *ngIf=\"noDataFound && loadingState!=ComponentLoadingState.Loading\">\r\n No Data Found\r\n</div>", styles: [".transaction-grid ::ng-deep .ag-header{background-color:#f9f9f9;font-weight:600;font-size:10px;color:#000;border-right:1px solid #e0e0e0}:host ::ng-deep .ag-header-cell{padding:2px!important;align-items:center!important;justify-content:center!important;border-right:1px solid #e0e0e0;white-space:normal!important;word-break:normal!important;overflow-wrap:break-word!important;text-align:center!important;height:auto!important}::ng-deep .ag-header-cell-label{display:flex!important;justify-content:center!important;align-items:center!important;width:100%;text-align:center!important}::ng-deep .ag-header-cell-text{text-align:center!important;width:100%!important;display:flex!important;justify-content:center!important}.transaction-grid ::ng-deep .ag-row{border-bottom:1px solid #e0e0e0}.transaction-grid ::ng-deep .ag-cell{font-size:9px;white-space:normal!important;word-break:keep-all!important;overflow-wrap:anywhere;line-height:1.4;padding:4px!important;color:#000;font-weight:500;border-right:.5px solid #e0e0e0;align-content:center;user-select:text!important;-webkit-user-select:text!important;-moz-user-select:text!important;-ms-user-select:text!important;cursor:text}::ng-deep .ag-cell-label-container{padding:0!important}.ag-theme-alpine{--ag-header-font-size: 10px;--ag-font-size: 10px;--ag-header-background-color: #fdfdfd;--ag-header-foreground-color: rgb(0, 0, 0)}::ng-deep .ag-paging-panel{height:30px!important}::ng-deep .compact-grid .ag-cell{cursor:default!important;border-right:1px solid #e0e0e0;padding:2px 3px!important;font-size:9px!important;display:flex!important;align-items:center!important}::ng-deep .compact-grid .ag-cell-value{cursor:text!important;font-size:9px!important;padding:0 3px 0 2px!important}::ng-deep .compact-grid .ag-right-aligned-cell{text-align:right!important;justify-content:flex-end!important;text-overflow:ellipsis}.grid-size{width:100%!important;font-weight:500!important;height:390px!important}::ng-deep .ag-root{-webkit-user-select:text!important;user-select:text!important}::ng-deep .ag-cell{-webkit-user-select:text!important;user-select:text!important}.margin-bottom-30{margin-bottom:30px}::ng-deep .accordion-button{display:flex;align-items:flex-start;width:100%;min-height:30px;background-color:#e7f1ff;border:0}.title-stack{display:flex;flex-direction:column;line-height:1.2}.line-1{font-weight:600}::ng-deep .accordion-button.collapsed{color:#0c63e4!important;background-color:#f4f7fc!important}::ng-deep .accordion-button{color:#052c65!important;background-color:#f4f7fc!important}::ng-deep .accordion-item{margin-bottom:10px}::ng-deep .accordion-item{border-radius:0!important;margin-bottom:10px}::ng-deep .accordion-button{border-radius:0!important;font-size:13px!important}::ng-deep .accordion-collapse{border-radius:0!important}::ng-deep .accordion-body{border-radius:0!important}::ng-deep .accordion-item{border:1px solid #b0bac5!important}::ng-deep .accordion-item{border:1px solid #b0bac5;border-radius:0;margin-bottom:10px}::ng-deep .accordion-button{border:none;background-color:#e7f1ff;box-shadow:none}::ng-deep .accordion-button.collapsed{border-bottom:none!important}::ng-deep .accordion-button:not(.collapsed){background-color:#fff;border-bottom:none!important}::ng-deep .accordion-body{border-top:1px solid #b0bac5}:host ::ng-deep .my-2{margin-bottom:10px!important}label{margin-bottom:0!important}::ng-deep .card-header .btn-link{font-size:13px!important;color:#0c63e4!important}\n"] }]
483
+ args: [{ selector: 'lib-accounting-report', template: "<lib-search-filter [ReportName]=\"ReportName\" (searchClicked)=\"getReport($event)\"></lib-search-filter>\r\n\r\n<app-loader class=\"\" *ngIf=\"loadingState == ComponentLoadingState.Loading\"></app-loader>\r\n\r\n<div *ngIf=\"accountingReportModel!=undefined && accountingReportModel.accountingReportByBranchGroups?.length\">\r\n\r\n <lib-metadata [reportName]=\"ReportName\" [showmetaDataOne]=\"true\" [showmetaDataTwo]=\"true\" [metaDataOne]=\"leftData\"\r\n [metaDataTwo]=\"rightData\" (exportEvent)=\"handleExport($event)\" (searchEvent)=\"onSearch($event)\"></lib-metadata>\r\n\r\n <ngb-accordion #acc=\"ngbAccordion\" [closeOthers]=\"false\" [activeIds]=\"'panel-0'\">\r\n <ng-container *ngFor=\"let group of accountingReportModel?.accountingReportByBranchGroups; let i = index\">\r\n <ngb-panel [id]=\"'panel-' + i\">\r\n <ng-template ngbPanelTitle>\r\n <label class=\"title-stack line-1\">\r\n {{ group.branchNameAndCode }}\r\n </label>\r\n </ng-template>\r\n\r\n <ng-template ngbPanelContent>\r\n <!-- Send Transactions -->\r\n <div *ngIf=\"group.sendTransactions.entries.length\">\r\n <h6 class=\"subgroupcolumn\">{{ group.sendTransactions.subGroupName }}</h6>\r\n <div style=\"position: relative;\">\r\n <lib-page-size-selector [totalEntries]=\"group.sendTransactions.entries.length\" [defaultSize]=\"'15'\"\r\n [gridApi]=\"gridApis[i * 2]\">\r\n </lib-page-size-selector>\r\n\r\n <ag-grid-angular class=\"ag-theme-alpine compact-grid grid-size\" style=\"width: 100%; height: 370px;\"\r\n [columnDefs]=\"columnDefs\" [defaultColDef]=\"defaultColDef\" [rowData]=\"group.sendTransactions.entries\"\r\n [rowHeight]=\"20\" [headerHeight]=\"24\" [pagination]=\"true\" [paginationPageSize]=\"paginationArray[i]\"\r\n (gridReady)=\"onGridReady($event, i * 2)\" (gridSizeChanged)=\"onGridSizeChanged($event, i * 2)\">\r\n </ag-grid-angular>\r\n </div>\r\n </div>\r\n\r\n <!-- Receive Transactions -->\r\n <div *ngIf=\"group.receiveTransactions.entries.length\" class=\"mt-3\">\r\n <h6 class=\"subgroupcolumn\">{{ group.receiveTransactions.subGroupName }}</h6>\r\n <div style=\"position: relative;\">\r\n <lib-page-size-selector [totalEntries]=\"group.receiveTransactions.entries.length\" [defaultSize]=\"'15'\"\r\n [gridApi]=\"gridApis[i * 2 + 1]\">\r\n </lib-page-size-selector>\r\n\r\n <ag-grid-angular class=\"ag-theme-alpine compact-grid grid-size\" style=\"width: 100%; height: 370px;\"\r\n [columnDefs]=\"columnDefs\" [defaultColDef]=\"defaultColDef\" [rowData]=\"group.receiveTransactions.entries\"\r\n [rowHeight]=\"20\" [headerHeight]=\"24\" [pagination]=\"true\" [paginationPageSize]=\"paginationArray[i]\"\r\n (gridReady)=\"onGridReady($event, i * 2 + 1)\" (gridSizeChanged)=\"onGridSizeChanged($event, i * 2)\">\r\n </ag-grid-angular>\r\n </div>\r\n </div>\r\n </ng-template>\r\n </ngb-panel>\r\n </ng-container>\r\n </ngb-accordion>\r\n\r\n\r\n</div>\r\n\r\n<div class=\"alert alert-warning mt-3\" *ngIf=\"noDataFound && loadingState!=ComponentLoadingState.Loading\">\r\n No Data found matching your search criteria.\r\n</div>", styles: [".transaction-grid ::ng-deep .ag-header{background-color:#f9f9f9;font-weight:600;font-size:10px;color:#000;border-right:1px solid #e0e0e0}:host ::ng-deep .ag-header-cell{padding:2px!important;align-items:center!important;justify-content:center!important;border-right:1px solid #e0e0e0;white-space:normal!important;word-break:normal!important;overflow-wrap:break-word!important;text-align:center!important;height:auto!important}::ng-deep .ag-header-cell-label{display:flex!important;justify-content:center!important;align-items:center!important;width:100%;text-align:center!important}::ng-deep .ag-header-cell-text{text-align:center!important;width:100%!important;display:flex!important;justify-content:center!important}.transaction-grid ::ng-deep .ag-row{border-bottom:1px solid #e0e0e0}.transaction-grid ::ng-deep .ag-cell{font-size:9px;white-space:normal!important;word-break:keep-all!important;overflow-wrap:anywhere;line-height:1.4;padding:4px!important;color:#000;font-weight:500;border-right:.5px solid #e0e0e0;align-content:center;user-select:text!important;-webkit-user-select:text!important;-moz-user-select:text!important;-ms-user-select:text!important;cursor:text}::ng-deep .ag-cell-label-container{padding:0!important}.ag-theme-alpine{--ag-header-font-size: 10px;--ag-font-size: 10px;--ag-header-background-color: #fdfdfd;--ag-header-foreground-color: rgb(0, 0, 0)}::ng-deep .ag-paging-panel{height:30px!important}::ng-deep .compact-grid .ag-cell{cursor:default!important;border-right:1px solid #e0e0e0;padding:2px 3px!important;font-size:9px!important;display:flex!important;align-items:center!important}::ng-deep .compact-grid .ag-cell-value{cursor:text!important;font-size:9px!important;padding:0 3px 0 2px!important}::ng-deep .compact-grid .ag-right-aligned-cell{text-align:right!important;justify-content:flex-end!important;text-overflow:ellipsis}.grid-size{width:100%!important;font-weight:500!important;height:390px!important}::ng-deep .ag-root{-webkit-user-select:text!important;user-select:text!important}::ng-deep .ag-cell{-webkit-user-select:text!important;user-select:text!important}.margin-bottom-30{margin-bottom:30px}::ng-deep .accordion-button{display:flex;align-items:flex-start;width:100%;min-height:30px;background-color:#e7f1ff;border:0}.title-stack{display:flex;flex-direction:column;line-height:1.2}.line-1{font-weight:600}::ng-deep .accordion-button.collapsed{color:#0c63e4!important;background-color:#f4f7fc!important}::ng-deep .accordion-button{color:#052c65!important;background-color:#f4f7fc!important}::ng-deep .accordion-item{margin-bottom:10px}::ng-deep .accordion-item{border-radius:0!important;margin-bottom:10px}::ng-deep .accordion-button{border-radius:0!important;font-size:13px!important}::ng-deep .accordion-collapse{border-radius:0!important}::ng-deep .accordion-body{border-radius:0!important}::ng-deep .accordion-item{border:1px solid #b0bac5!important}::ng-deep .accordion-item{border:1px solid #b0bac5;border-radius:0;margin-bottom:10px}::ng-deep .accordion-button{border:none;background-color:#e7f1ff;box-shadow:none}::ng-deep .accordion-button.collapsed{border-bottom:none!important}::ng-deep .accordion-button:not(.collapsed){background-color:#fff;border-bottom:none!important}::ng-deep .accordion-body{border-top:1px solid #b0bac5}:host ::ng-deep .my-2{margin-bottom:10px!important}label{margin-bottom:0!important}::ng-deep .card-header .btn-link{font-size:13px!important;color:#0c63e4!important}.subgroupcolumn{font-family:Open Sans!important;font-size:13px!important;color:#052c65!important;font-weight:700!important}\n"] }]
452
484
  }], ctorParameters: function () { return [{ type: i1.ReportService }, { type: i2.ExportService }]; } });
453
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"accounting-report.component.js","sourceRoot":"","sources":["../../../../../../projects/reports-lib/src/lib/components/accounting-report/accounting-report.component.ts","../../../../../../projects/reports-lib/src/lib/components/accounting-report/accounting-report.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit } from '@angular/core';\r\nimport { AccountingReportModel } from '../../models/accounting-report/accounting-report-model';\r\nimport { ColDef, ColumnApi, GridApi, GridReadyEvent } from 'ag-grid-community';\r\nimport { ReportService } from '../../services/report.service';\r\nimport { ExportService } from '../../shared/export.service';\r\nimport { formatDate } from '@angular/common';\r\nimport { ComponentLoadingStates } from '../../models/component-loading-states';\r\nimport { AccountingReportByBranchGroups } from '../../models/accounting-report/accounting-report-branch-group';\r\n\r\nimport jsPDF from 'jspdf';\r\nimport 'jspdf-autotable';\r\nimport * as ExcelJS from 'exceljs';\r\nimport * as FileSaver from 'file-saver';\r\n\r\ndeclare module 'jspdf' {\r\n  interface jsPDF {\r\n    autoTable: (options: any) => jsPDF;\r\n  }\r\n}\r\n\r\nexport interface AccountingReportRequest {\r\n  startDate: string;\r\n  endDate: string;\r\n  sendCountryCode: string;\r\n  recvCountryCode: string;\r\n  businessPartnerCorrelationID: string;\r\n  transactionStatus: string;\r\n  payoutCurrency: string;\r\n  transactionType: string;\r\n  branchCode: string;\r\n  companyCode: string;\r\n}\r\n\r\n@Component({\r\n  selector: 'lib-accounting-report',\r\n  templateUrl: './accounting-report.component.html',\r\n  styleUrls: ['./accounting-report.component.scss']\r\n})\r\nexport class AccountingReportComponent implements OnInit {\r\n\r\n  ReportName: string = \"Accounting\";\r\n  reportUser: any;\r\n  reportTime: any;\r\n  reportPeriod: any;\r\n  branchNameAndCode: any;\r\n  subGroupColumn: any;\r\n  ComponentLoadingState = ComponentLoadingStates;\r\n  loadingState: ComponentLoadingStates = ComponentLoadingStates.Complete;\r\n  noDataFound: boolean = false;\r\n\r\n  leftData: Record<string, string>;\r\n  rightData: Record<string, string>;\r\n\r\n  searchText: string = '';\r\n  rowData = [];\r\n  accountingReportModel: AccountingReportModel;\r\n  pageSize: number = 15;\r\n\r\n  selectedExportOption: string = 'excel';\r\n  exportFormats = [{ formatName: \"Excel\", code: 'excel' }, { formatName: \"PDF\", code: 'pdf' }, { formatName: \"CSV\", code: 'csv' }]\r\n\r\n  defaultColDef: ColDef = {\r\n    resizable: true,\r\n    sortable: false,\r\n    minWidth: 40,\r\n    suppressSizeToFit: false,\r\n    cellStyle: { userSelect: 'text', 'line-height': '1.2', 'white-space': 'normal', 'word-break': 'normal', 'overflow-wrap': 'break-word' },\r\n\r\n    //  Header wrapping\r\n    wrapHeaderText: true,\r\n    autoHeaderHeight: true,\r\n\r\n    //  Cell wrapping\r\n    wrapText: true,\r\n    autoHeight: true\r\n  };\r\n\r\n  columnDefs: ColDef[] = [\r\n    { headerName: 'BusinessDate', field: 'businessDate', tooltipField: 'businessDate' },\r\n    { headerName: 'TxnDate&Time', field: 'transactionDateAndTime', tooltipField: 'transactionDateAndTime', minWidth: 110, },\r\n    { headerName: 'Transaction Number', field: 'transactionNumber', tooltipField: 'transactionNumber' },\r\n    { headerName: 'SendClient', field: 'sendClient', tooltipField: 'sendClient' },\r\n    { headerName: 'Principle SendClient (If Applicable)', field: 'principleSendClient', tooltipField: 'principleSendClient' },\r\n    { headerName: 'ReceiveClient', field: 'receiveClient', tooltipField: 'receiveClient' },\r\n    { headerName: 'Principle ReceiveClient (If Applicable)', field: 'principleReceiveClient', tooltipField: 'principleReceiveClient' },\r\n    { headerName: 'ReceiveCcy', field: 'receiveCurrency', tooltipField: 'receiveCurrency' },\r\n    { headerName: 'AmountPaid', field: 'amountPaid', tooltipField: 'amountPaid', cellClass: 'ag-right-aligned-cell' },\r\n    { headerName: 'SendCcy', field: 'sendCurrency', tooltipField: 'sendCurrency', },\r\n    { headerName: 'ServiceFee', field: 'serviceFee', tooltipField: 'serviceFee', cellClass: 'ag-right-aligned-cell' },\r\n    { headerName: 'Tax', field: 'tax', tooltipField: 'tax', cellClass: 'ag-right-aligned-cell' },\r\n    { headerName: 'PrincipleSend Amount', field: 'principleSendAmount', tooltipField: 'principleSendAmount', cellClass: 'ag-right-aligned-cell' },\r\n    { headerName: 'Transaction Status', field: 'transactionStatus', tooltipField: 'transactionStatus' },\r\n    { headerName: 'SettlementCcy', field: 'settlementCurrency', tooltipField: 'settlementCurrency', cellClass: 'ag-right-aligned-cell' },\r\n    { headerName: 'ClientSettl (in SCcy)', field: 'clientSettlementInSCcy', tooltipField: 'clientSettlementInSCcy', cellClass: 'ag-right-aligned-cell' },\r\n    { headerName: 'ClientSettl (in USD)', field: 'clientSettlementInUSD', tooltipField: 'clientSettlementInUSD', cellClass: 'ag-right-aligned-cell' },\r\n    { headerName: 'ShareType', field: 'shareType', tooltipField: 'shareType' },\r\n    { headerName: 'ShareValue', field: 'shareValue', tooltipField: 'shareValue', cellClass: 'ag-right-aligned-cell' },\r\n    { headerName: 'Send/Receive FeeCcy', field: 'sendReceiveFeeCcy', tooltipField: 'sendReceiveFeeCcy' },\r\n    { headerName: 'ShareAmt (in USD)', field: 'shareAmountInUSD', tooltipField: 'shareAmountInUSD', cellClass: 'ag-right-aligned-cell' },\r\n    { headerName: 'Settlement Rate', field: 'settlementRate', tooltipField: 'settlementRate', cellClass: 'ag-right-aligned-cell' },\r\n  ];\r\n\r\n\r\n  gridApis: GridApi[] = [];\r\n  paginationArray: any[];\r\n\r\n  gridColumnApi: ColumnApi;\r\n  ezremitUser: boolean = false;\r\n  originalGroupEntries: AccountingReportByBranchGroups[] = [];\r\n\r\n  constructor(private reportService: ReportService, private exportService: ExportService) { }\r\n\r\n  ngOnInit(): void {\r\n    const ezremitusername = sessionStorage.getItem('ezremitusername');\r\n    if (ezremitusername) {\r\n      this.ezremitUser = true;\r\n    }\r\n  }\r\n\r\n  public getAccountingReport(request?: AccountingReportRequest) {\r\n    this.loadingState = ComponentLoadingStates.Loading;\r\n    this.accountingReportModel = undefined;\r\n    this.branchNameAndCode = undefined;\r\n    this.subGroupColumn = undefined;\r\n    const finalReq = request;\r\n\r\n    this.reportService.getAccountingReport(finalReq).subscribe(data => {\r\n      this.accountingReportModel = data;\r\n      this.loadingState = ComponentLoadingStates.Complete;\r\n\r\n      this.accountingReportModel.accountingReportByBranchGroups.forEach(group => {\r\n        group.accountingReportEntriesList = group.accountingReportEntriesList.map(entry => ({\r\n          ...entry,\r\n          businessDate: formatDate(entry.businessDate, 'dd/MM/yyyy', 'en-US'),\r\n          transactionDateAndTime: formatDate(entry.transactionDateAndTime, 'dd/MM/yyyy hh:mm a', 'en-US'),\r\n        }));\r\n      });\r\n\r\n      this.accountingReportModel = data;\r\n      this.noDataFound = Object.keys(this.accountingReportModel.accountingReportByBranchGroups).length == 0 ? true : false;\r\n      this.paginationArray = new Array(Object.keys(this.accountingReportModel).length).fill(15);\r\n\r\n      this.reportUser = this.accountingReportModel.reportUser;\r\n      this.reportTime = formatDate(new Date(), 'dd/MM/yyyy hh:mm a', 'en-US');\r\n      this.reportPeriod = `${formatDate(finalReq.startDate, 'dd/MM/yyyy', 'en-US')} - ${formatDate(finalReq.endDate, 'dd/MM/yyyy', 'en-US')}`;\r\n\r\n      this.leftData = {\r\n        'Report User ': `${this.reportUser}`,\r\n        'Report Time': `${this.reportTime}`,\r\n      }\r\n\r\n      this.rightData = {\r\n        'Report Period': `${this.reportPeriod}`,\r\n        'Company': \"Xpress Money\"\r\n      }\r\n\r\n      // Deep copy to preserve original data for search\r\n      this.originalGroupEntries = this.accountingReportModel.accountingReportByBranchGroups.map(group => ({\r\n        ...group,\r\n        accountingReportEntriesList: [...group.accountingReportEntriesList]\r\n      }));\r\n\r\n\r\n    }, error => {\r\n      console.log(error);\r\n    });\r\n  }\r\n\r\n  async handleExport(option: string) {\r\n    this.selectedExportOption = option;\r\n    switch (this.selectedExportOption) {\r\n      case 'excel':\r\n        this.exportToExcel();\r\n        break;\r\n      case 'pdf':\r\n        this.exportToPdf();\r\n        break;\r\n      case 'csv':\r\n        this.exportToCsv();\r\n        break;\r\n      default:\r\n        alert('Please select an export format.');\r\n    }\r\n  }\r\n\r\n  onSearch(text: string) {\r\n    const normalize = (str: any): string =>\r\n      str?.toString()\r\n        .toLowerCase()\r\n        .replace(/,/g, '')\r\n        .replace(/\\s+/g, ' ')\r\n        .replace(/[\\u200B-\\u200D\\uFEFF]/g, '')\r\n        .trim();\r\n\r\n    this.searchText = text;\r\n    const search = normalize(text);\r\n\r\n    if (!this.accountingReportModel?.accountingReportByBranchGroups) return;\r\n\r\n    this.accountingReportModel.accountingReportByBranchGroups.forEach((group, index) => {\r\n      const originalEntries = this.originalGroupEntries[index]?.accountingReportEntriesList || [];\r\n\r\n      if (search) {\r\n        // Filter entries based on search text\r\n        group.accountingReportEntriesList = originalEntries.filter(entry =>\r\n          Object.values(entry).some(value =>\r\n            normalize(value).includes(search)\r\n          )\r\n        );\r\n      } else {\r\n        // Restore original entries\r\n        group.accountingReportEntriesList = [...originalEntries];\r\n      }\r\n\r\n      const gridApi = this.gridApis[index];\r\n      if (gridApi) {\r\n        gridApi.setRowData(group.accountingReportEntriesList);\r\n\r\n        // Reset pagination to page 1\r\n        if (gridApi.paginationGoToFirstPage) {\r\n          gridApi.paginationGoToFirstPage();\r\n        }\r\n\r\n        // Optional: reset selected page size if you have dynamic pageSize\r\n        if (gridApi.paginationSetPageSize) {\r\n          gridApi.paginationSetPageSize(this.pageSize);\r\n        }\r\n      }\r\n    });\r\n\r\n\r\n\r\n  }\r\n\r\n  onGridReady(params: GridReadyEvent, id: number) {\r\n    // this.gridAPi = params.api;\r\n    this.gridColumnApi = params.columnApi;\r\n    this.gridApis[id] = params.api;\r\n\r\n    // Auto size all columns after grid data is loaded\r\n    setTimeout(() => this.autoSizeAllColumns(), 100);\r\n  }\r\n\r\n  onGridSizeChanged(params: any) {\r\n    this.autoSizeAllColumns();\r\n  }\r\n\r\n  autoSizeAllColumns(skipHeader: boolean = false) {\r\n    if (!this.gridColumnApi) return;\r\n    const allColumnIds: string[] = [];\r\n    this.gridColumnApi.getColumns().forEach((column: any) => {\r\n      allColumnIds.push(column.getId());\r\n    });\r\n    this.gridColumnApi.autoSizeColumns(allColumnIds, skipHeader);\r\n  }\r\n\r\n  formatNumber(params: any): string {\r\n    if (params.value == null) return '';\r\n\r\n    const field = params.colDef.field;\r\n\r\n    if (field === 'settlementRate') {\r\n      return Number(params.value).toFixed(8);\r\n    }\r\n\r\n    return Number(params.value).toFixed(3);\r\n  }\r\n\r\n  private exportToPdf() {\r\n    if (!this.accountingReportModel.accountingReportByBranchGroups?.length) return;\r\n    const title = 'Accounting Report';\r\n    const fileName = 'Accounting-Report.pdf';\r\n\r\n    // Metadata\r\n    const metadata: [string, string][] = [\r\n      ['Report User:', this.reportUser],\r\n      ['Report Time:', this.reportTime],\r\n      ['Report Period:', this.reportPeriod],\r\n    ];\r\n\r\n    const doc = new jsPDF({ orientation: 'landscape', unit: 'mm', format: [700, 210] });\r\n\r\n    const logoWidth = 38.4, logoHeight = 17.5, logoX = 15, logoY = 8;\r\n    const pageWidth = doc.internal.pageSize.width;\r\n    const titleY = 18;\r\n\r\n    // Logo\r\n    if (this.exportService['logoBase64']) {\r\n      doc.addImage(this.exportService['logoBase64'], 'PNG', logoX, logoY, logoWidth, logoHeight);\r\n    }\r\n\r\n    // Title\r\n    doc.setFontSize(15);\r\n    doc.setFont('helvetica', 'bold');\r\n    doc.text(title, pageWidth / 2, titleY, { align: 'center' });\r\n\r\n    let currentY = titleY + 14;\r\n\r\n    // Metadata\r\n    doc.setFontSize(10);\r\n    metadata.forEach(([label, value], i) => {\r\n      const y = currentY + i * 7;\r\n      doc.setFont('helvetica', 'bold');\r\n      doc.text(label, 15, y);\r\n      const labelWidth = doc.getTextWidth(label + ' ');\r\n      doc.setFont('helvetica', 'normal');\r\n      doc.text(value ?? '', 15 + labelWidth, y);\r\n    });\r\n    currentY += metadata.length * 7 + 5;\r\n\r\n    // Groups\r\n    this.accountingReportModel.accountingReportByBranchGroups.forEach((group, index) => {\r\n      // if (index > 0) doc.addPage();\r\n\r\n      doc.setFontSize(10);\r\n      doc.setFont('helvetica', 'bold');\r\n\r\n      const branchText = `Branch (Name & Code): ${group.branchNameAndCode}`;\r\n      doc.text(branchText, 15, currentY);\r\n\r\n      // measure width of branch text\r\n      const branchWidth = doc.getTextWidth(branchText);\r\n\r\n      // add small gap (e.g., 10mm) before printing subgroup\r\n      doc.text(`Sub Group: ${group.subGroupColumn}`, 15 + branchWidth + 10, currentY);\r\n      currentY += 5;\r\n\r\n      // Table\r\n      const { headers, rows } = this.prepareAccountingTable(group.accountingReportEntriesList);\r\n\r\n       (doc as any).autoTable( {\r\n        head: [headers],\r\n        body: rows,\r\n        startY: currentY,\r\n        theme: 'grid',\r\n        headStyles: {\r\n          fillColor: [220, 220, 220], textColor: 0,\r\n          fontStyle: 'bold', fontSize: 9, halign: 'center',\r\n        },\r\n        bodyStyles: { fontSize: 8, fillColor: [255, 255, 255], textColor: [0, 0, 0] },\r\n        styles: { cellPadding: 2, overflow: 'linebreak', minCellHeight: 6 },\r\n      });\r\n\r\n      currentY = (doc as any).lastAutoTable.finalY + 10; // move cursor after table\r\n    });\r\n\r\n    doc.save(fileName);\r\n  }\r\n\r\n  private exportToExcel() {\r\n    if (!this.accountingReportModel.accountingReportByBranchGroups?.length) return;\r\n    const title = 'Accounting Report';\r\n    const fileName = 'Accounting-Report.xlsx';\r\n\r\n    const workbook = new ExcelJS.Workbook();\r\n    const worksheet = workbook.addWorksheet('Accounting Report'); // ✅ single sheet\r\n\r\n    let currentRow = 1;\r\n\r\n    // ✅ Add logo\r\n    if (this.exportService.logoBase64) {\r\n      const base64Data = this.exportService.logoBase64.replace(/^data:image\\/\\w+;base64,/, '');\r\n      const imageId = workbook.addImage({\r\n        base64: base64Data,\r\n        extension: 'png',\r\n      });\r\n\r\n      worksheet.addImage(imageId, {\r\n        tl: { col: 0, row: 0 }, // A1\r\n        ext: { width: 145, height: 66 },\r\n        editAs: 'oneCell',\r\n      });\r\n    }\r\n\r\n    // ✅ Title\r\n    const titleRow = worksheet.getRow(currentRow);\r\n    titleRow.getCell(6).value = title; // Column F\r\n    titleRow.getCell(6).font = { bold: true, size: 16 };\r\n    titleRow.getCell(6).alignment = { vertical: 'middle', horizontal: 'left' };\r\n    worksheet.mergeCells(`F${currentRow}:J${currentRow}`);\r\n\r\n\r\n    currentRow += 3;\r\n\r\n    // ✅ Metadata\r\n    const metadata: [string, string][] = [\r\n      ['Report User', this.reportUser],\r\n      ['Report Time', this.reportTime],\r\n      ['Report Period', this.reportPeriod],\r\n    ];\r\n    metadata.forEach(([label, value]) => {\r\n      const row = worksheet.getRow(currentRow++);\r\n      row.getCell(1).value = {\r\n        richText: [\r\n          { text: `${label}: `, font: { bold: true } },\r\n          { text: value ?? '', font: { bold: false } }\r\n        ]\r\n      };\r\n    });\r\n\r\n    worksheet.addRow([]);\r\n    currentRow++;\r\n\r\n    // ✅ Loop through all groups in one sheet\r\n    this.accountingReportModel.accountingReportByBranchGroups.forEach((group) => {\r\n      // Branch + SubGroup on same line\r\n      const branchRow = worksheet.getRow(currentRow++);\r\n      branchRow.getCell(1).value = {\r\n        richText: [\r\n          { text: 'Branch (Name & Code): ', font: { bold: true } },\r\n          { text: group.branchNameAndCode ?? '', font: { bold: false } },\r\n          { text: '    Sub Group: ', font: { bold: true } }, // ← spaces ensure a gap\r\n          { text: group.subGroupColumn ?? '', font: { bold: false } }\r\n        ]\r\n      };\r\n\r\n\r\n      worksheet.addRow([]);\r\n      currentRow++;\r\n\r\n      // Table headers\r\n      const { headers, rows } = this.prepareAccountingTable(group.accountingReportEntriesList);\r\n      const headerRow = worksheet.getRow(currentRow++);\r\n      headers.forEach((header, i) => {\r\n        const cell = headerRow.getCell(i + 1);\r\n        cell.value = header;\r\n        cell.font = { bold: true };\r\n        cell.fill = { type: 'pattern', pattern: 'solid', fgColor: { argb: 'D9D9D9' } };\r\n        cell.alignment = { vertical: 'middle', horizontal: 'center' };\r\n        cell.border = {\r\n          top: { style: 'thin' }, bottom: { style: 'thin' },\r\n          left: { style: 'thin' }, right: { style: 'thin' }\r\n        };\r\n      });\r\n\r\n      // Table rows\r\n      rows.forEach(r => {\r\n        const row = worksheet.getRow(currentRow++);\r\n        r.forEach((val, i) => {\r\n          const cell = row.getCell(i + 1);\r\n          cell.value = val;\r\n          cell.border = {\r\n            top: { style: 'thin' }, bottom: { style: 'thin' },\r\n            left: { style: 'thin' }, right: { style: 'thin' }\r\n          };\r\n        });\r\n      });\r\n\r\n      worksheet.addRow([]);\r\n      currentRow++;\r\n    });\r\n\r\n    // ✅ Auto column widths (after all groups processed)\r\n    const allHeaders = this.prepareAccountingTable(\r\n      this.accountingReportModel.accountingReportByBranchGroups[0]?.accountingReportEntriesList || []\r\n    ).headers;\r\n\r\n    allHeaders.forEach((header, i) => {\r\n      let maxLength = header.length;\r\n      this.accountingReportModel.accountingReportByBranchGroups.forEach(group => {\r\n        group.accountingReportEntriesList.forEach(r => {\r\n          const val = r[i] ? r[i].toString() : '';\r\n          maxLength = Math.max(maxLength, val.length);\r\n        });\r\n      });\r\n      worksheet.getColumn(i + 1).width = maxLength + 2;\r\n    });\r\n\r\n    // ✅ Save\r\n    workbook.xlsx.writeBuffer().then(buffer => {\r\n      const blob = new Blob([buffer], {\r\n        type: 'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet'\r\n      });\r\n      FileSaver.saveAs(blob, fileName);\r\n    });\r\n  }\r\n\r\n\r\n  private prepareAccountingTable(data: any[]): { headers: string[], rows: any[][] } {\r\n    const currencyFields = ['amountPaid', 'serviceFee', 'tax', 'principleSendAmount', 'clientSettlementInSCcy'];\r\n    const headers = ['Sr No', ...this.columnDefs.map(c => c.headerName)];\r\n    const rows = data.map((row, i) => {\r\n      return [\r\n        i + 1,\r\n        ...this.columnDefs.map(col => {\r\n          let val = row[col.field];\r\n          if (val == null) return '';\r\n          if (currencyFields.includes(col.field)) return parseFloat(val).toFixed(3);\r\n          if (col.field === 'settlementRate') return parseFloat(val).toFixed(8);\r\n          return val;\r\n        })\r\n      ];\r\n    });\r\n    return { headers, rows };\r\n  }\r\n\r\n\r\n  private exportToCsv() {\r\n    if (!this.accountingReportModel.accountingReportByBranchGroups?.length) return;\r\n    const fileName = 'Accounting-Report.csv';\r\n    const rows: string[] = [];\r\n\r\n    // Metadata\r\n    rows.push('Report Title: Accounting Report');\r\n    rows.push('');\r\n    rows.push(`Report User: ${this.reportUser}`);\r\n    rows.push(`Report Time: ${this.reportTime}`);\r\n    rows.push(`Report Period: ${this.reportPeriod}`);\r\n    rows.push(`Company: Xpress Money`);\r\n    rows.push('');\r\n\r\n    this.accountingReportModel.accountingReportByBranchGroups.forEach(group => {\r\n      rows.push(`Branch (Name & Code): ${group.branchNameAndCode} Sub Group: ${group.subGroupColumn}`);\r\n      rows.push(this.columnDefs.map(col => `\"${col.headerName}\"`).join(','));\r\n\r\n      group.accountingReportEntriesList.forEach(entry => {\r\n        const row = this.columnDefs.map(col => {\r\n          const val = entry[col.field];\r\n          if (val == null) return '';\r\n          if (['amountPaid', 'serviceFee', 'tax', 'principleSendAmount', 'clientSettlementInSCcy'].includes(col.field)) {\r\n            return parseFloat(val).toFixed(3);\r\n          }\r\n          if (col.field === 'settlementRate') {\r\n            return parseFloat(val).toFixed(8);\r\n          }\r\n          return `\"${val}\"`;\r\n        }).join(',');\r\n        rows.push(row);\r\n      });\r\n\r\n      rows.push('');\r\n    });\r\n\r\n    const blob = new Blob([rows.join('\\n')], { type: 'text/csv;charset=utf-8;' });\r\n    const link = document.createElement('a');\r\n    link.href = URL.createObjectURL(blob);\r\n    link.setAttribute('download', fileName);\r\n    document.body.appendChild(link);\r\n    link.click();\r\n    document.body.removeChild(link);\r\n  }\r\n\r\n\r\n\r\n  getReport(payload: any) {\r\n    const modal = payload?.modal || payload;\r\n\r\n    const req: AccountingReportRequest = {\r\n      startDate: modal.fromDate, // yyyy-MM-dd from the filter\r\n      endDate: modal.toDate,\r\n      sendCountryCode: modal.sendCountry ?? 'ALL',\r\n      recvCountryCode: modal.receiveCountry ?? 'ALL',\r\n      businessPartnerCorrelationID: modal.client ?? 'ALL',\r\n      transactionStatus: modal.transactionStatus.join(\",\"),\r\n      payoutCurrency: modal.currency ?? 'ALL',\r\n      transactionType: modal.product ?? 'ALL',\r\n      branchCode: modal.branch ?? 'ALL',\r\n      companyCode: 'ALL' // or 'BH' if your API requires it specifically\r\n    };\r\n\r\n    this.getAccountingReport(req);\r\n  }\r\n\r\n\r\n\r\n}\r\n","<lib-search-filter [ReportName]=\"ReportName\" (searchClicked)=\"getReport($event)\"></lib-search-filter>\r\n\r\n<app-loader class=\"\" *ngIf=\"loadingState == ComponentLoadingState.Loading\"></app-loader>\r\n\r\n<div *ngIf=\"accountingReportModel!=undefined\">\r\n\r\n  <lib-metadata [reportName]=\"ReportName\" [showmetaDataOne]=\"true\" [showmetaDataTwo]=\"true\" [metaDataOne]=\"leftData\"\r\n    [metaDataTwo]=\"rightData\" (exportEvent)=\"handleExport($event)\" (searchEvent)=\"onSearch($event)\"></lib-metadata>\r\n\r\n  <ngb-accordion #acc=\"ngbAccordion\" [closeOthers]=\"false\" [activeIds]=\"'panel-0'\">\r\n    <ng-container *ngFor=\"let group of accountingReportModel?.accountingReportByBranchGroups; let i = index\">\r\n      <ngb-panel [id]=\"'panel-' + i\">\r\n\r\n        <ng-template ngbPanelTitle>\r\n          <label class=\"title-stack line-1\">\r\n            {{ group.branchNameAndCode }} → {{ group.subGroupColumn }}\r\n          </label>\r\n        </ng-template>\r\n\r\n        <ng-template ngbPanelContent>\r\n          <div style=\"position: relative;\">\r\n            <lib-page-size-selector [totalEntries]=\"group.accountingReportEntriesList.length\" [defaultSize]=\"'15'\"\r\n              [gridApi]=\"gridApis[i]\">\r\n            </lib-page-size-selector>\r\n\r\n            <ag-grid-angular class=\"ag-theme-alpine compact-grid grid-size\" style=\"width: 100%;height: 370px;\"\r\n              [columnDefs]=\"columnDefs\" [defaultColDef]=\"defaultColDef\" [rowData]=\"group.accountingReportEntriesList\"\r\n              [rowHeight]=\"20\" [headerHeight]=\"24\" [pagination]=\"true\" [paginationPageSize]=\"paginationArray[i]\"\r\n              (gridReady)=\"onGridReady($event,i)\" (gridSizeChanged)=\"onGridSizeChanged($event)\">\r\n            </ag-grid-angular>\r\n          </div>\r\n        </ng-template>\r\n      </ngb-panel>\r\n    </ng-container>\r\n  </ngb-accordion>\r\n\r\n</div>\r\n\r\n<div class=\"alert alert-warning mt-3\" *ngIf=\"noDataFound && loadingState!=ComponentLoadingState.Loading\">\r\n  No Data Found\r\n</div>"]}
485
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"accounting-report.component.js","sourceRoot":"","sources":["../../../../../../projects/reports-lib/src/lib/components/accounting-report/accounting-report.component.ts","../../../../../../projects/reports-lib/src/lib/components/accounting-report/accounting-report.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit } from '@angular/core';\r\nimport { AccountingReportModel } from '../../models/accounting-report/accounting-report-model';\r\nimport { ColDef, ColumnApi, GridApi, GridReadyEvent } from 'ag-grid-community';\r\nimport { ReportService } from '../../services/report.service';\r\nimport { ExportService } from '../../shared/export.service';\r\nimport { formatDate } from '@angular/common';\r\nimport { ComponentLoadingStates } from '../../models/component-loading-states';\r\nimport { AccountingReportBranchGroup } from '../../models/accounting-report/accounting-report-branch-group';\r\nimport jsPDF from 'jspdf';\r\nimport 'jspdf-autotable';\r\nimport * as ExcelJS from 'exceljs';\r\nimport * as FileSaver from 'file-saver';\r\n\r\ndeclare module 'jspdf' {\r\n  interface jsPDF {\r\n    autoTable: (options: any) => jsPDF;\r\n  }\r\n}\r\n\r\nexport interface AccountingReportRequest {\r\n  startDate: string;\r\n  endDate: string;\r\n  sendCountryCode: string;\r\n  recvCountryCode: string;\r\n  businessPartnerCorrelationID: string;\r\n  transactionStatus: string;\r\n  payoutCurrency: string;\r\n  transactionType: string;\r\n  branchCode: string;\r\n  companyCode: string;\r\n}\r\n\r\n@Component({\r\n  selector: 'lib-accounting-report',\r\n  templateUrl: './accounting-report.component.html',\r\n  styleUrls: ['./accounting-report.component.scss']\r\n})\r\nexport class AccountingReportComponent implements OnInit {\r\n\r\n  ReportName: string = \"Accounting\";\r\n  reportUser: any;\r\n  reportTime: any;\r\n  reportPeriod: any;\r\n  branchNameAndCode: any;\r\n  subGroupColumn: any;\r\n  ComponentLoadingState = ComponentLoadingStates;\r\n  loadingState: ComponentLoadingStates = ComponentLoadingStates.Complete;\r\n  noDataFound: boolean = false;\r\n\r\n  leftData: Record<string, string>;\r\n  rightData: Record<string, string>;\r\n\r\n  searchText: string = '';\r\n  rowData = [];\r\n  accountingReportModel: AccountingReportModel;\r\n  pageSize: number = 15;\r\n\r\n  selectedExportOption: string = 'excel';\r\n  exportFormats = [{ formatName: \"Excel\", code: 'excel' }, { formatName: \"PDF\", code: 'pdf' }, { formatName: \"CSV\", code: 'csv' }]\r\n\r\n  defaultColDef: ColDef = {\r\n    resizable: true,\r\n    sortable: false,\r\n    minWidth: 40,\r\n    suppressSizeToFit: false,\r\n    cellStyle: { userSelect: 'text', 'line-height': '1.2', 'white-space': 'normal', 'word-break': 'normal', 'overflow-wrap': 'break-word' },\r\n\r\n    //  Header wrapping\r\n    wrapHeaderText: true,\r\n    autoHeaderHeight: true,\r\n\r\n    //  Cell wrapping\r\n    wrapText: true,\r\n    autoHeight: true\r\n  };\r\n\r\n  columnDefs: ColDef[] = [\r\n    { headerName: 'BusinessDate', field: 'businessDate', tooltipField: 'businessDate' },\r\n    { headerName: 'TxnDate&Time', field: 'transactionDateAndTime', tooltipField: 'transactionDateAndTime', minWidth: 110, },\r\n    { headerName: 'Transaction Number', field: 'transactionNumber', tooltipField: 'transactionNumber' },\r\n    { headerName: 'SendClient', field: 'sendClient', tooltipField: 'sendClient' },\r\n    { headerName: 'Principle SendClient (If Applicable)', field: 'principleSendClient', tooltipField: 'principleSendClient' },\r\n    { headerName: 'ReceiveClient', field: 'receiveClient', tooltipField: 'receiveClient' },\r\n    { headerName: 'Principle ReceiveClient (If Applicable)', field: 'principleReceiveClient', tooltipField: 'principleReceiveClient' },\r\n    { headerName: 'ReceiveCcy', field: 'receiveCurrency', tooltipField: 'receiveCurrency' },\r\n    { headerName: 'AmountPaid', field: 'amountPaid', tooltipField: 'amountPaid', cellClass: 'ag-right-aligned-cell' },\r\n    { headerName: 'SendCcy', field: 'sendCurrency', tooltipField: 'sendCurrency', },\r\n    { headerName: 'ServiceFee', field: 'serviceFee', tooltipField: 'serviceFee', cellClass: 'ag-right-aligned-cell' },\r\n    { headerName: 'Tax', field: 'tax', tooltipField: 'tax', cellClass: 'ag-right-aligned-cell' },\r\n    { headerName: 'PrincipleSend Amount', field: 'principleSendAmount', tooltipField: 'principleSendAmount', cellClass: 'ag-right-aligned-cell' },\r\n    { headerName: 'Transaction Status', field: 'transactionStatus', tooltipField: 'transactionStatus' },\r\n    { headerName: 'SettlementCcy', field: 'settlementCurrency', tooltipField: 'settlementCurrency', cellClass: 'ag-right-aligned-cell' },\r\n    { headerName: 'ClientSettl (in SCcy)', field: 'clientSettlementInSCcy', tooltipField: 'clientSettlementInSCcy', cellClass: 'ag-right-aligned-cell' },\r\n    { headerName: 'ClientSettl (in USD)', field: 'clientSettlementInUSD', tooltipField: 'clientSettlementInUSD', cellClass: 'ag-right-aligned-cell' },\r\n    { headerName: 'ShareType', field: 'shareType', tooltipField: 'shareType' },\r\n    { headerName: 'ShareValue', field: 'shareValue', tooltipField: 'shareValue', cellClass: 'ag-right-aligned-cell' },\r\n    { headerName: 'Send/Receive FeeCcy', field: 'sendReceiveFeeCcy', tooltipField: 'sendReceiveFeeCcy' },\r\n    { headerName: 'ShareAmt (in USD)', field: 'shareAmountInUSD', tooltipField: 'shareAmountInUSD', cellClass: 'ag-right-aligned-cell' },\r\n    { headerName: 'Settlement Rate', field: 'settlementRate', tooltipField: 'settlementRate', cellClass: 'ag-right-aligned-cell' },\r\n  ];\r\n\r\n\r\n  gridApis: GridApi[] = [];\r\n  gridColumnApis: ColumnApi[] = [];\r\n\r\n  paginationArray: any[];\r\n  ezremitUser: boolean = false;\r\n  originalGroupEntries: AccountingReportBranchGroup[] = [];\r\n\r\n  constructor(private reportService: ReportService, private exportService: ExportService) { }\r\n\r\n  ngOnInit(): void {\r\n    const ezremitusername = sessionStorage.getItem('ezremitusername');\r\n    if (ezremitusername) {\r\n      this.ezremitUser = true;\r\n    }\r\n  }\r\n\r\n  public getAccountingReport(request?: AccountingReportRequest) {\r\n    this.loadingState = ComponentLoadingStates.Loading;\r\n    this.accountingReportModel = undefined;\r\n    this.branchNameAndCode = undefined;\r\n    this.subGroupColumn = undefined;\r\n    const finalReq = request;\r\n\r\n    this.reportService.getAccountingReport(finalReq).subscribe(data => {\r\n      this.accountingReportModel = data;\r\n      this.loadingState = ComponentLoadingStates.Complete;\r\n\r\n      console.log(this.accountingReportModel);\r\n\r\n      this.accountingReportModel.accountingReportByBranchGroups.forEach(group => {\r\n        group.sendTransactions.entries = group.sendTransactions.entries.map(entry => ({\r\n          ...entry,\r\n          businessDate: formatDate(entry.businessDate, 'dd/MM/yyyy', 'en-US'),\r\n          transactionDateAndTime: formatDate(entry.transactionDateAndTime, 'dd/MM/yyyy hh:mm a', 'en-US'),\r\n        }));\r\n\r\n        group.receiveTransactions.entries = group.receiveTransactions.entries.map(entry => ({\r\n          ...entry,\r\n          businessDate: formatDate(entry.businessDate, 'dd/MM/yyyy', 'en-US'),\r\n          transactionDateAndTime: formatDate(entry.transactionDateAndTime, 'dd/MM/yyyy hh:mm a', 'en-US'),\r\n        }));\r\n      });\r\n\r\n\r\n      this.accountingReportModel = data;\r\n      this.noDataFound = Object.keys(this.accountingReportModel.accountingReportByBranchGroups).length == 0 ? true : false;\r\n      const branchCount = this.accountingReportModel.accountingReportByBranchGroups.length;\r\n      this.paginationArray = new Array(branchCount * 2).fill(15);\r\n\r\n\r\n      this.reportUser = this.accountingReportModel.reportUser;\r\n      this.reportTime = formatDate(new Date(), 'dd/MM/yyyy hh:mm a', 'en-US');\r\n      this.reportPeriod = `${formatDate(finalReq.startDate, 'dd/MM/yyyy', 'en-US')} - ${formatDate(finalReq.endDate, 'dd/MM/yyyy', 'en-US')}`;\r\n\r\n      this.leftData = {\r\n        'Report User ': `${this.reportUser}`,\r\n        'Report Time': `${this.reportTime}`,\r\n      }\r\n\r\n      this.rightData = {\r\n        'Report Period': `${this.reportPeriod}`,\r\n        'Company': \"Xpress Money\"\r\n      }\r\n\r\n      // Deep copy to preserve original data for search\r\n      this.originalGroupEntries = this.accountingReportModel.accountingReportByBranchGroups.map(group => ({\r\n        ...group,\r\n        sendTransactions: {\r\n          ...group.sendTransactions,\r\n          entries: [...group.sendTransactions.entries]\r\n        },\r\n        receiveTransactions: {\r\n          ...group.receiveTransactions,\r\n          entries: [...group.receiveTransactions.entries]\r\n        }\r\n      }));\r\n\r\n\r\n    }, error => {\r\n      console.log(error);\r\n    });\r\n  }\r\n\r\n  async handleExport(option: string) {\r\n    this.selectedExportOption = option;\r\n    switch (this.selectedExportOption) {\r\n      case 'excel':\r\n        this.exportToExcel();\r\n        break;\r\n      case 'pdf':\r\n        this.exportToPdf();\r\n        break;\r\n      case 'csv':\r\n        this.exportToCsv();\r\n        break;\r\n      default:\r\n        alert('Please select an export format.');\r\n    }\r\n  }\r\n\r\n  onSearch(text: string) {\r\n    const normalize = (str: any): string =>\r\n      str?.toString()\r\n        .toLowerCase()\r\n        .replace(/,/g, '')\r\n        .replace(/\\s+/g, ' ')\r\n        .replace(/[\\u200B-\\u200D\\uFEFF]/g, '')\r\n        .trim();\r\n\r\n    this.searchText = text;\r\n    const search = normalize(text);\r\n\r\n    if (!this.accountingReportModel?.accountingReportByBranchGroups) return;\r\n\r\n    this.accountingReportModel.accountingReportByBranchGroups.forEach((group, index) => {\r\n      const originalSendEntries = this.originalGroupEntries[index]?.sendTransactions.entries || [];\r\n      const originalReceiveEntries = this.originalGroupEntries[index]?.receiveTransactions.entries || [];\r\n\r\n      if (search) {\r\n        group.sendTransactions.entries = originalSendEntries.filter(entry =>\r\n          Object.values(entry).some(value => normalize(value).includes(search))\r\n        );\r\n        group.receiveTransactions.entries = originalReceiveEntries.filter(entry =>\r\n          Object.values(entry).some(value => normalize(value).includes(search))\r\n        );\r\n      } else {\r\n        group.sendTransactions.entries = [...originalSendEntries];\r\n        group.receiveTransactions.entries = [...originalReceiveEntries];\r\n      }\r\n\r\n      // Reset both grids\r\n      [group.sendTransactions.entries, group.receiveTransactions.entries].forEach((entries, idx) => {\r\n        const gridApi = this.gridApis[index * 2 + idx]; // keep separate ids for grids\r\n        if (gridApi) {\r\n          gridApi.setRowData(entries);\r\n          if (gridApi.paginationGoToFirstPage) gridApi.paginationGoToFirstPage();\r\n          if (gridApi.paginationSetPageSize) gridApi.paginationSetPageSize(this.pageSize);\r\n        }\r\n      });\r\n    });\r\n\r\n  }\r\n\r\n  onGridReady(params: GridReadyEvent, id: number) {\r\n    this.gridApis[id] = params.api;\r\n    this.gridColumnApis[id] = params.columnApi;   // ✅ keep per grid\r\n\r\n    setTimeout(() => this.autoSizeAllColumns(id), 100);\r\n  }\r\n\r\n\r\n  onGridSizeChanged(params: any, id: number) {\r\n    this.autoSizeAllColumns(id);\r\n  }\r\n\r\n\r\n  autoSizeAllColumns(id: number, skipHeader: boolean = false) {\r\n    const columnApi = this.gridColumnApis[id];\r\n    if (!columnApi) return;\r\n\r\n    const allColumnIds: string[] = [];\r\n    columnApi.getColumns().forEach((column: any) => {\r\n      allColumnIds.push(column.getId());\r\n    });\r\n\r\n    columnApi.autoSizeColumns(allColumnIds, skipHeader);\r\n  }\r\n\r\n\r\n  formatNumber(params: any): string {\r\n    if (params.value == null) return '';\r\n\r\n    const field = params.colDef.field;\r\n\r\n    if (field === 'settlementRate') {\r\n      return Number(params.value).toFixed(8);\r\n    }\r\n\r\n    return Number(params.value).toFixed(3);\r\n  }\r\n\r\n  private exportToPdf() {\r\n    if (!this.accountingReportModel.accountingReportByBranchGroups?.length) return;\r\n    const title = 'Accounting Report';\r\n    const fileName = 'Accounting-Report.pdf';\r\n\r\n    const metadata: [string, string][] = [\r\n      ['Report User:', this.reportUser],\r\n      ['Report Time:', this.reportTime],\r\n      ['Report Period:', this.reportPeriod],\r\n    ];\r\n\r\n    const doc = new jsPDF({ orientation: 'landscape', unit: 'mm', format: [700, 210] });\r\n\r\n    const logoWidth = 38.4, logoHeight = 17.5, logoX = 15, logoY = 8;\r\n    const pageWidth = doc.internal.pageSize.width;\r\n    const titleY = 18;\r\n\r\n    // Logo\r\n    if (this.exportService['logoBase64']) {\r\n      doc.addImage(this.exportService['logoBase64'], 'PNG', logoX, logoY, logoWidth, logoHeight);\r\n    }\r\n\r\n    // Title\r\n    doc.setFontSize(15);\r\n    doc.setFont('helvetica', 'bold');\r\n    doc.text(title, pageWidth / 2, titleY, { align: 'center' });\r\n\r\n    let currentY = titleY + 14;\r\n\r\n    // Metadata\r\n    doc.setFontSize(10);\r\n    metadata.forEach(([label, value], i) => {\r\n      const y = currentY + i * 7;\r\n      doc.setFont('helvetica', 'bold');\r\n      doc.text(label, 15, y);\r\n      const labelWidth = doc.getTextWidth(label + ' ');\r\n      doc.setFont('helvetica', 'normal');\r\n      doc.text(value ?? '', 15 + labelWidth, y);\r\n    });\r\n    currentY += metadata.length * 7 + 5;\r\n\r\n    // Branches\r\n    this.accountingReportModel.accountingReportByBranchGroups.forEach(group => {\r\n      doc.setFontSize(10);\r\n      doc.setFont('helvetica', 'bold');\r\n\r\n      const branchText = `Branch (Name & Code): ${group.branchNameAndCode}`;\r\n      doc.text(branchText, 15, currentY);\r\n      currentY += 7;\r\n\r\n      // Loop subgroups (Send + Receive)\r\n      [group.sendTransactions, group.receiveTransactions].forEach(subGroup => {\r\n        if (!subGroup.entries?.length) return;\r\n\r\n        doc.setFont('helvetica', 'bold');\r\n        doc.text(`Sub Group: ${subGroup.subGroupName}`, 15, currentY);\r\n        currentY += 5;\r\n\r\n        const { headers, rows } = this.prepareAccountingTable(subGroup.entries);\r\n\r\n        (doc as any).autoTable({\r\n          head: [headers],\r\n          body: rows,\r\n          startY: currentY,\r\n          theme: 'grid',\r\n          headStyles: {\r\n            fillColor: [220, 220, 220], textColor: 0,\r\n            fontStyle: 'bold', fontSize: 9, halign: 'center',\r\n          },\r\n          bodyStyles: { fontSize: 8, fillColor: [255, 255, 255], textColor: [0, 0, 0] },\r\n          styles: { cellPadding: 2, overflow: 'linebreak', minCellHeight: 6 },\r\n        });\r\n\r\n        currentY = (doc as any).lastAutoTable.finalY + 10;\r\n      });\r\n    });\r\n\r\n    doc.save(fileName);\r\n  }\r\n\r\n  private exportToExcel() {\r\n    if (!this.accountingReportModel.accountingReportByBranchGroups?.length) return;\r\n    const title = 'Accounting Report';\r\n    const fileName = 'Accounting-Report.xlsx';\r\n\r\n    const workbook = new ExcelJS.Workbook();\r\n    const worksheet = workbook.addWorksheet('Accounting Report');\r\n    let currentRow = 1;\r\n\r\n    // Logo\r\n    if (this.exportService.logoBase64) {\r\n      const base64Data = this.exportService.logoBase64.replace(/^data:image\\/\\w+;base64,/, '');\r\n      const imageId = workbook.addImage({\r\n        base64: base64Data,\r\n        extension: 'png',\r\n      });\r\n      worksheet.addImage(imageId, { tl: { col: 0, row: 0 }, ext: { width: 145, height: 66 }, editAs: 'oneCell' });\r\n    }\r\n\r\n    // Title\r\n    const titleRow = worksheet.getRow(currentRow);\r\n    titleRow.getCell(6).value = title;\r\n    titleRow.getCell(6).font = { bold: true, size: 16 };\r\n    titleRow.getCell(6).alignment = { vertical: 'middle', horizontal: 'left' };\r\n    worksheet.mergeCells(`F${currentRow}:J${currentRow}`);\r\n    currentRow += 3;\r\n\r\n    // Metadata\r\n    const metadata: [string, string][] = [\r\n      ['Report User', this.reportUser],\r\n      ['Report Time', this.reportTime],\r\n      ['Report Period', this.reportPeriod],\r\n    ];\r\n    metadata.forEach(([label, value]) => {\r\n      const row = worksheet.getRow(currentRow++);\r\n      row.getCell(1).value = {\r\n        richText: [\r\n          { text: `${label}: `, font: { bold: true } },\r\n          { text: value ?? '', font: { bold: false } }\r\n        ]\r\n      };\r\n    });\r\n\r\n    worksheet.addRow([]); currentRow++;\r\n\r\n    // Branches\r\n    this.accountingReportModel.accountingReportByBranchGroups.forEach(group => {\r\n      const branchRow = worksheet.getRow(currentRow++);\r\n      branchRow.getCell(1).value = {\r\n        richText: [\r\n          { text: 'Branch (Name & Code): ', font: { bold: true } },\r\n          { text: group.branchNameAndCode ?? '', font: { bold: false } }\r\n        ]\r\n      };\r\n      worksheet.addRow([]); currentRow++;\r\n\r\n      // Loop subgroups\r\n      [group.sendTransactions, group.receiveTransactions].forEach(subGroup => {\r\n        if (!subGroup.entries?.length) return;\r\n\r\n        const subGroupRow = worksheet.getRow(currentRow++);\r\n        subGroupRow.getCell(1).value = {\r\n          richText: [\r\n            { text: 'Sub Group: ', font: { bold: true } },\r\n            { text: subGroup.subGroupName ?? '', font: { bold: false } }\r\n          ]\r\n        };\r\n\r\n        worksheet.addRow([]); currentRow++;\r\n\r\n        // Headers\r\n        const { headers, rows } = this.prepareAccountingTable(subGroup.entries);\r\n        const headerRow = worksheet.getRow(currentRow++);\r\n        headers.forEach((header, i) => {\r\n          const cell = headerRow.getCell(i + 1);\r\n          cell.value = header;\r\n          cell.font = { bold: true };\r\n          cell.fill = { type: 'pattern', pattern: 'solid', fgColor: { argb: 'D9D9D9' } };\r\n          cell.alignment = { vertical: 'middle', horizontal: 'center' };\r\n          cell.border = { top: { style: 'thin' }, bottom: { style: 'thin' }, left: { style: 'thin' }, right: { style: 'thin' } };\r\n        });\r\n\r\n        // Rows\r\n        rows.forEach(r => {\r\n          const row = worksheet.getRow(currentRow++);\r\n          r.forEach((val, i) => {\r\n            const cell = row.getCell(i + 1);\r\n            cell.value = val;\r\n            cell.border = { top: { style: 'thin' }, bottom: { style: 'thin' }, left: { style: 'thin' }, right: { style: 'thin' } };\r\n          });\r\n        });\r\n\r\n        worksheet.addRow([]); currentRow++;\r\n      });\r\n    });\r\n\r\n    // 🔹 Auto-adjust column widths (including Sr No)\r\n    const allHeaders = ['Sr No', ...this.columnDefs.map(c => c.headerName)];\r\n    allHeaders.forEach((header, i) => {\r\n      let maxLength = header.length; // start with header length\r\n\r\n      this.accountingReportModel.accountingReportByBranchGroups.forEach(group => {\r\n        [group.sendTransactions, group.receiveTransactions].forEach(subGroup => {\r\n          subGroup.entries.forEach(entry => {\r\n            // Sr No column (i = 0) is just numbers\r\n            let val = i === 0 ? (subGroup.entries.indexOf(entry) + 1).toString() : (entry[this.columnDefs[i - 1]?.field] ?? '');\r\n            const len = val.toString().length;\r\n            if (len > maxLength) maxLength = len;\r\n          });\r\n        });\r\n      });\r\n\r\n      worksheet.getColumn(i + 1).width = maxLength + 5; // padding\r\n    });\r\n\r\n    workbook.xlsx.writeBuffer().then(buffer => {\r\n      const blob = new Blob([buffer], {\r\n        type: 'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet'\r\n      });\r\n      FileSaver.saveAs(blob, fileName);\r\n    });\r\n  }\r\n\r\n\r\n\r\n\r\n\r\n  private prepareAccountingTable(data: any[]): { headers: string[], rows: any[][] } {\r\n    const currencyFields = ['amountPaid', 'serviceFee', 'tax', 'principleSendAmount', 'clientSettlementInSCcy'];\r\n    const headers = ['Sr No', ...this.columnDefs.map(c => c.headerName)];\r\n\r\n    if (!data || data.length === 0) {\r\n      return { headers, rows: [] }; // ✅ return headers only, empty rows\r\n    }\r\n\r\n    const rows = data.map((row, i) => {\r\n      return [\r\n        i + 1,\r\n        ...this.columnDefs.map(col => {\r\n          let val = row[col.field];\r\n          if (val == null) return '';\r\n          if (currencyFields.includes(col.field)) return parseFloat(val).toFixed(3);\r\n          if (col.field === 'settlementRate') return parseFloat(val).toFixed(8);\r\n          return val;\r\n        })\r\n      ];\r\n    });\r\n\r\n    return { headers, rows };\r\n  }\r\n\r\n  private exportToCsv() {\r\n    if (!this.accountingReportModel.accountingReportByBranchGroups?.length) return;\r\n    const fileName = 'Accounting-Report.csv';\r\n    const rows: string[] = [];\r\n\r\n    rows.push('Report Title: Accounting Report');\r\n    rows.push('');\r\n    rows.push(`Report User: ${this.reportUser}`);\r\n    rows.push(`Report Time: ${this.reportTime}`);\r\n    rows.push(`Report Period: ${this.reportPeriod}`);\r\n    rows.push(`Company: Xpress Money`);\r\n    rows.push('');\r\n\r\n    this.accountingReportModel.accountingReportByBranchGroups.forEach(group => {\r\n      rows.push(`Branch (Name & Code): ${group.branchNameAndCode}`);\r\n\r\n      [group.sendTransactions, group.receiveTransactions].forEach(subGroup => {\r\n        if (!subGroup.entries?.length) return;\r\n\r\n        rows.push(`Sub Group: ${subGroup.subGroupName}`);\r\n\r\n        // 🔹 Add \"Sr No\" at the beginning of headers\r\n        rows.push(['\"Sr No\"', ...this.columnDefs.map(col => `\"${col.headerName}\"`)].join(','));\r\n\r\n        subGroup.entries.forEach((entry, idx) => {\r\n          // 🔹 Add serial number at start of each row\r\n          const row = [\r\n            (idx + 1).toString(),\r\n            ...this.columnDefs.map(col => {\r\n              const val = entry[col.field];\r\n              if (val == null) return '';\r\n              if (['amountPaid', 'serviceFee', 'tax', 'principleSendAmount', 'clientSettlementInSCcy'].includes(col.field)) {\r\n                return parseFloat(val).toFixed(3);\r\n              }\r\n              if (col.field === 'settlementRate') {\r\n                return parseFloat(val).toFixed(8);\r\n              }\r\n              return `\"${val}\"`;\r\n            })\r\n          ].join(',');\r\n          rows.push(row);\r\n        });\r\n\r\n        rows.push('');\r\n      });\r\n    });\r\n\r\n    const blob = new Blob([rows.join('\\n')], { type: 'text/csv;charset=utf-8;' });\r\n    const link = document.createElement('a');\r\n    link.href = URL.createObjectURL(blob);\r\n    link.setAttribute('download', fileName);\r\n    document.body.appendChild(link);\r\n    link.click();\r\n    document.body.removeChild(link);\r\n  }\r\n\r\n\r\n\r\n\r\n\r\n  getReport(payload: any) {\r\n    const modal = payload?.modal || payload;\r\n\r\n    const req: AccountingReportRequest = {\r\n      startDate: modal.fromDate, // yyyy-MM-dd from the filter\r\n      endDate: modal.toDate,\r\n      sendCountryCode: modal.sendCountry ?? 'ALL',\r\n      recvCountryCode: modal.receiveCountry ?? 'ALL',\r\n      businessPartnerCorrelationID: modal.client ?? 'ALL',\r\n      transactionStatus: modal.transactionStatus.join(\",\"),\r\n      payoutCurrency: modal.currency ?? 'ALL',\r\n      transactionType: modal.product ?? 'ALL',\r\n      branchCode: modal.branch ?? 'ALL',\r\n      companyCode: 'ALL' // or 'BH' if your API requires it specifically\r\n    };\r\n\r\n    this.getAccountingReport(req);\r\n  }\r\n\r\n}\r\n","<lib-search-filter [ReportName]=\"ReportName\" (searchClicked)=\"getReport($event)\"></lib-search-filter>\r\n\r\n<app-loader class=\"\" *ngIf=\"loadingState == ComponentLoadingState.Loading\"></app-loader>\r\n\r\n<div *ngIf=\"accountingReportModel!=undefined && accountingReportModel.accountingReportByBranchGroups?.length\">\r\n\r\n  <lib-metadata [reportName]=\"ReportName\" [showmetaDataOne]=\"true\" [showmetaDataTwo]=\"true\" [metaDataOne]=\"leftData\"\r\n    [metaDataTwo]=\"rightData\" (exportEvent)=\"handleExport($event)\" (searchEvent)=\"onSearch($event)\"></lib-metadata>\r\n\r\n  <ngb-accordion #acc=\"ngbAccordion\" [closeOthers]=\"false\" [activeIds]=\"'panel-0'\">\r\n    <ng-container *ngFor=\"let group of accountingReportModel?.accountingReportByBranchGroups; let i = index\">\r\n      <ngb-panel [id]=\"'panel-' + i\">\r\n        <ng-template ngbPanelTitle>\r\n          <label class=\"title-stack line-1\">\r\n            {{ group.branchNameAndCode }}\r\n          </label>\r\n        </ng-template>\r\n\r\n        <ng-template ngbPanelContent>\r\n          <!-- Send Transactions -->\r\n          <div *ngIf=\"group.sendTransactions.entries.length\">\r\n            <h6 class=\"subgroupcolumn\">{{ group.sendTransactions.subGroupName }}</h6>\r\n            <div style=\"position: relative;\">\r\n              <lib-page-size-selector [totalEntries]=\"group.sendTransactions.entries.length\" [defaultSize]=\"'15'\"\r\n                [gridApi]=\"gridApis[i * 2]\">\r\n              </lib-page-size-selector>\r\n\r\n              <ag-grid-angular class=\"ag-theme-alpine compact-grid grid-size\" style=\"width: 100%; height: 370px;\"\r\n                [columnDefs]=\"columnDefs\" [defaultColDef]=\"defaultColDef\" [rowData]=\"group.sendTransactions.entries\"\r\n                [rowHeight]=\"20\" [headerHeight]=\"24\" [pagination]=\"true\" [paginationPageSize]=\"paginationArray[i]\"\r\n                (gridReady)=\"onGridReady($event, i * 2)\" (gridSizeChanged)=\"onGridSizeChanged($event, i * 2)\">\r\n              </ag-grid-angular>\r\n            </div>\r\n          </div>\r\n\r\n          <!-- Receive Transactions -->\r\n          <div *ngIf=\"group.receiveTransactions.entries.length\" class=\"mt-3\">\r\n            <h6 class=\"subgroupcolumn\">{{ group.receiveTransactions.subGroupName }}</h6>\r\n            <div style=\"position: relative;\">\r\n              <lib-page-size-selector [totalEntries]=\"group.receiveTransactions.entries.length\" [defaultSize]=\"'15'\"\r\n                [gridApi]=\"gridApis[i * 2 + 1]\">\r\n              </lib-page-size-selector>\r\n\r\n              <ag-grid-angular class=\"ag-theme-alpine compact-grid grid-size\" style=\"width: 100%; height: 370px;\"\r\n                [columnDefs]=\"columnDefs\" [defaultColDef]=\"defaultColDef\" [rowData]=\"group.receiveTransactions.entries\"\r\n                [rowHeight]=\"20\" [headerHeight]=\"24\" [pagination]=\"true\" [paginationPageSize]=\"paginationArray[i]\"\r\n                (gridReady)=\"onGridReady($event, i * 2 + 1)\" (gridSizeChanged)=\"onGridSizeChanged($event, i * 2)\">\r\n              </ag-grid-angular>\r\n            </div>\r\n          </div>\r\n        </ng-template>\r\n      </ngb-panel>\r\n    </ng-container>\r\n  </ngb-accordion>\r\n\r\n\r\n</div>\r\n\r\n<div class=\"alert alert-warning mt-3\" *ngIf=\"noDataFound && loadingState!=ComponentLoadingState.Loading\">\r\n  No Data found matching your search criteria.\r\n</div>"]}