@colijnit/corecomponents_v12 12.0.34 → 12.0.35

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.
@@ -9,34 +9,37 @@ export class FilterItemComponent {
9
9
  this.expanded = false;
10
10
  // Set to false to use filter item with a multi selectable collection. Set to true to specify custom content
11
11
  this.customContent = false;
12
- // Set to true to show filter input field.
13
- this.searchable = true;
14
12
  // Set to true to show all results. Set to false to get 'show more' and 'show less' buttons to expand and contract.
15
13
  this.showAllResults = false;
16
14
  this.searchPlaceholder = "Search...";
17
15
  this.showMoreLabel = 'Show more';
18
16
  this.showLessLabel = 'Show less';
19
17
  this.noResultsLabel = "No results";
20
- this.collectionChanged = new EventEmitter();
21
- this.filteredCollection = { filterItems: [] };
18
+ this.collectionChange = new EventEmitter();
19
+ this.filteredCollection = [];
22
20
  this.limitTo = 10;
23
21
  this.filterText = "";
24
- this._collection = { filterItems: [] };
22
+ this.searchable = true;
23
+ this._collection = [];
25
24
  }
26
25
  set collection(value) {
27
- var _a, _b;
26
+ var _a;
28
27
  this._collection = value;
29
- this.filteredCollection.filterItems = (_b = (_a = this._collection) === null || _a === void 0 ? void 0 : _a.filterItems) === null || _b === void 0 ? void 0 : _b.slice();
28
+ this.filteredCollection = (_a = this._collection) === null || _a === void 0 ? void 0 : _a.slice();
30
29
  }
31
30
  get collection() {
32
31
  return this._collection;
33
32
  }
34
- // output bij: filtertext, kan gebruikt worden voor wanneer collectie opgehaald wordt
35
33
  showClass() {
36
34
  return true;
37
35
  }
38
36
  ngOnInit() {
39
37
  this.setToInitialLimit();
38
+ this.setSearchable();
39
+ }
40
+ setSearchable() {
41
+ var _a;
42
+ this.searchable = ((_a = this.collection) === null || _a === void 0 ? void 0 : _a.length) > 10;
40
43
  }
