@sachin9822/reports-lib 0.0.131 → 0.0.133
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 +29 -22
- package/esm2020/lib/components/branch-activity-send-report/branch-activity-send-report.component.mjs +2 -2
- package/esm2020/lib/components/transaction-enquiry-report/transaction-enquiry-report.component.mjs +337 -0
- package/esm2020/lib/models/transaction-enquiry-report/transaction-enquiry.model.mjs +8 -0
- package/esm2020/lib/reports-lib-routing.module.mjs +16 -4
- package/esm2020/lib/reports-lib.module.mjs +25 -6
- package/esm2020/lib/services/report.service.mjs +27 -1
- package/esm2020/lib/shared/export.service.mjs +26 -8
- package/esm2020/lib/shared/page-size-selector/page-size-selector.component.mjs +2 -2
- package/esm2020/lib/shared/search-filter/search-filter.component.mjs +399 -0
- package/esm2020/public-api.mjs +8 -1
- package/fesm2015/sachin9822-reports-lib.mjs +892 -80
- package/fesm2015/sachin9822-reports-lib.mjs.map +1 -1
- package/fesm2020/sachin9822-reports-lib.mjs +873 -80
- package/fesm2020/sachin9822-reports-lib.mjs.map +1 -1
- package/lib/assets/config/app-config.json +3 -1
- package/lib/components/acc-gl-details-enquiry-report/acc-gl-details-enquiry-report.component.d.ts +6 -2
- package/lib/components/transaction-enquiry-report/transaction-enquiry-report.component.d.ts +93 -0
- package/lib/models/transaction-enquiry-report/transaction-enquiry.model.d.ts +139 -0
- package/lib/reports-lib-routing.module.d.ts +2 -1
- package/lib/reports-lib.module.d.ts +12 -10
- package/lib/services/report.service.d.ts +7 -1
- package/lib/shared/search-filter/search-filter.component.d.ts +68 -0
- package/package.json +1 -1
- package/public-api.d.ts +6 -0
@@ -0,0 +1,399 @@
|
|
1
|
+
import { Component, EventEmitter, Input, Output } from '@angular/core';
|
2
|
+
import { FormArray, FormGroup, Validators } from '@angular/forms';
|
3
|
+
import { ComponentLoadingState } from '../../models/transaction-enquiry-report/transaction-enquiry.model';
|
4
|
+
import { Subject } from 'rxjs';
|
5
|
+
import { takeUntil } from 'rxjs/operators';
|
6
|
+
import * as i0 from "@angular/core";
|
7
|
+
import * as i1 from "../../services/report.service";
|
8
|
+
import * as i2 from "@angular/forms";
|
9
|
+
import * as i3 from "../../services/config.service";
|
10
|
+
import * as i4 from "@angular/router";
|
11
|
+
import * as i5 from "@angular/common";
|
12
|
+
import * as i6 from "@ng-bootstrap/ng-bootstrap";
|
13
|
+
import * as i7 from "@ng-select/ng-select";
|
14
|
+
import * as i8 from "../loader/loader.component";
|
15
|
+
export class SearchFilterComponent {
|
16
|
+
constructor(reportService, fb, config) {
|
17
|
+
this.reportService = reportService;
|
18
|
+
this.fb = fb;
|
19
|
+
this.config = config;
|
20
|
+
this.searchClicked = new EventEmitter();
|
21
|
+
this.formValidationError = false;
|
22
|
+
this.destroy$ = new Subject();
|
23
|
+
this.loadingState = ComponentLoadingState.Complete;
|
24
|
+
this.ComponentLoadingState = ComponentLoadingState;
|
25
|
+
this.hasSearched = false;
|
26
|
+
this._errorMessage = '';
|
27
|
+
this.currentUser = '';
|
28
|
+
this.usernameMissing = false;
|
29
|
+
this.token = sessionStorage.getItem('access_token');
|
30
|
+
this.applicationType = 'ezremit';
|
31
|
+
this.companyCode = 'BH';
|
32
|
+
this.userReportDefaults = null;
|
33
|
+
this.companyReportConfig = null;
|
34
|
+
this.clients1 = [];
|
35
|
+
this.branches = [];
|
36
|
+
this.users = [];
|
37
|
+
this.currencies = [];
|
38
|
+
this.products = [];
|
39
|
+
this.transactionStatuses = [];
|
40
|
+
this.selectedStatuses = [];
|
41
|
+
this.showStatusDropdown = false;
|
42
|
+
this.visibleFieldKeys = [];
|
43
|
+
this.dateType = 1;
|
44
|
+
// Field visibility map, 'fromDate', 'toDate','product','userId','currency','transactionStatus','transactionNo'
|
45
|
+
this.visibleFieldsMap = {
|
46
|
+
'Transaction Enquiry': ['client', 'fromDate', 'toDate', 'branch', 'product', 'currency', 'userId', 'transactionStatus', 'transactionNo'],
|
47
|
+
'FC Ledger': ['client', 'fromDate', 'toDate', 'currency', 'product'],
|
48
|
+
'Branch Activity': ['branch', 'userId', 'fromDate', 'toDate'],
|
49
|
+
'ACC GL Details Enquiry': ['dateType', 'date'],
|
50
|
+
// Add more report types here
|
51
|
+
};
|
52
|
+
this.serviceUrl = this.config.get.serviceUrl;
|
53
|
+
let fossilUser = sessionStorage.getItem('fossilusername');
|
54
|
+
let ezremitUser = sessionStorage.getItem('ezremitusername');
|
55
|
+
if (fossilUser)
|
56
|
+
this.currentUser = fossilUser;
|
57
|
+
else if (ezremitUser)
|
58
|
+
this.currentUser = ezremitUser;
|
59
|
+
else {
|
60
|
+
this.currentUser = 'vipul.katale@xpressmoney.tech';
|
61
|
+
this.usernameMissing = true;
|
62
|
+
}
|
63
|
+
}
|
64
|
+
get visibleFields() {
|
65
|
+
return this.visibleFieldsMap[this.ReportName] || [];
|
66
|
+
}
|
67
|
+
isFieldVisible(field) {
|
68
|
+
return this.visibleFields.includes(field);
|
69
|
+
}
|
70
|
+
ngOnInit() {
|
71
|
+
this.checkReport();
|
72
|
+
}
|
73
|
+
ngOnDestroy() {
|
74
|
+
this.destroy$.next();
|
75
|
+
this.destroy$.complete();
|
76
|
+
}
|
77
|
+
checkReport() {
|
78
|
+
if (this.ReportName == "Transaction Enquiry") {
|
79
|
+
this.currentUser = this.currentUser.replace(/"/g, '');
|
80
|
+
this.initializeForm();
|
81
|
+
this.subscribeToDateChanges();
|
82
|
+
this.loadInitialData();
|
83
|
+
}
|
84
|
+
if (this.ReportName == "ACC GL Details Enquiry") {
|
85
|
+
this.initializeForm();
|
86
|
+
}
|
87
|
+
}
|
88
|
+
loadInitialData() {
|
89
|
+
if (this.ReportName == 'Transaction Enquiry') {
|
90
|
+
this.loadInitialDatafortxnEnquiry();
|
91
|
+
}
|
92
|
+
}
|
93
|
+
initializeForm() {
|
94
|
+
if (this.ReportName == "Transaction Enquiry") {
|
95
|
+
this.searchForm = this.fb.group({
|
96
|
+
client: ['', Validators.required],
|
97
|
+
fromDate: [new Date().toISOString().split("T")[0], Validators.required],
|
98
|
+
toDate: [new Date().toISOString().split("T")[0], Validators.required],
|
99
|
+
branch: ['', Validators.required],
|
100
|
+
userId: ['-1'],
|
101
|
+
currency: ['All'],
|
102
|
+
product: ['All', Validators.required],
|
103
|
+
transactionStatus: [['All'], Validators.required],
|
104
|
+
transactionNo: [''],
|
105
|
+
cardNo: [''],
|
106
|
+
idType: [''],
|
107
|
+
idNo: [''],
|
108
|
+
senderName: [''],
|
109
|
+
beneficiaryName: [''],
|
110
|
+
telNo: [''],
|
111
|
+
receiveAmount: [''],
|
112
|
+
branchName: [''],
|
113
|
+
country: [''],
|
114
|
+
});
|
115
|
+
this.selectedStatuses = ['All'];
|
116
|
+
}
|
117
|
+
if (this.ReportName == "ACC GL Details Enquiry") {
|
118
|
+
this.searchForm = this.fb.group({
|
119
|
+
date: [new Date().toISOString().split("T")[0], Validators.required],
|
120
|
+
dateType: [1, Validators.required]
|
121
|
+
});
|
122
|
+
}
|
123
|
+
}
|
124
|
+
async loadInitialDatafortxnEnquiry() {
|
125
|
+
this.loadingState = ComponentLoadingState.Loading;
|
126
|
+
this.errorMessage = '';
|
127
|
+
try {
|
128
|
+
const data = await this.reportService
|
129
|
+
.getPageLoadData(this.currentUser)
|
130
|
+
.pipe(takeUntil(this.destroy$))
|
131
|
+
.toPromise();
|
132
|
+
if (data) {
|
133
|
+
this.clients1 = data.clients || [];
|
134
|
+
this.currencies = data.currencies || [];
|
135
|
+
this.transactionStatuses = (data.transactionStatuses || []).filter(ts => ts.transactionStatus !== '');
|
136
|
+
if (!this.transactionStatuses.some(s => s.transactionStatus === 'All')) {
|
137
|
+
this.transactionStatuses.unshift({
|
138
|
+
transactionStatus: 'All',
|
139
|
+
});
|
140
|
+
}
|
141
|
+
this.setDefaultFormValues();
|
142
|
+
if (this.clients1.length === 1) {
|
143
|
+
this.searchForm.patchValue({
|
144
|
+
client: this.clients1[0].businessPartnerCode,
|
145
|
+
});
|
146
|
+
await this.onClientChange();
|
147
|
+
}
|
148
|
+
}
|
149
|
+
this.loadingState = ComponentLoadingState.Complete;
|
150
|
+
}
|
151
|
+
catch (error) {
|
152
|
+
this.errorMessage = 'Failed to load initial data';
|
153
|
+
this.loadingState = ComponentLoadingState.Error;
|
154
|
+
}
|
155
|
+
}
|
156
|
+
subscribeToDateChanges() {
|
157
|
+
this.searchForm.get('fromDate')?.valueChanges.subscribe(fromDateStr => {
|
158
|
+
const toDateControl = this.searchForm.get('toDate');
|
159
|
+
const toDateStr = toDateControl?.value;
|
160
|
+
if (!fromDateStr || !toDateStr)
|
161
|
+
return;
|
162
|
+
const fromDate = new Date(fromDateStr);
|
163
|
+
const toDate = new Date(toDateStr);
|
164
|
+
const maxToDate = new Date(fromDate);
|
165
|
+
maxToDate?.setDate(fromDate.getDate() + 31);
|
166
|
+
if (toDate > maxToDate) {
|
167
|
+
toDateControl?.patchValue(maxToDate.toISOString().split("T")[0]);
|
168
|
+
}
|
169
|
+
});
|
170
|
+
this.searchForm.get('toDate')?.valueChanges.subscribe(toDateStr => {
|
171
|
+
const fromDateControl = this.searchForm.get('fromDate');
|
172
|
+
const fromDateStr = fromDateControl?.value;
|
173
|
+
if (!toDateStr || !fromDateStr)
|
174
|
+
return;
|
175
|
+
const toDate = new Date(toDateStr);
|
176
|
+
const fromDate = new Date(fromDateStr);
|
177
|
+
const minFromDate = new Date(toDate);
|
178
|
+
minFromDate?.setDate(toDate.getDate() - 31);
|
179
|
+
if (fromDate < minFromDate) {
|
180
|
+
fromDateControl?.patchValue(minFromDate.toISOString().split("T")[0]);
|
181
|
+
}
|
182
|
+
});
|
183
|
+
}
|
184
|
+
setDefaultFormValues() {
|
185
|
+
if (this.userReportDefaults) {
|
186
|
+
this.searchForm.patchValue({
|
187
|
+
currency: this.userReportDefaults.LocalCurrency || 'All',
|
188
|
+
});
|
189
|
+
}
|
190
|
+
}
|
191
|
+
async onClientChange() {
|
192
|
+
this.loadingState = ComponentLoadingState.Loading;
|
193
|
+
if (this.ReportName == "Transaction Enquiry") {
|
194
|
+
const selectedClient = this.searchForm.get('client')?.value;
|
195
|
+
if (!selectedClient)
|
196
|
+
return;
|
197
|
+
this.searchForm.patchValue({ branch: '', userId: '' });
|
198
|
+
this.branches = [];
|
199
|
+
this.products = [];
|
200
|
+
this.users = [];
|
201
|
+
try {
|
202
|
+
await Promise.all([
|
203
|
+
this.loadBranchesByAgent(selectedClient),
|
204
|
+
this.loadProductsByAgent(selectedClient),
|
205
|
+
]);
|
206
|
+
this.loadingState = ComponentLoadingState.Complete;
|
207
|
+
}
|
208
|
+
catch (err) {
|
209
|
+
this.errorMessage = 'Failed to load branch/product';
|
210
|
+
this.loadingState = ComponentLoadingState.Complete;
|
211
|
+
}
|
212
|
+
}
|
213
|
+
}
|
214
|
+
async loadBranchesByAgent(agentCode) {
|
215
|
+
const branches = await this.reportService
|
216
|
+
.getBranchesByAgent(agentCode, this.currentUser)
|
217
|
+
.pipe(takeUntil(this.destroy$))
|
218
|
+
.toPromise();
|
219
|
+
this.branches = branches || [];
|
220
|
+
if (this.branches.length === 1) {
|
221
|
+
this.searchForm.patchValue({ branch: this.branches[0].branchCode });
|
222
|
+
await this.loadUsersByBranch(agentCode, this.branches[0].branchCode);
|
223
|
+
}
|
224
|
+
else if (this.branches.some(b => b.branchCode === 'All')) {
|
225
|
+
this.searchForm.patchValue({ branch: 'All' });
|
226
|
+
await this.loadUsersByBranch(agentCode, 'All');
|
227
|
+
}
|
228
|
+
else {
|
229
|
+
this.searchForm.patchValue({ branch: '' });
|
230
|
+
this.users = [];
|
231
|
+
}
|
232
|
+
}
|
233
|
+
async loadProductsByAgent(agentCode) {
|
234
|
+
const products = await this.reportService
|
235
|
+
.getProductsByAgent(agentCode)
|
236
|
+
.pipe(takeUntil(this.destroy$))
|
237
|
+
.toPromise();
|
238
|
+
this.products = products || [];
|
239
|
+
}
|
240
|
+
async onBranchChange() {
|
241
|
+
this.loadingState = ComponentLoadingState.Loading;
|
242
|
+
if (this.ReportName == "Transaction Enquiry") {
|
243
|
+
const client = this.searchForm.get('client')?.value;
|
244
|
+
const branch = this.searchForm.get('branch')?.value;
|
245
|
+
if (client && branch) {
|
246
|
+
await this.loadUsersByBranch(client, branch);
|
247
|
+
this.loadingState = ComponentLoadingState.Complete;
|
248
|
+
}
|
249
|
+
else {
|
250
|
+
this.users = [];
|
251
|
+
this.loadingState = ComponentLoadingState.Complete;
|
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
|
+
});
|
282
|
+
}
|
283
|
+
onSearch() {
|
284
|
+
if (this.ReportName == "Transaction Enquiry") {
|
285
|
+
this.hasSearched = true;
|
286
|
+
if (this.searchForm.invalid) {
|
287
|
+
this.formValidationError = true;
|
288
|
+
this.markFormGroupTouched(this.searchForm);
|
289
|
+
return;
|
290
|
+
}
|
291
|
+
this.formValidationError = false;
|
292
|
+
this.searchClicked.emit(this.buildSearchCriteria());
|
293
|
+
}
|
294
|
+
if (this.ReportName == "ACC GL Details Enquiry") {
|
295
|
+
const modal = {
|
296
|
+
selectedDateType: this.searchForm.controls["dateType"]?.value,
|
297
|
+
selectedDate: this.searchForm.controls["date"]?.value
|
298
|
+
};
|
299
|
+
this.searchClicked.emit(modal);
|
300
|
+
}
|
301
|
+
}
|
302
|
+
markFormGroupTouched(formGroup) {
|
303
|
+
Object.values(formGroup.controls).forEach(control => {
|
304
|
+
if (control instanceof FormGroup || control instanceof FormArray) {
|
305
|
+
this.markFormGroupTouched(control);
|
306
|
+
}
|
307
|
+
else {
|
308
|
+
control.markAsTouched();
|
309
|
+
}
|
310
|
+
});
|
311
|
+
}
|
312
|
+
buildSearchCriteria() {
|
313
|
+
if (this.ReportName == "Transaction Enquiry") {
|
314
|
+
const formValue = this.searchForm.value;
|
315
|
+
return {
|
316
|
+
bank: formValue.client,
|
317
|
+
fromDate: this.toIsoFormat(formValue.fromDate),
|
318
|
+
toDate: this.toIsoFormat(formValue.toDate),
|
319
|
+
branch: formValue.branch,
|
320
|
+
user: formValue.userId || '-1',
|
321
|
+
currency: formValue.currency,
|
322
|
+
product: formValue.product,
|
323
|
+
status: this.selectedStatuses.includes('All') ? [''] : this.selectedStatuses,
|
324
|
+
transactionNo: (formValue.transactionNo || '').trim(),
|
325
|
+
cardNo: formValue.cardNo || '',
|
326
|
+
idType: formValue.idType || '',
|
327
|
+
idNo: formValue.idNo || '',
|
328
|
+
senderName: formValue.senderName || '',
|
329
|
+
beneficiaryName: formValue.beneficiaryName || '',
|
330
|
+
telNo: formValue.telNo || '',
|
331
|
+
payoutAmount: formValue.receiveAmount || '',
|
332
|
+
branchName: formValue.branchName || '',
|
333
|
+
company: this.companyCode || '',
|
334
|
+
country: formValue.country || '',
|
335
|
+
sysUserID: this.currentUser,
|
336
|
+
};
|
337
|
+
}
|
338
|
+
}
|
339
|
+
toIsoFormat(dateInput) {
|
340
|
+
if (!dateInput)
|
341
|
+
return undefined;
|
342
|
+
// Handle { year, month, day }
|
343
|
+
if (typeof dateInput === 'object' &&
|
344
|
+
dateInput.year &&
|
345
|
+
dateInput.month &&
|
346
|
+
dateInput.day) {
|
347
|
+
const year = dateInput.year;
|
348
|
+
const month = String(dateInput.month).padStart(2, '0');
|
349
|
+
const day = String(dateInput.day).padStart(2, '0');
|
350
|
+
return `${year}-${month}-${day}`;
|
351
|
+
}
|
352
|
+
// Handle JS Date object
|
353
|
+
if (dateInput instanceof Date) {
|
354
|
+
if (isNaN(dateInput.getTime()))
|
355
|
+
return undefined;
|
356
|
+
const year = dateInput.getFullYear();
|
357
|
+
const month = String(dateInput.getMonth() + 1).padStart(2, '0');
|
358
|
+
const day = String(dateInput.getDate()).padStart(2, '0');
|
359
|
+
return `${year}-${month}-${day}`;
|
360
|
+
}
|
361
|
+
// Handle dd/MM/yyyy string
|
362
|
+
if (typeof dateInput === 'string' && dateInput.includes('/')) {
|
363
|
+
const parts = dateInput.split('/');
|
364
|
+
if (parts.length === 3) {
|
365
|
+
const [day, month, year] = parts;
|
366
|
+
return `${year}-${month.padStart(2, '0')}-${day.padStart(2, '0')}`;
|
367
|
+
}
|
368
|
+
}
|
369
|
+
// Handle ISO string (yyyy-MM-dd or yyyy-MM-ddTHH:mm:ss.sssZ)
|
370
|
+
if (typeof dateInput === 'string' && /^\d{4}-\d{2}-\d{2}/.test(dateInput)) {
|
371
|
+
// Use only date part if full ISO string
|
372
|
+
return dateInput.substring(0, 10);
|
373
|
+
}
|
374
|
+
return undefined;
|
375
|
+
}
|
376
|
+
get errorMessage() {
|
377
|
+
return this._errorMessage;
|
378
|
+
}
|
379
|
+
set errorMessage(value) {
|
380
|
+
this._errorMessage = value;
|
381
|
+
}
|
382
|
+
get isLoading() {
|
383
|
+
return this.loadingState === ComponentLoadingState.Loading;
|
384
|
+
}
|
385
|
+
get isError() {
|
386
|
+
return this.loadingState === ComponentLoadingState.Error;
|
387
|
+
}
|
388
|
+
}
|
389
|
+
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:visible;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}::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}}\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" }] });
|
391
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: SearchFilterComponent, decorators: [{
|
392
|
+
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:visible;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}::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}}\n"] }]
|
394
|
+
}], ctorParameters: function () { return [{ type: i1.ReportService }, { type: i2.FormBuilder }, { type: i3.ConfigService }]; }, propDecorators: { ReportName: [{
|
395
|
+
type: Input
|
396
|
+
}], searchClicked: [{
|
397
|
+
type: Output
|
398
|
+
}] } });
|
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>"]}
|