@mediusinc/mng-commons 0.14.0 → 0.14.2
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/assets/i18n/en.json +3 -2
- package/assets/i18n/sl.json +3 -2
- package/esm2020/lib/api/models/filter-param.model.mjs +1 -1
- package/esm2020/lib/api/models/query-result.model.mjs +7 -1
- package/esm2020/lib/api/utils/medius-rest.util.mjs +59 -6
- package/esm2020/lib/components/form/date-range/date-range.component.mjs +109 -0
- package/esm2020/lib/components/form/index.mjs +2 -1
- package/esm2020/lib/components/tableview/route/tableview-route.component.mjs +3 -3
- package/esm2020/lib/components/tableview/table/column-filter/column-filter.component.mjs +34 -22
- package/esm2020/lib/components/tableview/table/table.component.mjs +24 -5
- package/esm2020/lib/components/tableview/tableview.component.mjs +17 -4
- package/esm2020/lib/descriptors/action.descriptor.mjs +1 -1
- package/esm2020/lib/descriptors/column.descriptor.mjs +16 -1
- package/esm2020/lib/descriptors/filter.descriptor.mjs +26 -3
- package/esm2020/lib/mng-commons.module.mjs +5 -2
- package/esm2020/lib/services/commons.service.mjs +6 -5
- package/esm2020/lib/utils/date.util.mjs +118 -0
- package/esm2020/lib/utils/index.mjs +2 -1
- package/fesm2015/mediusinc-mng-commons.mjs +408 -43
- package/fesm2015/mediusinc-mng-commons.mjs.map +1 -1
- package/fesm2020/mediusinc-mng-commons.mjs +400 -40
- package/fesm2020/mediusinc-mng-commons.mjs.map +1 -1
- package/lib/api/models/filter-param.model.d.ts +2 -2
- package/lib/api/models/query-result.model.d.ts +1 -0
- package/lib/components/form/date-range/date-range.component.d.ts +28 -0
- package/lib/components/form/index.d.ts +1 -0
- package/lib/components/tableview/table/column-filter/column-filter.component.d.ts +13 -7
- package/lib/components/tableview/table/table.component.d.ts +2 -0
- package/lib/components/tableview/tableview.component.d.ts +7 -3
- package/lib/descriptors/action.descriptor.d.ts +3 -3
- package/lib/descriptors/filter.descriptor.d.ts +5 -0
- package/lib/mng-commons.module.d.ts +63 -62
- package/lib/services/commons.service.d.ts +3 -2
- package/lib/utils/date.util.d.ts +7 -0
- package/lib/utils/index.d.ts +1 -0
- package/package.json +1 -1
- package/templates/tableview-route.component.html +1 -1
- package/version-info.json +5 -5
|
@@ -1,5 +1,6 @@
|
|
|
1
|
-
import { Component, Input } from '@angular/core';
|
|
2
|
-
import {
|
|
1
|
+
import { Component, Input, ViewChild } from '@angular/core';
|
|
2
|
+
import { ColumnFilter } from 'primeng/table';
|
|
3
|
+
import { Subject, debounceTime, distinctUntilChanged } from 'rxjs';
|
|
3
4
|
import { FilterLookupTypeEnum, FilterMatchModeEnum, FilterTypeEnum, TableFilterDisplayEnum } from '../../../../descriptors/types';
|
|
4
5
|
import * as i0 from "@angular/core";
|
|
5
6
|
import * as i1 from "primeng/api";
|
|
@@ -9,7 +10,8 @@ import * as i4 from "primeng/calendar";
|
|
|
9
10
|
import * as i5 from "primeng/table";
|
|
10
11
|
import * as i6 from "../../../form/autocomplete/autocomplete.component";
|
|
11
12
|
import * as i7 from "../../../form/dropdown/dropdown.component";
|
|
12
|
-
import * as i8 from "
|
|
13
|
+
import * as i8 from "../../../form/date-range/date-range.component";
|
|
14
|
+
import * as i9 from "@ngx-translate/core";
|
|
13
15
|
/**
|
|
14
16
|
* Cannot be on push change detection strategy because of filter updates triggered from route which causes to force update values in force metadata
|
|
15
17
|
* and these must be propagated through to this component and beyond to primeNG.
|
|
@@ -23,6 +25,14 @@ export class MngTableColumnFilterComponent {
|
|
|
23
25
|
this.primeShowMatchMode = true;
|
|
24
26
|
this.primeDisplay = 'row';
|
|
25
27
|
this.primeMatchModes = null;
|
|
28
|
+
this.dateDebounceSubject = new Subject();
|
|
29
|
+
this.dateDebounceSubscription = this.dateDebounceSubject.pipe(debounceTime(500), distinctUntilChanged()).subscribe(v => {
|
|
30
|
+
this.dateFilterCallback?.(v);
|
|
31
|
+
});
|
|
32
|
+
}
|
|
33
|
+
get activeMatchMode() {
|
|
34
|
+
const filter = this.primeColumnFilter?.dt.filters[this.descriptor.property];
|
|
35
|
+
return filter?.matchMode;
|
|
26
36
|
}
|
|
27
37
|
ngOnInit() {
|
|
28
38
|
this.primeDefaultMatchMode = this.descriptor.defaultFilterMatchMode ?? FilterMatchModeEnum.Equals;
|
|
@@ -36,7 +46,7 @@ export class MngTableColumnFilterComponent {
|
|
|
36
46
|
break;
|
|
37
47
|
case FilterTypeEnum.Date:
|
|
38
48
|
this.primeType = 'date';
|
|
39
|
-
this.primeDefaultMatchMode =
|
|
49
|
+
this.primeDefaultMatchMode = FilterMatchModeEnum.DateIs;
|
|
40
50
|
break;
|
|
41
51
|
case FilterTypeEnum.Lookup:
|
|
42
52
|
this.primeType = 'lookup';
|
|
@@ -50,7 +60,7 @@ export class MngTableColumnFilterComponent {
|
|
|
50
60
|
break;
|
|
51
61
|
case FilterTypeEnum.String:
|
|
52
62
|
this.primeType = 'text';
|
|
53
|
-
this.primeDefaultMatchMode =
|
|
63
|
+
this.primeDefaultMatchMode = FilterMatchModeEnum.Contains;
|
|
54
64
|
break;
|
|
55
65
|
}
|
|
56
66
|
if (this.descriptor.matchModes) {
|
|
@@ -64,20 +74,22 @@ export class MngTableColumnFilterComponent {
|
|
|
64
74
|
this.primeDisplay = 'menu';
|
|
65
75
|
}
|
|
66
76
|
}
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
if (typeof value === 'string' || typeof value === 'number') {
|
|
70
|
-
return new Date(value);
|
|
71
|
-
}
|
|
72
|
-
else if (value instanceof Date) {
|
|
73
|
-
return value;
|
|
74
|
-
}
|
|
75
|
-
else {
|
|
76
|
-
return null;
|
|
77
|
-
}
|
|
77
|
+
ngOnDestroy() {
|
|
78
|
+
this.dateDebounceSubscription?.unsubscribe();
|
|
78
79
|
}
|
|
79
80
|
// eslint-disable-next-line @typescript-eslint/ban-types
|
|
80
81
|
dateFilter(value, filterCallback) {
|
|
82
|
+
this.dateFilterCallback = filterCallback;
|
|
83
|
+
if (this.activeMatchMode === FilterMatchModeEnum.Between && Array.isArray(value)) {
|
|
84
|
+
const dateValues = value.filter(v => v instanceof Date);
|
|
85
|
+
if (dateValues.length <= 1) {
|
|
86
|
+
return;
|
|
87
|
+
}
|
|
88
|
+
}
|
|
89
|
+
this.dateDebounceSubject.next(value);
|
|
90
|
+
}
|
|
91
|
+
// eslint-disable-next-line @typescript-eslint/ban-types
|
|
92
|
+
dateRangeChange(value, filterCallback) {
|
|
81
93
|
filterCallback(value);
|
|
82
94
|
}
|
|
83
95
|
// eslint-disable-next-line @typescript-eslint/ban-types
|
|
@@ -91,18 +103,18 @@ export class MngTableColumnFilterComponent {
|
|
|
91
103
|
}
|
|
92
104
|
filterCallback(value);
|
|
93
105
|
}
|
|
94
|
-
toLookupFilterValue(value) {
|
|
95
|
-
return this.lookupDescriptor.dataKeyProperty && value ? { [this.lookupDescriptor.dataKeyProperty]: value } : value;
|
|
96
|
-
}
|
|
97
106
|
}
|
|
98
107
|
MngTableColumnFilterComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.1.0", ngImport: i0, type: MngTableColumnFilterComponent, deps: [{ token: i1.PrimeNGConfig }], target: i0.ɵɵFactoryTarget.Component });
|
|
99
|
-
MngTableColumnFilterComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.1.0", type: MngTableColumnFilterComponent, selector: "mng-table-column-filter", inputs: { descriptor: "descriptor", display: "display" }, ngImport: i0, template: "<p-columnFilter\n class=\"ml-auto\"\n [type]=\"primeType\"\n [field]=\"descriptor.property\"\n [display]=\"primeDisplay\"\n [matchMode]=\"primeDefaultMatchMode\"\n [matchModeOptions]=\"$any(primeMatchModes)\"\n [placeholder]=\"descriptor.placeholder ?? 'mngTable.typeToFilter' | translate\"\n [showMatchModes]=\"true\"\n [showOperator]=\"false\"\n [showAddButton]=\"false\"\n [hideOnClear]=\"true\"\n [showMenu]=\"primeShowMatchMode\"\n [minFractionDigits]=\"$any(descriptor.numberMinFractionDigits)\"\n [maxFractionDigits]=\"$any(descriptor.numberMaxFractionDigits)\"\n [useGrouping]=\"descriptor.numberUseGrouping\">\n <ng-template *ngIf=\"primeType === 'date'\" pTemplate=\"filter\" let-value let-filterCallback=\"filterCallback\">\n <p-calendar\n
|
|
108
|
+
MngTableColumnFilterComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.1.0", type: MngTableColumnFilterComponent, selector: "mng-table-column-filter", inputs: { descriptor: "descriptor", display: "display" }, viewQueries: [{ propertyName: "primeColumnFilter", first: true, predicate: ColumnFilter, descendants: true }], ngImport: i0, template: "<p-columnFilter\n class=\"ml-auto\"\n [type]=\"primeType\"\n [field]=\"descriptor.property\"\n [display]=\"primeDisplay\"\n [matchMode]=\"$any(primeDefaultMatchMode)\"\n [matchModeOptions]=\"$any(primeMatchModes)\"\n [placeholder]=\"descriptor.placeholder ?? 'mngTable.typeToFilter' | translate\"\n [showMatchModes]=\"true\"\n [showOperator]=\"false\"\n [showAddButton]=\"false\"\n [hideOnClear]=\"true\"\n [showMenu]=\"primeShowMatchMode\"\n [minFractionDigits]=\"$any(descriptor.numberMinFractionDigits)\"\n [maxFractionDigits]=\"$any(descriptor.numberMaxFractionDigits)\"\n [useGrouping]=\"descriptor.numberUseGrouping\">\n <ng-template *ngIf=\"primeType === 'date'\" pTemplate=\"filter\" let-value let-filterCallback=\"filterCallback\">\n <ng-container *ngIf=\"activeMatchMode === 'between'; else datePicker\">\n <mng-date-range\n [ngModel]=\"value\"\n (ngModelChange)=\"dateFilter($event, filterCallback)\"\n [showTime]=\"descriptor.datePickerShowTime\"\n [dateFormat]=\"descriptor.datePickerFormat\"\n [placeholder]=\"descriptor.placeholder ?? 'mngTable.typeToFilter' | translate\"></mng-date-range>\n </ng-container>\n <ng-template #datePicker>\n <p-calendar\n appendTo=\"body\"\n [ngModel]=\"value\"\n (ngModelChange)=\"dateFilter($event, filterCallback)\"\n [placeholder]=\"descriptor.placeholder ?? 'mngTable.typeToFilter' | translate\"\n [showIcon]=\"true\"\n [dateFormat]=\"descriptor.datePickerFormat ?? 'dd.mm.yy'\"\n [showTime]=\"descriptor.datePickerShowTime\">\n </p-calendar>\n </ng-template>\n </ng-template>\n <ng-template *ngIf=\"lookupDescriptor\" pTemplate=\"filter\" let-value let-filterCallback=\"filterCallback\">\n <ng-container [ngSwitch]=\"lookupDescriptor.lookupType\">\n <mng-autocomplete\n *ngSwitchCase=\"lookupTypeAutocomplete\"\n [ngModel]=\"value\"\n [dataProvider]=\"lookupDescriptor.dataProvider\"\n [dataKeyProperty]=\"lookupDescriptor.dataKeyProperty\"\n [itemsValueProperty]=\"lookupDescriptor.itemsValueProperty\"\n [itemsLabelProperty]=\"lookupDescriptor.itemsLabelProperty\"\n [itemsLabelTranslate]=\"lookupDescriptor.itemsLabelTranslate\"\n [multiselect]=\"lookupDescriptor.multiselect\"\n [openOnFocus]=\"lookupDescriptor.autocompleteOpenOnFocus\"\n [inlineSearch]=\"lookupDescriptor.autocompleteInlineSearch\"\n [placeholder]=\"descriptor.placeholder ?? 'mngTable.searchToFilter' | translate\"\n [className]=\"lookupDescriptor.className\"\n [dropdownClassName]=\"lookupDescriptor.dropdownClassName\"\n (valueChange)=\"autocompleteFilter($event, filterCallback)\">\n </mng-autocomplete>\n <mng-dropdown\n *ngSwitchCase=\"lookupTypeDropdown\"\n [ngModel]=\"value\"\n [dataProvider]=\"lookupDescriptor.dataProvider\"\n [itemsValueProperty]=\"lookupDescriptor.itemsValueProperty\"\n [itemsLabelProperty]=\"lookupDescriptor.itemsLabelProperty\"\n [itemsLabelTranslate]=\"lookupDescriptor.itemsLabelTranslate\"\n [multiselect]=\"lookupDescriptor.multiselect\"\n [placeholder]=\"descriptor.placeholder ?? 'mngTable.selectToFilter' | translate\"\n [className]=\"lookupDescriptor.className\"\n [dropdownClassName]=\"lookupDescriptor.dropdownClassName\"\n [showClear]=\"false\"\n [changeValueOnBlur]=\"lookupDescriptor.multiselect\"\n (valueChange)=\"dropdownFilter($event, filterCallback)\">\n </mng-dropdown>\n </ng-container>\n </ng-template>\n</p-columnFilter>\n", dependencies: [{ kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { kind: "directive", type: i2.NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { kind: "directive", type: i3.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1.PrimeTemplate, selector: "[pTemplate]", inputs: ["type", "pTemplate"] }, { kind: "component", type: i4.Calendar, selector: "p-calendar", inputs: ["style", "styleClass", "inputStyle", "inputId", "name", "inputStyleClass", "placeholder", "ariaLabelledBy", "iconAriaLabel", "disabled", "dateFormat", "multipleSeparator", "rangeSeparator", "inline", "showOtherMonths", "selectOtherMonths", "showIcon", "icon", "appendTo", "readonlyInput", "shortYearCutoff", "monthNavigator", "yearNavigator", "hourFormat", "timeOnly", "stepHour", "stepMinute", "stepSecond", "showSeconds", "required", "showOnFocus", "showWeek", "showClear", "dataType", "selectionMode", "maxDateCount", "showButtonBar", "todayButtonStyleClass", "clearButtonStyleClass", "autoZIndex", "baseZIndex", "panelStyleClass", "panelStyle", "keepInvalid", "hideOnDateTimeSelect", "touchUI", "timeSeparator", "focusTrap", "showTransitionOptions", "hideTransitionOptions", "tabindex", "view", "defaultDate", "minDate", "maxDate", "disabledDates", "disabledDays", "yearRange", "showTime", "responsiveOptions", "numberOfMonths", "firstDayOfWeek", "locale"], outputs: ["onFocus", "onBlur", "onClose", "onSelect", "onClear", "onInput", "onTodayClick", "onClearClick", "onMonthChange", "onYearChange", "onClickOutside", "onShow"] }, { kind: "directive", type: i3.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i5.ColumnFilter, selector: "p-columnFilter", inputs: ["field", "type", "display", "showMenu", "matchMode", "operator", "showOperator", "showClearButton", "showApplyButton", "showMatchModes", "showAddButton", "hideOnClear", "placeholder", "matchModeOptions", "maxConstraints", "minFractionDigits", "maxFractionDigits", "prefix", "suffix", "locale", "localeMatcher", "currency", "currencyDisplay", "useGrouping"] }, { kind: "component", type: i6.MngAutocompleteComponent, selector: "mng-autocomplete", inputs: ["dataProvider", "dataKeyProperty", "itemsValueProperty", "itemsLabelProperty", "itemsLabelTranslate", "inlineSearch", "openOnFocus", "multiselect", "placeholder", "className", "dropdownClassName"], outputs: ["valueChange"] }, { kind: "component", type: i7.MngDropdownComponent, selector: "mng-dropdown", inputs: ["dataProvider", "dataKeyProperty", "itemsLabelProperty", "itemsLabelTranslate", "itemsValueProperty", "itemsDisabledProperty", "multiselect", "placeholder", "showClear", "selectFirstItem", "className", "dropdownClassName", "changeValueOnBlur"], outputs: ["valueChange"] }, { kind: "component", type: i8.MngDateRangeComponent, selector: "mng-date-range", inputs: ["placeholder", "showTime", "showSeconds", "dateFormat"] }, { kind: "pipe", type: i9.TranslatePipe, name: "translate" }] });
|
|
100
109
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.1.0", ngImport: i0, type: MngTableColumnFilterComponent, decorators: [{
|
|
101
110
|
type: Component,
|
|
102
|
-
args: [{ selector: 'mng-table-column-filter', template: "<p-columnFilter\n class=\"ml-auto\"\n [type]=\"primeType\"\n [field]=\"descriptor.property\"\n [display]=\"primeDisplay\"\n [matchMode]=\"primeDefaultMatchMode\"\n [matchModeOptions]=\"$any(primeMatchModes)\"\n [placeholder]=\"descriptor.placeholder ?? 'mngTable.typeToFilter' | translate\"\n [showMatchModes]=\"true\"\n [showOperator]=\"false\"\n [showAddButton]=\"false\"\n [hideOnClear]=\"true\"\n [showMenu]=\"primeShowMatchMode\"\n [minFractionDigits]=\"$any(descriptor.numberMinFractionDigits)\"\n [maxFractionDigits]=\"$any(descriptor.numberMaxFractionDigits)\"\n [useGrouping]=\"descriptor.numberUseGrouping\">\n <ng-template *ngIf=\"primeType === 'date'\" pTemplate=\"filter\" let-value let-filterCallback=\"filterCallback\">\n <p-calendar\n
|
|
111
|
+
args: [{ selector: 'mng-table-column-filter', template: "<p-columnFilter\n class=\"ml-auto\"\n [type]=\"primeType\"\n [field]=\"descriptor.property\"\n [display]=\"primeDisplay\"\n [matchMode]=\"$any(primeDefaultMatchMode)\"\n [matchModeOptions]=\"$any(primeMatchModes)\"\n [placeholder]=\"descriptor.placeholder ?? 'mngTable.typeToFilter' | translate\"\n [showMatchModes]=\"true\"\n [showOperator]=\"false\"\n [showAddButton]=\"false\"\n [hideOnClear]=\"true\"\n [showMenu]=\"primeShowMatchMode\"\n [minFractionDigits]=\"$any(descriptor.numberMinFractionDigits)\"\n [maxFractionDigits]=\"$any(descriptor.numberMaxFractionDigits)\"\n [useGrouping]=\"descriptor.numberUseGrouping\">\n <ng-template *ngIf=\"primeType === 'date'\" pTemplate=\"filter\" let-value let-filterCallback=\"filterCallback\">\n <ng-container *ngIf=\"activeMatchMode === 'between'; else datePicker\">\n <mng-date-range\n [ngModel]=\"value\"\n (ngModelChange)=\"dateFilter($event, filterCallback)\"\n [showTime]=\"descriptor.datePickerShowTime\"\n [dateFormat]=\"descriptor.datePickerFormat\"\n [placeholder]=\"descriptor.placeholder ?? 'mngTable.typeToFilter' | translate\"></mng-date-range>\n </ng-container>\n <ng-template #datePicker>\n <p-calendar\n appendTo=\"body\"\n [ngModel]=\"value\"\n (ngModelChange)=\"dateFilter($event, filterCallback)\"\n [placeholder]=\"descriptor.placeholder ?? 'mngTable.typeToFilter' | translate\"\n [showIcon]=\"true\"\n [dateFormat]=\"descriptor.datePickerFormat ?? 'dd.mm.yy'\"\n [showTime]=\"descriptor.datePickerShowTime\">\n </p-calendar>\n </ng-template>\n </ng-template>\n <ng-template *ngIf=\"lookupDescriptor\" pTemplate=\"filter\" let-value let-filterCallback=\"filterCallback\">\n <ng-container [ngSwitch]=\"lookupDescriptor.lookupType\">\n <mng-autocomplete\n *ngSwitchCase=\"lookupTypeAutocomplete\"\n [ngModel]=\"value\"\n [dataProvider]=\"lookupDescriptor.dataProvider\"\n [dataKeyProperty]=\"lookupDescriptor.dataKeyProperty\"\n [itemsValueProperty]=\"lookupDescriptor.itemsValueProperty\"\n [itemsLabelProperty]=\"lookupDescriptor.itemsLabelProperty\"\n [itemsLabelTranslate]=\"lookupDescriptor.itemsLabelTranslate\"\n [multiselect]=\"lookupDescriptor.multiselect\"\n [openOnFocus]=\"lookupDescriptor.autocompleteOpenOnFocus\"\n [inlineSearch]=\"lookupDescriptor.autocompleteInlineSearch\"\n [placeholder]=\"descriptor.placeholder ?? 'mngTable.searchToFilter' | translate\"\n [className]=\"lookupDescriptor.className\"\n [dropdownClassName]=\"lookupDescriptor.dropdownClassName\"\n (valueChange)=\"autocompleteFilter($event, filterCallback)\">\n </mng-autocomplete>\n <mng-dropdown\n *ngSwitchCase=\"lookupTypeDropdown\"\n [ngModel]=\"value\"\n [dataProvider]=\"lookupDescriptor.dataProvider\"\n [itemsValueProperty]=\"lookupDescriptor.itemsValueProperty\"\n [itemsLabelProperty]=\"lookupDescriptor.itemsLabelProperty\"\n [itemsLabelTranslate]=\"lookupDescriptor.itemsLabelTranslate\"\n [multiselect]=\"lookupDescriptor.multiselect\"\n [placeholder]=\"descriptor.placeholder ?? 'mngTable.selectToFilter' | translate\"\n [className]=\"lookupDescriptor.className\"\n [dropdownClassName]=\"lookupDescriptor.dropdownClassName\"\n [showClear]=\"false\"\n [changeValueOnBlur]=\"lookupDescriptor.multiselect\"\n (valueChange)=\"dropdownFilter($event, filterCallback)\">\n </mng-dropdown>\n </ng-container>\n </ng-template>\n</p-columnFilter>\n" }]
|
|
103
112
|
}], ctorParameters: function () { return [{ type: i1.PrimeNGConfig }]; }, propDecorators: { descriptor: [{
|
|
104
113
|
type: Input
|
|
105
114
|
}], display: [{
|
|
106
115
|
type: Input
|
|
116
|
+
}], primeColumnFilter: [{
|
|
117
|
+
type: ViewChild,
|
|
118
|
+
args: [ColumnFilter]
|
|
107
119
|
}] } });
|
|
108
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"column-filter.component.js","sourceRoot":"","sources":["../../../../../../../src/lib/components/tableview/table/column-filter/column-filter.component.ts","../../../../../../../src/lib/components/tableview/table/column-filter/column-filter.component.html"],"names":[],"mappings":"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","sourcesContent":["import {Component, Input, OnInit} from '@angular/core';\n\nimport {FilterMatchMode, PrimeNGConfig, SelectItem} from 'primeng/api';\n\nimport {FilterDescriptor, FilterLookupDescriptor} from '../../../../descriptors';\nimport {FilterLookupTypeEnum, FilterMatchModeEnum, FilterTypeEnum, TableFilterDisplayEnum} from '../../../../descriptors/types';\n\n/**\n * Cannot be on push change detection strategy because of filter updates triggered from route which causes to force update values in force metadata\n * and these must be propagated through to this component and beyond to primeNG.\n */\n@Component({\n    selector: 'mng-table-column-filter',\n    templateUrl: './column-filter.component.html'\n})\nexport class MngTableColumnFilterComponent<T> implements OnInit {\n    public readonly lookupTypeDropdown: FilterLookupTypeEnum = FilterLookupTypeEnum.Dropdown;\n    public readonly lookupTypeAutocomplete: FilterLookupTypeEnum = FilterLookupTypeEnum.Autocomplete;\n\n    @Input() descriptor!: FilterDescriptor<T>;\n    @Input() display!: TableFilterDisplayEnum;\n\n    public lookupDescriptor?: FilterLookupDescriptor<T>;\n\n    public primeField!: string;\n    public primeType = 'text';\n    public primeShowMatchMode = true;\n    public primeDefaultMatchMode!: string;\n    public primeDisplay = 'row';\n    public primeMatchModes: SelectItem[] | null = null;\n\n    constructor(private primeConfig: PrimeNGConfig) {}\n\n    ngOnInit() {\n        this.primeDefaultMatchMode = this.descriptor.defaultFilterMatchMode ?? FilterMatchModeEnum.Equals;\n\n        switch (this.descriptor.filterType) {\n            case FilterTypeEnum.Boolean:\n                this.primeType = 'boolean';\n                this.primeShowMatchMode = false;\n                break;\n            case FilterTypeEnum.Number:\n                this.primeType = 'numeric';\n                break;\n            case FilterTypeEnum.Date:\n                this.primeType = 'date';\n                this.primeDefaultMatchMode = FilterMatchMode.DATE_AFTER;\n                break;\n            case FilterTypeEnum.Lookup:\n                this.primeType = 'lookup';\n                this.primeShowMatchMode = false;\n                this.lookupDescriptor = this.descriptor as FilterLookupDescriptor<T>;\n                this.primeField = `${this.descriptor.property}${this.lookupDescriptor.itemsValueProperty ? `.${this.lookupDescriptor.itemsValueProperty}` : ''}`;\n                this.primeMatchModes = [{value: FilterMatchModeEnum.Equals, label: this.primeConfig.getTranslation(FilterMatchModeEnum.Equals)}];\n\n                if (this.lookupDescriptor.multiselect) {\n                    this.primeDefaultMatchMode = FilterMatchModeEnum.In;\n                }\n                break;\n            case FilterTypeEnum.String:\n                this.primeType = 'text';\n                this.primeDefaultMatchMode = FilterMatchMode.CONTAINS;\n                break;\n        }\n\n        if (this.descriptor.matchModes) {\n            this.primeMatchModes = this.descriptor.matchModes.map(mm => <SelectItem>{value: mm, label: this.primeConfig.getTranslation(mm)});\n\n            if (!this.primeMatchModes.map(matchMode => matchMode.value).includes(this.primeDefaultMatchMode)) {\n                this.primeDefaultMatchMode = this.descriptor.matchModes[0];\n            }\n\n            this.primeShowMatchMode = this.primeMatchModes?.length > 1;\n        }\n\n        if (this.display === TableFilterDisplayEnum.Menu) {\n            this.primeDisplay = 'menu';\n        }\n    }\n\n    valueToDate(value: unknown): Date | null {\n        console.log('call', this.descriptor.property);\n        if (typeof value === 'string' || typeof value === 'number') {\n            return new Date(value);\n        } else if (value instanceof Date) {\n            return value;\n        } else {\n            return null;\n        }\n    }\n\n    // eslint-disable-next-line @typescript-eslint/ban-types\n    dateFilter(value: T, filterCallback: Function) {\n        filterCallback(value);\n    }\n\n    // eslint-disable-next-line @typescript-eslint/ban-types\n    autocompleteFilter(value: T, filterCallback: Function) {\n        filterCallback(value);\n    }\n\n    // eslint-disable-next-line @typescript-eslint/ban-types, @typescript-eslint/no-explicit-any\n    dropdownFilter(value: any, filterCallback: Function) {\n        if (Array.isArray(value) && value.length === 0) {\n            value = undefined;\n        }\n        filterCallback(value);\n    }\n\n    toLookupFilterValue(value?: any) {\n        return this.lookupDescriptor!.dataKeyProperty && value ? {[this.lookupDescriptor!.dataKeyProperty]: value} : value;\n    }\n}\n","<p-columnFilter\n    class=\"ml-auto\"\n    [type]=\"primeType\"\n    [field]=\"descriptor.property\"\n    [display]=\"primeDisplay\"\n    [matchMode]=\"primeDefaultMatchMode\"\n    [matchModeOptions]=\"$any(primeMatchModes)\"\n    [placeholder]=\"descriptor.placeholder ?? 'mngTable.typeToFilter' | translate\"\n    [showMatchModes]=\"true\"\n    [showOperator]=\"false\"\n    [showAddButton]=\"false\"\n    [hideOnClear]=\"true\"\n    [showMenu]=\"primeShowMatchMode\"\n    [minFractionDigits]=\"$any(descriptor.numberMinFractionDigits)\"\n    [maxFractionDigits]=\"$any(descriptor.numberMaxFractionDigits)\"\n    [useGrouping]=\"descriptor.numberUseGrouping\">\n    <ng-template *ngIf=\"primeType === 'date'\" pTemplate=\"filter\" let-value let-filterCallback=\"filterCallback\">\n        <p-calendar\n            appendTo=\"body\"\n            [ngModel]=\"value\"\n            (ngModelChange)=\"dateFilter($event, filterCallback)\"\n            [placeholder]=\"descriptor.placeholder ?? 'mngTable.typeToFilter' | translate\"\n            [showIcon]=\"true\"\n            [dateFormat]=\"descriptor.datePickerFormat ?? 'dd.mm.yy'\"\n            [showTime]=\"descriptor.datePickerShowTime\">\n        </p-calendar>\n    </ng-template>\n    <ng-template *ngIf=\"lookupDescriptor\" pTemplate=\"filter\" let-value let-filterCallback=\"filterCallback\">\n        <ng-container [ngSwitch]=\"lookupDescriptor.lookupType\">\n            <mng-autocomplete\n                *ngSwitchCase=\"lookupTypeAutocomplete\"\n                [ngModel]=\"value\"\n                [dataProvider]=\"lookupDescriptor.dataProvider\"\n                [dataKeyProperty]=\"lookupDescriptor.dataKeyProperty\"\n                [itemsValueProperty]=\"lookupDescriptor.itemsValueProperty\"\n                [itemsLabelProperty]=\"lookupDescriptor.itemsLabelProperty\"\n                [itemsLabelTranslate]=\"lookupDescriptor.itemsLabelTranslate\"\n                [multiselect]=\"lookupDescriptor.multiselect\"\n                [openOnFocus]=\"lookupDescriptor.autocompleteOpenOnFocus\"\n                [inlineSearch]=\"lookupDescriptor.autocompleteInlineSearch\"\n                [placeholder]=\"descriptor.placeholder ?? 'mngTable.searchToFilter' | translate\"\n                [className]=\"lookupDescriptor.className\"\n                [dropdownClassName]=\"lookupDescriptor.dropdownClassName\"\n                (valueChange)=\"autocompleteFilter($event, filterCallback)\">\n            </mng-autocomplete>\n            <mng-dropdown\n                *ngSwitchCase=\"lookupTypeDropdown\"\n                [ngModel]=\"value\"\n                [dataProvider]=\"lookupDescriptor.dataProvider\"\n                [itemsValueProperty]=\"lookupDescriptor.itemsValueProperty\"\n                [itemsLabelProperty]=\"lookupDescriptor.itemsLabelProperty\"\n                [itemsLabelTranslate]=\"lookupDescriptor.itemsLabelTranslate\"\n                [multiselect]=\"lookupDescriptor.multiselect\"\n                [placeholder]=\"descriptor.placeholder ?? 'mngTable.selectToFilter' | translate\"\n                [className]=\"lookupDescriptor.className\"\n                [dropdownClassName]=\"lookupDescriptor.dropdownClassName\"\n                [showClear]=\"false\"\n                [changeValueOnBlur]=\"lookupDescriptor.multiselect\"\n                (valueChange)=\"dropdownFilter($event, filterCallback)\">\n            </mng-dropdown>\n        </ng-container>\n    </ng-template>\n</p-columnFilter>\n"]}
|
|
120
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"column-filter.component.js","sourceRoot":"","sources":["../../../../../../../src/lib/components/tableview/table/column-filter/column-filter.component.ts","../../../../../../../src/lib/components/tableview/table/column-filter/column-filter.component.html"],"names":[],"mappings":"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","sourcesContent":["import {Component, Input, OnDestroy, OnInit, ViewChild} from '@angular/core';\n\nimport {FilterMetadata, PrimeNGConfig, SelectItem} from 'primeng/api';\nimport {ColumnFilter} from 'primeng/table';\nimport {Subject, Subscription, debounceTime, distinctUntilChanged} from 'rxjs';\n\nimport {FilterDescriptor, FilterLookupDescriptor} from '../../../../descriptors';\nimport {FilterLookupTypeEnum, FilterMatchModeEnum, FilterTypeEnum, TableFilterDisplayEnum} from '../../../../descriptors/types';\n\n/**\n * Cannot be on push change detection strategy because of filter updates triggered from route which causes to force update values in force metadata\n * and these must be propagated through to this component and beyond to primeNG.\n */\n@Component({\n    selector: 'mng-table-column-filter',\n    templateUrl: './column-filter.component.html'\n})\nexport class MngTableColumnFilterComponent<T> implements OnInit, OnDestroy {\n    public readonly lookupTypeDropdown: FilterLookupTypeEnum = FilterLookupTypeEnum.Dropdown;\n    public readonly lookupTypeAutocomplete: FilterLookupTypeEnum = FilterLookupTypeEnum.Autocomplete;\n\n    @Input() descriptor!: FilterDescriptor<T>;\n    @Input() display!: TableFilterDisplayEnum;\n\n    @ViewChild(ColumnFilter) public primeColumnFilter!: ColumnFilter;\n\n    public lookupDescriptor?: FilterLookupDescriptor<T>;\n\n    public primeField!: string;\n    public primeType = 'text';\n    public primeShowMatchMode = true;\n    public primeDefaultMatchMode!: FilterMatchModeEnum;\n    public primeDisplay = 'row';\n    public primeMatchModes: SelectItem[] | null = null;\n\n    // eslint-disable-next-line @typescript-eslint/ban-types\n    private dateFilterCallback?: Function;\n    private dateDebounceSubject = new Subject<Date | Date[] | null>();\n    private dateDebounceSubscription?: Subscription;\n\n    constructor(private primeConfig: PrimeNGConfig) {\n        this.dateDebounceSubscription = this.dateDebounceSubject.pipe(debounceTime(500), distinctUntilChanged()).subscribe(v => {\n            this.dateFilterCallback?.(v);\n        });\n    }\n\n    public get activeMatchMode(): FilterMatchModeEnum | undefined {\n        const filter = this.primeColumnFilter?.dt.filters[this.descriptor.property] as FilterMetadata;\n        return filter?.matchMode as FilterMatchModeEnum | undefined;\n    }\n\n    ngOnInit() {\n        this.primeDefaultMatchMode = this.descriptor.defaultFilterMatchMode ?? FilterMatchModeEnum.Equals;\n\n        switch (this.descriptor.filterType) {\n            case FilterTypeEnum.Boolean:\n                this.primeType = 'boolean';\n                this.primeShowMatchMode = false;\n                break;\n            case FilterTypeEnum.Number:\n                this.primeType = 'numeric';\n                break;\n            case FilterTypeEnum.Date:\n                this.primeType = 'date';\n                this.primeDefaultMatchMode = FilterMatchModeEnum.DateIs;\n                break;\n            case FilterTypeEnum.Lookup:\n                this.primeType = 'lookup';\n                this.primeShowMatchMode = false;\n                this.lookupDescriptor = this.descriptor as FilterLookupDescriptor<T>;\n                this.primeField = `${this.descriptor.property}${this.lookupDescriptor.itemsValueProperty ? `.${this.lookupDescriptor.itemsValueProperty}` : ''}`;\n                this.primeMatchModes = [{value: FilterMatchModeEnum.Equals, label: this.primeConfig.getTranslation(FilterMatchModeEnum.Equals)}];\n\n                if (this.lookupDescriptor.multiselect) {\n                    this.primeDefaultMatchMode = FilterMatchModeEnum.In;\n                }\n                break;\n            case FilterTypeEnum.String:\n                this.primeType = 'text';\n                this.primeDefaultMatchMode = FilterMatchModeEnum.Contains;\n                break;\n        }\n\n        if (this.descriptor.matchModes) {\n            this.primeMatchModes = this.descriptor.matchModes.map(mm => <SelectItem>{value: mm, label: this.primeConfig.getTranslation(mm)});\n\n            if (!this.primeMatchModes.map(matchMode => matchMode.value).includes(this.primeDefaultMatchMode)) {\n                this.primeDefaultMatchMode = this.descriptor.matchModes[0] as FilterMatchModeEnum;\n            }\n\n            this.primeShowMatchMode = this.primeMatchModes?.length > 1;\n        }\n\n        if (this.display === TableFilterDisplayEnum.Menu) {\n            this.primeDisplay = 'menu';\n        }\n    }\n\n    ngOnDestroy() {\n        this.dateDebounceSubscription?.unsubscribe();\n    }\n\n    // eslint-disable-next-line @typescript-eslint/ban-types\n    dateFilter(value: Date | Date[] | null, filterCallback: Function) {\n        this.dateFilterCallback = filterCallback;\n        if (this.activeMatchMode === FilterMatchModeEnum.Between && Array.isArray(value)) {\n            const dateValues = value.filter(v => v instanceof Date);\n            if (dateValues.length <= 1) {\n                return;\n            }\n        }\n        this.dateDebounceSubject.next(value);\n    }\n\n    // eslint-disable-next-line @typescript-eslint/ban-types\n    dateRangeChange(value: Date[] | null, filterCallback: Function) {\n        filterCallback(value);\n    }\n\n    // eslint-disable-next-line @typescript-eslint/ban-types\n    autocompleteFilter(value: T, filterCallback: Function) {\n        filterCallback(value);\n    }\n\n    // eslint-disable-next-line @typescript-eslint/ban-types, @typescript-eslint/no-explicit-any\n    dropdownFilter(value: any, filterCallback: Function) {\n        if (Array.isArray(value) && value.length === 0) {\n            value = undefined;\n        }\n        filterCallback(value);\n    }\n}\n","<p-columnFilter\n    class=\"ml-auto\"\n    [type]=\"primeType\"\n    [field]=\"descriptor.property\"\n    [display]=\"primeDisplay\"\n    [matchMode]=\"$any(primeDefaultMatchMode)\"\n    [matchModeOptions]=\"$any(primeMatchModes)\"\n    [placeholder]=\"descriptor.placeholder ?? 'mngTable.typeToFilter' | translate\"\n    [showMatchModes]=\"true\"\n    [showOperator]=\"false\"\n    [showAddButton]=\"false\"\n    [hideOnClear]=\"true\"\n    [showMenu]=\"primeShowMatchMode\"\n    [minFractionDigits]=\"$any(descriptor.numberMinFractionDigits)\"\n    [maxFractionDigits]=\"$any(descriptor.numberMaxFractionDigits)\"\n    [useGrouping]=\"descriptor.numberUseGrouping\">\n    <ng-template *ngIf=\"primeType === 'date'\" pTemplate=\"filter\" let-value let-filterCallback=\"filterCallback\">\n        <ng-container *ngIf=\"activeMatchMode === 'between'; else datePicker\">\n            <mng-date-range\n                [ngModel]=\"value\"\n                (ngModelChange)=\"dateFilter($event, filterCallback)\"\n                [showTime]=\"descriptor.datePickerShowTime\"\n                [dateFormat]=\"descriptor.datePickerFormat\"\n                [placeholder]=\"descriptor.placeholder ?? 'mngTable.typeToFilter' | translate\"></mng-date-range>\n        </ng-container>\n        <ng-template #datePicker>\n            <p-calendar\n                appendTo=\"body\"\n                [ngModel]=\"value\"\n                (ngModelChange)=\"dateFilter($event, filterCallback)\"\n                [placeholder]=\"descriptor.placeholder ?? 'mngTable.typeToFilter' | translate\"\n                [showIcon]=\"true\"\n                [dateFormat]=\"descriptor.datePickerFormat ?? 'dd.mm.yy'\"\n                [showTime]=\"descriptor.datePickerShowTime\">\n            </p-calendar>\n        </ng-template>\n    </ng-template>\n    <ng-template *ngIf=\"lookupDescriptor\" pTemplate=\"filter\" let-value let-filterCallback=\"filterCallback\">\n        <ng-container [ngSwitch]=\"lookupDescriptor.lookupType\">\n            <mng-autocomplete\n                *ngSwitchCase=\"lookupTypeAutocomplete\"\n                [ngModel]=\"value\"\n                [dataProvider]=\"lookupDescriptor.dataProvider\"\n                [dataKeyProperty]=\"lookupDescriptor.dataKeyProperty\"\n                [itemsValueProperty]=\"lookupDescriptor.itemsValueProperty\"\n                [itemsLabelProperty]=\"lookupDescriptor.itemsLabelProperty\"\n                [itemsLabelTranslate]=\"lookupDescriptor.itemsLabelTranslate\"\n                [multiselect]=\"lookupDescriptor.multiselect\"\n                [openOnFocus]=\"lookupDescriptor.autocompleteOpenOnFocus\"\n                [inlineSearch]=\"lookupDescriptor.autocompleteInlineSearch\"\n                [placeholder]=\"descriptor.placeholder ?? 'mngTable.searchToFilter' | translate\"\n                [className]=\"lookupDescriptor.className\"\n                [dropdownClassName]=\"lookupDescriptor.dropdownClassName\"\n                (valueChange)=\"autocompleteFilter($event, filterCallback)\">\n            </mng-autocomplete>\n            <mng-dropdown\n                *ngSwitchCase=\"lookupTypeDropdown\"\n                [ngModel]=\"value\"\n                [dataProvider]=\"lookupDescriptor.dataProvider\"\n                [itemsValueProperty]=\"lookupDescriptor.itemsValueProperty\"\n                [itemsLabelProperty]=\"lookupDescriptor.itemsLabelProperty\"\n                [itemsLabelTranslate]=\"lookupDescriptor.itemsLabelTranslate\"\n                [multiselect]=\"lookupDescriptor.multiselect\"\n                [placeholder]=\"descriptor.placeholder ?? 'mngTable.selectToFilter' | translate\"\n                [className]=\"lookupDescriptor.className\"\n                [dropdownClassName]=\"lookupDescriptor.dropdownClassName\"\n                [showClear]=\"false\"\n                [changeValueOnBlur]=\"lookupDescriptor.multiselect\"\n                (valueChange)=\"dropdownFilter($event, filterCallback)\">\n            </mng-dropdown>\n        </ng-container>\n    </ng-template>\n</p-columnFilter>\n"]}
|