@mediusinc/mng-commons 5.3.0-rc.1 → 5.3.0-rc.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/core/data-list/filter-metadata.model.d.ts +20 -0
- package/core/helpers/number.d.ts +5 -0
- package/core/helpers/type-helpers.d.ts +1 -0
- package/core/index.d.ts +2 -0
- package/core/provide.d.ts +3 -2
- package/core/services/tokens/module-config.token.d.ts +7 -6
- package/esm2022/core/data-list/data-list-params-helpers.mjs +3 -1
- package/esm2022/core/data-list/filter-metadata.model.mjs +2 -0
- package/esm2022/core/helpers/date.mjs +2 -2
- package/esm2022/core/helpers/number.mjs +19 -0
- package/esm2022/core/helpers/type-helpers.mjs +1 -1
- package/esm2022/core/index.mjs +3 -1
- package/esm2022/core/pipes/boolean.pipe.mjs +7 -1
- package/esm2022/core/provide.mjs +4 -3
- package/esm2022/core/services/tokens/module-config.token.mjs +1 -1
- package/esm2022/filter/descriptors/filter-lookup.descriptor.mjs +2 -3
- package/esm2022/filter/descriptors/filter.descriptor.mjs +76 -31
- package/esm2022/filter/models/filter.model.mjs +6 -1
- package/esm2022/form/components/date-range/date-range.component.mjs +45 -14
- package/esm2022/form/components/dropdown/dropdown.component.mjs +77 -93
- package/esm2022/form/components/number-range/number-range.component.mjs +29 -12
- package/esm2022/table/api/descriptors/column.descriptor.mjs +2 -1
- package/esm2022/table/api/descriptors/table.descriptor.mjs +11 -20
- package/esm2022/table/api/models/table-columns.model.mjs +1 -1
- package/esm2022/table/api/models/table.model.mjs +1 -1
- package/esm2022/table/components/column-filter/column-filter.component.mjs +396 -0
- package/esm2022/table/components/filter/filter-active-tag/filter-active-tag.component.mjs +52 -0
- package/esm2022/table/components/filter/filter-form/filter-form.component.mjs +197 -0
- package/esm2022/table/components/filter/filter-overlay-with-tag/filter-overlay-with-tag.component.mjs +135 -0
- package/esm2022/table/components/table/table.component.mjs +34 -25
- package/esm2022/table/helpers/filters.mjs +297 -0
- package/esm2022/table/index.mjs +13 -2
- package/esm2022/table/models/filter.model.mjs +2 -0
- package/esm2022/table/pipes/filter-value.pipe.mjs +77 -0
- package/esm2022/table/provide.mjs +19 -0
- package/esm2022/table/services/data-list.service.mjs +1 -1
- package/esm2022/table/services/table-feature-config.token.mjs +3 -0
- package/esm2022/tableview/action/components/editor/injector-context/action-editor-injector-context.component.mjs +2 -2
- package/esm2022/tableview/action/components/localization/data-language-dropdown.component.mjs +2 -2
- package/esm2022/tableview/api/editor/descriptors/field.descriptor.mjs +1 -1
- package/esm2022/tableview/api/editor/models/editor-fields.model.mjs +1 -1
- package/esm2022/tableview/api/tableview/descriptors/tableview.descriptor.mjs +11 -13
- package/esm2022/tableview/editor/components/formly/fields/formly-field-dropdown/formly-field-dropdown.component.mjs +2 -2
- package/esm2022/tableview/tableview/components/tableview/tableview.component.mjs +3 -4
- package/fesm2022/mediusinc-mng-commons-core.mjs +32 -4
- package/fesm2022/mediusinc-mng-commons-core.mjs.map +1 -1
- package/fesm2022/mediusinc-mng-commons-filter.mjs +81 -32
- package/fesm2022/mediusinc-mng-commons-filter.mjs.map +1 -1
- package/fesm2022/mediusinc-mng-commons-form.mjs +149 -117
- package/fesm2022/mediusinc-mng-commons-form.mjs.map +1 -1
- package/fesm2022/mediusinc-mng-commons-table-api.mjs +11 -19
- package/fesm2022/mediusinc-mng-commons-table-api.mjs.map +1 -1
- package/fesm2022/mediusinc-mng-commons-table.mjs +832 -359
- package/fesm2022/mediusinc-mng-commons-table.mjs.map +1 -1
- package/fesm2022/mediusinc-mng-commons-tableview-api.mjs +10 -12
- package/fesm2022/mediusinc-mng-commons-tableview-api.mjs.map +1 -1
- package/fesm2022/mediusinc-mng-commons-tableview.mjs +5 -5
- package/fesm2022/mediusinc-mng-commons-tableview.mjs.map +1 -1
- package/filter/descriptors/filter.descriptor.d.ts +60 -16
- package/filter/models/filter.model.d.ts +4 -0
- package/form/components/date-range/date-range.component.d.ts +9 -3
- package/form/components/dropdown/dropdown.component.d.ts +6 -7
- package/form/components/number-range/number-range.component.d.ts +8 -4
- package/i18n/en.json +32 -0
- package/i18n/sl.json +32 -0
- package/package.json +7 -7
- package/table/api/descriptors/table.descriptor.d.ts +7 -7
- package/table/api/models/table-columns.model.d.ts +3 -3
- package/table/api/models/table.model.d.ts +0 -12
- package/table/components/{column-filter-full/column-filter-full.component.d.ts → column-filter/column-filter.component.d.ts} +23 -38
- package/table/components/filter/filter-active-tag/filter-active-tag.component.d.ts +20 -0
- package/table/components/filter/filter-form/filter-form.component.d.ts +53 -0
- package/table/components/filter/filter-overlay-with-tag/filter-overlay-with-tag.component.d.ts +35 -0
- package/table/components/table/table.component.d.ts +10 -7
- package/table/helpers/filters.d.ts +31 -0
- package/table/index.d.ts +10 -1
- package/table/models/filter.model.d.ts +24 -0
- package/table/pipes/filter-value.pipe.d.ts +19 -0
- package/table/provide.d.ts +8 -0
- package/table/services/data-list.service.d.ts +3 -2
- package/table/services/table-feature-config.token.d.ts +6 -0
- package/tableview/api/editor/descriptors/field.descriptor.d.ts +3 -3
- package/tableview/api/editor/models/editor-fields.model.d.ts +4 -4
- package/tableview/api/tableview/descriptors/tableview.descriptor.d.ts +8 -6
- package/version-info.json +5 -5
- package/esm2022/table/components/column-filter-full/column-filter-full.component.mjs +0 -655
|
@@ -1,26 +1,33 @@
|
|
|
1
|
-
import { ChangeDetectionStrategy, Component, DestroyRef, Injector, booleanAttribute, effect, forwardRef, inject, input } from '@angular/core';
|
|
1
|
+
import { ChangeDetectionStrategy, ChangeDetectorRef, Component, DestroyRef, Injector, booleanAttribute, effect, forwardRef, inject, input } from '@angular/core';
|
|
2
2
|
import { takeUntilDestroyed } from '@angular/core/rxjs-interop';
|
|
3
|
-
import { FormBuilder, NG_VALUE_ACCESSOR, ReactiveFormsModule } from '@angular/forms';
|
|
3
|
+
import { FormBuilder, FormsModule, NG_VALIDATORS, NG_VALUE_ACCESSOR, ReactiveFormsModule, Validators } from '@angular/forms';
|
|
4
4
|
import { CalendarModule } from 'primeng/calendar';
|
|
5
5
|
import { merge } from 'rxjs';
|
|
6
6
|
import * as i0 from "@angular/core";
|
|
7
|
-
import * as i1 from "
|
|
8
|
-
import * as i2 from "
|
|
7
|
+
import * as i1 from "@angular/forms";
|
|
8
|
+
import * as i2 from "primeng/calendar";
|
|
9
9
|
export const DATE_RANGE_VALUE_ACCESSOR = {
|
|
10
10
|
provide: NG_VALUE_ACCESSOR,
|
|
11
11
|
useExisting: forwardRef(() => DateRangeComponent),
|
|
12
12
|
multi: true
|
|
13
13
|
};
|
|
14
|
+
export const DATE_RANGE_VALIDATOR = {
|
|
15
|
+
provide: NG_VALIDATORS,
|
|
16
|
+
useExisting: forwardRef(() => DateRangeComponent),
|
|
17
|
+
multi: true
|
|
18
|
+
};
|
|
14
19
|
export class DateRangeComponent {
|
|
15
20
|
constructor() {
|
|
16
21
|
this.formBuilder = inject(FormBuilder);
|
|
17
22
|
this.injector = inject(Injector);
|
|
18
23
|
this.destroyRef = inject(DestroyRef);
|
|
24
|
+
this.cdr = inject(ChangeDetectorRef);
|
|
19
25
|
this.placeholder = input();
|
|
20
26
|
this.showTime = input(false);
|
|
21
27
|
this.showSeconds = input(false);
|
|
22
28
|
this.dateFormat = input();
|
|
23
29
|
this.className = input();
|
|
30
|
+
this.required = input(false, { transform: booleanAttribute });
|
|
24
31
|
this.disabled = input(false, {
|
|
25
32
|
transform: booleanAttribute
|
|
26
33
|
});
|
|
@@ -28,6 +35,8 @@ export class DateRangeComponent {
|
|
|
28
35
|
this.onChangeFn = () => { };
|
|
29
36
|
// eslint-disable-next-line @typescript-eslint/no-empty-function
|
|
30
37
|
this.onTouchedFn = () => { };
|
|
38
|
+
// eslint-disable-next-line @typescript-eslint/no-empty-function
|
|
39
|
+
this.onValidatorChangeFn = () => { };
|
|
31
40
|
}
|
|
32
41
|
get fromCtrl() {
|
|
33
42
|
return this.fromToFormControl.get('from');
|
|
@@ -40,9 +49,9 @@ export class DateRangeComponent {
|
|
|
40
49
|
}
|
|
41
50
|
ngOnInit() {
|
|
42
51
|
this.fromToFormControl = this.formBuilder.group({
|
|
43
|
-
from: [],
|
|
44
|
-
to: [],
|
|
45
|
-
dateRange: []
|
|
52
|
+
from: [null, Validators.required],
|
|
53
|
+
to: [null, Validators.required],
|
|
54
|
+
dateRange: [null, Validators.required]
|
|
46
55
|
});
|
|
47
56
|
effect(() => {
|
|
48
57
|
this.setDisabledState(this.disabled());
|
|
@@ -57,6 +66,9 @@ export class DateRangeComponent {
|
|
|
57
66
|
registerOnTouched(fn) {
|
|
58
67
|
this.onTouchedFn = fn;
|
|
59
68
|
}
|
|
69
|
+
registerOnValidatorChange(fn) {
|
|
70
|
+
this.onValidatorChangeFn = fn;
|
|
71
|
+
}
|
|
60
72
|
setDisabledState(isDisabled) {
|
|
61
73
|
if (isDisabled && this.fromToFormControl?.enabled) {
|
|
62
74
|
this.fromToFormControl.disable();
|
|
@@ -83,15 +95,34 @@ export class DateRangeComponent {
|
|
|
83
95
|
startDate = new Date(obj);
|
|
84
96
|
}
|
|
85
97
|
if (this.showTime()) {
|
|
86
|
-
this.fromCtrl.setValue(startDate);
|
|
87
|
-
this.toCtrl.setValue(endDate);
|
|
98
|
+
this.fromCtrl.setValue(startDate, { emitEvent: false });
|
|
99
|
+
this.toCtrl.setValue(endDate, { emitEvent: false });
|
|
88
100
|
}
|
|
89
101
|
else if (startDate || endDate) {
|
|
90
|
-
this.dateRangeCtrl.setValue([startDate, endDate]);
|
|
102
|
+
this.dateRangeCtrl.setValue([startDate, endDate], { emitEvent: false });
|
|
103
|
+
}
|
|
104
|
+
else {
|
|
105
|
+
this.dateRangeCtrl.setValue(null, { emitEvent: false });
|
|
106
|
+
}
|
|
107
|
+
}
|
|
108
|
+
validate() {
|
|
109
|
+
if (!this.required())
|
|
110
|
+
return null;
|
|
111
|
+
if (this.showTime()) {
|
|
112
|
+
if (this.fromCtrl.hasError('required') || this.toCtrl.hasError('required')) {
|
|
113
|
+
return {
|
|
114
|
+
required: true
|
|
115
|
+
};
|
|
116
|
+
}
|
|
91
117
|
}
|
|
92
118
|
else {
|
|
93
|
-
this.dateRangeCtrl.
|
|
119
|
+
if (this.dateRangeCtrl.hasError('required')) {
|
|
120
|
+
return {
|
|
121
|
+
required: true
|
|
122
|
+
};
|
|
123
|
+
}
|
|
94
124
|
}
|
|
125
|
+
return null;
|
|
95
126
|
}
|
|
96
127
|
onValueChange() {
|
|
97
128
|
if (this.showTime()) {
|
|
@@ -105,12 +136,12 @@ export class DateRangeComponent {
|
|
|
105
136
|
}
|
|
106
137
|
}
|
|
107
138
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.5", ngImport: i0, type: DateRangeComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
108
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.0.5", type: DateRangeComponent, isStandalone: true, selector: "mng-date-range", inputs: { placeholder: { classPropertyName: "placeholder", publicName: "placeholder", isSignal: true, isRequired: false, transformFunction: null }, showTime: { classPropertyName: "showTime", publicName: "showTime", isSignal: true, isRequired: false, transformFunction: null }, showSeconds: { classPropertyName: "showSeconds", publicName: "showSeconds", isSignal: true, isRequired: false, transformFunction: null }, dateFormat: { classPropertyName: "dateFormat", publicName: "dateFormat", isSignal: true, isRequired: false, transformFunction: null }, className: { classPropertyName: "className", publicName: "className", isSignal: true, isRequired: false, transformFunction: null }, disabled: { classPropertyName: "disabled", publicName: "disabled", isSignal: true, isRequired: false, transformFunction: null } }, host: { properties: { "class": "className()" } }, providers: [DATE_RANGE_VALUE_ACCESSOR], ngImport: i0, template: "@if (showTime()) {\n <div class=\"flex gap-2\">\n <p-calendar\n appendTo=\"body\"\n [formControl]=\"fromCtrl\"\n [maxDate]=\"toCtrl.value\"\n [placeholder]=\"placeholder()\"\n [dateFormat]=\"dateFormat()\"\n [showTime]=\"true\"\n [showSeconds]=\"showSeconds()\"\n [showIcon]=\"true\"\n [firstDayOfWeek]=\"1\"\n (onBlur)=\"onBlur()\"></p-calendar>\n <p-calendar\n appendTo=\"body\"\n [formControl]=\"toCtrl\"\n [minDate]=\"fromCtrl.value\"\n [placeholder]=\"placeholder()\"\n [dateFormat]=\"dateFormat()\"\n [showTime]=\"true\"\n [showSeconds]=\"showSeconds()\"\n [showIcon]=\"true\"\n [firstDayOfWeek]=\"1\"\n (onBlur)=\"onBlur()\"></p-calendar>\n </div>\n} @else {\n <p-calendar\n appendTo=\"body\"\n [formControl]=\"dateRangeCtrl\"\n [placeholder]=\"placeholder()\"\n [dateFormat]=\"dateFormat()\"\n selectionMode=\"range\"\n [showIcon]=\"true\"\n [firstDayOfWeek]=\"1\"\n (onBlur)=\"onBlur()\"></p-calendar>\n}\n", dependencies: [{ kind: "ngmodule", type: CalendarModule }, { kind: "component", type:
|
|
139
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.0.5", type: DateRangeComponent, isStandalone: true, selector: "mng-date-range", inputs: { placeholder: { classPropertyName: "placeholder", publicName: "placeholder", isSignal: true, isRequired: false, transformFunction: null }, showTime: { classPropertyName: "showTime", publicName: "showTime", isSignal: true, isRequired: false, transformFunction: null }, showSeconds: { classPropertyName: "showSeconds", publicName: "showSeconds", isSignal: true, isRequired: false, transformFunction: null }, dateFormat: { classPropertyName: "dateFormat", publicName: "dateFormat", isSignal: true, isRequired: false, transformFunction: null }, className: { classPropertyName: "className", publicName: "className", isSignal: true, isRequired: false, transformFunction: null }, required: { classPropertyName: "required", publicName: "required", isSignal: true, isRequired: false, transformFunction: null }, disabled: { classPropertyName: "disabled", publicName: "disabled", isSignal: true, isRequired: false, transformFunction: null } }, host: { properties: { "class": "className()" } }, providers: [DATE_RANGE_VALUE_ACCESSOR, DATE_RANGE_VALIDATOR], ngImport: i0, template: "@if (showTime()) {\n <div class=\"flex gap-2\">\n <p-calendar\n appendTo=\"body\"\n [formControl]=\"fromCtrl\"\n [maxDate]=\"toCtrl.value\"\n [placeholder]=\"placeholder()\"\n [dateFormat]=\"dateFormat()\"\n [showTime]=\"true\"\n [showSeconds]=\"showSeconds()\"\n [showIcon]=\"true\"\n [firstDayOfWeek]=\"1\"\n (onBlur)=\"onBlur()\"></p-calendar>\n <p-calendar\n appendTo=\"body\"\n [formControl]=\"toCtrl\"\n [minDate]=\"fromCtrl.value\"\n [placeholder]=\"placeholder()\"\n [dateFormat]=\"dateFormat()\"\n [showTime]=\"true\"\n [showSeconds]=\"showSeconds()\"\n [showIcon]=\"true\"\n [firstDayOfWeek]=\"1\"\n (onBlur)=\"onBlur()\"></p-calendar>\n </div>\n} @else {\n <p-calendar\n appendTo=\"body\"\n [formControl]=\"dateRangeCtrl\"\n [placeholder]=\"placeholder()\"\n [dateFormat]=\"dateFormat()\"\n selectionMode=\"range\"\n [showIcon]=\"true\"\n [firstDayOfWeek]=\"1\"\n (onBlur)=\"onBlur()\"></p-calendar>\n}\n", dependencies: [{ kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "ngmodule", type: CalendarModule }, { 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: "ngmodule", type: ReactiveFormsModule }, { kind: "directive", type: i1.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
109
140
|
}
|
|
110
141
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.5", ngImport: i0, type: DateRangeComponent, decorators: [{
|
|
111
142
|
type: Component,
|
|
112
|
-
args: [{ standalone: true, selector: 'mng-date-range', providers: [DATE_RANGE_VALUE_ACCESSOR], imports: [CalendarModule, ReactiveFormsModule], changeDetection: ChangeDetectionStrategy.OnPush, host: {
|
|
143
|
+
args: [{ standalone: true, selector: 'mng-date-range', providers: [DATE_RANGE_VALUE_ACCESSOR, DATE_RANGE_VALIDATOR], imports: [FormsModule, CalendarModule, ReactiveFormsModule], changeDetection: ChangeDetectionStrategy.OnPush, host: {
|
|
113
144
|
'[class]': 'className()'
|
|
114
145
|
}, template: "@if (showTime()) {\n <div class=\"flex gap-2\">\n <p-calendar\n appendTo=\"body\"\n [formControl]=\"fromCtrl\"\n [maxDate]=\"toCtrl.value\"\n [placeholder]=\"placeholder()\"\n [dateFormat]=\"dateFormat()\"\n [showTime]=\"true\"\n [showSeconds]=\"showSeconds()\"\n [showIcon]=\"true\"\n [firstDayOfWeek]=\"1\"\n (onBlur)=\"onBlur()\"></p-calendar>\n <p-calendar\n appendTo=\"body\"\n [formControl]=\"toCtrl\"\n [minDate]=\"fromCtrl.value\"\n [placeholder]=\"placeholder()\"\n [dateFormat]=\"dateFormat()\"\n [showTime]=\"true\"\n [showSeconds]=\"showSeconds()\"\n [showIcon]=\"true\"\n [firstDayOfWeek]=\"1\"\n (onBlur)=\"onBlur()\"></p-calendar>\n </div>\n} @else {\n <p-calendar\n appendTo=\"body\"\n [formControl]=\"dateRangeCtrl\"\n [placeholder]=\"placeholder()\"\n [dateFormat]=\"dateFormat()\"\n selectionMode=\"range\"\n [showIcon]=\"true\"\n [firstDayOfWeek]=\"1\"\n (onBlur)=\"onBlur()\"></p-calendar>\n}\n" }]
|
|
115
146
|
}] });
|
|
116
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"date-range.component.js","sourceRoot":"","sources":["../../../../../form/src/components/date-range/date-range.component.ts","../../../../../form/src/components/date-range/date-range.component.html"],"names":[],"mappings":"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","sourcesContent":["import {ChangeDetectionStrategy, Component, DestroyRef, ExistingProvider, Injector, OnInit, booleanAttribute, effect, forwardRef, inject, input} from '@angular/core';\nimport {takeUntilDestroyed} from '@angular/core/rxjs-interop';\nimport {ControlValueAccessor, FormBuilder, FormControl, FormGroup, NG_VALUE_ACCESSOR, ReactiveFormsModule} from '@angular/forms';\n\nimport {CalendarModule} from 'primeng/calendar';\nimport {merge} from 'rxjs';\n\nexport const DATE_RANGE_VALUE_ACCESSOR: ExistingProvider = {\n    provide: NG_VALUE_ACCESSOR,\n    useExisting: forwardRef(() => DateRangeComponent),\n    multi: true\n};\n\n@Component({\n    standalone: true,\n    selector: 'mng-date-range',\n    templateUrl: './date-range.component.html',\n    providers: [DATE_RANGE_VALUE_ACCESSOR],\n    imports: [CalendarModule, ReactiveFormsModule],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    host: {\n        '[class]': 'className()'\n    }\n})\nexport class DateRangeComponent implements OnInit, ControlValueAccessor {\n    private readonly formBuilder = inject(FormBuilder);\n    private readonly injector = inject(Injector);\n    private readonly destroyRef = inject(DestroyRef);\n\n    public placeholder = input<string>();\n    public showTime = input(false);\n    public showSeconds = input(false);\n    public dateFormat = input<string>();\n    public className = input<string>();\n\n    public disabled = input(false, {\n        transform: booleanAttribute\n    });\n\n    private fromToFormControl!: FormGroup;\n\n    // eslint-disable-next-line @typescript-eslint/no-empty-function\n    private onChangeFn: any = () => {};\n    // eslint-disable-next-line @typescript-eslint/no-empty-function\n    private onTouchedFn: any = () => {};\n\n    public get fromCtrl() {\n        return this.fromToFormControl.get('from') as FormControl;\n    }\n\n    public get toCtrl() {\n        return this.fromToFormControl.get('to') as FormControl;\n    }\n\n    public get dateRangeCtrl() {\n        return this.fromToFormControl.get('dateRange') as FormControl;\n    }\n\n    ngOnInit() {\n        this.fromToFormControl = this.formBuilder.group({\n            from: [],\n            to: [],\n            dateRange: []\n        });\n\n        effect(\n            () => {\n                this.setDisabledState(this.disabled());\n            },\n            {injector: this.injector}\n        );\n\n        merge(this.fromCtrl.valueChanges, this.toCtrl.valueChanges, this.dateRangeCtrl.valueChanges)\n            .pipe(takeUntilDestroyed(this.destroyRef))\n            .subscribe(() => this.onValueChange());\n    }\n\n    registerOnChange(fn: any): void {\n        this.onChangeFn = fn;\n    }\n\n    registerOnTouched(fn: any): void {\n        this.onTouchedFn = fn;\n    }\n\n    setDisabledState(isDisabled: boolean): void {\n        if (isDisabled && this.fromToFormControl?.enabled) {\n            this.fromToFormControl.disable();\n        } else if (!isDisabled && this.fromToFormControl?.disabled) {\n            this.fromToFormControl.enable();\n        }\n    }\n\n    onBlur() {\n        this.onTouchedFn();\n    }\n\n    writeValue(obj: any): void {\n        let startDate: Date | null = null;\n        let endDate: Date | null = null;\n\n        if (Array.isArray(obj)) {\n            if (obj.length > 0 && (obj[0] instanceof Date || typeof obj[0] === 'string' || typeof obj[0] === 'number')) {\n                startDate = new Date(obj[0]);\n            }\n            if (obj.length > 1 && (obj[1] instanceof Date || typeof obj[1] === 'string' || typeof obj[1] === 'number')) {\n                endDate = new Date(obj[1]);\n            }\n        } else if (obj instanceof Date || typeof obj === 'string' || typeof obj === 'number') {\n            startDate = new Date(obj);\n        }\n\n        if (this.showTime()) {\n            this.fromCtrl.setValue(startDate);\n            this.toCtrl.setValue(endDate);\n        } else if (startDate || endDate) {\n            this.dateRangeCtrl.setValue([startDate, endDate]);\n        } else {\n            this.dateRangeCtrl.setValue(null);\n        }\n    }\n\n    private onValueChange() {\n        if (this.showTime()) {\n            const fromDate = this.fromCtrl.value as Date;\n            const toDate = this.toCtrl.value as Date;\n            this.onChangeFn([fromDate, toDate]);\n        } else {\n            const date = this.dateRangeCtrl.value as Date[];\n            this.onChangeFn(date);\n        }\n    }\n}\n","@if (showTime()) {\n    <div class=\"flex gap-2\">\n        <p-calendar\n            appendTo=\"body\"\n            [formControl]=\"fromCtrl\"\n            [maxDate]=\"toCtrl.value\"\n            [placeholder]=\"placeholder()\"\n            [dateFormat]=\"dateFormat()\"\n            [showTime]=\"true\"\n            [showSeconds]=\"showSeconds()\"\n            [showIcon]=\"true\"\n            [firstDayOfWeek]=\"1\"\n            (onBlur)=\"onBlur()\"></p-calendar>\n        <p-calendar\n            appendTo=\"body\"\n            [formControl]=\"toCtrl\"\n            [minDate]=\"fromCtrl.value\"\n            [placeholder]=\"placeholder()\"\n            [dateFormat]=\"dateFormat()\"\n            [showTime]=\"true\"\n            [showSeconds]=\"showSeconds()\"\n            [showIcon]=\"true\"\n            [firstDayOfWeek]=\"1\"\n            (onBlur)=\"onBlur()\"></p-calendar>\n    </div>\n} @else {\n    <p-calendar\n        appendTo=\"body\"\n        [formControl]=\"dateRangeCtrl\"\n        [placeholder]=\"placeholder()\"\n        [dateFormat]=\"dateFormat()\"\n        selectionMode=\"range\"\n        [showIcon]=\"true\"\n        [firstDayOfWeek]=\"1\"\n        (onBlur)=\"onBlur()\"></p-calendar>\n}\n"]}
|
|
147
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"date-range.component.js","sourceRoot":"","sources":["../../../../../form/src/components/date-range/date-range.component.ts","../../../../../form/src/components/date-range/date-range.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Component,\n    DestroyRef,\n    ExistingProvider,\n    Injector,\n    OnInit,\n    booleanAttribute,\n    effect,\n    forwardRef,\n    inject,\n    input\n} from '@angular/core';\nimport {takeUntilDestroyed} from '@angular/core/rxjs-interop';\nimport {\n    ControlValueAccessor,\n    FormBuilder,\n    FormControl,\n    FormGroup,\n    FormsModule,\n    NG_VALIDATORS,\n    NG_VALUE_ACCESSOR,\n    ReactiveFormsModule,\n    ValidationErrors,\n    Validator,\n    Validators\n} from '@angular/forms';\n\nimport {CalendarModule} from 'primeng/calendar';\nimport {merge} from 'rxjs';\n\nexport const DATE_RANGE_VALUE_ACCESSOR: ExistingProvider = {\n    provide: NG_VALUE_ACCESSOR,\n    useExisting: forwardRef(() => DateRangeComponent),\n    multi: true\n};\n\nexport const DATE_RANGE_VALIDATOR: ExistingProvider = {\n    provide: NG_VALIDATORS,\n    useExisting: forwardRef(() => DateRangeComponent),\n    multi: true\n};\n\n@Component({\n    standalone: true,\n    selector: 'mng-date-range',\n    templateUrl: './date-range.component.html',\n    providers: [DATE_RANGE_VALUE_ACCESSOR, DATE_RANGE_VALIDATOR],\n    imports: [FormsModule, CalendarModule, ReactiveFormsModule],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    host: {\n        '[class]': 'className()'\n    }\n})\nexport class DateRangeComponent implements OnInit, ControlValueAccessor, Validator {\n    private readonly formBuilder = inject(FormBuilder);\n    private readonly injector = inject(Injector);\n    private readonly destroyRef = inject(DestroyRef);\n    private readonly cdr = inject(ChangeDetectorRef);\n\n    public placeholder = input<string>();\n    public showTime = input(false);\n    public showSeconds = input(false);\n    public dateFormat = input<string>();\n    public className = input<string>();\n    public required = input(false, {transform: booleanAttribute});\n    public disabled = input(false, {\n        transform: booleanAttribute\n    });\n\n    private fromToFormControl!: FormGroup;\n\n    // eslint-disable-next-line @typescript-eslint/no-empty-function\n    private onChangeFn: any = () => {};\n    // eslint-disable-next-line @typescript-eslint/no-empty-function\n    private onTouchedFn: any = () => {};\n    // eslint-disable-next-line @typescript-eslint/no-empty-function\n    private onValidatorChangeFn: any = () => {};\n\n    public get fromCtrl() {\n        return this.fromToFormControl.get('from') as FormControl;\n    }\n\n    public get toCtrl() {\n        return this.fromToFormControl.get('to') as FormControl;\n    }\n\n    public get dateRangeCtrl() {\n        return this.fromToFormControl.get('dateRange') as FormControl;\n    }\n\n    ngOnInit() {\n        this.fromToFormControl = this.formBuilder.group({\n            from: [null, Validators.required],\n            to: [null, Validators.required],\n            dateRange: [null, Validators.required]\n        });\n\n        effect(\n            () => {\n                this.setDisabledState(this.disabled());\n            },\n            {injector: this.injector}\n        );\n\n        merge(this.fromCtrl.valueChanges, this.toCtrl.valueChanges, this.dateRangeCtrl.valueChanges)\n            .pipe(takeUntilDestroyed(this.destroyRef))\n            .subscribe(() => this.onValueChange());\n    }\n\n    registerOnChange(fn: any): void {\n        this.onChangeFn = fn;\n    }\n\n    registerOnTouched(fn: any): void {\n        this.onTouchedFn = fn;\n    }\n\n    registerOnValidatorChange?(fn: () => void): void {\n        this.onValidatorChangeFn = fn;\n    }\n\n    setDisabledState(isDisabled: boolean): void {\n        if (isDisabled && this.fromToFormControl?.enabled) {\n            this.fromToFormControl.disable();\n        } else if (!isDisabled && this.fromToFormControl?.disabled) {\n            this.fromToFormControl.enable();\n        }\n    }\n\n    onBlur() {\n        this.onTouchedFn();\n    }\n\n    writeValue(obj: any): void {\n        let startDate: Date | null = null;\n        let endDate: Date | null = null;\n\n        if (Array.isArray(obj)) {\n            if (obj.length > 0 && (obj[0] instanceof Date || typeof obj[0] === 'string' || typeof obj[0] === 'number')) {\n                startDate = new Date(obj[0]);\n            }\n            if (obj.length > 1 && (obj[1] instanceof Date || typeof obj[1] === 'string' || typeof obj[1] === 'number')) {\n                endDate = new Date(obj[1]);\n            }\n        } else if (obj instanceof Date || typeof obj === 'string' || typeof obj === 'number') {\n            startDate = new Date(obj);\n        }\n\n        if (this.showTime()) {\n            this.fromCtrl.setValue(startDate, {emitEvent: false});\n            this.toCtrl.setValue(endDate, {emitEvent: false});\n        } else if (startDate || endDate) {\n            this.dateRangeCtrl.setValue([startDate, endDate], {emitEvent: false});\n        } else {\n            this.dateRangeCtrl.setValue(null, {emitEvent: false});\n        }\n    }\n\n    validate(): ValidationErrors | null {\n        if (!this.required()) return null;\n\n        if (this.showTime()) {\n            if (this.fromCtrl.hasError('required') || this.toCtrl.hasError('required')) {\n                return {\n                    required: true\n                };\n            }\n        } else {\n            if (this.dateRangeCtrl.hasError('required')) {\n                return {\n                    required: true\n                };\n            }\n        }\n\n        return null;\n    }\n\n    private onValueChange() {\n        if (this.showTime()) {\n            const fromDate = this.fromCtrl.value as Date;\n            const toDate = this.toCtrl.value as Date;\n            this.onChangeFn([fromDate, toDate]);\n        } else {\n            const date = this.dateRangeCtrl.value as Date[];\n            this.onChangeFn(date);\n        }\n    }\n}\n","@if (showTime()) {\n    <div class=\"flex gap-2\">\n        <p-calendar\n            appendTo=\"body\"\n            [formControl]=\"fromCtrl\"\n            [maxDate]=\"toCtrl.value\"\n            [placeholder]=\"placeholder()\"\n            [dateFormat]=\"dateFormat()\"\n            [showTime]=\"true\"\n            [showSeconds]=\"showSeconds()\"\n            [showIcon]=\"true\"\n            [firstDayOfWeek]=\"1\"\n            (onBlur)=\"onBlur()\"></p-calendar>\n        <p-calendar\n            appendTo=\"body\"\n            [formControl]=\"toCtrl\"\n            [minDate]=\"fromCtrl.value\"\n            [placeholder]=\"placeholder()\"\n            [dateFormat]=\"dateFormat()\"\n            [showTime]=\"true\"\n            [showSeconds]=\"showSeconds()\"\n            [showIcon]=\"true\"\n            [firstDayOfWeek]=\"1\"\n            (onBlur)=\"onBlur()\"></p-calendar>\n    </div>\n} @else {\n    <p-calendar\n        appendTo=\"body\"\n        [formControl]=\"dateRangeCtrl\"\n        [placeholder]=\"placeholder()\"\n        [dateFormat]=\"dateFormat()\"\n        selectionMode=\"range\"\n        [showIcon]=\"true\"\n        [firstDayOfWeek]=\"1\"\n        (onBlur)=\"onBlur()\"></p-calendar>\n}\n"]}
|