@sachin9822/reports-lib 0.0.209 → 0.0.211

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.
Files changed (38) hide show
  1. package/esm2020/lib/components/acc-gl-details-enquiry-report/acc-gl-details-enquiry-report.component.mjs +13 -12
  2. package/esm2020/lib/components/accounting-report/accounting-report.component.mjs +4 -3
  3. package/esm2020/lib/components/branch-activity-receive-report/branch-activity-receive-report.component.mjs +1 -1
  4. package/esm2020/lib/components/branch-activity-send-report/branch-activity-send-report.component.mjs +1 -1
  5. package/esm2020/lib/components/branch-activity-send-summary-report/branch-activity-send-summary-report.component.mjs +700 -0
  6. package/esm2020/lib/components/cancellation-transaction-report/cancellation-transaction-report.component.mjs +1 -1
  7. package/esm2020/lib/components/credit-limit-status-enquiry-report/credit-limit-status-enquiry-report.component.mjs +3 -3
  8. package/esm2020/lib/components/funding-report/funding-report.component.mjs +3 -3
  9. package/esm2020/lib/components/revenue-per-transaction-report/revenue-per-transaction-report.component.mjs +4 -3
  10. package/esm2020/lib/components/statement-of-accounts-report/statement-of-accounts-report.component.mjs +3 -3
  11. package/esm2020/lib/components/transaction-enquiry-report/transaction-enquiry-report.component.mjs +1 -1
  12. package/esm2020/lib/components/transaction-monitoring-report/transaction-monitoring-report.component.mjs +311 -0
  13. package/esm2020/lib/components/trial-balance-accounts-report/trial-balance-accounts-report.component.mjs +7 -6
  14. package/esm2020/lib/models/branch-activity-report/branch-activity-send-report.mjs +1 -1
  15. package/esm2020/lib/models/transaction-monitoring-report/transaction-monitoring-report-request-domain-model.mjs +6 -0
  16. package/esm2020/lib/models/transaction-monitoring-report/transaction-monitoring-report.mjs +5 -0
  17. package/esm2020/lib/reports-lib.module.mjs +15 -5
  18. package/esm2020/lib/services/report.service.mjs +62 -4
  19. package/esm2020/lib/shared/export-generic.service.mjs +10 -1
  20. package/esm2020/lib/shared/search-filter/search-filter.component.mjs +525 -189
  21. package/esm2020/public-api.mjs +5 -1
  22. package/fesm2015/sachin9822-reports-lib.mjs +1715 -330
  23. package/fesm2015/sachin9822-reports-lib.mjs.map +1 -1
  24. package/fesm2020/sachin9822-reports-lib.mjs +1721 -329
  25. package/fesm2020/sachin9822-reports-lib.mjs.map +1 -1
  26. package/lib/assets/images/Search.svg +9 -9
  27. package/lib/assets/svg-loaders/blue-tail-spin.svg +31 -31
  28. package/lib/components/branch-activity-send-summary-report/branch-activity-send-summary-report.component.d.ts +78 -0
  29. package/lib/components/transaction-monitoring-report/transaction-monitoring-report.component.d.ts +68 -0
  30. package/lib/components/trial-balance-accounts-report/trial-balance-accounts-report.component.d.ts +1 -1
  31. package/lib/models/branch-activity-report/branch-activity-send-report.d.ts +4 -0
  32. package/lib/models/transaction-monitoring-report/transaction-monitoring-report-request-domain-model.d.ts +13 -0
  33. package/lib/models/transaction-monitoring-report/transaction-monitoring-report.d.ts +23 -0
  34. package/lib/reports-lib.module.d.ts +12 -10
  35. package/lib/services/report.service.d.ts +11 -1
  36. package/lib/shared/search-filter/search-filter.component.d.ts +7 -5
  37. package/package.json +1 -1
  38. package/public-api.d.ts +4 -0
