ng-prime-tools 1.0.3 → 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 +397 -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/models/table-column.mjs +1 -1
- package/esm2022/lib/multi-search-criteria/index.mjs +6 -0
- package/esm2022/lib/multi-search-criteria/multi-search-criteria.component.mjs +138 -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 -11
- 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-currency.mjs +24 -18
- package/esm2022/lib/pipes/custom-date.pipe.mjs +44 -0
- package/esm2022/public-api.mjs +3 -1
- package/fesm2022/ng-prime-tools.mjs +286 -38
- 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/models/table-column.d.ts +2 -0
- package/lib/models/table-column.d.ts.map +1 -1
- 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 +28 -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.component.d.ts +0 -1
- package/lib/ng-advanced-prime-table/ng-advanced-prime-table.component.d.ts.map +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-currency.d.ts +1 -1
- package/lib/pipes/custom-currency.d.ts.map +1 -1
- 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
@@ -0,0 +1,138 @@
|
|
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.mode = 'static'; // Add mode input
|
21
|
+
this.filteredData = new EventEmitter();
|
22
|
+
this.searchCriteria = new EventEmitter();
|
23
|
+
this.selectAll = false;
|
24
|
+
this.selected = [];
|
25
|
+
}
|
26
|
+
ngOnInit() {
|
27
|
+
this.criteria.forEach((item) => {
|
28
|
+
if (item.type === SearchCriteriaTypeEnum.MULTISELECT &&
|
29
|
+
item.filterOptions) {
|
30
|
+
this.selected = [...item.filterOptions];
|
31
|
+
item.value = this.selected;
|
32
|
+
}
|
33
|
+
});
|
34
|
+
}
|
35
|
+
getCurrencySymbol(input) {
|
36
|
+
return input.currency || 'EUR';
|
37
|
+
}
|
38
|
+
search() {
|
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));
|
69
|
+
}
|
70
|
+
else if (criterion.type === SearchCriteriaTypeEnum.AMOUNT) {
|
71
|
+
return !criterion.value || item[criterion.code] === criterion.value;
|
72
|
+
}
|
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
|
+
});
|
86
|
+
});
|
87
|
+
this.filteredData.emit(filtered);
|
88
|
+
}
|
89
|
+
}
|
90
|
+
clear() {
|
91
|
+
this.criteria.forEach((input) => {
|
92
|
+
input.value = null;
|
93
|
+
});
|
94
|
+
this.filteredData.emit(this.data);
|
95
|
+
}
|
96
|
+
onSelectAllChange(event, criterion) {
|
97
|
+
this.selectAll = event.checked;
|
98
|
+
criterion.value = event.checked ? [...(criterion.filterOptions ?? [])] : [];
|
99
|
+
}
|
100
|
+
parseDate(dateString) {
|
101
|
+
if (!dateString) {
|
102
|
+
return null;
|
103
|
+
}
|
104
|
+
if (Object.prototype.toString.call(dateString) === '[object Date]') {
|
105
|
+
return dateString;
|
106
|
+
}
|
107
|
+
const parts = dateString.split('/');
|
108
|
+
if (parts.length === 3) {
|
109
|
+
const day = parseInt(parts[0], 10);
|
110
|
+
const month = parseInt(parts[1], 10) - 1;
|
111
|
+
const year = parseInt(parts[2], 10);
|
112
|
+
const date = new Date(year, month, day);
|
113
|
+
return isNaN(date.getTime()) ? null : date;
|
114
|
+
}
|
115
|
+
return null;
|
116
|
+
}
|
117
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: MultiSearchCriteriaComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
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"] }] }); }
|
119
|
+
}
|
120
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: MultiSearchCriteriaComponent, decorators: [{
|
121
|
+
type: Component,
|
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"] }]
|
123
|
+
}], propDecorators: { title: [{
|
124
|
+
type: Input
|
125
|
+
}], criteria: [{
|
126
|
+
type: Input
|
127
|
+
}], inputsPerRow: [{
|
128
|
+
type: Input
|
129
|
+
}], data: [{
|
130
|
+
type: Input
|
131
|
+
}], mode: [{
|
132
|
+
type: Input
|
133
|
+
}], filteredData: [{
|
134
|
+
type: Output
|
135
|
+
}], searchCriteria: [{
|
136
|
+
type: Output
|
137
|
+
}] } });
|
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"]}
|
@@ -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==
|