@sachin9822/reports-lib 0.0.143 → 0.0.145
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.
- package/esm2020/lib/components/acc-gl-details-enquiry-report/acc-gl-details-enquiry-report.component.mjs +4 -4
- package/esm2020/lib/components/branch-activity-send-report/branch-activity-send-report.component.mjs +54 -428
- package/esm2020/lib/components/transaction-enquiry-report/transaction-enquiry-report.component.mjs +17 -9
- package/esm2020/lib/reports-lib.module.mjs +1 -4
- package/esm2020/lib/shared/search-filter/search-filter.component.mjs +215 -55
- package/fesm2015/sachin9822-reports-lib.mjs +284 -501
- package/fesm2015/sachin9822-reports-lib.mjs.map +1 -1
- package/fesm2020/sachin9822-reports-lib.mjs +281 -493
- package/fesm2020/sachin9822-reports-lib.mjs.map +1 -1
- package/lib/components/branch-activity-send-report/branch-activity-send-report.component.d.ts +11 -11
- package/lib/components/transaction-enquiry-report/transaction-enquiry-report.component.d.ts +5 -2
- package/lib/reports-lib.module.d.ts +6 -6
- package/lib/shared/search-filter/search-filter.component.d.ts +10 -1
- package/package.json +1 -1
- package/lib/assets/config/app-config.frontend.json +0 -38
- package/lib/assets/config/app-config.release.json +0 -3
|
@@ -2,6 +2,8 @@ import { Component, EventEmitter, Input, Output } from '@angular/core';
|
|
|
2
2
|
import { FormArray, FormGroup, Validators } from '@angular/forms';
|
|
3
3
|
import { ComponentLoadingState } from '../../models/transaction-enquiry-report/transaction-enquiry.model';
|
|
4
4
|
import { Subject } from 'rxjs';
|
|
5
|
+
import { forkJoin, of } from 'rxjs';
|
|
6
|
+
import { catchError, map } from 'rxjs/operators';
|
|
5
7
|
import { takeUntil } from 'rxjs/operators';
|
|
6
8
|
import * as i0 from "@angular/core";
|
|
7
9
|
import * as i1 from "../../services/report.service";
|
|
@@ -31,6 +33,7 @@ export class SearchFilterComponent {
|
|
|
31
33
|
this.companyCode = 'BH';
|
|
32
34
|
this.userReportDefaults = null;
|
|
33
35
|
this.companyReportConfig = null;
|
|
36
|
+
this.isOpen = false;
|
|
34
37
|
this.clients1 = [];
|
|
35
38
|
this.branches = [];
|
|
36
39
|
this.users = [];
|
|
@@ -40,12 +43,14 @@ export class SearchFilterComponent {
|
|
|
40
43
|
this.selectedStatuses = [];
|
|
41
44
|
this.showStatusDropdown = false;
|
|
42
45
|
this.visibleFieldKeys = [];
|
|
46
|
+
this.countries = [];
|
|
47
|
+
this.transactionProducts = [];
|
|
43
48
|
this.dateType = 1;
|
|
44
49
|
// Field visibility map, 'fromDate', 'toDate','product','userId','currency','transactionStatus','transactionNo'
|
|
45
50
|
this.visibleFieldsMap = {
|
|
46
|
-
'Transaction Enquiry': ['client', 'fromDate', 'toDate', 'branch', 'product', 'currency', '
|
|
51
|
+
'Transaction Enquiry': ['client', 'fromDate', 'toDate', 'branch', 'product', 'currency', 'transactionStatus', 'transactionNo'],
|
|
47
52
|
'FC Ledger': ['client', 'fromDate', 'toDate', 'currency', 'product'],
|
|
48
|
-
'Branch Activity': ['branch', '
|
|
53
|
+
'Branch Activity Send': ['client', 'fromDate', 'toDate', 'branch', 'transactionProduct', 'currency', 'transactionStatus', 'sendCountry', 'receiveCountry'],
|
|
49
54
|
'ACC GL Details Enquiry': ['dateType', 'date'],
|
|
50
55
|
// Add more report types here
|
|
51
56
|
};
|
|
@@ -57,9 +62,10 @@ export class SearchFilterComponent {
|
|
|
57
62
|
else if (ezremitUser)
|
|
58
63
|
this.currentUser = ezremitUser;
|
|
59
64
|
else {
|
|
60
|
-
this.currentUser = 'vipul.katale@xpressmoney.tech';
|
|
65
|
+
// this.currentUser = 'vipul.katale@xpressmoney.tech';
|
|
61
66
|
this.usernameMissing = true;
|
|
62
67
|
}
|
|
68
|
+
this.currentUser = this.currentUser.replace(/^["'](.*)["']$/, '$1');
|
|
63
69
|
}
|
|
64
70
|
get visibleFields() {
|
|
65
71
|
return this.visibleFieldsMap[this.ReportName] || [];
|
|
@@ -81,6 +87,11 @@ export class SearchFilterComponent {
|
|
|
81
87
|
this.subscribeToDateChanges();
|
|
82
88
|
this.loadInitialData();
|
|
83
89
|
}
|
|
90
|
+
if (this.ReportName == "Branch Activity Send") {
|
|
91
|
+
this.initializeForm();
|
|
92
|
+
this.loadInitialData();
|
|
93
|
+
this.subscribeToDateChanges();
|
|
94
|
+
}
|
|
84
95
|
if (this.ReportName == "ACC GL Details Enquiry") {
|
|
85
96
|
this.initializeForm();
|
|
86
97
|
}
|
|
@@ -89,17 +100,20 @@ export class SearchFilterComponent {
|
|
|
89
100
|
if (this.ReportName == 'Transaction Enquiry') {
|
|
90
101
|
this.loadInitialDatafortxnEnquiry();
|
|
91
102
|
}
|
|
103
|
+
if (this.ReportName == "Branch Activity Send") {
|
|
104
|
+
this.loadInitialDataforBranchActivitySend();
|
|
105
|
+
}
|
|
92
106
|
}
|
|
93
107
|
initializeForm() {
|
|
94
108
|
if (this.ReportName == "Transaction Enquiry") {
|
|
95
109
|
this.searchForm = this.fb.group({
|
|
96
|
-
client: [
|
|
110
|
+
client: [null, Validators.required],
|
|
97
111
|
fromDate: [new Date().toISOString().split("T")[0], Validators.required],
|
|
98
112
|
toDate: [new Date().toISOString().split("T")[0], Validators.required],
|
|
99
|
-
branch: [
|
|
113
|
+
branch: [null, Validators.required],
|
|
100
114
|
userId: ['-1'],
|
|
101
115
|
currency: ['All'],
|
|
102
|
-
product: [
|
|
116
|
+
product: [null, Validators.required],
|
|
103
117
|
transactionStatus: [['All'], Validators.required],
|
|
104
118
|
transactionNo: [''],
|
|
105
119
|
cardNo: [''],
|
|
@@ -120,6 +134,59 @@ export class SearchFilterComponent {
|
|
|
120
134
|
dateType: [1, Validators.required]
|
|
121
135
|
});
|
|
122
136
|
}
|
|
137
|
+
if (this.ReportName == "Branch Activity Send") {
|
|
138
|
+
this.searchForm = this.fb.group({
|
|
139
|
+
client: [null, Validators.required],
|
|
140
|
+
fromDate: [new Date().toISOString().split("T")[0], Validators.required],
|
|
141
|
+
toDate: [new Date().toISOString().split("T")[0], Validators.required],
|
|
142
|
+
branch: [null, Validators.required],
|
|
143
|
+
currency: ['All'],
|
|
144
|
+
product: ['All', Validators.required],
|
|
145
|
+
transactionStatus: [['All'], Validators.required],
|
|
146
|
+
sendCountry: ['All'],
|
|
147
|
+
receiveCountry: ['All']
|
|
148
|
+
});
|
|
149
|
+
}
|
|
150
|
+
}
|
|
151
|
+
loadInitialDataforBranchActivitySend() {
|
|
152
|
+
this.loadingState = ComponentLoadingState.Loading;
|
|
153
|
+
forkJoin({
|
|
154
|
+
params: this.reportService.getParams().pipe(catchError(err => {
|
|
155
|
+
console.error('Error loading params', err);
|
|
156
|
+
return of(null);
|
|
157
|
+
})),
|
|
158
|
+
clients: this.reportService.getPayInAgents(this.currentUser).pipe(map((clients) => clients.map((client, index) => ({
|
|
159
|
+
businessPartnerName: client.agent,
|
|
160
|
+
businessPartnerCode: client.code,
|
|
161
|
+
displayOrder: index // or use some value from the API if available
|
|
162
|
+
}))), catchError(err => {
|
|
163
|
+
console.error('Error loading clients', err);
|
|
164
|
+
return of([]);
|
|
165
|
+
}))
|
|
166
|
+
}).subscribe({
|
|
167
|
+
next: ({ params, clients }) => {
|
|
168
|
+
this.params = params;
|
|
169
|
+
this.clients1 = clients;
|
|
170
|
+
// this.clientsData = [...clients];
|
|
171
|
+
this.countries = [...params?.countries];
|
|
172
|
+
this.currencies = [...params?.currencies];
|
|
173
|
+
this.transactionStatuses = [...params?.transactionStatusTypes];
|
|
174
|
+
this.transactionProducts = [...params?.transactionProductTypes];
|
|
175
|
+
if (!sessionStorage.getItem('fossilusername') && this.clients1?.length) {
|
|
176
|
+
this.selectClient(this.clients1[0].businessPartnerCode);
|
|
177
|
+
}
|
|
178
|
+
// this.loadingState = ComponentLoadingStates.Complete;
|
|
179
|
+
},
|
|
180
|
+
error: err => {
|
|
181
|
+
// Occurs only if an inner catchError still rethrows
|
|
182
|
+
console.error('Unexpected forkJoin error', err);
|
|
183
|
+
this.loadingState = ComponentLoadingState.Complete;
|
|
184
|
+
},
|
|
185
|
+
complete: () => {
|
|
186
|
+
this.loadingState = ComponentLoadingState.Complete;
|
|
187
|
+
this.onClientSelected();
|
|
188
|
+
}
|
|
189
|
+
});
|
|
123
190
|
}
|
|
124
191
|
async loadInitialDatafortxnEnquiry() {
|
|
125
192
|
this.loadingState = ComponentLoadingState.Loading;
|
|
@@ -163,8 +230,10 @@ export class SearchFilterComponent {
|
|
|
163
230
|
const toDate = new Date(toDateStr);
|
|
164
231
|
const maxToDate = new Date(fromDate);
|
|
165
232
|
maxToDate?.setDate(fromDate.getDate() + 31);
|
|
166
|
-
if (toDate > maxToDate) {
|
|
233
|
+
if (toDate.setHours(0, 0, 0, 0) > maxToDate.setHours(0, 0, 0, 0) || toDate.setHours(0, 0, 0, 0) < fromDate.setHours(0, 0, 0, 0)) {
|
|
234
|
+
maxToDate.setHours(12, 0, 0, 0);
|
|
167
235
|
toDateControl?.patchValue(maxToDate.toISOString().split("T")[0]);
|
|
236
|
+
console.log(toDateControl);
|
|
168
237
|
}
|
|
169
238
|
});
|
|
170
239
|
this.searchForm.get('toDate')?.valueChanges.subscribe(toDateStr => {
|
|
@@ -176,7 +245,8 @@ export class SearchFilterComponent {
|
|
|
176
245
|
const fromDate = new Date(fromDateStr);
|
|
177
246
|
const minFromDate = new Date(toDate);
|
|
178
247
|
minFromDate?.setDate(toDate.getDate() - 31);
|
|
179
|
-
if (fromDate < minFromDate) {
|
|
248
|
+
if (fromDate.setHours(0, 0, 0, 0) < minFromDate.setHours(0, 0, 0, 0)) {
|
|
249
|
+
minFromDate.setHours(12, 0, 0, 0);
|
|
180
250
|
fromDateControl?.patchValue(minFromDate.toISOString().split("T")[0]);
|
|
181
251
|
}
|
|
182
252
|
});
|
|
@@ -189,8 +259,8 @@ export class SearchFilterComponent {
|
|
|
189
259
|
}
|
|
190
260
|
}
|
|
191
261
|
async onClientChange() {
|
|
192
|
-
this.loadingState = ComponentLoadingState.Loading;
|
|
193
262
|
if (this.ReportName == "Transaction Enquiry") {
|
|
263
|
+
this.loadingState = ComponentLoadingState.Loading;
|
|
194
264
|
const selectedClient = this.searchForm.get('client')?.value;
|
|
195
265
|
if (!selectedClient)
|
|
196
266
|
return;
|
|
@@ -203,6 +273,7 @@ export class SearchFilterComponent {
|
|
|
203
273
|
this.loadBranchesByAgent(selectedClient),
|
|
204
274
|
this.loadProductsByAgent(selectedClient),
|
|
205
275
|
]);
|
|
276
|
+
this.searchForm.patchValue({ product: 'All' });
|
|
206
277
|
this.loadingState = ComponentLoadingState.Complete;
|
|
207
278
|
}
|
|
208
279
|
catch (err) {
|
|
@@ -210,6 +281,32 @@ export class SearchFilterComponent {
|
|
|
210
281
|
this.loadingState = ComponentLoadingState.Complete;
|
|
211
282
|
}
|
|
212
283
|
}
|
|
284
|
+
if (this.ReportName == "Branch Activity Send") {
|
|
285
|
+
const selectedClient = this.searchForm.get('client')?.value;
|
|
286
|
+
if (!selectedClient)
|
|
287
|
+
return;
|
|
288
|
+
this.loadingState = ComponentLoadingState.Loading;
|
|
289
|
+
this.reportService.getBranchByAgent(this.currentUser, selectedClient).subscribe({
|
|
290
|
+
next: (data) => {
|
|
291
|
+
this.branches = data;
|
|
292
|
+
},
|
|
293
|
+
error: (err) => {
|
|
294
|
+
this.loadingState = ComponentLoadingState.Complete;
|
|
295
|
+
},
|
|
296
|
+
complete: () => {
|
|
297
|
+
if (sessionStorage.getItem("ezremitusername")) {
|
|
298
|
+
const index = this.branches.findIndex((branch) => branch.branchCode === "All");
|
|
299
|
+
if (index == -1) {
|
|
300
|
+
this.searchForm.controls['branch'].setValue(this.branches[0].branchCode);
|
|
301
|
+
}
|
|
302
|
+
else {
|
|
303
|
+
this.searchForm.controls['branch'].setValue('All');
|
|
304
|
+
}
|
|
305
|
+
}
|
|
306
|
+
this.loadingState = ComponentLoadingState.Complete;
|
|
307
|
+
}
|
|
308
|
+
});
|
|
309
|
+
}
|
|
213
310
|
}
|
|
214
311
|
async loadBranchesByAgent(agentCode) {
|
|
215
312
|
const branches = await this.reportService
|
|
@@ -219,11 +316,11 @@ export class SearchFilterComponent {
|
|
|
219
316
|
this.branches = branches || [];
|
|
220
317
|
if (this.branches.length === 1) {
|
|
221
318
|
this.searchForm.patchValue({ branch: this.branches[0].branchCode });
|
|
222
|
-
await this.loadUsersByBranch(agentCode, this.branches[0].branchCode);
|
|
319
|
+
// await this.loadUsersByBranch(agentCode, this.branches[0].branchCode);
|
|
223
320
|
}
|
|
224
321
|
else if (this.branches.some(b => b.branchCode === 'All')) {
|
|
225
322
|
this.searchForm.patchValue({ branch: 'All' });
|
|
226
|
-
await this.loadUsersByBranch(agentCode, 'All');
|
|
323
|
+
// await this.loadUsersByBranch(agentCode, 'All');
|
|
227
324
|
}
|
|
228
325
|
else {
|
|
229
326
|
this.searchForm.patchValue({ branch: '' });
|
|
@@ -238,48 +335,47 @@ export class SearchFilterComponent {
|
|
|
238
335
|
this.products = products || [];
|
|
239
336
|
}
|
|
240
337
|
async onBranchChange() {
|
|
241
|
-
this.
|
|
242
|
-
|
|
243
|
-
|
|
244
|
-
|
|
245
|
-
|
|
246
|
-
|
|
247
|
-
|
|
248
|
-
|
|
249
|
-
|
|
250
|
-
|
|
251
|
-
|
|
252
|
-
|
|
253
|
-
}
|
|
254
|
-
}
|
|
255
|
-
async loadUsersByBranch(agentCode, branchCode) {
|
|
256
|
-
return new Promise((resolve, reject) => {
|
|
257
|
-
this.reportService
|
|
258
|
-
.getUsersByBranch(agentCode, branchCode)
|
|
259
|
-
.pipe(takeUntil(this.destroy$))
|
|
260
|
-
.subscribe({
|
|
261
|
-
next: (users) => {
|
|
262
|
-
this.users = users || [];
|
|
263
|
-
// Try to find a user indicating "All"
|
|
264
|
-
const allUser = this.users.find(u => u.userName === 'All' || u.userId === -1);
|
|
265
|
-
if (allUser) {
|
|
266
|
-
// If "All" is present, select it
|
|
267
|
-
this.searchForm.patchValue({ userId: allUser.userId });
|
|
268
|
-
}
|
|
269
|
-
else if (this.users.length === 1) {
|
|
270
|
-
// If only one user, select that user
|
|
271
|
-
this.searchForm.patchValue({ userId: this.users[0].userId });
|
|
272
|
-
}
|
|
273
|
-
else {
|
|
274
|
-
// Otherwise, clear user selection
|
|
275
|
-
this.searchForm.patchValue({ userId: '' });
|
|
276
|
-
}
|
|
277
|
-
resolve();
|
|
278
|
-
},
|
|
279
|
-
error: (err) => reject(err),
|
|
280
|
-
});
|
|
281
|
-
});
|
|
338
|
+
// if (this.ReportName == "Transaction Enquiry") {
|
|
339
|
+
// this.loadingState = ComponentLoadingState.Loading;
|
|
340
|
+
// const client = this.searchForm.get('client')?.value;
|
|
341
|
+
// const branch = this.searchForm.get('branch')?.value;
|
|
342
|
+
// if (client && branch) {
|
|
343
|
+
// // await this.loadUsersByBranch(client, branch);
|
|
344
|
+
// this.loadingState = ComponentLoadingState.Complete;
|
|
345
|
+
// } else {
|
|
346
|
+
// this.users = [];
|
|
347
|
+
// this.loadingState = ComponentLoadingState.Complete;
|
|
348
|
+
// }
|
|
349
|
+
// }
|
|
282
350
|
}
|
|
351
|
+
// private async loadUsersByBranch(agentCode: string, branchCode: string): Promise<void> {
|
|
352
|
+
// return new Promise<void>((resolve, reject) => {
|
|
353
|
+
// this.reportService
|
|
354
|
+
// .getUsersByBranch(agentCode, branchCode)
|
|
355
|
+
// .pipe(takeUntil(this.destroy$))
|
|
356
|
+
// .subscribe({
|
|
357
|
+
// next: (users) => {
|
|
358
|
+
// this.users = users || [];
|
|
359
|
+
// // Try to find a user indicating "All"
|
|
360
|
+
// const allUser = this.users.find(
|
|
361
|
+
// u => u.userName === 'All' || u.userId === -1
|
|
362
|
+
// );
|
|
363
|
+
// if (allUser) {
|
|
364
|
+
// // If "All" is present, select it
|
|
365
|
+
// this.searchForm.patchValue({ userId: allUser.userId });
|
|
366
|
+
// } else if (this.users.length === 1) {
|
|
367
|
+
// // If only one user, select that user
|
|
368
|
+
// this.searchForm.patchValue({ userId: this.users[0].userId });
|
|
369
|
+
// } else {
|
|
370
|
+
// // Otherwise, clear user selection
|
|
371
|
+
// this.searchForm.patchValue({ userId: '' });
|
|
372
|
+
// }
|
|
373
|
+
// resolve();
|
|
374
|
+
// },
|
|
375
|
+
// error: (err) => reject(err),
|
|
376
|
+
// });
|
|
377
|
+
// });
|
|
378
|
+
// }
|
|
283
379
|
onSearch() {
|
|
284
380
|
if (this.ReportName == "Transaction Enquiry") {
|
|
285
381
|
this.hasSearched = true;
|
|
@@ -291,6 +387,16 @@ export class SearchFilterComponent {
|
|
|
291
387
|
this.formValidationError = false;
|
|
292
388
|
this.searchClicked.emit(this.buildSearchCriteria());
|
|
293
389
|
}
|
|
390
|
+
if (this.ReportName == "Branch Activity Send") {
|
|
391
|
+
this.hasSearched = true;
|
|
392
|
+
if (this.searchForm.invalid) {
|
|
393
|
+
this.formValidationError = true;
|
|
394
|
+
// this.markFormGroupTouched(this.searchForm);
|
|
395
|
+
return;
|
|
396
|
+
}
|
|
397
|
+
this.formValidationError = false;
|
|
398
|
+
this.searchClicked.emit(this.buildSearchCriteria());
|
|
399
|
+
}
|
|
294
400
|
if (this.ReportName == "ACC GL Details Enquiry") {
|
|
295
401
|
const modal = {
|
|
296
402
|
selectedDateType: this.searchForm.controls["dateType"]?.value,
|
|
@@ -335,6 +441,13 @@ export class SearchFilterComponent {
|
|
|
335
441
|
sysUserID: this.currentUser,
|
|
336
442
|
};
|
|
337
443
|
}
|
|
444
|
+
if (this.ReportName == "Branch Activity Send") {
|
|
445
|
+
const formValue = this.searchForm.value;
|
|
446
|
+
return {
|
|
447
|
+
modal: formValue,
|
|
448
|
+
sysUserID: this.currentUser
|
|
449
|
+
};
|
|
450
|
+
}
|
|
338
451
|
}
|
|
339
452
|
toIsoFormat(dateInput) {
|
|
340
453
|
if (!dateInput)
|
|
@@ -373,6 +486,12 @@ export class SearchFilterComponent {
|
|
|
373
486
|
}
|
|
374
487
|
return undefined;
|
|
375
488
|
}
|
|
489
|
+
onOpen() {
|
|
490
|
+
this.isOpen = true;
|
|
491
|
+
}
|
|
492
|
+
onClose() {
|
|
493
|
+
this.isOpen = false;
|
|
494
|
+
}
|
|
376
495
|
get errorMessage() {
|
|
377
496
|
return this._errorMessage;
|
|
378
497
|
}
|
|
@@ -385,15 +504,56 @@ export class SearchFilterComponent {
|
|
|
385
504
|
get isError() {
|
|
386
505
|
return this.loadingState === ComponentLoadingState.Error;
|
|
387
506
|
}
|
|
507
|
+
selectClient(client) {
|
|
508
|
+
this.searchForm.controls["client"].setValue(client);
|
|
509
|
+
this.searchForm.controls["branch"].setValue(null);
|
|
510
|
+
this.onAgentSelected(client);
|
|
511
|
+
}
|
|
512
|
+
onAgentSelected(code) {
|
|
513
|
+
if (this.searchForm.controls['client'].value === null) {
|
|
514
|
+
return;
|
|
515
|
+
}
|
|
516
|
+
this.searchForm.controls['branch'].patchValue(null);
|
|
517
|
+
// this.loadingState = ComponentLoadingStates.Loading;
|
|
518
|
+
this.reportService.getBranchByAgent(this.currentUser, code).subscribe({
|
|
519
|
+
next: (data) => {
|
|
520
|
+
this.branches = data;
|
|
521
|
+
},
|
|
522
|
+
error: (err) => {
|
|
523
|
+
// this.loadingState = ComponentLoadingStates.Complete;
|
|
524
|
+
},
|
|
525
|
+
complete: () => {
|
|
526
|
+
if (sessionStorage.getItem("ezremitusername")) {
|
|
527
|
+
const index = this.branches.findIndex((branch) => branch.branchCode === "All");
|
|
528
|
+
if (index == -1) {
|
|
529
|
+
this.searchForm.controls['branch'].setValue(this.branches[0].branchCode);
|
|
530
|
+
}
|
|
531
|
+
else {
|
|
532
|
+
this.searchForm.controls['branch'].setValue('All');
|
|
533
|
+
}
|
|
534
|
+
}
|
|
535
|
+
if (sessionStorage.getItem("fossilusername")) {
|
|
536
|
+
this.searchForm.controls['branch'].setValue('All');
|
|
537
|
+
}
|
|
538
|
+
// this.loadingState = ComponentLoadingStates.Complete;
|
|
539
|
+
}
|
|
540
|
+
});
|
|
541
|
+
}
|
|
542
|
+
onClientSelected() {
|
|
543
|
+
this.searchForm.get('client')?.valueChanges.subscribe((val) => {
|
|
544
|
+
val = this.searchForm.get('client')?.value;
|
|
545
|
+
this.onAgentSelected(val);
|
|
546
|
+
});
|
|
547
|
+
}
|
|
388
548
|
}
|
|
389
549
|
SearchFilterComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: SearchFilterComponent, deps: [{ token: i1.ReportService }, { token: i2.FormBuilder }, { token: i3.ConfigService }], target: i0.ɵɵFactoryTarget.Component });
|
|
390
|
-
SearchFilterComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: SearchFilterComponent, selector: "lib-search-filter", inputs: { ReportName: "ReportName" }, outputs: { searchClicked: "searchClicked" }, ngImport: i0, template: "<h6 class=\"Breadcrumb\">\r\n <a class=\"BreadCrumbLink\" [routerLink]=\"['/reports']\">\r\n <h1>Reports</h1>\r\n </a>\r\n <a href=\"BreadCrumbLink\"></a>\r\n <span class=\"BreadCrumbArrow\"></span>\r\n <a class=\"BreadCrumbLink\">\r\n <h2>{{ ReportName }}</h2>\r\n </a>\r\n</h6>\r\n\r\n<app-loader *ngIf=\"loadingState === ComponentLoadingState.Loading\"></app-loader>\r\n\r\n<section class=\"filter-section\">\r\n <form [formGroup]=\"searchForm\" (ngSubmit)=\"onSearch()\" class=\"report-filter-form\">\r\n <div class=\"row\">\r\n <div class=\"col-custom-10-5\">\r\n <div class=\"grid-container\">\r\n <div class=\"filter-grid\">\r\n\r\n <!-- Dynamically render filters in order -->\r\n <ng-container *ngFor=\"let field of visibleFields\">\r\n <ng-container [ngSwitch]=\"field\">\r\n\r\n <!-- Client -->\r\n <div class=\"form-field\" *ngSwitchCase=\"'client'\">\r\n <div class=\"row align-items-center\">\r\n <div class=\"col-2\">\r\n <label class=\"form-label label-data\">Client<span class=\"text-danger\">*</span></label>\r\n </div>\r\n <div class=\"col-10\">\r\n <ng-select [items]=\"clients1\" bindLabel=\"businessPartnerName\" bindValue=\"businessPartnerCode\"\r\n placeholder=\"Select Client\" [clearable]=\"false\" formControlName=\"client\" required\r\n (change)=\"onClientChange()\">\r\n </ng-select>\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <!-- Branch -->\r\n <div class=\"form-field\" *ngSwitchCase=\"'branch'\">\r\n <div class=\"row align-items-center\">\r\n <div class=\"col-2\">\r\n <label class=\"form-label label-data\">Branch<span class=\"text-danger\">*</span></label>\r\n </div>\r\n <div class=\"col-10\">\r\n <ng-select [items]=\"branches\" bindLabel=\"businessPartnerBranch\" bindValue=\"branchCode\"\r\n placeholder=\"Select Branch\" [clearable]=\"false\" formControlName=\"branch\" required\r\n (change)=\"onBranchChange()\">\r\n </ng-select>\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <!-- From Date -->\r\n <div class=\"form-field\" *ngSwitchCase=\"'fromDate'\">\r\n <div class=\"row align-items-center\">\r\n <div class=\"col-2\">\r\n <label class=\"form-label label-data\">From Date<span class=\"text-danger\">*</span></label>\r\n </div>\r\n <div class=\"col-10\">\r\n <div class=\"input-group date-group\">\r\n <input class=\"form-control dpicker\" placeholder=\"dd/mm/yyyy\" ngbDatepicker\r\n #fromDateInput=\"ngbDatepicker\" formControlName=\"fromDate\" autocomplete=\"off\" />\r\n <button class=\"input-group-button cal\" (click)=\"fromDateInput.toggle()\" type=\"button\">\r\n <i class=\"fa fa-calendar\" aria-hidden=\"true\"></i>\r\n </button>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <!-- To Date -->\r\n <div class=\"form-field\" *ngSwitchCase=\"'toDate'\">\r\n <div class=\"row align-items-center\">\r\n <div class=\"col-2\">\r\n <label class=\"form-label label-data\">To Date<span class=\"text-danger\">*</span></label>\r\n </div>\r\n <div class=\"col-10\">\r\n <div class=\"input-group date-group\">\r\n <input class=\"form-control dpicker\" placeholder=\"dd/mm/yyyy\" ngbDatepicker\r\n #toDateInput=\"ngbDatepicker\" formControlName=\"toDate\" autocomplete=\"off\" />\r\n <button class=\"input-group-button cal\" (click)=\"toDateInput.toggle()\" type=\"button\">\r\n <i class=\"fa fa-calendar\" aria-hidden=\"true\"></i>\r\n </button>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <!-- Product -->\r\n <div class=\"form-field\" *ngSwitchCase=\"'product'\">\r\n <div class=\"row align-items-center\">\r\n <div class=\"col-2\">\r\n <label class=\"form-label label-data\">Product</label>\r\n </div>\r\n <div class=\"col-10\">\r\n <ng-select [items]=\"products\" bindLabel=\"productName\" bindValue=\"productCode\"\r\n placeholder=\"Select Product\" [clearable]=\"false\" formControlName=\"product\">\r\n </ng-select>\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <!-- User -->\r\n <div class=\"form-field\" *ngSwitchCase=\"'userId'\">\r\n <div class=\"row align-items-center\">\r\n <div class=\"col-2\">\r\n <label class=\"form-label label-data\">User<span class=\"text-danger\">*</span></label>\r\n </div>\r\n <div class=\"col-10\">\r\n <ng-select [items]=\"users\" bindLabel=\"userName\" bindValue=\"userId\" placeholder=\"Select User\"\r\n [clearable]=\"false\" formControlName=\"userId\" required>\r\n </ng-select>\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <!-- Currency -->\r\n <div class=\"form-field\" *ngSwitchCase=\"'currency'\">\r\n <div class=\"row align-items-center\">\r\n <div class=\"col-2\">\r\n <label class=\"form-label label-data\">Currency</label>\r\n </div>\r\n <div class=\"col-10\">\r\n <ng-select [items]=\"currencies\" bindLabel=\"currencyCode\" bindValue=\"currencyCode\"\r\n placeholder=\"Select Currency\" [clearable]=\"false\" formControlName=\"currency\">\r\n </ng-select>\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <!-- Transaction Status (Multi-select) -->\r\n <div class=\"form-field\" *ngSwitchCase=\"'transactionStatus'\">\r\n <div class=\"row align-items-center\">\r\n <div class=\"col-2\">\r\n <label class=\"form-label label-data\">Trans. Status<span class=\"text-danger\">*</span></label>\r\n </div>\r\n <div class=\"col-10\">\r\n <ng-select class=\"transaction-status-select\" [items]=\"transactionStatuses\"\r\n bindLabel=\"transactionStatus\" bindValue=\"transactionStatus\" [multiple]=\"true\"\r\n placeholder=\"Select Transaction Status\" formControlName=\"transactionStatus\"\r\n [closeOnSelect]=\"false\" [clearable]=\"false\" [searchable]=\"false\" required>\r\n <ng-template ng-option-tmp let-item=\"item\" let-item$=\"item$\">\r\n <input type=\"checkbox\" [checked]=\"item$.selected\" /> {{ item.transactionStatus }}\r\n </ng-template>\r\n </ng-select>\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <!-- Transaction No -->\r\n <div class=\"form-field\" *ngSwitchCase=\"'transactionNo'\">\r\n <div class=\"row align-items-center\">\r\n <div class=\"col-2\">\r\n <label class=\"form-label label-data\">Trans. Number</label>\r\n </div>\r\n <div class=\"col-10\">\r\n <input class=\"form-control dpicker\" formControlName=\"transactionNo\"\r\n placeholder=\"Enter transaction number\" />\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <!-- Value Date -->\r\n <div class=\"form-field\" *ngSwitchCase=\"'valueDate'\">\r\n <div class=\"row align-items-center\">\r\n <div class=\"col-3\">\r\n <label class=\"form-label label-data\">Value Date<span class=\"text-danger\">*</span></label>\r\n </div>\r\n <div class=\"col-9\">\r\n <div class=\"input-group\">\r\n <input class=\"form-control dpicker\" placeholder=\"dd/mm/yyyy\" ngbDatepicker\r\n #toDateInput=\"ngbDatepicker\" formControlName=\"toDate\" autocomplete=\"off\" />\r\n <button class=\"btn btn-outline-secondary\" type=\"button\" (click)=\"toDateInput.toggle()\">\r\n <i class=\"fa fa-calendar\"></i>\r\n </button>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <!-- Date Type -->\r\n <div class=\"form-field\" *ngSwitchCase=\"'dateType'\">\r\n <div class=\"row align-items-center\">\r\n <div class=\"col-2\">\r\n <label class=\"form-label label-data\">Date Type</label>\r\n </div>\r\n <div class=\"col-10\">\r\n <ng-select placeholder=\"- Please select -\" formControlName=\"dateType\" [clearable]=\"false\"\r\n required>\r\n <ng-option [value]=\"1\">\r\n Value Date\r\n </ng-option>\r\n <ng-option [value]=\"2\">\r\n Posting Date\r\n </ng-option>\r\n </ng-select>\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <!-- Date -->\r\n <div class=\"form-field\" *ngSwitchCase=\"'date'\">\r\n <div class=\"row align-items-center\">\r\n <div class=\"col-2\">\r\n <label class=\"form-label label-data\">Date</label>\r\n </div>\r\n <div class=\"col-10\">\r\n <div class=\"input-group date-group\">\r\n <input class=\"form-control dpicker\" placeholder=\"dd/mm/yyyy\" ngbDatepicker\r\n #toDateInput=\"ngbDatepicker\" formControlName=\"date\" autocomplete=\"off\" />\r\n <button class=\"input-group-button cal\" (click)=\"toDateInput.toggle()\" type=\"button\">\r\n <i class=\"fa fa-calendar\" aria-hidden=\"true\"></i>\r\n </button>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n\r\n </ng-container>\r\n </ng-container>\r\n\r\n </div>\r\n </div>\r\n </div>\r\n <div class=\"col-custom-1-5\">\r\n <!-- View Report Button (Always at Top-Right) -->\r\n <div class=\"form-field view-report-btn\">\r\n <button type=\"submit\" class=\"btn btn-report\">View</button>\r\n </div>\r\n </div>\r\n </div>\r\n </form>\r\n</section>\r\n<hr>\r\n<!-- Error Messages -->\r\n<div class=\"alert alert-danger mt-3\" *ngIf=\"formValidationError && hasSearched\">\r\n Please fill all required fields before submitting the form.\r\n</div>\r\n\r\n<div class=\"alert alert-danger mt-3\" *ngIf=\"errorMessage && loadingState === ComponentLoadingState.Error\">\r\n {{ errorMessage }}\r\n <button type=\"button\" class=\"btn-close\" (click)=\"errorMessage = ''\"></button>\r\n</div>", styles: ["@charset \"UTF-8\";.filter-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;grid-column:span 3}.form-field{display:flex;flex-direction:column;padding:0 4px 0 0!important;min-width:0}.col-custom-10-5{flex:0 0 87.5%!important;max-width:87.5%!important}.col-custom-1-5{flex:0 0 12.5%!important;max-width:12.5%!important}::ng-deep .ng-select .ng-select-container .ng-value-container{overflow:hidden;flex-wrap:nowrap}::ng-deep .ng-select .ng-select-container .ng-value-container .ng-value{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:100%}::ng-deep .ng-select .ng-select-container{height:32px!important;min-height:32px!important;font-size:12px!important;align-items:center}.form-label{margin-bottom:0!important}.date-group{height:32px!important}::ng-deep .transaction-status-select .ng-dropdown-panel .ng-dropdown-panel-items .ng-option{padding:4px 0!important}::ng-deep .ng-select .ng-select-container .ng-value-container{padding-top:0}::ng-deep .ng-dropdown-panel .ng-option{font-size:12px}.btn-report{border-radius:4px;background-color:#8091a5;color:#fff!important;font-size:14px!important;height:32px;padding:4px 15px!important;margin-left:10px!important;width:110px}::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}.fa-calendar{--fa: \"\\f073\" !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;margin-left:0!important}.cal:focus{box-shadow:none!important}.label-data{font-weight:600!important;font-size:.7rem!important;line-height:1rem}@media (max-width: 768px){.filter-grid{grid-template-columns:1fr;gap:12px}}.input-group-button{background:none!important;border:1px solid #1877F2!important;background-color:#1877f2!important;border-radius:0 3px 3px 0!important;min-width:35px;margin-left:1px;height:32px!important;cursor:pointer}.input-group-button .fa{color:#fff}.input-group-button:focus{box-shadow:0 0 5px 3px #009ee054}.input-group-button:focus{outline:none!important;box-shadow:none!important}\n"], dependencies: [{ kind: "directive", type: i4.RouterLinkWithHref, selector: "a[routerLink],area[routerLink]", inputs: ["target", "queryParams", "fragment", "queryParamsHandling", "state", "relativeTo", "preserveFragment", "skipLocationChange", "replaceUrl", "routerLink"] }, { kind: "directive", type: i5.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i5.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i5.NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { kind: "directive", type: i5.NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { kind: "directive", type: i2.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i2.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i2.RequiredValidator, selector: ":not([type=checkbox])[required][formControlName],:not([type=checkbox])[required][formControl],:not([type=checkbox])[required][ngModel]", inputs: ["required"] }, { kind: "directive", type: i6.NgbInputDatepicker, selector: "input[ngbDatepicker]", inputs: ["autoClose", "datepickerClass", "dayTemplate", "dayTemplateData", "displayMonths", "firstDayOfWeek", "footerTemplate", "markDisabled", "minDate", "maxDate", "navigation", "outsideDays", "placement", "popperOptions", "restoreFocus", "showWeekNumbers", "startDate", "container", "positionTarget", "weekdays", "disabled"], outputs: ["dateSelect", "navigate", "closed"], exportAs: ["ngbDatepicker"] }, { kind: "directive", type: i2.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i2.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }, { kind: "component", type: i7.NgSelectComponent, selector: "ng-select", inputs: ["bindLabel", "bindValue", "markFirst", "placeholder", "notFoundText", "typeToSearchText", "addTagText", "loadingText", "clearAllText", "appearance", "dropdownPosition", "appendTo", "loading", "closeOnSelect", "hideSelected", "selectOnTab", "openOnEnter", "maxSelectedItems", "groupBy", "groupValue", "bufferAmount", "virtualScroll", "selectableGroup", "selectableGroupAsModel", "searchFn", "trackByFn", "clearOnBackspace", "labelForId", "inputAttrs", "tabIndex", "readonly", "searchWhileComposing", "minTermLength", "editableSearchTerm", "keyDownFn", "typeahead", "multiple", "addTag", "searchable", "clearable", "isOpen", "items", "compareWith", "clearSearchOnAdd"], outputs: ["blur", "focus", "change", "open", "close", "search", "clear", "add", "remove", "scroll", "scrollToEnd"] }, { kind: "component", type: i7.NgOptionComponent, selector: "ng-option", inputs: ["value", "disabled"] }, { kind: "directive", type: i7.NgOptionTemplateDirective, selector: "[ng-option-tmp]" }, { kind: "component", type: i8.LoaderComponent, selector: "app-loader" }] });
|
|
550
|
+
SearchFilterComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: SearchFilterComponent, selector: "lib-search-filter", inputs: { ReportName: "ReportName" }, outputs: { searchClicked: "searchClicked" }, ngImport: i0, template: "<h6 class=\"Breadcrumb\">\r\n <a class=\"BreadCrumbLink\" [routerLink]=\"['/reports']\">\r\n <h1>Reports</h1>\r\n </a>\r\n <a href=\"BreadCrumbLink\"></a>\r\n <span class=\"BreadCrumbArrow\"></span>\r\n <a class=\"BreadCrumbLink\">\r\n <h2>{{ ReportName }}</h2>\r\n </a>\r\n</h6>\r\n\r\n<app-loader *ngIf=\"loadingState === ComponentLoadingState.Loading\"></app-loader>\r\n<section>\r\n <form [formGroup]=\"searchForm\" (ngSubmit)=\"onSearch()\">\r\n <div class=\"row\">\r\n <div class=\"col-custom-10-5\">\r\n <div class=\"filter-grid\">\r\n\r\n <!-- Dynamically render filters in order -->\r\n <ng-container *ngFor=\"let field of visibleFields\">\r\n <ng-container [ngSwitch]=\"field\">\r\n\r\n <!-- Client -->\r\n <div class=\"form-field\" *ngSwitchCase=\"'client'\">\r\n <div class=\"row align-items-center\">\r\n <div class=\"col-2\">\r\n <label class=\"form-label label-data\">Client<span class=\"text-danger\">*</span></label>\r\n </div>\r\n <div class=\"col-10\">\r\n <ng-select [items]=\"clients1\" bindLabel=\"businessPartnerName\" bindValue=\"businessPartnerCode\"\r\n placeholder=\"Select Client\" [clearable]=\"false\" formControlName=\"client\" required\r\n (change)=\"onClientChange()\" (open)=\"onOpen()\" (close)=\"onClose()\" [searchable]=\"isOpen\">\r\n </ng-select>\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <!-- Branch -->\r\n <div class=\"form-field\" *ngSwitchCase=\"'branch'\">\r\n <div class=\"row align-items-center\">\r\n <div class=\"col-2\">\r\n <label class=\"form-label label-data\">Branch<span class=\"text-danger\">*</span></label>\r\n </div>\r\n <div class=\"col-10\">\r\n <ng-select [items]=\"branches\" bindLabel=\"businessPartnerBranch\" bindValue=\"branchCode\"\r\n placeholder=\"Select Branch\" [clearable]=\"false\" formControlName=\"branch\" required\r\n (change)=\"onBranchChange()\" (open)=\"onOpen()\" (close)=\"onClose()\" [searchable]=\"isOpen\">\r\n </ng-select>\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <!-- From Date -->\r\n <div class=\"form-field\" *ngSwitchCase=\"'fromDate'\">\r\n <div class=\"row align-items-center\">\r\n <div class=\"col-2\">\r\n <label class=\"form-label label-data\">From Date<span class=\"text-danger\">*</span></label>\r\n </div>\r\n <div class=\"col-10\">\r\n <div class=\"input-group date-group\">\r\n <input class=\"form-control dpicker\" placeholder=\"dd/mm/yyyy\" ngbDatepicker\r\n #fromDateInput=\"ngbDatepicker\" formControlName=\"fromDate\" autocomplete=\"off\" />\r\n <button class=\"input-group-button cal\" (click)=\"fromDateInput.toggle()\" type=\"button\">\r\n <i class=\"fa fa-calendar\" aria-hidden=\"true\"></i>\r\n </button>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <!-- To Date -->\r\n <div class=\"form-field\" *ngSwitchCase=\"'toDate'\">\r\n <div class=\"row align-items-center\">\r\n <div class=\"col-2\">\r\n <label class=\"form-label label-data\">To Date<span class=\"text-danger\">*</span></label>\r\n </div>\r\n <div class=\"col-10\">\r\n <div class=\"input-group date-group\">\r\n <input class=\"form-control dpicker\" placeholder=\"dd/mm/yyyy\" ngbDatepicker\r\n #toDateInput=\"ngbDatepicker\" formControlName=\"toDate\" autocomplete=\"off\" />\r\n <button class=\"input-group-button cal\" (click)=\"toDateInput.toggle()\" type=\"button\">\r\n <i class=\"fa fa-calendar\" aria-hidden=\"true\"></i>\r\n </button>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <!-- Product -->\r\n <div class=\"form-field\" *ngSwitchCase=\"'product'\">\r\n <div class=\"row align-items-center\">\r\n <div class=\"col-2\">\r\n <label class=\"form-label label-data\">Product</label>\r\n </div>\r\n <div class=\"col-10\">\r\n <ng-select [items]=\"products\" bindLabel=\"productName\" bindValue=\"productCode\"\r\n placeholder=\"Select Product\" [clearable]=\"false\" formControlName=\"product\" (open)=\"onOpen()\" (close)=\"onClose()\" [searchable]=\"isOpen\">\r\n </ng-select>\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <!-- User -->\r\n <div class=\"form-field\" *ngSwitchCase=\"'userId'\">\r\n <div class=\"row align-items-center\">\r\n <div class=\"col-2\">\r\n <label class=\"form-label label-data\">User<span class=\"text-danger\">*</span></label>\r\n </div>\r\n <div class=\"col-10\">\r\n <ng-select [items]=\"users\" bindLabel=\"userName\" bindValue=\"userId\" placeholder=\"Select User\"\r\n [clearable]=\"false\" formControlName=\"userId\" required (open)=\"onOpen()\" (close)=\"onClose()\" [searchable]=\"isOpen\">\r\n </ng-select>\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <!-- Currency -->\r\n <div class=\"form-field\" *ngSwitchCase=\"'currency'\">\r\n <div class=\"row align-items-center\">\r\n <div class=\"col-2\">\r\n <label class=\"form-label label-data\">Currency</label>\r\n </div>\r\n <div class=\"col-10\">\r\n <ng-select [items]=\"currencies\" bindLabel=\"currencyCode\" bindValue=\"currencyCode\"\r\n placeholder=\"Select Currency\" [clearable]=\"false\" formControlName=\"currency\" (open)=\"onOpen()\" (close)=\"onClose()\" [searchable]=\"isOpen\">\r\n </ng-select>\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <!-- Transaction Status (Multi-select) -->\r\n <div class=\"form-field\" *ngSwitchCase=\"'transactionStatus'\">\r\n <div class=\"row align-items-center\">\r\n <div class=\"col-2\">\r\n <label class=\"form-label label-data\">Txn. Status<span class=\"text-danger\">*</span></label>\r\n </div>\r\n <div class=\"col-10\">\r\n <ng-select class=\"transaction-status-select\" [items]=\"transactionStatuses\"\r\n bindLabel=\"transactionStatus\" bindValue=\"transactionStatus\" [multiple]=\"true\"\r\n placeholder=\"Select Transaction Status\" formControlName=\"transactionStatus\"\r\n [closeOnSelect]=\"false\" [clearable]=\"false\" [searchable]=\"false\" required>\r\n <ng-template ng-option-tmp let-item=\"item\" let-item$=\"item$\">\r\n <input type=\"checkbox\" [checked]=\"item$.selected\" /> {{ item.transactionStatus }}\r\n </ng-template>\r\n </ng-select>\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <!-- Transaction No -->\r\n <div class=\"form-field\" *ngSwitchCase=\"'transactionNo'\">\r\n <div class=\"row align-items-center\">\r\n <div class=\"col-2\">\r\n <label class=\"form-label label-data\">Txn. Number</label>\r\n </div>\r\n <div class=\"col-10\">\r\n <input class=\"form-control dpicker\" formControlName=\"transactionNo\"\r\n placeholder=\"Enter transaction number\" />\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <!-- Value Date -->\r\n <div class=\"form-field\" *ngSwitchCase=\"'valueDate'\">\r\n <div class=\"row align-items-center\">\r\n <div class=\"col-3\">\r\n <label class=\"form-label label-data\">Value Date<span class=\"text-danger\">*</span></label>\r\n </div>\r\n <div class=\"col-9\">\r\n <div class=\"input-group\">\r\n <input class=\"form-control dpicker\" placeholder=\"dd/mm/yyyy\" ngbDatepicker\r\n #toDateInput=\"ngbDatepicker\" formControlName=\"toDate\" autocomplete=\"off\" />\r\n <button class=\"btn btn-outline-secondary\" type=\"button\" (click)=\"toDateInput.toggle()\">\r\n <i class=\"fa fa-calendar\"></i>\r\n </button>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <!-- Send Country -->\r\n <div class=\"form-field\" *ngSwitchCase=\"'sendCountry'\">\r\n <div class=\"row align-items-center\">\r\n <div class=\"col-2\">\r\n <label class=\"form-label label-data\">Send Country</label>\r\n </div>\r\n <div class=\"col-10\">\r\n <ng-select [items]=\"countries\" bindLabel=\"country\" bindValue=\"countryCode\"\r\n placeholder=\"Select Product\" [clearable]=\"false\" formControlName=\"sendCountry\">\r\n </ng-select>\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <!-- Receive Country -->\r\n <div class=\"form-field\" *ngSwitchCase=\"'receiveCountry'\">\r\n <div class=\"row align-items-center\">\r\n <div class=\"col-2\">\r\n <label class=\"form-label label-data\">Receive Country</label>\r\n </div>\r\n <div class=\"col-10\">\r\n <ng-select [items]=\"countries\" bindLabel=\"country\" bindValue=\"countryCode\"\r\n placeholder=\"Select Product\" [clearable]=\"false\" formControlName=\"receiveCountry\">\r\n </ng-select>\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <!--Transaction Product -->\r\n <div class=\"form-field\" *ngSwitchCase=\"'transactionProduct'\">\r\n <div class=\"row align-items-center\">\r\n <div class=\"col-2\">\r\n <label class=\"form-label label-data\">Product</label>\r\n </div>\r\n <div class=\"col-10\">\r\n <ng-select [items]=\"transactionProducts\" bindLabel=\"name\" bindValue=\"productCode\"\r\n placeholder=\"Select Product\" [clearable]=\"false\" formControlName=\"product\">\r\n </ng-select>\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <!-- Value Date -->\r\n <div class=\"form-field\" *ngSwitchCase=\"'valueDate'\">\r\n <div class=\"row align-items-center\">\r\n <div class=\"col-3\">\r\n <label class=\"form-label label-data\">Value Date<span class=\"text-danger\">*</span></label>\r\n </div>\r\n <div class=\"col-9\">\r\n <div class=\"input-group\">\r\n <input class=\"form-control dpicker\" placeholder=\"dd/mm/yyyy\" ngbDatepicker\r\n #toDateInput=\"ngbDatepicker\" formControlName=\"toDate\" autocomplete=\"off\" />\r\n <button class=\"btn btn-outline-secondary\" type=\"button\" (click)=\"toDateInput.toggle()\">\r\n <i class=\"fa fa-calendar\"></i>\r\n </button>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <!-- Date Type -->\r\n <div class=\"form-field\" *ngSwitchCase=\"'dateType'\">\r\n <div class=\"row align-items-center\">\r\n <div class=\"col-2\">\r\n <label class=\"form-label label-data\">Date Type</label>\r\n </div>\r\n <div class=\"col-10\">\r\n <ng-select placeholder=\"- Please select -\" formControlName=\"dateType\" [clearable]=\"false\"\r\n required>\r\n <ng-option [value]=\"1\">\r\n Value Date\r\n </ng-option>\r\n <ng-option [value]=\"2\">\r\n Posting Date\r\n </ng-option>\r\n </ng-select>\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <!-- Date -->\r\n <div class=\"form-field\" *ngSwitchCase=\"'date'\">\r\n <div class=\"row align-items-center\">\r\n <div class=\"col-2\">\r\n <label class=\"form-label label-data\">Date</label>\r\n </div>\r\n <div class=\"col-10\">\r\n <div class=\"input-group date-group\">\r\n <input class=\"form-control dpicker\" placeholder=\"dd/mm/yyyy\" ngbDatepicker\r\n #toDateInput=\"ngbDatepicker\" formControlName=\"date\" autocomplete=\"off\" />\r\n <button class=\"input-group-button cal\" (click)=\"toDateInput.toggle()\" type=\"button\">\r\n <i class=\"fa fa-calendar\" aria-hidden=\"true\"></i>\r\n </button>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n\r\n </ng-container>\r\n </ng-container>\r\n\r\n </div>\r\n\r\n </div>\r\n <div class=\"col-custom-1-5\">\r\n <!-- View Report Button (Always at Top-Right) -->\r\n <div class=\"form-field view-report-btn\">\r\n <button type=\"submit\" class=\"btn btn-report\">View</button>\r\n </div>\r\n </div>\r\n </div>\r\n </form>\r\n</section>\r\n<hr>\r\n<!-- Error Messages -->\r\n<div class=\"alert alert-danger mt-3\" *ngIf=\"formValidationError && hasSearched\">\r\n Please fill all required fields before submitting the form.\r\n</div>\r\n\r\n<div class=\"alert alert-danger mt-3\" *ngIf=\"errorMessage && loadingState === ComponentLoadingState.Error\">\r\n {{ errorMessage }}\r\n <button type=\"button\" class=\"btn-close\" (click)=\"errorMessage = ''\"></button>\r\n</div>", styles: ["@charset \"UTF-8\";.filter-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;grid-column:span 3}.form-field{display:flex;flex-direction:column;padding:0 4px 0 0!important;min-width:0}.col-custom-10-5{flex:0 0 87.5%!important;max-width:87.5%!important}.col-custom-1-5{flex:0 0 12.5%!important;max-width:12.5%!important;padding:0!important}::ng-deep .ng-select .ng-select-container .ng-value-container{overflow:hidden;flex-wrap:nowrap}::ng-deep .ng-select .ng-select-container .ng-value-container .ng-value{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:100%}::ng-deep .ng-select .ng-select-container{height:32px!important;min-height:32px!important;font-size:12px!important;align-items:center}.form-label{margin-bottom:0!important}.date-group{height:32px!important}::ng-deep .transaction-status-select .ng-dropdown-panel .ng-dropdown-panel-items .ng-option{padding:4px 0!important}::ng-deep .ng-select .ng-select-container .ng-value-container{padding-top:0}::ng-deep .ng-dropdown-panel .ng-option{font-size:12px}.btn-report{border-radius:4px;background-color:#8091a5;color:#fff!important;font-size:14px!important;height:32px;padding:4px 15px!important;margin-left:10px!important;width:110px!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}.fa-calendar{--fa: \"\\f073\" !important}.dpicker{border:1px solid #ccc!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;margin-left:0!important}.cal:focus{box-shadow:none!important}.label-data{font-weight:600!important;font-size:.7rem!important;line-height:1rem}@media (max-width: 768px){.filter-grid{grid-template-columns:1fr;gap:12px}}.input-group-button{background:none!important;border:1px solid #1877F2!important;background-color:#1877f2!important;border-radius:0 3px 3px 0!important;min-width:35px;margin-left:1px;height:32px!important;cursor:pointer}.input-group-button .fa{color:#fff}.input-group-button:focus{box-shadow:0 0 5px 3px #009ee054}.input-group-button:focus{outline:none!important;box-shadow:none!important}.Breadcrumb h1,.Breadcrumb h2{font-weight:700}\n"], dependencies: [{ kind: "directive", type: i4.RouterLinkWithHref, selector: "a[routerLink],area[routerLink]", inputs: ["target", "queryParams", "fragment", "queryParamsHandling", "state", "relativeTo", "preserveFragment", "skipLocationChange", "replaceUrl", "routerLink"] }, { kind: "directive", type: i5.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i5.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i5.NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { kind: "directive", type: i5.NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { kind: "directive", type: i6.NgbInputDatepicker, selector: "input[ngbDatepicker]", inputs: ["autoClose", "datepickerClass", "dayTemplate", "dayTemplateData", "displayMonths", "firstDayOfWeek", "footerTemplate", "markDisabled", "minDate", "maxDate", "navigation", "outsideDays", "placement", "popperOptions", "restoreFocus", "showWeekNumbers", "startDate", "container", "positionTarget", "weekdays", "disabled"], outputs: ["dateSelect", "navigate", "closed"], exportAs: ["ngbDatepicker"] }, { kind: "directive", type: i2.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i2.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i2.RequiredValidator, selector: ":not([type=checkbox])[required][formControlName],:not([type=checkbox])[required][formControl],:not([type=checkbox])[required][ngModel]", inputs: ["required"] }, { kind: "directive", type: i2.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i2.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }, { kind: "component", type: i7.NgSelectComponent, selector: "ng-select", inputs: ["bindLabel", "bindValue", "markFirst", "placeholder", "notFoundText", "typeToSearchText", "addTagText", "loadingText", "clearAllText", "appearance", "dropdownPosition", "appendTo", "loading", "closeOnSelect", "hideSelected", "selectOnTab", "openOnEnter", "maxSelectedItems", "groupBy", "groupValue", "bufferAmount", "virtualScroll", "selectableGroup", "selectableGroupAsModel", "searchFn", "trackByFn", "clearOnBackspace", "labelForId", "inputAttrs", "tabIndex", "readonly", "searchWhileComposing", "minTermLength", "editableSearchTerm", "keyDownFn", "typeahead", "multiple", "addTag", "searchable", "clearable", "isOpen", "items", "compareWith", "clearSearchOnAdd"], outputs: ["blur", "focus", "change", "open", "close", "search", "clear", "add", "remove", "scroll", "scrollToEnd"] }, { kind: "component", type: i7.NgOptionComponent, selector: "ng-option", inputs: ["value", "disabled"] }, { kind: "directive", type: i7.NgOptionTemplateDirective, selector: "[ng-option-tmp]" }, { kind: "component", type: i8.LoaderComponent, selector: "app-loader" }] });
|
|
391
551
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: SearchFilterComponent, decorators: [{
|
|
392
552
|
type: Component,
|
|
393
|
-
args: [{ selector: 'lib-search-filter', template: "<h6 class=\"Breadcrumb\">\r\n <a class=\"BreadCrumbLink\" [routerLink]=\"['/reports']\">\r\n <h1>Reports</h1>\r\n </a>\r\n <a href=\"BreadCrumbLink\"></a>\r\n <span class=\"BreadCrumbArrow\"></span>\r\n <a class=\"BreadCrumbLink\">\r\n <h2>{{ ReportName }}</h2>\r\n </a>\r\n</h6>\r\n\r\n<app-loader *ngIf=\"loadingState === ComponentLoadingState.Loading\"></app-loader>\r\n\r\n<section class=\"filter-section\">\r\n <form [formGroup]=\"searchForm\" (ngSubmit)=\"onSearch()\" class=\"report-filter-form\">\r\n <div class=\"row\">\r\n <div class=\"col-custom-10-5\">\r\n <div class=\"grid-container\">\r\n <div class=\"filter-grid\">\r\n\r\n <!-- Dynamically render filters in order -->\r\n <ng-container *ngFor=\"let field of visibleFields\">\r\n <ng-container [ngSwitch]=\"field\">\r\n\r\n <!-- Client -->\r\n <div class=\"form-field\" *ngSwitchCase=\"'client'\">\r\n <div class=\"row align-items-center\">\r\n <div class=\"col-2\">\r\n <label class=\"form-label label-data\">Client<span class=\"text-danger\">*</span></label>\r\n </div>\r\n <div class=\"col-10\">\r\n <ng-select [items]=\"clients1\" bindLabel=\"businessPartnerName\" bindValue=\"businessPartnerCode\"\r\n placeholder=\"Select Client\" [clearable]=\"false\" formControlName=\"client\" required\r\n (change)=\"onClientChange()\">\r\n </ng-select>\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <!-- Branch -->\r\n <div class=\"form-field\" *ngSwitchCase=\"'branch'\">\r\n <div class=\"row align-items-center\">\r\n <div class=\"col-2\">\r\n <label class=\"form-label label-data\">Branch<span class=\"text-danger\">*</span></label>\r\n </div>\r\n <div class=\"col-10\">\r\n <ng-select [items]=\"branches\" bindLabel=\"businessPartnerBranch\" bindValue=\"branchCode\"\r\n placeholder=\"Select Branch\" [clearable]=\"false\" formControlName=\"branch\" required\r\n (change)=\"onBranchChange()\">\r\n </ng-select>\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <!-- From Date -->\r\n <div class=\"form-field\" *ngSwitchCase=\"'fromDate'\">\r\n <div class=\"row align-items-center\">\r\n <div class=\"col-2\">\r\n <label class=\"form-label label-data\">From Date<span class=\"text-danger\">*</span></label>\r\n </div>\r\n <div class=\"col-10\">\r\n <div class=\"input-group date-group\">\r\n <input class=\"form-control dpicker\" placeholder=\"dd/mm/yyyy\" ngbDatepicker\r\n #fromDateInput=\"ngbDatepicker\" formControlName=\"fromDate\" autocomplete=\"off\" />\r\n <button class=\"input-group-button cal\" (click)=\"fromDateInput.toggle()\" type=\"button\">\r\n <i class=\"fa fa-calendar\" aria-hidden=\"true\"></i>\r\n </button>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <!-- To Date -->\r\n <div class=\"form-field\" *ngSwitchCase=\"'toDate'\">\r\n <div class=\"row align-items-center\">\r\n <div class=\"col-2\">\r\n <label class=\"form-label label-data\">To Date<span class=\"text-danger\">*</span></label>\r\n </div>\r\n <div class=\"col-10\">\r\n <div class=\"input-group date-group\">\r\n <input class=\"form-control dpicker\" placeholder=\"dd/mm/yyyy\" ngbDatepicker\r\n #toDateInput=\"ngbDatepicker\" formControlName=\"toDate\" autocomplete=\"off\" />\r\n <button class=\"input-group-button cal\" (click)=\"toDateInput.toggle()\" type=\"button\">\r\n <i class=\"fa fa-calendar\" aria-hidden=\"true\"></i>\r\n </button>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <!-- Product -->\r\n <div class=\"form-field\" *ngSwitchCase=\"'product'\">\r\n <div class=\"row align-items-center\">\r\n <div class=\"col-2\">\r\n <label class=\"form-label label-data\">Product</label>\r\n </div>\r\n <div class=\"col-10\">\r\n <ng-select [items]=\"products\" bindLabel=\"productName\" bindValue=\"productCode\"\r\n placeholder=\"Select Product\" [clearable]=\"false\" formControlName=\"product\">\r\n </ng-select>\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <!-- User -->\r\n <div class=\"form-field\" *ngSwitchCase=\"'userId'\">\r\n <div class=\"row align-items-center\">\r\n <div class=\"col-2\">\r\n <label class=\"form-label label-data\">User<span class=\"text-danger\">*</span></label>\r\n </div>\r\n <div class=\"col-10\">\r\n <ng-select [items]=\"users\" bindLabel=\"userName\" bindValue=\"userId\" placeholder=\"Select User\"\r\n [clearable]=\"false\" formControlName=\"userId\" required>\r\n </ng-select>\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <!-- Currency -->\r\n <div class=\"form-field\" *ngSwitchCase=\"'currency'\">\r\n <div class=\"row align-items-center\">\r\n <div class=\"col-2\">\r\n <label class=\"form-label label-data\">Currency</label>\r\n </div>\r\n <div class=\"col-10\">\r\n <ng-select [items]=\"currencies\" bindLabel=\"currencyCode\" bindValue=\"currencyCode\"\r\n placeholder=\"Select Currency\" [clearable]=\"false\" formControlName=\"currency\">\r\n </ng-select>\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <!-- Transaction Status (Multi-select) -->\r\n <div class=\"form-field\" *ngSwitchCase=\"'transactionStatus'\">\r\n <div class=\"row align-items-center\">\r\n <div class=\"col-2\">\r\n <label class=\"form-label label-data\">Trans. Status<span class=\"text-danger\">*</span></label>\r\n </div>\r\n <div class=\"col-10\">\r\n <ng-select class=\"transaction-status-select\" [items]=\"transactionStatuses\"\r\n bindLabel=\"transactionStatus\" bindValue=\"transactionStatus\" [multiple]=\"true\"\r\n placeholder=\"Select Transaction Status\" formControlName=\"transactionStatus\"\r\n [closeOnSelect]=\"false\" [clearable]=\"false\" [searchable]=\"false\" required>\r\n <ng-template ng-option-tmp let-item=\"item\" let-item$=\"item$\">\r\n <input type=\"checkbox\" [checked]=\"item$.selected\" /> {{ item.transactionStatus }}\r\n </ng-template>\r\n </ng-select>\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <!-- Transaction No -->\r\n <div class=\"form-field\" *ngSwitchCase=\"'transactionNo'\">\r\n <div class=\"row align-items-center\">\r\n <div class=\"col-2\">\r\n <label class=\"form-label label-data\">Trans. Number</label>\r\n </div>\r\n <div class=\"col-10\">\r\n <input class=\"form-control dpicker\" formControlName=\"transactionNo\"\r\n placeholder=\"Enter transaction number\" />\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <!-- Value Date -->\r\n <div class=\"form-field\" *ngSwitchCase=\"'valueDate'\">\r\n <div class=\"row align-items-center\">\r\n <div class=\"col-3\">\r\n <label class=\"form-label label-data\">Value Date<span class=\"text-danger\">*</span></label>\r\n </div>\r\n <div class=\"col-9\">\r\n <div class=\"input-group\">\r\n <input class=\"form-control dpicker\" placeholder=\"dd/mm/yyyy\" ngbDatepicker\r\n #toDateInput=\"ngbDatepicker\" formControlName=\"toDate\" autocomplete=\"off\" />\r\n <button class=\"btn btn-outline-secondary\" type=\"button\" (click)=\"toDateInput.toggle()\">\r\n <i class=\"fa fa-calendar\"></i>\r\n </button>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <!-- Date Type -->\r\n <div class=\"form-field\" *ngSwitchCase=\"'dateType'\">\r\n <div class=\"row align-items-center\">\r\n <div class=\"col-2\">\r\n <label class=\"form-label label-data\">Date Type</label>\r\n </div>\r\n <div class=\"col-10\">\r\n <ng-select placeholder=\"- Please select -\" formControlName=\"dateType\" [clearable]=\"false\"\r\n required>\r\n <ng-option [value]=\"1\">\r\n Value Date\r\n </ng-option>\r\n <ng-option [value]=\"2\">\r\n Posting Date\r\n </ng-option>\r\n </ng-select>\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <!-- Date -->\r\n <div class=\"form-field\" *ngSwitchCase=\"'date'\">\r\n <div class=\"row align-items-center\">\r\n <div class=\"col-2\">\r\n <label class=\"form-label label-data\">Date</label>\r\n </div>\r\n <div class=\"col-10\">\r\n <div class=\"input-group date-group\">\r\n <input class=\"form-control dpicker\" placeholder=\"dd/mm/yyyy\" ngbDatepicker\r\n #toDateInput=\"ngbDatepicker\" formControlName=\"date\" autocomplete=\"off\" />\r\n <button class=\"input-group-button cal\" (click)=\"toDateInput.toggle()\" type=\"button\">\r\n <i class=\"fa fa-calendar\" aria-hidden=\"true\"></i>\r\n </button>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n\r\n </ng-container>\r\n </ng-container>\r\n\r\n </div>\r\n </div>\r\n </div>\r\n <div class=\"col-custom-1-5\">\r\n <!-- View Report Button (Always at Top-Right) -->\r\n <div class=\"form-field view-report-btn\">\r\n <button type=\"submit\" class=\"btn btn-report\">View</button>\r\n </div>\r\n </div>\r\n </div>\r\n </form>\r\n</section>\r\n<hr>\r\n<!-- Error Messages -->\r\n<div class=\"alert alert-danger mt-3\" *ngIf=\"formValidationError && hasSearched\">\r\n Please fill all required fields before submitting the form.\r\n</div>\r\n\r\n<div class=\"alert alert-danger mt-3\" *ngIf=\"errorMessage && loadingState === ComponentLoadingState.Error\">\r\n {{ errorMessage }}\r\n <button type=\"button\" class=\"btn-close\" (click)=\"errorMessage = ''\"></button>\r\n</div>", styles: ["@charset \"UTF-8\";.filter-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;grid-column:span 3}.form-field{display:flex;flex-direction:column;padding:0 4px 0 0!important;min-width:0}.col-custom-10-5{flex:0 0 87.5%!important;max-width:87.5%!important}.col-custom-1-5{flex:0 0 12.5%!important;max-width:12.5%!important}::ng-deep .ng-select .ng-select-container .ng-value-container{overflow:hidden;flex-wrap:nowrap}::ng-deep .ng-select .ng-select-container .ng-value-container .ng-value{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:100%}::ng-deep .ng-select .ng-select-container{height:32px!important;min-height:32px!important;font-size:12px!important;align-items:center}.form-label{margin-bottom:0!important}.date-group{height:32px!important}::ng-deep .transaction-status-select .ng-dropdown-panel .ng-dropdown-panel-items .ng-option{padding:4px 0!important}::ng-deep .ng-select .ng-select-container .ng-value-container{padding-top:0}::ng-deep .ng-dropdown-panel .ng-option{font-size:12px}.btn-report{border-radius:4px;background-color:#8091a5;color:#fff!important;font-size:14px!important;height:32px;padding:4px 15px!important;margin-left:10px!important;width:110px}::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}.fa-calendar{--fa: \"\\f073\" !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;margin-left:0!important}.cal:focus{box-shadow:none!important}.label-data{font-weight:600!important;font-size:.7rem!important;line-height:1rem}@media (max-width: 768px){.filter-grid{grid-template-columns:1fr;gap:12px}}.input-group-button{background:none!important;border:1px solid #1877F2!important;background-color:#1877f2!important;border-radius:0 3px 3px 0!important;min-width:35px;margin-left:1px;height:32px!important;cursor:pointer}.input-group-button .fa{color:#fff}.input-group-button:focus{box-shadow:0 0 5px 3px #009ee054}.input-group-button:focus{outline:none!important;box-shadow:none!important}\n"] }]
|
|
553
|
+
args: [{ selector: 'lib-search-filter', template: "<h6 class=\"Breadcrumb\">\r\n <a class=\"BreadCrumbLink\" [routerLink]=\"['/reports']\">\r\n <h1>Reports</h1>\r\n </a>\r\n <a href=\"BreadCrumbLink\"></a>\r\n <span class=\"BreadCrumbArrow\"></span>\r\n <a class=\"BreadCrumbLink\">\r\n <h2>{{ ReportName }}</h2>\r\n </a>\r\n</h6>\r\n\r\n<app-loader *ngIf=\"loadingState === ComponentLoadingState.Loading\"></app-loader>\r\n<section>\r\n <form [formGroup]=\"searchForm\" (ngSubmit)=\"onSearch()\">\r\n <div class=\"row\">\r\n <div class=\"col-custom-10-5\">\r\n <div class=\"filter-grid\">\r\n\r\n <!-- Dynamically render filters in order -->\r\n <ng-container *ngFor=\"let field of visibleFields\">\r\n <ng-container [ngSwitch]=\"field\">\r\n\r\n <!-- Client -->\r\n <div class=\"form-field\" *ngSwitchCase=\"'client'\">\r\n <div class=\"row align-items-center\">\r\n <div class=\"col-2\">\r\n <label class=\"form-label label-data\">Client<span class=\"text-danger\">*</span></label>\r\n </div>\r\n <div class=\"col-10\">\r\n <ng-select [items]=\"clients1\" bindLabel=\"businessPartnerName\" bindValue=\"businessPartnerCode\"\r\n placeholder=\"Select Client\" [clearable]=\"false\" formControlName=\"client\" required\r\n (change)=\"onClientChange()\" (open)=\"onOpen()\" (close)=\"onClose()\" [searchable]=\"isOpen\">\r\n </ng-select>\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <!-- Branch -->\r\n <div class=\"form-field\" *ngSwitchCase=\"'branch'\">\r\n <div class=\"row align-items-center\">\r\n <div class=\"col-2\">\r\n <label class=\"form-label label-data\">Branch<span class=\"text-danger\">*</span></label>\r\n </div>\r\n <div class=\"col-10\">\r\n <ng-select [items]=\"branches\" bindLabel=\"businessPartnerBranch\" bindValue=\"branchCode\"\r\n placeholder=\"Select Branch\" [clearable]=\"false\" formControlName=\"branch\" required\r\n (change)=\"onBranchChange()\" (open)=\"onOpen()\" (close)=\"onClose()\" [searchable]=\"isOpen\">\r\n </ng-select>\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <!-- From Date -->\r\n <div class=\"form-field\" *ngSwitchCase=\"'fromDate'\">\r\n <div class=\"row align-items-center\">\r\n <div class=\"col-2\">\r\n <label class=\"form-label label-data\">From Date<span class=\"text-danger\">*</span></label>\r\n </div>\r\n <div class=\"col-10\">\r\n <div class=\"input-group date-group\">\r\n <input class=\"form-control dpicker\" placeholder=\"dd/mm/yyyy\" ngbDatepicker\r\n #fromDateInput=\"ngbDatepicker\" formControlName=\"fromDate\" autocomplete=\"off\" />\r\n <button class=\"input-group-button cal\" (click)=\"fromDateInput.toggle()\" type=\"button\">\r\n <i class=\"fa fa-calendar\" aria-hidden=\"true\"></i>\r\n </button>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <!-- To Date -->\r\n <div class=\"form-field\" *ngSwitchCase=\"'toDate'\">\r\n <div class=\"row align-items-center\">\r\n <div class=\"col-2\">\r\n <label class=\"form-label label-data\">To Date<span class=\"text-danger\">*</span></label>\r\n </div>\r\n <div class=\"col-10\">\r\n <div class=\"input-group date-group\">\r\n <input class=\"form-control dpicker\" placeholder=\"dd/mm/yyyy\" ngbDatepicker\r\n #toDateInput=\"ngbDatepicker\" formControlName=\"toDate\" autocomplete=\"off\" />\r\n <button class=\"input-group-button cal\" (click)=\"toDateInput.toggle()\" type=\"button\">\r\n <i class=\"fa fa-calendar\" aria-hidden=\"true\"></i>\r\n </button>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <!-- Product -->\r\n <div class=\"form-field\" *ngSwitchCase=\"'product'\">\r\n <div class=\"row align-items-center\">\r\n <div class=\"col-2\">\r\n <label class=\"form-label label-data\">Product</label>\r\n </div>\r\n <div class=\"col-10\">\r\n <ng-select [items]=\"products\" bindLabel=\"productName\" bindValue=\"productCode\"\r\n placeholder=\"Select Product\" [clearable]=\"false\" formControlName=\"product\" (open)=\"onOpen()\" (close)=\"onClose()\" [searchable]=\"isOpen\">\r\n </ng-select>\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <!-- User -->\r\n <div class=\"form-field\" *ngSwitchCase=\"'userId'\">\r\n <div class=\"row align-items-center\">\r\n <div class=\"col-2\">\r\n <label class=\"form-label label-data\">User<span class=\"text-danger\">*</span></label>\r\n </div>\r\n <div class=\"col-10\">\r\n <ng-select [items]=\"users\" bindLabel=\"userName\" bindValue=\"userId\" placeholder=\"Select User\"\r\n [clearable]=\"false\" formControlName=\"userId\" required (open)=\"onOpen()\" (close)=\"onClose()\" [searchable]=\"isOpen\">\r\n </ng-select>\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <!-- Currency -->\r\n <div class=\"form-field\" *ngSwitchCase=\"'currency'\">\r\n <div class=\"row align-items-center\">\r\n <div class=\"col-2\">\r\n <label class=\"form-label label-data\">Currency</label>\r\n </div>\r\n <div class=\"col-10\">\r\n <ng-select [items]=\"currencies\" bindLabel=\"currencyCode\" bindValue=\"currencyCode\"\r\n placeholder=\"Select Currency\" [clearable]=\"false\" formControlName=\"currency\" (open)=\"onOpen()\" (close)=\"onClose()\" [searchable]=\"isOpen\">\r\n </ng-select>\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <!-- Transaction Status (Multi-select) -->\r\n <div class=\"form-field\" *ngSwitchCase=\"'transactionStatus'\">\r\n <div class=\"row align-items-center\">\r\n <div class=\"col-2\">\r\n <label class=\"form-label label-data\">Txn. Status<span class=\"text-danger\">*</span></label>\r\n </div>\r\n <div class=\"col-10\">\r\n <ng-select class=\"transaction-status-select\" [items]=\"transactionStatuses\"\r\n bindLabel=\"transactionStatus\" bindValue=\"transactionStatus\" [multiple]=\"true\"\r\n placeholder=\"Select Transaction Status\" formControlName=\"transactionStatus\"\r\n [closeOnSelect]=\"false\" [clearable]=\"false\" [searchable]=\"false\" required>\r\n <ng-template ng-option-tmp let-item=\"item\" let-item$=\"item$\">\r\n <input type=\"checkbox\" [checked]=\"item$.selected\" /> {{ item.transactionStatus }}\r\n </ng-template>\r\n </ng-select>\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <!-- Transaction No -->\r\n <div class=\"form-field\" *ngSwitchCase=\"'transactionNo'\">\r\n <div class=\"row align-items-center\">\r\n <div class=\"col-2\">\r\n <label class=\"form-label label-data\">Txn. Number</label>\r\n </div>\r\n <div class=\"col-10\">\r\n <input class=\"form-control dpicker\" formControlName=\"transactionNo\"\r\n placeholder=\"Enter transaction number\" />\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <!-- Value Date -->\r\n <div class=\"form-field\" *ngSwitchCase=\"'valueDate'\">\r\n <div class=\"row align-items-center\">\r\n <div class=\"col-3\">\r\n <label class=\"form-label label-data\">Value Date<span class=\"text-danger\">*</span></label>\r\n </div>\r\n <div class=\"col-9\">\r\n <div class=\"input-group\">\r\n <input class=\"form-control dpicker\" placeholder=\"dd/mm/yyyy\" ngbDatepicker\r\n #toDateInput=\"ngbDatepicker\" formControlName=\"toDate\" autocomplete=\"off\" />\r\n <button class=\"btn btn-outline-secondary\" type=\"button\" (click)=\"toDateInput.toggle()\">\r\n <i class=\"fa fa-calendar\"></i>\r\n </button>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <!-- Send Country -->\r\n <div class=\"form-field\" *ngSwitchCase=\"'sendCountry'\">\r\n <div class=\"row align-items-center\">\r\n <div class=\"col-2\">\r\n <label class=\"form-label label-data\">Send Country</label>\r\n </div>\r\n <div class=\"col-10\">\r\n <ng-select [items]=\"countries\" bindLabel=\"country\" bindValue=\"countryCode\"\r\n placeholder=\"Select Product\" [clearable]=\"false\" formControlName=\"sendCountry\">\r\n </ng-select>\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <!-- Receive Country -->\r\n <div class=\"form-field\" *ngSwitchCase=\"'receiveCountry'\">\r\n <div class=\"row align-items-center\">\r\n <div class=\"col-2\">\r\n <label class=\"form-label label-data\">Receive Country</label>\r\n </div>\r\n <div class=\"col-10\">\r\n <ng-select [items]=\"countries\" bindLabel=\"country\" bindValue=\"countryCode\"\r\n placeholder=\"Select Product\" [clearable]=\"false\" formControlName=\"receiveCountry\">\r\n </ng-select>\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <!--Transaction Product -->\r\n <div class=\"form-field\" *ngSwitchCase=\"'transactionProduct'\">\r\n <div class=\"row align-items-center\">\r\n <div class=\"col-2\">\r\n <label class=\"form-label label-data\">Product</label>\r\n </div>\r\n <div class=\"col-10\">\r\n <ng-select [items]=\"transactionProducts\" bindLabel=\"name\" bindValue=\"productCode\"\r\n placeholder=\"Select Product\" [clearable]=\"false\" formControlName=\"product\">\r\n </ng-select>\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <!-- Value Date -->\r\n <div class=\"form-field\" *ngSwitchCase=\"'valueDate'\">\r\n <div class=\"row align-items-center\">\r\n <div class=\"col-3\">\r\n <label class=\"form-label label-data\">Value Date<span class=\"text-danger\">*</span></label>\r\n </div>\r\n <div class=\"col-9\">\r\n <div class=\"input-group\">\r\n <input class=\"form-control dpicker\" placeholder=\"dd/mm/yyyy\" ngbDatepicker\r\n #toDateInput=\"ngbDatepicker\" formControlName=\"toDate\" autocomplete=\"off\" />\r\n <button class=\"btn btn-outline-secondary\" type=\"button\" (click)=\"toDateInput.toggle()\">\r\n <i class=\"fa fa-calendar\"></i>\r\n </button>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <!-- Date Type -->\r\n <div class=\"form-field\" *ngSwitchCase=\"'dateType'\">\r\n <div class=\"row align-items-center\">\r\n <div class=\"col-2\">\r\n <label class=\"form-label label-data\">Date Type</label>\r\n </div>\r\n <div class=\"col-10\">\r\n <ng-select placeholder=\"- Please select -\" formControlName=\"dateType\" [clearable]=\"false\"\r\n required>\r\n <ng-option [value]=\"1\">\r\n Value Date\r\n </ng-option>\r\n <ng-option [value]=\"2\">\r\n Posting Date\r\n </ng-option>\r\n </ng-select>\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <!-- Date -->\r\n <div class=\"form-field\" *ngSwitchCase=\"'date'\">\r\n <div class=\"row align-items-center\">\r\n <div class=\"col-2\">\r\n <label class=\"form-label label-data\">Date</label>\r\n </div>\r\n <div class=\"col-10\">\r\n <div class=\"input-group date-group\">\r\n <input class=\"form-control dpicker\" placeholder=\"dd/mm/yyyy\" ngbDatepicker\r\n #toDateInput=\"ngbDatepicker\" formControlName=\"date\" autocomplete=\"off\" />\r\n <button class=\"input-group-button cal\" (click)=\"toDateInput.toggle()\" type=\"button\">\r\n <i class=\"fa fa-calendar\" aria-hidden=\"true\"></i>\r\n </button>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n\r\n </ng-container>\r\n </ng-container>\r\n\r\n </div>\r\n\r\n </div>\r\n <div class=\"col-custom-1-5\">\r\n <!-- View Report Button (Always at Top-Right) -->\r\n <div class=\"form-field view-report-btn\">\r\n <button type=\"submit\" class=\"btn btn-report\">View</button>\r\n </div>\r\n </div>\r\n </div>\r\n </form>\r\n</section>\r\n<hr>\r\n<!-- Error Messages -->\r\n<div class=\"alert alert-danger mt-3\" *ngIf=\"formValidationError && hasSearched\">\r\n Please fill all required fields before submitting the form.\r\n</div>\r\n\r\n<div class=\"alert alert-danger mt-3\" *ngIf=\"errorMessage && loadingState === ComponentLoadingState.Error\">\r\n {{ errorMessage }}\r\n <button type=\"button\" class=\"btn-close\" (click)=\"errorMessage = ''\"></button>\r\n</div>", styles: ["@charset \"UTF-8\";.filter-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;grid-column:span 3}.form-field{display:flex;flex-direction:column;padding:0 4px 0 0!important;min-width:0}.col-custom-10-5{flex:0 0 87.5%!important;max-width:87.5%!important}.col-custom-1-5{flex:0 0 12.5%!important;max-width:12.5%!important;padding:0!important}::ng-deep .ng-select .ng-select-container .ng-value-container{overflow:hidden;flex-wrap:nowrap}::ng-deep .ng-select .ng-select-container .ng-value-container .ng-value{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:100%}::ng-deep .ng-select .ng-select-container{height:32px!important;min-height:32px!important;font-size:12px!important;align-items:center}.form-label{margin-bottom:0!important}.date-group{height:32px!important}::ng-deep .transaction-status-select .ng-dropdown-panel .ng-dropdown-panel-items .ng-option{padding:4px 0!important}::ng-deep .ng-select .ng-select-container .ng-value-container{padding-top:0}::ng-deep .ng-dropdown-panel .ng-option{font-size:12px}.btn-report{border-radius:4px;background-color:#8091a5;color:#fff!important;font-size:14px!important;height:32px;padding:4px 15px!important;margin-left:10px!important;width:110px!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}.fa-calendar{--fa: \"\\f073\" !important}.dpicker{border:1px solid #ccc!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;margin-left:0!important}.cal:focus{box-shadow:none!important}.label-data{font-weight:600!important;font-size:.7rem!important;line-height:1rem}@media (max-width: 768px){.filter-grid{grid-template-columns:1fr;gap:12px}}.input-group-button{background:none!important;border:1px solid #1877F2!important;background-color:#1877f2!important;border-radius:0 3px 3px 0!important;min-width:35px;margin-left:1px;height:32px!important;cursor:pointer}.input-group-button .fa{color:#fff}.input-group-button:focus{box-shadow:0 0 5px 3px #009ee054}.input-group-button:focus{outline:none!important;box-shadow:none!important}.Breadcrumb h1,.Breadcrumb h2{font-weight:700}\n"] }]
|
|
394
554
|
}], ctorParameters: function () { return [{ type: i1.ReportService }, { type: i2.FormBuilder }, { type: i3.ConfigService }]; }, propDecorators: { ReportName: [{
|
|
395
555
|
type: Input
|
|
396
556
|
}], searchClicked: [{
|
|
397
557
|
type: Output
|
|
398
558
|
}] } });
|
|
399
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"search-filter.component.js","sourceRoot":"","sources":["../../../../../../projects/reports-lib/src/lib/shared/search-filter/search-filter.component.ts","../../../../../../projects/reports-lib/src/lib/shared/search-filter/search-filter.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, HostListener, Input, OnInit, OnDestroy, Output } from '@angular/core';\r\nimport { AbstractControl, FormArray, FormBuilder, FormGroup, ValidatorFn, Validators } from '@angular/forms';\r\nimport { UserReportDefaults, CompanyReportConfig, ComponentLoadingState, Client, Branch, Currency, Product, TransactionStatus, User } from '../../models/transaction-enquiry-report/transaction-enquiry.model';\r\nimport { Subject } from 'rxjs';\r\nimport { takeUntil } from 'rxjs/operators';\r\nimport { ReportService } from '../../services/report.service';\r\nimport { ConfigService } from '../../services/config.service';\r\n\r\n\r\n@Component({\r\n  selector: 'lib-search-filter',\r\n  templateUrl: './search-filter.component.html',\r\n  styleUrls: ['./search-filter.component.scss']\r\n})\r\n\r\nexport class SearchFilterComponent implements OnInit, OnDestroy {\r\n  @Input() ReportName!: string;\r\n  @Output() searchClicked = new EventEmitter<any>();\r\n\r\n  searchForm!: FormGroup;\r\n  formValidationError: boolean = false;\r\n  private destroy$ = new Subject<void>();\r\n\r\n  loadingState: ComponentLoadingState = ComponentLoadingState.Complete;\r\n  ComponentLoadingState = ComponentLoadingState;\r\n  hasSearched: boolean = false;\r\n  private _errorMessage: string = '';\r\n\r\n  currentUser: string = '';\r\n  usernameMissing: boolean = false;\r\n  token = sessionStorage.getItem('access_token');\r\n  applicationType = 'ezremit';\r\n  companyCode = 'BH';\r\n  serviceUrl: string;\r\n  userReportDefaults: UserReportDefaults | null = null;\r\n  companyReportConfig: CompanyReportConfig | null = null;\r\n\r\n  clients1: Client[] = [];\r\n  branches: Branch[] = [];\r\n  users: User[] = [];\r\n  currencies: Currency[] = [];\r\n  products: Product[] = [];\r\n  transactionStatuses: TransactionStatus[] = [];\r\n  selectedStatuses: string[] = [];\r\n  showStatusDropdown: boolean = false;\r\n  visibleFieldKeys: string[] = [];\r\n  dateType: any = 1;\r\n  date: any;\r\n\r\n  // Field visibility map, 'fromDate', 'toDate','product','userId','currency','transactionStatus','transactionNo'\r\n  visibleFieldsMap: { [report: string]: string[] } = {\r\n    'Transaction Enquiry': ['client', 'fromDate', 'toDate', 'branch', 'product', 'currency', 'userId', 'transactionStatus', 'transactionNo'],\r\n    'FC Ledger': ['client', 'fromDate', 'toDate', 'currency', 'product'],\r\n    'Branch Activity': ['branch', 'userId', 'fromDate', 'toDate'],\r\n    'ACC GL Details Enquiry': ['dateType', 'date'],\r\n    // Add more report types here\r\n  };\r\n\r\n  get visibleFields(): string[] {\r\n    return this.visibleFieldsMap[this.ReportName] || [];\r\n  }\r\n\r\n  isFieldVisible(field: string): boolean {\r\n    return this.visibleFields.includes(field);\r\n  }\r\n\r\n  constructor(\r\n    private reportService: ReportService,\r\n    private fb: FormBuilder,\r\n    private config: ConfigService\r\n  ) {\r\n    this.serviceUrl = this.config.get.serviceUrl;\r\n    let fossilUser = sessionStorage.getItem('fossilusername');\r\n    let ezremitUser = sessionStorage.getItem('ezremitusername');\r\n\r\n    if (fossilUser) this.currentUser = fossilUser;\r\n    else if (ezremitUser) this.currentUser = ezremitUser;\r\n    else {\r\n      this.currentUser = 'vipul.katale@xpressmoney.tech';\r\n      this.usernameMissing = true;\r\n    }\r\n  }\r\n\r\n  ngOnInit(): void {\r\n    this.checkReport();\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    this.destroy$.next();\r\n    this.destroy$.complete();\r\n  }\r\n\r\n  private checkReport() {\r\n    if (this.ReportName == \"Transaction Enquiry\") {\r\n      this.currentUser = this.currentUser.replace(/\"/g, '');\r\n\r\n      this.initializeForm();\r\n      this.subscribeToDateChanges();\r\n      this.loadInitialData();\r\n    }\r\n\r\n    if (this.ReportName == \"ACC GL Details Enquiry\") {\r\n      this.initializeForm();\r\n    }\r\n  }\r\n\r\n  loadInitialData() {\r\n    if (this.ReportName == 'Transaction Enquiry') {\r\n      this.loadInitialDatafortxnEnquiry();\r\n    }\r\n\r\n\r\n  }\r\n\r\n  private initializeForm(): void {\r\n    if (this.ReportName == \"Transaction Enquiry\") {\r\n\r\n      this.searchForm = this.fb.group(\r\n        {\r\n          client: ['', Validators.required],\r\n          fromDate: [new Date().toISOString().split(\"T\")[0], Validators.required],\r\n          toDate: [new Date().toISOString().split(\"T\")[0], Validators.required],\r\n          branch: ['', Validators.required],\r\n          userId: ['-1'],\r\n          currency: ['All'],\r\n          product: ['All', Validators.required],\r\n          transactionStatus: [['All'], Validators.required],\r\n          transactionNo: [''],\r\n          cardNo: [''],\r\n          idType: [''],\r\n          idNo: [''],\r\n          senderName: [''],\r\n          beneficiaryName: [''],\r\n          telNo: [''],\r\n          receiveAmount: [''],\r\n          branchName: [''],\r\n          country: [''],\r\n        },\r\n      );\r\n\r\n      this.selectedStatuses = ['All'];\r\n    }\r\n\r\n    if (this.ReportName == \"ACC GL Details Enquiry\") {\r\n      this.searchForm = this.fb.group(\r\n        {\r\n          date: [new Date().toISOString().split(\"T\")[0], Validators.required],\r\n          dateType: [1, Validators.required]\r\n        });\r\n    }\r\n  }\r\n\r\n  private async loadInitialDatafortxnEnquiry(): Promise<void> {\r\n    this.loadingState = ComponentLoadingState.Loading;\r\n    this.errorMessage = '';\r\n    try {\r\n      const data = await this.reportService\r\n        .getPageLoadData(this.currentUser)\r\n        .pipe(takeUntil(this.destroy$))\r\n        .toPromise();\r\n\r\n      if (data) {\r\n        this.clients1 = data.clients || [];\r\n        this.currencies = data.currencies || [];\r\n        this.transactionStatuses = (data.transactionStatuses || []).filter(\r\n          ts => ts.transactionStatus !== ''\r\n        );\r\n\r\n        if (\r\n          !this.transactionStatuses.some(\r\n            s => s.transactionStatus === 'All'\r\n          )\r\n        ) {\r\n          this.transactionStatuses.unshift({\r\n            transactionStatus: 'All',\r\n          } as TransactionStatus);\r\n        }\r\n\r\n        this.setDefaultFormValues();\r\n\r\n        if (this.clients1.length === 1) {\r\n          this.searchForm.patchValue({\r\n            client: this.clients1[0].businessPartnerCode,\r\n          });\r\n          await this.onClientChange();\r\n        }\r\n      }\r\n\r\n      this.loadingState = ComponentLoadingState.Complete;\r\n    } catch (error) {\r\n      this.errorMessage = 'Failed to load initial data';\r\n      this.loadingState = ComponentLoadingState.Error;\r\n    }\r\n  }\r\n\r\n\r\n  private subscribeToDateChanges(): void {\r\n    this.searchForm.get('fromDate')?.valueChanges.subscribe(fromDateStr => {\r\n      const toDateControl = this.searchForm.get('toDate');\r\n      const toDateStr = toDateControl?.value;\r\n      if (!fromDateStr || !toDateStr) return;\r\n      const fromDate = new Date(fromDateStr);\r\n      const toDate = new Date(toDateStr);\r\n\r\n      const maxToDate = new Date(fromDate);\r\n      maxToDate?.setDate(fromDate.getDate() + 31);\r\n      if (toDate > maxToDate) {\r\n        toDateControl?.patchValue(maxToDate.toISOString().split(\"T\")[0]);\r\n      }\r\n    });\r\n\r\n    this.searchForm.get('toDate')?.valueChanges.subscribe(toDateStr => {\r\n      const fromDateControl = this.searchForm.get('fromDate');\r\n      const fromDateStr = fromDateControl?.value;\r\n      if (!toDateStr || !fromDateStr) return;\r\n      const toDate = new Date(toDateStr);\r\n      const fromDate = new Date(fromDateStr);\r\n\r\n      const minFromDate = new Date(toDate);\r\n      minFromDate?.setDate(toDate.getDate() - 31);\r\n      if (fromDate < minFromDate) {\r\n        fromDateControl?.patchValue(minFromDate.toISOString().split(\"T\")[0]);\r\n      }\r\n    });\r\n  }\r\n\r\n\r\n  private setDefaultFormValues(): void {\r\n    if (this.userReportDefaults) {\r\n      this.searchForm.patchValue({\r\n        currency: this.userReportDefaults.LocalCurrency || 'All',\r\n      });\r\n    }\r\n  }\r\n\r\n\r\n  async onClientChange(): Promise<void> {\r\n    this.loadingState = ComponentLoadingState.Loading;\r\n    if (this.ReportName == \"Transaction Enquiry\") {\r\n      const selectedClient = this.searchForm.get('client')?.value;\r\n      if (!selectedClient) return;\r\n\r\n      this.searchForm.patchValue({ branch: '', userId: '' });\r\n      this.branches = [];\r\n      this.products = [];\r\n      this.users = [];\r\n\r\n      try {\r\n        await Promise.all([\r\n          this.loadBranchesByAgent(selectedClient),\r\n          this.loadProductsByAgent(selectedClient),\r\n        ]);\r\n        this.loadingState = ComponentLoadingState.Complete;\r\n      } catch (err) {\r\n        this.errorMessage = 'Failed to load branch/product';\r\n        this.loadingState = ComponentLoadingState.Complete;\r\n      }\r\n    }\r\n  }\r\n\r\n  private async loadBranchesByAgent(agentCode: string): Promise<void> {\r\n    const branches = await this.reportService\r\n      .getBranchesByAgent(agentCode, this.currentUser)\r\n      .pipe(takeUntil(this.destroy$))\r\n      .toPromise();\r\n    this.branches = branches || [];\r\n\r\n    if (this.branches.length === 1) {\r\n      this.searchForm.patchValue({ branch: this.branches[0].branchCode });\r\n      await this.loadUsersByBranch(agentCode, this.branches[0].branchCode);\r\n    } else if (this.branches.some(b => b.branchCode === 'All')) {\r\n      this.searchForm.patchValue({ branch: 'All' });\r\n      await this.loadUsersByBranch(agentCode, 'All');\r\n    } else {\r\n      this.searchForm.patchValue({ branch: '' });\r\n      this.users = [];\r\n    }\r\n  }\r\n\r\n  private async loadProductsByAgent(agentCode: string): Promise<void> {\r\n    const products = await this.reportService\r\n      .getProductsByAgent(agentCode)\r\n      .pipe(takeUntil(this.destroy$))\r\n      .toPromise();\r\n    this.products = products || [];\r\n  }\r\n\r\n  async onBranchChange(): Promise<void> {\r\n    this.loadingState = ComponentLoadingState.Loading;\r\n    if (this.ReportName == \"Transaction Enquiry\") {\r\n      const client = this.searchForm.get('client')?.value;\r\n      const branch = this.searchForm.get('branch')?.value;\r\n      if (client && branch) {\r\n        await this.loadUsersByBranch(client, branch);\r\n        this.loadingState = ComponentLoadingState.Complete;\r\n      } else {\r\n        this.users = [];\r\n        this.loadingState = ComponentLoadingState.Complete;\r\n      }\r\n    }\r\n  }\r\n\r\n  private async loadUsersByBranch(agentCode: string, branchCode: string): Promise<void> {\r\n    return new Promise<void>((resolve, reject) => {\r\n      this.reportService\r\n        .getUsersByBranch(agentCode, branchCode)\r\n        .pipe(takeUntil(this.destroy$))\r\n        .subscribe({\r\n          next: (users) => {\r\n            this.users = users || [];\r\n\r\n            // Try to find a user indicating \"All\"\r\n            const allUser = this.users.find(\r\n              u => u.userName === 'All' || u.userId === -1\r\n            );\r\n\r\n            if (allUser) {\r\n              // If \"All\" is present, select it\r\n              this.searchForm.patchValue({ userId: allUser.userId });\r\n            } else if (this.users.length === 1) {\r\n              // If only one user, select that user\r\n              this.searchForm.patchValue({ userId: this.users[0].userId });\r\n            } else {\r\n              // Otherwise, clear user selection\r\n              this.searchForm.patchValue({ userId: '' });\r\n            }\r\n\r\n            resolve();\r\n          },\r\n          error: (err) => reject(err),\r\n        });\r\n    });\r\n  }\r\n\r\n  onSearch(): void {\r\n    if (this.ReportName == \"Transaction Enquiry\") {\r\n      this.hasSearched = true;\r\n      if (this.searchForm.invalid) {\r\n        this.formValidationError = true;\r\n        this.markFormGroupTouched(this.searchForm);\r\n        return;\r\n      }\r\n      this.formValidationError = false;\r\n      this.searchClicked.emit(this.buildSearchCriteria());\r\n    }\r\n\r\n    if (this.ReportName == \"ACC GL Details Enquiry\") {\r\n      const modal = {\r\n        selectedDateType: this.searchForm.controls[\"dateType\"]?.value,\r\n        selectedDate: this.searchForm.controls[\"date\"]?.value\r\n      }\r\n      this.searchClicked.emit(modal);\r\n    }\r\n  }\r\n\r\n  private markFormGroupTouched(formGroup: FormGroup | FormArray): void {\r\n    Object.values(formGroup.controls).forEach(control => {\r\n      if (control instanceof FormGroup || control instanceof FormArray) {\r\n        this.markFormGroupTouched(control);\r\n      } else {\r\n        control.markAsTouched();\r\n      }\r\n    });\r\n  }\r\n\r\n  private buildSearchCriteria(): any {\r\n    if (this.ReportName == \"Transaction Enquiry\") {\r\n      const formValue = this.searchForm.value;\r\n      return {\r\n        bank: formValue.client,\r\n        fromDate: this.toIsoFormat(formValue.fromDate),\r\n        toDate: this.toIsoFormat(formValue.toDate),\r\n        branch: formValue.branch,\r\n        user: formValue.userId || '-1',\r\n        currency: formValue.currency,\r\n        product: formValue.product,\r\n        status: this.selectedStatuses.includes('All') ? [''] : this.selectedStatuses,\r\n        transactionNo: (formValue.transactionNo || '').trim(),\r\n        cardNo: formValue.cardNo || '',\r\n        idType: formValue.idType || '',\r\n        idNo: formValue.idNo || '',\r\n        senderName: formValue.senderName || '',\r\n        beneficiaryName: formValue.beneficiaryName || '',\r\n        telNo: formValue.telNo || '',\r\n        payoutAmount: formValue.receiveAmount || '',\r\n        branchName: formValue.branchName || '',\r\n        company: this.companyCode || '',\r\n        country: formValue.country || '',\r\n        sysUserID: this.currentUser,\r\n      };\r\n    }\r\n  }\r\n\r\n  toIsoFormat(dateInput: any): string | undefined {\r\n    if (!dateInput) return undefined;\r\n\r\n    // Handle { year, month, day }\r\n    if (\r\n      typeof dateInput === 'object' &&\r\n      dateInput.year &&\r\n      dateInput.month &&\r\n      dateInput.day\r\n    ) {\r\n      const year = dateInput.year;\r\n      const month = String(dateInput.month).padStart(2, '0');\r\n      const day = String(dateInput.day).padStart(2, '0');\r\n      return `${year}-${month}-${day}`;\r\n    }\r\n\r\n    // Handle JS Date object\r\n    if (dateInput instanceof Date) {\r\n      if (isNaN(dateInput.getTime())) return undefined;\r\n      const year = dateInput.getFullYear();\r\n      const month = String(dateInput.getMonth() + 1).padStart(2, '0');\r\n      const day = String(dateInput.getDate()).padStart(2, '0');\r\n      return `${year}-${month}-${day}`;\r\n    }\r\n\r\n    // Handle dd/MM/yyyy string\r\n    if (typeof dateInput === 'string' && dateInput.includes('/')) {\r\n      const parts = dateInput.split('/');\r\n      if (parts.length === 3) {\r\n        const [day, month, year] = parts;\r\n        return `${year}-${month.padStart(2, '0')}-${day.padStart(2, '0')}`;\r\n      }\r\n    }\r\n\r\n    // Handle ISO string (yyyy-MM-dd or yyyy-MM-ddTHH:mm:ss.sssZ)\r\n    if (typeof dateInput === 'string' && /^\\d{4}-\\d{2}-\\d{2}/.test(dateInput)) {\r\n      // Use only date part if full ISO string\r\n      return dateInput.substring(0, 10);\r\n    }\r\n\r\n    return undefined;\r\n  }\r\n\r\n\r\n  get errorMessage(): string {\r\n    return this._errorMessage;\r\n  }\r\n\r\n  set errorMessage(value: string) {\r\n    this._errorMessage = value;\r\n  }\r\n\r\n  get isLoading(): boolean {\r\n    return this.loadingState === ComponentLoadingState.Loading;\r\n  }\r\n\r\n  get isError(): boolean {\r\n    return this.loadingState === ComponentLoadingState.Error;\r\n  }\r\n}\r\n","<h6 class=\"Breadcrumb\">\r\n  <a class=\"BreadCrumbLink\" [routerLink]=\"['/reports']\">\r\n    <h1>Reports</h1>\r\n  </a>\r\n  <a href=\"BreadCrumbLink\"></a>\r\n  <span class=\"BreadCrumbArrow\"></span>\r\n  <a class=\"BreadCrumbLink\">\r\n    <h2>{{ ReportName }}</h2>\r\n  </a>\r\n</h6>\r\n\r\n<app-loader *ngIf=\"loadingState === ComponentLoadingState.Loading\"></app-loader>\r\n\r\n<section class=\"filter-section\">\r\n  <form [formGroup]=\"searchForm\" (ngSubmit)=\"onSearch()\" class=\"report-filter-form\">\r\n    <div class=\"row\">\r\n      <div class=\"col-custom-10-5\">\r\n        <div class=\"grid-container\">\r\n          <div class=\"filter-grid\">\r\n\r\n            <!-- Dynamically render filters in order -->\r\n            <ng-container *ngFor=\"let field of visibleFields\">\r\n              <ng-container [ngSwitch]=\"field\">\r\n\r\n                <!-- Client -->\r\n                <div class=\"form-field\" *ngSwitchCase=\"'client'\">\r\n                  <div class=\"row align-items-center\">\r\n                    <div class=\"col-2\">\r\n                      <label class=\"form-label label-data\">Client<span class=\"text-danger\">*</span></label>\r\n                    </div>\r\n                    <div class=\"col-10\">\r\n                      <ng-select [items]=\"clients1\" bindLabel=\"businessPartnerName\" bindValue=\"businessPartnerCode\"\r\n                        placeholder=\"Select Client\" [clearable]=\"false\" formControlName=\"client\" required\r\n                        (change)=\"onClientChange()\">\r\n                      </ng-select>\r\n                    </div>\r\n                  </div>\r\n                </div>\r\n\r\n                <!-- Branch -->\r\n                <div class=\"form-field\" *ngSwitchCase=\"'branch'\">\r\n                  <div class=\"row align-items-center\">\r\n                    <div class=\"col-2\">\r\n                      <label class=\"form-label label-data\">Branch<span class=\"text-danger\">*</span></label>\r\n                    </div>\r\n                    <div class=\"col-10\">\r\n                      <ng-select [items]=\"branches\" bindLabel=\"businessPartnerBranch\" bindValue=\"branchCode\"\r\n                        placeholder=\"Select Branch\" [clearable]=\"false\" formControlName=\"branch\" required\r\n                        (change)=\"onBranchChange()\">\r\n                      </ng-select>\r\n                    </div>\r\n                  </div>\r\n                </div>\r\n\r\n                <!-- From Date -->\r\n                <div class=\"form-field\" *ngSwitchCase=\"'fromDate'\">\r\n                  <div class=\"row align-items-center\">\r\n                    <div class=\"col-2\">\r\n                      <label class=\"form-label label-data\">From Date<span class=\"text-danger\">*</span></label>\r\n                    </div>\r\n                    <div class=\"col-10\">\r\n                      <div class=\"input-group date-group\">\r\n                        <input class=\"form-control dpicker\" placeholder=\"dd/mm/yyyy\" ngbDatepicker\r\n                          #fromDateInput=\"ngbDatepicker\" formControlName=\"fromDate\" autocomplete=\"off\" />\r\n                        <button class=\"input-group-button cal\" (click)=\"fromDateInput.toggle()\" type=\"button\">\r\n                          <i class=\"fa fa-calendar\" aria-hidden=\"true\"></i>\r\n                        </button>\r\n                      </div>\r\n                    </div>\r\n                  </div>\r\n                </div>\r\n\r\n                <!-- To Date -->\r\n                <div class=\"form-field\" *ngSwitchCase=\"'toDate'\">\r\n                  <div class=\"row align-items-center\">\r\n                    <div class=\"col-2\">\r\n                      <label class=\"form-label label-data\">To Date<span class=\"text-danger\">*</span></label>\r\n                    </div>\r\n                    <div class=\"col-10\">\r\n                      <div class=\"input-group date-group\">\r\n                        <input class=\"form-control dpicker\" placeholder=\"dd/mm/yyyy\" ngbDatepicker\r\n                          #toDateInput=\"ngbDatepicker\" formControlName=\"toDate\" autocomplete=\"off\" />\r\n                        <button class=\"input-group-button cal\" (click)=\"toDateInput.toggle()\" type=\"button\">\r\n                          <i class=\"fa fa-calendar\" aria-hidden=\"true\"></i>\r\n                        </button>\r\n                      </div>\r\n                    </div>\r\n                  </div>\r\n                </div>\r\n\r\n                <!-- Product -->\r\n                <div class=\"form-field\" *ngSwitchCase=\"'product'\">\r\n                  <div class=\"row align-items-center\">\r\n                    <div class=\"col-2\">\r\n                      <label class=\"form-label label-data\">Product</label>\r\n                    </div>\r\n                    <div class=\"col-10\">\r\n                      <ng-select [items]=\"products\" bindLabel=\"productName\" bindValue=\"productCode\"\r\n                        placeholder=\"Select Product\" [clearable]=\"false\" formControlName=\"product\">\r\n                      </ng-select>\r\n                    </div>\r\n                  </div>\r\n                </div>\r\n\r\n                <!-- User -->\r\n                <div class=\"form-field\" *ngSwitchCase=\"'userId'\">\r\n                  <div class=\"row align-items-center\">\r\n                    <div class=\"col-2\">\r\n                      <label class=\"form-label label-data\">User<span class=\"text-danger\">*</span></label>\r\n                    </div>\r\n                    <div class=\"col-10\">\r\n                      <ng-select [items]=\"users\" bindLabel=\"userName\" bindValue=\"userId\" placeholder=\"Select User\"\r\n                        [clearable]=\"false\" formControlName=\"userId\" required>\r\n                      </ng-select>\r\n                    </div>\r\n                  </div>\r\n                </div>\r\n\r\n                <!-- Currency -->\r\n                <div class=\"form-field\" *ngSwitchCase=\"'currency'\">\r\n                  <div class=\"row align-items-center\">\r\n                    <div class=\"col-2\">\r\n                      <label class=\"form-label label-data\">Currency</label>\r\n                    </div>\r\n                    <div class=\"col-10\">\r\n                      <ng-select [items]=\"currencies\" bindLabel=\"currencyCode\" bindValue=\"currencyCode\"\r\n                        placeholder=\"Select Currency\" [clearable]=\"false\" formControlName=\"currency\">\r\n                      </ng-select>\r\n                    </div>\r\n                  </div>\r\n                </div>\r\n\r\n                <!-- Transaction Status (Multi-select) -->\r\n                <div class=\"form-field\" *ngSwitchCase=\"'transactionStatus'\">\r\n                  <div class=\"row align-items-center\">\r\n                    <div class=\"col-2\">\r\n                      <label class=\"form-label label-data\">Trans. Status<span class=\"text-danger\">*</span></label>\r\n                    </div>\r\n                    <div class=\"col-10\">\r\n                      <ng-select class=\"transaction-status-select\" [items]=\"transactionStatuses\"\r\n                        bindLabel=\"transactionStatus\" bindValue=\"transactionStatus\" [multiple]=\"true\"\r\n                        placeholder=\"Select Transaction Status\" formControlName=\"transactionStatus\"\r\n                        [closeOnSelect]=\"false\" [clearable]=\"false\" [searchable]=\"false\" required>\r\n                        <ng-template ng-option-tmp let-item=\"item\" let-item$=\"item$\">\r\n                          <input type=\"checkbox\" [checked]=\"item$.selected\" /> {{ item.transactionStatus }}\r\n                        </ng-template>\r\n                      </ng-select>\r\n                    </div>\r\n                  </div>\r\n                </div>\r\n\r\n                <!-- Transaction No -->\r\n                <div class=\"form-field\" *ngSwitchCase=\"'transactionNo'\">\r\n                  <div class=\"row align-items-center\">\r\n                    <div class=\"col-2\">\r\n                      <label class=\"form-label label-data\">Trans. Number</label>\r\n                    </div>\r\n                    <div class=\"col-10\">\r\n                      <input class=\"form-control dpicker\" formControlName=\"transactionNo\"\r\n                        placeholder=\"Enter transaction number\" />\r\n                    </div>\r\n                  </div>\r\n                </div>\r\n\r\n                <!-- Value Date -->\r\n                <div class=\"form-field\" *ngSwitchCase=\"'valueDate'\">\r\n                  <div class=\"row align-items-center\">\r\n                    <div class=\"col-3\">\r\n                      <label class=\"form-label label-data\">Value Date<span class=\"text-danger\">*</span></label>\r\n                    </div>\r\n                    <div class=\"col-9\">\r\n                      <div class=\"input-group\">\r\n                        <input class=\"form-control dpicker\" placeholder=\"dd/mm/yyyy\" ngbDatepicker\r\n                          #toDateInput=\"ngbDatepicker\" formControlName=\"toDate\" autocomplete=\"off\" />\r\n                        <button class=\"btn btn-outline-secondary\" type=\"button\" (click)=\"toDateInput.toggle()\">\r\n                          <i class=\"fa fa-calendar\"></i>\r\n                        </button>\r\n                      </div>\r\n                    </div>\r\n                  </div>\r\n                </div>\r\n\r\n                <!-- Date Type -->\r\n                <div class=\"form-field\" *ngSwitchCase=\"'dateType'\">\r\n                  <div class=\"row align-items-center\">\r\n                    <div class=\"col-2\">\r\n                      <label class=\"form-label label-data\">Date Type</label>\r\n                    </div>\r\n                    <div class=\"col-10\">\r\n                      <ng-select placeholder=\"- Please select -\" formControlName=\"dateType\" [clearable]=\"false\"\r\n                        required>\r\n                        <ng-option [value]=\"1\">\r\n                          Value Date\r\n                        </ng-option>\r\n                        <ng-option [value]=\"2\">\r\n                          Posting Date\r\n                        </ng-option>\r\n                      </ng-select>\r\n                    </div>\r\n                  </div>\r\n                </div>\r\n\r\n                <!-- Date -->\r\n                <div class=\"form-field\" *ngSwitchCase=\"'date'\">\r\n                  <div class=\"row align-items-center\">\r\n                    <div class=\"col-2\">\r\n                      <label class=\"form-label label-data\">Date</label>\r\n                    </div>\r\n                    <div class=\"col-10\">\r\n                      <div class=\"input-group date-group\">\r\n                        <input class=\"form-control dpicker\" placeholder=\"dd/mm/yyyy\" ngbDatepicker\r\n                          #toDateInput=\"ngbDatepicker\" formControlName=\"date\" autocomplete=\"off\" />\r\n                        <button class=\"input-group-button cal\" (click)=\"toDateInput.toggle()\" type=\"button\">\r\n                          <i class=\"fa fa-calendar\" aria-hidden=\"true\"></i>\r\n                        </button>\r\n                      </div>\r\n                    </div>\r\n                  </div>\r\n                </div>\r\n\r\n              </ng-container>\r\n            </ng-container>\r\n\r\n          </div>\r\n        </div>\r\n      </div>\r\n      <div class=\"col-custom-1-5\">\r\n        <!-- View Report Button (Always at Top-Right) -->\r\n        <div class=\"form-field view-report-btn\">\r\n          <button type=\"submit\" class=\"btn btn-report\">View</button>\r\n        </div>\r\n      </div>\r\n    </div>\r\n  </form>\r\n</section>\r\n<hr>\r\n<!-- Error Messages -->\r\n<div class=\"alert alert-danger mt-3\" *ngIf=\"formValidationError && hasSearched\">\r\n  Please fill all required fields before submitting the form.\r\n</div>\r\n\r\n<div class=\"alert alert-danger mt-3\" *ngIf=\"errorMessage && loadingState === ComponentLoadingState.Error\">\r\n  {{ errorMessage }}\r\n  <button type=\"button\" class=\"btn-close\" (click)=\"errorMessage = ''\"></button>\r\n</div>"]}
|
|
559
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"search-filter.component.js","sourceRoot":"","sources":["../../../../../../projects/reports-lib/src/lib/shared/search-filter/search-filter.component.ts","../../../../../../projects/reports-lib/src/lib/shared/search-filter/search-filter.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, HostListener, Input, OnInit, OnDestroy, Output } from '@angular/core';\r\nimport { AbstractControl, FormArray, FormBuilder, FormGroup, ValidatorFn, Validators } from '@angular/forms';\r\nimport { UserReportDefaults, CompanyReportConfig, ComponentLoadingState, Client, Branch, Currency, Product, TransactionStatus, User } from '../../models/transaction-enquiry-report/transaction-enquiry.model';\r\nimport { Subject } from 'rxjs';\r\nimport { forkJoin, of } from 'rxjs';\r\nimport { catchError, map } from 'rxjs/operators';\r\nimport { takeUntil } from 'rxjs/operators';\r\nimport { ReportService } from '../../services/report.service';\r\nimport { ConfigService } from '../../services/config.service';\r\n\r\n\r\n@Component({\r\n  selector: 'lib-search-filter',\r\n  templateUrl: './search-filter.component.html',\r\n  styleUrls: ['./search-filter.component.scss']\r\n})\r\n\r\nexport class SearchFilterComponent implements OnInit, OnDestroy {\r\n  @Input() ReportName!: string;\r\n  @Output() searchClicked = new EventEmitter<any>();\r\n\r\n  searchForm!: FormGroup;\r\n  formValidationError: boolean = false;\r\n  private destroy$ = new Subject<void>();\r\n\r\n  loadingState: ComponentLoadingState = ComponentLoadingState.Complete;\r\n  ComponentLoadingState = ComponentLoadingState;\r\n  hasSearched: boolean = false;\r\n  private _errorMessage: string = '';\r\n\r\n  currentUser: string = '';\r\n  usernameMissing: boolean = false;\r\n  token = sessionStorage.getItem('access_token');\r\n  applicationType = 'ezremit';\r\n  companyCode = 'BH';\r\n  serviceUrl: string;\r\n  userReportDefaults: UserReportDefaults | null = null;\r\n  companyReportConfig: CompanyReportConfig | null = null;\r\n  public isOpen = false;\r\n\r\n  clients1: Client[] = [];\r\n  branches: Branch[] = [];\r\n  users: User[] = [];\r\n  currencies: Currency[] = [];\r\n  products: Product[] = [];\r\n  transactionStatuses: TransactionStatus[] = [];\r\n  selectedStatuses: string[] = [];\r\n  showStatusDropdown: boolean = false;\r\n  visibleFieldKeys: string[] = [];\r\n  params: any;\r\n  countries: any[] = [];\r\n  transactionProducts: any[] = [];\r\n  dateType: any = 1;\r\n  date: any;\r\n\r\n  // Field visibility map, 'fromDate', 'toDate','product','userId','currency','transactionStatus','transactionNo'\r\n  visibleFieldsMap: { [report: string]: string[] } = {\r\n    'Transaction Enquiry': ['client', 'fromDate', 'toDate','branch', 'product', 'currency', 'transactionStatus','transactionNo'],\r\n    'FC Ledger': ['client', 'fromDate', 'toDate', 'currency', 'product'],\r\n    'Branch Activity Send': ['client', 'fromDate', 'toDate', 'branch', 'transactionProduct', 'currency', 'transactionStatus', 'sendCountry', 'receiveCountry'],\r\n    'ACC GL Details Enquiry': ['dateType', 'date'],\r\n    // Add more report types here\r\n  };\r\n\r\n  get visibleFields(): string[] {\r\n    return this.visibleFieldsMap[this.ReportName] || [];\r\n  }\r\n\r\n  isFieldVisible(field: string): boolean {\r\n    return this.visibleFields.includes(field);\r\n  }\r\n\r\n  constructor(\r\n    private reportService: ReportService,\r\n    private fb: FormBuilder,\r\n    private config: ConfigService\r\n  ) {\r\n    this.serviceUrl = this.config.get.serviceUrl;\r\n    let fossilUser = sessionStorage.getItem('fossilusername');\r\n    let ezremitUser = sessionStorage.getItem('ezremitusername');\r\n\r\n    if (fossilUser) this.currentUser = fossilUser;\r\n    else if (ezremitUser) this.currentUser = ezremitUser;\r\n    else {\r\n      // this.currentUser = 'vipul.katale@xpressmoney.tech';\r\n      this.usernameMissing = true;\r\n    }\r\n    this.currentUser = this.currentUser.replace(/^[\"'](.*)[\"']$/, '$1');\r\n  }\r\n\r\n  ngOnInit(): void {\r\n    this.checkReport();\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    this.destroy$.next();\r\n    this.destroy$.complete();\r\n  }\r\n\r\n  private checkReport() {\r\n    if (this.ReportName == \"Transaction Enquiry\") {\r\n      this.currentUser = this.currentUser.replace(/\"/g, '');\r\n\r\n      this.initializeForm();\r\n      this.subscribeToDateChanges();\r\n      this.loadInitialData();\r\n    }\r\n    if (this.ReportName == \"Branch Activity Send\") {\r\n      this.initializeForm();\r\n      this.loadInitialData();\r\n      this.subscribeToDateChanges();\r\n    }\r\n     if (this.ReportName == \"ACC GL Details Enquiry\") {\r\n      this.initializeForm();\r\n    }\r\n  }\r\n  \r\n\r\n  loadInitialData() {\r\n    if (this.ReportName == 'Transaction Enquiry') {\r\n      this.loadInitialDatafortxnEnquiry();\r\n    }\r\n\r\n    if (this.ReportName == \"Branch Activity Send\") {\r\n      this.loadInitialDataforBranchActivitySend();\r\n    }\r\n\r\n  }\r\n\r\n  private initializeForm(): void {\r\n    if (this.ReportName == \"Transaction Enquiry\") {\r\n      this.searchForm = this.fb.group(\r\n        {\r\n          client: [null, Validators.required],\r\n          fromDate: [new Date().toISOString().split(\"T\")[0], Validators.required],\r\n          toDate: [new Date().toISOString().split(\"T\")[0], Validators.required],\r\n          branch: [null, Validators.required],\r\n          userId: ['-1'],\r\n          currency: ['All'],\r\n          product: [null, Validators.required],\r\n          transactionStatus: [['All'], Validators.required],\r\n          transactionNo: [''],\r\n          cardNo: [''],\r\n          idType: [''],\r\n          idNo: [''],\r\n          senderName: [''],\r\n          beneficiaryName: [''],\r\n          telNo: [''],\r\n          receiveAmount: [''],\r\n          branchName: [''],\r\n          country: [''],\r\n        },\r\n      );\r\n\r\n      this.selectedStatuses = ['All'];\r\n}\r\nif (this.ReportName == \"ACC GL Details Enquiry\") {\r\n    this.searchForm = this.fb.group(\r\n        {\r\n            date: [new Date().toISOString().split(\"T\")[0], Validators.required],\r\n            dateType: [1, Validators.required]\r\n        });\r\n}\r\n    if (this.ReportName == \"Branch Activity Send\") {\r\n      this.searchForm = this.fb.group(\r\n        {\r\n          client: [null, Validators.required],\r\n          fromDate: [new Date().toISOString().split(\"T\")[0], Validators.required],\r\n          toDate: [new Date().toISOString().split(\"T\")[0], Validators.required],\r\n          branch: [null, Validators.required],\r\n          currency: ['All'],\r\n          product: ['All', Validators.required],\r\n          transactionStatus: [['All'], Validators.required],\r\n          sendCountry: ['All'],\r\n          receiveCountry: ['All']\r\n        }\r\n      );\r\n    }\r\n  }\r\n\r\n  loadInitialDataforBranchActivitySend() {\r\n    this.loadingState = ComponentLoadingState.Loading;\r\n    forkJoin({\r\n      params: this.reportService.getParams().pipe(\r\n        catchError(err => {\r\n          console.error('Error loading params', err);\r\n          return of(null);\r\n        })\r\n      ),\r\n      clients: this.reportService.getPayInAgents(this.currentUser).pipe(\r\n        map((clients: any[]): Client[] =>\r\n          clients.map((client, index) => ({\r\n            businessPartnerName: client.agent,\r\n            businessPartnerCode: client.code,\r\n            displayOrder: index // or use some value from the API if available\r\n          }))\r\n        ),\r\n        catchError(err => {\r\n          console.error('Error loading clients', err);\r\n          return of([]);\r\n        })\r\n      )\r\n    }).subscribe(\r\n      {\r\n        next: ({ params, clients }) => {\r\n          this.params = params;\r\n          this.clients1 = clients;\r\n          // this.clientsData = [...clients];\r\n          this.countries = [...params?.countries]\r\n          this.currencies = [...params?.currencies];\r\n          this.transactionStatuses = [...params?.transactionStatusTypes];\r\n          this.transactionProducts = [...params?.transactionProductTypes];\r\n          if (!sessionStorage.getItem('fossilusername') && this.clients1?.length) {\r\n            this.selectClient(this.clients1[0].businessPartnerCode);\r\n          }\r\n          // this.loadingState = ComponentLoadingStates.Complete;\r\n        },\r\n        error: err => {\r\n          // Occurs only if an inner catchError still rethrows\r\n          console.error('Unexpected forkJoin error', err);\r\n          this.loadingState = ComponentLoadingState.Complete;\r\n        },\r\n        complete: () => {\r\n          this.loadingState = ComponentLoadingState.Complete;\r\n          this.onClientSelected();\r\n        }\r\n      }\r\n    );\r\n  }\r\n\r\n  private async loadInitialDatafortxnEnquiry(): Promise<void> {\r\n    this.loadingState = ComponentLoadingState.Loading;\r\n    this.errorMessage = '';\r\n    try {\r\n      const data = await this.reportService\r\n        .getPageLoadData(this.currentUser)\r\n        .pipe(takeUntil(this.destroy$))\r\n        .toPromise();\r\n\r\n      if (data) {\r\n        this.clients1 = data.clients || [];\r\n        this.currencies = data.currencies || [];\r\n        this.transactionStatuses = (data.transactionStatuses || []).filter(\r\n          ts => ts.transactionStatus !== ''\r\n        );\r\n        if (\r\n          !this.transactionStatuses.some(\r\n            s => s.transactionStatus === 'All'\r\n          )\r\n        ) {\r\n          this.transactionStatuses.unshift({\r\n            transactionStatus: 'All',\r\n          } as TransactionStatus);\r\n        }\r\n\r\n        this.setDefaultFormValues();\r\n\r\n        if (this.clients1.length === 1) {\r\n          this.searchForm.patchValue({\r\n            client: this.clients1[0].businessPartnerCode,\r\n          });\r\n          await this.onClientChange();\r\n        }\r\n      }\r\n\r\n      this.loadingState = ComponentLoadingState.Complete;\r\n    } catch (error) {\r\n      this.errorMessage = 'Failed to load initial data';\r\n      this.loadingState = ComponentLoadingState.Error;\r\n    }\r\n  }\r\n\r\n\r\n  private subscribeToDateChanges(): void {\r\n    this.searchForm.get('fromDate')?.valueChanges.subscribe(fromDateStr => {\r\n      const toDateControl = this.searchForm.get('toDate');\r\n      const toDateStr = toDateControl?.value;\r\n      if (!fromDateStr || !toDateStr) return;\r\n      const fromDate = new Date(fromDateStr);\r\n      const toDate = new Date(toDateStr);\r\n\r\n      const maxToDate = new Date(fromDate);\r\n      maxToDate?.setDate(fromDate.getDate() + 31);\r\n      if (toDate.setHours(0,0,0,0) > maxToDate.setHours(0,0,0,0) || toDate.setHours(0,0,0,0) < fromDate.setHours(0,0,0,0)) { \r\n        maxToDate.setHours(12,0,0,0);\r\n        toDateControl?.patchValue(maxToDate.toISOString().split(\"T\")[0]);\r\n        console.log(toDateControl);\r\n      }\r\n    });\r\n\r\n    this.searchForm.get('toDate')?.valueChanges.subscribe(toDateStr => {\r\n      const fromDateControl = this.searchForm.get('fromDate');\r\n      const fromDateStr = fromDateControl?.value;\r\n      if (!toDateStr || !fromDateStr) return;\r\n      const toDate = new Date(toDateStr);\r\n      const fromDate = new Date(fromDateStr);\r\n\r\n      const minFromDate = new Date(toDate);\r\n      minFromDate?.setDate(toDate.getDate() - 31);\r\n      if (fromDate.setHours(0,0,0,0) < minFromDate.setHours(0,0,0,0)) {  \r\n        minFromDate.setHours(12,0,0,0);\r\n        fromDateControl?.patchValue(minFromDate.toISOString().split(\"T\")[0]);\r\n      }\r\n    });\r\n  }\r\n\r\n\r\n  private setDefaultFormValues(): void {\r\n    if (this.userReportDefaults) {\r\n      this.searchForm.patchValue({\r\n        currency: this.userReportDefaults.LocalCurrency || 'All',\r\n      });\r\n    }\r\n  }\r\n\r\n\r\n  async onClientChange(): Promise<void> {\r\n    if (this.ReportName == \"Transaction Enquiry\") {\r\n      this.loadingState = ComponentLoadingState.Loading;\r\n      const selectedClient = this.searchForm.get('client')?.value;\r\n      if (!selectedClient) return;\r\n\r\n      this.searchForm.patchValue({ branch: '', userId: '' });\r\n      this.branches = [];\r\n      this.products = [];\r\n      this.users = [];\r\n\r\n      try {\r\n        await Promise.all([\r\n          this.loadBranchesByAgent(selectedClient),\r\n          this.loadProductsByAgent(selectedClient),\r\n        ]);\r\n        this.searchForm.patchValue({ product: 'All' });\r\n        this.loadingState = ComponentLoadingState.Complete;\r\n      } catch (err) {\r\n        this.errorMessage = 'Failed to load branch/product';\r\n        this.loadingState = ComponentLoadingState.Complete;\r\n      }\r\n    }\r\n\r\n    if (this.ReportName == \"Branch Activity Send\") {\r\n      const selectedClient = this.searchForm.get('client')?.value;\r\n      if (!selectedClient) return;\r\n      this.loadingState = ComponentLoadingState.Loading;\r\n      this.reportService.getBranchByAgent(this.currentUser, selectedClient).subscribe({\r\n        next: (data) => {\r\n          this.branches = data;\r\n        },\r\n        error: (err) => {\r\n          this.loadingState = ComponentLoadingState.Complete;\r\n        },\r\n        complete: () => {\r\n          if (sessionStorage.getItem(\"ezremitusername\")) {\r\n            const index = this.branches.findIndex((branch) => branch.branchCode === \"All\");\r\n            if (index == -1) {\r\n              this.searchForm.controls['branch'].setValue(this.branches[0].branchCode)\r\n            } else {\r\n              this.searchForm.controls['branch'].setValue('All');\r\n            }\r\n          }\r\n          this.loadingState = ComponentLoadingState.Complete;\r\n\r\n        }\r\n      });\r\n    }\r\n  }\r\n\r\n  private async loadBranchesByAgent(agentCode: string): Promise<void> {\r\n    const branches = await this.reportService\r\n      .getBranchesByAgent(agentCode, this.currentUser)\r\n      .pipe(takeUntil(this.destroy$))\r\n      .toPromise();\r\n    this.branches = branches || [];\r\n\r\n    if (this.branches.length === 1) {\r\n      this.searchForm.patchValue({ branch: this.branches[0].branchCode });\r\n      // await this.loadUsersByBranch(agentCode, this.branches[0].branchCode);\r\n    } else if (this.branches.some(b => b.branchCode === 'All')) {\r\n      this.searchForm.patchValue({ branch: 'All' });\r\n      // await this.loadUsersByBranch(agentCode, 'All');\r\n    } else {\r\n      this.searchForm.patchValue({ branch: '' });\r\n      this.users = [];\r\n    }\r\n  }\r\n\r\n  private async loadProductsByAgent(agentCode: string): Promise<void> {\r\n    const products = await this.reportService\r\n      .getProductsByAgent(agentCode)\r\n      .pipe(takeUntil(this.destroy$))\r\n      .toPromise();\r\n    this.products = products || [];\r\n  }\r\n\r\n  async onBranchChange(): Promise<void> {\r\n    // if (this.ReportName == \"Transaction Enquiry\") {\r\n    //   this.loadingState = ComponentLoadingState.Loading;\r\n    //   const client = this.searchForm.get('client')?.value;\r\n    //   const branch = this.searchForm.get('branch')?.value;\r\n    //   if (client && branch) {\r\n    //     // await this.loadUsersByBranch(client, branch);\r\n    //     this.loadingState = ComponentLoadingState.Complete;\r\n    //   } else {\r\n    //     this.users = [];\r\n    //     this.loadingState = ComponentLoadingState.Complete;\r\n    //   }\r\n    // }\r\n  }\r\n\r\n//   private async loadUsersByBranch(agentCode: string, branchCode: string): Promise<void> {\r\n//   return new Promise<void>((resolve, reject) => {\r\n//     this.reportService\r\n//       .getUsersByBranch(agentCode, branchCode)\r\n//       .pipe(takeUntil(this.destroy$))\r\n//       .subscribe({\r\n//         next: (users) => {\r\n//           this.users = users || [];\r\n\r\n//           // Try to find a user indicating \"All\"\r\n//           const allUser = this.users.find(\r\n//             u => u.userName === 'All' || u.userId === -1\r\n//           );\r\n\r\n//           if (allUser) {\r\n//             // If \"All\" is present, select it\r\n//             this.searchForm.patchValue({ userId: allUser.userId });\r\n//           } else if (this.users.length === 1) {\r\n//             // If only one user, select that user\r\n//             this.searchForm.patchValue({ userId: this.users[0].userId });\r\n//           } else {\r\n//             // Otherwise, clear user selection\r\n//             this.searchForm.patchValue({ userId: '' });\r\n//           }\r\n\r\n//           resolve();\r\n//         },\r\n//         error: (err) => reject(err),\r\n//       });\r\n//   });\r\n// }\r\n\r\n  onSearch(): void {\r\n    if (this.ReportName == \"Transaction Enquiry\") {\r\n      this.hasSearched = true;\r\n      if (this.searchForm.invalid) {\r\n        this.formValidationError = true;\r\n        this.markFormGroupTouched(this.searchForm);\r\n        return;\r\n      }\r\n      this.formValidationError = false;\r\n      this.searchClicked.emit(this.buildSearchCriteria());\r\n    }\r\n\r\n    if (this.ReportName == \"Branch Activity Send\") {\r\n      this.hasSearched = true;\r\n      if (this.searchForm.invalid) {\r\n        this.formValidationError = true;\r\n        // this.markFormGroupTouched(this.searchForm);\r\n        return;\r\n      }\r\n      this.formValidationError = false;\r\n      this.searchClicked.emit(this.buildSearchCriteria());\r\n    }\r\n\r\n    if (this.ReportName == \"ACC GL Details Enquiry\") {\r\n      const modal = {\r\n        selectedDateType: this.searchForm.controls[\"dateType\"]?.value,\r\n        selectedDate: this.searchForm.controls[\"date\"]?.value\r\n      }\r\n      this.searchClicked.emit(modal);\r\n    }\r\n  }\r\n\r\n  private markFormGroupTouched(formGroup: FormGroup | FormArray): void {\r\n    Object.values(formGroup.controls).forEach(control => {\r\n      if (control instanceof FormGroup || control instanceof FormArray) {\r\n        this.markFormGroupTouched(control);\r\n      } else {\r\n        control.markAsTouched();\r\n      }\r\n    });\r\n  }\r\n\r\n  private buildSearchCriteria(): any {\r\n    if (this.ReportName == \"Transaction Enquiry\") {\r\n      const formValue = this.searchForm.value;\r\n      return {\r\n        bank: formValue.client,\r\n        fromDate: this.toIsoFormat(formValue.fromDate),\r\n        toDate: this.toIsoFormat(formValue.toDate),\r\n        branch: formValue.branch,\r\n        user: formValue.userId || '-1',\r\n        currency: formValue.currency,\r\n        product: formValue.product,\r\n        status: this.selectedStatuses.includes('All') ? [''] : this.selectedStatuses,\r\n        transactionNo: (formValue.transactionNo || '').trim(),\r\n        cardNo: formValue.cardNo || '',\r\n        idType: formValue.idType || '',\r\n        idNo: formValue.idNo || '',\r\n        senderName: formValue.senderName || '',\r\n        beneficiaryName: formValue.beneficiaryName || '',\r\n        telNo: formValue.telNo || '',\r\n        payoutAmount: formValue.receiveAmount || '',\r\n        branchName: formValue.branchName || '',\r\n        company: this.companyCode || '',\r\n        country: formValue.country || '',\r\n        sysUserID: this.currentUser,\r\n      };\r\n    }\r\n\r\n    if (this.ReportName == \"Branch Activity Send\") {\r\n      const formValue = this.searchForm.value;\r\n      return {\r\n        modal: formValue,\r\n        sysUserID: this.currentUser\r\n      }\r\n    }\r\n  }\r\n\r\n  toIsoFormat(dateInput: any): string | undefined {\r\n    if (!dateInput) return undefined;\r\n\r\n    // Handle { year, month, day }\r\n    if (\r\n      typeof dateInput === 'object' &&\r\n      dateInput.year &&\r\n      dateInput.month &&\r\n      dateInput.day\r\n    ) {\r\n      const year = dateInput.year;\r\n      const month = String(dateInput.month).padStart(2, '0');\r\n      const day = String(dateInput.day).padStart(2, '0');\r\n      return `${year}-${month}-${day}`;\r\n    }\r\n\r\n    // Handle JS Date object\r\n    if (dateInput instanceof Date) {\r\n      if (isNaN(dateInput.getTime())) return undefined;\r\n      const year = dateInput.getFullYear();\r\n      const month = String(dateInput.getMonth() + 1).padStart(2, '0');\r\n      const day = String(dateInput.getDate()).padStart(2, '0');\r\n      return `${year}-${month}-${day}`;\r\n    }\r\n\r\n    // Handle dd/MM/yyyy string\r\n    if (typeof dateInput === 'string' && dateInput.includes('/')) {\r\n      const parts = dateInput.split('/');\r\n      if (parts.length === 3) {\r\n        const [day, month, year] = parts;\r\n        return `${year}-${month.padStart(2, '0')}-${day.padStart(2, '0')}`;\r\n      }\r\n    }\r\n\r\n    // Handle ISO string (yyyy-MM-dd or yyyy-MM-ddTHH:mm:ss.sssZ)\r\n    if (typeof dateInput === 'string' && /^\\d{4}-\\d{2}-\\d{2}/.test(dateInput)) {\r\n      // Use only date part if full ISO string\r\n      return dateInput.substring(0, 10);\r\n    }\r\n\r\n    return undefined;\r\n  }\r\n\r\n  onOpen() {\r\n    this.isOpen = true;\r\n  }\r\n  onClose() {\r\n    this.isOpen = false;\r\n  }\r\n\r\n\r\n  get errorMessage(): string {\r\n    return this._errorMessage;\r\n  }\r\n\r\n  set errorMessage(value: string) {\r\n    this._errorMessage = value;\r\n  }\r\n\r\n  get isLoading(): boolean {\r\n    return this.loadingState === ComponentLoadingState.Loading;\r\n  }\r\n\r\n  get isError(): boolean {\r\n    return this.loadingState === ComponentLoadingState.Error;\r\n  }\r\n\r\n  selectClient(client: any) {\r\n    this.searchForm.controls[\"client\"].setValue(client);\r\n    this.searchForm.controls[\"branch\"].setValue(null);\r\n    this.onAgentSelected(client);\r\n  }\r\n\r\n  onAgentSelected(code: any) {\r\n    if (this.searchForm.controls['client'].value === null) {\r\n      return;\r\n    }\r\n    this.searchForm.controls['branch'].patchValue(null);\r\n    // this.loadingState = ComponentLoadingStates.Loading;\r\n    this.reportService.getBranchByAgent(this.currentUser, code).subscribe({\r\n      next: (data) => {\r\n        this.branches = data;\r\n      },\r\n      error: (err) => {\r\n        // this.loadingState = ComponentLoadingStates.Complete;\r\n      },\r\n      complete: () => {\r\n        if (sessionStorage.getItem(\"ezremitusername\")) {\r\n          const index = this.branches.findIndex((branch) => branch.branchCode === \"All\");\r\n          if (index == -1) {\r\n            this.searchForm.controls['branch'].setValue(this.branches[0].branchCode)\r\n          } else {\r\n            this.searchForm.controls['branch'].setValue('All');\r\n          }\r\n        }\r\n        if (sessionStorage.getItem(\"fossilusername\")){\r\n          this.searchForm.controls['branch'].setValue('All');\r\n        }\r\n        // this.loadingState = ComponentLoadingStates.Complete;\r\n\r\n      }\r\n    });\r\n  }\r\n\r\n  onClientSelected() {\r\n    this.searchForm.get('client')?.valueChanges.subscribe((val) => {\r\n      val = this.searchForm.get('client')?.value;\r\n      this.onAgentSelected(val);\r\n    })\r\n  }\r\n}\r\n","<h6 class=\"Breadcrumb\">\r\n  <a class=\"BreadCrumbLink\" [routerLink]=\"['/reports']\">\r\n    <h1>Reports</h1>\r\n  </a>\r\n  <a href=\"BreadCrumbLink\"></a>\r\n  <span class=\"BreadCrumbArrow\"></span>\r\n  <a class=\"BreadCrumbLink\">\r\n    <h2>{{ ReportName }}</h2>\r\n  </a>\r\n</h6>\r\n\r\n<app-loader *ngIf=\"loadingState === ComponentLoadingState.Loading\"></app-loader>\r\n<section>\r\n  <form [formGroup]=\"searchForm\" (ngSubmit)=\"onSearch()\">\r\n    <div class=\"row\">\r\n      <div class=\"col-custom-10-5\">\r\n        <div class=\"filter-grid\">\r\n\r\n            <!-- Dynamically render filters in order -->\r\n            <ng-container *ngFor=\"let field of visibleFields\">\r\n              <ng-container [ngSwitch]=\"field\">\r\n\r\n              <!-- Client -->\r\n              <div class=\"form-field\" *ngSwitchCase=\"'client'\">\r\n                <div class=\"row align-items-center\">\r\n                  <div class=\"col-2\">\r\n                    <label class=\"form-label label-data\">Client<span class=\"text-danger\">*</span></label>\r\n                  </div>\r\n                  <div class=\"col-10\">\r\n                    <ng-select [items]=\"clients1\" bindLabel=\"businessPartnerName\" bindValue=\"businessPartnerCode\"\r\n                      placeholder=\"Select Client\" [clearable]=\"false\" formControlName=\"client\" required\r\n                      (change)=\"onClientChange()\" (open)=\"onOpen()\" (close)=\"onClose()\" [searchable]=\"isOpen\">\r\n                    </ng-select>\r\n                  </div>\r\n                </div>\r\n              </div>\r\n\r\n              <!-- Branch -->\r\n              <div class=\"form-field\" *ngSwitchCase=\"'branch'\">\r\n                <div class=\"row align-items-center\">\r\n                  <div class=\"col-2\">\r\n                    <label class=\"form-label label-data\">Branch<span class=\"text-danger\">*</span></label>\r\n                  </div>\r\n                  <div class=\"col-10\">\r\n                    <ng-select [items]=\"branches\" bindLabel=\"businessPartnerBranch\" bindValue=\"branchCode\"\r\n                      placeholder=\"Select Branch\" [clearable]=\"false\" formControlName=\"branch\" required\r\n                      (change)=\"onBranchChange()\" (open)=\"onOpen()\" (close)=\"onClose()\" [searchable]=\"isOpen\">\r\n                    </ng-select>\r\n                  </div>\r\n                </div>\r\n              </div>\r\n\r\n                <!-- From Date -->\r\n                <div class=\"form-field\" *ngSwitchCase=\"'fromDate'\">\r\n                  <div class=\"row align-items-center\">\r\n                    <div class=\"col-2\">\r\n                      <label class=\"form-label label-data\">From Date<span class=\"text-danger\">*</span></label>\r\n                    </div>\r\n                    <div class=\"col-10\">\r\n                      <div class=\"input-group date-group\">\r\n                        <input class=\"form-control dpicker\" placeholder=\"dd/mm/yyyy\" ngbDatepicker\r\n                          #fromDateInput=\"ngbDatepicker\" formControlName=\"fromDate\" autocomplete=\"off\" />\r\n                        <button class=\"input-group-button cal\" (click)=\"fromDateInput.toggle()\" type=\"button\">\r\n                          <i class=\"fa fa-calendar\" aria-hidden=\"true\"></i>\r\n                        </button>\r\n                      </div>\r\n                    </div>\r\n                  </div>\r\n                </div>\r\n\r\n                <!-- To Date -->\r\n                <div class=\"form-field\" *ngSwitchCase=\"'toDate'\">\r\n                  <div class=\"row align-items-center\">\r\n                    <div class=\"col-2\">\r\n                      <label class=\"form-label label-data\">To Date<span class=\"text-danger\">*</span></label>\r\n                    </div>\r\n                    <div class=\"col-10\">\r\n                      <div class=\"input-group date-group\">\r\n                        <input class=\"form-control dpicker\" placeholder=\"dd/mm/yyyy\" ngbDatepicker\r\n                          #toDateInput=\"ngbDatepicker\" formControlName=\"toDate\" autocomplete=\"off\" />\r\n                        <button class=\"input-group-button cal\" (click)=\"toDateInput.toggle()\" type=\"button\">\r\n                          <i class=\"fa fa-calendar\" aria-hidden=\"true\"></i>\r\n                        </button>\r\n                      </div>\r\n                    </div>\r\n                  </div>\r\n                </div>\r\n\r\n              <!-- Product -->\r\n              <div class=\"form-field\" *ngSwitchCase=\"'product'\">\r\n                <div class=\"row align-items-center\">\r\n                  <div class=\"col-2\">\r\n                    <label class=\"form-label label-data\">Product</label>\r\n                  </div>\r\n                  <div class=\"col-10\">\r\n                    <ng-select [items]=\"products\" bindLabel=\"productName\" bindValue=\"productCode\"\r\n                      placeholder=\"Select Product\" [clearable]=\"false\" formControlName=\"product\" (open)=\"onOpen()\" (close)=\"onClose()\" [searchable]=\"isOpen\">\r\n                    </ng-select>\r\n                  </div>\r\n                </div>\r\n              </div>\r\n\r\n              <!-- User -->\r\n              <div class=\"form-field\" *ngSwitchCase=\"'userId'\">\r\n                <div class=\"row align-items-center\">\r\n                  <div class=\"col-2\">\r\n                    <label class=\"form-label label-data\">User<span class=\"text-danger\">*</span></label>\r\n                  </div>\r\n                  <div class=\"col-10\">\r\n                    <ng-select [items]=\"users\" bindLabel=\"userName\" bindValue=\"userId\" placeholder=\"Select User\"\r\n                      [clearable]=\"false\" formControlName=\"userId\" required (open)=\"onOpen()\" (close)=\"onClose()\" [searchable]=\"isOpen\">\r\n                    </ng-select>\r\n                  </div>\r\n                </div>\r\n              </div>\r\n\r\n              <!-- Currency -->\r\n              <div class=\"form-field\" *ngSwitchCase=\"'currency'\">\r\n                <div class=\"row align-items-center\">\r\n                  <div class=\"col-2\">\r\n                    <label class=\"form-label label-data\">Currency</label>\r\n                  </div>\r\n                  <div class=\"col-10\">\r\n                    <ng-select [items]=\"currencies\" bindLabel=\"currencyCode\" bindValue=\"currencyCode\"\r\n                      placeholder=\"Select Currency\" [clearable]=\"false\" formControlName=\"currency\" (open)=\"onOpen()\" (close)=\"onClose()\" [searchable]=\"isOpen\">\r\n                    </ng-select>\r\n                  </div>\r\n                </div>\r\n              </div>\r\n\r\n              <!-- Transaction Status (Multi-select) -->\r\n              <div class=\"form-field\" *ngSwitchCase=\"'transactionStatus'\">\r\n                <div class=\"row align-items-center\">\r\n                  <div class=\"col-2\">\r\n                    <label class=\"form-label label-data\">Txn. Status<span class=\"text-danger\">*</span></label>\r\n                  </div>\r\n                  <div class=\"col-10\">\r\n                    <ng-select class=\"transaction-status-select\" [items]=\"transactionStatuses\"\r\n                      bindLabel=\"transactionStatus\" bindValue=\"transactionStatus\" [multiple]=\"true\"\r\n                      placeholder=\"Select Transaction Status\" formControlName=\"transactionStatus\"\r\n                      [closeOnSelect]=\"false\" [clearable]=\"false\" [searchable]=\"false\" required>\r\n                      <ng-template ng-option-tmp let-item=\"item\" let-item$=\"item$\">\r\n                        <input type=\"checkbox\" [checked]=\"item$.selected\" /> {{ item.transactionStatus }}\r\n                      </ng-template>\r\n                    </ng-select>\r\n                  </div>\r\n                </div>\r\n              </div>\r\n\r\n              <!-- Transaction No -->\r\n              <div class=\"form-field\" *ngSwitchCase=\"'transactionNo'\">\r\n                <div class=\"row align-items-center\">\r\n                  <div class=\"col-2\">\r\n                    <label class=\"form-label label-data\">Txn. Number</label>\r\n                  </div>\r\n                  <div class=\"col-10\">\r\n                    <input class=\"form-control dpicker\" formControlName=\"transactionNo\"\r\n                      placeholder=\"Enter transaction number\" />\r\n                  </div>\r\n                </div>\r\n              </div>\r\n\r\n              <!-- Value Date -->\r\n              <div class=\"form-field\" *ngSwitchCase=\"'valueDate'\">\r\n                <div class=\"row align-items-center\">\r\n                  <div class=\"col-3\">\r\n                    <label class=\"form-label label-data\">Value Date<span class=\"text-danger\">*</span></label>\r\n                  </div>\r\n                  <div class=\"col-9\">\r\n                    <div class=\"input-group\">\r\n                      <input class=\"form-control dpicker\" placeholder=\"dd/mm/yyyy\" ngbDatepicker\r\n                        #toDateInput=\"ngbDatepicker\" formControlName=\"toDate\" autocomplete=\"off\" />\r\n                      <button class=\"btn btn-outline-secondary\" type=\"button\" (click)=\"toDateInput.toggle()\">\r\n                        <i class=\"fa fa-calendar\"></i>\r\n                      </button>\r\n                    </div>\r\n                  </div>\r\n                </div>\r\n              </div>\r\n\r\n              <!-- Send Country -->\r\n              <div class=\"form-field\" *ngSwitchCase=\"'sendCountry'\">\r\n                <div class=\"row align-items-center\">\r\n                  <div class=\"col-2\">\r\n                    <label class=\"form-label label-data\">Send Country</label>\r\n                  </div>\r\n                  <div class=\"col-10\">\r\n                    <ng-select [items]=\"countries\" bindLabel=\"country\" bindValue=\"countryCode\"\r\n                      placeholder=\"Select Product\" [clearable]=\"false\" formControlName=\"sendCountry\">\r\n                    </ng-select>\r\n                  </div>\r\n                </div>\r\n              </div>\r\n\r\n              <!-- Receive Country -->\r\n              <div class=\"form-field\" *ngSwitchCase=\"'receiveCountry'\">\r\n                <div class=\"row align-items-center\">\r\n                  <div class=\"col-2\">\r\n                    <label class=\"form-label label-data\">Receive Country</label>\r\n                  </div>\r\n                  <div class=\"col-10\">\r\n                    <ng-select [items]=\"countries\" bindLabel=\"country\" bindValue=\"countryCode\"\r\n                      placeholder=\"Select Product\" [clearable]=\"false\" formControlName=\"receiveCountry\">\r\n                    </ng-select>\r\n                  </div>\r\n                </div>\r\n              </div>\r\n\r\n              <!--Transaction Product -->\r\n              <div class=\"form-field\" *ngSwitchCase=\"'transactionProduct'\">\r\n                <div class=\"row align-items-center\">\r\n                  <div class=\"col-2\">\r\n                    <label class=\"form-label label-data\">Product</label>\r\n                  </div>\r\n                  <div class=\"col-10\">\r\n                    <ng-select [items]=\"transactionProducts\" bindLabel=\"name\" bindValue=\"productCode\"\r\n                      placeholder=\"Select Product\" [clearable]=\"false\" formControlName=\"product\">\r\n                    </ng-select>\r\n                  </div>\r\n                </div>\r\n              </div>\r\n\r\n                <!-- Value Date -->\r\n                <div class=\"form-field\" *ngSwitchCase=\"'valueDate'\">\r\n                  <div class=\"row align-items-center\">\r\n                    <div class=\"col-3\">\r\n                      <label class=\"form-label label-data\">Value Date<span class=\"text-danger\">*</span></label>\r\n                    </div>\r\n                    <div class=\"col-9\">\r\n                      <div class=\"input-group\">\r\n                        <input class=\"form-control dpicker\" placeholder=\"dd/mm/yyyy\" ngbDatepicker\r\n                          #toDateInput=\"ngbDatepicker\" formControlName=\"toDate\" autocomplete=\"off\" />\r\n                        <button class=\"btn btn-outline-secondary\" type=\"button\" (click)=\"toDateInput.toggle()\">\r\n                          <i class=\"fa fa-calendar\"></i>\r\n                        </button>\r\n                      </div>\r\n                    </div>\r\n                  </div>\r\n                </div>\r\n\r\n                <!-- Date Type -->\r\n                <div class=\"form-field\" *ngSwitchCase=\"'dateType'\">\r\n                  <div class=\"row align-items-center\">\r\n                    <div class=\"col-2\">\r\n                      <label class=\"form-label label-data\">Date Type</label>\r\n                    </div>\r\n                    <div class=\"col-10\">\r\n                      <ng-select placeholder=\"- Please select -\" formControlName=\"dateType\" [clearable]=\"false\"\r\n                        required>\r\n                        <ng-option [value]=\"1\">\r\n                          Value Date\r\n                        </ng-option>\r\n                        <ng-option [value]=\"2\">\r\n                          Posting Date\r\n                        </ng-option>\r\n                      </ng-select>\r\n                    </div>\r\n                  </div>\r\n                </div>\r\n\r\n                <!-- Date -->\r\n                <div class=\"form-field\" *ngSwitchCase=\"'date'\">\r\n                  <div class=\"row align-items-center\">\r\n                    <div class=\"col-2\">\r\n                      <label class=\"form-label label-data\">Date</label>\r\n                    </div>\r\n                    <div class=\"col-10\">\r\n                      <div class=\"input-group date-group\">\r\n                        <input class=\"form-control dpicker\" placeholder=\"dd/mm/yyyy\" ngbDatepicker\r\n                          #toDateInput=\"ngbDatepicker\" formControlName=\"date\" autocomplete=\"off\" />\r\n                        <button class=\"input-group-button cal\" (click)=\"toDateInput.toggle()\" type=\"button\">\r\n                          <i class=\"fa fa-calendar\" aria-hidden=\"true\"></i>\r\n                        </button>\r\n                      </div>\r\n                    </div>\r\n                  </div>\r\n                </div>\r\n\r\n              </ng-container>\r\n            </ng-container>\r\n\r\n        </div>\r\n\r\n      </div>\r\n      <div class=\"col-custom-1-5\">\r\n        <!-- View Report Button (Always at Top-Right) -->\r\n        <div class=\"form-field view-report-btn\">\r\n          <button type=\"submit\" class=\"btn btn-report\">View</button>\r\n        </div>\r\n      </div>\r\n    </div>\r\n  </form>\r\n</section>\r\n<hr>\r\n<!-- Error Messages -->\r\n<div class=\"alert alert-danger mt-3\" *ngIf=\"formValidationError && hasSearched\">\r\n  Please fill all required fields before submitting the form.\r\n</div>\r\n\r\n<div class=\"alert alert-danger mt-3\" *ngIf=\"errorMessage && loadingState === ComponentLoadingState.Error\">\r\n  {{ errorMessage }}\r\n  <button type=\"button\" class=\"btn-close\" (click)=\"errorMessage = ''\"></button>\r\n</div>"]}
|