ng-prime-tools 1.0.3 → 1.0.4
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 +185 -13
- package/esm2022/lib/enums/public_api.mjs +2 -1
- package/esm2022/lib/enums/search-criteria-type-enum.mjs +10 -0
- package/esm2022/lib/models/filter-option.mjs +2 -0
- package/esm2022/lib/models/public_api.mjs +3 -1
- package/esm2022/lib/models/search-criteria.mjs +2 -0
- package/esm2022/lib/multi-search-criteria/index.mjs +6 -0
- package/esm2022/lib/multi-search-criteria/multi-search-criteria.component.mjs +128 -0
- package/esm2022/lib/multi-search-criteria/multi-search-criteria.module.mjs +48 -0
- package/esm2022/lib/multi-search-criteria/public_api.mjs +4 -0
- package/esm2022/lib/ng-advanced-prime-table/index.mjs +2 -2
- package/esm2022/lib/ng-advanced-prime-table/ng-advanced-prime-table.component.mjs +4 -3
- package/esm2022/lib/ng-advanced-prime-table/ng-advanced-prime-table.module.mjs +4 -3
- package/esm2022/lib/ng-prime-tools.module.mjs +30 -0
- package/esm2022/lib/pipes/custom-date.pipe.mjs +44 -0
- package/esm2022/public-api.mjs +3 -1
- package/fesm2022/ng-prime-tools.mjs +253 -13
- package/fesm2022/ng-prime-tools.mjs.map +1 -1
- package/lib/enums/public_api.d.ts +1 -0
- package/lib/enums/public_api.d.ts.map +1 -1
- package/lib/enums/search-criteria-type-enum.d.ts +9 -0
- package/lib/enums/search-criteria-type-enum.d.ts.map +1 -0
- package/lib/models/filter-option.d.ts +5 -0
- package/lib/models/filter-option.d.ts.map +1 -0
- package/lib/models/public_api.d.ts +2 -0
- package/lib/models/public_api.d.ts.map +1 -1
- package/lib/models/search-criteria.d.ts +11 -0
- package/lib/models/search-criteria.d.ts.map +1 -0
- package/lib/multi-search-criteria/index.d.ts +6 -0
- package/lib/multi-search-criteria/index.d.ts.map +1 -0
- package/lib/multi-search-criteria/multi-search-criteria.component.d.ts +24 -0
- package/lib/multi-search-criteria/multi-search-criteria.component.d.ts.map +1 -0
- package/lib/multi-search-criteria/multi-search-criteria.module.d.ts +16 -0
- package/lib/multi-search-criteria/multi-search-criteria.module.d.ts.map +1 -0
- package/lib/multi-search-criteria/public_api.d.ts +3 -0
- package/lib/multi-search-criteria/public_api.d.ts.map +1 -0
- package/lib/ng-advanced-prime-table/index.d.ts +1 -1
- package/lib/ng-advanced-prime-table/ng-advanced-prime-table.module.d.ts +13 -12
- package/lib/ng-advanced-prime-table/ng-advanced-prime-table.module.d.ts.map +1 -1
- package/lib/ng-prime-tools.module.d.ts +11 -0
- package/lib/ng-prime-tools.module.d.ts.map +1 -0
- package/lib/pipes/custom-date.pipe.d.ts +8 -0
- package/lib/pipes/custom-date.pipe.d.ts.map +1 -0
- package/package.json +3 -3
- package/public-api.d.ts +2 -0
- package/public-api.d.ts.map +1 -1
package/README.md
CHANGED
@@ -1,25 +1,197 @@
|
|
1
|
-
#
|
1
|
+
# NG Prime Tools
|
2
2
|
|
3
|
-
|
3
|
+
An advanced PrimeNG tools library for Angular.
|
4
4
|
|
5
|
-
##
|
5
|
+
## Table of Contents
|
6
6
|
|
7
|
-
|
7
|
+
- [Introduction](#introduction)
|
8
|
+
- [Installation](#installation)
|
9
|
+
- [Compatibility](#compatibility)
|
10
|
+
- [Usage](#usage)
|
11
|
+
- [ng-advanced-prime-table](#ng-advanced-prime-table)
|
12
|
+
- [Inputs](#inputs)
|
13
|
+
- [Outputs](#outputs)
|
14
|
+
- [Example](#example)
|
15
|
+
- [Changelog](#changelog)
|
16
|
+
- [License](#license)
|
8
17
|
|
9
|
-
|
18
|
+
## Introduction
|
10
19
|
|
11
|
-
|
20
|
+
`ng-prime-tools` is a collection of advanced tools built on top of PrimeNG for Angular applications.
|
12
21
|
|
13
|
-
|
22
|
+
## Installation
|
14
23
|
|
15
|
-
|
24
|
+
To install `ng-prime-tools`, use the following command:
|
16
25
|
|
17
|
-
|
26
|
+
```bash
|
27
|
+
npm install ng-prime-tools
|
28
|
+
```
|
18
29
|
|
19
|
-
##
|
30
|
+
## Compatibility
|
20
31
|
|
21
|
-
|
32
|
+
- **Angular Version**: 17.3.1 or higher
|
33
|
+
- **PrimeNG Version**: 17.18.0 or higher
|
22
34
|
|
23
|
-
##
|
35
|
+
## Usage
|
24
36
|
|
25
|
-
|
37
|
+
### ng-advanced-prime-table
|
38
|
+
|
39
|
+
To use the `ng-advanced-prime-table` component, follow these steps:
|
40
|
+
|
41
|
+
1. **Import the Module:**
|
42
|
+
|
43
|
+
Import the `NgAdvancedPrimeTableModule` in your Angular module or standalone component.
|
44
|
+
|
45
|
+
```typescript
|
46
|
+
import { NgAdvancedPrimeTableModule, TableColumn, TableTypeEnum } from "ng-prime-tools";
|
47
|
+
```
|
48
|
+
|
49
|
+
2. **Add the Component:**
|
50
|
+
|
51
|
+
Add the `ng-advanced-prime-table` component to your template:
|
52
|
+
|
53
|
+
```html
|
54
|
+
<ng-advanced-prime-table [columns]="columns" [data]="data" [hasSearchFilter]="true" [hasColumnFilter]="true" [isPaginated]="true" [totalRecords]="totalRecords" [isSortable]="true"></ng-advanced-prime-table>
|
55
|
+
```
|
56
|
+
|
57
|
+
3. **Define the Inputs:**
|
58
|
+
|
59
|
+
In your component, define the necessary inputs for the table:
|
60
|
+
|
61
|
+
```typescript
|
62
|
+
import { Component, OnInit } from "@angular/core";
|
63
|
+
import { NgAdvancedPrimeTableModule } from "ng-prime-tools/ng-advanced-prime-table";
|
64
|
+
import { TableColumn } from "ng-prime-tools/models";
|
65
|
+
import { TableTypeEnum } from "ng-prime-tools/enums";
|
66
|
+
|
67
|
+
@Component({
|
68
|
+
selector: "app-root",
|
69
|
+
standalone: true,
|
70
|
+
imports: [NgAdvancedPrimeTableModule],
|
71
|
+
templateUrl: "./app.component.html",
|
72
|
+
styleUrls: ["./app.component.css"],
|
73
|
+
})
|
74
|
+
export class AppComponent implements OnInit {
|
75
|
+
columns: TableColumn[] = [];
|
76
|
+
data: any[] = [];
|
77
|
+
totalRecords: number = 0;
|
78
|
+
|
79
|
+
ngOnInit(): void {
|
80
|
+
this.columns = [
|
81
|
+
{
|
82
|
+
title: "Name",
|
83
|
+
code: "name",
|
84
|
+
type: TableTypeEnum.STRING,
|
85
|
+
isEditable: true,
|
86
|
+
},
|
87
|
+
{
|
88
|
+
title: "Date",
|
89
|
+
code: "date",
|
90
|
+
type: TableTypeEnum.DATE,
|
91
|
+
isEditable: true,
|
92
|
+
},
|
93
|
+
{
|
94
|
+
title: "Amount",
|
95
|
+
code: "amount",
|
96
|
+
type: TableTypeEnum.AMOUNT,
|
97
|
+
currency: "USD",
|
98
|
+
isEditable: true,
|
99
|
+
},
|
100
|
+
];
|
101
|
+
|
102
|
+
this.data = [
|
103
|
+
{ name: "John Doe", date: "11/06/2024", amount: 100 },
|
104
|
+
{ name: "Jane Doe", date: "20/06/2024", amount: 200 },
|
105
|
+
];
|
106
|
+
|
107
|
+
this.totalRecords = this.data.length;
|
108
|
+
}
|
109
|
+
}
|
110
|
+
```
|
111
|
+
|
112
|
+
### Inputs
|
113
|
+
|
114
|
+
- **data** (`any[]`): The data to be displayed in the table.
|
115
|
+
- **columns** (`TableColumn[]`): The columns configuration for the table.
|
116
|
+
- **totalRecords** (`number`): The total number of records.
|
117
|
+
- **rowsPerPage** (`number[]`): The number of rows per page options for pagination.
|
118
|
+
- **hasSearchFilter** (`boolean`): Whether the table has a global search filter.
|
119
|
+
- **hasColumnFilter** (`boolean`): Whether the table has column-specific filters.
|
120
|
+
- **isPaginated** (`boolean`): Whether the table is paginated.
|
121
|
+
- **actions** (`any[]`): The actions available for the table rows.
|
122
|
+
- **isSortable** (`boolean`): Whether the table columns are sortable.
|
123
|
+
|
124
|
+
### Outputs
|
125
|
+
|
126
|
+
- **filter** (`EventEmitter`): Emitted when the table is filtered.
|
127
|
+
- **search** (`EventEmitter<any>`): Emitted when a global search is performed.
|
128
|
+
|
129
|
+
### Example
|
130
|
+
|
131
|
+
Here's a complete example of how to use the `ng-advanced-prime-table` component:
|
132
|
+
|
133
|
+
```typescript
|
134
|
+
import { Component, OnInit } from "@angular/core";
|
135
|
+
import { CommonModule } from "@angular/common";
|
136
|
+
import { NgAdvancedPrimeTableModule } from "ng-prime-tools/ng-advanced-prime-table";
|
137
|
+
import { TableColumn } from "ng-prime-tools/models";
|
138
|
+
import { TableTypeEnum } from "ng-prime-tools/enums";
|
139
|
+
|
140
|
+
@Component({
|
141
|
+
selector: "app-root",
|
142
|
+
standalone: true,
|
143
|
+
imports: [CommonModule, NgAdvancedPrimeTableModule],
|
144
|
+
templateUrl: "./app.component.html",
|
145
|
+
styleUrls: ["./app.component.css"],
|
146
|
+
})
|
147
|
+
export class AppComponent implements OnInit {
|
148
|
+
columns: TableColumn[] = [];
|
149
|
+
data: any[] = [];
|
150
|
+
totalRecords: number = 0;
|
151
|
+
|
152
|
+
ngOnInit(): void {
|
153
|
+
this.columns = [
|
154
|
+
{
|
155
|
+
title: "Name",
|
156
|
+
code: "name",
|
157
|
+
type: TableTypeEnum.STRING,
|
158
|
+
isEditable: true,
|
159
|
+
},
|
160
|
+
{
|
161
|
+
title: "Date",
|
162
|
+
code: "date",
|
163
|
+
type: TableTypeEnum.DATE,
|
164
|
+
isEditable: true,
|
165
|
+
},
|
166
|
+
{
|
167
|
+
title: "Amount",
|
168
|
+
code: "amount",
|
169
|
+
type: TableTypeEnum.AMOUNT,
|
170
|
+
currency: "USD",
|
171
|
+
isEditable: true,
|
172
|
+
},
|
173
|
+
];
|
174
|
+
|
175
|
+
this.data = [
|
176
|
+
{ name: "ZAK JAAI", date: "11/06/2024", amount: 100 },
|
177
|
+
{ name: "ZAK2 JAAI", date: "20/06/2024", amount: 200 },
|
178
|
+
];
|
179
|
+
|
180
|
+
this.totalRecords = this.data.length;
|
181
|
+
}
|
182
|
+
}
|
183
|
+
```
|
184
|
+
|
185
|
+
```html
|
186
|
+
<ng-advanced-prime-table [columns]="columns" [data]="data" [hasSearchFilter]="true" [hasColumnFilter]="true" [isPaginated]="true" [totalRecords]="totalRecords" [isSortable]="true"></ng-advanced-prime-table>
|
187
|
+
```
|
188
|
+
|
189
|
+
## Changelog
|
190
|
+
|
191
|
+
### Version 1.0.3
|
192
|
+
|
193
|
+
- Initial release with `ng-advanced-prime-table` component.
|
194
|
+
|
195
|
+
## License
|
196
|
+
|
197
|
+
This project is licensed under the MIT License.
|
@@ -1,3 +1,4 @@
|
|
1
1
|
// projects/ng-prime-tools/src/lib/enums/public_api.ts
|
2
2
|
export * from './table-type-enum';
|
3
|
-
|
3
|
+
export * from './search-criteria-type-enum';
|
4
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljX2FwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25nLXByaW1lLXRvb2xzL3NyYy9saWIvZW51bXMvcHVibGljX2FwaS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxzREFBc0Q7QUFDdEQsY0FBYyxtQkFBbUIsQ0FBQztBQUNsQyxjQUFjLDZCQUE2QixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLy8gcHJvamVjdHMvbmctcHJpbWUtdG9vbHMvc3JjL2xpYi9lbnVtcy9wdWJsaWNfYXBpLnRzXG5leHBvcnQgKiBmcm9tICcuL3RhYmxlLXR5cGUtZW51bSc7XG5leHBvcnQgKiBmcm9tICcuL3NlYXJjaC1jcml0ZXJpYS10eXBlLWVudW0nO1xuIl19
|
@@ -0,0 +1,10 @@
|
|
1
|
+
export var SearchCriteriaTypeEnum;
|
2
|
+
(function (SearchCriteriaTypeEnum) {
|
3
|
+
SearchCriteriaTypeEnum["DATE"] = "DATE";
|
4
|
+
SearchCriteriaTypeEnum["DATERANGE"] = "DATERANGE";
|
5
|
+
SearchCriteriaTypeEnum["STRING"] = "STRING";
|
6
|
+
SearchCriteriaTypeEnum["AMOUNT"] = "AMOUNT";
|
7
|
+
SearchCriteriaTypeEnum["NUMBER"] = "NUMBER";
|
8
|
+
SearchCriteriaTypeEnum["MULTISELECT"] = "MULTISELECT";
|
9
|
+
})(SearchCriteriaTypeEnum || (SearchCriteriaTypeEnum = {}));
|
10
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2VhcmNoLWNyaXRlcmlhLXR5cGUtZW51bS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25nLXByaW1lLXRvb2xzL3NyYy9saWIvZW51bXMvc2VhcmNoLWNyaXRlcmlhLXR5cGUtZW51bS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxNQUFNLENBQU4sSUFBWSxzQkFPWDtBQVBELFdBQVksc0JBQXNCO0lBQ2hDLHVDQUFhLENBQUE7SUFDYixpREFBdUIsQ0FBQTtJQUN2QiwyQ0FBaUIsQ0FBQTtJQUNqQiwyQ0FBaUIsQ0FBQTtJQUNqQiwyQ0FBaUIsQ0FBQTtJQUNqQixxREFBMkIsQ0FBQTtBQUM3QixDQUFDLEVBUFcsc0JBQXNCLEtBQXRCLHNCQUFzQixRQU9qQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBlbnVtIFNlYXJjaENyaXRlcmlhVHlwZUVudW0ge1xuICBEQVRFID0gJ0RBVEUnLFxuICBEQVRFUkFOR0UgPSAnREFURVJBTkdFJyxcbiAgU1RSSU5HID0gJ1NUUklORycsXG4gIEFNT1VOVCA9ICdBTU9VTlQnLFxuICBOVU1CRVIgPSAnTlVNQkVSJyxcbiAgTVVMVElTRUxFQ1QgPSAnTVVMVElTRUxFQ1QnLFxufVxuIl19
|
@@ -0,0 +1,2 @@
|
|
1
|
+
export {};
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmlsdGVyLW9wdGlvbi5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25nLXByaW1lLXRvb2xzL3NyYy9saWIvbW9kZWxzL2ZpbHRlci1vcHRpb24udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBpbnRlcmZhY2UgRmlsdGVyT3B0aW9uIHtcbiAgbGFiZWw6IHN0cmluZztcbiAgdmFsdWU6IHN0cmluZztcbn1cbiJdfQ==
|
@@ -1,3 +1,5 @@
|
|
1
1
|
// projects/ng-prime-tools/src/lib/models/public_api.ts
|
2
2
|
export * from './table-column';
|
3
|
-
|
3
|
+
export * from './search-criteria';
|
4
|
+
export * from './filter-option';
|
5
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljX2FwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25nLXByaW1lLXRvb2xzL3NyYy9saWIvbW9kZWxzL3B1YmxpY19hcGkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsdURBQXVEO0FBQ3ZELGNBQWMsZ0JBQWdCLENBQUM7QUFDL0IsY0FBYyxtQkFBbUIsQ0FBQztBQUNsQyxjQUFjLGlCQUFpQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLy8gcHJvamVjdHMvbmctcHJpbWUtdG9vbHMvc3JjL2xpYi9tb2RlbHMvcHVibGljX2FwaS50c1xuZXhwb3J0ICogZnJvbSAnLi90YWJsZS1jb2x1bW4nO1xuZXhwb3J0ICogZnJvbSAnLi9zZWFyY2gtY3JpdGVyaWEnO1xuZXhwb3J0ICogZnJvbSAnLi9maWx0ZXItb3B0aW9uJztcbiJdfQ==
|
@@ -0,0 +1,2 @@
|
|
1
|
+
export {};
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2VhcmNoLWNyaXRlcmlhLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmctcHJpbWUtdG9vbHMvc3JjL2xpYi9tb2RlbHMvc2VhcmNoLWNyaXRlcmlhLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBTZWFyY2hDcml0ZXJpYVR5cGVFbnVtIH0gZnJvbSAnLi4vZW51bXMvc2VhcmNoLWNyaXRlcmlhLXR5cGUtZW51bSc7XG5pbXBvcnQgeyBGaWx0ZXJPcHRpb24gfSBmcm9tICcuL2ZpbHRlci1vcHRpb24nO1xuXG5leHBvcnQgaW50ZXJmYWNlIFNlYXJjaENyaXRlcmlhIHtcbiAgdGl0bGU6IHN0cmluZztcbiAgY29kZTogc3RyaW5nO1xuICB0eXBlOiBTZWFyY2hDcml0ZXJpYVR5cGVFbnVtO1xuICB2YWx1ZT86IGFueTtcbiAgZmlsdGVyT3B0aW9ucz86IEZpbHRlck9wdGlvbltdO1xuICBjdXJyZW5jeT86IHN0cmluZztcbn1cbiJdfQ==
|
@@ -0,0 +1,6 @@
|
|
1
|
+
/**
|
2
|
+
* Generated bundle index. Do not edit.
|
3
|
+
*/
|
4
|
+
/// <amd-module name="ng-prime-tools/multi-search-criteria" />
|
5
|
+
export * from './public_api';
|
6
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZy1wcmltZS10b29scy9zcmMvbGliL211bHRpLXNlYXJjaC1jcml0ZXJpYS9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7R0FFRztBQUNILDhEQUE4RDtBQUM5RCxjQUFjLGNBQWMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogR2VuZXJhdGVkIGJ1bmRsZSBpbmRleC4gRG8gbm90IGVkaXQuXG4gKi9cbi8vLyA8YW1kLW1vZHVsZSBuYW1lPVwibmctcHJpbWUtdG9vbHMvbXVsdGktc2VhcmNoLWNyaXRlcmlhXCIgLz5cbmV4cG9ydCAqIGZyb20gJy4vcHVibGljX2FwaSc7XG4iXX0=
|
@@ -0,0 +1,128 @@
|
|
1
|
+
import { Component, Input, Output, EventEmitter } from '@angular/core';
|
2
|
+
import { SearchCriteriaTypeEnum } from '../enums';
|
3
|
+
import * as i0 from "@angular/core";
|
4
|
+
import * as i1 from "@angular/common";
|
5
|
+
import * as i2 from "primeng/calendar";
|
6
|
+
import * as i3 from "primeng/button";
|
7
|
+
import * as i4 from "primeng/api";
|
8
|
+
import * as i5 from "primeng/inputtext";
|
9
|
+
import * as i6 from "primeng/multiselect";
|
10
|
+
import * as i7 from "@angular/forms";
|
11
|
+
import * as i8 from "primeng/inputnumber";
|
12
|
+
import * as i9 from "primeng/panel";
|
13
|
+
export class MultiSearchCriteriaComponent {
|
14
|
+
constructor() {
|
15
|
+
this.SearchCriteriaTypeEnum = SearchCriteriaTypeEnum;
|
16
|
+
this.title = '';
|
17
|
+
this.criteria = [];
|
18
|
+
this.inputsPerRow = 3;
|
19
|
+
this.data = [];
|
20
|
+
this.filteredData = new EventEmitter();
|
21
|
+
this.selectAll = false;
|
22
|
+
this.selected = [];
|
23
|
+
}
|
24
|
+
ngOnInit() {
|
25
|
+
this.criteria.forEach((item) => {
|
26
|
+
if (item.type === SearchCriteriaTypeEnum.MULTISELECT &&
|
27
|
+
item.filterOptions) {
|
28
|
+
this.selected = [...item.filterOptions];
|
29
|
+
item.value = this.selected;
|
30
|
+
}
|
31
|
+
});
|
32
|
+
}
|
33
|
+
getCurrencySymbol(input) {
|
34
|
+
return input.currency || 'EUR';
|
35
|
+
}
|
36
|
+
search() {
|
37
|
+
console.log('Original Data:', this.data);
|
38
|
+
const filtered = this.data.filter((item) => {
|
39
|
+
return this.criteria.every((criterion) => {
|
40
|
+
console.log('Criterion:', criterion);
|
41
|
+
if (criterion.type === SearchCriteriaTypeEnum.DATERANGE) {
|
42
|
+
const [startDate, endDate] = criterion.value || [
|
43
|
+
undefined,
|
44
|
+
undefined,
|
45
|
+
];
|
46
|
+
const itemDate = this.parseDate(item[criterion.code] || item['date']);
|
47
|
+
console.log('Item Date:', itemDate, 'Start Date:', startDate, 'End Date:', endDate);
|
48
|
+
if (!startDate && !endDate) {
|
49
|
+
return true;
|
50
|
+
}
|
51
|
+
if (itemDate === null) {
|
52
|
+
return false;
|
53
|
+
}
|
54
|
+
const parsedStartDate = startDate ? this.parseDate(startDate) : null;
|
55
|
+
const parsedEndDate = endDate ? this.parseDate(endDate) : null;
|
56
|
+
console.log('Parsed Start Date:', parsedStartDate, 'Parsed End Date:', parsedEndDate);
|
57
|
+
return ((!parsedStartDate || itemDate >= parsedStartDate) &&
|
58
|
+
(!parsedEndDate || itemDate <= parsedEndDate));
|
59
|
+
}
|
60
|
+
else if (criterion.type === SearchCriteriaTypeEnum.AMOUNT) {
|
61
|
+
return !criterion.value || item[criterion.code] === criterion.value;
|
62
|
+
}
|
63
|
+
else if (criterion.type === SearchCriteriaTypeEnum.MULTISELECT) {
|
64
|
+
return (!criterion.value ||
|
65
|
+
criterion.value.some((option) => option.label === item[criterion.code]));
|
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;
|
75
|
+
});
|
76
|
+
});
|
77
|
+
console.log('Filtered Data:', filtered);
|
78
|
+
this.filteredData.emit(filtered);
|
79
|
+
}
|
80
|
+
clear() {
|
81
|
+
this.criteria.forEach((input) => {
|
82
|
+
input.value = null;
|
83
|
+
});
|
84
|
+
this.filteredData.emit(this.data);
|
85
|
+
}
|
86
|
+
onSelectAllChange(event) {
|
87
|
+
this.selectAll = event.checked;
|
88
|
+
this.selected = event.checked
|
89
|
+
? [
|
90
|
+
...(this.criteria.find((criterion) => criterion.type === SearchCriteriaTypeEnum.MULTISELECT)?.filterOptions || []),
|
91
|
+
]
|
92
|
+
: [];
|
93
|
+
}
|
94
|
+
parseDate(dateString) {
|
95
|
+
if (!dateString) {
|
96
|
+
return null;
|
97
|
+
}
|
98
|
+
if (Object.prototype.toString.call(dateString) === '[object Date]') {
|
99
|
+
return dateString;
|
100
|
+
}
|
101
|
+
const parts = dateString.split('/');
|
102
|
+
if (parts.length === 3) {
|
103
|
+
const day = parseInt(parts[0], 10);
|
104
|
+
const month = parseInt(parts[1], 10) - 1;
|
105
|
+
const year = parseInt(parts[2], 10);
|
106
|
+
const date = new Date(year, month, day);
|
107
|
+
return isNaN(date.getTime()) ? null : date;
|
108
|
+
}
|
109
|
+
return null;
|
110
|
+
}
|
111
|
+
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"] }] }); }
|
113
|
+
}
|
114
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: MultiSearchCriteriaComponent, decorators: [{
|
115
|
+
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"] }]
|
117
|
+
}], propDecorators: { title: [{
|
118
|
+
type: Input
|
119
|
+
}], criteria: [{
|
120
|
+
type: Input
|
121
|
+
}], inputsPerRow: [{
|
122
|
+
type: Input
|
123
|
+
}], data: [{
|
124
|
+
type: Input
|
125
|
+
}], filteredData: [{
|
126
|
+
type: Output
|
127
|
+
}] } });
|
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"]}
|
@@ -0,0 +1,48 @@
|
|
1
|
+
import { NgModule } from '@angular/core';
|
2
|
+
import { CommonModule } from '@angular/common';
|
3
|
+
import { FormsModule } from '@angular/forms';
|
4
|
+
import { ButtonModule } from 'primeng/button';
|
5
|
+
import { CalendarModule } from 'primeng/calendar';
|
6
|
+
import { InputTextModule } from 'primeng/inputtext';
|
7
|
+
import { MultiSelectModule } from 'primeng/multiselect';
|
8
|
+
import { InputNumberModule } from 'primeng/inputnumber';
|
9
|
+
import { PanelModule } from 'primeng/panel';
|
10
|
+
import { MultiSearchCriteriaComponent } from './multi-search-criteria.component';
|
11
|
+
import * as i0 from "@angular/core";
|
12
|
+
export class MultiSearchCriteriaModule {
|
13
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: MultiSearchCriteriaModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
|
14
|
+
static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "17.3.11", ngImport: i0, type: MultiSearchCriteriaModule, declarations: [MultiSearchCriteriaComponent], imports: [CommonModule,
|
15
|
+
CalendarModule,
|
16
|
+
InputTextModule,
|
17
|
+
MultiSelectModule,
|
18
|
+
ButtonModule,
|
19
|
+
FormsModule,
|
20
|
+
InputNumberModule,
|
21
|
+
PanelModule], exports: [MultiSearchCriteriaComponent] }); }
|
22
|
+
static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: MultiSearchCriteriaModule, imports: [CommonModule,
|
23
|
+
CalendarModule,
|
24
|
+
InputTextModule,
|
25
|
+
MultiSelectModule,
|
26
|
+
ButtonModule,
|
27
|
+
FormsModule,
|
28
|
+
InputNumberModule,
|
29
|
+
PanelModule] }); }
|
30
|
+
}
|
31
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: MultiSearchCriteriaModule, decorators: [{
|
32
|
+
type: NgModule,
|
33
|
+
args: [{
|
34
|
+
declarations: [MultiSearchCriteriaComponent],
|
35
|
+
imports: [
|
36
|
+
CommonModule,
|
37
|
+
CalendarModule,
|
38
|
+
InputTextModule,
|
39
|
+
MultiSelectModule,
|
40
|
+
ButtonModule,
|
41
|
+
FormsModule,
|
42
|
+
InputNumberModule,
|
43
|
+
PanelModule,
|
44
|
+
],
|
45
|
+
exports: [MultiSearchCriteriaComponent],
|
46
|
+
}]
|
47
|
+
}] });
|
48
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibXVsdGktc2VhcmNoLWNyaXRlcmlhLm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25nLXByaW1lLXRvb2xzL3NyYy9saWIvbXVsdGktc2VhcmNoLWNyaXRlcmlhL211bHRpLXNlYXJjaC1jcml0ZXJpYS5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN6QyxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUFFLFdBQVcsRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBQzdDLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQUM5QyxPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0sa0JBQWtCLENBQUM7QUFDbEQsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLG1CQUFtQixDQUFDO0FBQ3BELE9BQU8sRUFBRSxpQkFBaUIsRUFBRSxNQUFNLHFCQUFxQixDQUFDO0FBQ3hELE9BQU8sRUFBRSxpQkFBaUIsRUFBRSxNQUFNLHFCQUFxQixDQUFDO0FBQ3hELE9BQU8sRUFBRSxXQUFXLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDNUMsT0FBTyxFQUFFLDRCQUE0QixFQUFFLE1BQU0sbUNBQW1DLENBQUM7O0FBZ0JqRixNQUFNLE9BQU8seUJBQXlCOytHQUF6Qix5QkFBeUI7Z0hBQXpCLHlCQUF5QixpQkFickIsNEJBQTRCLGFBRXpDLFlBQVk7WUFDWixjQUFjO1lBQ2QsZUFBZTtZQUNmLGlCQUFpQjtZQUNqQixZQUFZO1lBQ1osV0FBVztZQUNYLGlCQUFpQjtZQUNqQixXQUFXLGFBRUgsNEJBQTRCO2dIQUUzQix5QkFBeUIsWUFYbEMsWUFBWTtZQUNaLGNBQWM7WUFDZCxlQUFlO1lBQ2YsaUJBQWlCO1lBQ2pCLFlBQVk7WUFDWixXQUFXO1lBQ1gsaUJBQWlCO1lBQ2pCLFdBQVc7OzRGQUlGLHlCQUF5QjtrQkFkckMsUUFBUTttQkFBQztvQkFDUixZQUFZLEVBQUUsQ0FBQyw0QkFBNEIsQ0FBQztvQkFDNUMsT0FBTyxFQUFFO3dCQUNQLFlBQVk7d0JBQ1osY0FBYzt3QkFDZCxlQUFlO3dCQUNmLGlCQUFpQjt3QkFDakIsWUFBWTt3QkFDWixXQUFXO3dCQUNYLGlCQUFpQjt3QkFDakIsV0FBVztxQkFDWjtvQkFDRCxPQUFPLEVBQUUsQ0FBQyw0QkFBNEIsQ0FBQztpQkFDeEMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBOZ01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcbmltcG9ydCB7IEZvcm1zTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvZm9ybXMnO1xuaW1wb3J0IHsgQnV0dG9uTW9kdWxlIH0gZnJvbSAncHJpbWVuZy9idXR0b24nO1xuaW1wb3J0IHsgQ2FsZW5kYXJNb2R1bGUgfSBmcm9tICdwcmltZW5nL2NhbGVuZGFyJztcbmltcG9ydCB7IElucHV0VGV4dE1vZHVsZSB9IGZyb20gJ3ByaW1lbmcvaW5wdXR0ZXh0JztcbmltcG9ydCB7IE11bHRpU2VsZWN0TW9kdWxlIH0gZnJvbSAncHJpbWVuZy9tdWx0aXNlbGVjdCc7XG5pbXBvcnQgeyBJbnB1dE51bWJlck1vZHVsZSB9IGZyb20gJ3ByaW1lbmcvaW5wdXRudW1iZXInO1xuaW1wb3J0IHsgUGFuZWxNb2R1bGUgfSBmcm9tICdwcmltZW5nL3BhbmVsJztcbmltcG9ydCB7IE11bHRpU2VhcmNoQ3JpdGVyaWFDb21wb25lbnQgfSBmcm9tICcuL211bHRpLXNlYXJjaC1jcml0ZXJpYS5jb21wb25lbnQnO1xuXG5ATmdNb2R1bGUoe1xuICBkZWNsYXJhdGlvbnM6IFtNdWx0aVNlYXJjaENyaXRlcmlhQ29tcG9uZW50XSxcbiAgaW1wb3J0czogW1xuICAgIENvbW1vbk1vZHVsZSxcbiAgICBDYWxlbmRhck1vZHVsZSxcbiAgICBJbnB1dFRleHRNb2R1bGUsXG4gICAgTXVsdGlTZWxlY3RNb2R1bGUsXG4gICAgQnV0dG9uTW9kdWxlLFxuICAgIEZvcm1zTW9kdWxlLFxuICAgIElucHV0TnVtYmVyTW9kdWxlLFxuICAgIFBhbmVsTW9kdWxlLFxuICBdLFxuICBleHBvcnRzOiBbTXVsdGlTZWFyY2hDcml0ZXJpYUNvbXBvbmVudF0sXG59KVxuZXhwb3J0IGNsYXNzIE11bHRpU2VhcmNoQ3JpdGVyaWFNb2R1bGUge31cbiJdfQ==
|
@@ -0,0 +1,4 @@
|
|
1
|
+
// projects/ng-prime-tools/src/lib/ng-advanced-prime-table/index.ts
|
2
|
+
export * from './multi-search-criteria.module';
|
3
|
+
export * from './multi-search-criteria.component';
|
4
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljX2FwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25nLXByaW1lLXRvb2xzL3NyYy9saWIvbXVsdGktc2VhcmNoLWNyaXRlcmlhL3B1YmxpY19hcGkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsbUVBQW1FO0FBQ25FLGNBQWMsZ0NBQWdDLENBQUM7QUFDL0MsY0FBYyxtQ0FBbUMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8vIHByb2plY3RzL25nLXByaW1lLXRvb2xzL3NyYy9saWIvbmctYWR2YW5jZWQtcHJpbWUtdGFibGUvaW5kZXgudHNcbmV4cG9ydCAqIGZyb20gJy4vbXVsdGktc2VhcmNoLWNyaXRlcmlhLm1vZHVsZSc7XG5leHBvcnQgKiBmcm9tICcuL211bHRpLXNlYXJjaC1jcml0ZXJpYS5jb21wb25lbnQnO1xuIl19
|
@@ -1,6 +1,6 @@
|
|
1
1
|
/**
|
2
2
|
* Generated bundle index. Do not edit.
|
3
3
|
*/
|
4
|
-
/// <amd-module name="ng-prime-tools/
|
4
|
+
/// <amd-module name="ng-prime-tools/multi-search-criteria" />
|
5
5
|
export * from './public_api';
|
6
|
-
//# sourceMappingURL=data:application/json;base64,
|
6
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZy1wcmltZS10b29scy9zcmMvbGliL25nLWFkdmFuY2VkLXByaW1lLXRhYmxlL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOztHQUVHO0FBQ0gsOERBQThEO0FBQzlELGNBQWMsY0FBYyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBHZW5lcmF0ZWQgYnVuZGxlIGluZGV4LiBEbyBub3QgZWRpdC5cbiAqL1xuLy8vIDxhbWQtbW9kdWxlIG5hbWU9XCJuZy1wcmltZS10b29scy9tdWx0aS1zZWFyY2gtY3JpdGVyaWFcIiAvPlxuZXhwb3J0ICogZnJvbSAnLi9wdWJsaWNfYXBpJztcbiJdfQ==
|