41
44
  setToInitialLimit() {
42
45
  this.limitTo = this.initialLimit;
@@ -45,31 +48,31 @@ export class FilterItemComponent {
45
48
  this.limitTo += 10;
46
49
  }
47
50
  moreToShow() {
48
- var _a, _b;
51
+ var _a;
49
52
  if (this.showAllResults) {
50
53
  return false;
51
54
  }
52
- return ((_b = (_a = this.filteredCollection) === null || _a === void 0 ? void 0 : _a.filterItems) === null || _b === void 0 ? void 0 : _b.length) > this.limitTo;
55
+ return ((_a = this.filteredCollection) === null || _a === void 0 ? void 0 : _a.length) > this.limitTo;
53
56
  }
54
57
  lessToShow() {
55
- var _a, _b, _c, _d;
58
+ var _a, _b;
56
59
  if (this.showAllResults) {
57
60
  return false;
58
61
  }
59
- return ((_b = (_a = this.filteredCollection) === null || _a === void 0 ? void 0 : _a.filterItems) === null || _b === void 0 ? void 0 : _b.length) <= this.limitTo && ((_d = (_c = this.filteredCollection) === null || _c === void 0 ? void 0 : _c.filterItems) === null || _d === void 0 ? void 0 : _d.length) > this.initialLimit;
62
+ 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;
60
63
  }
61
64
  // Applies filter to the collection.
62
65
  applyFilter(text) {
63
66
  var _a, _b;
64
67
  if (!this.collection) {
65
- return { filterItems: [] };
68
+ return [];
66
69
  }
67
70
  const filterText = (_a = this.filterText) === null || _a === void 0 ? void 0 : _a.toString().toLowerCase();
68
71
  let filteredItemCount = 0;
69
- this.filteredCollection.filterItems = (_b = this.collection) === null || _b === void 0 ? void 0 : _b.filterItems.filter((item) => {
72
+ this.filteredCollection = (_b = this.collection) === null || _b === void 0 ? void 0 : _b.filter((item) => {
70
73
  var _a;
71
- const labelText = (_a = item[this.fields.text]) === null || _a === void 0 ? void 0 : _a.toString().toLowerCase();
72
- const isHiddenByFilter = (labelText.indexOf(filterText) === -1);
74
+ const labelText = (_a = item.description) === null || _a === void 0 ? void 0 : _a.toString().toLowerCase();
75
+ const isHiddenByFilter = ((labelText === null || labelText === void 0 ? void 0 : labelText.indexOf(filterText)) === -1);
73
76
  if (isHiddenByFilter) {
74
77
  return false;
75
78
  }
@@ -104,21 +107,22 @@ FilterItemComponent.decorators = [
104
107
  (modelChange)="applyFilter($event)"
105
108
  >
106
109
  </co-input-text>
107
- <div class="no-results" *ngIf="filteredCollection?.filterItems?.length === 0">
110
+ <div class="no-results" *ngIf="filteredCollection?.length === 0">
108
111
  <span [textContent]="noResultsLabel"></span>
109
112
  </div>
110
113
  <div class="co-filter-item-collection-results">
111
114
  <div class="co-filter-item-collection-result-items"
112
- *ngFor="let option of filteredCollection?.filterItems; let index = index">
115
+ *ngFor="let option of filteredCollection; let index = index">
113
116
  <div class="co-filter-item-collection-result-item" *ngIf="index < limitTo || showAllResults">
114
- <co-input-checkbox [label]="option[fields.text]"
117
+ <co-input-checkbox [label]="option.description"
115
118
  [(model)]="option.checked"
116
- (modelChange)="collectionChanged.emit()"
119
+ (modelChange)="collectionChange.emit(collection)"
117
120
  ></co-input-checkbox>
118
- <div class="co-filter-item-amount" *ngIf="fields.count"
119
- [textContent]="option[fields.count] | append: ')' | prepend: ' ('"
121
+ <div class="co-filter-item-amount" *ngIf="option.count"
122
+ [textContent]="option.count.toString() | append: ')' | prepend: ' ('"
120
123
  ></div>
121
124
  </div>
125
+
122
126
  </div>
123
127
  </div>
124
128
  <div class="co-filter-show-more-or-less" *ngIf="!showAllResults">
@@ -152,18 +156,16 @@ FilterItemComponent.ctorParameters = () => [
152
156
  ];
153
157
  FilterItemComponent.propDecorators = {
154
158
  collection: [{ type: Input }],
155
- fields: [{ type: Input }],
156
159
  placeholder: [{ type: Input }],
157
160
  initialLimit: [{ type: Input }],
158
161
  expanded: [{ type: Input }],
159
162
  customContent: [{ type: Input }],
160
- searchable: [{ type: Input }],
161
163
  showAllResults: [{ type: Input }],
162
164
  searchPlaceholder: [{ type: Input }],
163
165
  showMoreLabel: [{ type: Input }],
164
166
  showLessLabel: [{ type: Input }],
165
167
  noResultsLabel: [{ type: Input }],
166
- collectionChanged: [{ type: Output }],
168
+ collectionChange: [{ type: Output }],
167
169
  showClass: [{ type: HostBinding, args: ["class.co-filter-item",] }]
168
170
  };
169
- //# 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 { Component, EventEmitter, HostBinding, Input, OnInit, Output, ViewEncapsulation } from \"@angular/core\";\r\nimport { CoreComponentsIcon } from \"../../core/enum/core-components-icon.enum\";\r\nimport { FilterViewmodel } from \"../../core/interface/filter-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      >\r\n        <div class=\"co-filter-item-collapsable-content\">\r\n          <div class=\"co-filter-item-custom-content\" *ngIf=\"customContent; else collectionContent\">\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=\"searchable\"\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?.filterItems?.length === 0\">\r\n                <span [textContent]=\"noResultsLabel\"></span>\r\n              </div>\r\n              <div class=\"co-filter-item-collection-results\">\r\n                <div class=\"co-filter-item-collection-result-items\"\r\n                     *ngFor=\"let option of filteredCollection?.filterItems; let index = index\">\r\n                  <div class=\"co-filter-item-collection-result-item\" *ngIf=\"index < limitTo || showAllResults\">\r\n                    <co-input-checkbox [label]=\"option[fields.text]\"\r\n                                       [(model)]=\"option.checked\"\r\n                                       (modelChange)=\"collectionChanged.emit()\"\r\n                    ></co-input-checkbox>\r\n                    <div class=\"co-filter-item-amount\" *ngIf=\"fields.count\"\r\n                         [textContent]=\"option[fields.count] | append: ')' | prepend: '      ('\"\r\n                    ></div>\r\n                  </div>\r\n                </div>\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})\r\nexport class FilterItemComponent implements OnInit {\r\n  public icons: typeof CoreComponentsIcon = CoreComponentsIcon;\r\n\r\n  @Input()\r\n  public set collection(value: FilterViewmodel) {\r\n    this._collection = value;\r\n    this.filteredCollection.filterItems = this._collection?.filterItems?.slice();\r\n  }\r\n\r\n  public get collection(): FilterViewmodel {\r\n    return this._collection;\r\n  }\r\n\r\n  @Input()\r\n  public fields: { text, value, count?: string };\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  // 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 filter input field.\r\n  @Input()\r\n  public searchable: boolean = true;\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 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 collectionChanged: EventEmitter<any> = new EventEmitter<any>();\r\n  // output bij: filtertext, kan gebruikt worden voor wanneer collectie opgehaald wordt\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: FilterViewmodel = {filterItems: []};\r\n  public limitTo: number = 10;\r\n  public filterText: string = \"\";\r\n\r\n  private _collection: FilterViewmodel = {filterItems: []};\r\n\r\n  constructor(public iconService: IconCacheService) {\r\n  }\r\n\r\n  public ngOnInit(): void {\r\n    this.setToInitialLimit();\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?.filterItems?.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?.filterItems?.length <= this.limitTo && this.filteredCollection?.filterItems?.length > this.initialLimit;\r\n  }\r\n\r\n\r\n  // Applies filter to the collection.\r\n  public applyFilter(text: string): FilterViewmodel {\r\n    if (!this.collection) {\r\n      return {filterItems: []};\r\n    }\r\n\r\n    const filterText: string = this.filterText?.toString().toLowerCase();\r\n    let filteredItemCount: number = 0;\r\n    this.filteredCollection.filterItems = this.collection?.filterItems.filter((item) => {\r\n      const labelText: string = item[this.fields.text]?.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"]}
171
+ //# 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 { Component, EventEmitter, HostBinding, Input, OnInit, Output, ViewEncapsulation } from \"@angular/core\";\r\nimport { CoreComponentsIcon } from \"../../core/enum/core-components-icon.enum\";\r\nimport { FilterItemViewmodel } from \"../../core/interface/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      >\r\n        <div class=\"co-filter-item-collapsable-content\">\r\n          <div class=\"co-filter-item-custom-content\" *ngIf=\"customContent; else collectionContent\">\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=\"searchable\"\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                <div class=\"co-filter-item-collection-result-items\"\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 [label]=\"option.description\"\r\n                                       [(model)]=\"option.checked\"\r\n                                       (modelChange)=\"collectionChange.emit(collection)\"\r\n                    ></co-input-checkbox>\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                </div>\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})\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  // 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 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  @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 searchable: boolean = true;\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.setSearchable();\r\n  }\r\n\r\n  public setSearchable(): void {\r\n    this.searchable = this.collection?.length > 10;\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\r\n  // Applies filter to the collection.\r\n  public applyFilter(text: string): [] {\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"]}
@@ -1,14 +1,14 @@
1
- import { NgModule } from "@angular/core";
1
+ import { ScrollingModule } from '@angular/cdk/scrolling';
2
2
  import { CommonModule } from "@angular/common";
3
+ import { NgModule } from "@angular/core";
4
+ import { AppendPipeModule } from '../../pipes/append.pipe.module';
5
+ import { PrependPipeModule } from '../../pipes/prepend.pipe.module';
3
6
  import { CollapsibleModule } from "../collapsible/collapsible.module";
4
7
  import { IconModule } from "../icon/icon.module";
5
8
  import { InputCheckboxMultiSelectModule } from "../input-checkbox-multi-select/input-checkbox-multi-select.module";
6
9
  import { InputCheckboxModule } from "../input-checkbox/input-checkbox.module";
7
10
  import { InputTextModule } from "../input-text/input-text.module";
8
11
  import { FilterItemComponent } from "./filter-item.component";
9
- import { ScrollingModule } from '@angular/cdk/scrolling';
10
- import { AppendPipeModule } from '../../pipes/append.pipe.module';
11
- import { PrependPipeModule } from '../../pipes/prepend.pipe.module';
12
12
  export class FilterItemModule {
13
13
  }
14
14
  FilterItemModule.decorators = [
@@ -32,4 +32,4 @@ FilterItemModule.decorators = [
32
32
  ]
33
33
  },] }
34
34
  ];
35
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmlsdGVyLWl0ZW0ubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvY29yZWNvbXBvbmVudHMvc3JjL2xpYi9jb21wb25lbnRzL2ZpbHRlci1pdGVtL2ZpbHRlci1pdGVtLm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUMsUUFBUSxFQUFDLE1BQU0sZUFBZSxDQUFDO0FBQ3ZDLE9BQU8sRUFBQyxZQUFZLEVBQUMsTUFBTSxpQkFBaUIsQ0FBQztBQUM3QyxPQUFPLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSxtQ0FBbUMsQ0FBQztBQUN0RSxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0scUJBQXFCLENBQUM7QUFDakQsT0FBTyxFQUFFLDhCQUE4QixFQUFFLE1BQU0sbUVBQW1FLENBQUM7QUFDbkgsT0FBTyxFQUFFLG1CQUFtQixFQUFFLE1BQU0seUNBQXlDLENBQUM7QUFDOUUsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLGlDQUFpQyxDQUFDO0FBQ2xFLE9BQU8sRUFBRSxtQkFBbUIsRUFBRSxNQUFNLHlCQUF5QixDQUFDO0FBQzlELE9BQU8sRUFBQyxlQUFlLEVBQUMsTUFBTSx3QkFBd0IsQ0FBQztBQUN2RCxPQUFPLEVBQUMsZ0JBQWdCLEVBQUMsTUFBTSxnQ0FBZ0MsQ0FBQztBQUNoRSxPQUFPLEVBQUMsaUJBQWlCLEVBQUMsTUFBTSxpQ0FBaUMsQ0FBQztBQXFCbEUsTUFBTSxPQUFPLGdCQUFnQjs7O1lBbkI1QixRQUFRLFNBQUM7Z0JBQ1IsT0FBTyxFQUFFO29CQUNQLFlBQVk7b0JBQ1osaUJBQWlCO29CQUNqQixlQUFlO29CQUNmLDhCQUE4QjtvQkFDOUIsbUJBQW1CO29CQUNuQixVQUFVO29CQUNWLGVBQWU7b0JBQ2YsZ0JBQWdCO29CQUNoQixpQkFBaUI7aUJBQ2xCO2dCQUNELFlBQVksRUFBRTtvQkFDWixtQkFBbUI7aUJBQ3BCO2dCQUNELE9BQU8sRUFBRTtvQkFDUCxtQkFBbUI7aUJBQ3BCO2FBQ0YiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge05nTW9kdWxlfSBmcm9tIFwiQGFuZ3VsYXIvY29yZVwiO1xyXG5pbXBvcnQge0NvbW1vbk1vZHVsZX0gZnJvbSBcIkBhbmd1bGFyL2NvbW1vblwiO1xyXG5pbXBvcnQgeyBDb2xsYXBzaWJsZU1vZHVsZSB9IGZyb20gXCIuLi9jb2xsYXBzaWJsZS9jb2xsYXBzaWJsZS5tb2R1bGVcIjtcclxuaW1wb3J0IHsgSWNvbk1vZHVsZSB9IGZyb20gXCIuLi9pY29uL2ljb24ubW9kdWxlXCI7XHJcbmltcG9ydCB7IElucHV0Q2hlY2tib3hNdWx0aVNlbGVjdE1vZHVsZSB9IGZyb20gXCIuLi9pbnB1dC1jaGVja2JveC1tdWx0aS1zZWxlY3QvaW5wdXQtY2hlY2tib3gtbXVsdGktc2VsZWN0Lm1vZHVsZVwiO1xyXG5pbXBvcnQgeyBJbnB1dENoZWNrYm94TW9kdWxlIH0gZnJvbSBcIi4uL2lucHV0LWNoZWNrYm94L2lucHV0LWNoZWNrYm94Lm1vZHVsZVwiO1xyXG5pbXBvcnQgeyBJbnB1dFRleHRNb2R1bGUgfSBmcm9tIFwiLi4vaW5wdXQtdGV4dC9pbnB1dC10ZXh0Lm1vZHVsZVwiO1xyXG5pbXBvcnQgeyBGaWx0ZXJJdGVtQ29tcG9uZW50IH0gZnJvbSBcIi4vZmlsdGVyLWl0ZW0uY29tcG9uZW50XCI7XHJcbmltcG9ydCB7U2Nyb2xsaW5nTW9kdWxlfSBmcm9tICdAYW5ndWxhci9jZGsvc2Nyb2xsaW5nJztcclxuaW1wb3J0IHtBcHBlbmRQaXBlTW9kdWxlfSBmcm9tICcuLi8uLi9waXBlcy9hcHBlbmQucGlwZS5tb2R1bGUnO1xyXG5pbXBvcnQge1ByZXBlbmRQaXBlTW9kdWxlfSBmcm9tICcuLi8uLi9waXBlcy9wcmVwZW5kLnBpcGUubW9kdWxlJztcclxuXHJcbkBOZ01vZHVsZSh7XHJcbiAgaW1wb3J0czogW1xyXG4gICAgQ29tbW9uTW9kdWxlLFxyXG4gICAgQ29sbGFwc2libGVNb2R1bGUsXHJcbiAgICBJbnB1dFRleHRNb2R1bGUsXHJcbiAgICBJbnB1dENoZWNrYm94TXVsdGlTZWxlY3RNb2R1bGUsXHJcbiAgICBJbnB1dENoZWNrYm94TW9kdWxlLFxyXG4gICAgSWNvbk1vZHVsZSxcclxuICAgIFNjcm9sbGluZ01vZHVsZSxcclxuICAgIEFwcGVuZFBpcGVNb2R1bGUsXHJcbiAgICBQcmVwZW5kUGlwZU1vZHVsZVxyXG4gIF0sXHJcbiAgZGVjbGFyYXRpb25zOiBbXHJcbiAgICBGaWx0ZXJJdGVtQ29tcG9uZW50XHJcbiAgXSxcclxuICBleHBvcnRzOiBbXHJcbiAgICBGaWx0ZXJJdGVtQ29tcG9uZW50XHJcbiAgXVxyXG59KVxyXG5leHBvcnQgY2xhc3MgRmlsdGVySXRlbU1vZHVsZSB7XHJcblxyXG59XHJcbiJdfQ==
35
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmlsdGVyLWl0ZW0ubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvY29yZWNvbXBvbmVudHMvc3JjL2xpYi9jb21wb25lbnRzL2ZpbHRlci1pdGVtL2ZpbHRlci1pdGVtLm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sd0JBQXdCLENBQUM7QUFDekQsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDekMsT0FBTyxFQUFFLGdCQUFnQixFQUFFLE1BQU0sZ0NBQWdDLENBQUM7QUFDbEUsT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0saUNBQWlDLENBQUM7QUFDcEUsT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0sbUNBQW1DLENBQUM7QUFDdEUsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLHFCQUFxQixDQUFDO0FBQ2pELE9BQU8sRUFBRSw4QkFBOEIsRUFBRSxNQUFNLG1FQUFtRSxDQUFDO0FBQ25ILE9BQU8sRUFBRSxtQkFBbUIsRUFBRSxNQUFNLHlDQUF5QyxDQUFDO0FBQzlFLE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSxpQ0FBaUMsQ0FBQztBQUNsRSxPQUFPLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSx5QkFBeUIsQ0FBQztBQXFCOUQsTUFBTSxPQUFPLGdCQUFnQjs7O1lBbkI1QixRQUFRLFNBQUM7Z0JBQ1IsT0FBTyxFQUFFO29CQUNQLFlBQVk7b0JBQ1osaUJBQWlCO29CQUNqQixlQUFlO29CQUNmLDhCQUE4QjtvQkFDOUIsbUJBQW1CO29CQUNuQixVQUFVO29CQUNWLGVBQWU7b0JBQ2YsZ0JBQWdCO29CQUNoQixpQkFBaUI7aUJBQ2xCO2dCQUNELFlBQVksRUFBRTtvQkFDWixtQkFBbUI7aUJBQ3BCO2dCQUNELE9BQU8sRUFBRTtvQkFDUCxtQkFBbUI7aUJBQ3BCO2FBQ0YiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBTY3JvbGxpbmdNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jZGsvc2Nyb2xsaW5nJztcclxuaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSBcIkBhbmd1bGFyL2NvbW1vblwiO1xyXG5pbXBvcnQgeyBOZ01vZHVsZSB9IGZyb20gXCJAYW5ndWxhci9jb3JlXCI7XHJcbmltcG9ydCB7IEFwcGVuZFBpcGVNb2R1bGUgfSBmcm9tICcuLi8uLi9waXBlcy9hcHBlbmQucGlwZS5tb2R1bGUnO1xyXG5pbXBvcnQgeyBQcmVwZW5kUGlwZU1vZHVsZSB9IGZyb20gJy4uLy4uL3BpcGVzL3ByZXBlbmQucGlwZS5tb2R1bGUnO1xyXG5pbXBvcnQgeyBDb2xsYXBzaWJsZU1vZHVsZSB9IGZyb20gXCIuLi9jb2xsYXBzaWJsZS9jb2xsYXBzaWJsZS5tb2R1bGVcIjtcclxuaW1wb3J0IHsgSWNvbk1vZHVsZSB9IGZyb20gXCIuLi9pY29uL2ljb24ubW9kdWxlXCI7XHJcbmltcG9ydCB7IElucHV0Q2hlY2tib3hNdWx0aVNlbGVjdE1vZHVsZSB9IGZyb20gXCIuLi9pbnB1dC1jaGVja2JveC1tdWx0aS1zZWxlY3QvaW5wdXQtY2hlY2tib3gtbXVsdGktc2VsZWN0Lm1vZHVsZVwiO1xyXG5pbXBvcnQgeyBJbnB1dENoZWNrYm94TW9kdWxlIH0gZnJvbSBcIi4uL2lucHV0LWNoZWNrYm94L2lucHV0LWNoZWNrYm94Lm1vZHVsZVwiO1xyXG5pbXBvcnQgeyBJbnB1dFRleHRNb2R1bGUgfSBmcm9tIFwiLi4vaW5wdXQtdGV4dC9pbnB1dC10ZXh0Lm1vZHVsZVwiO1xyXG5pbXBvcnQgeyBGaWx0ZXJJdGVtQ29tcG9uZW50IH0gZnJvbSBcIi4vZmlsdGVyLWl0ZW0uY29tcG9uZW50XCI7XHJcblxyXG5ATmdNb2R1bGUoe1xyXG4gIGltcG9ydHM6IFtcclxuICAgIENvbW1vbk1vZHVsZSxcclxuICAgIENvbGxhcHNpYmxlTW9kdWxlLFxyXG4gICAgSW5wdXRUZXh0TW9kdWxlLFxyXG4gICAgSW5wdXRDaGVja2JveE11bHRpU2VsZWN0TW9kdWxlLFxyXG4gICAgSW5wdXRDaGVja2JveE1vZHVsZSxcclxuICAgIEljb25Nb2R1bGUsXHJcbiAgICBTY3JvbGxpbmdNb2R1bGUsXHJcbiAgICBBcHBlbmRQaXBlTW9kdWxlLFxyXG4gICAgUHJlcGVuZFBpcGVNb2R1bGVcclxuICBdLFxyXG4gIGRlY2xhcmF0aW9uczogW1xyXG4gICAgRmlsdGVySXRlbUNvbXBvbmVudFxyXG4gIF0sXHJcbiAgZXhwb3J0czogW1xyXG4gICAgRmlsdGVySXRlbUNvbXBvbmVudFxyXG4gIF1cclxufSlcclxuZXhwb3J0IGNsYXNzIEZpbHRlckl0ZW1Nb2R1bGUge1xyXG5cclxufVxyXG4iXX0=
@@ -1,2 +1,2 @@
1
1
  export {};
2
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmlsdGVyLWl0ZW0tdmlld21vZGVsLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvY29yZWNvbXBvbmVudHMvc3JjL2xpYi9jb3JlL2ludGVyZmFjZS9maWx0ZXItaXRlbS12aWV3bW9kZWwudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBpbnRlcmZhY2UgRmlsdGVySXRlbVZpZXdtb2RlbCB7XHJcbiAgY2hlY2tlZDogYm9vbGVhbjtcclxuICBjb2RlOiBzdHJpbmcgfCBudW1iZXI7XHJcbiAgZGVzY3JpcHRpb246IHN0cmluZyB8IG51bWJlcjtcclxuICBjb3VudD86IG51bWJlcjtcclxufVxyXG4iXX0=
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmlsdGVyLWl0ZW0tdmlld21vZGVsLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvY29yZWNvbXBvbmVudHMvc3JjL2xpYi9jb3JlL2ludGVyZmFjZS9maWx0ZXItaXRlbS12aWV3bW9kZWwudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBpbnRlcmZhY2UgRmlsdGVySXRlbVZpZXdtb2RlbCB7XHJcbiAgY2hlY2tlZDogYm9vbGVhbjtcclxuICBjb2RlOiBzdHJpbmcgfCBudW1iZXI7XHJcbiAgZGVzY3JpcHRpb246IHN0cmluZztcclxuICBjb3VudD86IG51bWJlcjtcclxufVxyXG4iXX0=
@@ -9315,34 +9315,37 @@ class FilterItemComponent {
9315
9315
  this.expanded = false;
9316
9316
  // Set to false to use filter item with a multi selectable collection. Set to true to specify custom content
9317
9317
  this.customContent = false;
9318
- // Set to true to show filter input field.
9319
- this.searchable = true;
9320
9318
  // Set to true to show all results. Set to false to get 'show more' and 'show less' buttons to expand and contract.
9321
9319
  this.showAllResults = false;
9322
9320
  this.searchPlaceholder = "Search...";
9323
9321
  this.showMoreLabel = 'Show more';
9324
9322
  this.showLessLabel = 'Show less';
9325
9323
  this.noResultsLabel = "No results";
9326
- this.collectionChanged = new EventEmitter();
9327
- this.filteredCollection = { filterItems: [] };
9324
+ this.collectionChange = new EventEmitter();
9325
+ this.filteredCollection = [];
9328
9326
  this.limitTo = 10;
9329
9327
  this.filterText = "";
9330
- this._collection = { filterItems: [] };
9328
+ this.searchable = true;
9329
+ this._collection = [];
9331
9330
  }
9332
9331
  set collection(value) {
9333
- var _a, _b;
9332
+ var _a;
9334
9333
  this._collection = value;
9335
- this.filteredCollection.filterItems = (_b = (_a = this._collection) === null || _a === void 0 ? void 0 : _a.filterItems) === null || _b === void 0 ? void 0 : _b.slice();
9334
+ this.filteredCollection = (_a = this._collection) === null || _a === void 0 ? void 0 : _a.slice();
9336
9335
  }
9337
9336
  get collection() {
9338
9337
  return this._collection;
9339
9338
  }
9340
- // output bij: filtertext, kan gebruikt worden voor wanneer collectie opgehaald wordt
9341
9339
  showClass() {
9342
9340
  return true;
9343
9341
  }
9344
9342
  ngOnInit() {
9345
9343
  this.setToInitialLimit();
9344
+ this.setSearchable();
9345
+ }
9346
+ setSearchable() {
9347
+ var _a;
9348
+ this.searchable = ((_a = this.collection) === null || _a === void 0 ? void 0 : _a.length) > 10;
9346
9349
  }
9347
9350
  setToInitialLimit() {
9348
9351
  this.limitTo = this.initialLimit;
@@ -9351,31 +9354,31 @@ class FilterItemComponent {
9351
9354
  this.limitTo += 10;
9352
9355
  }
9353
9356
  moreToShow() {
9354
- var _a, _b;
9357
+ var _a;
9355
9358
  if (this.showAllResults) {
9356
9359
  return false;
9357
9360
  }
9358
- return ((_b = (_a = this.filteredCollection) === null || _a === void 0 ? void 0 : _a.filterItems) === null || _b === void 0 ? void 0 : _b.length) > this.limitTo;
9361
+ return ((_a = this.filteredCollection) === null || _a === void 0 ? void 0 : _a.length) > this.limitTo;
9359
9362
  }
9360
9363
  lessToShow() {
9361
- var _a, _b, _c, _d;
9364
+ var _a, _b;
9362
9365
  if (this.showAllResults) {
9363
9366
  return false;
9364
9367
  }
9365
- return ((_b = (_a = this.filteredCollection) === null || _a === void 0 ? void 0 : _a.filterItems) === null || _b === void 0 ? void 0 : _b.length) <= this.limitTo && ((_d = (_c = this.filteredCollection) === null || _c === void 0 ? void 0 : _c.filterItems) === null || _d === void 0 ? void 0 : _d.length) > this.initialLimit;
9368
+ 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;
9366
9369
  }
9367
9370
  // Applies filter to the collection.
9368
9371
  applyFilter(text) {
9369
9372
  var _a, _b;
9370
9373
  if (!this.collection) {
9371
- return { filterItems: [] };
9374
+ return [];
9372
9375
  }
9373
9376
  const filterText = (_a = this.filterText) === null || _a === void 0 ? void 0 : _a.toString().toLowerCase();
9374
9377
  let filteredItemCount = 0;
9375
- this.filteredCollection.filterItems = (_b = this.collection) === null || _b === void 0 ? void 0 : _b.filterItems.filter((item) => {
9378
+ this.filteredCollection = (_b = this.collection) === null || _b === void 0 ? void 0 : _b.filter((item) => {
9376
9379
  var _a;
9377
- const labelText = (_a = item[this.fields.text]) === null || _a === void 0 ? void 0 : _a.toString().toLowerCase();
9378
- const isHiddenByFilter = (labelText.indexOf(filterText) === -1);
9380
+ const labelText = (_a = item.description) === null || _a === void 0 ? void 0 : _a.toString().toLowerCase();
9381
+ const isHiddenByFilter = ((labelText === null || labelText === void 0 ? void 0 : labelText.indexOf(filterText)) === -1);
9379
9382
  if (isHiddenByFilter) {
9380
9383
  return false;
9381
9384
  }
@@ -9410,21 +9413,22 @@ FilterItemComponent.decorators = [
9410
9413
  (modelChange)="applyFilter($event)"
9411
9414
  >
9412
9415
  </co-input-text>
9413
- <div class="no-results" *ngIf="filteredCollection?.filterItems?.length === 0">
9416
+ <div class="no-results" *ngIf="filteredCollection?.length === 0">
9414
9417
  <span [textContent]="noResultsLabel"></span>
9415
9418
  </div>
9416
9419
  <div class="co-filter-item-collection-results">
9417
9420
  <div class="co-filter-item-collection-result-items"
9418
- *ngFor="let option of filteredCollection?.filterItems; let index = index">
9421
+ *ngFor="let option of filteredCollection; let index = index">
9419
9422
  <div class="co-filter-item-collection-result-item" *ngIf="index < limitTo || showAllResults">
9420
- <co-input-checkbox [label]="option[fields.text]"
9423
+ <co-input-checkbox [label]="option.description"
9421
9424
  [(model)]="option.checked"
9422
- (modelChange)="collectionChanged.emit()"
9425
+ (modelChange)="collectionChange.emit(collection)"
9423
9426
  ></co-input-checkbox>
9424
- <div class="co-filter-item-amount" *ngIf="fields.count"
9425
- [textContent]="option[fields.count] | append: ')' | prepend: ' ('"
9427
+ <div class="co-filter-item-amount" *ngIf="option.count"
9428
+ [textContent]="option.count.toString() | append: ')' | prepend: ' ('"
9426
9429
  ></div>
9427
9430
  </div>
9431
+
9428
9432
  </div>
9429
9433
  </div>
9430
9434
  <div class="co-filter-show-more-or-less" *ngIf="!showAllResults">
@@ -9458,18 +9462,16 @@ FilterItemComponent.ctorParameters = () => [
9458
9462
  ];
9459
9463
  FilterItemComponent.propDecorators = {
9460
9464
  collection: [{ type: Input }],
9461
- fields: [{ type: Input }],
9462
9465
  placeholder: [{ type: Input }],
9463
9466
  initialLimit: [{ type: Input }],
9464
9467
  expanded: [{ type: Input }],
9465
9468
  customContent: [{ type: Input }],
9466
- searchable: [{ type: Input }],
9467
9469
  showAllResults: [{ type: Input }],
9468
9470
  searchPlaceholder: [{ type: Input }],
9469
9471
  showMoreLabel: [{ type: Input }],
9470
9472
  showLessLabel: [{ type: Input }],
9471
9473
  noResultsLabel: [{ type: Input }],
9472
- collectionChanged: [{ type: Output }],
9474
+ collectionChange: [{ type: Output }],
9473
9475
  showClass: [{ type: HostBinding, args: ["class.co-filter-item",] }]
9474
9476
  };
9475
9477