@mediusinc/mng-commons 5.3.0-rc.0 → 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.
Files changed (101) hide show
  1. package/core/components/pages/error/error.page.component.d.ts +3 -0
  2. package/core/components/pages/not-found/not-found.page.component.d.ts +3 -0
  3. package/core/data-list/filter-metadata.model.d.ts +20 -0
  4. package/core/enum/enum-helpers.d.ts +5 -0
  5. package/core/helpers/number.d.ts +5 -0
  6. package/core/helpers/type-helpers.d.ts +1 -0
  7. package/core/index.d.ts +3 -1
  8. package/core/provide.d.ts +3 -2
  9. package/core/services/{local-storage-config.service.d.ts → commons-storage.service.d.ts} +4 -3
  10. package/core/services/commons.service.d.ts +24 -0
  11. package/core/services/tokens/module-config.token.d.ts +30 -8
  12. package/esm2022/core/components/pages/error/error.page.component.mjs +4 -1
  13. package/esm2022/core/components/pages/not-found/not-found.page.component.mjs +4 -1
  14. package/esm2022/core/data-list/data-list-params-helpers.mjs +3 -1
  15. package/esm2022/core/data-list/filter-metadata.model.mjs +2 -0
  16. package/esm2022/core/enum/enum-helpers.mjs +10 -1
  17. package/esm2022/core/helpers/date.mjs +2 -2
  18. package/esm2022/core/helpers/number.mjs +19 -0
  19. package/esm2022/core/helpers/type-helpers.mjs +1 -1
  20. package/esm2022/core/index.mjs +4 -2
  21. package/esm2022/core/pipes/boolean.pipe.mjs +7 -1
  22. package/esm2022/core/pipes/enum.pipe.mjs +16 -5
  23. package/esm2022/core/provide.mjs +6 -5
  24. package/esm2022/core/router/route-builder.mjs +8 -1
  25. package/esm2022/core/security/permission.guard.mjs +2 -2
  26. package/esm2022/core/security/permission.service.mjs +2 -2
  27. package/esm2022/core/services/commons-storage.service.mjs +31 -0
  28. package/esm2022/core/services/commons.service.mjs +25 -1
  29. package/esm2022/core/services/tokens/module-config.token.mjs +1 -1
  30. package/esm2022/filter/descriptors/filter-lookup.descriptor.mjs +2 -3
  31. package/esm2022/filter/descriptors/filter.descriptor.mjs +76 -31
  32. package/esm2022/filter/models/filter.model.mjs +6 -1
  33. package/esm2022/form/components/date-range/date-range.component.mjs +45 -14
  34. package/esm2022/form/components/dropdown/dropdown.component.mjs +77 -93
  35. package/esm2022/form/components/number-range/number-range.component.mjs +29 -12
  36. package/esm2022/table/api/descriptors/column.descriptor.mjs +2 -1
  37. package/esm2022/table/api/descriptors/table.descriptor.mjs +11 -20
  38. package/esm2022/table/api/models/table-columns.model.mjs +1 -1
  39. package/esm2022/table/api/models/table.model.mjs +1 -1
  40. package/esm2022/table/components/column-filter/column-filter.component.mjs +396 -0
  41. package/esm2022/table/components/filter/filter-active-tag/filter-active-tag.component.mjs +52 -0
  42. package/esm2022/table/components/filter/filter-form/filter-form.component.mjs +197 -0
  43. package/esm2022/table/components/filter/filter-overlay-with-tag/filter-overlay-with-tag.component.mjs +135 -0
  44. package/esm2022/table/components/table/table.component.mjs +39 -30
  45. package/esm2022/table/helpers/filters.mjs +297 -0
  46. package/esm2022/table/index.mjs +13 -2
  47. package/esm2022/table/models/filter.model.mjs +2 -0
  48. package/esm2022/table/pipes/filter-value.pipe.mjs +77 -0
  49. package/esm2022/table/provide.mjs +19 -0
  50. package/esm2022/table/services/data-list.service.mjs +1 -1
  51. package/esm2022/table/services/table-feature-config.token.mjs +3 -0
  52. package/esm2022/tableview/action/components/editor/injector-context/action-editor-injector-context.component.mjs +2 -2
  53. package/esm2022/tableview/action/components/localization/data-language-dropdown.component.mjs +2 -2
  54. package/esm2022/tableview/api/editor/descriptors/field.descriptor.mjs +1 -1
  55. package/esm2022/tableview/api/editor/models/editor-fields.model.mjs +1 -1
  56. package/esm2022/tableview/api/tableview/descriptors/tableview.descriptor.mjs +11 -13
  57. package/esm2022/tableview/editor/components/formly/fields/formly-field-dropdown/formly-field-dropdown.component.mjs +2 -2
  58. package/esm2022/tableview/tableview/components/tableview/tableview.component.mjs +3 -4
  59. package/fesm2022/mediusinc-mng-commons-core.mjs +103 -17
  60. package/fesm2022/mediusinc-mng-commons-core.mjs.map +1 -1
  61. package/fesm2022/mediusinc-mng-commons-filter.mjs +81 -32
  62. package/fesm2022/mediusinc-mng-commons-filter.mjs.map +1 -1
  63. package/fesm2022/mediusinc-mng-commons-form.mjs +149 -117
  64. package/fesm2022/mediusinc-mng-commons-form.mjs.map +1 -1
  65. package/fesm2022/mediusinc-mng-commons-table-api.mjs +11 -19
  66. package/fesm2022/mediusinc-mng-commons-table-api.mjs.map +1 -1
  67. package/fesm2022/mediusinc-mng-commons-table.mjs +836 -363
  68. package/fesm2022/mediusinc-mng-commons-table.mjs.map +1 -1
  69. package/fesm2022/mediusinc-mng-commons-tableview-api.mjs +10 -12
  70. package/fesm2022/mediusinc-mng-commons-tableview-api.mjs.map +1 -1
  71. package/fesm2022/mediusinc-mng-commons-tableview.mjs +5 -5
  72. package/fesm2022/mediusinc-mng-commons-tableview.mjs.map +1 -1
  73. package/filter/descriptors/filter.descriptor.d.ts +60 -16
  74. package/filter/models/filter.model.d.ts +4 -0
  75. package/form/components/date-range/date-range.component.d.ts +9 -3
  76. package/form/components/dropdown/dropdown.component.d.ts +6 -7
  77. package/form/components/number-range/number-range.component.d.ts +8 -4
  78. package/i18n/en.json +40 -0
  79. package/i18n/sl.json +40 -0
  80. package/package.json +7 -7
  81. package/table/api/descriptors/table.descriptor.d.ts +7 -7
  82. package/table/api/models/table-columns.model.d.ts +3 -3
  83. package/table/api/models/table.model.d.ts +0 -12
  84. package/table/components/{column-filter-full/column-filter-full.component.d.ts → column-filter/column-filter.component.d.ts} +23 -38
  85. package/table/components/filter/filter-active-tag/filter-active-tag.component.d.ts +20 -0
  86. package/table/components/filter/filter-form/filter-form.component.d.ts +53 -0
  87. package/table/components/filter/filter-overlay-with-tag/filter-overlay-with-tag.component.d.ts +35 -0
  88. package/table/components/table/table.component.d.ts +11 -8
  89. package/table/helpers/filters.d.ts +31 -0
  90. package/table/index.d.ts +10 -1
  91. package/table/models/filter.model.d.ts +24 -0
  92. package/table/pipes/filter-value.pipe.d.ts +19 -0
  93. package/table/provide.d.ts +8 -0
  94. package/table/services/data-list.service.d.ts +3 -2
  95. package/table/services/table-feature-config.token.d.ts +6 -0
  96. package/tableview/api/editor/descriptors/field.descriptor.d.ts +3 -3
  97. package/tableview/api/editor/models/editor-fields.model.d.ts +4 -4
  98. package/tableview/api/tableview/descriptors/tableview.descriptor.d.ts +8 -6
  99. package/version-info.json +5 -5
  100. package/esm2022/core/services/local-storage-config.service.mjs +0 -29
  101. package/esm2022/table/components/column-filter-full/column-filter-full.component.mjs +0 -655
