@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.
- package/bundles/colijnit-corecomponents_v12.umd.js +21 -21
- package/bundles/colijnit-corecomponents_v12.umd.js.map +1 -1
- package/colijnit-corecomponents_v12.metadata.json +1 -1
- package/esm2015/lib/components/filter-item/filter-item.component.js +28 -26
- package/esm2015/lib/components/filter-item/filter-item.module.js +5 -5
- package/esm2015/lib/core/interface/filter-item-viewmodel.js +1 -1
- package/fesm2015/colijnit-corecomponents_v12.js +27 -25
- package/fesm2015/colijnit-corecomponents_v12.js.map +1 -1
- package/lib/components/filter-item/filter-item.component.d.ts +8 -12
- package/lib/components/filter-item/style/_layout.scss +9 -3
- package/lib/components/filter-item/style/_material-definition.scss +8 -1
- package/lib/core/interface/filter-item-viewmodel.d.ts +1 -1
- package/package.json +1 -1
- package/esm2015/lib/core/interface/filter-viewmodel.js +0 -2
- package/lib/core/interface/filter-viewmodel.d.ts +0 -4
|
@@ -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.
|
|
21
|
-
this.filteredCollection =
|
|
18
|
+
this.collectionChange = new EventEmitter();
|
|
19
|
+
this.filteredCollection = [];
|
|
22
20
|
this.limitTo = 10;
|
|
23
21
|
this.filterText = "";
|
|
24
|
-
this.
|
|
22
|
+
this.searchable = true;
|
|
23
|
+
this._collection = [];
|
|
25
24
|
}
|
|
26
25
|
set collection(value) {
|
|
27
|
-
var _a
|
|
26
|
+
var _a;
|
|
28
27
|
this._collection = value;
|
|
29
|
-
this.filteredCollection
|
|
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
|
|
51
|
+
var _a;
|
|
49
52
|
if (this.showAllResults) {
|
|
50
53
|
return false;
|
|
51
54
|
}
|
|
52
|
-
return ((
|
|
55
|
+
return ((_a = this.filteredCollection) === null || _a === void 0 ? void 0 : _a.length) > this.limitTo;
|
|
53
56
|
}
|
|
54
57
|
lessToShow() {
|
|
55
|
-
var _a, _b
|
|
58
|
+
var _a, _b;
|
|
56
59
|
if (this.showAllResults) {
|
|
57
60
|
return false;
|
|
58
61
|
}
|
|
59
|
-
return ((
|
|
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
|
|
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
|
|
72
|
+
this.filteredCollection = (_b = this.collection) === null || _b === void 0 ? void 0 : _b.filter((item) => {
|
|
70
73
|
var _a;
|
|
71
|
-
const labelText = (_a = item
|
|
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?.
|
|
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
|
|
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
|
|
117
|
+
<co-input-checkbox [label]="option.description"
|
|
115
118
|
[(model)]="option.checked"
|
|
116
|
-
(modelChange)="
|
|
119
|
+
(modelChange)="collectionChange.emit(collection)"
|
|
117
120
|
></co-input-checkbox>
|
|
118
|
-
<div class="co-filter-item-amount" *ngIf="
|
|
119
|
-
[textContent]="option
|
|
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
|
-
|
|
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 {
|
|
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,
|
|
35
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmlsdGVyLWl0ZW0ubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvY29yZWNvbXBvbmVudHMvc3JjL2xpYi9jb21wb25lbnRzL2ZpbHRlci1pdGVtL2ZpbHRlci1pdGVtLm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sd0JBQXdCLENBQUM7QUFDekQsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDekMsT0FBTyxFQUFFLGdCQUFnQixFQUFFLE1BQU0sZ0NBQWdDLENBQUM7QUFDbEUsT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0saUNBQWlDLENBQUM7QUFDcEUsT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0sbUNBQW1DLENBQUM7QUFDdEUsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLHFCQUFxQixDQUFDO0FBQ2pELE9BQU8sRUFBRSw4QkFBOEIsRUFBRSxNQUFNLG1FQUFtRSxDQUFDO0FBQ25ILE9BQU8sRUFBRSxtQkFBbUIsRUFBRSxNQUFNLHlDQUF5QyxDQUFDO0FBQzlFLE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSxpQ0FBaUMsQ0FBQztBQUNsRSxPQUFPLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSx5QkFBeUIsQ0FBQztBQXFCOUQsTUFBTSxPQUFPLGdCQUFnQjs7O1lBbkI1QixRQUFRLFNBQUM7Z0JBQ1IsT0FBTyxFQUFFO29CQUNQLFlBQVk7b0JBQ1osaUJBQWlCO29CQUNqQixlQUFlO29CQUNmLDhCQUE4QjtvQkFDOUIsbUJBQW1CO29CQUNuQixVQUFVO29CQUNWLGVBQWU7b0JBQ2YsZ0JBQWdCO29CQUNoQixpQkFBaUI7aUJBQ2xCO2dCQUNELFlBQVksRUFBRTtvQkFDWixtQkFBbUI7aUJBQ3BCO2dCQUNELE9BQU8sRUFBRTtvQkFDUCxtQkFBbUI7aUJBQ3BCO2FBQ0YiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBTY3JvbGxpbmdNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jZGsvc2Nyb2xsaW5nJztcclxuaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSBcIkBhbmd1bGFyL2NvbW1vblwiO1xyXG5pbXBvcnQgeyBOZ01vZHVsZSB9IGZyb20gXCJAYW5ndWxhci9jb3JlXCI7XHJcbmltcG9ydCB7IEFwcGVuZFBpcGVNb2R1bGUgfSBmcm9tICcuLi8uLi9waXBlcy9hcHBlbmQucGlwZS5tb2R1bGUnO1xyXG5pbXBvcnQgeyBQcmVwZW5kUGlwZU1vZHVsZSB9IGZyb20gJy4uLy4uL3BpcGVzL3ByZXBlbmQucGlwZS5tb2R1bGUnO1xyXG5pbXBvcnQgeyBDb2xsYXBzaWJsZU1vZHVsZSB9IGZyb20gXCIuLi9jb2xsYXBzaWJsZS9jb2xsYXBzaWJsZS5tb2R1bGVcIjtcclxuaW1wb3J0IHsgSWNvbk1vZHVsZSB9IGZyb20gXCIuLi9pY29uL2ljb24ubW9kdWxlXCI7XHJcbmltcG9ydCB7IElucHV0Q2hlY2tib3hNdWx0aVNlbGVjdE1vZHVsZSB9IGZyb20gXCIuLi9pbnB1dC1jaGVja2JveC1tdWx0aS1zZWxlY3QvaW5wdXQtY2hlY2tib3gtbXVsdGktc2VsZWN0Lm1vZHVsZVwiO1xyXG5pbXBvcnQgeyBJbnB1dENoZWNrYm94TW9kdWxlIH0gZnJvbSBcIi4uL2lucHV0LWNoZWNrYm94L2lucHV0LWNoZWNrYm94Lm1vZHVsZVwiO1xyXG5pbXBvcnQgeyBJbnB1dFRleHRNb2R1bGUgfSBmcm9tIFwiLi4vaW5wdXQtdGV4dC9pbnB1dC10ZXh0Lm1vZHVsZVwiO1xyXG5pbXBvcnQgeyBGaWx0ZXJJdGVtQ29tcG9uZW50IH0gZnJvbSBcIi4vZmlsdGVyLWl0ZW0uY29tcG9uZW50XCI7XHJcblxyXG5ATmdNb2R1bGUoe1xyXG4gIGltcG9ydHM6IFtcclxuICAgIENvbW1vbk1vZHVsZSxcclxuICAgIENvbGxhcHNpYmxlTW9kdWxlLFxyXG4gICAgSW5wdXRUZXh0TW9kdWxlLFxyXG4gICAgSW5wdXRDaGVja2JveE11bHRpU2VsZWN0TW9kdWxlLFxyXG4gICAgSW5wdXRDaGVja2JveE1vZHVsZSxcclxuICAgIEljb25Nb2R1bGUsXHJcbiAgICBTY3JvbGxpbmdNb2R1bGUsXHJcbiAgICBBcHBlbmRQaXBlTW9kdWxlLFxyXG4gICAgUHJlcGVuZFBpcGVNb2R1bGVcclxuICBdLFxyXG4gIGRlY2xhcmF0aW9uczogW1xyXG4gICAgRmlsdGVySXRlbUNvbXBvbmVudFxyXG4gIF0sXHJcbiAgZXhwb3J0czogW1xyXG4gICAgRmlsdGVySXRlbUNvbXBvbmVudFxyXG4gIF1cclxufSlcclxuZXhwb3J0IGNsYXNzIEZpbHRlckl0ZW1Nb2R1bGUge1xyXG5cclxufVxyXG4iXX0=
|
|
@@ -1,2 +1,2 @@
|
|
|
1
1
|
export {};
|
|
2
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
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.
|
|
9327
|
-
this.filteredCollection =
|
|
9324
|
+
this.collectionChange = new EventEmitter();
|
|
9325
|
+
this.filteredCollection = [];
|
|
9328
9326
|
this.limitTo = 10;
|
|
9329
9327
|
this.filterText = "";
|
|
9330
|
-
this.
|
|
9328
|
+
this.searchable = true;
|
|
9329
|
+
this._collection = [];
|
|
9331
9330
|
}
|
|
9332
9331
|
set collection(value) {
|
|
9333
|
-
var _a
|
|
9332
|
+
var _a;
|
|
9334
9333
|
this._collection = value;
|
|
9335
|
-
this.filteredCollection
|
|
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
|
|
9357
|
+
var _a;
|
|
9355
9358
|
if (this.showAllResults) {
|
|
9356
9359
|
return false;
|
|
9357
9360
|
}
|
|
9358
|
-
return ((
|
|
9361
|
+
return ((_a = this.filteredCollection) === null || _a === void 0 ? void 0 : _a.length) > this.limitTo;
|
|
9359
9362
|
}
|
|
9360
9363
|
lessToShow() {
|
|
9361
|
-
var _a, _b
|
|
9364
|
+
var _a, _b;
|
|
9362
9365
|
if (this.showAllResults) {
|
|
9363
9366
|
return false;
|
|
9364
9367
|
}
|
|
9365
|
-
return ((
|
|
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
|
|
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
|
|
9378
|
+
this.filteredCollection = (_b = this.collection) === null || _b === void 0 ? void 0 : _b.filter((item) => {
|
|
9376
9379
|
var _a;
|
|
9377
|
-
const labelText = (_a = item
|
|
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?.
|
|
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
|
|
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
|
|
9423
|
+
<co-input-checkbox [label]="option.description"
|
|
9421
9424
|
[(model)]="option.checked"
|
|
9422
|
-
(modelChange)="
|
|
9425
|
+
(modelChange)="collectionChange.emit(collection)"
|
|
9423
9426
|
></co-input-checkbox>
|
|
9424
|
-
<div class="co-filter-item-amount" *ngIf="
|
|
9425
|
-
[textContent]="option
|
|
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
|
-
|
|
9474
|
+
collectionChange: [{ type: Output }],
|
|
9473
9475
|
showClass: [{ type: HostBinding, args: ["class.co-filter-item",] }]
|
|
9474
9476
|
};
|
|
9475
9477
|
|