@colijnit/corecomponents_v12 12.1.6 → 12.1.8

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.
@@ -1,23 +1,29 @@
1
1
  import { __awaiter } from "tslib";
2
- import { ChangeDetectionStrategy, Component, EventEmitter, HostBinding, Input, Output, ViewEncapsulation } from '@angular/core';
2
+ import { ChangeDetectionStrategy, ChangeDetectorRef, 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
- constructor(iconService) {
7
+ constructor(iconService, _changeDetector) {
7
8
  this.iconService = iconService;
9
+ this._changeDetector = _changeDetector;
8
10
  this.icons = CoreComponentsIcon;
11
+ this.modes = FilterItemMode;
12
+ this.mode = this.modes.Filterlist;
9
13
  this.initialLimit = 10;
10
14
  this.expanded = false;
11
15
  // Set to false to use filter item with a multi selectable collection. Set to true to specify custom content
12
16
  this.customContent = false;
13
17
  // Set to true to show all results. Set to false to get 'show more' and 'show less' buttons to expand and contract.
14
18
  this.showAllResults = false;
15
- this.singleSelect = false;
16
19
  this.filterButtonLabel = "Search";
17
20
  this.searchPlaceholder = 'Search...';
18
21
  this.showMoreLabel = 'Show more';
19
22
  this.showLessLabel = 'Show less';
20
23
  this.noResultsLabel = "No results";
24
+ this.sliderDefaultMin = 0;
25
+ this.sliderDefaultMax = 100000;
26
+ this.modelChange = new EventEmitter();
21
27
  this.collectionChange = new EventEmitter();
22
28
  this.filterButtonClicked = new EventEmitter();
23
29
  this.filteredCollection = [];
@@ -30,16 +36,51 @@ export class FilterItemComponent {
30
36
  var _a;
31
37
  this._collection = value;
32
38
  this.filteredCollection = (_a = this._collection) === null || _a === void 0 ? void 0 : _a.slice();
39
+ //reset the model in case there was no collection to set its values on when it was set.
40
+ this.model = this._model;
33
41
  }
34
42
  get collection() {
35
43
  return this._collection;
36
44
  }
37
- showClass() {
38
- return true;
45
+ set model(filterString) {
46
+ switch (this.mode) {
47
+ case this.modes.Filterlist:
48
+ this._readModelForFilterList(filterString);
49
+ break;
50
+ case this.modes.SingleSelectList:
51
+ this._readModelForSingleSelectList(filterString);
52
+ break;
53
+ case this.modes.SelectListWithStringCollectionOutput:
54
+ this._readModelForStringCollectionList(filterString);
55
+ break;
56
+ case this.modes.SelectListWithNumberOutput:
57
+ this._readModelForSelectListWithNumberOutput(filterString);
58
+ break;
59
+ case this.modes.Slider:
60
+ this._readModelForSliderMode(filterString);
61
+ break;
62
+ case this.modes.CheckboxToText:
63
+ case this.modes.CheckboxToSimpleText:
64
+ this._readModelForCheckboxToText(filterString);
65
+ break;
66
+ case this.modes.CheckboxToBinary:
67
+ this._readModelForCheckboxToBinary(filterString);
68
+ break;
69
+ case this.modes.DateField:
70
+ this._readModelForDateField(filterString);
71
+ break;
72
+ case this.modes.DateRangeField:
73
+ this._readModelForDateRangeField(filterString);
74
+ break;
75
+ }
76
+ }
77
+ get model() {
78
+ return this._model;
39
79
  }
40
80
  ngOnInit() {
41
81
  this.setToInitialLimit();
42
82
  this.showButton = this.valueSelected();
83
+ this.checkBoxToTextModel = false;
43
84
  }
44
85
  setToInitialLimit() {
45
86
  this.limitTo = this.initialLimit;
@@ -62,17 +103,57 @@ export class FilterItemComponent {
62
103
  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
104
  }
64
105
  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;
70
- }
71
- });
106
+ switch (this.mode) {
107
+ case this.modes.Filterlist:
108
+ this.showButton = true;
109
+ model.checked = !model.checked;
110
+ this._createModelForFilterList();
111
+ break;
112
+ case this.modes.SelectListWithStringCollectionOutput:
113
+ this.showButton = true;
114
+ model.checked = !model.checked;
115
+ this._createModelForStringCollectionList();
116
+ break;
117
+ case this.modes.SingleSelectList:
118
+ this.showButton = true;
119
+ this.uncheckForSingleSelect(model);
120
+ model.checked = !model.checked;
121
+ this._createModelForSingleSelectList();
122
+ break;
123
+ case this.modes.SelectListWithNumberOutput:
124
+ this.showButton = true;
125
+ model.checked = !model.checked;
126
+ this._createModelForSelectListWithNumberOutput();
127
+ break;
128
+ case this.modes.Slider:
129
+ this._createModelForSliderMode();
130
+ break;
131
+ case this.modes.CheckboxToText:
132
+ this._createModelForCheckboxToText();
133
+ break;
134
+ case this.modes.CheckboxToSimpleText:
135
+ this._createModelForCheckboxToSimpleText();
136
+ break;
137
+ case this.modes.CheckboxToBinary:
138
+ this._createModelForCheckboxToBinary();
139
+ break;
140
+ case this.modes.DateRangeField:
141
+ this._createModelForDateRange(model);
142
+ break;
143
+ case this.modes.TextField:
144
+ this._model = (typeof this._model === 'string' && this._model.length === 0) ? undefined : this._model;
145
+ break;
72
146
  }
73
- model.checked = !model.checked;
147
+ this.modelChange.emit(this._model);
74
148
  this.collectionChange.emit(this.collection);
75
149
  }
150
+ uncheckForSingleSelect(model) {
151
+ this.collection.forEach(m => {
152
+ if (m.code !== model.code && m.description !== model.description) {
153
+ m.checked = false;
154
+ }
155
+ });
156
+ }
76
157
  valueSelected() {
77
158
  if (this.collection) {
78
159
  return !!this.collection.find(c => c.checked);
@@ -114,6 +195,226 @@ export class FilterItemComponent {
114
195
  onButtonClicked() {
115
196
  this.filterButtonClicked.emit();
116
197
  }
198
+ /////////////////////////////////////////////////////////////
199
+ //Model creation for all of the different options available//
200
+ /////////////////////////////////////////////////////////////
201
+ _createModelForFilterList() {
202
+ let filterRange = [];
203
+ if (this.collection !== null && this.collection !== undefined) {
204
+ this.collection.forEach((viewModel) => {
205
+ if (viewModel.checked) {
206
+ filterRange.push(`?='${viewModel.code}'`);
207
+ }
208
+ });
209
+ if (filterRange.length > 0) {
210
+ this._model = filterRange.join(',');
211
+ }
212
+ else {
213
+ this._model = undefined;
214
+ }
215
+ }
216
+ }
217
+ _createModelForStringCollectionList() {
218
+ let filterRange = [];
219
+ this.collection.forEach((viewModel) => {
220
+ if (viewModel.checked) {
221
+ filterRange.push(viewModel.code.toString());
222
+ }
223
+ });
224
+ if (filterRange.length > 0) {
225
+ this._model = filterRange;
226
+ }
227
+ else {
228
+ this._model = undefined;
229
+ }
230
+ }
231
+ _createModelForSingleSelectList() {
232
+ let filterString = "";
233
+ this.collection.forEach((viewModel) => {
234
+ if (viewModel.checked) {
235
+ filterString = viewModel.code.toString();
236
+ }
237
+ });
238
+ if (filterString.length > 0) {
239
+ this._model = filterString;
240
+ }
241
+ else {
242
+ this._model = undefined;
243
+ }
244
+ }
245
+ _createModelForSelectListWithNumberOutput() {
246
+ let filterNumber = null;
247
+ this.collection.forEach((viewModel) => {
248
+ if (viewModel.checked) {
249
+ if (filterNumber == null) {
250
+ filterNumber = 0;
251
+ }
252
+ filterNumber += Number(viewModel.code);
253
+ }
254
+ });
255
+ this._model = filterNumber;
256
+ }
257
+ _createModelForSliderMode() {
258
+ this.sliderMin = !!this.sliderMin ? this.sliderMin : this.sliderDefaultMin;
259
+ this.sliderMax = !!this.sliderMax ? this.sliderMax : this.sliderDefaultMax;
260
+ let trueLowerBound = Math.min(this.sliderMin, this.sliderMax);
261
+ let trueUpperBound = Math.max(this.sliderMin, this.sliderMax);
262
+ this._model = `${trueLowerBound} - ${trueUpperBound}`;
263
+ }
264
+ _createModelForCheckboxToText() {
265
+ if (this.checkBoxToTextModel) {
266
+ this._model = "?='J'";
267
+ }
268
+ else {
269
+ this._model = "?='N'";
270
+ }
271
+ }
272
+ _createModelForCheckboxToSimpleText() {
273
+ if (this.checkBoxToTextModel) {
274
+ this._model = "J";
275
+ }
276
+ else {
277
+ this._model = "N";
278
+ }
279
+ }
280
+ _createModelForCheckboxToBinary() {
281
+ if (this.checkBoxToTextModel) {
282
+ this._model = 1;
283
+ }
284
+ else {
285
+ this._model = 0;
286
+ }
287
+ }
288
+ _createModelForDateRange(dates) {
289
+ if (dates) {
290
+ let startDate = dates[0];
291
+ let endDate = dates[1];
292
+ const startDateRequest = startDate ? this._formatDateToString(startDate) : '';
293
+ const endDateRequest = endDate ? this._formatDateToString(endDate) : '';
294
+ this._model = `?>=\'${startDateRequest}\'& ?<=\'${endDateRequest}\'`;
295
+ }
296
+ }
297
+ _formatDateToString(date) {
298
+ let day = date.getDate().toString().padStart(2, '0');
299
+ let month = (date.getMonth() + 1).toString().padStart(2, '0');
300
+ let year = date.getFullYear();
301
+ return `${day}-${month}-${year}`;
302
+ }
303
+ ////////////////////////////////////////////////////////////
304
+ //Model reading for all of the different options available//
305
+ ////////////////////////////////////////////////////////////
306
+ _readModelForFilterList(filterModel) {
307
+ let filterList = [];
308
+ let itemsToCheck = [];
309
+ this._uncheckAll();
310
+ this._model = filterModel;
311
+ if (filterModel !== null && filterModel !== undefined && typeof filterModel === 'string' && filterModel.length != 0 && this.collection !== null && this.collection !== undefined) {
312
+ filterList = filterModel.split(",");
313
+ filterList.forEach((filter) => {
314
+ itemsToCheck.push(filter.substr(3, filter.length - 4));
315
+ });
316
+ for (const item of itemsToCheck) {
317
+ let filter = this.collection.find(element => element.code.toString() === item);
318
+ if (filter !== null && filter !== undefined) {
319
+ filter.checked = true;
320
+ }
321
+ else {
322
+ filter.checked = false;
323
+ }
324
+ }
325
+ this._model = filterModel;
326
+ }
327
+ }
328
+ _readModelForSingleSelectList(singleSelectModel) {
329
+ this._uncheckAll();
330
+ this._model = singleSelectModel;
331
+ if (singleSelectModel !== null && singleSelectModel !== undefined && this.collection !== null && this.collection !== undefined) {
332
+ let filter = this.collection.find(element => element.code.toString() === singleSelectModel);
333
+ if (filter) {
334
+ filter.checked = true;
335
+ }
336
+ }
337
+ }
338
+ _readModelForStringCollectionList(collectionModel) {
339
+ this._uncheckAll();
340
+ this._model = collectionModel;
341
+ if (collectionModel !== null && collectionModel !== undefined && this.collection !== null && this.collection !== undefined) {
342
+ this.collection.forEach((viewModel) => {
343
+ if (collectionModel.indexOf(viewModel.code.toString()) > -1) {
344
+ viewModel.checked = true;
345
+ }
346
+ else {
347
+ viewModel.checked = false;
348
+ }
349
+ });
350
+ }
351
+ }
352
+ _readModelForSelectListWithNumberOutput(numberModel) {
353
+ this._uncheckAll();
354
+ this._model = numberModel;
355
+ if (numberModel !== null && numberModel !== undefined && this.collection !== null && this.collection !== undefined) {
356
+ for (const item of this.collection) {
357
+ const itemCode = item.code;
358
+ const modValue = (numberModel % (2 * itemCode));
359
+ item.checked = (modValue >= itemCode);
360
+ }
361
+ }
362
+ }
363
+ _uncheckAll() {
364
+ if (this.collection !== null && this.collection !== undefined) {
365
+ this.collection.forEach(m => {
366
+ m.checked = false;
367
+ });
368
+ }
369
+ }
370
+ _readModelForSliderMode(sliderModel) {
371
+ this._model = sliderModel;
372
+ if (sliderModel !== undefined && sliderModel !== null) {
373
+ let sliderInputCollection = sliderModel.split(' - ');
374
+ this.sliderMin = parseInt(sliderInputCollection[0]);
375
+ this.sliderMax = parseInt(sliderInputCollection[1]);
376
+ }
377
+ else {
378
+ this.sliderMin = this.sliderDefaultMin;
379
+ this.sliderMax = this.sliderDefaultMax;
380
+ }
381
+ }
382
+ _readModelForCheckboxToText(checkboxToTextModel) {
383
+ this._model = checkboxToTextModel;
384
+ if (checkboxToTextModel !== undefined && checkboxToTextModel !== null) {
385
+ this.checkBoxToTextModel = (checkboxToTextModel.indexOf('J') > -1);
386
+ }
387
+ else {
388
+ this.checkBoxToTextModel = false;
389
+ }
390
+ }
391
+ _readModelForCheckboxToBinary(checkboxToBinary) {
392
+ this._model = checkboxToBinary;
393
+ if (checkboxToBinary !== undefined && checkboxToBinary !== null) {
394
+ this.checkBoxToTextModel = (checkboxToBinary >= 1);
395
+ }
396
+ else {
397
+ this.checkBoxToTextModel = false;
398
+ }
399
+ }
400
+ _readModelForDateField(dateFieldModel) {
401
+ this._model = dateFieldModel;
402
+ if (dateFieldModel !== undefined && dateFieldModel !== null) {
403
+ this._model = new Date(dateFieldModel);
404
+ }
405
+ }
406
+ _readModelForDateRangeField(dateRangeFieldModel) {
407
+ this._model = dateRangeFieldModel;
408
+ if (dateRangeFieldModel !== undefined && dateRangeFieldModel !== null) {
409
+ let dateCollection = dateRangeFieldModel.split('&');
410
+ let startString = dateCollection[0].trim().substr(4, dateCollection[0].length - 5);
411
+ let endString = dateCollection[1].trim().substr(4, dateCollection[1].length - 5);
412
+ let startDateComponents = startString.split('-');
413
+ let endDateComponents = endString.split('-');
414
+ this.dateRangeStart = new Date(parseInt(startDateComponents[2]), parseInt(startDateComponents[1]) - 1, parseInt(startDateComponents[0]));
415
+ this.dateRangeEnd = new Date(parseInt(endDateComponents[2]), parseInt(endDateComponents[1]) - 1, parseInt(endDateComponents[0]));
416
+ }
417
+ }
117
418
  }
118
419
  FilterItemComponent.decorators = [
119
420
  { type: Component, args: [{
@@ -135,7 +436,8 @@ FilterItemComponent.decorators = [
135
436
  <ng-content></ng-content>
136
437
  </div>
137
438
  <ng-template #collectionContent>
138
- <div class="co-filter-item-collection-content">
439
+ <div class="co-filter-item-collection-content" *ngIf="mode === modes.Filterlist || mode === modes.SingleSelectList
440
+ || mode === modes.SelectListWithNumberOutput || mode === modes.SelectListWithStringCollectionOutput">
139
441
  <co-input-text
140
442
  *ngIf="collection?.length > 10 || minSearchCharsToLoadCollection"
141
443
  [placeholder]="searchPlaceholder"
@@ -150,13 +452,13 @@ FilterItemComponent.decorators = [
150
452
  <ng-container
151
453
  *ngFor="let option of filteredCollection; let index = index">
152
454
  <div class="co-filter-item-collection-result-item" *ngIf="index < limitTo || showAllResults">
153
- <co-input-checkbox *ngIf="!singleSelect"
455
+ <co-input-checkbox *ngIf="mode !== modes.SingleSelectList"
154
456
  [label]="option.description"
155
457
  [model]="option.checked"
156
458
  [clickableLabel]="false"
157
459
  (modelChange)="handleModelChange(option)"
158
460
  ></co-input-checkbox>
159
- <co-input-radio-button *ngIf="singleSelect"
461
+ <co-input-radio-button *ngIf="mode === modes.SingleSelectList"
160
462
  [label]="option.description"
161
463
  [model]="option.checked"
162
464
  (modelChange)="handleModelChange(option)"
@@ -185,6 +487,57 @@ FilterItemComponent.decorators = [
185
487
  </div>
186
488
  </div>
187
489
  </div>
490
+ <div class="co-filter-item-slider-content" *ngIf="mode === modes.Slider">
491
+ <co-input-text
492
+ class="slider-from"
493
+ [type]="'number'"
494
+ [digitsOnly]="true"
495
+ [hideArrowButtons]="true"
496
+ [excludePlusMinus]="true"
497
+ [label]="'FROM' | localize"
498
+ [(model)]="sliderMin"
499
+ (modelChange)="handleModelChange($event)"
500
+ ></co-input-text>
501
+ <co-input-text
502
+ class="slider-to"
503
+ [type]="'number'"
504
+ [digitsOnly]="true"
505
+ [hideArrowButtons]="true"
506
+ [excludePlusMinus]="true"
507
+ [label]="'TO' | localize"
508
+ [(model)]="sliderMax"
509
+ (modelChange)="handleModelChange($event)"
510
+ ></co-input-text>
511
+ </div>
512
+ <div class="co-filter-item-checkbox-content" *ngIf="mode === modes.Checkbox ">
513
+ <co-input-checkbox
514
+ [(model)]="model"
515
+ (modelChange)="handleModelChange($event)"></co-input-checkbox>
516
+ </div>
517
+ <div class="co-filter-item-checkbox-content"
518
+ *ngIf="mode === modes.CheckboxToText || mode === modes.CheckboxToSimpleText || mode === modes.CheckboxToBinary">
519
+ <co-input-checkbox
520
+ [(model)]="checkBoxToTextModel"
521
+ (modelChange)="handleModelChange($event)"></co-input-checkbox>
522
+ </div>
523
+ <div class="co-filter-item-textfield-content" *ngIf="mode === modes.TextField">
524
+ <co-input-text
525
+ [(model)]="model"
526
+ (modelChange)="handleModelChange($event)"></co-input-text>
527
+ </div>
528
+ <div class="co-filter-item-dateField-content" *ngIf="mode === modes.DateField">
529
+ <co-input-date
530
+ [(model)]="model"
531
+ (modelChange)="handleModelChange($event)"
532
+ ></co-input-date>
533
+ </div>
534
+ <div class="co-filter-item-dateField-content" *ngIf="mode === modes.DateRangeField">
535
+ <co-input-date-range
536
+ [model]="[dateRangeStart, dateRangeEnd]"
537
+ (modelChange)="handleModelChange($event)"
538
+ [placeholder]="'SELECT_DATE' | localize">
539
+ </co-input-date-range>
540
+ </div>
188
541
  </ng-template>
189
542
  </div>
190
543
  </co-collapsible>
@@ -196,9 +549,11 @@ FilterItemComponent.decorators = [
196
549
  },] }
197
550
  ];
198
551
  FilterItemComponent.ctorParameters = () => [
199
- { type: IconCacheService }
552
+ { type: IconCacheService },
553
+ { type: ChangeDetectorRef }
200
554
  ];
201
555
  FilterItemComponent.propDecorators = {
556
+ mode: [{ type: Input }],
202
557
  collection: [{ type: Input }],
203
558
  placeholder: [{ type: Input }],
204
559
  initialLimit: [{ type: Input }],
@@ -207,14 +562,17 @@ FilterItemComponent.propDecorators = {
207
562
  collectionLoadFn: [{ type: Input }],
208
563
  customContent: [{ type: Input }],
209
564
  showAllResults: [{ type: Input }],
210
- singleSelect: [{ type: Input }],
211
565
  filterButtonLabel: [{ type: Input }],
212
566
  searchPlaceholder: [{ type: Input }],
213
567
  showMoreLabel: [{ type: Input }],
214
568
  showLessLabel: [{ type: Input }],
215
569
  noResultsLabel: [{ type: Input }],
570
+ sliderDefaultMin: [{ type: Input }],
571
+ sliderDefaultMax: [{ type: Input }],
572
+ model: [{ type: Input }],
573
+ modelChange: [{ type: Output }],
216
574
  collectionChange: [{ type: Output }],
217
575
  filterButtonClicked: [{ type: Output }],
218
- showClass: [{ type: HostBinding, args: ["class.co-filter-item",] }]
576
+ filteredCollection: [{ type: HostBinding, args: ["class.co-filter-item",] }]
219
577
  };
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"]}
578
+ //# 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, ChangeDetectorRef,\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            </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\"\r\n                 *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    //reset the model in case there was no collection to set its values on when it was set.\r\n    this.model = this._model;\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 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    switch (this.mode) {\r\n      case this.modes.Filterlist:\r\n        this._readModelForFilterList(filterString);\r\n        break;\r\n      case this.modes.SingleSelectList:\r\n        this._readModelForSingleSelectList(filterString);\r\n        break;\r\n      case this.modes.SelectListWithStringCollectionOutput:\r\n        this._readModelForStringCollectionList(filterString);\r\n        break;\r\n      case this.modes.SelectListWithNumberOutput:\r\n        this._readModelForSelectListWithNumberOutput(filterString);\r\n        break;\r\n      case this.modes.Slider:\r\n        this._readModelForSliderMode(filterString);\r\n        break;\r\n      case this.modes.CheckboxToText:\r\n      case this.modes.CheckboxToSimpleText:\r\n        this._readModelForCheckboxToText(filterString);\r\n        break;\r\n      case this.modes.CheckboxToBinary:\r\n        this._readModelForCheckboxToBinary(filterString);\r\n        break;\r\n      case this.modes.DateField:\r\n        this._readModelForDateField(filterString);\r\n        break;\r\n      case this.modes.DateRangeField:\r\n        this._readModelForDateRangeField(filterString);\r\n        break;\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<FilterItemViewmodel[]> = new EventEmitter<FilterItemViewmodel[]>();\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\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  //models for the slider field inputs\r\n  public sliderMin: number;\r\n  public sliderMax: number;\r\n\r\n  //models for th daterange input\r\n  public dateRangeStart: Date;\r\n  public dateRangeEnd: Date;\r\n\r\n  //model for the textbox options that need a converted output\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              private _changeDetector: ChangeDetectorRef) {\r\n  }\r\n\r\n  public ngOnInit(): void {\r\n    this.setToInitialLimit();\r\n    this.showButton = this.valueSelected();\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    switch (this.mode) {\r\n      case this.modes.Filterlist:\r\n        this.showButton = true;\r\n        model.checked = !model.checked;\r\n        this._createModelForFilterList();\r\n        break;\r\n      case this.modes.SelectListWithStringCollectionOutput:\r\n        this.showButton = true;\r\n        model.checked = !model.checked;\r\n        this._createModelForStringCollectionList();\r\n        break;\r\n      case 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        break;\r\n      case this.modes.SelectListWithNumberOutput:\r\n        this.showButton = true;\r\n        model.checked = !model.checked;\r\n        this._createModelForSelectListWithNumberOutput();\r\n        break;\r\n      case this.modes.Slider:\r\n        this._createModelForSliderMode();\r\n        break;\r\n      case this.modes.CheckboxToText:\r\n        this._createModelForCheckboxToText();\r\n        break;\r\n      case this.modes.CheckboxToSimpleText:\r\n        this._createModelForCheckboxToSimpleText();\r\n        break;\r\n      case this.modes.CheckboxToBinary:\r\n        this._createModelForCheckboxToBinary();\r\n        break;\r\n      case this.modes.DateRangeField:\r\n        this._createModelForDateRange(model);\r\n        break;\r\n      case this.modes.TextField:\r\n        this._model = (typeof this._model === 'string' && this._model.length === 0) ? undefined : this._model;\r\n        break;\r\n    }\r\n    this.modelChange.emit(this._model);\r\n    this.collectionChange.emit(this.collection);\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  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  /////////////////////////////////////////////////////////////\r\n  //Model creation for all of the different options available//\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      if (filterRange.length > 0) {\r\n        this._model = filterRange.join(',');\r\n      } else {\r\n        this._model = undefined;\r\n      }\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    if (filterRange.length > 0) {\r\n      this._model = filterRange;\r\n    } else {\r\n      this._model = undefined;\r\n    }\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    if (filterString.length > 0) {\r\n      this._model = filterString;\r\n    } else {\r\n      this._model = undefined;\r\n    }\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  private _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      this._model = `?>=\\'${startDateRequest}\\'& ?<=\\'${endDateRequest}\\'`;\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  ////////////////////////////////////////////////////////////\r\n  //Model reading for all of the different options available//\r\n  ////////////////////////////////////////////////////////////\r\n  private _readModelForFilterList(filterModel: string): void {\r\n    let filterList: string[] = [];\r\n    let itemsToCheck: string[] = [];\r\n    this._uncheckAll();\r\n    this._model = filterModel;\r\n\r\n    if (filterModel !== null && filterModel !== undefined && typeof filterModel === 'string' && filterModel.length != 0 && this.collection !== null && this.collection !== undefined) {\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 !== null && filter !== undefined) {\r\n          filter.checked = true;\r\n        } else {\r\n          filter.checked = false;\r\n        }\r\n      }\r\n      this._model = filterModel;\r\n    }\r\n\r\n  }\r\n\r\n  private _readModelForSingleSelectList(singleSelectModel: string) {\r\n    this._uncheckAll();\r\n    this._model = singleSelectModel;\r\n\r\n    if (singleSelectModel !== null && singleSelectModel !== undefined && this.collection !== null && this.collection !== undefined) {\r\n      let filter = this.collection.find(element => element.code.toString() === singleSelectModel);\r\n      if (filter) {\r\n        filter.checked = true;\r\n      }\r\n    }\r\n  }\r\n\r\n  private _readModelForStringCollectionList(collectionModel: string[]): void {\r\n    this._uncheckAll();\r\n    this._model = collectionModel;\r\n\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.toString()) > -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  private _readModelForSelectListWithNumberOutput(numberModel: number) {\r\n    this._uncheckAll();\r\n    this._model = numberModel;\r\n\r\n    if (numberModel !== null && numberModel !== undefined && this.collection !== null && this.collection !== 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  private _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  private _readModelForSliderMode(sliderModel: string): void {\r\n    this._model = sliderModel;\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  private _readModelForCheckboxToText(checkboxToTextModel: string): void {\r\n    this._model = checkboxToTextModel;\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  private _readModelForCheckboxToBinary(checkboxToBinary: number): void {\r\n    this._model = checkboxToBinary;\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  private _readModelForDateField(dateFieldModel: string): void {\r\n    this._model = dateFieldModel;\r\n    if (dateFieldModel !== undefined && dateFieldModel !== null) {\r\n      this._model = new Date(dateFieldModel);\r\n    }\r\n  }\r\n\r\n  private _readModelForDateRangeField(dateRangeFieldModel: string): void {\r\n    this._model = dateRangeFieldModel;\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"]}