@@ -0,0 +1,700 @@
1
+ import { Component, inject } from '@angular/core';
2
+ import { themeAlpine } from '@ag-grid-community/theming';
3
+ import { ComponentLoadingStates } from '../../models/component-loading-states';
4
+ import { GenericExportService } from '../../shared/export-generic.service';
5
+ // import { formatDate } from '@angular/common';
6
+ // import { ComponentLoadingStates } from 'src/app/models/component-loading-states';
7
+ // import { GenericExportService } from 'src/app/shared/export-generic.service';
8
+ // import { ExportOptions } from 'projects/reports-lib/src/lib/shared/export-generic.service';
9
+ // import { Injectable } from '@angular/core';
10
+ // import jsPDF from 'jspdf';
11
+ // import 'jspdf-autotable';
12
+ import * as ExcelJS from 'exceljs';
13
+ import * as FileSaver from 'file-saver';
14
+ import { formatDate } from '@angular/common';
15
+ import * as i0 from "@angular/core";
16
+ import * as i1 from "../../services/report.service";
17
+ import * as i2 from "ag-grid-angular";
18
+ import * as i3 from "@angular/common";
19
+ import * as i4 from "../../shared/page-size-selector/page-size-selector.component";
20
+ import * as i5 from "../../shared/metadata/metadata.component";
21
+ import * as i6 from "@ng-bootstrap/ng-bootstrap";
22
+ import * as i7 from "../../shared/loader/loader.component";
23
+ import * as i8 from "../../shared/search-filter/search-filter.component";
24
+ export class BranchActivitySendSummaryReportComponent {
25
+ constructor(reportService, ngZone) {
26
+ this.reportService = reportService;
27
+ this.ngZone = ngZone;
28
+ this.dataMap = {};
29
+ this.filteredData = {};
30
+ this.proxyData = {};
31
+ this.selectedExportOption = 'excel';
32
+ this.gridApis = [];
33
+ this.user = "";
34
+ this.ComponentLoadingState = ComponentLoadingStates;
35
+ this.loadingState = ComponentLoadingStates.Loading;
36
+ this.ReportName = "Branch Activity Send Summary";
37
+ this.exportService = inject(GenericExportService);
38
+ this.searchCriteria = [];
39
+ // flags
40
+ this.showMessage = false;
41
+ this.noDataFound = false;
42
+ this.isFormValid = false;
43
+ this.clearSearch = false;
44
+ this.isTotalSummary = false;
45
+ this.columnDefs = [
46
+ {
47
+ field: 'businessDateTime', headerName: 'Business Date', flex: 1, wrapText: true, autoHeight: true, headerClass: 'ag-left-aligned-header', minWidth: 70, width: 70, tooltipField: 'businessDateTime',
48
+ valueFormatter: (params) => {
49
+ const row = params.data;
50
+ if (row && row.payinCCcode === 'Total') {
51
+ return ''; // hide date for total row
52
+ }
53
+ return params.value;
54
+ }
55
+ },
56
+ { field: 'product', headerName: 'Product', flex: 1, wrapText: true, autoHeight: true, minWidth: 80, width: 120, tooltipField: 'product' },
57
+ { field: 'payoutCCcode', headerName: 'Receive Currency', flex: 1, wrapText: true, autoHeight: true, minWidth: 90, width: 110, tooltipField: 'payoutCCcode' },
58
+ { field: 'payoutAmount', headerName: 'Receive Amount', flex: 1, wrapText: true, autoHeight: true, minWidth: 90, maxWidth: 120, cellClass: 'ag-right-aligned-cell compact-cell', tooltipField: 'payoutAmount' },
59
+ { field: 'payinCCcode', headerName: 'Send Currency', flex: 1, wrapText: true, autoHeight: true, minWidth: 90, maxWidth: 90, tooltipField: 'payinCCcode' },
60
+ { field: 'payinAmount', headerName: 'Send Amount', flex: 1, wrapText: true, autoHeight: true, minWidth: 80, maxWidth: 120, cellClass: 'ag-right-aligned-cell compact-cell', tooltipField: 'payinAmount' },
61
+ { field: 'transactionCommissionAmount', headerName: 'Service Fee', flex: 1, wrapText: true, autoHeight: true, minWidth: 90, maxWidth: 100, cellClass: 'ag-right-aligned-cell compact-cell', tooltipField: 'transactionCommissionAmount' },
62
+ { field: 'tax', headerName: 'Tax', flex: 1, wrapText: true, autoHeight: true, minWidth: 80, maxWidth: 100, cellClass: 'ag-right-aligned-cell compact-cell', tooltipField: 'tax' },
63
+ { field: 'totalPayinAmount', headerName: 'Total Send Amount', minWidth: 100, flex: 1, wrapText: true, autoHeight: true, cellClass: 'ag-right-aligned-cell compact-cell', tooltipField: 'totalPayinAmount' },
64
+ { field: 'transactionCount', headerName: 'Transaction Count', flex: 1, wrapText: true, autoHeight: true, minWidth: 80, maxWidth: 100, cellClass: 'ag-right-aligned-cell compact-cell', tooltipField: 'txnCount' },
65
+ { field: 'status', headerName: 'Transaction Status', minWidth: 100, flex: 1, wrapText: true, autoHeight: true, tooltipField: 'status' }
66
+ ];
67
+ this.defaultColDef = {
68
+ sortable: true,
69
+ filter: true,
70
+ resizable: true,
71
+ minwidth: 40,
72
+ wrapHeaderText: true,
73
+ autoHeaderHeight: true,
74
+ suppressSizeToFit: false,
75
+ wrapText: true
76
+ };
77
+ // rowClassRules = {
78
+ // debugger
79
+ // 'total-row': params => params.data?.isTotalRow
80
+ // };
81
+ this.rowClassRules = {
82
+ 'total-row': (params) => {
83
+ console.log('Row Data:', params.data.isTotalRow);
84
+ if (params.data.isTotalRow) {
85
+ return params.data?.isTotalRow;
86
+ }
87
+ }
88
+ };
89
+ this.rowData = [];
90
+ this.reportTheme = themeAlpine.withParams({
91
+ headerFontSize: '10px',
92
+ fontFamily: ['Arial', 'sans-serif'],
93
+ fontSize: '9px'
94
+ });
95
+ }
96
+ ngOnInit() {
97
+ this.loadingState = ComponentLoadingStates.Complete;
98
+ // Check if User is falcon user or fossilUser
99
+ if (sessionStorage.getItem('fossilusername')) {
100
+ this.sysUserId = sessionStorage.getItem('fossilusername');
101
+ }
102
+ else {
103
+ this.sysUserId = sessionStorage.getItem('ezremitusername');
104
+ }
105
+ this.sysUserId = this.sysUserId.replace(/^["'](.*)["']$/, '$1');
106
+ this.user = this.sysUserId;
107
+ console.log("System User Id : " + this.sysUserId);
108
+ }
109
+ filter(text) {
110
+ this.searchText = text;
111
+ if (this.searchText == null) {
112
+ return;
113
+ }
114
+ if (this.searchText?.length === 0) {
115
+ this.filteredData = structuredClone(this.dataMap);
116
+ return;
117
+ }
118
+ this.searchText = this.searchText?.trim()?.toLowerCase();
119
+ for (const [key, entries] of Object.entries(this.proxyData)) {
120
+ const filteredData = entries.filter(entry => Object.values(entry)
121
+ .some(val => {
122
+ let a = val?.toString().toLowerCase();
123
+ if (a == null) {
124
+ return false;
125
+ }
126
+ return a?.search(this.searchText) == -1 ? false : true;
127
+ }));
128
+ this.filteredData[key] = filteredData;
129
+ }
130
+ this.filteredData;
131
+ }
132
+ onGridReady(params, id) {
133
+ params.api.sizeColumnsToFit();
134
+ this.gridColumnApi = params.columnApi;
135
+ this.gridApis[id] = params.api;
136
+ params.columnApi.setColumnVisible('businessDateTime', !this.isTotalSummary);
137
+ params.api.sizeColumnsToFit();
138
+ }
139
+ handleExport(option) {
140
+ this.selectedExportOption = option;
141
+ if (!this.hasAnyGroups()) {
142
+ alert("There is no data to export based on your current filter.");
143
+ return;
144
+ }
145
+ // If no data, do nothing.
146
+ if (!this.filteredData || Object.keys(this.filteredData).length === 0) {
147
+ alert("No data to export");
148
+ return;
149
+ }
150
+ const title = "Branch Activity Send Summary";
151
+ const reportTimeFormatter = this.dateValueFormatter('dd/MM/yyyy hh:mm a');
152
+ const metadata = [
153
+ ['Report Period ', this.fromDate + " - " + this.toDate],
154
+ ['Report User & Time', this.user ? this.user + " @ " + this.reportDate : '' + " @ " + this.reportDate],
155
+ ];
156
+ // --- search criteria ---
157
+ const searchCriteria = this.searchCriteria;
158
+ //const columns = this.columnDefs;
159
+ //exclude Business Date col for Total Summary Report.
160
+ let columns = [...this.columnDefs];
161
+ const summaryReport = this.searchCriteria.find(x => x[0] === 'Summary Report:')?.[1];
162
+ if (summaryReport === 'Total Summary') {
163
+ columns = columns.filter(col => col.field !== 'businessDateTime');
164
+ }
165
+ // const data = this.dataMap;
166
+ const cleanedData = {};
167
+ Object.keys(this.dataMap).forEach(key => {
168
+ cleanedData[key] = this.dataMap[key].map(row => {
169
+ if (row.isTotalRow) {
170
+ return {
171
+ ...row,
172
+ businessDateTime: '',
173
+ product: '',
174
+ receiveCurrency: '',
175
+ receiveAmount: ''
176
+ };
177
+ }
178
+ return row;
179
+ });
180
+ });
181
+ const data = cleanedData;
182
+ const options = {
183
+ currencyFields: [
184
+ 'payoutAmount', 'payinAmount', 'transactionCommissionAmount', 'tax', 'totalPayinAmount'
185
+ ],
186
+ // specify all date fields expected
187
+ dateFields: [],
188
+ dateFieldFormats: {
189
+ txnDateAndTime: 'dd/MM/yyyy hh:mm a',
190
+ cancellationBranchDateTime: 'dd/MM/yyyy HH:mm',
191
+ cancellationBusinessDate: 'dd/MM/yyyy'
192
+ },
193
+ specialDecimalFields: {
194
+ rate: 8 // future field with 8 decimal places
195
+ },
196
+ groupByKey: true
197
+ };
198
+ switch (this.selectedExportOption) {
199
+ case 'excel':
200
+ this.exportToExcel({ title, metadata, searchCriteria, columns, data, options });
201
+ break;
202
+ case 'pdf':
203
+ this.exportService.exportToPdf({ title, metadata, searchCriteria, columns, data, options });
204
+ break;
205
+ case 'csv':
206
+ this.exportService.exportToCsv({ title, metadata, searchCriteria, columns, data, options });
207
+ break;
208
+ default:
209
+ alert("Please select an export format.");
210
+ }
211
+ }
212
+ async exportToExcel({ title, metadata, searchCriteria, columns, data, options = {} }) {
213
+ const workbook = new ExcelJS.Workbook();
214
+ const worksheet = workbook.addWorksheet(title);
215
+ // ===================== PRE CALC =====================
216
+ const headerLabels = ['Sr No', ...columns.map(col => col.headerName || col.field)];
217
+ const totalCols = headerLabels.length;
218
+ const titleStartCol = 4;
219
+ const titleColLetter = String.fromCharCode(64 + titleStartCol);
220
+ const titleMergeEnd = String.fromCharCode(64 + totalCols);
221
+ // ===================== LOGO =====================
222
+ if (this.logoBase64) {
223
+ const base64Data = this.logoBase64.replace(/^data:image\/\w+;base64,/, '');
224
+ const imageId = workbook.addImage({
225
+ base64: base64Data,
226
+ extension: 'png',
227
+ });
228
+ worksheet.addImage(imageId, {
229
+ tl: { col: 0, row: 0 },
230
+ ext: { width: 145, height: 66 }
231
+ });
232
+ worksheet.getRow(1).height = 24;
233
+ worksheet.getRow(2).height = 22;
234
+ worksheet.getRow(3).height = 22;
235
+ }
236
+ // ===================== TITLE =====================
237
+ worksheet.mergeCells(`${titleColLetter}1:${titleMergeEnd}1`);
238
+ const titleCell = worksheet.getRow(1).getCell(titleStartCol);
239
+ titleCell.value = title;
240
+ titleCell.font = { bold: true, size: 16 };
241
+ titleCell.alignment = { vertical: 'middle', horizontal: 'left' };
242
+ // ===================== METADATA =====================
243
+ let metaRowStart = 4;
244
+ metadata.forEach(([label, value], idx) => {
245
+ const row = worksheet.getRow(metaRowStart + idx);
246
+ row.getCell(1).value = {
247
+ richText: [
248
+ { text: `${label} : `, font: { bold: true } },
249
+ { text: value ?? '', font: { bold: false } }
250
+ ]
251
+ };
252
+ worksheet.mergeCells(`A${row.number}:${titleMergeEnd}${row.number}`);
253
+ });
254
+ let currentRow = metaRowStart + metadata.length;
255
+ worksheet.getRow(++currentRow).height = 6;
256
+ currentRow++;
257
+ // ===================== SEARCH CRITERIA =====================
258
+ worksheet.mergeCells(currentRow, 1, currentRow, 6);
259
+ worksheet.getCell(currentRow, 1).value = 'Search Criteria:-';
260
+ worksheet.getCell(currentRow, 1).font = { bold: true };
261
+ currentRow += 2;
262
+ for (let i = 0; i < searchCriteria.length; i += 2) {
263
+ const left = searchCriteria[i];
264
+ const right = searchCriteria[i + 1];
265
+ const row = worksheet.getRow(currentRow++);
266
+ worksheet.mergeCells(row.number, 1, row.number, 3);
267
+ row.getCell(1).value = {
268
+ richText: [
269
+ { text: (left?.[0] ?? '') + ' ', font: { bold: true } },
270
+ { text: left?.[1] ?? '' }
271
+ ]
272
+ };
273
+ row.getCell(1).alignment = { wrapText: true, vertical: 'middle' };
274
+ if (right) {
275
+ worksheet.mergeCells(row.number, 4, row.number, 6);
276
+ row.getCell(4).value = {
277
+ richText: [
278
+ { text: (right?.[0] ?? '') + ' ', font: { bold: true } },
279
+ { text: right?.[1] ?? '' }
280
+ ]
281
+ };
282
+ row.getCell(4).alignment = { wrapText: true, vertical: 'middle' };
283
+ }
284
+ }
285
+ currentRow++;
286
+ // ===================== HEADER ROW =====================
287
+ const headerRow = worksheet.getRow(currentRow++);
288
+ headerLabels.forEach((header, i) => {
289
+ const cell = headerRow.getCell(i + 1);
290
+ cell.value = header;
291
+ cell.font = { bold: true };
292
+ cell.fill = {
293
+ type: 'pattern',
294
+ pattern: 'solid',
295
+ fgColor: { argb: 'D9D9D9' }
296
+ };
297
+ cell.alignment = { vertical: 'middle', horizontal: 'center' };
298
+ cell.border = {
299
+ top: { style: 'thin' },
300
+ bottom: { style: 'thin' },
301
+ left: { style: 'thin' },
302
+ right: { style: 'thin' }
303
+ };
304
+ });
305
+ headerRow.eachCell((cell) => {
306
+ if (cell.value === 'Transaction Count') {
307
+ cell.value = 'Transaction\nCount';
308
+ cell.alignment = {
309
+ horizontal: 'center',
310
+ vertical: 'middle',
311
+ wrapText: true
312
+ };
313
+ }
314
+ });
315
+ // ===================== DATA SECTION =====================
316
+ let rowIdx = currentRow;
317
+ let serialNumber = 1;
318
+ if (options.groupByKey && !Array.isArray(data)) {
319
+ for (const [group, items] of Object.entries(data)) {
320
+ const groupRow = worksheet.getRow(rowIdx++);
321
+ groupRow.getCell(1).value = group;
322
+ groupRow.font = { bold: true };
323
+ worksheet.mergeCells(`A${groupRow.number}:${titleMergeEnd}${groupRow.number}`);
324
+ items.forEach((item) => {
325
+ const rowData = this.prepareTableRows([item], columns, options)[0];
326
+ const dataRow = worksheet.getRow(rowIdx++);
327
+ const fullRow = [
328
+ !item?.isTotalRow ? serialNumber++ : '',
329
+ ...rowData
330
+ ];
331
+ fullRow.forEach((val, cIdx) => {
332
+ const cell = dataRow.getCell(cIdx + 1);
333
+ // cell.value = val;
334
+ //added by bharati for
335
+ const field = columns[cIdx - 1]?.field;
336
+ // ✅ Amount fields (Receive Amount, Send Amount, Total Send Amount etc.)
337
+ /*
338
+ if (
339
+ field=='totalPayinAmount'||
340
+ field=='payinAmount'||
341
+ field === 'transactionCommissionAmount' ||
342
+ field === 'tax'
343
+ ) {
344
+ if (val !== '' && val !== null && val !== undefined) {
345
+ cell.value = Number(val);
346
+ cell.numFmt = '#,##0.000';
347
+ cell.alignment = { horizontal: 'right', vertical: 'middle' };
348
+ } else {
349
+ cell.value = '';
350
+ }
351
+ }
352
+ else {
353
+ cell.value = val;
354
+ } */
355
+ if (item?.isTotalRow && field === 'receiveAmount') {
356
+ cell.value = '';
357
+ }
358
+ else if (field?.toLowerCase().includes('amount') ||
359
+ field === 'serviceFee' ||
360
+ field === 'tax') {
361
+ if (val !== '' && val !== null && val !== undefined) {
362
+ cell.value = val; // already number
363
+ cell.numFmt = '#,##0.000'; // Excel formatting
364
+ cell.alignment = { horizontal: 'right', vertical: 'middle' };
365
+ }
366
+ else {
367
+ cell.value = '';
368
+ }
369
+ }
370
+ else {
371
+ cell.value = val;
372
+ }
373
+ cell.border = {
374
+ top: { style: 'thin' },
375
+ bottom: { style: 'thin' },
376
+ left: { style: 'thin' },
377
+ right: { style: 'thin' }
378
+ };
379
+ });
380
+ if (item?.isTotalRow) {
381
+ dataRow.eachCell(cell => {
382
+ cell.font = {
383
+ ...cell.font,
384
+ bold: true,
385
+ size: 12
386
+ };
387
+ });
388
+ }
389
+ });
390
+ }
391
+ }
392
+ else {
393
+ this.prepareTableRows(data, columns, options)
394
+ .forEach((rowData, index) => {
395
+ const dataRow = worksheet.getRow(rowIdx++);
396
+ const originalItem = data[index];
397
+ const fullRow = [
398
+ !originalItem?.isTotalRow ? serialNumber++ : '',
399
+ ...rowData
400
+ ];
401
+ fullRow.forEach((val, cIdx) => {
402
+ const cell = dataRow.getCell(cIdx + 1);
403
+ //cell.value = val;
404
+ /* if (cIdx === 0) {
405
+ cell.value = val;
406
+ } else {
407
+
408
+ const field = columns[cIdx - 1]?.field;
409
+
410
+ if (
411
+ field=='totalPayinAmount'||
412
+ field=='payinAmount'||
413
+ field === 'transactionCommissionAmount' ||
414
+ field === 'tax'
415
+ ) {
416
+ cell.value = Number(val);
417
+ cell.numFmt = '#,##0.000';
418
+ cell.alignment = { horizontal: 'right', vertical: 'middle' };
419
+ }
420
+ else {
421
+ cell.value = val;
422
+ }
423
+ } */
424
+ const field = columns[cIdx - 1]?.field;
425
+ if (cIdx === 0) {
426
+ cell.value = val;
427
+ }
428
+ else if (originalItem?.isTotalRow && field === 'receiveAmount') {
429
+ cell.value = '';
430
+ }
431
+ else if (field?.toLowerCase().includes('amount') ||
432
+ field === 'serviceFee' ||
433
+ field === 'tax') {
434
+ if (val !== '' && val !== null && val !== undefined) {
435
+ cell.value = val; // already number
436
+ cell.numFmt = '#,##0.000'; // Excel formatting
437
+ cell.alignment = { horizontal: 'right', vertical: 'middle' };
438
+ }
439
+ else {
440
+ cell.value = '';
441
+ }
442
+ }
443
+ else {
444
+ cell.value = val;
445
+ }
446
+ cell.border = {
447
+ top: { style: 'thin' },
448
+ bottom: { style: 'thin' },
449
+ left: { style: 'thin' },
450
+ right: { style: 'thin' }
451
+ };
452
+ });
453
+ if (originalItem?.isTotalRow) {
454
+ dataRow.eachCell(cell => {
455
+ cell.font = {
456
+ ...cell.font,
457
+ bold: true,
458
+ size: 12
459
+ };
460
+ });
461
+ }
462
+ });
463
+ }
464
+ // ===================== AUTO WIDTH =====================
465
+ for (let i = 1; i <= totalCols; i++) {
466
+ let maxLength = 10;
467
+ worksheet.eachRow({ includeEmpty: true }, (row) => {
468
+ const cell = row.getCell(i);
469
+ if (cell.isMerged)
470
+ return;
471
+ let cellValue = '';
472
+ if (cell.value == null) {
473
+ cellValue = '';
474
+ }
475
+ else if (typeof cell.value === 'object' && 'richText' in cell.value) {
476
+ cellValue = cell.value.richText.map(rt => rt.text).join('');
477
+ }
478
+ else {
479
+ cellValue = cell.value.toString();
480
+ }
481
+ maxLength = Math.max(maxLength, cellValue.length);
482
+ });
483
+ worksheet.getColumn(i).width = Math.min(maxLength, 50);
484
+ }
485
+ //new code:bharati
486
+ worksheet.columns.forEach((column, index) => {
487
+ if (index === 0)
488
+ return; // skip Sr No
489
+ const field = columns[index - 1]?.field;
490
+ if (field === 'payinAmount') {
491
+ column.width = 14;
492
+ }
493
+ if (field === 'payoutAmount') {
494
+ column.width = 15;
495
+ }
496
+ if (field === 'transactionCount') {
497
+ column.width = 14;
498
+ }
499
+ });
500
+ // worksheet.columns.forEach((column) => {
501
+ // if (column.header === 'Send Amount') {
502
+ // column.width = 25;
503
+ // }
504
+ // });
505
+ // ===================== SAVE FILE =====================
506
+ const buffer = await workbook.xlsx.writeBuffer();
507
+ FileSaver.saveAs(new Blob([buffer], {
508
+ type: 'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet'
509
+ }), title.replace(/\s/g, '-') + '.xlsx');
510
+ }
511
+ // private prepareTableRows(data: any[], columns: any[], options: ExportOptions = {}): any[][] {
512
+ // const {
513
+ // excludeFields = [],
514
+ // currencyFields = [],
515
+ // dateFields = [],
516
+ // dateFieldFormats = {},
517
+ // specialDecimalFields = {}
518
+ // } = options;
519
+ // const filtered = columns.filter(c =>
520
+ // c.field && !excludeFields.some(f => c.field.toLowerCase().includes(f))
521
+ // );
522
+ // return data.map((row) => ([
523
+ // ...filtered.map(col => {
524
+ // let value = row[col.field];
525
+ // // Format date fields with custom formats if specified
526
+ // if (col.field && (dateFields.includes(col.field) || col.field in dateFieldFormats)) {
527
+ // const format = dateFieldFormats[col.field] || 'dd/MM/yyyy';
528
+ // value = this.formatDateByFormat(value, format);
529
+ // }
530
+ // // Format special decimal fields with specific decimals
531
+ // else if (col.field && col.field in specialDecimalFields && value != null) {
532
+ // const decimals = specialDecimalFields[col.field];
533
+ // value = parseFloat(value).toFixed(decimals);
534
+ // }
535
+ // // Format regular currency fields with 3 decimals
536
+ // else if (col.field && currencyFields.includes(col.field) && value != null) {
537
+ // value = parseFloat(value).toFixed(3);
538
+ // }
539
+ // return value ?? '';
540
+ // })
541
+ // ]));
542
+ // }
543
+ prepareTableRows(data, columns, options = {}) {
544
+ const { excludeFields = [], currencyFields = [], dateFields = [], dateFieldFormats = {}, specialDecimalFields = {} } = options;
545
+ const filtered = columns.filter(c => c.field && !excludeFields.some(f => c.field.toLowerCase().includes(f)));
546
+ return data.map((row) => ([
547
+ ...filtered.map(col => {
548
+ let value = row[col.field];
549
+ // ✅ Date formatting (keep as string)
550
+ if (col.field &&
551
+ (dateFields.includes(col.field) || col.field in dateFieldFormats)) {
552
+ const format = dateFieldFormats[col.field] || 'dd/MM/yyyy';
553
+ value = this.formatDateByFormat(value, format);
554
+ }
555
+ // ✅ Special decimal fields → return NUMBER (no toFixed)
556
+ else if (col.field &&
557
+ col.field in specialDecimalFields &&
558
+ value != null) {
559
+ value = Number(value);
560
+ }
561
+ // ✅ Currency fields → return NUMBER (no toFixed)
562
+ else if (col.field &&
563
+ currencyFields.includes(col.field) &&
564
+ value != null) {
565
+ value = Number(value);
566
+ }
567
+ return value ?? '';
568
+ })
569
+ ]));
570
+ }
571
+ formatDateByFormat(val, format) {
572
+ // Helper to pad single digits
573
+ const pad = (n) => n.toString().padStart(2, '0');
574
+ // Parse date for "DD/MM/YYYY hh:mm AM/PM" format manually
575
+ if (typeof val === 'string' && /^\d{2}\/\d{2}\/\d{4} \d{2}:\d{2} [AP]M$/.test(val)) {
576
+ const parts = val.match(/^(\d{2})\/(\d{2})\/(\d{4}) (\d{2}):(\d{2}) ([AP]M)$/);
577
+ if (!parts)
578
+ return '';
579
+ let [, dd, mm, yyyy, hh, min, ampm] = parts;
580
+ let hours = parseInt(hh, 10);
581
+ if (ampm === 'PM' && hours !== 12)
582
+ hours += 12;
583
+ if (ampm === 'AM' && hours === 12)
584
+ hours = 0;
585
+ val = new Date(parseInt(yyyy, 10), parseInt(mm, 10) - 1, parseInt(dd, 10), hours, parseInt(min, 10));
586
+ }
587
+ else {
588
+ val = new Date(val);
589
+ }
590
+ if (isNaN(val.getTime()))
591
+ return '';
592
+ const dt = val;
593
+ switch (format) {
594
+ case 'dd/MM/yyyy hh:mm a': { // 11/07/2025 10:56 PM
595
+ let hours12 = dt.getHours() % 12 || 12;
596
+ let ampm = dt.getHours() >= 12 ? 'PM' : 'AM';
597
+ return `${pad(dt.getDate())}/${pad(dt.getMonth() + 1)}/${dt.getFullYear()} ${pad(hours12)}:${pad(dt.getMinutes())} ${ampm}`;
598
+ }
599
+ case 'dd/MM/yyyy HH:mm': { // 28/07/2025 13:08
600
+ return `${pad(dt.getDate())}/${pad(dt.getMonth() + 1)}/${dt.getFullYear()} ${pad(dt.getHours())}:${pad(dt.getMinutes())}`;
601
+ }
602
+ case 'dd/MM/yyyy': { // 28/07/2025
603
+ return `${pad(dt.getDate())}/${pad(dt.getMonth() + 1)}/${dt.getFullYear()}`;
604
+ }
605
+ default:
606
+ return dt.toLocaleString();
607
+ }
608
+ }
609
+ dateValueFormatter(format) {
610
+ return (params) => {
611
+ if (!params.value)
612
+ return '';
613
+ try {
614
+ return formatDate(params.value, format, 'en-US');
615
+ }
616
+ catch {
617
+ return '';
618
+ }
619
+ };
620
+ }
621
+ getKeys(obj) {
622
+ return obj ? Object.keys(obj) : [];
623
+ }
624
+ hasAnyGroups() {
625
+ return this.filteredData && this.getKeys(this.filteredData).length > 0;
626
+ }
627
+ formatAmount(params) {
628
+ const value = params?.value;
629
+ if (value !== null && value !== undefined && value !== '') {
630
+ const num = Number(value);
631
+ return (Math.trunc(num * 1000) / 1000).toFixed(3);
632
+ }
633
+ return '';
634
+ }
635
+ handleSearch(criteria) {
636
+ this.searchCriteria = criteria.searchCriteria;
637
+ this.reportDate = new Date().toISOString();
638
+ this.reportDate = formatDate(this.reportDate, 'dd/MM/yyyy hh:mm a', 'en-US');
639
+ const modal = criteria.modal;
640
+ this.user = criteria.sysUserID;
641
+ this.fromDate = formatDate(modal.fromDate, 'dd/MM/yyyy hh:mm a', 'en-US').slice(0, 10);
642
+ this.toDate = formatDate(modal.toDate, 'dd/MM/yyyy hh:mm a', 'en-US').slice(0, 10);
643
+ console.log(modal);
644
+ // Code For Meta Data
645
+ this.leftData = {
646
+ 'Report Period': this.fromDate + " - " + this.toDate,
647
+ };
648
+ this.metaDataTwo = {
649
+ 'Report User & Time': this.user + " @ " + this.reportDate,
650
+ };
651
+ const isTotalSummary = modal.summaryReport === 'Total Summary';
652
+ this.isTotalSummary = isTotalSummary;
653
+ const searchData = {
654
+ "StartDate": modal.fromDate,
655
+ "EndDate": modal.toDate,
656
+ "SendCountryCode": modal.sendCountry,
657
+ "RecvCountryCode": modal.receiveCountry,
658
+ "BusinessPartnerCode": modal.client,
659
+ "TransactionStatus": modal.transactionStatus.join(","),
660
+ "PayoutCurrency": modal.receiveCurrency,
661
+ "TransactionType": modal.product,
662
+ "BranchCode": modal.branch,
663
+ "SummaryReport": modal.summaryReport
664
+ };
665
+ this.showMessage = true;
666
+ this.clearSearch = true;
667
+ this.loadingState = ComponentLoadingStates.Loading;
668
+ this.reportService.getBranchActivitySendSummaryReport(searchData).subscribe({
669
+ next: (data) => {
670
+ console.log(data);
671
+ this.dataMap = JSON.parse(JSON.stringify(data));
672
+ this.filteredData = data;
673
+ this.noDataFound = Object.keys(this.filteredData).length == 0 ? true : false;
674
+ this.proxyData = structuredClone(data);
675
+ this.paginationArray = new Array(Object.keys(this.filteredData).length).fill(15);
676
+ this.showMessage = Object.keys(this.filteredData).length == 0 ? true : false;
677
+ this.showReport = true;
678
+ },
679
+ error: (err) => {
680
+ this.loadingState = ComponentLoadingStates.Complete;
681
+ this.clearSearch = false;
682
+ },
683
+ complete: () => {
684
+ this.loadingState = ComponentLoadingStates.Complete;
685
+ this.showReport = true;
686
+ this.clearSearch = false;
687
+ }
688
+ });
689
+ }
690
+ handleFormValid(isValid) {
691
+ this.isFormValid = isValid;
692
+ }
693
+ }
694
+ BranchActivitySendSummaryReportComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: BranchActivitySendSummaryReportComponent, deps: [{ token: i1.ReportService }, { token: i0.NgZone }], target: i0.ɵɵFactoryTarget.Component });
695
+ BranchActivitySendSummaryReportComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: BranchActivitySendSummaryReportComponent, selector: "lib-branch-activity-send-summary-report", ngImport: i0, template: "<lib-search-filter \r\n [ReportName]=\"ReportName\" \r\n (searchClicked)=\"handleSearch($event)\"\r\n (formValid)=\"handleFormValid($event)\">\r\n</lib-search-filter >\r\n<app-loader class=\"\" *ngIf=\"loadingState == ComponentLoadingState.Loading\"></app-loader>\r\n\r\n<section *ngIf=\"showReport && isFormValid && !clearSearch\" class=\"my-2\">\r\n <ng-container *ngIf=\"!noDataFound\">\r\n <lib-metadata [reportName]=\"ReportName\" [showmetaDataOne]=\"true\" [showmetaDataTwo]=\"true\" [metaDataOne]=\"leftData\" [metaDataTwo]=\"metaDataTwo\"(exportEvent)=\"handleExport($event)\" (searchEvent)=\"filter($event)\"></lib-metadata>\r\n\r\n <ngb-accordion #acc=\"ngbAccordion\" [closeOthers]=\"false\">\r\n <ng-container *ngFor=\"let item of filteredData | keyvalue; let i = index\">\r\n <ngb-panel *ngIf=\"item.value.length > 0\" [id]=\"'panel-' + i\">\r\n\r\n <ng-template ngbPanelTitle style=\"height: 10%;\">\r\n <label\r\n class=\"panel-cls\">{{\r\n item.key\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]=\"item?.value?.length\"\r\n [defaultSize]=\"'15'\" [gridApi]=\"gridApis[i]\">\r\n ></lib-page-size-selector>\r\n\r\n <ag-grid-angular class=\"ag-theme-alpine transaction-grid\" style=\"width: 100%;height: 380px;\"\r\n [columnDefs]=\"columnDefs\" \r\n [defaultColDef]=\"defaultColDef\" \r\n [rowData]=\"item.value\" \r\n [rowHeight]=\"20\"\r\n [headerHeight]=\"22\"\r\n [pagination]=\"true\" \r\n [paginationPageSize]=\"paginationArray[i]\" \r\n [rowClassRules]=\"rowClassRules\"\r\n (gridReady)=\"onGridReady($event,i)\"\r\n >\r\n </ag-grid-angular>\r\n </div>\r\n </ng-template>\r\n\r\n </ngb-panel>\r\n </ng-container>\r\n </ngb-accordion>\r\n </ng-container>\r\n <div class=\"alert alert-warning mt-3\" *ngIf=\"noDataFound\">\r\n No Data found matching your search criteria.\r\n </div>\r\n</section>", styles: [".btn-report{border-radius:4px;background-color:#8091a5;color:#fff!important;font-size:14px!important;height:32px!important;height:32px;min-width:110px;margin:0 0 0 20px!important;padding:4px 15px!important}.tooltip-block{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;border:1px solid #ccc!important}.dpicker{border:1px solid #ccc!important;font-family:system-ui,-apple-system,Segoe UI,Roboto,Helvetica Neue,Noto Sans,Liberation Sans,Arial,sans-serif,\"Apple Color Emoji\",\"Segoe UI Emoji\",Segoe UI Symbol,\"Noto Color Emoji\"!important;font-size:12px!important;font-weight:400!important;height:32px!important}.dpicker:focus{box-shadow:0 0 5px 3px #1877f2!important}.cal{height:32px!important;background-color:#1877f2!important}.cal:focus{box-shadow:none!important}.input-group-button{background:none;border:1px solid #0081c6;background-color:#0081c6;border-radius:0 3px 3px 0;min-width:35px;margin-left:1px;cursor:pointer}.labl{font-size:11.2px;font-weight:700!important}.info{font-size:12px!important;font-weight:400;padding-left:.5rem}.label-data{font-weight:600!important;font-size:.7rem!important;line-height:1rem}.meta-td{padding:0!important}.title{text-align:center;font-size:18px;font-weight:700!important}.export-options{display:inline-flex;font-size:.75rem;height:2rem!important;width:5rem!important;margin-right:-1;margin-left:.4rem}.opt-cls{display:block;height:100%;width:5rem;border:1px solid #ccc!important;border-radius:4px!important;margin-right:1rem!important;outline:none!important}.opt-cls:focus{box-shadow:0 0 5px 3px #1877f2}.export-selector{height:2rem!important;width:100%}.search-btn{height:32px!important;height:32px;width:36px;background-color:#8091a5;border:none;border-radius:0 4px 4px 0;display:flex;justify-content:center;align-items:center}.search-btn:hover{background-color:#8091a5}.search-icon{height:16px;width:16px;object-fit:contain}.search-input{outline:none!important;border:1px solid #ccc!important;width:190px;height:32px!important;font-size:.75rem;padding:.25rem .5rem;border-top-left-radius:4px;border-bottom-left-radius:4px;border-top-right-radius:0!important;border-bottom-right-radius:0!important;text-transform:uppercase}.search-input:focus{box-shadow:0 0 5px 3px #1877f2!important}.searchBox{margin-right:auto;display:flex}table{width:100%;border-collapse:separate;margin-bottom:0!important;table-layout:fixed!important}td{padding:0 1rem 6px 0!important;border-right:0 solid #ffffff!important;background-color:#fff!important}.row-cls{height:2.5rem!important}.inputbox{padding-left:1rem;font-family:system-ui,-apple-system,Segoe UI,Roboto,Helvetica Neue,Noto Sans,Liberation Sans,Arial,sans-serif,\"Apple Color Emoji\",\"Segoe UI Emoji\",Segoe UI Symbol,\"Noto Color Emoji\"}::ng-deep .ng-select.ng-select-single .ng-select-container{height:32px I!important}::ng-deep .ng-select.ng-select-multiple .ng-select-container .ng-value-container{max-height:32px!important;overflow-x:auto!important;overflow-y:auto;white-space:nowrap!important}::ng-deep .ng-select .ng-select-multiple .ng-select-container .ng-value-container{max-height:32px!important;overflow-x:auto!important;white-space:nowrap!important}::ng-deep .ng-select .ng-select-multiple .ng-select-container .ng-value-container .ng-value{max-width:200px!important;overflow:hidden!important;text-overflow:hidden!important;white-space:nowrap!important}::ng-deep .ng-select .ng-select-container{cursor:default;display:flex;outline:none;overflow:hidden;position:relative;width:100%}::ng-deep .ng-dropdown-panel .ng-dropdown-panel-items .ng-option{box-sizing:border-box;cursor:pointer;display:block;white-space:nowrap;overflow-x:scroll!important;text-overflow:clip!important}::ng-deep .ng-dropdown-panel .ng-dropdown-panel-items .ng-option::-webkit-scrollbar{display:none!important;width:0!important}::ng-deep .ng-select .ng-select-container:focus-within{box-shadow:0 0 5px 3px #1877f2!important}::ng-deep .ng-select .ng-select-container:focus{box-shadow:0 0 5px 3px #1877f2!important}::ng-deep .ng-select .ng-select-container,::ng-deep .ng-select.ng-select-single .ng-select-container,::ng-deep .ng-select.ng-select-multiple .ng-select-container{min-height:32px!important;height:32px!important;font-size:12px!important}.panel-cls{font-weight:700;font-size:13px;line-height:1.2;margin:0;padding:2px 0;color:#16181e}.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}::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;font-weight:500!important}.transaction-grid ::ng-deep .ag-row.total-row .ag-cell{font-weight:700!important;font-size:11px!important}\n"], dependencies: [{ kind: "component", type: i2.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: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i4.PageSizeSelectorComponent, selector: "lib-page-size-selector", inputs: ["pageSizeArray", "defaultSize", "totalEntries", "gridApi"] }, { kind: "component", type: i5.MetadataComponent, selector: "lib-metadata", inputs: ["metaDataOne", "metaDataTwo", "showmetaDataOne", "showmetaDataTwo", "reportName"], outputs: ["searchEvent", "exportEvent"] }, { kind: "component", type: i6.NgbAccordion, selector: "ngb-accordion", inputs: ["animation", "activeIds", "closeOthers", "destroyOnHide", "type"], outputs: ["panelChange", "shown", "hidden"], exportAs: ["ngbAccordion"] }, { kind: "directive", type: i6.NgbPanel, selector: "ngb-panel", inputs: ["disabled", "id", "title", "type", "cardClass"], outputs: ["shown", "hidden"] }, { kind: "directive", type: i6.NgbPanelTitle, selector: "ng-template[ngbPanelTitle]" }, { kind: "directive", type: i6.NgbPanelContent, selector: "ng-template[ngbPanelContent]" }, { kind: "component", type: i7.LoaderComponent, selector: "app-loader" }, { kind: "component", type: i8.SearchFilterComponent, selector: "lib-search-filter", inputs: ["ReportName", "initialFilters"], outputs: ["searchClicked", "formValid"] }, { kind: "pipe", type: i3.KeyValuePipe, name: "keyvalue" }] });
696
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: BranchActivitySendSummaryReportComponent, decorators: [{
697
+ type: Component,
698
+ args: [{ selector: 'lib-branch-activity-send-summary-report', template: "<lib-search-filter \r\n [ReportName]=\"ReportName\" \r\n (searchClicked)=\"handleSearch($event)\"\r\n (formValid)=\"handleFormValid($event)\">\r\n</lib-search-filter >\r\n<app-loader class=\"\" *ngIf=\"loadingState == ComponentLoadingState.Loading\"></app-loader>\r\n\r\n<section *ngIf=\"showReport && isFormValid && !clearSearch\" class=\"my-2\">\r\n <ng-container *ngIf=\"!noDataFound\">\r\n <lib-metadata [reportName]=\"ReportName\" [showmetaDataOne]=\"true\" [showmetaDataTwo]=\"true\" [metaDataOne]=\"leftData\" [metaDataTwo]=\"metaDataTwo\"(exportEvent)=\"handleExport($event)\" (searchEvent)=\"filter($event)\"></lib-metadata>\r\n\r\n <ngb-accordion #acc=\"ngbAccordion\" [closeOthers]=\"false\">\r\n <ng-container *ngFor=\"let item of filteredData | keyvalue; let i = index\">\r\n <ngb-panel *ngIf=\"item.value.length > 0\" [id]=\"'panel-' + i\">\r\n\r\n <ng-template ngbPanelTitle style=\"height: 10%;\">\r\n <label\r\n class=\"panel-cls\">{{\r\n item.key\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]=\"item?.value?.length\"\r\n [defaultSize]=\"'15'\" [gridApi]=\"gridApis[i]\">\r\n ></lib-page-size-selector>\r\n\r\n <ag-grid-angular class=\"ag-theme-alpine transaction-grid\" style=\"width: 100%;height: 380px;\"\r\n [columnDefs]=\"columnDefs\" \r\n [defaultColDef]=\"defaultColDef\" \r\n [rowData]=\"item.value\" \r\n [rowHeight]=\"20\"\r\n [headerHeight]=\"22\"\r\n [pagination]=\"true\" \r\n [paginationPageSize]=\"paginationArray[i]\" \r\n [rowClassRules]=\"rowClassRules\"\r\n (gridReady)=\"onGridReady($event,i)\"\r\n >\r\n </ag-grid-angular>\r\n </div>\r\n </ng-template>\r\n\r\n </ngb-panel>\r\n </ng-container>\r\n </ngb-accordion>\r\n </ng-container>\r\n <div class=\"alert alert-warning mt-3\" *ngIf=\"noDataFound\">\r\n No Data found matching your search criteria.\r\n </div>\r\n</section>", styles: [".btn-report{border-radius:4px;background-color:#8091a5;color:#fff!important;font-size:14px!important;height:32px!important;height:32px;min-width:110px;margin:0 0 0 20px!important;padding:4px 15px!important}.tooltip-block{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;border:1px solid #ccc!important}.dpicker{border:1px solid #ccc!important;font-family:system-ui,-apple-system,Segoe UI,Roboto,Helvetica Neue,Noto Sans,Liberation Sans,Arial,sans-serif,\"Apple Color Emoji\",\"Segoe UI Emoji\",Segoe UI Symbol,\"Noto Color Emoji\"!important;font-size:12px!important;font-weight:400!important;height:32px!important}.dpicker:focus{box-shadow:0 0 5px 3px #1877f2!important}.cal{height:32px!important;background-color:#1877f2!important}.cal:focus{box-shadow:none!important}.input-group-button{background:none;border:1px solid #0081c6;background-color:#0081c6;border-radius:0 3px 3px 0;min-width:35px;margin-left:1px;cursor:pointer}.labl{font-size:11.2px;font-weight:700!important}.info{font-size:12px!important;font-weight:400;padding-left:.5rem}.label-data{font-weight:600!important;font-size:.7rem!important;line-height:1rem}.meta-td{padding:0!important}.title{text-align:center;font-size:18px;font-weight:700!important}.export-options{display:inline-flex;font-size:.75rem;height:2rem!important;width:5rem!important;margin-right:-1;margin-left:.4rem}.opt-cls{display:block;height:100%;width:5rem;border:1px solid #ccc!important;border-radius:4px!important;margin-right:1rem!important;outline:none!important}.opt-cls:focus{box-shadow:0 0 5px 3px #1877f2}.export-selector{height:2rem!important;width:100%}.search-btn{height:32px!important;height:32px;width:36px;background-color:#8091a5;border:none;border-radius:0 4px 4px 0;display:flex;justify-content:center;align-items:center}.search-btn:hover{background-color:#8091a5}.search-icon{height:16px;width:16px;object-fit:contain}.search-input{outline:none!important;border:1px solid #ccc!important;width:190px;height:32px!important;font-size:.75rem;padding:.25rem .5rem;border-top-left-radius:4px;border-bottom-left-radius:4px;border-top-right-radius:0!important;border-bottom-right-radius:0!important;text-transform:uppercase}.search-input:focus{box-shadow:0 0 5px 3px #1877f2!important}.searchBox{margin-right:auto;display:flex}table{width:100%;border-collapse:separate;margin-bottom:0!important;table-layout:fixed!important}td{padding:0 1rem 6px 0!important;border-right:0 solid #ffffff!important;background-color:#fff!important}.row-cls{height:2.5rem!important}.inputbox{padding-left:1rem;font-family:system-ui,-apple-system,Segoe UI,Roboto,Helvetica Neue,Noto Sans,Liberation Sans,Arial,sans-serif,\"Apple Color Emoji\",\"Segoe UI Emoji\",Segoe UI Symbol,\"Noto Color Emoji\"}::ng-deep .ng-select.ng-select-single .ng-select-container{height:32px I!important}::ng-deep .ng-select.ng-select-multiple .ng-select-container .ng-value-container{max-height:32px!important;overflow-x:auto!important;overflow-y:auto;white-space:nowrap!important}::ng-deep .ng-select .ng-select-multiple .ng-select-container .ng-value-container{max-height:32px!important;overflow-x:auto!important;white-space:nowrap!important}::ng-deep .ng-select .ng-select-multiple .ng-select-container .ng-value-container .ng-value{max-width:200px!important;overflow:hidden!important;text-overflow:hidden!important;white-space:nowrap!important}::ng-deep .ng-select .ng-select-container{cursor:default;display:flex;outline:none;overflow:hidden;position:relative;width:100%}::ng-deep .ng-dropdown-panel .ng-dropdown-panel-items .ng-option{box-sizing:border-box;cursor:pointer;display:block;white-space:nowrap;overflow-x:scroll!important;text-overflow:clip!important}::ng-deep .ng-dropdown-panel .ng-dropdown-panel-items .ng-option::-webkit-scrollbar{display:none!important;width:0!important}::ng-deep .ng-select .ng-select-container:focus-within{box-shadow:0 0 5px 3px #1877f2!important}::ng-deep .ng-select .ng-select-container:focus{box-shadow:0 0 5px 3px #1877f2!important}::ng-deep .ng-select .ng-select-container,::ng-deep .ng-select.ng-select-single .ng-select-container,::ng-deep .ng-select.ng-select-multiple .ng-select-container{min-height:32px!important;height:32px!important;font-size:12px!important}.panel-cls{font-weight:700;font-size:13px;line-height:1.2;margin:0;padding:2px 0;color:#16181e}.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}::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;font-weight:500!important}.transaction-grid ::ng-deep .ag-row.total-row .ag-cell{font-weight:700!important;font-size:11px!important}\n"] }]
699
+ }], ctorParameters: function () { return [{ type: i1.ReportService }, { type: i0.NgZone }]; } });
700
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"branch-activity-send-summary-report.component.js","sourceRoot":"","sources":["../../../../../../projects/reports-lib/src/lib/components/branch-activity-send-summary-report/branch-activity-send-summary-report.component.ts","../../../../../../projects/reports-lib/src/lib/components/branch-activity-send-summary-report/branch-activity-send-summary-report.component.html"],"names":[],"mappings":"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","sourcesContent":[" import { Component, NgZone, OnInit, inject } from '@angular/core';\r\n // import { Component, ElementRef, HostListener, ViewChild } from '@angular/core';\r\n import { ColDef, GridApi, GridReadyEvent } from 'ag-grid-community';\r\n import { themeAlpine } from '@ag-grid-community/theming';\r\nimport { BranchActivityReport } from '../../models/branch-activity-report/branch-activity-send-report';\r\nimport { ComponentLoadingStates } from '../../models/component-loading-states';\r\nimport { ExportOptions, GenericExportService } from '../../shared/export-generic.service';\r\nimport { ReportService } from '../../services/report.service';\r\n// import { formatDate } from '@angular/common';\r\n// import { ComponentLoadingStates } from 'src/app/models/component-loading-states';\r\n// import { GenericExportService } from 'src/app/shared/export-generic.service';\r\n// import { ExportOptions } from 'projects/reports-lib/src/lib/shared/export-generic.service';\r\n// import { Injectable } from '@angular/core';\r\n// import jsPDF from 'jspdf';\r\n// import 'jspdf-autotable';\r\n import * as ExcelJS from 'exceljs';\r\n import * as FileSaver from 'file-saver';\r\nimport { formatDate } from '@angular/common';\r\n\r\n@Component({\r\n  selector: 'lib-branch-activity-send-summary-report',\r\n  templateUrl: './branch-activity-send-summary-report.component.html',\r\n  styleUrls: ['./branch-activity-send-summary-report.component.scss']\r\n})\r\nexport class BranchActivitySendSummaryReportComponent implements OnInit {\r\n  dataMap: Record<string, BranchActivityReport[]> = {}\r\n  filteredData: Record<string, BranchActivityReport[]> = {}\r\n  proxyData: Record<string, BranchActivityReport[]> = {}\r\n  showReport: boolean;\r\n  paginationArray: any[];\r\n  selectedExportOption = 'excel';\r\n  gridApis: GridApi[] = [];\r\n  gridColumnApi;\r\n  user: string = \"\";\r\n  reportDate: string;\r\n  fromDate: string;\r\n  toDate: string;\r\n  searchText: string;\r\n  buffer: any;\r\n  sysUserId: string;\r\n  private logoBase64: string | undefined;\r\n  ComponentLoadingState = ComponentLoadingStates;\r\n  loadingState: ComponentLoadingStates = ComponentLoadingStates.Loading;\r\n  ReportName: string = \"Branch Activity Send Summary\";\r\n  leftData: Record<string, string>;\r\n  metaDataTwo: Record<string, string>;\r\n  exportService: GenericExportService = inject(GenericExportService);\r\n  searchCriteria: [string, string][] = [];\r\n\r\n  // flags\r\n  showMessage: boolean = false;\r\n  noDataFound: boolean = false;\r\n  isFormValid: boolean = false;\r\n  clearSearch: boolean = false;\r\n  isTotalSummary: boolean = false;\r\n  columnDefs: ColDef<BranchActivityReport>[] = [\r\n\r\n    {\r\n      field: 'businessDateTime', headerName: 'Business Date', flex: 1, wrapText: true, autoHeight: true, headerClass: 'ag-left-aligned-header', minWidth: 70, width: 70, tooltipField: 'businessDateTime',\r\n      valueFormatter: (params) => {\r\n        const row = params.data as BranchActivityReport | null;\r\n\r\n        if (row && row.payinCCcode === 'Total') {\r\n          return ''; // hide date for total row\r\n        }\r\n\r\n        return params.value;\r\n      }\r\n    },\r\n    { field: 'product', headerName: 'Product', flex: 1, wrapText: true, autoHeight: true, minWidth: 80, width: 120, tooltipField: 'product' },\r\n    { field: 'payoutCCcode', headerName: 'Receive Currency', flex: 1, wrapText: true, autoHeight: true, minWidth: 90, width: 110, tooltipField: 'payoutCCcode' },\r\n    { field: 'payoutAmount', headerName: 'Receive Amount', flex: 1, wrapText: true, autoHeight: true, minWidth: 90, maxWidth: 120, cellClass: 'ag-right-aligned-cell compact-cell', tooltipField: 'payoutAmount' },\r\n    { field: 'payinCCcode', headerName: 'Send Currency', flex: 1, wrapText: true, autoHeight: true, minWidth: 90, maxWidth: 90, tooltipField: 'payinCCcode' },\r\n    { field: 'payinAmount', headerName: 'Send Amount', flex: 1, wrapText: true, autoHeight: true, minWidth: 80, maxWidth: 120, cellClass: 'ag-right-aligned-cell compact-cell', tooltipField: 'payinAmount' },\r\n    { field: 'transactionCommissionAmount', headerName: 'Service Fee', flex: 1, wrapText: true, autoHeight: true, minWidth: 90, maxWidth: 100, cellClass: 'ag-right-aligned-cell compact-cell', tooltipField: 'transactionCommissionAmount' },\r\n    { field: 'tax', headerName: 'Tax', flex: 1, wrapText: true, autoHeight: true, minWidth: 80, maxWidth: 100, cellClass: 'ag-right-aligned-cell compact-cell', tooltipField: 'tax' },\r\n    { field: 'totalPayinAmount', headerName: 'Total Send Amount', minWidth: 100, flex: 1, wrapText: true, autoHeight: true, cellClass: 'ag-right-aligned-cell compact-cell', tooltipField: 'totalPayinAmount' },\r\n    { field: 'transactionCount', headerName: 'Transaction Count', flex: 1, wrapText: true, autoHeight: true, minWidth: 80, maxWidth: 100, cellClass: 'ag-right-aligned-cell compact-cell', tooltipField: 'txnCount' },\r\n    { field: 'status', headerName: 'Transaction Status', minWidth: 100, flex: 1, wrapText: true, autoHeight: true, tooltipField: 'status' }\r\n  ];\r\n\r\n\r\n  defaultColDef = {\r\n    sortable: true,\r\n    filter: true,\r\n    resizable: true,\r\n    minwidth: 40,\r\n    wrapHeaderText: true,\r\n    autoHeaderHeight: true,\r\n    suppressSizeToFit: false,\r\n    wrapText: true\r\n  };\r\n\r\n  // rowClassRules = {\r\n  //   debugger\r\n  //   'total-row': params => params.data?.isTotalRow\r\n  // };\r\n\r\n  rowClassRules = {\r\n    'total-row': (params) => {\r\n      console.log('Row Data:', params.data.isTotalRow);\r\n      if (params.data.isTotalRow) {\r\n        return params.data?.isTotalRow;\r\n      }\r\n\r\n    }\r\n  };\r\n\r\n  rowData: BranchActivityReport[] = [];\r\n\r\n  constructor(private reportService: ReportService, private ngZone: NgZone) { }\r\n\r\n  reportTheme = themeAlpine.withParams({\r\n    headerFontSize: '10px',\r\n    fontFamily: ['Arial', 'sans-serif'],\r\n    fontSize: '9px'\r\n  });\r\n\r\n  ngOnInit(): void {\r\n    this.loadingState = ComponentLoadingStates.Complete;\r\n    // Check if User is falcon user or fossilUser\r\n    if (sessionStorage.getItem('fossilusername')) {\r\n      this.sysUserId = sessionStorage.getItem('fossilusername')\r\n    }\r\n    else {\r\n      this.sysUserId = sessionStorage.getItem('ezremitusername');\r\n    }\r\n    this.sysUserId = this.sysUserId.replace(/^[\"'](.*)[\"']$/, '$1');\r\n    this.user = this.sysUserId;\r\n    console.log(\"System User Id : \" + this.sysUserId);\r\n  }\r\n\r\n  filter(text: string) {\r\n    this.searchText = text;\r\n    if (this.searchText == null) {\r\n      return;\r\n    }\r\n    if (this.searchText?.length === 0) {\r\n      this.filteredData = structuredClone(this.dataMap);\r\n      return;\r\n    }\r\n    this.searchText = this.searchText?.trim()?.toLowerCase();\r\n    for (const [key, entries] of Object.entries(this.proxyData)) {\r\n      const filteredData = entries.filter(entry => Object.values(entry)\r\n        .some(val => {\r\n          let a: string = val?.toString().toLowerCase();\r\n          if(a == null){\r\n            return false;\r\n          }\r\n          return a?.search(this.searchText) == -1 ? false : true;\r\n        }))\r\n\r\n      this.filteredData[key] = filteredData;\r\n    }\r\n    this.filteredData;\r\n  }\r\n\r\n  onGridReady(params: GridReadyEvent, id: number) {\r\n    params.api.sizeColumnsToFit();\r\n    this.gridColumnApi = params.columnApi;\r\n    this.gridApis[id] = params.api;\r\n    params.columnApi.setColumnVisible('businessDateTime', !this.isTotalSummary);\r\n    params.api.sizeColumnsToFit();\r\n  }\r\n\r\n  handleExport(option: string): void {\r\n    this.selectedExportOption = option;\r\n    if (!this.hasAnyGroups()) {\r\n      alert(\"There is no data to export based on your current filter.\");\r\n      return;\r\n    }\r\n    // If no data, do nothing.\r\n    if (!this.filteredData || Object.keys(this.filteredData).length === 0) {\r\n      alert(\"No data to export\");\r\n      return;\r\n    }\r\n    const title = \"Branch Activity Send Summary\";\r\n    const reportTimeFormatter = this.dateValueFormatter('dd/MM/yyyy hh:mm a');\r\n    const metadata: [string, string][] = [\r\n      ['Report Period ', this.fromDate + \" - \" + this.toDate],\r\n      ['Report User & Time', this.user ? this.user + \" @ \" + this.reportDate : '' + \" @ \" + this.reportDate],\r\n    ];\r\n    // --- search criteria ---\r\n    const searchCriteria: [string, string][] = this.searchCriteria;\r\n    //const columns = this.columnDefs;\r\n\r\n    //exclude Business Date col for Total Summary Report.\r\n    let columns = [...this.columnDefs];\r\n    const summaryReport = this.searchCriteria.find(x => x[0] === 'Summary Report:')?.[1];\r\n     \r\n    if (summaryReport === 'Total Summary') {\r\n      columns = columns.filter(col => col.field !== 'businessDateTime');\r\n    }\r\n\r\n    // const data = this.dataMap;\r\n    const cleanedData = {};\r\n\r\n    Object.keys(this.dataMap).forEach(key => {\r\n      cleanedData[key] = this.dataMap[key].map(row => {\r\n        if (row.isTotalRow) {\r\n          return {\r\n            ...row,\r\n            businessDateTime: '',\r\n            product: '',\r\n            receiveCurrency: '',\r\n            receiveAmount: ''\r\n          };\r\n        }\r\n        return row;\r\n      });\r\n    });\r\n\r\n    const data = cleanedData;\r\n    const options = {\r\n      currencyFields: [\r\n        'payoutAmount', 'payinAmount', 'transactionCommissionAmount', 'tax', 'totalPayinAmount'\r\n      ],\r\n      // specify all date fields expected\r\n      dateFields: [],\r\n\r\n      dateFieldFormats: {\r\n        txnDateAndTime: 'dd/MM/yyyy hh:mm a',\r\n        cancellationBranchDateTime: 'dd/MM/yyyy HH:mm',\r\n        cancellationBusinessDate: 'dd/MM/yyyy'\r\n      },\r\n\r\n      specialDecimalFields: {\r\n        rate: 8       // future field with 8 decimal places\r\n      },\r\n\r\n      groupByKey: true\r\n    };\r\n\r\n    switch (this.selectedExportOption) {\r\n      case 'excel':\r\n        this.exportToExcel({ title, metadata, searchCriteria, columns, data, options });\r\n        break;\r\n      case 'pdf':\r\n        this.exportService.exportToPdf({ title, metadata, searchCriteria, columns, data, options });\r\n        break;\r\n      case 'csv':\r\n        this.exportService.exportToCsv({ title, metadata, searchCriteria, columns, data, options });\r\n        break;\r\n      default:\r\n        alert(\"Please select an export format.\");\r\n    }\r\n  }\r\n\r\n  async exportToExcel({\r\n    title,\r\n    metadata,\r\n    searchCriteria,\r\n    columns,\r\n    data,\r\n    options = {}\r\n  }: {\r\n    title: string;\r\n    metadata: [string, string][];\r\n    searchCriteria: [string, string][];\r\n    columns: any[];\r\n    data: any[] | Record<string, any[]>;\r\n    options?: ExportOptions;\r\n  }): Promise<void> {\r\n\r\n    const workbook = new ExcelJS.Workbook();\r\n    const worksheet = workbook.addWorksheet(title);\r\n\r\n    // ===================== PRE CALC =====================\r\n    const headerLabels = ['Sr No', ...columns.map(col => col.headerName || col.field)];\r\n    const totalCols = headerLabels.length;\r\n\r\n    const titleStartCol = 4;\r\n    const titleColLetter = String.fromCharCode(64 + titleStartCol);\r\n    const titleMergeEnd = String.fromCharCode(64 + totalCols);\r\n\r\n    // ===================== LOGO =====================\r\n    if (this.logoBase64) {\r\n      const base64Data = this.logoBase64.replace(/^data:image\\/\\w+;base64,/, '');\r\n\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 },\r\n        ext: { width: 145, height: 66 }\r\n      });\r\n\r\n      worksheet.getRow(1).height = 24;\r\n      worksheet.getRow(2).height = 22;\r\n      worksheet.getRow(3).height = 22;\r\n    }\r\n\r\n    // ===================== TITLE =====================\r\n    worksheet.mergeCells(`${titleColLetter}1:${titleMergeEnd}1`);\r\n    const titleCell = worksheet.getRow(1).getCell(titleStartCol);\r\n    titleCell.value = title;\r\n    titleCell.font = { bold: true, size: 16 };\r\n    titleCell.alignment = { vertical: 'middle', horizontal: 'left' };\r\n\r\n    // ===================== METADATA =====================\r\n    let metaRowStart = 4;\r\n\r\n    metadata.forEach(([label, value], idx) => {\r\n      const row = worksheet.getRow(metaRowStart + idx);\r\n\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      worksheet.mergeCells(`A${row.number}:${titleMergeEnd}${row.number}`);\r\n    });\r\n\r\n    let currentRow = metaRowStart + metadata.length;\r\n\r\n    worksheet.getRow(++currentRow).height = 6;\r\n    currentRow++;\r\n\r\n    // ===================== SEARCH CRITERIA =====================\r\n    worksheet.mergeCells(currentRow, 1, currentRow, 6);\r\n    worksheet.getCell(currentRow, 1).value = 'Search Criteria:-';\r\n    worksheet.getCell(currentRow, 1).font = { bold: true };\r\n    currentRow += 2;\r\n\r\n    for (let i = 0; i < searchCriteria.length; i += 2) {\r\n      const left = searchCriteria[i];\r\n      const right = searchCriteria[i + 1];\r\n\r\n      const row = worksheet.getRow(currentRow++);\r\n\r\n      worksheet.mergeCells(row.number, 1, row.number, 3);\r\n      row.getCell(1).value = {\r\n        richText: [\r\n          { text: (left?.[0] ?? '') + ' ', font: { bold: true } },\r\n          { text: left?.[1] ?? '' }\r\n        ]\r\n      };\r\n      row.getCell(1).alignment = { wrapText: true, vertical: 'middle' };\r\n\r\n      if (right) {\r\n        worksheet.mergeCells(row.number, 4, row.number, 6);\r\n        row.getCell(4).value = {\r\n          richText: [\r\n            { text: (right?.[0] ?? '') + ' ', font: { bold: true } },\r\n            { text: right?.[1] ?? '' }\r\n          ]\r\n        };\r\n        row.getCell(4).alignment = { wrapText: true, vertical: 'middle' };\r\n      }\r\n    }\r\n\r\n    currentRow++;\r\n\r\n    // ===================== HEADER ROW =====================\r\n    const headerRow = worksheet.getRow(currentRow++);\r\n\r\n    headerLabels.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 = {\r\n        type: 'pattern',\r\n        pattern: 'solid',\r\n        fgColor: { argb: 'D9D9D9' }\r\n      };\r\n      cell.alignment = { vertical: 'middle', horizontal: 'center' };\r\n      cell.border = {\r\n        top: { style: 'thin' },\r\n        bottom: { style: 'thin' },\r\n        left: { style: 'thin' },\r\n        right: { style: 'thin' }\r\n      };\r\n    });\r\n    headerRow.eachCell((cell) => {\r\n      if (cell.value === 'Transaction Count') {\r\n        cell.value = 'Transaction\\nCount';\r\n        cell.alignment = {\r\n          horizontal: 'center',\r\n          vertical: 'middle',\r\n          wrapText: true\r\n        };\r\n      }\r\n    });\r\n    // ===================== DATA SECTION =====================\r\n    let rowIdx = currentRow;\r\n    let serialNumber = 1;\r\n\r\n    if (options.groupByKey && !Array.isArray(data)) {\r\n\r\n      for (const [group, items] of Object.entries(data)) {\r\n\r\n        const groupRow = worksheet.getRow(rowIdx++);\r\n        groupRow.getCell(1).value = group;\r\n        groupRow.font = { bold: true };\r\n        worksheet.mergeCells(`A${groupRow.number}:${titleMergeEnd}${groupRow.number}`);\r\n\r\n        items.forEach((item) => {\r\n\r\n          const rowData = this.prepareTableRows([item], columns, options)[0];\r\n          const dataRow = worksheet.getRow(rowIdx++);\r\n\r\n          const fullRow = [\r\n            !item?.isTotalRow ? serialNumber++ : '',\r\n            ...rowData\r\n          ];\r\n\r\n          fullRow.forEach((val, cIdx) => {\r\n            const cell = dataRow.getCell(cIdx + 1);\r\n            //   cell.value = val;\r\n            //added by bharati for \r\n            const field = columns[cIdx - 1]?.field;\r\n\r\n            // ✅ Amount fields (Receive Amount, Send Amount, Total Send Amount etc.)\r\n            /*\r\n            if (\r\n              field=='totalPayinAmount'||\r\n              field=='payinAmount'||\r\n              field === 'transactionCommissionAmount' ||\r\n              field === 'tax'\r\n            ) {\r\n                        if (val !== '' && val !== null && val !== undefined) {\r\n                            cell.value = Number(val);\r\n                            cell.numFmt = '#,##0.000';\r\n                            cell.alignment = { horizontal: 'right', vertical: 'middle' };\r\n                        } else {\r\n                            cell.value = '';\r\n                        }\r\n                    }\r\n            else {\r\n              cell.value = val;\r\n            } */\r\n\r\n            if (item?.isTotalRow && field === 'receiveAmount') {\r\n              cell.value = '';\r\n            }\r\n            else if (\r\n              field?.toLowerCase().includes('amount') ||\r\n              field === 'serviceFee' ||\r\n              field === 'tax'\r\n            ) {\r\n              if (val !== '' && val !== null && val !== undefined) {\r\n                cell.value = val;                // already number\r\n                cell.numFmt = '#,##0.000';       // Excel formatting\r\n                cell.alignment = { horizontal: 'right', vertical: 'middle' };\r\n              } else {\r\n                cell.value = '';\r\n              }\r\n            }\r\n            else {\r\n              cell.value = val;\r\n            }\r\n            cell.border = {\r\n              top: { style: 'thin' },\r\n              bottom: { style: 'thin' },\r\n              left: { style: 'thin' },\r\n              right: { style: 'thin' }\r\n            };\r\n          });\r\n\r\n          if (item?.isTotalRow) {\r\n            dataRow.eachCell(cell => {\r\n               cell.font = {\r\n                ...cell.font,\r\n                bold: true,\r\n                size: 12\r\n              };\r\n            });\r\n          }\r\n        });\r\n      }\r\n\r\n    } else {\r\n\r\n      this.prepareTableRows(data as any[], columns, options)\r\n        .forEach((rowData, index) => {\r\n\r\n          const dataRow = worksheet.getRow(rowIdx++);\r\n          const originalItem = (data as any[])[index];\r\n\r\n          const fullRow = [\r\n            !originalItem?.isTotalRow ? serialNumber++ : '',\r\n            ...rowData\r\n          ];\r\n\r\n          fullRow.forEach((val, cIdx) => {\r\n            const cell = dataRow.getCell(cIdx + 1);\r\n            //cell.value = val;\r\n            /*   if (cIdx === 0) {\r\n cell.value = val;\r\n} else {\r\n\r\n const field = columns[cIdx - 1]?.field;\r\n\r\n if (\r\n     field=='totalPayinAmount'||\r\n     field=='payinAmount'||\r\n     field === 'transactionCommissionAmount' ||\r\n     field === 'tax'\r\n ) {\r\n     cell.value = Number(val);\r\n     cell.numFmt = '#,##0.000';\r\n     cell.alignment = { horizontal: 'right', vertical: 'middle' };\r\n }\r\n else {\r\n     cell.value = val;\r\n }\r\n} */\r\n\r\n            const field = columns[cIdx - 1]?.field;\r\n\r\n            if (cIdx === 0) {\r\n              cell.value = val;\r\n            }\r\n            else if (originalItem?.isTotalRow && field === 'receiveAmount') {\r\n              cell.value = '';\r\n            }\r\n            else if (\r\n              field?.toLowerCase().includes('amount') ||\r\n              field === 'serviceFee' ||\r\n              field === 'tax'\r\n            ) {\r\n              if (val !== '' && val !== null && val !== undefined) {\r\n                cell.value = val;                // already number\r\n                cell.numFmt = '#,##0.000';       // Excel formatting\r\n                cell.alignment = { horizontal: 'right', vertical: 'middle' };\r\n              } else {\r\n                cell.value = '';\r\n              }\r\n            }\r\n            else {\r\n              cell.value = val;\r\n            }\r\n\r\n            cell.border = {\r\n              top: { style: 'thin' },\r\n              bottom: { style: 'thin' },\r\n              left: { style: 'thin' },\r\n              right: { style: 'thin' }\r\n            };\r\n          });\r\n\r\n          if (originalItem?.isTotalRow) {\r\n            dataRow.eachCell(cell => {\r\n               cell.font = {\r\n                ...cell.font,\r\n                bold: true,\r\n                size: 12\r\n              };\r\n            });\r\n          }\r\n        });\r\n    }\r\n\r\n    // ===================== AUTO WIDTH =====================\r\n    for (let i = 1; i <= totalCols; i++) {\r\n      let maxLength = 10;\r\n\r\n      worksheet.eachRow({ includeEmpty: true }, (row) => {\r\n        const cell = row.getCell(i);\r\n        if (cell.isMerged) return;\r\n\r\n        let cellValue = '';\r\n\r\n        if (cell.value == null) {\r\n          cellValue = '';\r\n        } else if (typeof cell.value === 'object' && 'richText' in cell.value) {\r\n          cellValue = cell.value.richText.map(rt => rt.text).join('');\r\n        } else {\r\n          cellValue = cell.value.toString();\r\n        }\r\n\r\n        maxLength = Math.max(maxLength, cellValue.length);\r\n      });\r\n\r\n      worksheet.getColumn(i).width = Math.min(maxLength, 50);\r\n    }\r\n    //new code:bharati\r\n\r\n    worksheet.columns.forEach((column, index) => {\r\n\r\n      if (index === 0) return; // skip Sr No\r\n\r\n      const field = columns[index - 1]?.field;\r\n\r\n      if (field === 'payinAmount') {\r\n        column.width = 14;\r\n      }\r\n      if (field === 'payoutAmount') {\r\n        column.width = 15;\r\n      }\r\n      if (field === 'transactionCount') {\r\n        column.width = 14;\r\n      }\r\n    });\r\n\r\n    // worksheet.columns.forEach((column) => {\r\n    //   if (column.header === 'Send Amount') {\r\n    //     column.width = 25;\r\n    //   }\r\n    // });\r\n\r\n\r\n    // ===================== SAVE FILE =====================\r\n    const buffer = await workbook.xlsx.writeBuffer();\r\n\r\n    FileSaver.saveAs(\r\n      new Blob([buffer], {\r\n        type: 'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet'\r\n      }),\r\n      title.replace(/\\s/g, '-') + '.xlsx'\r\n    );\r\n  }\r\n\r\n  //   private prepareTableRows(data: any[], columns: any[], options: ExportOptions = {}): any[][] {\r\n  //           const {\r\n  //               excludeFields = [],\r\n  //               currencyFields = [],\r\n  //               dateFields = [],\r\n  //               dateFieldFormats = {},\r\n  //               specialDecimalFields = {}\r\n  //           } = options;\r\n\r\n  //           const filtered = columns.filter(c =>\r\n  //               c.field && !excludeFields.some(f => c.field.toLowerCase().includes(f))\r\n  //           );\r\n\r\n  //         return data.map((row) => ([\r\n  // ...filtered.map(col => {\r\n  //                   let value = row[col.field];\r\n  //                   // Format date fields with custom formats if specified\r\n  //                   if (col.field && (dateFields.includes(col.field) || col.field in dateFieldFormats)) {\r\n  //                       const format = dateFieldFormats[col.field] || 'dd/MM/yyyy';\r\n  //                       value = this.formatDateByFormat(value, format);\r\n  //                   }\r\n  //                   // Format special decimal fields with specific decimals\r\n  //                   else if (col.field && col.field in specialDecimalFields && value != null) {\r\n  //                       const decimals = specialDecimalFields[col.field];\r\n  //                       value = parseFloat(value).toFixed(decimals);\r\n  //                   }\r\n  //                   // Format regular currency fields with 3 decimals\r\n  //                   else if (col.field && currencyFields.includes(col.field) && value != null) {\r\n  //                       value = parseFloat(value).toFixed(3);\r\n  //                   }\r\n\r\n  //                   return value ?? '';\r\n  //               })\r\n  //           ]));\r\n  //       }\r\n  private prepareTableRows(\r\n    data: any[],\r\n    columns: any[],\r\n    options: ExportOptions = {}\r\n  ): any[][] {\r\n\r\n    const {\r\n      excludeFields = [],\r\n      currencyFields = [],\r\n      dateFields = [],\r\n      dateFieldFormats = {},\r\n      specialDecimalFields = {}\r\n    } = options;\r\n\r\n    const filtered = columns.filter(c =>\r\n      c.field && !excludeFields.some(f => c.field.toLowerCase().includes(f))\r\n    );\r\n\r\n    return data.map((row) => ([\r\n      ...filtered.map(col => {\r\n\r\n        let value = row[col.field];\r\n\r\n        // ✅ Date formatting (keep as string)\r\n        if (\r\n          col.field &&\r\n          (dateFields.includes(col.field) || col.field in dateFieldFormats)\r\n        ) {\r\n          const format = dateFieldFormats[col.field] || 'dd/MM/yyyy';\r\n          value = this.formatDateByFormat(value, format);\r\n        }\r\n\r\n        // ✅ Special decimal fields → return NUMBER (no toFixed)\r\n        else if (\r\n          col.field &&\r\n          col.field in specialDecimalFields &&\r\n          value != null\r\n        ) {\r\n          value = Number(value);\r\n        }\r\n\r\n        // ✅ Currency fields → return NUMBER (no toFixed)\r\n        else if (\r\n          col.field &&\r\n          currencyFields.includes(col.field) &&\r\n          value != null\r\n        ) {\r\n          value = Number(value);\r\n        }\r\n\r\n        return value ?? '';\r\n      })\r\n    ]));\r\n  }\r\n  private formatDateByFormat(val: any, format: string): string {\r\n    // Helper to pad single digits\r\n    const pad = (n: number) => n.toString().padStart(2, '0');\r\n\r\n    // Parse date for \"DD/MM/YYYY hh:mm AM/PM\" format manually\r\n    if (typeof val === 'string' && /^\\d{2}\\/\\d{2}\\/\\d{4} \\d{2}:\\d{2} [AP]M$/.test(val)) {\r\n\r\n      const parts = val.match(/^(\\d{2})\\/(\\d{2})\\/(\\d{4}) (\\d{2}):(\\d{2}) ([AP]M)$/);\r\n      if (!parts) return '';\r\n      let [, dd, mm, yyyy, hh, min, ampm] = parts;\r\n      let hours = parseInt(hh, 10);\r\n      if (ampm === 'PM' && hours !== 12) hours += 12;\r\n      if (ampm === 'AM' && hours === 12) hours = 0;\r\n      val = new Date(parseInt(yyyy, 10), parseInt(mm, 10) - 1, parseInt(dd, 10), hours, parseInt(min, 10));\r\n    } else {\r\n      val = new Date(val);\r\n    }\r\n\r\n    if (isNaN(val.getTime())) return '';\r\n\r\n    const dt = val;\r\n\r\n    switch (format) {\r\n      case 'dd/MM/yyyy hh:mm a': { // 11/07/2025 10:56 PM\r\n        let hours12 = dt.getHours() % 12 || 12;\r\n        let ampm = dt.getHours() >= 12 ? 'PM' : 'AM';\r\n        return `${pad(dt.getDate())}/${pad(dt.getMonth() + 1)}/${dt.getFullYear()} ${pad(hours12)}:${pad(dt.getMinutes())} ${ampm}`;\r\n      }\r\n      case 'dd/MM/yyyy HH:mm': { // 28/07/2025 13:08\r\n        return `${pad(dt.getDate())}/${pad(dt.getMonth() + 1)}/${dt.getFullYear()} ${pad(dt.getHours())}:${pad(dt.getMinutes())}`;\r\n      }\r\n      case 'dd/MM/yyyy': { // 28/07/2025\r\n        return `${pad(dt.getDate())}/${pad(dt.getMonth() + 1)}/${dt.getFullYear()}`;\r\n      }\r\n      default:\r\n        return dt.toLocaleString();\r\n    }\r\n  }\r\n\r\n  dateValueFormatter(format: string) {\r\n    return (params: any) => {\r\n      if (!params.value) return '';\r\n      try {\r\n        return formatDate(params.value, format, 'en-US');\r\n      } catch {\r\n        return '';\r\n      }\r\n    }\r\n  }\r\n\r\n  getKeys(obj: Record<string, unknown>): string[] {\r\n    return obj ? Object.keys(obj) : [];\r\n  }\r\n\r\n  hasAnyGroups(): boolean {\r\n    return this.filteredData && this.getKeys(this.filteredData).length > 0;\r\n  }\r\n\r\n  formatAmount(params: any): string {\r\n    const value = params?.value;\r\n    if (value !== null && value !== undefined && value !== '') {\r\n      const num = Number(value);\r\n      return (Math.trunc(num * 1000) / 1000).toFixed(3);\r\n    }\r\n    return '';\r\n  }\r\n\r\n  handleSearch(criteria: any): void {\r\n    this.searchCriteria = criteria.searchCriteria;\r\n    this.reportDate = new Date().toISOString();\r\n    this.reportDate = formatDate(this.reportDate, 'dd/MM/yyyy hh:mm a', 'en-US');\r\n    const modal = criteria.modal;\r\n    this.user = criteria.sysUserID;\r\n    this.fromDate = formatDate(modal.fromDate, 'dd/MM/yyyy hh:mm a', 'en-US').slice(0, 10);\r\n    this.toDate = formatDate(modal.toDate, 'dd/MM/yyyy hh:mm a', 'en-US').slice(0, 10);\r\n    console.log(modal);\r\n    // Code For Meta Data\r\n    this.leftData = {\r\n      'Report Period': this.fromDate + \" - \" + this.toDate,\r\n    }\r\n\r\n    this.metaDataTwo = {\r\n      'Report User & Time': this.user + \" @ \" + this.reportDate,\r\n    }\r\n    const isTotalSummary = modal.summaryReport === 'Total Summary';\r\n    this.isTotalSummary = isTotalSummary;\r\n\r\n    const searchData = {\r\n      \"StartDate\": modal.fromDate,\r\n      \"EndDate\": modal.toDate,\r\n      \"SendCountryCode\": modal.sendCountry,\r\n      \"RecvCountryCode\": modal.receiveCountry,\r\n      \"BusinessPartnerCode\": modal.client,\r\n      \"TransactionStatus\": modal.transactionStatus.join(\",\"),\r\n      \"PayoutCurrency\": modal.receiveCurrency,\r\n      \"TransactionType\": modal.product,\r\n      \"BranchCode\": modal.branch,\r\n      \"SummaryReport\": modal.summaryReport\r\n\r\n    };\r\n    this.showMessage = true;\r\n    this.clearSearch = true;\r\n    this.loadingState = ComponentLoadingStates.Loading;\r\n    this.reportService.getBranchActivitySendSummaryReport(searchData).subscribe({\r\n      next: (data) => {\r\n        console.log(data);\r\n        this.dataMap = JSON.parse(JSON.stringify(data));\r\n        this.filteredData = data;\r\n        this.noDataFound = Object.keys(this.filteredData).length == 0 ? true : false;\r\n        this.proxyData = structuredClone(data);\r\n        this.paginationArray = new Array(Object.keys(this.filteredData).length).fill(15);\r\n        this.showMessage = Object.keys(this.filteredData).length == 0 ? true : false;\r\n        this.showReport = true;\r\n      },\r\n\r\n      error: (err) => {\r\n        this.loadingState = ComponentLoadingStates.Complete;\r\n        this.clearSearch = false;\r\n      },\r\n\r\n      complete: () => {\r\n        this.loadingState = ComponentLoadingStates.Complete;\r\n        this.showReport = true;\r\n        this.clearSearch = false;\r\n      }\r\n    })\r\n  }\r\n\r\n  handleFormValid(isValid: boolean): void {\r\n    this.isFormValid = isValid;\r\n  }\r\n\r\n}\r\n\r\n","<lib-search-filter \r\n    [ReportName]=\"ReportName\" \r\n    (searchClicked)=\"handleSearch($event)\"\r\n    (formValid)=\"handleFormValid($event)\">\r\n</lib-search-filter >\r\n<app-loader class=\"\" *ngIf=\"loadingState == ComponentLoadingState.Loading\"></app-loader>\r\n\r\n<section *ngIf=\"showReport && isFormValid && !clearSearch\" class=\"my-2\">\r\n  <ng-container *ngIf=\"!noDataFound\">\r\n     <lib-metadata [reportName]=\"ReportName\" [showmetaDataOne]=\"true\" [showmetaDataTwo]=\"true\" [metaDataOne]=\"leftData\" [metaDataTwo]=\"metaDataTwo\"(exportEvent)=\"handleExport($event)\" (searchEvent)=\"filter($event)\"></lib-metadata>\r\n\r\n  <ngb-accordion #acc=\"ngbAccordion\" [closeOthers]=\"false\">\r\n    <ng-container *ngFor=\"let item of filteredData | keyvalue; let i = index\">\r\n      <ngb-panel *ngIf=\"item.value.length > 0\" [id]=\"'panel-' + i\">\r\n\r\n        <ng-template ngbPanelTitle style=\"height: 10%;\">\r\n          <label\r\n            class=\"panel-cls\">{{\r\n            item.key\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]=\"item?.value?.length\"\r\n            [defaultSize]=\"'15'\" [gridApi]=\"gridApis[i]\">\r\n            ></lib-page-size-selector>\r\n\r\n            <ag-grid-angular class=\"ag-theme-alpine transaction-grid\" style=\"width: 100%;height: 380px;\"\r\n              [columnDefs]=\"columnDefs\" \r\n              [defaultColDef]=\"defaultColDef\" \r\n              [rowData]=\"item.value\" \r\n              [rowHeight]=\"20\"\r\n              [headerHeight]=\"22\"\r\n              [pagination]=\"true\" \r\n              [paginationPageSize]=\"paginationArray[i]\" \r\n              [rowClassRules]=\"rowClassRules\"\r\n              (gridReady)=\"onGridReady($event,i)\"\r\n              >\r\n            </ag-grid-angular>\r\n          </div>\r\n        </ng-template>\r\n\r\n      </ngb-panel>\r\n    </ng-container>\r\n  </ngb-accordion>\r\n  </ng-container>\r\n  <div class=\"alert alert-warning mt-3\" *ngIf=\"noDataFound\">\r\n    No Data found matching your search criteria.\r\n  </div>\r\n</section>"]}