ng-prime-tools 1.0.4 → 1.0.5
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/README.md +212 -0
- package/esm2022/lib/models/table-column.mjs +1 -1
- package/esm2022/lib/multi-search-criteria/multi-search-criteria.component.mjs +58 -48
- package/esm2022/lib/ng-advanced-prime-table/ng-advanced-prime-table.component.mjs +3 -11
- package/esm2022/lib/pipes/custom-currency.mjs +24 -18
- package/fesm2022/ng-prime-tools.mjs +82 -74
- package/fesm2022/ng-prime-tools.mjs.map +1 -1
- package/lib/models/table-column.d.ts +2 -0
- package/lib/models/table-column.d.ts.map +1 -1
- package/lib/multi-search-criteria/multi-search-criteria.component.d.ts +6 -2
- package/lib/multi-search-criteria/multi-search-criteria.component.d.ts.map +1 -1
- package/lib/ng-advanced-prime-table/ng-advanced-prime-table.component.d.ts +0 -1
- package/lib/ng-advanced-prime-table/ng-advanced-prime-table.component.d.ts.map +1 -1
- package/lib/pipes/custom-currency.d.ts +1 -1
- package/lib/pipes/custom-currency.d.ts.map +1 -1
- package/package.json +1 -1
package/README.md
CHANGED
@@ -12,6 +12,10 @@ An advanced PrimeNG tools library for Angular.
|
|
12
12
|
- [Inputs](#inputs)
|
13
13
|
- [Outputs](#outputs)
|
14
14
|
- [Example](#example)
|
15
|
+
- [multi-search-criteria](#multi-search-criteria)
|
16
|
+
- [Inputs](#inputs-1)
|
17
|
+
- [Outputs](#outputs-1)
|
18
|
+
- [Example](#example-1)
|
15
19
|
- [Changelog](#changelog)
|
16
20
|
- [License](#license)
|
17
21
|
|
@@ -186,8 +190,216 @@ export class AppComponent implements OnInit {
|
|
186
190
|
<ng-advanced-prime-table [columns]="columns" [data]="data" [hasSearchFilter]="true" [hasColumnFilter]="true" [isPaginated]="true" [totalRecords]="totalRecords" [isSortable]="true"></ng-advanced-prime-table>
|
187
191
|
```
|
188
192
|
|
193
|
+
### multi-search-criteria
|
194
|
+
|
195
|
+
To use the `multi-search-criteria` component, follow these steps:
|
196
|
+
|
197
|
+
1. **Import the Module:**
|
198
|
+
|
199
|
+
Import the `MultiSearchCriteriaModule` in your Angular module or standalone component.
|
200
|
+
|
201
|
+
```typescript
|
202
|
+
import { MultiSearchCriteriaModule, SearchCriteria, SearchCriteriaTypeEnum } from "ng-prime-tools";
|
203
|
+
```
|
204
|
+
|
205
|
+
2. **Add the Component:**
|
206
|
+
|
207
|
+
Add the `multi-search-criteria` component to your template:
|
208
|
+
|
209
|
+
```html
|
210
|
+
<multi-search-criteria [title]="'Multi-Criteria Search'" [criteria]="criteria" [data]="data" [mode]="'dynamic'" (filteredData)="onFilteredData($event)" (searchCriteria)="onSearchData($event)"></multi-search-criteria>
|
211
|
+
```
|
212
|
+
|
213
|
+
3. **Define the Inputs:**
|
214
|
+
|
215
|
+
In your component, define the necessary inputs for the criteria:
|
216
|
+
|
217
|
+
```typescript
|
218
|
+
import { Component, OnInit } from "@angular/core";
|
219
|
+
import { CommonModule } from "@angular/common";
|
220
|
+
import { MultiSearchCriteriaModule, SearchCriteria, SearchCriteriaTypeEnum, FilterOption } from "ng-prime-tools";
|
221
|
+
|
222
|
+
@Component({
|
223
|
+
selector: "app-root",
|
224
|
+
standalone: true,
|
225
|
+
imports: [CommonModule, MultiSearchCriteriaModule],
|
226
|
+
templateUrl: "./app.component.html",
|
227
|
+
styleUrls: ["./app.component.css"],
|
228
|
+
})
|
229
|
+
export class AppComponent implements OnInit {
|
230
|
+
criteria: SearchCriteria[] = [];
|
231
|
+
data: any[] = [];
|
232
|
+
filteredData: any[] = [];
|
233
|
+
totalRecords: number = 0;
|
234
|
+
|
235
|
+
ngOnInit(): void {
|
236
|
+
this.criteria = [
|
237
|
+
{
|
238
|
+
title: "Name",
|
239
|
+
code: "name",
|
240
|
+
type: SearchCriteriaTypeEnum.STRING,
|
241
|
+
},
|
242
|
+
{
|
243
|
+
title: "Date Range",
|
244
|
+
code: "dateRange",
|
245
|
+
type: SearchCriteriaTypeEnum.DATERANGE,
|
246
|
+
},
|
247
|
+
{
|
248
|
+
title: "Amount",
|
249
|
+
code: "amount",
|
250
|
+
type: SearchCriteriaTypeEnum.AMOUNT,
|
251
|
+
currency: "USD",
|
252
|
+
},
|
253
|
+
{
|
254
|
+
title: "Type",
|
255
|
+
code: "type",
|
256
|
+
type: SearchCriteriaTypeEnum.MULTISELECT,
|
257
|
+
filterOptions: [
|
258
|
+
{ label: "Invoice", value: "Invoice" },
|
259
|
+
{ label: "Bill", value: "Bill" },
|
260
|
+
],
|
261
|
+
},
|
262
|
+
];
|
263
|
+
|
264
|
+
this.data = [
|
265
|
+
{ name: "ZAK JAAI", date: "11/06/2024", amount: 100, type: "Invoice" },
|
266
|
+
{ name: "ZAK2 JAAI", date: "20/06/2024", amount: 200, type: "Bill" },
|
267
|
+
];
|
268
|
+
|
269
|
+
this.filteredData = [...this.data];
|
270
|
+
this.totalRecords = this.data.length;
|
271
|
+
}
|
272
|
+
|
273
|
+
onFilteredData(filteredData: any[]): void {
|
274
|
+
this.filteredData = filteredData;
|
275
|
+
this.totalRecords = filteredData.length;
|
276
|
+
}
|
277
|
+
|
278
|
+
onSearchData(searchCriteria: { [key: string]: any }): void {
|
279
|
+
console.log(searchCriteria);
|
280
|
+
}
|
281
|
+
}
|
282
|
+
```
|
283
|
+
|
284
|
+
### Inputs
|
285
|
+
|
286
|
+
- **title** (`
|
287
|
+
|
288
|
+
string`): The title of the multi-search criteria panel.
|
289
|
+
|
290
|
+
- **criteria** (`SearchCriteria[]`): The search criteria configuration.
|
291
|
+
- **data** (`any[]`): The data to be filtered (used in static mode).
|
292
|
+
- **mode** (`'static' | 'dynamic'`): The mode of the multi-search criteria component.
|
293
|
+
- `'static'`: Filters the data directly within the component.
|
294
|
+
- `'dynamic'`: Emits the search criteria to be handled externally (e.g., for server-side filtering).
|
295
|
+
|
296
|
+
### Outputs
|
297
|
+
|
298
|
+
- **filteredData** (`EventEmitter<any[]>`): Emitted with the filtered data (only in static mode).
|
299
|
+
- **searchCriteria** (`EventEmitter<{ [key: string]: any }>`): Emitted with the search criteria (only in dynamic mode).
|
300
|
+
|
301
|
+
### Example
|
302
|
+
|
303
|
+
Here's a complete example of how to use the `multi-search-criteria` component in dynamic mode:
|
304
|
+
|
305
|
+
```typescript
|
306
|
+
import { Component, OnInit } from "@angular/core";
|
307
|
+
import { CommonModule } from "@angular/common";
|
308
|
+
import { MultiSearchCriteriaModule, SearchCriteria, SearchCriteriaTypeEnum, FilterOption } from "ng-prime-tools";
|
309
|
+
|
310
|
+
@Component({
|
311
|
+
selector: "app-root",
|
312
|
+
standalone: true,
|
313
|
+
imports: [CommonModule, MultiSearchCriteriaModule],
|
314
|
+
templateUrl: "./app.component.html",
|
315
|
+
styleUrls: ["./app.component.css"],
|
316
|
+
})
|
317
|
+
export class AppComponent implements OnInit {
|
318
|
+
criteria: SearchCriteria[] = [];
|
319
|
+
data: any[] = [];
|
320
|
+
filteredData: any[] = [];
|
321
|
+
totalRecords: number = 0;
|
322
|
+
|
323
|
+
ngOnInit(): void {
|
324
|
+
this.criteria = [
|
325
|
+
{
|
326
|
+
title: "Name",
|
327
|
+
code: "name",
|
328
|
+
type: SearchCriteriaTypeEnum.STRING,
|
329
|
+
},
|
330
|
+
{
|
331
|
+
title: "Date Range",
|
332
|
+
code: "dateRange",
|
333
|
+
type: SearchCriteriaTypeEnum.DATERANGE,
|
334
|
+
},
|
335
|
+
{
|
336
|
+
title: "Amount",
|
337
|
+
code: "amount",
|
338
|
+
type: SearchCriteriaTypeEnum.AMOUNT,
|
339
|
+
currency: "USD",
|
340
|
+
},
|
341
|
+
{
|
342
|
+
title: "Type",
|
343
|
+
code: "type",
|
344
|
+
type: SearchCriteriaTypeEnum.MULTISELECT,
|
345
|
+
filterOptions: [
|
346
|
+
{ label: "Invoice", value: "Invoice" },
|
347
|
+
{ label: "Bill", value: "Bill" },
|
348
|
+
],
|
349
|
+
},
|
350
|
+
];
|
351
|
+
|
352
|
+
this.data = [
|
353
|
+
{ name: "ZAK JAAI", date: "11/06/2024", amount: 100, type: "Invoice" },
|
354
|
+
{ name: "ZAK2 JAAI", date: "20/06/2024", amount: 200, type: "Bill" },
|
355
|
+
];
|
356
|
+
|
357
|
+
this.filteredData = [...this.data];
|
358
|
+
this.totalRecords = this.data.length;
|
359
|
+
}
|
360
|
+
|
361
|
+
onFilteredData(filteredData: any[]): void {
|
362
|
+
this.filteredData = filteredData;
|
363
|
+
this.totalRecords = filteredData.length;
|
364
|
+
}
|
365
|
+
|
366
|
+
onSearchData(searchCriteria: { [key: string]: any }): void {
|
367
|
+
console.log(searchCriteria);
|
368
|
+
// Perform server-side search or any other external data fetching logic
|
369
|
+
}
|
370
|
+
}
|
371
|
+
```
|
372
|
+
|
373
|
+
```html
|
374
|
+
<multi-search-criteria [title]="'Multi-Criteria Search'" [criteria]="criteria" [data]="data" [mode]="'dynamic'" (filteredData)="onFilteredData($event)" (searchCriteria)="onSearchData($event)"></multi-search-criteria>
|
375
|
+
|
376
|
+
<ng-advanced-prime-table [columns]="columns" [data]="filteredData" [hasSearchFilter]="true" [hasColumnFilter]="true" [isPaginated]="true" [totalRecords]="totalRecords" [isSortable]="true"></ng-advanced-prime-table>
|
377
|
+
```
|
378
|
+
|
189
379
|
## Changelog
|
190
380
|
|
381
|
+
### Version 1.0.5
|
382
|
+
|
383
|
+
#### New Features
|
384
|
+
|
385
|
+
- **`multi-search-criteria` Component**
|
386
|
+
|
387
|
+
- Added support for `mode` input to handle dynamic and static filtering.
|
388
|
+
- `mode` input can be set to `'dynamic'` or `'static'`. When set to `'dynamic'`, the component emits search criteria for backend filtering. When set to `'static'`, the component filters data locally.
|
389
|
+
- Fixed the bug in the `selectAll` functionality for multi-select filters.
|
390
|
+
- Users can select or deselect all options in a multi-select filter.
|
391
|
+
|
392
|
+
- **`ng-advanced-prime-table` Component**
|
393
|
+
- Added support for customizable amount formatting.
|
394
|
+
- New inputs for columns of type `AMOUNT`:
|
395
|
+
- `thousandSeparator` (`comma` or `space`): Specifies the character used for thousands separator.
|
396
|
+
- `decimalSeparator` (`comma` or `dot`): Specifies the character used for decimal separator.
|
397
|
+
- Updated the `customCurrency` pipe to handle optional currency display and customizable separators.
|
398
|
+
|
399
|
+
### Version 1.0.4
|
400
|
+
|
401
|
+
- Added `multi-search-criteria` component.
|
402
|
+
|
191
403
|
### Version 1.0.3
|
192
404
|
|
193
405
|
- Initial release with `ng-advanced-prime-table` component.
|
@@ -1,2 +1,2 @@
|
|
1
1
|
export {};
|
2
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFibGUtY29sdW1uLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmctcHJpbWUtdG9vbHMvc3JjL2xpYi9tb2RlbHMvdGFibGUtY29sdW1uLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBUYWJsZVR5cGVFbnVtIH0gZnJvbSAnLi4vZW51bXMvdGFibGUtdHlwZS1lbnVtJztcblxuZXhwb3J0IGludGVyZmFjZSBUYWJsZUNvbHVtbiB7XG4gIHRpdGxlOiBzdHJpbmc7XG4gIGNvZGU/OiBzdHJpbmc7XG4gIHR5cGU/OiBUYWJsZVR5cGVFbnVtO1xuICBvcHRpb25zPzogYW55W107XG4gIGlzRWRpdGFibGU/OiBib29sZWFuO1xuICBpc0ZpbHRlcj86IGJvb2xlYW47XG4gIGRhdGVGb3JtYXQ/OiBzdHJpbmc7XG4gIGN1cnJlbmN5Pzogc3RyaW5nO1xuICBmaWx0ZXJPcHRpb25zPzogYW55W107XG4gIGRlY2ltYWxQbGFjZXM/OiBudW1iZXI7XG4gIGlzU29ydGFibGU/
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFibGUtY29sdW1uLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmctcHJpbWUtdG9vbHMvc3JjL2xpYi9tb2RlbHMvdGFibGUtY29sdW1uLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBUYWJsZVR5cGVFbnVtIH0gZnJvbSAnLi4vZW51bXMvdGFibGUtdHlwZS1lbnVtJztcblxuZXhwb3J0IGludGVyZmFjZSBUYWJsZUNvbHVtbiB7XG4gIHRpdGxlOiBzdHJpbmc7XG4gIGNvZGU/OiBzdHJpbmc7XG4gIHR5cGU/OiBUYWJsZVR5cGVFbnVtO1xuICBvcHRpb25zPzogYW55W107XG4gIGlzRWRpdGFibGU/OiBib29sZWFuO1xuICBpc0ZpbHRlcj86IGJvb2xlYW47XG4gIGRhdGVGb3JtYXQ/OiBzdHJpbmc7XG4gIGN1cnJlbmN5Pzogc3RyaW5nO1xuICBmaWx0ZXJPcHRpb25zPzogYW55W107XG4gIGRlY2ltYWxQbGFjZXM/OiBudW1iZXI7XG4gIGlzU29ydGFibGU/OiBib29sZWFuO1xuICB0aG91c2FuZFNlcGFyYXRvcj86ICdjb21tYScgfCAnc3BhY2UnO1xuICBkZWNpbWFsU2VwYXJhdG9yPzogJ2NvbW1hJyB8ICdkb3QnO1xufVxuIl19
|
@@ -17,7 +17,9 @@ export class MultiSearchCriteriaComponent {
|
|
17
17
|
this.criteria = [];
|
18
18
|
this.inputsPerRow = 3;
|
19
19
|
this.data = [];
|
20
|
+
this.mode = 'static'; // Add mode input
|
20
21
|
this.filteredData = new EventEmitter();
|
22
|
+
this.searchCriteria = new EventEmitter();
|
21
23
|
this.selectAll = false;
|
22
24
|
this.selected = [];
|
23
25
|
}
|
@@ -34,48 +36,56 @@ export class MultiSearchCriteriaComponent {
|
|
34
36
|
return input.currency || 'EUR';
|
35
37
|
}
|
36
38
|
search() {
|
37
|
-
|
38
|
-
|
39
|
-
|
40
|
-
|
41
|
-
|
42
|
-
|
43
|
-
|
44
|
-
|
45
|
-
|
46
|
-
|
47
|
-
|
48
|
-
|
49
|
-
|
39
|
+
if (this.mode === 'dynamic') {
|
40
|
+
const criteriaValues = {};
|
41
|
+
this.criteria.forEach((criterion) => {
|
42
|
+
if (criterion.value !== null && criterion.value !== undefined) {
|
43
|
+
criteriaValues[criterion.code] = criterion.value;
|
44
|
+
}
|
45
|
+
});
|
46
|
+
this.searchCriteria.emit(criteriaValues);
|
47
|
+
}
|
48
|
+
else {
|
49
|
+
const filtered = this.data.filter((item) => {
|
50
|
+
return this.criteria.every((criterion) => {
|
51
|
+
if (criterion.type === SearchCriteriaTypeEnum.DATERANGE) {
|
52
|
+
const [startDate, endDate] = criterion.value || [
|
53
|
+
undefined,
|
54
|
+
undefined,
|
55
|
+
];
|
56
|
+
const itemDate = this.parseDate(item[criterion.code] || item['date']);
|
57
|
+
if (!startDate && !endDate) {
|
58
|
+
return true;
|
59
|
+
}
|
60
|
+
if (itemDate === null) {
|
61
|
+
return false;
|
62
|
+
}
|
63
|
+
const parsedStartDate = startDate
|
64
|
+
? this.parseDate(startDate)
|
65
|
+
: null;
|
66
|
+
const parsedEndDate = endDate ? this.parseDate(endDate) : null;
|
67
|
+
return ((!parsedStartDate || itemDate >= parsedStartDate) &&
|
68
|
+
(!parsedEndDate || itemDate <= parsedEndDate));
|
50
69
|
}
|
51
|
-
if (
|
52
|
-
return
|
70
|
+
else if (criterion.type === SearchCriteriaTypeEnum.AMOUNT) {
|
71
|
+
return !criterion.value || item[criterion.code] === criterion.value;
|
53
72
|
}
|
54
|
-
|
55
|
-
|
56
|
-
|
57
|
-
|
58
|
-
|
59
|
-
|
60
|
-
|
61
|
-
|
62
|
-
|
63
|
-
|
64
|
-
|
65
|
-
|
66
|
-
}
|
67
|
-
else if (criterion.type === SearchCriteriaTypeEnum.STRING) {
|
68
|
-
return (!criterion.value ||
|
69
|
-
item[criterion.code]
|
70
|
-
.toString()
|
71
|
-
.toLowerCase()
|
72
|
-
.includes(criterion.value.toString().toLowerCase()));
|
73
|
-
}
|
74
|
-
return true;
|
73
|
+
else if (criterion.type === SearchCriteriaTypeEnum.MULTISELECT) {
|
74
|
+
return (!criterion.value ||
|
75
|
+
criterion.value.some((option) => option.label === item[criterion.code]));
|
76
|
+
}
|
77
|
+
else if (criterion.type === SearchCriteriaTypeEnum.STRING) {
|
78
|
+
return (!criterion.value ||
|
79
|
+
item[criterion.code]
|
80
|
+
.toString()
|
81
|
+
.toLowerCase()
|
82
|
+
.includes(criterion.value.toString().toLowerCase()));
|
83
|
+
}
|
84
|
+
return true;
|
85
|
+
});
|
75
86
|
});
|
76
|
-
|
77
|
-
|
78
|
-
this.filteredData.emit(filtered);
|
87
|
+
this.filteredData.emit(filtered);
|
88
|
+
}
|
79
89
|
}
|
80
90
|
clear() {
|
81
91
|
this.criteria.forEach((input) => {
|
@@ -83,13 +93,9 @@ export class MultiSearchCriteriaComponent {
|
|
83
93
|
});
|
84
94
|
this.filteredData.emit(this.data);
|
85
95
|
}
|
86
|
-
onSelectAllChange(event) {
|
96
|
+
onSelectAllChange(event, criterion) {
|
87
97
|
this.selectAll = event.checked;
|
88
|
-
|
89
|
-
? [
|
90
|
-
...(this.criteria.find((criterion) => criterion.type === SearchCriteriaTypeEnum.MULTISELECT)?.filterOptions || []),
|
91
|
-
]
|
92
|
-
: [];
|
98
|
+
criterion.value = event.checked ? [...(criterion.filterOptions ?? [])] : [];
|
93
99
|
}
|
94
100
|
parseDate(dateString) {
|
95
101
|
if (!dateString) {
|
@@ -109,11 +115,11 @@ export class MultiSearchCriteriaComponent {
|
|
109
115
|
return null;
|
110
116
|
}
|
111
117
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: MultiSearchCriteriaComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
112
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.11", type: MultiSearchCriteriaComponent, selector: "multi-search-criteria", inputs: { title: "title", criteria: "criteria", inputsPerRow: "inputsPerRow", data: "data" }, outputs: { filteredData: "filteredData" }, ngImport: i0, template: "<p-panel header=\"{{ title }}\" [toggleable]=\"true\" [collapsed]=\"true\">\n <div\n class=\"criteria-container\"\n [ngStyle]=\"{ 'grid-template-columns': 'repeat(' + inputsPerRow + ', 1fr)' }\"\n >\n <div *ngFor=\"let input of criteria\" class=\"criteria-item\">\n <label class=\"bsc-label\">{{ input.title }}</label>\n\n <ng-container [ngSwitch]=\"input.type\">\n <p-calendar\n *ngSwitchCase=\"SearchCriteriaTypeEnum.DATERANGE\"\n [(ngModel)]=\"input.value\"\n selectionMode=\"range\"\n [dateFormat]=\"'dd/mm/yy'\"\n class=\"full-width-input\"\n [showIcon]=\"true\"\n (ngModelChange)=\"input.value = $event\"\n ></p-calendar>\n <p-calendar\n *ngSwitchCase=\"SearchCriteriaTypeEnum.DATE\"\n [ngModel]=\"input.value\"\n (ngModelChange)=\"input.value = $event\"\n [dateFormat]=\"'dd/mm/yy'\"\n [showIcon]=\"true\"\n class=\"full-width-input\"\n ></p-calendar>\n <input\n *ngSwitchCase=\"SearchCriteriaTypeEnum.STRING\"\n type=\"text\"\n pInputText\n [(ngModel)]=\"input.value\"\n class=\"full-width-input\"\n />\n\n <p-inputNumber\n *ngSwitchCase=\"SearchCriteriaTypeEnum.AMOUNT\"\n type=\"number\"\n [(ngModel)]=\"input.value\"\n mode=\"decimal\"\n inputId=\"minmaxfraction\"\n [minFractionDigits]=\"2\"\n [maxFractionDigits]=\"5\"\n [placeholder]=\"getCurrencySymbol(input)\"\n class=\"full-width-input\"\n ></p-inputNumber>\n\n <p-inputNumber\n *ngSwitchCase=\"SearchCriteriaTypeEnum.NUMBER\"\n type=\"number\"\n [(ngModel)]=\"input.value\"\n class=\"full-width-input\"\n ></p-inputNumber>\n\n <p-multiSelect\n *ngSwitchCase=\"SearchCriteriaTypeEnum.MULTISELECT\"\n [options]=\"input.filterOptions\"\n [display]=\"'chip'\"\n placeholder=\"Select\"\n [selectAll]=\"selectAll\"\n [(ngModel)]=\"input.value\"\n optionLabel=\"label\"\n (onSelectAllChange)=\"onSelectAllChange($event)\"\n class=\"custom-multiselect full-width-input\"\n ></p-multiSelect>\n </ng-container>\n </div>\n </div>\n\n <ng-template pTemplate=\"footer\">\n <div class=\"footer-buttons\">\n <p-button\n label=\"Effacer\"\n icon=\"pi pi-times\"\n (click)=\"clear()\"\n class=\"footer-button\"\n ></p-button>\n <p-button\n label=\"Rechercher\"\n icon=\"pi pi-search\"\n (click)=\"search()\"\n class=\"footer-button\"\n ></p-button>\n </div>\n </ng-template>\n</p-panel>\n", styles: ["::ng-deep .p-element .p-hidden-accessible input{display:none}::ng-deep .bsc-label{display:block;margin-bottom:5px;font-weight:700}::ng-deep .custom-multiselect{width:100%}::ng-deep .p-multiselect .p-multiselect-label{font-size:14px;color:#333}::ng-deep .p-inputtext{width:100%}::ng-deep .p-calendar .p-inputtext{width:100%}::ng-deep .p-inputnumber{width:100%}.criteria-container{display:grid;gap:10px}.criteria-item{margin-bottom:10px;box-sizing:border-box}.full-width-input,::ng-deep .p-calendar,::ng-deep .p-multiselect{width:100%}::ng-deep .p-calendar .p-inputtext,::ng-deep .p-multiselect .p-multiselect-label{width:100%}.footer-buttons{display:flex;justify-content:flex-end;gap:10px}::ng-deep .footer-button button{width:140px;cursor:pointer}::ng-deep .p-panel .p-panel-footer{background:#f8f9fa}\n"], dependencies: [{ kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "directive", type: i1.NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { kind: "directive", type: i1.NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { kind: "component", type: i2.Calendar, selector: "p-calendar", inputs: ["iconDisplay", "style", "styleClass", "inputStyle", "inputId", "name", "inputStyleClass", "placeholder", "ariaLabelledBy", "ariaLabel", "iconAriaLabel", "disabled", "dateFormat", "multipleSeparator", "rangeSeparator", "inline", "showOtherMonths", "selectOtherMonths", "showIcon", "icon", "appendTo", "readonlyInput", "shortYearCutoff", "monthNavigator", "yearNavigator", "hourFormat", "timeOnly", "stepYearPicker", "stepHour", "stepMinute", "stepSecond", "showSeconds", "required", "showOnFocus", "showWeek", "startWeekFromFirstDayOfYear", "showClear", "dataType", "selectionMode", "maxDateCount", "showButtonBar", "todayButtonStyleClass", "clearButtonStyleClass", "autofocus", "autoZIndex", "baseZIndex", "panelStyleClass", "panelStyle", "keepInvalid", "hideOnDateTimeSelect", "touchUI", "timeSeparator", "focusTrap", "showTransitionOptions", "hideTransitionOptions", "tabindex", "variant", "minDate", "maxDate", "disabledDates", "disabledDays", "yearRange", "showTime", "responsiveOptions", "numberOfMonths", "firstDayOfWeek", "locale", "view", "defaultDate"], outputs: ["onFocus", "onBlur", "onClose", "onSelect", "onClear", "onInput", "onTodayClick", "onClearClick", "onMonthChange", "onYearChange", "onClickOutside", "onShow"] }, { kind: "component", type: i3.Button, selector: "p-button", inputs: ["type", "iconPos", "icon", "badge", "label", "disabled", "loading", "loadingIcon", "raised", "rounded", "text", "plain", "severity", "outlined", "link", "tabindex", "size", "style", "styleClass", "badgeClass", "ariaLabel", "autofocus"], outputs: ["onClick", "onFocus", "onBlur"] }, { kind: "directive", type: i4.PrimeTemplate, selector: "[pTemplate]", inputs: ["type", "pTemplate"] }, { kind: "directive", type: i5.InputText, selector: "[pInputText]", inputs: ["variant"] }, { kind: "component", type: i6.MultiSelect, selector: "p-multiSelect", inputs: ["id", "ariaLabel", "style", "styleClass", "panelStyle", "panelStyleClass", "inputId", "disabled", "readonly", "group", "filter", "filterPlaceHolder", "filterLocale", "overlayVisible", "tabindex", "variant", "appendTo", "dataKey", "name", "ariaLabelledBy", "displaySelectedLabel", "maxSelectedLabels", "selectionLimit", "selectedItemsLabel", "showToggleAll", "emptyFilterMessage", "emptyMessage", "resetFilterOnHide", "dropdownIcon", "optionLabel", "optionValue", "optionDisabled", "optionGroupLabel", "optionGroupChildren", "showHeader", "filterBy", "scrollHeight", "lazy", "virtualScroll", "loading", "virtualScrollItemSize", "loadingIcon", "virtualScrollOptions", "overlayOptions", "ariaFilterLabel", "filterMatchMode", "tooltip", "tooltipPosition", "tooltipPositionStyle", "tooltipStyleClass", "autofocusFilter", "display", "autocomplete", "showClear", "autofocus", "autoZIndex", "baseZIndex", "showTransitionOptions", "hideTransitionOptions", "defaultLabel", "placeholder", "options", "filterValue", "itemSize", "selectAll", "focusOnHover", "filterFields", "selectOnFocus", "autoOptionFocus"], outputs: ["onChange", "onFilter", "onFocus", "onBlur", "onClick", "onClear", "onPanelShow", "onPanelHide", "onLazyLoad", "onRemove", "onSelectAllChange"] }, { kind: "directive", type: i7.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: i7.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i7.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i8.InputNumber, selector: "p-inputNumber", inputs: ["showButtons", "format", "buttonLayout", "inputId", "styleClass", "style", "placeholder", "size", "maxlength", "tabindex", "title", "ariaLabelledBy", "ariaLabel", "ariaRequired", "name", "required", "autocomplete", "min", "max", "incrementButtonClass", "decrementButtonClass", "incrementButtonIcon", "decrementButtonIcon", "readonly", "step", "allowEmpty", "locale", "localeMatcher", "mode", "currency", "currencyDisplay", "useGrouping", "variant", "minFractionDigits", "maxFractionDigits", "prefix", "suffix", "inputStyle", "inputStyleClass", "showClear", "autofocus", "disabled"], outputs: ["onInput", "onFocus", "onBlur", "onKeyDown", "onClear"] }, { kind: "component", type: i9.Panel, selector: "p-panel", inputs: ["toggleable", "header", "collapsed", "style", "styleClass", "iconPos", "expandIcon", "collapseIcon", "showHeader", "toggler", "transitionOptions"], outputs: ["collapsedChange", "onBeforeToggle", "onAfterToggle"] }] }); }
|
118
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.11", type: MultiSearchCriteriaComponent, selector: "multi-search-criteria", inputs: { title: "title", criteria: "criteria", inputsPerRow: "inputsPerRow", data: "data", mode: "mode" }, outputs: { filteredData: "filteredData", searchCriteria: "searchCriteria" }, ngImport: i0, template: "<p-panel header=\"{{ title }}\" [toggleable]=\"true\" [collapsed]=\"true\">\n <div\n class=\"criteria-container\"\n [ngStyle]=\"{ 'grid-template-columns': 'repeat(' + inputsPerRow + ', 1fr)' }\"\n >\n <div *ngFor=\"let input of criteria\" class=\"criteria-item\">\n <label class=\"bsc-label\">{{ input.title }}</label>\n\n <ng-container [ngSwitch]=\"input.type\">\n <p-calendar\n *ngSwitchCase=\"SearchCriteriaTypeEnum.DATERANGE\"\n [(ngModel)]=\"input.value\"\n selectionMode=\"range\"\n [dateFormat]=\"'dd/mm/yy'\"\n class=\"full-width-input\"\n [showIcon]=\"true\"\n (ngModelChange)=\"input.value = $event\"\n ></p-calendar>\n <p-calendar\n *ngSwitchCase=\"SearchCriteriaTypeEnum.DATE\"\n [ngModel]=\"input.value\"\n (ngModelChange)=\"input.value = $event\"\n [dateFormat]=\"'dd/mm/yy'\"\n [showIcon]=\"true\"\n class=\"full-width-input\"\n ></p-calendar>\n <input\n *ngSwitchCase=\"SearchCriteriaTypeEnum.STRING\"\n type=\"text\"\n pInputText\n [(ngModel)]=\"input.value\"\n class=\"full-width-input\"\n />\n\n <p-inputNumber\n *ngSwitchCase=\"SearchCriteriaTypeEnum.AMOUNT\"\n type=\"number\"\n [(ngModel)]=\"input.value\"\n mode=\"decimal\"\n inputId=\"minmaxfraction\"\n [minFractionDigits]=\"2\"\n [maxFractionDigits]=\"5\"\n [placeholder]=\"getCurrencySymbol(input)\"\n class=\"full-width-input\"\n ></p-inputNumber>\n\n <p-inputNumber\n *ngSwitchCase=\"SearchCriteriaTypeEnum.NUMBER\"\n type=\"number\"\n [(ngModel)]=\"input.value\"\n class=\"full-width-input\"\n ></p-inputNumber>\n\n <p-multiSelect\n *ngSwitchCase=\"SearchCriteriaTypeEnum.MULTISELECT\"\n [options]=\"input.filterOptions\"\n [display]=\"'chip'\"\n placeholder=\"Select\"\n [selectAll]=\"selectAll\"\n [(ngModel)]=\"input.value\"\n optionLabel=\"label\"\n (onSelectAllChange)=\"onSelectAllChange($event, input)\"\n class=\"custom-multiselect full-width-input\"\n ></p-multiSelect>\n </ng-container>\n </div>\n </div>\n\n <ng-template pTemplate=\"footer\">\n <div class=\"footer-buttons\">\n <p-button\n label=\"Effacer\"\n icon=\"pi pi-times\"\n (click)=\"clear()\"\n class=\"footer-button\"\n ></p-button>\n <p-button\n label=\"Rechercher\"\n icon=\"pi pi-search\"\n (click)=\"search()\"\n class=\"footer-button\"\n ></p-button>\n </div>\n </ng-template>\n</p-panel>\n", styles: ["::ng-deep .p-element .p-hidden-accessible input{display:none}::ng-deep .bsc-label{display:block;margin-bottom:5px;font-weight:700}::ng-deep .custom-multiselect{width:100%}::ng-deep .p-multiselect .p-multiselect-label{font-size:14px;color:#333}::ng-deep .p-inputtext{width:100%}::ng-deep .p-calendar .p-inputtext{width:100%}::ng-deep .p-inputnumber{width:100%}.criteria-container{display:grid;gap:10px}.criteria-item{margin-bottom:10px;box-sizing:border-box}.full-width-input,::ng-deep .p-calendar,::ng-deep .p-multiselect{width:100%}::ng-deep .p-calendar .p-inputtext,::ng-deep .p-multiselect .p-multiselect-label{width:100%}.footer-buttons{display:flex;justify-content:flex-end;gap:10px}::ng-deep .footer-button button{width:140px;cursor:pointer}::ng-deep .p-panel .p-panel-footer{background:#f8f9fa}\n"], dependencies: [{ kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "directive", type: i1.NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { kind: "directive", type: i1.NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { kind: "component", type: i2.Calendar, selector: "p-calendar", inputs: ["iconDisplay", "style", "styleClass", "inputStyle", "inputId", "name", "inputStyleClass", "placeholder", "ariaLabelledBy", "ariaLabel", "iconAriaLabel", "disabled", "dateFormat", "multipleSeparator", "rangeSeparator", "inline", "showOtherMonths", "selectOtherMonths", "showIcon", "icon", "appendTo", "readonlyInput", "shortYearCutoff", "monthNavigator", "yearNavigator", "hourFormat", "timeOnly", "stepYearPicker", "stepHour", "stepMinute", "stepSecond", "showSeconds", "required", "showOnFocus", "showWeek", "startWeekFromFirstDayOfYear", "showClear", "dataType", "selectionMode", "maxDateCount", "showButtonBar", "todayButtonStyleClass", "clearButtonStyleClass", "autofocus", "autoZIndex", "baseZIndex", "panelStyleClass", "panelStyle", "keepInvalid", "hideOnDateTimeSelect", "touchUI", "timeSeparator", "focusTrap", "showTransitionOptions", "hideTransitionOptions", "tabindex", "variant", "minDate", "maxDate", "disabledDates", "disabledDays", "yearRange", "showTime", "responsiveOptions", "numberOfMonths", "firstDayOfWeek", "locale", "view", "defaultDate"], outputs: ["onFocus", "onBlur", "onClose", "onSelect", "onClear", "onInput", "onTodayClick", "onClearClick", "onMonthChange", "onYearChange", "onClickOutside", "onShow"] }, { kind: "component", type: i3.Button, selector: "p-button", inputs: ["type", "iconPos", "icon", "badge", "label", "disabled", "loading", "loadingIcon", "raised", "rounded", "text", "plain", "severity", "outlined", "link", "tabindex", "size", "style", "styleClass", "badgeClass", "ariaLabel", "autofocus"], outputs: ["onClick", "onFocus", "onBlur"] }, { kind: "directive", type: i4.PrimeTemplate, selector: "[pTemplate]", inputs: ["type", "pTemplate"] }, { kind: "directive", type: i5.InputText, selector: "[pInputText]", inputs: ["variant"] }, { kind: "component", type: i6.MultiSelect, selector: "p-multiSelect", inputs: ["id", "ariaLabel", "style", "styleClass", "panelStyle", "panelStyleClass", "inputId", "disabled", "readonly", "group", "filter", "filterPlaceHolder", "filterLocale", "overlayVisible", "tabindex", "variant", "appendTo", "dataKey", "name", "ariaLabelledBy", "displaySelectedLabel", "maxSelectedLabels", "selectionLimit", "selectedItemsLabel", "showToggleAll", "emptyFilterMessage", "emptyMessage", "resetFilterOnHide", "dropdownIcon", "optionLabel", "optionValue", "optionDisabled", "optionGroupLabel", "optionGroupChildren", "showHeader", "filterBy", "scrollHeight", "lazy", "virtualScroll", "loading", "virtualScrollItemSize", "loadingIcon", "virtualScrollOptions", "overlayOptions", "ariaFilterLabel", "filterMatchMode", "tooltip", "tooltipPosition", "tooltipPositionStyle", "tooltipStyleClass", "autofocusFilter", "display", "autocomplete", "showClear", "autofocus", "autoZIndex", "baseZIndex", "showTransitionOptions", "hideTransitionOptions", "defaultLabel", "placeholder", "options", "filterValue", "itemSize", "selectAll", "focusOnHover", "filterFields", "selectOnFocus", "autoOptionFocus"], outputs: ["onChange", "onFilter", "onFocus", "onBlur", "onClick", "onClear", "onPanelShow", "onPanelHide", "onLazyLoad", "onRemove", "onSelectAllChange"] }, { kind: "directive", type: i7.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: i7.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i7.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i8.InputNumber, selector: "p-inputNumber", inputs: ["showButtons", "format", "buttonLayout", "inputId", "styleClass", "style", "placeholder", "size", "maxlength", "tabindex", "title", "ariaLabelledBy", "ariaLabel", "ariaRequired", "name", "required", "autocomplete", "min", "max", "incrementButtonClass", "decrementButtonClass", "incrementButtonIcon", "decrementButtonIcon", "readonly", "step", "allowEmpty", "locale", "localeMatcher", "mode", "currency", "currencyDisplay", "useGrouping", "variant", "minFractionDigits", "maxFractionDigits", "prefix", "suffix", "inputStyle", "inputStyleClass", "showClear", "autofocus", "disabled"], outputs: ["onInput", "onFocus", "onBlur", "onKeyDown", "onClear"] }, { kind: "component", type: i9.Panel, selector: "p-panel", inputs: ["toggleable", "header", "collapsed", "style", "styleClass", "iconPos", "expandIcon", "collapseIcon", "showHeader", "toggler", "transitionOptions"], outputs: ["collapsedChange", "onBeforeToggle", "onAfterToggle"] }] }); }
|
113
119
|
}
|
114
120
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: MultiSearchCriteriaComponent, decorators: [{
|
115
121
|
type: Component,
|
116
|
-
args: [{ selector: 'multi-search-criteria', template: "<p-panel header=\"{{ title }}\" [toggleable]=\"true\" [collapsed]=\"true\">\n <div\n class=\"criteria-container\"\n [ngStyle]=\"{ 'grid-template-columns': 'repeat(' + inputsPerRow + ', 1fr)' }\"\n >\n <div *ngFor=\"let input of criteria\" class=\"criteria-item\">\n <label class=\"bsc-label\">{{ input.title }}</label>\n\n <ng-container [ngSwitch]=\"input.type\">\n <p-calendar\n *ngSwitchCase=\"SearchCriteriaTypeEnum.DATERANGE\"\n [(ngModel)]=\"input.value\"\n selectionMode=\"range\"\n [dateFormat]=\"'dd/mm/yy'\"\n class=\"full-width-input\"\n [showIcon]=\"true\"\n (ngModelChange)=\"input.value = $event\"\n ></p-calendar>\n <p-calendar\n *ngSwitchCase=\"SearchCriteriaTypeEnum.DATE\"\n [ngModel]=\"input.value\"\n (ngModelChange)=\"input.value = $event\"\n [dateFormat]=\"'dd/mm/yy'\"\n [showIcon]=\"true\"\n class=\"full-width-input\"\n ></p-calendar>\n <input\n *ngSwitchCase=\"SearchCriteriaTypeEnum.STRING\"\n type=\"text\"\n pInputText\n [(ngModel)]=\"input.value\"\n class=\"full-width-input\"\n />\n\n <p-inputNumber\n *ngSwitchCase=\"SearchCriteriaTypeEnum.AMOUNT\"\n type=\"number\"\n [(ngModel)]=\"input.value\"\n mode=\"decimal\"\n inputId=\"minmaxfraction\"\n [minFractionDigits]=\"2\"\n [maxFractionDigits]=\"5\"\n [placeholder]=\"getCurrencySymbol(input)\"\n class=\"full-width-input\"\n ></p-inputNumber>\n\n <p-inputNumber\n *ngSwitchCase=\"SearchCriteriaTypeEnum.NUMBER\"\n type=\"number\"\n [(ngModel)]=\"input.value\"\n class=\"full-width-input\"\n ></p-inputNumber>\n\n <p-multiSelect\n *ngSwitchCase=\"SearchCriteriaTypeEnum.MULTISELECT\"\n [options]=\"input.filterOptions\"\n [display]=\"'chip'\"\n placeholder=\"Select\"\n [selectAll]=\"selectAll\"\n [(ngModel)]=\"input.value\"\n optionLabel=\"label\"\n (onSelectAllChange)=\"onSelectAllChange($event)\"\n class=\"custom-multiselect full-width-input\"\n ></p-multiSelect>\n </ng-container>\n </div>\n </div>\n\n <ng-template pTemplate=\"footer\">\n <div class=\"footer-buttons\">\n <p-button\n label=\"Effacer\"\n icon=\"pi pi-times\"\n (click)=\"clear()\"\n class=\"footer-button\"\n ></p-button>\n <p-button\n label=\"Rechercher\"\n icon=\"pi pi-search\"\n (click)=\"search()\"\n class=\"footer-button\"\n ></p-button>\n </div>\n </ng-template>\n</p-panel>\n", styles: ["::ng-deep .p-element .p-hidden-accessible input{display:none}::ng-deep .bsc-label{display:block;margin-bottom:5px;font-weight:700}::ng-deep .custom-multiselect{width:100%}::ng-deep .p-multiselect .p-multiselect-label{font-size:14px;color:#333}::ng-deep .p-inputtext{width:100%}::ng-deep .p-calendar .p-inputtext{width:100%}::ng-deep .p-inputnumber{width:100%}.criteria-container{display:grid;gap:10px}.criteria-item{margin-bottom:10px;box-sizing:border-box}.full-width-input,::ng-deep .p-calendar,::ng-deep .p-multiselect{width:100%}::ng-deep .p-calendar .p-inputtext,::ng-deep .p-multiselect .p-multiselect-label{width:100%}.footer-buttons{display:flex;justify-content:flex-end;gap:10px}::ng-deep .footer-button button{width:140px;cursor:pointer}::ng-deep .p-panel .p-panel-footer{background:#f8f9fa}\n"] }]
|
122
|
+
args: [{ selector: 'multi-search-criteria', template: "<p-panel header=\"{{ title }}\" [toggleable]=\"true\" [collapsed]=\"true\">\n <div\n class=\"criteria-container\"\n [ngStyle]=\"{ 'grid-template-columns': 'repeat(' + inputsPerRow + ', 1fr)' }\"\n >\n <div *ngFor=\"let input of criteria\" class=\"criteria-item\">\n <label class=\"bsc-label\">{{ input.title }}</label>\n\n <ng-container [ngSwitch]=\"input.type\">\n <p-calendar\n *ngSwitchCase=\"SearchCriteriaTypeEnum.DATERANGE\"\n [(ngModel)]=\"input.value\"\n selectionMode=\"range\"\n [dateFormat]=\"'dd/mm/yy'\"\n class=\"full-width-input\"\n [showIcon]=\"true\"\n (ngModelChange)=\"input.value = $event\"\n ></p-calendar>\n <p-calendar\n *ngSwitchCase=\"SearchCriteriaTypeEnum.DATE\"\n [ngModel]=\"input.value\"\n (ngModelChange)=\"input.value = $event\"\n [dateFormat]=\"'dd/mm/yy'\"\n [showIcon]=\"true\"\n class=\"full-width-input\"\n ></p-calendar>\n <input\n *ngSwitchCase=\"SearchCriteriaTypeEnum.STRING\"\n type=\"text\"\n pInputText\n [(ngModel)]=\"input.value\"\n class=\"full-width-input\"\n />\n\n <p-inputNumber\n *ngSwitchCase=\"SearchCriteriaTypeEnum.AMOUNT\"\n type=\"number\"\n [(ngModel)]=\"input.value\"\n mode=\"decimal\"\n inputId=\"minmaxfraction\"\n [minFractionDigits]=\"2\"\n [maxFractionDigits]=\"5\"\n [placeholder]=\"getCurrencySymbol(input)\"\n class=\"full-width-input\"\n ></p-inputNumber>\n\n <p-inputNumber\n *ngSwitchCase=\"SearchCriteriaTypeEnum.NUMBER\"\n type=\"number\"\n [(ngModel)]=\"input.value\"\n class=\"full-width-input\"\n ></p-inputNumber>\n\n <p-multiSelect\n *ngSwitchCase=\"SearchCriteriaTypeEnum.MULTISELECT\"\n [options]=\"input.filterOptions\"\n [display]=\"'chip'\"\n placeholder=\"Select\"\n [selectAll]=\"selectAll\"\n [(ngModel)]=\"input.value\"\n optionLabel=\"label\"\n (onSelectAllChange)=\"onSelectAllChange($event, input)\"\n class=\"custom-multiselect full-width-input\"\n ></p-multiSelect>\n </ng-container>\n </div>\n </div>\n\n <ng-template pTemplate=\"footer\">\n <div class=\"footer-buttons\">\n <p-button\n label=\"Effacer\"\n icon=\"pi pi-times\"\n (click)=\"clear()\"\n class=\"footer-button\"\n ></p-button>\n <p-button\n label=\"Rechercher\"\n icon=\"pi pi-search\"\n (click)=\"search()\"\n class=\"footer-button\"\n ></p-button>\n </div>\n </ng-template>\n</p-panel>\n", styles: ["::ng-deep .p-element .p-hidden-accessible input{display:none}::ng-deep .bsc-label{display:block;margin-bottom:5px;font-weight:700}::ng-deep .custom-multiselect{width:100%}::ng-deep .p-multiselect .p-multiselect-label{font-size:14px;color:#333}::ng-deep .p-inputtext{width:100%}::ng-deep .p-calendar .p-inputtext{width:100%}::ng-deep .p-inputnumber{width:100%}.criteria-container{display:grid;gap:10px}.criteria-item{margin-bottom:10px;box-sizing:border-box}.full-width-input,::ng-deep .p-calendar,::ng-deep .p-multiselect{width:100%}::ng-deep .p-calendar .p-inputtext,::ng-deep .p-multiselect .p-multiselect-label{width:100%}.footer-buttons{display:flex;justify-content:flex-end;gap:10px}::ng-deep .footer-button button{width:140px;cursor:pointer}::ng-deep .p-panel .p-panel-footer{background:#f8f9fa}\n"] }]
|
117
123
|
}], propDecorators: { title: [{
|
118
124
|
type: Input
|
119
125
|
}], criteria: [{
|
@@ -122,7 +128,11 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.11", ngImpo
|
|
122
128
|
type: Input
|
123
129
|
}], data: [{
|
124
130
|
type: Input
|
131
|
+
}], mode: [{
|
132
|
+
type: Input
|
125
133
|
}], filteredData: [{
|
126
134
|
type: Output
|
135
|
+
}], searchCriteria: [{
|
136
|
+
type: Output
|
127
137
|
}] } });
|
128
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"multi-search-criteria.component.js","sourceRoot":"","sources":["../../../../../projects/ng-prime-tools/src/lib/multi-search-criteria/multi-search-criteria.component.ts","../../../../../projects/ng-prime-tools/src/lib/multi-search-criteria/multi-search-criteria.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, Output, EventEmitter, OnInit } from '@angular/core';\nimport { SearchCriteriaTypeEnum } from '../enums';\nimport { SearchCriteria } from '../models/search-criteria';\nimport { FilterOption } from '../models/filter-option';\n\n@Component({\n  selector: 'multi-search-criteria',\n  templateUrl: './multi-search-criteria.component.html',\n  styleUrls: ['./multi-search-criteria.component.css'],\n})\nexport class MultiSearchCriteriaComponent implements OnInit {\n  SearchCriteriaTypeEnum = SearchCriteriaTypeEnum;\n\n  @Input() title: String = '';\n  @Input() criteria: SearchCriteria[] = [];\n  @Input() inputsPerRow: number = 3;\n  @Input() data: any[] = [];\n  @Output() filteredData = new EventEmitter<any[]>();\n\n  selectAll: boolean = false;\n  selected: FilterOption[] = [];\n\n  ngOnInit() {\n    this.criteria.forEach((item) => {\n      if (\n        item.type === SearchCriteriaTypeEnum.MULTISELECT &&\n        item.filterOptions\n      ) {\n        this.selected = [...item.filterOptions];\n        item.value = this.selected;\n      }\n    });\n  }\n\n  getCurrencySymbol(input: SearchCriteria): string {\n    return input.currency || 'EUR';\n  }\n\n  search(): void {\n    console.log('Original Data:', this.data);\n    const filtered = this.data.filter((item) => {\n      return this.criteria.every((criterion) => {\n        console.log('Criterion:', criterion);\n        if (criterion.type === SearchCriteriaTypeEnum.DATERANGE) {\n          const [startDate, endDate] = criterion.value || [\n            undefined,\n            undefined,\n          ];\n          const itemDate = this.parseDate(item[criterion.code] || item['date']);\n          console.log(\n            'Item Date:',\n            itemDate,\n            'Start Date:',\n            startDate,\n            'End Date:',\n            endDate\n          );\n          if (!startDate && !endDate) {\n            return true;\n          }\n          if (itemDate === null) {\n            return false;\n          }\n          const parsedStartDate = startDate ? this.parseDate(startDate) : null;\n          const parsedEndDate = endDate ? this.parseDate(endDate) : null;\n          console.log(\n            'Parsed Start Date:',\n            parsedStartDate,\n            'Parsed End Date:',\n            parsedEndDate\n          );\n          return (\n            (!parsedStartDate || itemDate >= parsedStartDate) &&\n            (!parsedEndDate || itemDate <= parsedEndDate)\n          );\n        } else if (criterion.type === SearchCriteriaTypeEnum.AMOUNT) {\n          return !criterion.value || item[criterion.code] === criterion.value;\n        } else if (criterion.type === SearchCriteriaTypeEnum.MULTISELECT) {\n          return (\n            !criterion.value ||\n            criterion.value.some(\n              (option: FilterOption) => option.label === item[criterion.code]\n            )\n          );\n        } else if (criterion.type === SearchCriteriaTypeEnum.STRING) {\n          return (\n            !criterion.value ||\n            item[criterion.code]\n              .toString()\n              .toLowerCase()\n              .includes(criterion.value.toString().toLowerCase())\n          );\n        }\n        return true;\n      });\n    });\n    console.log('Filtered Data:', filtered);\n    this.filteredData.emit(filtered);\n  }\n\n  clear(): void {\n    this.criteria.forEach((input) => {\n      input.value = null;\n    });\n    this.filteredData.emit(this.data);\n  }\n\n  onSelectAllChange(event: any) {\n    this.selectAll = event.checked;\n    this.selected = event.checked\n      ? [\n          ...(this.criteria.find(\n            (criterion) => criterion.type === SearchCriteriaTypeEnum.MULTISELECT\n          )?.filterOptions || []),\n        ]\n      : [];\n  }\n\n  private parseDate(dateString: string | Date | null | undefined): Date | null {\n    if (!dateString) {\n      return null;\n    }\n\n    if (Object.prototype.toString.call(dateString) === '[object Date]') {\n      return dateString as Date;\n    }\n\n    const parts = (dateString as string).split('/');\n    if (parts.length === 3) {\n      const day = parseInt(parts[0], 10);\n      const month = parseInt(parts[1], 10) - 1;\n      const year = parseInt(parts[2], 10);\n      const date = new Date(year, month, day);\n      return isNaN(date.getTime()) ? null : date;\n    }\n    return null;\n  }\n}\n","<p-panel header=\"{{ title }}\" [toggleable]=\"true\" [collapsed]=\"true\">\n  <div\n    class=\"criteria-container\"\n    [ngStyle]=\"{ 'grid-template-columns': 'repeat(' + inputsPerRow + ', 1fr)' }\"\n  >\n    <div *ngFor=\"let input of criteria\" class=\"criteria-item\">\n      <label class=\"bsc-label\">{{ input.title }}</label>\n\n      <ng-container [ngSwitch]=\"input.type\">\n        <p-calendar\n          *ngSwitchCase=\"SearchCriteriaTypeEnum.DATERANGE\"\n          [(ngModel)]=\"input.value\"\n          selectionMode=\"range\"\n          [dateFormat]=\"'dd/mm/yy'\"\n          class=\"full-width-input\"\n          [showIcon]=\"true\"\n          (ngModelChange)=\"input.value = $event\"\n        ></p-calendar>\n        <p-calendar\n          *ngSwitchCase=\"SearchCriteriaTypeEnum.DATE\"\n          [ngModel]=\"input.value\"\n          (ngModelChange)=\"input.value = $event\"\n          [dateFormat]=\"'dd/mm/yy'\"\n          [showIcon]=\"true\"\n          class=\"full-width-input\"\n        ></p-calendar>\n        <input\n          *ngSwitchCase=\"SearchCriteriaTypeEnum.STRING\"\n          type=\"text\"\n          pInputText\n          [(ngModel)]=\"input.value\"\n          class=\"full-width-input\"\n        />\n\n        <p-inputNumber\n          *ngSwitchCase=\"SearchCriteriaTypeEnum.AMOUNT\"\n          type=\"number\"\n          [(ngModel)]=\"input.value\"\n          mode=\"decimal\"\n          inputId=\"minmaxfraction\"\n          [minFractionDigits]=\"2\"\n          [maxFractionDigits]=\"5\"\n          [placeholder]=\"getCurrencySymbol(input)\"\n          class=\"full-width-input\"\n        ></p-inputNumber>\n\n        <p-inputNumber\n          *ngSwitchCase=\"SearchCriteriaTypeEnum.NUMBER\"\n          type=\"number\"\n          [(ngModel)]=\"input.value\"\n          class=\"full-width-input\"\n        ></p-inputNumber>\n\n        <p-multiSelect\n          *ngSwitchCase=\"SearchCriteriaTypeEnum.MULTISELECT\"\n          [options]=\"input.filterOptions\"\n          [display]=\"'chip'\"\n          placeholder=\"Select\"\n          [selectAll]=\"selectAll\"\n          [(ngModel)]=\"input.value\"\n          optionLabel=\"label\"\n          (onSelectAllChange)=\"onSelectAllChange($event)\"\n          class=\"custom-multiselect full-width-input\"\n        ></p-multiSelect>\n      </ng-container>\n    </div>\n  </div>\n\n  <ng-template pTemplate=\"footer\">\n    <div class=\"footer-buttons\">\n      <p-button\n        label=\"Effacer\"\n        icon=\"pi pi-times\"\n        (click)=\"clear()\"\n        class=\"footer-button\"\n      ></p-button>\n      <p-button\n        label=\"Rechercher\"\n        icon=\"pi pi-search\"\n        (click)=\"search()\"\n        class=\"footer-button\"\n      ></p-button>\n    </div>\n  </ng-template>\n</p-panel>\n"]}
|
138
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"multi-search-criteria.component.js","sourceRoot":"","sources":["../../../../../projects/ng-prime-tools/src/lib/multi-search-criteria/multi-search-criteria.component.ts","../../../../../projects/ng-prime-tools/src/lib/multi-search-criteria/multi-search-criteria.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, Output, EventEmitter, OnInit } from '@angular/core';\nimport { SearchCriteriaTypeEnum } from '../enums';\nimport { SearchCriteria } from '../models/search-criteria';\nimport { FilterOption } from '../models/filter-option';\n\n@Component({\n  selector: 'multi-search-criteria',\n  templateUrl: './multi-search-criteria.component.html',\n  styleUrls: ['./multi-search-criteria.component.css'],\n})\nexport class MultiSearchCriteriaComponent implements OnInit {\n  SearchCriteriaTypeEnum = SearchCriteriaTypeEnum;\n\n  @Input() title: String = '';\n  @Input() criteria: SearchCriteria[] = [];\n  @Input() inputsPerRow: number = 3;\n  @Input() data: any[] = [];\n  @Input() mode: 'static' | 'dynamic' = 'static'; // Add mode input\n  @Output() filteredData = new EventEmitter<any[]>();\n  @Output() searchCriteria = new EventEmitter<{ [key: string]: any }>();\n\n  selectAll: boolean = false;\n  selected: FilterOption[] = [];\n\n  ngOnInit() {\n    this.criteria.forEach((item) => {\n      if (\n        item.type === SearchCriteriaTypeEnum.MULTISELECT &&\n        item.filterOptions\n      ) {\n        this.selected = [...item.filterOptions];\n        item.value = this.selected;\n      }\n    });\n  }\n\n  getCurrencySymbol(input: SearchCriteria): string {\n    return input.currency || 'EUR';\n  }\n\n  search(): void {\n    if (this.mode === 'dynamic') {\n      const criteriaValues: { [key: string]: any } = {};\n      this.criteria.forEach((criterion) => {\n        if (criterion.value !== null && criterion.value !== undefined) {\n          criteriaValues[criterion.code] = criterion.value;\n        }\n      });\n      this.searchCriteria.emit(criteriaValues);\n    } else {\n      const filtered = this.data.filter((item) => {\n        return this.criteria.every((criterion) => {\n          if (criterion.type === SearchCriteriaTypeEnum.DATERANGE) {\n            const [startDate, endDate] = criterion.value || [\n              undefined,\n              undefined,\n            ];\n            const itemDate = this.parseDate(\n              item[criterion.code] || item['date']\n            );\n            if (!startDate && !endDate) {\n              return true;\n            }\n            if (itemDate === null) {\n              return false;\n            }\n            const parsedStartDate = startDate\n              ? this.parseDate(startDate)\n              : null;\n            const parsedEndDate = endDate ? this.parseDate(endDate) : null;\n            return (\n              (!parsedStartDate || itemDate >= parsedStartDate) &&\n              (!parsedEndDate || itemDate <= parsedEndDate)\n            );\n          } else if (criterion.type === SearchCriteriaTypeEnum.AMOUNT) {\n            return !criterion.value || item[criterion.code] === criterion.value;\n          } else if (criterion.type === SearchCriteriaTypeEnum.MULTISELECT) {\n            return (\n              !criterion.value ||\n              criterion.value.some(\n                (option: FilterOption) => option.label === item[criterion.code]\n              )\n            );\n          } else if (criterion.type === SearchCriteriaTypeEnum.STRING) {\n            return (\n              !criterion.value ||\n              item[criterion.code]\n                .toString()\n                .toLowerCase()\n                .includes(criterion.value.toString().toLowerCase())\n            );\n          }\n          return true;\n        });\n      });\n      this.filteredData.emit(filtered);\n    }\n  }\n\n  clear(): void {\n    this.criteria.forEach((input) => {\n      input.value = null;\n    });\n    this.filteredData.emit(this.data);\n  }\n\n  onSelectAllChange(event: any, criterion: SearchCriteria) {\n    this.selectAll = event.checked;\n    criterion.value = event.checked ? [...(criterion.filterOptions ?? [])] : [];\n  }\n\n  private parseDate(dateString: string | Date | null | undefined): Date | null {\n    if (!dateString) {\n      return null;\n    }\n\n    if (Object.prototype.toString.call(dateString) === '[object Date]') {\n      return dateString as Date;\n    }\n\n    const parts = (dateString as string).split('/');\n    if (parts.length === 3) {\n      const day = parseInt(parts[0], 10);\n      const month = parseInt(parts[1], 10) - 1;\n      const year = parseInt(parts[2], 10);\n      const date = new Date(year, month, day);\n      return isNaN(date.getTime()) ? null : date;\n    }\n    return null;\n  }\n}\n","<p-panel header=\"{{ title }}\" [toggleable]=\"true\" [collapsed]=\"true\">\n  <div\n    class=\"criteria-container\"\n    [ngStyle]=\"{ 'grid-template-columns': 'repeat(' + inputsPerRow + ', 1fr)' }\"\n  >\n    <div *ngFor=\"let input of criteria\" class=\"criteria-item\">\n      <label class=\"bsc-label\">{{ input.title }}</label>\n\n      <ng-container [ngSwitch]=\"input.type\">\n        <p-calendar\n          *ngSwitchCase=\"SearchCriteriaTypeEnum.DATERANGE\"\n          [(ngModel)]=\"input.value\"\n          selectionMode=\"range\"\n          [dateFormat]=\"'dd/mm/yy'\"\n          class=\"full-width-input\"\n          [showIcon]=\"true\"\n          (ngModelChange)=\"input.value = $event\"\n        ></p-calendar>\n        <p-calendar\n          *ngSwitchCase=\"SearchCriteriaTypeEnum.DATE\"\n          [ngModel]=\"input.value\"\n          (ngModelChange)=\"input.value = $event\"\n          [dateFormat]=\"'dd/mm/yy'\"\n          [showIcon]=\"true\"\n          class=\"full-width-input\"\n        ></p-calendar>\n        <input\n          *ngSwitchCase=\"SearchCriteriaTypeEnum.STRING\"\n          type=\"text\"\n          pInputText\n          [(ngModel)]=\"input.value\"\n          class=\"full-width-input\"\n        />\n\n        <p-inputNumber\n          *ngSwitchCase=\"SearchCriteriaTypeEnum.AMOUNT\"\n          type=\"number\"\n          [(ngModel)]=\"input.value\"\n          mode=\"decimal\"\n          inputId=\"minmaxfraction\"\n          [minFractionDigits]=\"2\"\n          [maxFractionDigits]=\"5\"\n          [placeholder]=\"getCurrencySymbol(input)\"\n          class=\"full-width-input\"\n        ></p-inputNumber>\n\n        <p-inputNumber\n          *ngSwitchCase=\"SearchCriteriaTypeEnum.NUMBER\"\n          type=\"number\"\n          [(ngModel)]=\"input.value\"\n          class=\"full-width-input\"\n        ></p-inputNumber>\n\n        <p-multiSelect\n          *ngSwitchCase=\"SearchCriteriaTypeEnum.MULTISELECT\"\n          [options]=\"input.filterOptions\"\n          [display]=\"'chip'\"\n          placeholder=\"Select\"\n          [selectAll]=\"selectAll\"\n          [(ngModel)]=\"input.value\"\n          optionLabel=\"label\"\n          (onSelectAllChange)=\"onSelectAllChange($event, input)\"\n          class=\"custom-multiselect full-width-input\"\n        ></p-multiSelect>\n      </ng-container>\n    </div>\n  </div>\n\n  <ng-template pTemplate=\"footer\">\n    <div class=\"footer-buttons\">\n      <p-button\n        label=\"Effacer\"\n        icon=\"pi pi-times\"\n        (click)=\"clear()\"\n        class=\"footer-button\"\n      ></p-button>\n      <p-button\n        label=\"Rechercher\"\n        icon=\"pi pi-search\"\n        (click)=\"search()\"\n        class=\"footer-button\"\n      ></p-button>\n    </div>\n  </ng-template>\n</p-panel>\n"]}
|