@@ -1,16 +1,12 @@
1
1
  import { CommonsInternalError, LoggerService } from '@mediusinc/mng-commons/core';
2
- import { FilterTypeEnum } from '../models/filter.model';
2
+ import { FilterDisplayTypeEnum, FilterTypeEnum } from '../models/filter.model';
3
3
  export class FilterDescriptor {
4
4
  constructor(property) {
5
5
  this._filterType = FilterTypeEnum.String;
6
+ // default value
6
7
  this._hasDefaultValue = false;
7
8
  this._matchModes = null;
8
9
  this._numberUseGrouping = true;
9
- this._datePickerShowTime = false;
10
- this._datePickerShowSeconds = false;
11
- this._datePickerValueNoTime = undefined;
12
- this._datePickerValueNoTimezone = undefined;
13
- this._datePickerValueUtc = undefined;
14
10
  this._className = '';
15
11
  this._columnClassName = '';
16
12
  this._columnWidth = null;
@@ -24,6 +20,9 @@ export class FilterDescriptor {
24
20
  get showOnColumn() {
25
21
  return this._showOnColumn;
26
22
  }
23
+ get displayType() {
24
+ return this._displayType;
25
+ }
27
26
  get hasDefaultValue() {
28
27
  return this._hasDefaultValue;
29
28
  }
@@ -36,6 +35,15 @@ export class FilterDescriptor {
36
35
  get matchModes() {
37
36
  return this._matchModes;
38
37
  }
38
+ get displayFormat() {
39
+ return this._displayFormat;
40
+ }
41
+ get displayFormatApplyToField() {
42
+ return this._displayFormatApplyToField;
43
+ }
44
+ get locale() {
45
+ return this._locale;
46
+ }
39
47
  get numberMinFractionDigits() {
40
48
  return this._numberMinFractionDigits;
41
49
  }
@@ -54,14 +62,14 @@ export class FilterDescriptor {
54
62
  get datePickerShowSeconds() {
55
63
  return this._datePickerShowSeconds;
56
64
  }
57
- get datePickerValueUtc() {
58
- return this._datePickerValueUtc;
65
+ get dateValueUtc() {
66
+ return this._dateValueUtc;
59
67
  }
60
- get datePickerValueNoTimezone() {
61
- return this._datePickerValueNoTimezone;
68
+ get dateValueNoTimezone() {
69
+ return this._dateValueNoTimezone;
62
70
  }
63
- get datePickerValueNoTime() {
64
- return this._datePickerValueNoTime;
71
+ get dateValueNoTime() {
72
+ return this._dateValueNoTime;
65
73
  }
66
74
  get placeholder() {
67
75
  return this._placeholder;
@@ -84,15 +92,33 @@ export class FilterDescriptor {
84
92
  get property() {
85
93
  return this._property;
86
94
  }
95
+ get title() {
96
+ return this._title;
97
+ }
87
98
  asFilterType(filterType) {
88
99
  this._filterType = filterType;
89
100
  return this;
90
101
  }
91
- withShowOnColumn(property) {
92
- return this.withShowOnColumnUnsafe(property);
102
+ asDate(opts) {
103
+ this._filterType = FilterTypeEnum.Date;
104
+ this.withDisplayFormat(opts?.displayFormat).withDatePickerDisplay(opts).withDateValue(opts);
105
+ return this;
106
+ }
107
+ asNumber(opts) {
108
+ this._filterType = FilterTypeEnum.Number;
109
+ this.withDisplayFormat(opts?.displayFormat).withNumberFractions(opts?.minFractionDigits, opts?.maxFractionDigits).withLocale(opts?.locale);
110
+ return this;
111
+ }
112
+ withShowOnColumn(property, displayType = FilterDisplayTypeEnum.Column) {
113
+ return this.withShowOnColumnUnsafe(property, displayType);
114
+ }
115
+ withDisplayType(type) {
116
+ this._displayType = type;
117
+ return this;
93
118
  }
94
- withShowOnColumnUnsafe(property) {
119
+ withShowOnColumnUnsafe(property, displayType = FilterDisplayTypeEnum.Column) {
95
120
  this._showOnColumn = property;
121
+ this._displayType = displayType;
96
122
  return this;
97
123
  }
98
124
  withDefaultFilter(value, matchMode) {
@@ -103,10 +129,10 @@ export class FilterDescriptor {
103
129
  return this;
104
130
  }
105
131
  validateDefaultFilter(value, matchMode) {
106
- if (matchMode === 'between' && (!Array.isArray(value) || value.filter(v => v != null).length !== 2)) {
132
+ if (matchMode === 'between' && value != null && (!Array.isArray(value) || value.filter(v => v != null).length !== 2)) {
107
133
  throw new CommonsInternalError(`Default value for filter match mode ${matchMode} must provide exactly 2 values in array`);
108
134
  }
109
- if ((matchMode === 'in' || matchMode === 'notIn') && (!Array.isArray(value) || value.filter(v => v != null).length === 0)) {
135
+ if ((matchMode === 'in' || matchMode === 'notIn') && value != null && (!Array.isArray(value) || value.filter(v => v != null).length === 0)) {
110
136
  throw new CommonsInternalError(`Default value for filter match mode ${matchMode} must be array and provide at least 1 non-null value`);
111
137
  }
112
138
  if (matchMode === 'exists' || matchMode === 'doesNotExist') {
@@ -117,6 +143,15 @@ export class FilterDescriptor {
117
143
  LoggerService.get().debug(`WARNING: Default filter match mode '${matchMode}' could not be assigned for property ${this._property}.`);
118
144
  }
119
145
  }
146
+ withDisplayFormat(format, applyToField) {
147
+ this._displayFormat = format;
148
+ this._displayFormatApplyToField = applyToField;
149
+ return this;
150
+ }
151
+ withLocale(locale) {
152
+ this._locale = locale;
153
+ return this;
154
+ }
120
155
  withNumberFractions(min, max) {
121
156
  this._numberMinFractionDigits = min;
122
157
  this._numberMaxFractionDigits = max;
@@ -126,22 +161,26 @@ export class FilterDescriptor {
126
161
  this._numberUseGrouping = useGrouping;
127
162
  return this;
128
163
  }
164
+ /**
165
+ * @deprecated Use ${withDatePickerDisplay} instead.
166
+ */
129
167
  withDateFormat(format, showTime = false, showSeconds = false) {
130
168
  this._datePickerFormat = format;
131
169
  this._datePickerShowTime = showTime;
132
170
  this._datePickerShowSeconds = showSeconds;
133
171
  return this;
134
172
  }
135
- withDateValue(utc, noTimezone, noTime) {
136
- if (typeof utc !== 'undefined') {
137
- this._datePickerValueUtc = utc;
138
- }
139
- if (typeof noTimezone !== 'undefined') {
140
- this._datePickerValueNoTimezone = noTimezone;
141
- }
142
- if (typeof noTime !== 'undefined') {
143
- this._datePickerValueNoTime = noTime;
144
- }
173
+ withDatePickerDisplay(opts) {
174
+ this._displayFormatApplyToField = opts?.applyFromDisplayFormat;
175
+ this._datePickerFormat = opts?.format;
176
+ this._datePickerShowTime = opts?.showTime;
177
+ this._datePickerShowSeconds = opts?.showSeconds;
178
+ return this;
179
+ }
180
+ withDateValue(opts) {
181
+ this._dateValueUtc = opts?.utc;
182
+ this._dateValueNoTimezone = opts?.noTimeZone;
183
+ this._dateValueNoTime = opts?.noTime;
145
184
  return this;
146
185
  }
147
186
  withPlaceholder(placeholder) {
@@ -169,6 +208,10 @@ export class FilterDescriptor {
169
208
  this._matchModes = matchModes;
170
209
  return this;
171
210
  }
211
+ withTitle(key) {
212
+ this._title = key;
213
+ return this;
214
+ }
172
215
  copy() {
173
216
  const descriptor = new FilterDescriptor(this._property);
174
217
  this.copyFieldsTo(descriptor);
@@ -179,14 +222,16 @@ export class FilterDescriptor {
179
222
  descriptor._hasDefaultValue = this._hasDefaultValue;
180
223
  descriptor._defaultValue = this._defaultValue;
181
224
  descriptor._defaultMatchMode = this._defaultMatchMode;
225
+ descriptor._displayFormat = this._displayFormat;
226
+ descriptor._locale = this._locale;
182
227
  descriptor._numberMinFractionDigits = this._numberMinFractionDigits;
183
228
  descriptor._numberMaxFractionDigits = this._numberMaxFractionDigits;
184
229
  descriptor._numberUseGrouping = this._numberUseGrouping;
185
230
  descriptor._datePickerFormat = this._datePickerFormat;
186
231
  descriptor._datePickerShowTime = this._datePickerShowTime;
187
- descriptor._datePickerValueUtc = this._datePickerValueUtc;
188
- descriptor._datePickerValueNoTimezone = this._datePickerValueNoTimezone;
189
- descriptor._datePickerValueNoTime = this._datePickerValueNoTime;
232
+ descriptor._dateValueUtc = this._dateValueUtc;
233
+ descriptor._dateValueNoTimezone = this._dateValueNoTimezone;
234
+ descriptor._dateValueNoTime = this._dateValueNoTime;
190
235
  descriptor._placeholder = this._placeholder;
191
236
  descriptor._className = this._className;
192
237
  descriptor._columnWidth = this._columnWidth;
@@ -194,4 +239,4 @@ export class FilterDescriptor {
194
239
  descriptor._columnClassName = this._columnClassName;
195
240
  }
196
241
  }
197
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"filter.descriptor.js","sourceRoot":"","sources":["../../../../filter/src/descriptors/filter.descriptor.ts"],"names":[],"mappings":"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","sourcesContent":["import {CommonsInternalError, FilterMatchModeExtendedType, IFilterDescriptor, LoggerService} from '@mediusinc/mng-commons/core';\nimport {InputTrimType} from '@mediusinc/mng-commons/form/api';\n\nimport {FilterTypeEnum} from '../models/filter.model';\n\nexport class FilterDescriptor<FilterModel, TableModel> implements IFilterDescriptor<FilterModel, TableModel> {\n    protected readonly _property: string;\n    protected _showOnColumn: string;\n\n    protected _filterType = FilterTypeEnum.String;\n\n    protected _hasDefaultValue = false;\n    protected _defaultMatchMode?: FilterMatchModeExtendedType;\n    protected _defaultValue?: FilterModel | FilterModel[];\n    protected _matchModes: string[] | null = null;\n\n    // number filter specific properties\n    protected _numberMinFractionDigits?: number;\n    protected _numberMaxFractionDigits?: number;\n    protected _numberUseGrouping = true;\n\n    // date filter specific properties\n    protected _datePickerFormat?: string;\n    protected _datePickerShowTime = false;\n    protected _datePickerShowSeconds = false;\n    protected _datePickerValueNoTime?: boolean = undefined;\n    protected _datePickerValueNoTimezone?: boolean = undefined;\n    protected _datePickerValueUtc?: boolean = undefined;\n\n    protected _placeholder?: string;\n    protected _className = '';\n    protected _columnClassName = '';\n    protected _columnWidth: number | null = null;\n    protected _columnMinWidth: number | null = null;\n    protected _inputTrim?: InputTrimType;\n\n    constructor(property: string) {\n        this._property = property;\n        this._showOnColumn = property;\n    }\n\n    public get filterType() {\n        return this._filterType;\n    }\n\n    public get showOnColumn() {\n        return this._showOnColumn;\n    }\n\n    public get hasDefaultValue() {\n        return this._hasDefaultValue;\n    }\n\n    public get defaultValue() {\n        return this._defaultValue;\n    }\n\n    public get defaultMatchMode() {\n        return this._defaultMatchMode;\n    }\n\n    public get matchModes() {\n        return this._matchModes;\n    }\n\n    public get numberMinFractionDigits() {\n        return this._numberMinFractionDigits;\n    }\n\n    public get numberMaxFractionDigits() {\n        return this._numberMaxFractionDigits;\n    }\n\n    public get numberUseGrouping() {\n        return this._numberUseGrouping;\n    }\n\n    public get datePickerFormat() {\n        return this._datePickerFormat;\n    }\n\n    public get datePickerShowTime() {\n        return this._datePickerShowTime;\n    }\n\n    public get datePickerShowSeconds() {\n        return this._datePickerShowSeconds;\n    }\n\n    public get datePickerValueUtc() {\n        return this._datePickerValueUtc;\n    }\n\n    public get datePickerValueNoTimezone() {\n        return this._datePickerValueNoTimezone;\n    }\n\n    public get datePickerValueNoTime() {\n        return this._datePickerValueNoTime;\n    }\n\n    public get placeholder() {\n        return this._placeholder;\n    }\n\n    public get className() {\n        return this._className;\n    }\n\n    public get columnClassName() {\n        return this._columnClassName;\n    }\n\n    public get columnWidth() {\n        return this._columnWidth;\n    }\n\n    public get columnMinWidth() {\n        return this._columnMinWidth;\n    }\n\n    public get trimOption() {\n        return this._inputTrim;\n    }\n\n    public get property() {\n        return this._property;\n    }\n\n    public asFilterType(filterType: FilterTypeEnum) {\n        this._filterType = filterType;\n        return this;\n    }\n\n    public withShowOnColumn(property: keyof TableModel): this {\n        return this.withShowOnColumnUnsafe(property as string);\n    }\n\n    public withShowOnColumnUnsafe(property: string): this {\n        this._showOnColumn = property;\n        return this;\n    }\n\n    public withDefaultFilter(value: FilterModel | FilterModel[] | undefined, matchMode: FilterMatchModeExtendedType): this {\n        this._hasDefaultValue = true;\n        this._defaultValue = value;\n        this._defaultMatchMode = matchMode;\n        this.validateDefaultFilter(value, matchMode);\n        return this;\n    }\n\n    protected validateDefaultFilter(value: FilterModel | FilterModel[] | undefined, matchMode: FilterMatchModeExtendedType) {\n        if (matchMode === 'between' && (!Array.isArray(value) || value.filter(v => v != null).length !== 2)) {\n            throw new CommonsInternalError(`Default value for filter match mode ${matchMode} must provide exactly 2 values in array`);\n        }\n        if ((matchMode === 'in' || matchMode === 'notIn') && (!Array.isArray(value) || value.filter(v => v != null).length === 0)) {\n            throw new CommonsInternalError(`Default value for filter match mode ${matchMode} must be array and provide at least 1 non-null value`);\n        }\n        if (matchMode === 'exists' || matchMode === 'doesNotExist') {\n            this._defaultValue = undefined;\n        }\n\n        if (matchMode && this._matchModes && this._matchModes.indexOf(matchMode) < 0) {\n            this._defaultMatchMode = undefined;\n            LoggerService.get().debug(`WARNING: Default filter match mode '${matchMode}' could not be assigned for property ${this._property}.`);\n        }\n    }\n\n    public withNumberFractions(min?: number, max?: number) {\n        this._numberMinFractionDigits = min;\n        this._numberMaxFractionDigits = max;\n        return this;\n    }\n\n    public withNumberGrouping(useGrouping = true): this {\n        this._numberUseGrouping = useGrouping;\n        return this;\n    }\n\n    public withDateFormat(format?: string, showTime = false, showSeconds = false): this {\n        this._datePickerFormat = format;\n        this._datePickerShowTime = showTime;\n        this._datePickerShowSeconds = showSeconds;\n        return this;\n    }\n\n    public withDateValue(utc?: boolean, noTimezone?: boolean, noTime?: boolean): this {\n        if (typeof utc !== 'undefined') {\n            this._datePickerValueUtc = utc;\n        }\n        if (typeof noTimezone !== 'undefined') {\n            this._datePickerValueNoTimezone = noTimezone;\n        }\n        if (typeof noTime !== 'undefined') {\n            this._datePickerValueNoTime = noTime;\n        }\n        return this;\n    }\n\n    public withPlaceholder(placeholder: string): this {\n        this._placeholder = placeholder;\n        return this;\n    }\n\n    public withClassName(className: string): this {\n        this._className = className;\n        return this;\n    }\n\n    public withColumnClassName(className: string): this {\n        this._columnClassName = className;\n        return this;\n    }\n\n    public withColumnWidth(width?: number, minWidth?: number): this {\n        this._columnWidth = width ?? null;\n        this._columnMinWidth = minWidth ?? null;\n        return this;\n    }\n\n    public withInputTrimming(trimOption: InputTrimType = 'both'): this {\n        this._inputTrim = trimOption;\n        return this;\n    }\n\n    public withMatchModes(matchModes: Array<FilterMatchModeExtendedType>): this {\n        this._matchModes = matchModes;\n        return this;\n    }\n\n    public copy(): FilterDescriptor<FilterModel, TableModel> {\n        const descriptor = new FilterDescriptor<FilterModel, TableModel>(this._property);\n        this.copyFieldsTo(descriptor);\n        return descriptor;\n    }\n\n    protected copyFieldsTo(descriptor: FilterDescriptor<FilterModel, TableModel>) {\n        descriptor._filterType = this._filterType;\n        descriptor._hasDefaultValue = this._hasDefaultValue;\n        descriptor._defaultValue = this._defaultValue;\n        descriptor._defaultMatchMode = this._defaultMatchMode;\n        descriptor._numberMinFractionDigits = this._numberMinFractionDigits;\n        descriptor._numberMaxFractionDigits = this._numberMaxFractionDigits;\n        descriptor._numberUseGrouping = this._numberUseGrouping;\n        descriptor._datePickerFormat = this._datePickerFormat;\n        descriptor._datePickerShowTime = this._datePickerShowTime;\n        descriptor._datePickerValueUtc = this._datePickerValueUtc;\n        descriptor._datePickerValueNoTimezone = this._datePickerValueNoTimezone;\n        descriptor._datePickerValueNoTime = this._datePickerValueNoTime;\n        descriptor._placeholder = this._placeholder;\n        descriptor._className = this._className;\n        descriptor._columnWidth = this._columnWidth;\n        descriptor._columnMinWidth = this._columnMinWidth;\n        descriptor._columnClassName = this._columnClassName;\n    }\n}\n"]}
242
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"filter.descriptor.js","sourceRoot":"","sources":["../../../../filter/src/descriptors/filter.descriptor.ts"],"names":[],"mappings":"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","sourcesContent":["import {CommonsInternalError, FilterMatchModeExtendedType, IFilterDescriptor, LoggerService} from '@mediusinc/mng-commons/core';\nimport {InputTrimType} from '@mediusinc/mng-commons/form/api';\n\nimport {FilterDisplayTypeEnum, FilterTypeEnum} from '../models/filter.model';\n\nexport type FilterDatePickerDisplayOptsType = {\n    applyFromDisplayFormat?: boolean;\n    format?: string;\n    showTime?: boolean;\n    showSeconds?: boolean;\n};\n\nexport type FilterDateValueOptsType = {\n    utc?: boolean;\n    noTime?: boolean;\n    noTimeZone?: boolean;\n};\n\nexport type FilterDateOptsType = FilterDateValueOptsType &\n    FilterDatePickerDisplayOptsType & {\n        displayFormat?: string;\n    };\n\nexport type FilterNumberFractionOptsType = {\n    minFractionDigits?: number;\n    maxFractionDigits?: number;\n};\n\nexport type FilterLocaleOptsType = {\n    locale?: string;\n};\n\nexport type FilterNumberOptsType = FilterNumberFractionOptsType &\n    FilterLocaleOptsType & {\n        displayFormat?: string;\n    };\n\nexport class FilterDescriptor<FilterModel, TableModel> implements IFilterDescriptor<FilterModel, TableModel> {\n    protected readonly _property: string;\n    protected _showOnColumn?: string;\n\n    protected _filterType = FilterTypeEnum.String;\n    protected _displayType?: FilterDisplayTypeEnum;\n\n    // default value\n    protected _hasDefaultValue = false;\n    protected _defaultMatchMode?: FilterMatchModeExtendedType;\n    protected _defaultValue?: FilterModel | FilterModel[];\n    protected _matchModes: string[] | null = null;\n\n    // value display\n    private _displayFormat?: string;\n    private _displayFormatApplyToField?: boolean;\n    private _locale?: string;\n\n    // number filter field specific properties\n    protected _numberMinFractionDigits?: number;\n    protected _numberMaxFractionDigits?: number;\n    protected _numberUseGrouping = true;\n\n    // date filter field specific properties\n    protected _datePickerFormat?: string;\n    protected _datePickerShowTime?: boolean;\n    protected _datePickerShowSeconds?: boolean;\n    protected _dateValueNoTime?: boolean;\n    protected _dateValueNoTimezone?: boolean;\n    protected _dateValueUtc?: boolean;\n\n    protected _placeholder?: string;\n    protected _className = '';\n    protected _columnClassName = '';\n    protected _columnWidth: number | null = null;\n    protected _columnMinWidth: number | null = null;\n    protected _inputTrim?: InputTrimType;\n    protected _title?: string;\n\n    constructor(property: string) {\n        this._property = property;\n        this._showOnColumn = property;\n    }\n\n    public get filterType() {\n        return this._filterType;\n    }\n\n    public get showOnColumn() {\n        return this._showOnColumn;\n    }\n\n    public get displayType() {\n        return this._displayType;\n    }\n\n    public get hasDefaultValue() {\n        return this._hasDefaultValue;\n    }\n\n    public get defaultValue() {\n        return this._defaultValue;\n    }\n\n    public get defaultMatchMode() {\n        return this._defaultMatchMode;\n    }\n\n    public get matchModes() {\n        return this._matchModes;\n    }\n\n    public get displayFormat() {\n        return this._displayFormat;\n    }\n\n    public get displayFormatApplyToField() {\n        return this._displayFormatApplyToField;\n    }\n\n    public get locale() {\n        return this._locale;\n    }\n\n    public get numberMinFractionDigits() {\n        return this._numberMinFractionDigits;\n    }\n\n    public get numberMaxFractionDigits() {\n        return this._numberMaxFractionDigits;\n    }\n\n    public get numberUseGrouping() {\n        return this._numberUseGrouping;\n    }\n\n    public get datePickerFormat() {\n        return this._datePickerFormat;\n    }\n\n    public get datePickerShowTime() {\n        return this._datePickerShowTime;\n    }\n\n    public get datePickerShowSeconds() {\n        return this._datePickerShowSeconds;\n    }\n\n    public get dateValueUtc() {\n        return this._dateValueUtc;\n    }\n\n    public get dateValueNoTimezone() {\n        return this._dateValueNoTimezone;\n    }\n\n    public get dateValueNoTime() {\n        return this._dateValueNoTime;\n    }\n\n    public get placeholder() {\n        return this._placeholder;\n    }\n\n    public get className() {\n        return this._className;\n    }\n\n    public get columnClassName() {\n        return this._columnClassName;\n    }\n\n    public get columnWidth() {\n        return this._columnWidth;\n    }\n\n    public get columnMinWidth() {\n        return this._columnMinWidth;\n    }\n\n    public get trimOption() {\n        return this._inputTrim;\n    }\n\n    public get property() {\n        return this._property;\n    }\n\n    public get title() {\n        return this._title;\n    }\n\n    public asFilterType(filterType: FilterTypeEnum) {\n        this._filterType = filterType;\n        return this;\n    }\n\n    public asDate(opts?: FilterDateOptsType): this {\n        this._filterType = FilterTypeEnum.Date;\n        this.withDisplayFormat(opts?.displayFormat).withDatePickerDisplay(opts).withDateValue(opts);\n        return this;\n    }\n\n    public asNumber(opts?: FilterNumberOptsType): this {\n        this._filterType = FilterTypeEnum.Number;\n        this.withDisplayFormat(opts?.displayFormat).withNumberFractions(opts?.minFractionDigits, opts?.maxFractionDigits).withLocale(opts?.locale);\n        return this;\n    }\n\n    public withShowOnColumn(property: keyof TableModel, displayType: FilterDisplayTypeEnum | undefined = FilterDisplayTypeEnum.Column): this {\n        return this.withShowOnColumnUnsafe(property as string, displayType);\n    }\n\n    public withDisplayType(type?: FilterDisplayTypeEnum): this {\n        this._displayType = type;\n        return this;\n    }\n\n    public withShowOnColumnUnsafe(property: string, displayType: FilterDisplayTypeEnum | undefined = FilterDisplayTypeEnum.Column): this {\n        this._showOnColumn = property;\n        this._displayType = displayType;\n        return this;\n    }\n\n    public withDefaultFilter(value: FilterModel | FilterModel[] | undefined, matchMode: FilterMatchModeExtendedType): this {\n        this._hasDefaultValue = true;\n        this._defaultValue = value;\n        this._defaultMatchMode = matchMode;\n        this.validateDefaultFilter(value, matchMode);\n        return this;\n    }\n\n    protected validateDefaultFilter(value: FilterModel | FilterModel[] | undefined, matchMode: FilterMatchModeExtendedType) {\n        if (matchMode === 'between' && value != null && (!Array.isArray(value) || value.filter(v => v != null).length !== 2)) {\n            throw new CommonsInternalError(`Default value for filter match mode ${matchMode} must provide exactly 2 values in array`);\n        }\n        if ((matchMode === 'in' || matchMode === 'notIn') && value != null && (!Array.isArray(value) || value.filter(v => v != null).length === 0)) {\n            throw new CommonsInternalError(`Default value for filter match mode ${matchMode} must be array and provide at least 1 non-null value`);\n        }\n        if (matchMode === 'exists' || matchMode === 'doesNotExist') {\n            this._defaultValue = undefined;\n        }\n\n        if (matchMode && this._matchModes && this._matchModes.indexOf(matchMode) < 0) {\n            this._defaultMatchMode = undefined;\n            LoggerService.get().debug(`WARNING: Default filter match mode '${matchMode}' could not be assigned for property ${this._property}.`);\n        }\n    }\n\n    public withDisplayFormat(format?: string, applyToField?: boolean): this {\n        this._displayFormat = format;\n        this._displayFormatApplyToField = applyToField;\n        return this;\n    }\n\n    public withLocale(locale?: string): this {\n        this._locale = locale;\n        return this;\n    }\n\n    public withNumberFractions(min?: number, max?: number) {\n        this._numberMinFractionDigits = min;\n        this._numberMaxFractionDigits = max;\n        return this;\n    }\n\n    public withNumberGrouping(useGrouping = true): this {\n        this._numberUseGrouping = useGrouping;\n        return this;\n    }\n\n    /**\n     * @deprecated Use ${withDatePickerDisplay} instead.\n     */\n    public withDateFormat(format?: string, showTime = false, showSeconds = false): this {\n        this._datePickerFormat = format;\n        this._datePickerShowTime = showTime;\n        this._datePickerShowSeconds = showSeconds;\n        return this;\n    }\n\n    public withDatePickerDisplay(opts?: FilterDatePickerDisplayOptsType): this {\n        this._displayFormatApplyToField = opts?.applyFromDisplayFormat;\n        this._datePickerFormat = opts?.format;\n        this._datePickerShowTime = opts?.showTime;\n        this._datePickerShowSeconds = opts?.showSeconds;\n        return this;\n    }\n\n    public withDateValue(opts?: FilterDateValueOptsType): this {\n        this._dateValueUtc = opts?.utc;\n        this._dateValueNoTimezone = opts?.noTimeZone;\n        this._dateValueNoTime = opts?.noTime;\n        return this;\n    }\n\n    public withPlaceholder(placeholder: string): this {\n        this._placeholder = placeholder;\n        return this;\n    }\n\n    public withClassName(className: string): this {\n        this._className = className;\n        return this;\n    }\n\n    public withColumnClassName(className: string): this {\n        this._columnClassName = className;\n        return this;\n    }\n\n    public withColumnWidth(width?: number, minWidth?: number): this {\n        this._columnWidth = width ?? null;\n        this._columnMinWidth = minWidth ?? null;\n        return this;\n    }\n\n    public withInputTrimming(trimOption: InputTrimType = 'both'): this {\n        this._inputTrim = trimOption;\n        return this;\n    }\n\n    public withMatchModes(matchModes: Array<FilterMatchModeExtendedType>): this {\n        this._matchModes = matchModes;\n        return this;\n    }\n\n    public withTitle(key: string): this {\n        this._title = key;\n        return this;\n    }\n\n    public copy(): FilterDescriptor<FilterModel, TableModel> {\n        const descriptor = new FilterDescriptor<FilterModel, TableModel>(this._property);\n        this.copyFieldsTo(descriptor);\n        return descriptor;\n    }\n\n    protected copyFieldsTo(descriptor: FilterDescriptor<FilterModel, TableModel>) {\n        descriptor._filterType = this._filterType;\n        descriptor._hasDefaultValue = this._hasDefaultValue;\n        descriptor._defaultValue = this._defaultValue;\n        descriptor._defaultMatchMode = this._defaultMatchMode;\n        descriptor._displayFormat = this._displayFormat;\n        descriptor._locale = this._locale;\n        descriptor._numberMinFractionDigits = this._numberMinFractionDigits;\n        descriptor._numberMaxFractionDigits = this._numberMaxFractionDigits;\n        descriptor._numberUseGrouping = this._numberUseGrouping;\n        descriptor._datePickerFormat = this._datePickerFormat;\n        descriptor._datePickerShowTime = this._datePickerShowTime;\n        descriptor._dateValueUtc = this._dateValueUtc;\n        descriptor._dateValueNoTimezone = this._dateValueNoTimezone;\n        descriptor._dateValueNoTime = this._dateValueNoTime;\n        descriptor._placeholder = this._placeholder;\n        descriptor._className = this._className;\n        descriptor._columnWidth = this._columnWidth;\n        descriptor._columnMinWidth = this._columnMinWidth;\n        descriptor._columnClassName = this._columnClassName;\n    }\n}\n"]}
@@ -12,4 +12,9 @@ export var FilterLookupTypeEnum;
12
12
  FilterLookupTypeEnum[FilterLookupTypeEnum["Dropdown"] = 0] = "Dropdown";
13
13
  FilterLookupTypeEnum[FilterLookupTypeEnum["Autocomplete"] = 1] = "Autocomplete";
14
14
  })(FilterLookupTypeEnum || (FilterLookupTypeEnum = {}));
15
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmlsdGVyLm1vZGVsLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vZmlsdGVyL3NyYy9tb2RlbHMvZmlsdGVyLm1vZGVsLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE1BQU0sQ0FBTixJQUFZLGNBT1g7QUFQRCxXQUFZLGNBQWM7SUFDdEIsdURBQU0sQ0FBQTtJQUNOLHVEQUFNLENBQUE7SUFDTix5REFBTyxDQUFBO0lBQ1AsbURBQUksQ0FBQTtJQUNKLHVEQUFNLENBQUE7SUFDTiwrREFBVSxDQUFBO0FBQ2QsQ0FBQyxFQVBXLGNBQWMsS0FBZCxjQUFjLFFBT3pCO0FBRUQsTUFBTSxDQUFOLElBQVksb0JBR1g7QUFIRCxXQUFZLG9CQUFvQjtJQUM1Qix1RUFBUSxDQUFBO0lBQ1IsK0VBQVksQ0FBQTtBQUNoQixDQUFDLEVBSFcsb0JBQW9CLEtBQXBCLG9CQUFvQixRQUcvQiIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBlbnVtIEZpbHRlclR5cGVFbnVtIHtcbiAgICBTdHJpbmcsXG4gICAgTnVtYmVyLFxuICAgIEJvb2xlYW4sXG4gICAgRGF0ZSxcbiAgICBMb29rdXAsXG4gICAgTG9va3VwRW51bVxufVxuXG5leHBvcnQgZW51bSBGaWx0ZXJMb29rdXBUeXBlRW51bSB7XG4gICAgRHJvcGRvd24sXG4gICAgQXV0b2NvbXBsZXRlXG59XG4iXX0=
15
+ export var FilterDisplayTypeEnum;
16
+ (function (FilterDisplayTypeEnum) {
17
+ FilterDisplayTypeEnum[FilterDisplayTypeEnum["Column"] = 0] = "Column";
18
+ FilterDisplayTypeEnum[FilterDisplayTypeEnum["OverlayWithTag"] = 1] = "OverlayWithTag";
19
+ })(FilterDisplayTypeEnum || (FilterDisplayTypeEnum = {}));
20
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmlsdGVyLm1vZGVsLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vZmlsdGVyL3NyYy9tb2RlbHMvZmlsdGVyLm1vZGVsLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE1BQU0sQ0FBTixJQUFZLGNBT1g7QUFQRCxXQUFZLGNBQWM7SUFDdEIsdURBQU0sQ0FBQTtJQUNOLHVEQUFNLENBQUE7SUFDTix5REFBTyxDQUFBO0lBQ1AsbURBQUksQ0FBQTtJQUNKLHVEQUFNLENBQUE7SUFDTiwrREFBVSxDQUFBO0FBQ2QsQ0FBQyxFQVBXLGNBQWMsS0FBZCxjQUFjLFFBT3pCO0FBRUQsTUFBTSxDQUFOLElBQVksb0JBR1g7QUFIRCxXQUFZLG9CQUFvQjtJQUM1Qix1RUFBUSxDQUFBO0lBQ1IsK0VBQVksQ0FBQTtBQUNoQixDQUFDLEVBSFcsb0JBQW9CLEtBQXBCLG9CQUFvQixRQUcvQjtBQUVELE1BQU0sQ0FBTixJQUFZLHFCQUdYO0FBSEQsV0FBWSxxQkFBcUI7SUFDN0IscUVBQU0sQ0FBQTtJQUNOLHFGQUFjLENBQUE7QUFDbEIsQ0FBQyxFQUhXLHFCQUFxQixLQUFyQixxQkFBcUIsUUFHaEMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgZW51bSBGaWx0ZXJUeXBlRW51bSB7XG4gICAgU3RyaW5nLFxuICAgIE51bWJlcixcbiAgICBCb29sZWFuLFxuICAgIERhdGUsXG4gICAgTG9va3VwLFxuICAgIExvb2t1cEVudW1cbn1cblxuZXhwb3J0IGVudW0gRmlsdGVyTG9va3VwVHlwZUVudW0ge1xuICAgIERyb3Bkb3duLFxuICAgIEF1dG9jb21wbGV0ZVxufVxuXG5leHBvcnQgZW51bSBGaWx0ZXJEaXNwbGF5VHlwZUVudW0ge1xuICAgIENvbHVtbixcbiAgICBPdmVybGF5V2l0aFRhZ1xufVxuIl19
@@ -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 "primeng/calendar";
8
- import * as i2 from "@angular/forms";
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.setValue(null);
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: i1.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: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
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"]}