@colijnit/corecomponents_v12 12.1.6 → 12.1.7

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.
@@ -2,22 +2,29 @@ import { __awaiter } from "tslib";
2
2
  import { ChangeDetectionStrategy, Component, EventEmitter, HostBinding, Input, Output, ViewEncapsulation } from '@angular/core';
3
3
  import { CoreComponentsIcon } from '../../core/enum/core-components-icon.enum';
4
4
  import { IconCacheService } from '../icon/icon-cache.service';
5
+ import { FilterItemMode } from '../../core/enum/filterItem-mode.enum';
5
6
  export class FilterItemComponent {
6
7
  constructor(iconService) {
7
8
  this.iconService = iconService;
8
9
  this.icons = CoreComponentsIcon;
10
+ this.modes = FilterItemMode;
11
+ this.mode = this.modes.FilterList;
9
12
  this.initialLimit = 10;
10
13
  this.expanded = false;
11
14
  // Set to false to use filter item with a multi selectable collection. Set to true to specify custom content
12
15
  this.customContent = false;
13
16
  // Set to true to show all results. Set to false to get 'show more' and 'show less' buttons to expand and contract.
14
17
  this.showAllResults = false;
15
- this.singleSelect = false;
18
+ //@Input()
19
+ //public singleSelect: boolean = false;
16
20
  this.filterButtonLabel = "Search";
17
21
  this.searchPlaceholder = 'Search...';
18
22
  this.showMoreLabel = 'Show more';
19
23
  this.showLessLabel = 'Show less';
20
24
  this.noResultsLabel = "No results";
25
+ this.sliderDefaultMin = 0;
26
+ this.sliderDefaultMax = 100000;
27
+ this.modelChange = new EventEmitter();
21
28
  this.collectionChange = new EventEmitter();
22
29
  this.filterButtonClicked = new EventEmitter();
23
30
  this.filteredCollection = [];
@@ -34,12 +41,47 @@ export class FilterItemComponent {
34
41
  get collection() {
35
42
  return this._collection;
36
43
  }
37
- showClass() {
38
- return true;
44
+ set model(filterString) {
45
+ if (this.mode === this.modes.FilterList) {
46
+ this.readModelForFilterList(filterString);
47
+ }
48
+ else if (this.mode === this.modes.SingleSelectList) {
49
+ this.readModelForSingleSelectList(filterString);
50
+ }
51
+ else if (this.mode === this.modes.SelectListWithStringCollectionOutput) {
52
+ this.readModelForStringCollectionList(filterString);
53
+ }
54
+ else if (this.mode === this.modes.SelectListWithNumberOutput) {
55
+ this.readModelForSelectListWithNumberOutput(filterString);
56
+ }
57
+ else if (this.mode === this.modes.Slider) {
58
+ this.readModelForSliderMode(filterString);
59
+ }
60
+ else if (this.mode === this.modes.CheckboxToText || this.mode === this.modes.CheckboxToSimpleText) {
61
+ this.readModelForCheckboxToText(filterString);
62
+ }
63
+ else if (this.mode === this.modes.CheckboxToBinary) {
64
+ this.readModelForCheckboxToBinary(filterString);
65
+ }
66
+ else if (this.mode === this.modes.DateField) {
67
+ this.readModelForDateField(filterString);
68
+ }
69
+ else if (this.mode === this.modes.DateRangeField) {
70
+ this.readModelForDateRangeField(filterString);
71
+ }
72
+ else if (this.mode === this.modes.Checkbox || this.mode === this.modes.TextField) {
73
+ this._model = filterString;
74
+ }
75
+ }
76
+ get model() {
77
+ return this._model;
39
78
  }
40
79
  ngOnInit() {
41
80
  this.setToInitialLimit();
42
81
  this.showButton = this.valueSelected();
82
+ this.sliderMin = this.sliderDefaultMin;
83
+ this.sliderMax = this.sliderDefaultMax;
84
+ this.checkBoxToTextModel = false;
43
85
  }
44
86
  setToInitialLimit() {
45
87
  this.limitTo = this.initialLimit;
@@ -62,16 +104,251 @@ export class FilterItemComponent {
62
104
  return ((_a = this.filteredCollection) === null || _a === void 0 ? void 0 : _a.length) <= this.limitTo && ((_b = this.filteredCollection) === null || _b === void 0 ? void 0 : _b.length) > this.initialLimit;
63
105
  }
64
106
  handleModelChange(model) {
65
- this.showButton = true;
66
- if (this.singleSelect) {
67
- this.collection.forEach(m => {
68
- if (m.code !== model.code && m.description !== model.description) {
69
- m.checked = false;
107
+ if (this.mode === this.modes.FilterList) {
108
+ this.showButton = true;
109
+ model.checked = !model.checked;
110
+ this.createModelForFilterList();
111
+ }
112
+ else if (this.mode === this.modes.SelectListWithStringCollectionOutput) {
113
+ this.showButton = true;
114
+ model.checked = !model.checked;
115
+ this.createModelForStringCollectionList();
116
+ }
117
+ else if (this.mode === this.modes.SingleSelectList) {
118
+ this.showButton = true;
119
+ this.uncheckForSingleSelect(model);
120
+ model.checked = !model.checked;
121
+ this.createModelForSingleSelectList();
122
+ }
123
+ else if (this.mode === this.modes.SelectListWithNumberOutput) {
124
+ this.showButton = true;
125
+ model.checked = !model.checked;
126
+ this.createModelForSelectListWithNumberOutput();
127
+ }
128
+ else if (this.mode === this.modes.Slider) {
129
+ this.createModelForSliderMode();
130
+ }
131
+ else if (this.mode === this.modes.CheckboxToText) {
132
+ this.createModelForCheckboxToText();
133
+ }
134
+ else if (this.mode === this.modes.CheckboxToSimpleText) {
135
+ this.createModelForCheckboxToSimpleText();
136
+ }
137
+ else if (this.mode === this.modes.CheckboxToBinary) {
138
+ this.createModelForCheckboxToBinary();
139
+ }
140
+ else if (this.mode === this.modes.DateRangeField) {
141
+ this.createModelForDateRange(model);
142
+ }
143
+ else if (this.mode === this.modes.TextField) {
144
+ this._model = (typeof this._model === 'string' && this._model.length === 0) ? undefined : this._model;
145
+ }
146
+ this.modelChange.emit(this._model);
147
+ }
148
+ uncheckForSingleSelect(model) {
149
+ this.collection.forEach(m => {
150
+ if (m.code !== model.code && m.description !== model.description) {
151
+ m.checked = false;
152
+ }
153
+ });
154
+ }
155
+ createModelForFilterList() {
156
+ let filterRange = [];
157
+ if (this.collection !== null && this.collection !== undefined) {
158
+ this.collection.forEach((viewModel) => {
159
+ if (viewModel.checked) {
160
+ filterRange.push(`?='${viewModel.code}'`);
161
+ }
162
+ });
163
+ this._model = filterRange.join(',');
164
+ }
165
+ }
166
+ createModelForStringCollectionList() {
167
+ let filterRange = [];
168
+ this.collection.forEach((viewModel) => {
169
+ if (viewModel.checked) {
170
+ filterRange.push(viewModel.code.toString());
171
+ }
172
+ });
173
+ this._model = filterRange;
174
+ }
175
+ createModelForSingleSelectList() {
176
+ let filterString = "";
177
+ this.collection.forEach((viewModel) => {
178
+ if (viewModel.checked) {
179
+ filterString = viewModel.code.toString();
180
+ }
181
+ });
182
+ this._model = filterString;
183
+ }
184
+ createModelForSelectListWithNumberOutput() {
185
+ let filterNumber = null;
186
+ this.collection.forEach((viewModel) => {
187
+ if (viewModel.checked) {
188
+ if (filterNumber == null) {
189
+ filterNumber = 0;
190
+ }
191
+ filterNumber += Number(viewModel.code);
192
+ }
193
+ });
194
+ this._model = filterNumber;
195
+ }
196
+ createModelForSliderMode() {
197
+ this.sliderMin = !!this.sliderMin ? this.sliderMin : this.sliderDefaultMin;
198
+ this.sliderMax = !!this.sliderMax ? this.sliderMax : this.sliderDefaultMax;
199
+ let trueLowerBound = Math.min(this.sliderMin, this.sliderMax);
200
+ let trueUpperBound = Math.max(this.sliderMin, this.sliderMax);
201
+ this._model = `${trueLowerBound} - ${trueUpperBound}`;
202
+ }
203
+ createModelForCheckboxToText() {
204
+ if (this.checkBoxToTextModel) {
205
+ this._model = "?='J'";
206
+ }
207
+ else {
208
+ this._model = "?='N'";
209
+ }
210
+ }
211
+ createModelForCheckboxToSimpleText() {
212
+ if (this.checkBoxToTextModel) {
213
+ this._model = "J";
214
+ }
215
+ else {
216
+ this._model = "N";
217
+ }
218
+ }
219
+ createModelForCheckboxToBinary() {
220
+ if (this.checkBoxToTextModel) {
221
+ this._model = 1;
222
+ }
223
+ else {
224
+ this._model = 0;
225
+ }
226
+ }
227
+ createModelForDateRange(dates) {
228
+ if (dates) {
229
+ let startDate = dates[0];
230
+ let endDate = dates[1];
231
+ const startDateRequest = startDate ? this._formatDateToString(startDate) : '';
232
+ const endDateRequest = endDate ? this._formatDateToString(endDate) : '';
233
+ const filter = `?>=\'${startDateRequest}\'& ?<=\'${endDateRequest}\'`;
234
+ this._model = filter;
235
+ }
236
+ }
237
+ _formatDateToString(date) {
238
+ let day = date.getDate().toString().padStart(2, '0');
239
+ let month = (date.getMonth() + 1).toString().padStart(2, '0');
240
+ let year = date.getFullYear();
241
+ return `${day}-${month}-${year}`;
242
+ }
243
+ readModelForFilterList(filterModel) {
244
+ let filterList = [];
245
+ let itemsToCheck = [];
246
+ this.uncheckAll();
247
+ if (filterModel !== null && filterModel !== undefined && typeof filterModel === 'string' && filterModel.length != 0) {
248
+ filterList = filterModel.split(",");
249
+ filterList.forEach((filter) => {
250
+ itemsToCheck.push(filter.substr(3, filter.length - 4));
251
+ });
252
+ for (const item of itemsToCheck) {
253
+ let filter = this.collection.find(element => element.code.toString() === item);
254
+ if (filter) {
255
+ filter.checked = true;
256
+ }
257
+ else {
258
+ filter.checked = false;
259
+ }
260
+ }
261
+ this._model = filterModel;
262
+ }
263
+ else {
264
+ this._model = undefined;
265
+ }
266
+ }
267
+ readModelForSingleSelectList(singleSelectModel) {
268
+ this.uncheckAll();
269
+ if (singleSelectModel !== null && singleSelectModel !== undefined) {
270
+ let filter = this.collection.find(element => element.code === singleSelectModel);
271
+ if (filter) {
272
+ filter.checked = true;
273
+ }
274
+ this.createModelForSingleSelectList();
275
+ }
276
+ }
277
+ readModelForStringCollectionList(collectionModel) {
278
+ this.uncheckAll();
279
+ if (collectionModel !== null && collectionModel !== undefined && this.collection !== null && this.collection !== undefined) {
280
+ this.collection.forEach((viewModel) => {
281
+ if (collectionModel.indexOf(viewModel.code) > -1) {
282
+ viewModel.checked = true;
283
+ }
284
+ else {
285
+ viewModel.checked = false;
70
286
  }
71
287
  });
72
288
  }
73
- model.checked = !model.checked;
74
- this.collectionChange.emit(this.collection);
289
+ }
290
+ readModelForSelectListWithNumberOutput(numberModel) {
291
+ this.uncheckAll();
292
+ if (numberModel !== null && numberModel !== undefined) {
293
+ for (const item of this.collection) {
294
+ const itemCode = item.code;
295
+ const modValue = (numberModel % (2 * itemCode));
296
+ item.checked = (modValue >= itemCode);
297
+ }
298
+ }
299
+ }
300
+ uncheckAll() {
301
+ if (this.collection !== null && this.collection !== undefined) {
302
+ this.collection.forEach(m => {
303
+ m.checked = false;
304
+ });
305
+ }
306
+ }
307
+ readModelForSliderMode(sliderModel) {
308
+ if (sliderModel !== undefined && sliderModel !== null) {
309
+ let sliderInputCollection = sliderModel.split(' - ');
310
+ this.sliderMin = parseInt(sliderInputCollection[0]);
311
+ this.sliderMax = parseInt(sliderInputCollection[1]);
312
+ }
313
+ else {
314
+ this.sliderMin = this.sliderDefaultMin;
315
+ this.sliderMax = this.sliderDefaultMax;
316
+ }
317
+ }
318
+ readModelForCheckboxToText(checkboxToTextModel) {
319
+ if (checkboxToTextModel !== undefined && checkboxToTextModel !== null) {
320
+ this.checkBoxToTextModel = (checkboxToTextModel.indexOf('J') > -1);
321
+ }
322
+ else {
323
+ this.checkBoxToTextModel = false;
324
+ }
325
+ }
326
+ readModelForCheckboxToBinary(checkboxToBinary) {
327
+ if (checkboxToBinary !== undefined && checkboxToBinary !== null) {
328
+ this.checkBoxToTextModel = (checkboxToBinary >= 1);
329
+ }
330
+ else {
331
+ this.checkBoxToTextModel = false;
332
+ }
333
+ }
334
+ readModelForDateField(dateFieldModel) {
335
+ if (dateFieldModel !== undefined && dateFieldModel !== null) {
336
+ this._model = new Date(dateFieldModel);
337
+ }
338
+ else {
339
+ this._model = undefined;
340
+ }
341
+ }
342
+ readModelForDateRangeField(dateRangeFieldModel) {
343
+ if (dateRangeFieldModel !== undefined && dateRangeFieldModel !== null) {
344
+ let dateCollection = dateRangeFieldModel.split('&');
345
+ let startString = dateCollection[0].trim().substr(4, dateCollection[0].length - 5);
346
+ let endString = dateCollection[1].trim().substr(4, dateCollection[1].length - 5);
347
+ let startDateComponents = startString.split('-');
348
+ let endDateComponents = endString.split('-');
349
+ this.dateRangeStart = new Date(parseInt(startDateComponents[2]), parseInt(startDateComponents[1]) - 1, parseInt(startDateComponents[0]));
350
+ this.dateRangeEnd = new Date(parseInt(endDateComponents[2]), parseInt(endDateComponents[1]) - 1, parseInt(endDateComponents[0]));
351
+ }
75
352
  }
76
353
  valueSelected() {
77
354
  if (this.collection) {
@@ -134,8 +411,9 @@ FilterItemComponent.decorators = [
134
411
  (keydown)="showButton=true" (mousedown)="showButton=true">
135
412
  <ng-content></ng-content>
136
413
  </div>
137
- <ng-template #collectionContent>
138
- <div class="co-filter-item-collection-content">
414
+ <ng-template #collectionContent >
415
+ <div class="co-filter-item-collection-content" *ngIf="mode === modes.FilterList || mode === modes.SingleSelectList
416
+ || mode === modes.SelectListWithNumberOutput || mode === modes.SelectListWithStringCollectionOutput">
139
417
  <co-input-text
140
418
  *ngIf="collection?.length > 10 || minSearchCharsToLoadCollection"
141
419
  [placeholder]="searchPlaceholder"
@@ -150,13 +428,13 @@ FilterItemComponent.decorators = [
150
428
  <ng-container
151
429
  *ngFor="let option of filteredCollection; let index = index">
152
430
  <div class="co-filter-item-collection-result-item" *ngIf="index < limitTo || showAllResults">
153
- <co-input-checkbox *ngIf="!singleSelect"
431
+ <co-input-checkbox *ngIf="mode !== modes.SingleSelectList"
154
432
  [label]="option.description"
155
433
  [model]="option.checked"
156
434
  [clickableLabel]="false"
157
435
  (modelChange)="handleModelChange(option)"
158
436
  ></co-input-checkbox>
159
- <co-input-radio-button *ngIf="singleSelect"
437
+ <co-input-radio-button *ngIf="mode === modes.SingleSelectList"
160
438
  [label]="option.description"
161
439
  [model]="option.checked"
162
440
  (modelChange)="handleModelChange(option)"
@@ -185,6 +463,57 @@ FilterItemComponent.decorators = [
185
463
  </div>
186
464
  </div>
187
465
  </div>
466
+ <div class="co-filter-item-slider-content" *ngIf="mode === modes.Slider">
467
+ <co-input-text
468
+ class="slider-from"
469
+ [type]="'number'"
470
+ [digitsOnly]="true"
471
+ [hideArrowButtons]="true"
472
+ [excludePlusMinus]="true"
473
+ [label]="'FROM' | localize"
474
+ [(model)]="sliderMin"
475
+ (modelChange)="handleModelChange($event)"
476
+ ></co-input-text>
477
+ <co-input-text
478
+ class="slider-to"
479
+ [type]="'number'"
480
+ [digitsOnly]="true"
481
+ [hideArrowButtons]="true"
482
+ [excludePlusMinus]="true"
483
+ [label]="'TO' | localize"
484
+ [(model)]="sliderMax"
485
+ (modelChange)="handleModelChange($event)"
486
+ ></co-input-text>
487
+ <!-- <co-icon [iconData]="iconService.getIcon(icons.Check)" (click)="filterOnPrice()"></co-icon>-->
488
+ </div>
489
+ <div class="co-filter-item-checkbox-content" *ngIf="mode === modes.Checkbox ">
490
+ <co-input-checkbox
491
+ [(model)]="model"
492
+ (modelChange)="handleModelChange($event)"></co-input-checkbox>
493
+ </div>
494
+ <div class="co-filter-item-checkbox-content" *ngIf="mode === modes.CheckboxToText || mode === modes.CheckboxToSimpleText || mode === modes.CheckboxToBinary">
495
+ <co-input-checkbox
496
+ [(model)]="checkBoxToTextModel"
497
+ (modelChange)="handleModelChange($event)"></co-input-checkbox>
498
+ </div>
499
+ <div class="co-filter-item-textfield-content" *ngIf="mode === modes.TextField">
500
+ <co-input-text
501
+ [(model)]="model"
502
+ (modelChange)="handleModelChange($event)"></co-input-text>
503
+ </div>
504
+ <div class="co-filter-item-dateField-content" *ngIf="mode === modes.DateField">
505
+ <co-input-date
506
+ [(model)]="model"
507
+ (modelChange)="handleModelChange($event)"
508
+ ></co-input-date>
509
+ </div>
510
+ <div class="co-filter-item-dateField-content" *ngIf="mode === modes.DateRangeField">
511
+ <co-input-date-range
512
+ [model]="[dateRangeStart, dateRangeEnd]"
513
+ (modelChange)="handleModelChange($event)"
514
+ [placeholder]="'SELECT_DATE' | localize">
515
+ </co-input-date-range>
516
+ </div>
188
517
  </ng-template>
189
518
  </div>
190
519
  </co-collapsible>
@@ -199,6 +528,7 @@ FilterItemComponent.ctorParameters = () => [
199
528
  { type: IconCacheService }
200
529
  ];
201
530
  FilterItemComponent.propDecorators = {
531
+ mode: [{ type: Input }],
202
532
  collection: [{ type: Input }],
203
533
  placeholder: [{ type: Input }],
204
534
  initialLimit: [{ type: Input }],
@@ -207,14 +537,17 @@ FilterItemComponent.propDecorators = {
207
537
  collectionLoadFn: [{ type: Input }],
208
538
  customContent: [{ type: Input }],
209
539
  showAllResults: [{ type: Input }],
210
- singleSelect: [{ type: Input }],
211
540
  filterButtonLabel: [{ type: Input }],
212
541
  searchPlaceholder: [{ type: Input }],
213
542
  showMoreLabel: [{ type: Input }],
214
543
  showLessLabel: [{ type: Input }],
215
544
  noResultsLabel: [{ type: Input }],
545
+ sliderDefaultMin: [{ type: Input }],
546
+ sliderDefaultMax: [{ type: Input }],
547
+ model: [{ type: Input }],
548
+ modelChange: [{ type: Output }],
216
549
  collectionChange: [{ type: Output }],
217
550
  filterButtonClicked: [{ type: Output }],
218
- showClass: [{ type: HostBinding, args: ["class.co-filter-item",] }]
551
+ filteredCollection: [{ type: HostBinding, args: ["class.co-filter-item",] }]
219
552
  };
220
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"filter-item.component.js","sourceRoot":"","sources":["../../../../../../projects/corecomponents/src/lib/components/filter-item/filter-item.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {ChangeDetectionStrategy, Component, EventEmitter, HostBinding, Input, OnInit, Output, ViewEncapsulation} from '@angular/core';\r\nimport {CoreComponentsIcon} from '../../core/enum/core-components-icon.enum';\r\nimport {FilterItemViewmodel} from './filter-item-viewmodel';\r\nimport {IconCacheService} from '../icon/icon-cache.service';\r\n\r\n@Component({\r\n  selector: \"co-filter-item\",\r\n  template: `\r\n    <div class=\"co-filter-item-header\">\r\n      <co-collapsible\r\n        [headerTitle]=\"placeholder\"\r\n        [expandButtonLast]=\"true\"\r\n        [iconData]=\"iconService.getIcon(icons.ArrowPointDown)\"\r\n        [expanded]=\"expanded\"\r\n        [showButton]=\"showButton\"\r\n        [buttonText]=\"filterButtonLabel\"\r\n        (buttonClicked)=\"onButtonClicked()\"\r\n      >\r\n        <div class=\"co-filter-item-collapsable-content\">\r\n          <div class=\"co-filter-item-custom-content\" *ngIf=\"customContent; else collectionContent\"\r\n               (keydown)=\"showButton=true\" (mousedown)=\"showButton=true\">\r\n            <ng-content></ng-content>\r\n          </div>\r\n          <ng-template #collectionContent>\r\n            <div class=\"co-filter-item-collection-content\">\r\n              <co-input-text\r\n                *ngIf=\"collection?.length > 10 || minSearchCharsToLoadCollection\"\r\n                [placeholder]=\"searchPlaceholder\"\r\n                [model]=\"filterText\"\r\n                (modelChange)=\"applyFilter($event)\"\r\n              >\r\n              </co-input-text>\r\n              <div class=\"no-results\" *ngIf=\"filteredCollection?.length === 0\">\r\n                <span [textContent]=\"noResultsLabel\"></span>\r\n              </div>\r\n              <div class=\"co-filter-item-collection-results\">\r\n                <ng-container\r\n                  *ngFor=\"let option of filteredCollection; let index = index\">\r\n                  <div class=\"co-filter-item-collection-result-item\" *ngIf=\"index < limitTo || showAllResults\">\r\n                    <co-input-checkbox *ngIf=\"!singleSelect\"\r\n                                       [label]=\"option.description\"\r\n                                       [model]=\"option.checked\"\r\n                                       [clickableLabel]=\"false\"\r\n                                       (modelChange)=\"handleModelChange(option)\"\r\n                    ></co-input-checkbox>\r\n                    <co-input-radio-button *ngIf=\"singleSelect\"\r\n                                           [label]=\"option.description\"\r\n                                           [model]=\"option.checked\"\r\n                                           (modelChange)=\"handleModelChange(option)\"\r\n                    ></co-input-radio-button>\r\n                    <div class=\"co-filter-item-amount\" *ngIf=\"option.count\"\r\n                         [textContent]=\"option.count.toString() | append: ')' | prepend: '      ('\"\r\n                    ></div>\r\n                  </div>\r\n\r\n                </ng-container>\r\n              </div>\r\n              <div class=\"co-filter-show-more-or-less\" *ngIf=\"!showAllResults\">\r\n                <div class=\"co-filter-show-more clickable\"\r\n                     *ngIf=\"moreToShow()\">\r\n                  <a (click)=\"increaseLimit()\">\r\n                    <co-icon [iconData]=\"iconService.getIcon(icons.ArrowPointDown)\"></co-icon>\r\n                    <span [textContent]=\"showMoreLabel\"></span>\r\n                  </a>\r\n                </div>\r\n                <div class=\"co-filter-show-less clickable\"\r\n                     *ngIf=\"lessToShow()\">\r\n                  <a (click)=\"setToInitialLimit()\">\r\n                    <co-icon [iconData]=\"iconService.getIcon(icons.ArrowPointUp)\"></co-icon>\r\n                    <span [textContent]=\"showLessLabel\"></span>\r\n                  </a>\r\n                </div>\r\n              </div>\r\n            </div>\r\n          </ng-template>\r\n        </div>\r\n      </co-collapsible>\r\n    </div>\r\n\r\n  `,\r\n  encapsulation: ViewEncapsulation.None,\r\n  changeDetection: ChangeDetectionStrategy.OnPush\r\n})\r\nexport class FilterItemComponent implements OnInit {\r\n  public icons: typeof CoreComponentsIcon = CoreComponentsIcon;\r\n\r\n  @Input()\r\n  public set collection(value: FilterItemViewmodel[]) {\r\n    this._collection = value;\r\n    this.filteredCollection = this._collection?.slice();\r\n  }\r\n\r\n  public get collection(): FilterItemViewmodel[] {\r\n    return this._collection;\r\n  }\r\n\r\n  @Input()\r\n  public placeholder: string;\r\n\r\n  @Input()\r\n  public initialLimit: number = 10;\r\n\r\n  @Input()\r\n  public expanded: boolean = false;\r\n\r\n  @Input()\r\n  public minSearchCharsToLoadCollection: number;\r\n\r\n  @Input()\r\n  public collectionLoadFn: Function;\r\n\r\n  // Set to false to use filter item with a multi selectable collection. Set to true to specify custom content\r\n  @Input()\r\n  public customContent: boolean = false;\r\n\r\n  // Set to true to show all results. Set to false to get 'show more' and 'show less' buttons to expand and contract.\r\n  @Input()\r\n  public showAllResults: boolean = false;\r\n\r\n  @Input()\r\n  public singleSelect: boolean = false;\r\n\r\n  @Input()\r\n  public filterButtonLabel: string = \"Search\";\r\n\r\n  @Input()\r\n  public searchPlaceholder: string = 'Search...';\r\n\r\n  @Input()\r\n  public showMoreLabel: string = 'Show more';\r\n\r\n  @Input()\r\n  public showLessLabel: string = 'Show less';\r\n\r\n  @Input()\r\n  public noResultsLabel: string = \"No results\";\r\n\r\n  @Output()\r\n  public collectionChange: EventEmitter<any> = new EventEmitter<any>();\r\n\r\n  @Output()\r\n  public filterButtonClicked: EventEmitter<void> = new EventEmitter<void>();\r\n\r\n  @HostBinding(\"class.co-filter-item\")\r\n  public showClass(): boolean {\r\n    return true;\r\n  }\r\n\r\n  public filteredCollection: FilterItemViewmodel[] = [];\r\n  public limitTo: number = 10;\r\n  public filterText: string = \"\";\r\n  public showButton: boolean = false;\r\n\r\n  private _collection: FilterItemViewmodel[] = [];\r\n\r\n  constructor(public iconService: IconCacheService) {\r\n  }\r\n\r\n  public ngOnInit(): void {\r\n    this.setToInitialLimit();\r\n    this.showButton = this.valueSelected();\r\n  }\r\n\r\n  public setToInitialLimit(): void {\r\n    this.limitTo = this.initialLimit;\r\n  }\r\n\r\n  public increaseLimit(): void {\r\n    this.limitTo += 10;\r\n  }\r\n\r\n  public moreToShow(): boolean {\r\n    if (this.showAllResults) {\r\n      return false;\r\n    }\r\n    return this.filteredCollection?.length > this.limitTo;\r\n  }\r\n\r\n  public lessToShow() {\r\n    if (this.showAllResults) {\r\n      return false;\r\n    }\r\n    return this.filteredCollection?.length <= this.limitTo && this.filteredCollection?.length > this.initialLimit;\r\n  }\r\n\r\n  public handleModelChange(model: FilterItemViewmodel) {\r\n    this.showButton = true;\r\n    if (this.singleSelect) {\r\n      this.collection.forEach(m => {\r\n        if (m.code !== model.code && m.description !== model.description) {\r\n          m.checked = false;\r\n        }\r\n      });\r\n    }\r\n    model.checked = !model.checked;\r\n    this.collectionChange.emit(this.collection);\r\n  }\r\n\r\n  public valueSelected() {\r\n    if (this.collection) {\r\n      return !!this.collection.find(c => c.checked);\r\n    }\r\n    return false;\r\n  }\r\n\r\n  // Applies filter to the collection.\r\n  public async applyFilter(text: string): Promise<[]> {\r\n    if (!isNaN(this.minSearchCharsToLoadCollection) && this.collectionLoadFn) {\r\n      if (text.length === this.minSearchCharsToLoadCollection && text.length > this.filterText.length) {\r\n        this.collection = await this.collectionLoadFn(text);\r\n      } else if (text.length < this.minSearchCharsToLoadCollection) {\r\n        this.collection = undefined;\r\n      }\r\n    }\r\n    this.filterText = text;\r\n    if (!this.collection) {\r\n      return [];\r\n    }\r\n\r\n    const filterText: string = this.filterText?.toString().toLowerCase();\r\n    let filteredItemCount: number = 0;\r\n    this.filteredCollection = this.collection?.filter((item) => {\r\n      const labelText: string = item.description?.toString().toLowerCase();\r\n      const isHiddenByFilter: boolean = (labelText?.indexOf(filterText) === -1);\r\n      if (isHiddenByFilter) {\r\n        return false;\r\n      } else {\r\n        filteredItemCount++;\r\n        return true;\r\n      }\r\n    });\r\n  }\r\n\r\n  public onButtonClicked(): void {\r\n    this.filterButtonClicked.emit();\r\n  }\r\n}\r\n"]}
553
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"filter-item.component.js","sourceRoot":"","sources":["../../../../../../projects/corecomponents/src/lib/components/filter-item/filter-item.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  ChangeDetectionStrategy,\r\n  Component,\r\n  EventEmitter, HostBinding,\r\n  Input,\r\n  OnInit,\r\n  Output,\r\n  ViewEncapsulation\r\n} from '@angular/core';\r\nimport {CoreComponentsIcon} from '../../core/enum/core-components-icon.enum';\r\nimport {FilterItemViewmodel} from './filter-item-viewmodel';\r\nimport {IconCacheService} from '../icon/icon-cache.service';\r\nimport {FilterItemMode} from '../../core/enum/filterItem-mode.enum';\r\n\r\n@Component({\r\n  selector: \"co-filter-item\",\r\n  template: `\r\n    <div class=\"co-filter-item-header\">\r\n      <co-collapsible\r\n        [headerTitle]=\"placeholder\"\r\n        [expandButtonLast]=\"true\"\r\n        [iconData]=\"iconService.getIcon(icons.ArrowPointDown)\"\r\n        [expanded]=\"expanded\"\r\n        [showButton]=\"showButton\"\r\n        [buttonText]=\"filterButtonLabel\"\r\n        (buttonClicked)=\"onButtonClicked()\"\r\n      >\r\n        <div class=\"co-filter-item-collapsable-content\">\r\n          <div class=\"co-filter-item-custom-content\" *ngIf=\"customContent; else collectionContent\"\r\n               (keydown)=\"showButton=true\" (mousedown)=\"showButton=true\">\r\n            <ng-content></ng-content>\r\n          </div>\r\n          <ng-template #collectionContent >\r\n            <div class=\"co-filter-item-collection-content\" *ngIf=\"mode === modes.FilterList || mode === modes.SingleSelectList\r\n                                                                   || mode === modes.SelectListWithNumberOutput || mode === modes.SelectListWithStringCollectionOutput\">\r\n              <co-input-text\r\n                *ngIf=\"collection?.length > 10 || minSearchCharsToLoadCollection\"\r\n                [placeholder]=\"searchPlaceholder\"\r\n                [model]=\"filterText\"\r\n                (modelChange)=\"applyFilter($event)\"\r\n              >\r\n              </co-input-text>\r\n              <div class=\"no-results\" *ngIf=\"filteredCollection?.length === 0\">\r\n                <span [textContent]=\"noResultsLabel\"></span>\r\n              </div>\r\n              <div class=\"co-filter-item-collection-results\">\r\n                <ng-container\r\n                  *ngFor=\"let option of filteredCollection; let index = index\">\r\n                  <div class=\"co-filter-item-collection-result-item\" *ngIf=\"index < limitTo || showAllResults\">\r\n                    <co-input-checkbox *ngIf=\"mode !== modes.SingleSelectList\"\r\n                                       [label]=\"option.description\"\r\n                                       [model]=\"option.checked\"\r\n                                       [clickableLabel]=\"false\"\r\n                                       (modelChange)=\"handleModelChange(option)\"\r\n                    ></co-input-checkbox>\r\n                    <co-input-radio-button *ngIf=\"mode === modes.SingleSelectList\"\r\n                                           [label]=\"option.description\"\r\n                                           [model]=\"option.checked\"\r\n                                           (modelChange)=\"handleModelChange(option)\"\r\n                    ></co-input-radio-button>\r\n                    <div class=\"co-filter-item-amount\" *ngIf=\"option.count\"\r\n                         [textContent]=\"option.count.toString() | append: ')' | prepend: '      ('\"\r\n                    ></div>\r\n                  </div>\r\n\r\n                </ng-container>\r\n              </div>\r\n              <div class=\"co-filter-show-more-or-less\" *ngIf=\"!showAllResults\">\r\n                <div class=\"co-filter-show-more clickable\"\r\n                     *ngIf=\"moreToShow()\">\r\n                  <a (click)=\"increaseLimit()\">\r\n                    <co-icon [iconData]=\"iconService.getIcon(icons.ArrowPointDown)\"></co-icon>\r\n                    <span [textContent]=\"showMoreLabel\"></span>\r\n                  </a>\r\n                </div>\r\n                <div class=\"co-filter-show-less clickable\"\r\n                     *ngIf=\"lessToShow()\">\r\n                  <a (click)=\"setToInitialLimit()\">\r\n                    <co-icon [iconData]=\"iconService.getIcon(icons.ArrowPointUp)\"></co-icon>\r\n                    <span [textContent]=\"showLessLabel\"></span>\r\n                  </a>\r\n                </div>\r\n              </div>\r\n            </div>\r\n            <div class=\"co-filter-item-slider-content\" *ngIf=\"mode === modes.Slider\">\r\n              <co-input-text\r\n                class=\"slider-from\"\r\n                [type]=\"'number'\"\r\n                [digitsOnly]=\"true\"\r\n                [hideArrowButtons]=\"true\"\r\n                [excludePlusMinus]=\"true\"\r\n                [label]=\"'FROM' | localize\"\r\n                [(model)]=\"sliderMin\"\r\n                (modelChange)=\"handleModelChange($event)\"\r\n              ></co-input-text>\r\n              <co-input-text\r\n                class=\"slider-to\"\r\n                [type]=\"'number'\"\r\n                [digitsOnly]=\"true\"\r\n                [hideArrowButtons]=\"true\"\r\n                [excludePlusMinus]=\"true\"\r\n                [label]=\"'TO' | localize\"\r\n                [(model)]=\"sliderMax\"\r\n                (modelChange)=\"handleModelChange($event)\"\r\n              ></co-input-text>\r\n               <!-- <co-icon [iconData]=\"iconService.getIcon(icons.Check)\" (click)=\"filterOnPrice()\"></co-icon>-->\r\n            </div>\r\n            <div class=\"co-filter-item-checkbox-content\" *ngIf=\"mode === modes.Checkbox \">\r\n              <co-input-checkbox\r\n                [(model)]=\"model\"\r\n                (modelChange)=\"handleModelChange($event)\"></co-input-checkbox>\r\n            </div>\r\n            <div class=\"co-filter-item-checkbox-content\" *ngIf=\"mode === modes.CheckboxToText || mode === modes.CheckboxToSimpleText || mode === modes.CheckboxToBinary\">\r\n              <co-input-checkbox\r\n                [(model)]=\"checkBoxToTextModel\"\r\n                (modelChange)=\"handleModelChange($event)\"></co-input-checkbox>\r\n            </div>\r\n            <div class=\"co-filter-item-textfield-content\" *ngIf=\"mode === modes.TextField\">\r\n              <co-input-text\r\n                [(model)]=\"model\"\r\n                (modelChange)=\"handleModelChange($event)\"></co-input-text>\r\n            </div>\r\n            <div class=\"co-filter-item-dateField-content\" *ngIf=\"mode === modes.DateField\">\r\n              <co-input-date\r\n                [(model)]=\"model\"\r\n                (modelChange)=\"handleModelChange($event)\"\r\n              ></co-input-date>\r\n            </div>\r\n            <div class=\"co-filter-item-dateField-content\" *ngIf=\"mode === modes.DateRangeField\">\r\n              <co-input-date-range\r\n                [model]=\"[dateRangeStart, dateRangeEnd]\"\r\n                (modelChange)=\"handleModelChange($event)\"\r\n                [placeholder]=\"'SELECT_DATE' | localize\">\r\n              </co-input-date-range>\r\n            </div>\r\n          </ng-template>\r\n        </div>\r\n      </co-collapsible>\r\n    </div>\r\n\r\n  `,\r\n  encapsulation: ViewEncapsulation.None,\r\n  changeDetection: ChangeDetectionStrategy.OnPush\r\n})\r\nexport class FilterItemComponent implements OnInit {\r\n  public icons: typeof CoreComponentsIcon = CoreComponentsIcon;\r\n  public modes: typeof FilterItemMode = FilterItemMode;\r\n\r\n  @Input()\r\n  public mode:FilterItemMode = this.modes.FilterList;\r\n\r\n  @Input()\r\n  public set collection(value: FilterItemViewmodel[]) {\r\n    this._collection = value;\r\n    this.filteredCollection = this._collection?.slice();\r\n  }\r\n\r\n  public get collection(): FilterItemViewmodel[] {\r\n    return this._collection;\r\n  }\r\n\r\n  @Input()\r\n  public placeholder: string;\r\n\r\n  @Input()\r\n  public initialLimit: number = 10;\r\n\r\n  @Input()\r\n  public expanded: boolean = false;\r\n\r\n  @Input()\r\n  public minSearchCharsToLoadCollection: number;\r\n\r\n  @Input()\r\n  public collectionLoadFn: Function;\r\n\r\n  // Set to false to use filter item with a multi selectable collection. Set to true to specify custom content\r\n  @Input()\r\n  public customContent: boolean = false;\r\n\r\n  // Set to true to show all results. Set to false to get 'show more' and 'show less' buttons to expand and contract.\r\n  @Input()\r\n  public showAllResults: boolean = false;\r\n\r\n  //@Input()\r\n  //public singleSelect: boolean = false;\r\n\r\n  @Input()\r\n  public filterButtonLabel: string = \"Search\";\r\n\r\n  @Input()\r\n  public searchPlaceholder: string = 'Search...';\r\n\r\n  @Input()\r\n  public showMoreLabel: string = 'Show more';\r\n\r\n  @Input()\r\n  public showLessLabel: string = 'Show less';\r\n\r\n  @Input()\r\n  public noResultsLabel: string = \"No results\";\r\n\r\n  @Input()\r\n  public sliderDefaultMin:number = 0;\r\n\r\n  @Input()\r\n  public sliderDefaultMax:number = 100000;\r\n\r\n  @Input()\r\n  public set model(filterString: any) {\r\n    if (this.mode === this.modes.FilterList) {\r\n      this.readModelForFilterList(filterString);\r\n    } else if (this.mode === this.modes.SingleSelectList) {\r\n      this.readModelForSingleSelectList(filterString);\r\n    } else if (this.mode === this.modes.SelectListWithStringCollectionOutput) {\r\n      this.readModelForStringCollectionList(filterString);\r\n    } else if (this.mode === this.modes.SelectListWithNumberOutput) {\r\n      this.readModelForSelectListWithNumberOutput(filterString);\r\n    } else if (this.mode === this.modes.Slider) {\r\n      this.readModelForSliderMode(filterString);\r\n    } else if (this.mode === this.modes.CheckboxToText || this.mode === this.modes.CheckboxToSimpleText) {\r\n      this.readModelForCheckboxToText(filterString);\r\n    }  else if (this.mode === this.modes.CheckboxToBinary) {\r\n      this.readModelForCheckboxToBinary(filterString);\r\n    } else if (this.mode === this.modes.DateField) {\r\n      this.readModelForDateField(filterString);\r\n    } else if (this.mode === this.modes.DateRangeField) {\r\n      this.readModelForDateRangeField(filterString);\r\n    } else if (this.mode === this.modes.Checkbox || this.mode === this.modes.TextField) {\r\n      this._model = filterString;\r\n    }\r\n  }\r\n\r\n  public get model(): any {\r\n     return this._model;\r\n  }\r\n\r\n  @Output()\r\n  public modelChange: EventEmitter<any> = new EventEmitter<any>();\r\n\r\n  @Output()\r\n  public collectionChange: EventEmitter<any> = new EventEmitter<any>();\r\n\r\n  @Output()\r\n  public filterButtonClicked: EventEmitter<void> = new EventEmitter<void>();\r\n\r\n  @HostBinding(\"class.co-filter-item\")\r\n  /*public set model(value: T) {\r\n    return true;\r\n  }*/\r\n\r\n  public filteredCollection: FilterItemViewmodel[] = [];\r\n  public limitTo: number = 10;\r\n  public filterText: string = \"\";\r\n  public showButton: boolean = false;\r\n\r\n  public sliderMin: number;\r\n  public sliderMax: number;\r\n\r\n  public dateRangeStart: Date;\r\n  public dateRangeEnd: Date;\r\n\r\n  public checkBoxToTextModel: boolean;\r\n\r\n  private _collection: FilterItemViewmodel[] = [];\r\n  private _model: any;\r\n\r\n  constructor(public iconService: IconCacheService) {\r\n  }\r\n\r\n  public ngOnInit(): void {\r\n    this.setToInitialLimit();\r\n    this.showButton = this.valueSelected();\r\n\r\n    this.sliderMin = this.sliderDefaultMin;\r\n    this.sliderMax = this.sliderDefaultMax;\r\n\r\n    this.checkBoxToTextModel = false;\r\n  }\r\n\r\n  public setToInitialLimit(): void {\r\n    this.limitTo = this.initialLimit;\r\n  }\r\n\r\n  public increaseLimit(): void {\r\n    this.limitTo += 10;\r\n  }\r\n\r\n  public moreToShow(): boolean {\r\n    if (this.showAllResults) {\r\n      return false;\r\n    }\r\n    return this.filteredCollection?.length > this.limitTo;\r\n  }\r\n\r\n  public lessToShow() {\r\n    if (this.showAllResults) {\r\n      return false;\r\n    }\r\n    return this.filteredCollection?.length <= this.limitTo && this.filteredCollection?.length > this.initialLimit;\r\n  }\r\n\r\n  public handleModelChange(model: any) {\r\n    if (this.mode === this.modes.FilterList) {\r\n      this.showButton = true;\r\n      model.checked = !model.checked;\r\n      this.createModelForFilterList();\r\n    } else if (this.mode === this.modes.SelectListWithStringCollectionOutput) {\r\n      this.showButton = true;\r\n      model.checked = !model.checked;\r\n      this.createModelForStringCollectionList();\r\n    } else if (this.mode === this.modes.SingleSelectList) {\r\n      this.showButton = true;\r\n      this.uncheckForSingleSelect(model);\r\n      model.checked = !model.checked;\r\n      this.createModelForSingleSelectList();\r\n    } else if (this.mode === this.modes.SelectListWithNumberOutput) {\r\n      this.showButton = true;\r\n      model.checked = !model.checked;\r\n      this.createModelForSelectListWithNumberOutput();\r\n    } else if (this.mode === this.modes.Slider) {\r\n      this.createModelForSliderMode();\r\n    } else if (this.mode === this.modes.CheckboxToText) {\r\n      this.createModelForCheckboxToText();\r\n    } else if (this.mode === this.modes.CheckboxToSimpleText) {\r\n      this.createModelForCheckboxToSimpleText();\r\n    } else if (this.mode === this.modes.CheckboxToBinary) {\r\n      this.createModelForCheckboxToBinary();\r\n    } else if (this.mode === this.modes.DateRangeField) {\r\n      this.createModelForDateRange(model);\r\n    } else if (this.mode === this.modes.TextField) {\r\n      this._model = (typeof this._model === 'string' && this._model.length === 0) ? undefined : this._model;\r\n    }\r\n    this.modelChange.emit(this._model);\r\n  }\r\n\r\n  private uncheckForSingleSelect(model: FilterItemViewmodel): void {\r\n    this.collection.forEach(m => {\r\n      if (m.code !== model.code && m.description !== model.description) {\r\n        m.checked = false;\r\n      }\r\n    });\r\n  }\r\n\r\n  private createModelForFilterList(): void{\r\n    let filterRange: string[] = [];\r\n    if(this.collection !== null && this.collection !== undefined) {\r\n      this.collection.forEach((viewModel: FilterItemViewmodel) => {\r\n        if (viewModel.checked) {\r\n          filterRange.push(`?='${viewModel.code}'`);\r\n        }\r\n      });\r\n      this._model = filterRange.join(',');\r\n    }\r\n  }\r\n\r\n  private createModelForStringCollectionList(): void {\r\n    let filterRange: string[] = [];\r\n    this.collection.forEach((viewModel: FilterItemViewmodel) => {\r\n      if (viewModel.checked) {\r\n        filterRange.push(viewModel.code.toString());\r\n      }\r\n    });\r\n    this._model = filterRange;\r\n  }\r\n\r\n  private createModelForSingleSelectList(): void{\r\n    let filterString: string = \"\";\r\n    this.collection.forEach((viewModel: FilterItemViewmodel) => {\r\n      if (viewModel.checked) {\r\n        filterString = viewModel.code.toString();\r\n      }\r\n    });\r\n    this._model = filterString;\r\n  }\r\n\r\n  private createModelForSelectListWithNumberOutput(): void{\r\n    let filterNumber: number = null;\r\n    this.collection.forEach((viewModel: FilterItemViewmodel) => {\r\n      if (viewModel.checked) {\r\n        if(filterNumber == null) {\r\n          filterNumber = 0;\r\n        }\r\n        filterNumber += Number(viewModel.code);\r\n      }\r\n    });\r\n    this._model = filterNumber;\r\n  }\r\n\r\n  public createModelForSliderMode(): void {\r\n    this.sliderMin = !!this.sliderMin ? this.sliderMin : this.sliderDefaultMin;\r\n    this.sliderMax = !!this.sliderMax ? this.sliderMax : this.sliderDefaultMax;\r\n\r\n    let trueLowerBound = Math.min(this.sliderMin, this.sliderMax);\r\n    let trueUpperBound = Math.max(this.sliderMin, this.sliderMax);\r\n\r\n    this._model = `${trueLowerBound} - ${trueUpperBound}`;\r\n  }\r\n\r\n  private createModelForCheckboxToText(): void {\r\n    if (this.checkBoxToTextModel) {\r\n      this._model = \"?='J'\";\r\n    } else {\r\n      this._model = \"?='N'\";\r\n    }\r\n  }\r\n\r\n  private createModelForCheckboxToSimpleText(): void {\r\n    if (this.checkBoxToTextModel) {\r\n      this._model = \"J\";\r\n    } else {\r\n      this._model = \"N\";\r\n    }\r\n  }\r\n\r\n  private createModelForCheckboxToBinary(): void {\r\n    if (this.checkBoxToTextModel) {\r\n      this._model = 1;\r\n    } else {\r\n      this._model = 0;\r\n    }\r\n  }\r\n\r\n  private createModelForDateRange(dates: Date[]): void {\r\n    if (dates) {\r\n      let startDate = dates[0];\r\n      let endDate = dates[1];\r\n\r\n      const startDateRequest = startDate ? this._formatDateToString(startDate) : '';\r\n      const endDateRequest = endDate ? this._formatDateToString(endDate) : '';\r\n\r\n      const filter = `?>=\\'${startDateRequest}\\'& ?<=\\'${endDateRequest}\\'`;\r\n\r\n      this._model = filter;\r\n    }\r\n  }\r\n\r\n  private _formatDateToString(date: Date): string {\r\n    let day = date.getDate().toString().padStart(2, '0');\r\n    let month = (date.getMonth() + 1).toString().padStart(2, '0');\r\n    let year = date.getFullYear();\r\n\r\n    return `${day}-${month}-${year}`;\r\n  }\r\n\r\n  public readModelForFilterList(filterModel: string): void {\r\n    let filterList: string[] = [];\r\n    let itemsToCheck: string[] = [];\r\n    this.uncheckAll();\r\n\r\n    if (filterModel !== null && filterModel !== undefined && typeof filterModel === 'string' && filterModel.length != 0 ) {\r\n      filterList = filterModel.split(\",\")\r\n      filterList.forEach((filter: string) => {\r\n        itemsToCheck.push(filter.substr(3, filter.length - 4));\r\n      });\r\n\r\n      for (const item of itemsToCheck) {\r\n        let filter = this.collection.find(element => element.code.toString() === item);\r\n        if (filter) {\r\n          filter.checked = true;\r\n        } else {\r\n          filter.checked = false;\r\n        }\r\n      }\r\n      this._model = filterModel;\r\n    } else {\r\n      this._model = undefined;\r\n    }\r\n\r\n  }\r\n\r\n  public readModelForSingleSelectList(singleSelectModel: string) {\r\n    this.uncheckAll();\r\n    if (singleSelectModel !== null && singleSelectModel !== undefined) {\r\n      let filter = this.collection.find(element => element.code === singleSelectModel);\r\n      if (filter) {\r\n        filter.checked = true;\r\n      }\r\n      this.createModelForSingleSelectList();\r\n    }\r\n  }\r\n\r\n  public readModelForStringCollectionList(collectionModel: string[]): void {\r\n    this.uncheckAll();\r\n    if (collectionModel !== null && collectionModel !== undefined && this.collection !== null && this.collection !== undefined) {\r\n      this.collection.forEach((viewModel: FilterItemViewmodel) => {\r\n        if (collectionModel.indexOf(viewModel.code as string) > -1) {\r\n          viewModel.checked = true;\r\n        } else {\r\n          viewModel.checked = false;\r\n        }\r\n      });\r\n    }\r\n  }\r\n\r\n  public readModelForSelectListWithNumberOutput(numberModel: number) {\r\n    this.uncheckAll();\r\n    if (numberModel !== null && numberModel !== undefined) {\r\n      for (const item of this.collection) {\r\n        const itemCode: number = item.code as number;\r\n        const modValue = (numberModel % (2 * itemCode));\r\n        item.checked = (modValue >= itemCode);\r\n      }\r\n    }\r\n  }\r\n\r\n  public uncheckAll() {\r\n    if(this.collection !== null && this.collection !== undefined) {\r\n      this.collection.forEach(m => {\r\n        m.checked = false;\r\n      });\r\n    }\r\n  }\r\n\r\n  public readModelForSliderMode(sliderModel:string): void {\r\n    if(sliderModel !== undefined && sliderModel !== null) {\r\n      let sliderInputCollection = sliderModel.split(' - ');\r\n      this.sliderMin = parseInt(sliderInputCollection[0]);\r\n      this.sliderMax = parseInt(sliderInputCollection[1]);\r\n    } else {\r\n      this.sliderMin = this.sliderDefaultMin;\r\n      this.sliderMax = this.sliderDefaultMax;\r\n    }\r\n  }\r\n\r\n  public readModelForCheckboxToText(checkboxToTextModel:string): void {\r\n    if(checkboxToTextModel !== undefined && checkboxToTextModel !== null) {\r\n      this.checkBoxToTextModel = (checkboxToTextModel.indexOf('J') > -1);\r\n    } else {\r\n      this.checkBoxToTextModel = false;\r\n    }\r\n  }\r\n\r\n  public readModelForCheckboxToBinary(checkboxToBinary:number): void {\r\n    if(checkboxToBinary !== undefined && checkboxToBinary !== null) {\r\n      this.checkBoxToTextModel = (checkboxToBinary >= 1);\r\n    } else {\r\n      this.checkBoxToTextModel = false;\r\n    }\r\n  }\r\n\r\n  public readModelForDateField(dateFieldModel:string): void {\r\n    if(dateFieldModel !== undefined && dateFieldModel !== null) {\r\n      this._model = new Date(dateFieldModel);\r\n    } else {\r\n      this._model = undefined;\r\n    }\r\n  }\r\n\r\n  public readModelForDateRangeField(dateRangeFieldModel:string): void {\r\n    if(dateRangeFieldModel !== undefined && dateRangeFieldModel !== null) {\r\n      let dateCollection = dateRangeFieldModel.split('&');\r\n\r\n      let startString = dateCollection[0].trim().substr(4, dateCollection[0].length - 5);\r\n      let endString = dateCollection[1].trim().substr(4, dateCollection[1].length - 5);\r\n\r\n      let startDateComponents = startString.split('-');\r\n      let endDateComponents = endString.split('-');\r\n\r\n      this.dateRangeStart = new Date(parseInt(startDateComponents[2]), parseInt(startDateComponents[1])-1, parseInt(startDateComponents[0]));\r\n      this.dateRangeEnd = new Date(parseInt(endDateComponents[2]), parseInt(endDateComponents[1])-1, parseInt(endDateComponents[0]));\r\n    }\r\n  }\r\n\r\n  public valueSelected() {\r\n    if (this.collection) {\r\n      return !!this.collection.find(c => c.checked);\r\n    }\r\n    return false;\r\n  }\r\n\r\n  // Applies filter to the collection.\r\n  public async applyFilter(text: string): Promise<[]> {\r\n    if (!isNaN(this.minSearchCharsToLoadCollection) && this.collectionLoadFn) {\r\n      if (text.length === this.minSearchCharsToLoadCollection && text.length > this.filterText.length) {\r\n        this.collection = await this.collectionLoadFn(text);\r\n      } else if (text.length < this.minSearchCharsToLoadCollection) {\r\n        this.collection = undefined;\r\n      }\r\n    }\r\n    this.filterText = text;\r\n    if (!this.collection) {\r\n      return [];\r\n    }\r\n\r\n    const filterText: string = this.filterText?.toString().toLowerCase();\r\n    let filteredItemCount: number = 0;\r\n    this.filteredCollection = this.collection?.filter((item) => {\r\n      const labelText: string = item.description?.toString().toLowerCase();\r\n      const isHiddenByFilter: boolean = (labelText?.indexOf(filterText) === -1);\r\n      if (isHiddenByFilter) {\r\n        return false;\r\n      } else {\r\n        filteredItemCount++;\r\n        return true;\r\n      }\r\n    });\r\n  }\r\n\r\n  public onButtonClicked(): void {\r\n    this.filterButtonClicked.emit();\r\n  }\r\n}\r\n"]}
@@ -9,6 +9,9 @@ import { InputCheckboxModule } from "../input-checkbox/input-checkbox.module";
9
9
  import { InputTextModule } from "../input-text/input-text.module";
10
10
  import { FilterItemComponent } from "./filter-item.component";
11
11
  import { InputRadioButtonModule } from '../input-radio-button/input-radio-button.module';
12
+ import { CoreComponentsTranslationModule } from "../../translation/core-components-translation.module";
13
+ import { InputDatePickerModule } from "../input-date-picker/input-date-picker.module";
14
+ import { InputDateRangePickerModule } from "../input-date-range-picker/input-date-range-picker.module";
12
15
  export class FilterItemModule {
13
16
  }
14
17
  FilterItemModule.decorators = [
@@ -24,7 +27,10 @@ FilterItemModule.decorators = [
24
27
  PrependPipeModule,
25
28
  InputTextModule,
26
29
  InputRadioButtonModule,
27
- InputTextModule
30
+ InputTextModule,
31
+ CoreComponentsTranslationModule,
32
+ InputDatePickerModule,
33
+ InputDateRangePickerModule
28
34
  ],
29
35
  declarations: [
30
36
  FilterItemComponent
@@ -34,4 +40,4 @@ FilterItemModule.decorators = [
34
40
  ]
35
41
  },] }
36
42
  ];
37
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmlsdGVyLWl0ZW0ubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvY29yZWNvbXBvbmVudHMvc3JjL2xpYi9jb21wb25lbnRzL2ZpbHRlci1pdGVtL2ZpbHRlci1pdGVtLm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sd0JBQXdCLENBQUM7QUFDekQsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDekMsT0FBTyxFQUFFLGdCQUFnQixFQUFFLE1BQU0sZ0NBQWdDLENBQUM7QUFDbEUsT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0saUNBQWlDLENBQUM7QUFDcEUsT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0sbUNBQW1DLENBQUM7QUFDdEUsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLHFCQUFxQixDQUFDO0FBQ2pELE9BQU8sRUFBRSxtQkFBbUIsRUFBRSxNQUFNLHlDQUF5QyxDQUFDO0FBQzlFLE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSxpQ0FBaUMsQ0FBQztBQUNsRSxPQUFPLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSx5QkFBeUIsQ0FBQztBQUM5RCxPQUFPLEVBQUMsc0JBQXNCLEVBQUMsTUFBTSxpREFBaUQsQ0FBQztBQXVCdkYsTUFBTSxPQUFPLGdCQUFnQjs7O1lBckI1QixRQUFRLFNBQUM7Z0JBQ04sT0FBTyxFQUFFO29CQUNMLFlBQVk7b0JBQ1osaUJBQWlCO29CQUNqQixlQUFlO29CQUNmLG1CQUFtQjtvQkFDbkIsVUFBVTtvQkFDVixlQUFlO29CQUNmLGdCQUFnQjtvQkFDaEIsaUJBQWlCO29CQUNqQixlQUFlO29CQUNmLHNCQUFzQjtvQkFDdEIsZUFBZTtpQkFDbEI7Z0JBQ0gsWUFBWSxFQUFFO29CQUNaLG1CQUFtQjtpQkFDcEI7Z0JBQ0QsT0FBTyxFQUFFO29CQUNQLG1CQUFtQjtpQkFDcEI7YUFDRiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFNjcm9sbGluZ01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2Nkay9zY3JvbGxpbmcnO1xyXG5pbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tIFwiQGFuZ3VsYXIvY29tbW9uXCI7XHJcbmltcG9ydCB7IE5nTW9kdWxlIH0gZnJvbSBcIkBhbmd1bGFyL2NvcmVcIjtcclxuaW1wb3J0IHsgQXBwZW5kUGlwZU1vZHVsZSB9IGZyb20gJy4uLy4uL3BpcGVzL2FwcGVuZC5waXBlLm1vZHVsZSc7XHJcbmltcG9ydCB7IFByZXBlbmRQaXBlTW9kdWxlIH0gZnJvbSAnLi4vLi4vcGlwZXMvcHJlcGVuZC5waXBlLm1vZHVsZSc7XHJcbmltcG9ydCB7IENvbGxhcHNpYmxlTW9kdWxlIH0gZnJvbSBcIi4uL2NvbGxhcHNpYmxlL2NvbGxhcHNpYmxlLm1vZHVsZVwiO1xyXG5pbXBvcnQgeyBJY29uTW9kdWxlIH0gZnJvbSBcIi4uL2ljb24vaWNvbi5tb2R1bGVcIjtcclxuaW1wb3J0IHsgSW5wdXRDaGVja2JveE1vZHVsZSB9IGZyb20gXCIuLi9pbnB1dC1jaGVja2JveC9pbnB1dC1jaGVja2JveC5tb2R1bGVcIjtcclxuaW1wb3J0IHsgSW5wdXRUZXh0TW9kdWxlIH0gZnJvbSBcIi4uL2lucHV0LXRleHQvaW5wdXQtdGV4dC5tb2R1bGVcIjtcclxuaW1wb3J0IHsgRmlsdGVySXRlbUNvbXBvbmVudCB9IGZyb20gXCIuL2ZpbHRlci1pdGVtLmNvbXBvbmVudFwiO1xyXG5pbXBvcnQge0lucHV0UmFkaW9CdXR0b25Nb2R1bGV9IGZyb20gJy4uL2lucHV0LXJhZGlvLWJ1dHRvbi9pbnB1dC1yYWRpby1idXR0b24ubW9kdWxlJztcclxuXHJcbkBOZ01vZHVsZSh7XHJcbiAgICBpbXBvcnRzOiBbXHJcbiAgICAgICAgQ29tbW9uTW9kdWxlLFxyXG4gICAgICAgIENvbGxhcHNpYmxlTW9kdWxlLFxyXG4gICAgICAgIElucHV0VGV4dE1vZHVsZSxcclxuICAgICAgICBJbnB1dENoZWNrYm94TW9kdWxlLFxyXG4gICAgICAgIEljb25Nb2R1bGUsXHJcbiAgICAgICAgU2Nyb2xsaW5nTW9kdWxlLFxyXG4gICAgICAgIEFwcGVuZFBpcGVNb2R1bGUsXHJcbiAgICAgICAgUHJlcGVuZFBpcGVNb2R1bGUsXHJcbiAgICAgICAgSW5wdXRUZXh0TW9kdWxlLFxyXG4gICAgICAgIElucHV0UmFkaW9CdXR0b25Nb2R1bGUsXHJcbiAgICAgICAgSW5wdXRUZXh0TW9kdWxlXHJcbiAgICBdLFxyXG4gIGRlY2xhcmF0aW9uczogW1xyXG4gICAgRmlsdGVySXRlbUNvbXBvbmVudFxyXG4gIF0sXHJcbiAgZXhwb3J0czogW1xyXG4gICAgRmlsdGVySXRlbUNvbXBvbmVudFxyXG4gIF1cclxufSlcclxuZXhwb3J0IGNsYXNzIEZpbHRlckl0ZW1Nb2R1bGUge1xyXG5cclxufVxyXG4iXX0=
43
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmlsdGVyLWl0ZW0ubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvY29yZWNvbXBvbmVudHMvc3JjL2xpYi9jb21wb25lbnRzL2ZpbHRlci1pdGVtL2ZpbHRlci1pdGVtLm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sd0JBQXdCLENBQUM7QUFDekQsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDekMsT0FBTyxFQUFFLGdCQUFnQixFQUFFLE1BQU0sZ0NBQWdDLENBQUM7QUFDbEUsT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0saUNBQWlDLENBQUM7QUFDcEUsT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0sbUNBQW1DLENBQUM7QUFDdEUsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLHFCQUFxQixDQUFDO0FBQ2pELE9BQU8sRUFBRSxtQkFBbUIsRUFBRSxNQUFNLHlDQUF5QyxDQUFDO0FBQzlFLE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSxpQ0FBaUMsQ0FBQztBQUNsRSxPQUFPLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSx5QkFBeUIsQ0FBQztBQUM5RCxPQUFPLEVBQUMsc0JBQXNCLEVBQUMsTUFBTSxpREFBaUQsQ0FBQztBQUN2RixPQUFPLEVBQUMsK0JBQStCLEVBQUMsTUFBTSxzREFBc0QsQ0FBQztBQUNyRyxPQUFPLEVBQUMscUJBQXFCLEVBQUMsTUFBTSwrQ0FBK0MsQ0FBQztBQUNwRixPQUFPLEVBQUMsMEJBQTBCLEVBQUMsTUFBTSwyREFBMkQsQ0FBQztBQTBCckcsTUFBTSxPQUFPLGdCQUFnQjs7O1lBeEI1QixRQUFRLFNBQUM7Z0JBQ04sT0FBTyxFQUFFO29CQUNMLFlBQVk7b0JBQ1osaUJBQWlCO29CQUNqQixlQUFlO29CQUNmLG1CQUFtQjtvQkFDbkIsVUFBVTtvQkFDVixlQUFlO29CQUNmLGdCQUFnQjtvQkFDaEIsaUJBQWlCO29CQUNqQixlQUFlO29CQUNmLHNCQUFzQjtvQkFDdEIsZUFBZTtvQkFDZiwrQkFBK0I7b0JBQy9CLHFCQUFxQjtvQkFDckIsMEJBQTBCO2lCQUM3QjtnQkFDSCxZQUFZLEVBQUU7b0JBQ1osbUJBQW1CO2lCQUNwQjtnQkFDRCxPQUFPLEVBQUU7b0JBQ1AsbUJBQW1CO2lCQUNwQjthQUNGIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgU2Nyb2xsaW5nTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY2RrL3Njcm9sbGluZyc7XHJcbmltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gXCJAYW5ndWxhci9jb21tb25cIjtcclxuaW1wb3J0IHsgTmdNb2R1bGUgfSBmcm9tIFwiQGFuZ3VsYXIvY29yZVwiO1xyXG5pbXBvcnQgeyBBcHBlbmRQaXBlTW9kdWxlIH0gZnJvbSAnLi4vLi4vcGlwZXMvYXBwZW5kLnBpcGUubW9kdWxlJztcclxuaW1wb3J0IHsgUHJlcGVuZFBpcGVNb2R1bGUgfSBmcm9tICcuLi8uLi9waXBlcy9wcmVwZW5kLnBpcGUubW9kdWxlJztcclxuaW1wb3J0IHsgQ29sbGFwc2libGVNb2R1bGUgfSBmcm9tIFwiLi4vY29sbGFwc2libGUvY29sbGFwc2libGUubW9kdWxlXCI7XHJcbmltcG9ydCB7IEljb25Nb2R1bGUgfSBmcm9tIFwiLi4vaWNvbi9pY29uLm1vZHVsZVwiO1xyXG5pbXBvcnQgeyBJbnB1dENoZWNrYm94TW9kdWxlIH0gZnJvbSBcIi4uL2lucHV0LWNoZWNrYm94L2lucHV0LWNoZWNrYm94Lm1vZHVsZVwiO1xyXG5pbXBvcnQgeyBJbnB1dFRleHRNb2R1bGUgfSBmcm9tIFwiLi4vaW5wdXQtdGV4dC9pbnB1dC10ZXh0Lm1vZHVsZVwiO1xyXG5pbXBvcnQgeyBGaWx0ZXJJdGVtQ29tcG9uZW50IH0gZnJvbSBcIi4vZmlsdGVyLWl0ZW0uY29tcG9uZW50XCI7XHJcbmltcG9ydCB7SW5wdXRSYWRpb0J1dHRvbk1vZHVsZX0gZnJvbSAnLi4vaW5wdXQtcmFkaW8tYnV0dG9uL2lucHV0LXJhZGlvLWJ1dHRvbi5tb2R1bGUnO1xyXG5pbXBvcnQge0NvcmVDb21wb25lbnRzVHJhbnNsYXRpb25Nb2R1bGV9IGZyb20gXCIuLi8uLi90cmFuc2xhdGlvbi9jb3JlLWNvbXBvbmVudHMtdHJhbnNsYXRpb24ubW9kdWxlXCI7XHJcbmltcG9ydCB7SW5wdXREYXRlUGlja2VyTW9kdWxlfSBmcm9tIFwiLi4vaW5wdXQtZGF0ZS1waWNrZXIvaW5wdXQtZGF0ZS1waWNrZXIubW9kdWxlXCI7XHJcbmltcG9ydCB7SW5wdXREYXRlUmFuZ2VQaWNrZXJNb2R1bGV9IGZyb20gXCIuLi9pbnB1dC1kYXRlLXJhbmdlLXBpY2tlci9pbnB1dC1kYXRlLXJhbmdlLXBpY2tlci5tb2R1bGVcIjtcclxuXHJcbkBOZ01vZHVsZSh7XHJcbiAgICBpbXBvcnRzOiBbXHJcbiAgICAgICAgQ29tbW9uTW9kdWxlLFxyXG4gICAgICAgIENvbGxhcHNpYmxlTW9kdWxlLFxyXG4gICAgICAgIElucHV0VGV4dE1vZHVsZSxcclxuICAgICAgICBJbnB1dENoZWNrYm94TW9kdWxlLFxyXG4gICAgICAgIEljb25Nb2R1bGUsXHJcbiAgICAgICAgU2Nyb2xsaW5nTW9kdWxlLFxyXG4gICAgICAgIEFwcGVuZFBpcGVNb2R1bGUsXHJcbiAgICAgICAgUHJlcGVuZFBpcGVNb2R1bGUsXHJcbiAgICAgICAgSW5wdXRUZXh0TW9kdWxlLFxyXG4gICAgICAgIElucHV0UmFkaW9CdXR0b25Nb2R1bGUsXHJcbiAgICAgICAgSW5wdXRUZXh0TW9kdWxlLFxyXG4gICAgICAgIENvcmVDb21wb25lbnRzVHJhbnNsYXRpb25Nb2R1bGUsXHJcbiAgICAgICAgSW5wdXREYXRlUGlja2VyTW9kdWxlLFxyXG4gICAgICAgIElucHV0RGF0ZVJhbmdlUGlja2VyTW9kdWxlXHJcbiAgICBdLFxyXG4gIGRlY2xhcmF0aW9uczogW1xyXG4gICAgRmlsdGVySXRlbUNvbXBvbmVudFxyXG4gIF0sXHJcbiAgZXhwb3J0czogW1xyXG4gICAgRmlsdGVySXRlbUNvbXBvbmVudFxyXG4gIF1cclxufSlcclxuZXhwb3J0IGNsYXNzIEZpbHRlckl0ZW1Nb2R1bGUge1xyXG5cclxufVxyXG4iXX0=