@colijnit/corecomponents_v12 12.0.51 → 12.0.52

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.
@@ -32,6 +32,7 @@ InputComboBoxComponent.decorators = [
32
32
  template: `
33
33
  <ejs-combobox #combo [dataSource]="collection"
34
34
  [fields]="fields"
35
+ [disabled]="readonly"
35
36
  [placeholder]="placeholder"
36
37
  [autofill]="true"
37
38
  [ngModel]="model"
@@ -73,4 +74,4 @@ InputComboBoxComponent.propDecorators = {
73
74
  valueChange: [{ type: Output }],
74
75
  showClass: [{ type: HostBinding, args: ["class.co-input-combo-box",] }]
75
76
  };
76
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5wdXQtY29tYm8tYm94LmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2NvcmVjb21wb25lbnRzL3NyYy9saWIvY29tcG9uZW50cy9pbnB1dC1jb21iby1ib3gvaW5wdXQtY29tYm8tYm94LmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQ0wsaUJBQWlCLEVBQ2pCLFNBQVMsRUFDVCx3QkFBd0IsRUFDeEIsVUFBVSxFQUFFLFlBQVksRUFDeEIsVUFBVSxFQUNWLFdBQVcsRUFDWCxLQUFLLEVBQ0wsUUFBUSxFQUFFLE1BQU0sRUFDaEIsU0FBUyxFQUNULGlCQUFpQixFQUNsQixNQUFNLGVBQWUsQ0FBQztBQUN2QixPQUFPLEVBQUMsa0JBQWtCLEVBQUMsTUFBTSw4QkFBOEIsQ0FBQztBQUNoRSxPQUFPLEVBQUMsdUNBQXVDLEVBQUMsTUFBTSw0REFBNEQsQ0FBQztBQUNuSCxPQUFPLEVBQUMsb0JBQW9CLEVBQUMsTUFBTSw0Q0FBNEMsQ0FBQztBQUNoRixPQUFPLEVBQUMsYUFBYSxFQUFDLE1BQU0sd0JBQXdCLENBQUM7QUFDckQsT0FBTyxFQUFDLHdCQUF3QixFQUFDLE1BQU0sa0NBQWtDLENBQUM7QUE4QjFFLE1BQU0sT0FBTyxzQkFBdUIsU0FBUSxrQkFBdUI7SUEyQmpFLFlBQ3FCLGFBQTRCLEVBQ3JDLGNBQWlDLEVBQ2pDLHdCQUFrRCxFQUNsRCxzQkFBZ0UsRUFDaEUsYUFBb0MsRUFDdkMsVUFBdUI7UUFFOUIsS0FBSyxDQUFDLGNBQWMsRUFBRSx3QkFBd0IsRUFBRSxzQkFBc0IsRUFBRSxhQUFhLEVBQUUsVUFBVSxDQUFDLENBQUM7UUFQaEYsa0JBQWEsR0FBYixhQUFhLENBQWU7UUFDckMsbUJBQWMsR0FBZCxjQUFjLENBQW1CO1FBQ2pDLDZCQUF3QixHQUF4Qix3QkFBd0IsQ0FBMEI7UUFDbEQsMkJBQXNCLEdBQXRCLHNCQUFzQixDQUEwQztRQUNoRSxrQkFBYSxHQUFiLGFBQWEsQ0FBdUI7UUFDdkMsZUFBVSxHQUFWLFVBQVUsQ0FBYTtRQWhCekIsY0FBUyxHQUFZLElBQUksQ0FBQztRQUcxQixnQkFBVyxHQUFzQixJQUFJLFlBQVksRUFBTyxDQUFDO1FBZ0I5RCxLQUFLLENBQUMsYUFBYSxFQUFFLENBQUM7SUFDeEIsQ0FBQztJQWRNLFNBQVM7UUFDZCxPQUFPLElBQUksQ0FBQztJQUNkLENBQUM7SUFjTSxPQUFPO1FBQ1osSUFBSSxJQUFJLENBQUMsU0FBUyxJQUFJLElBQUksQ0FBQyxLQUFLLEtBQUssU0FBUyxFQUFFO1lBQzlDLElBQUksQ0FBQyxLQUFLLENBQUMsU0FBUyxFQUFFLENBQUM7U0FDeEI7SUFDSCxDQUFDOzs7WUF0RUYsU0FBUyxTQUFDO2dCQUNULFFBQVEsRUFBRSxvQkFBb0I7Z0JBQzlCLFFBQVEsRUFBRTs7Ozs7Ozs7Ozs7Ozs7O0dBZVQ7Z0JBQ0QsU0FBUyxFQUFFLENBQUM7d0JBQ1YsT0FBTyxFQUFFLHdCQUF3Qjt3QkFDakMsV0FBVyxFQUFFLFVBQVUsQ0FBQyxHQUFHLEVBQUUsQ0FBQyxzQkFBc0IsQ0FBQztxQkFDdEQsRUFBRTt3QkFDRCxPQUFPLEVBQUUsa0JBQWtCO3dCQUMzQixXQUFXLEVBQUUsc0JBQXNCO3FCQUNwQyxDQUFDO2dCQUNGLGFBQWEsRUFBRSxpQkFBaUIsQ0FBQyxJQUFJO2FBQ3RDOzs7WUE5Qk8sYUFBYSx1QkEyRGhCLFFBQVE7WUF6RVgsaUJBQWlCO1lBRWpCLHdCQUF3QjtZQVVsQix1Q0FBdUM7WUFDdkMsb0JBQW9CO1lBVjFCLFVBQVU7OztvQkEyQ1QsU0FBUyxTQUFDLE9BQU87eUJBR2pCLEtBQUs7cUJBR0wsS0FBSzt1QkFHTCxLQUFLOzBCQUdMLEtBQUs7d0JBR0wsS0FBSzswQkFHTCxNQUFNO3dCQUdOLFdBQVcsU0FBQywwQkFBMEIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1xyXG4gIENoYW5nZURldGVjdG9yUmVmLFxyXG4gIENvbXBvbmVudCxcclxuICBDb21wb25lbnRGYWN0b3J5UmVzb2x2ZXIsXHJcbiAgRWxlbWVudFJlZiwgRXZlbnRFbWl0dGVyLFxyXG4gIGZvcndhcmRSZWYsXHJcbiAgSG9zdEJpbmRpbmcsXHJcbiAgSW5wdXQsXHJcbiAgT3B0aW9uYWwsIE91dHB1dCxcclxuICBWaWV3Q2hpbGQsXHJcbiAgVmlld0VuY2Fwc3VsYXRpb25cclxufSBmcm9tIFwiQGFuZ3VsYXIvY29yZVwiO1xyXG5pbXBvcnQge0Jhc2VJbnB1dENvbXBvbmVudH0gZnJvbSBcIi4uL2Jhc2UvYmFzZS1pbnB1dC5jb21wb25lbnRcIjtcclxuaW1wb3J0IHtGb3JtSW5wdXRVc2VyTW9kZWxDaGFuZ2VMaXN0ZW5lclNlcnZpY2V9IGZyb20gXCIuLi8uLi9jb3JlL3NlcnZpY2UvZm9ybS1pbnB1dC11c2VyLWNoYW5nZS1saXN0ZW5lci5zZXJ2aWNlXCI7XHJcbmltcG9ydCB7Tmdab25lV3JhcHBlclNlcnZpY2V9IGZyb20gXCIuLi8uLi9jb3JlL3NlcnZpY2Uvbmctem9uZS13cmFwcGVyLnNlcnZpY2VcIjtcclxuaW1wb3J0IHtGb3JtQ29tcG9uZW50fSBmcm9tIFwiLi4vZm9ybS9mb3JtLmNvbXBvbmVudFwiO1xyXG5pbXBvcnQge0NPTVBPTkVOVF9JTlRFUkZBQ0VfTkFNRX0gZnJvbSBcIi4uL2Jhc2UvY29tcG9uZW50LWludGVyZmFjZS1uYW1lXCI7XHJcbmltcG9ydCB7Q29tYm9Cb3hDb21wb25lbnR9IGZyb20gXCJAc3luY2Z1c2lvbi9lajItYW5ndWxhci1kcm9wZG93bnNcIjtcclxuXHJcbkBDb21wb25lbnQoe1xyXG4gIHNlbGVjdG9yOiBcImNvLWlucHV0LWNvbWJvLWJveFwiLFxyXG4gIHRlbXBsYXRlOiBgXHJcbiAgICA8ZWpzLWNvbWJvYm94ICNjb21ibyBbZGF0YVNvdXJjZV09XCJjb2xsZWN0aW9uXCJcclxuICAgICAgICAgICAgICAgICAgW2ZpZWxkc109XCJmaWVsZHNcIlxyXG4gICAgICAgICAgICAgICAgICBbcGxhY2Vob2xkZXJdPVwicGxhY2Vob2xkZXJcIlxyXG4gICAgICAgICAgICAgICAgICBbYXV0b2ZpbGxdPVwidHJ1ZVwiXHJcbiAgICAgICAgICAgICAgICAgIFtuZ01vZGVsXT1cIm1vZGVsXCJcclxuICAgICAgICAgICAgICAgICAgKG5nTW9kZWxDaGFuZ2UpPVwibW9kZWxDaGFuZ2UuZW1pdCgkZXZlbnQpXCJcclxuICAgICAgICAgICAgICAgICAgKHZhbHVlQ2hhbmdlKT1cInZhbHVlQ2hhbmdlLmVtaXQoJGV2ZW50KVwiXHJcbiAgICAgICAgICAgICAgICAgIChmb2N1cyk9XCJvbkZvY3VzKClcIlxyXG4gICAgICAgICAgICAgICAgICBzaG93Q2xlYXJCdXR0b249XCJ0cnVlXCJcclxuICAgICAgICAgICAgICAgICAgZmxvYXRMYWJlbFR5cGU9XCJBdXRvXCJcclxuICAgID5cclxuICAgIDwvZWpzLWNvbWJvYm94PlxyXG4gICAgPGRpdiBjbGFzcz1cInJlcXVpcmVkLWluZGljYXRvclwiPjwvZGl2PlxyXG4gICAgPG5nLXRlbXBsYXRlICN2YWxpZGF0aW9uRXJyb3I+PC9uZy10ZW1wbGF0ZT5cclxuICBgLFxyXG4gIHByb3ZpZGVyczogW3tcclxuICAgIHByb3ZpZGU6IENPTVBPTkVOVF9JTlRFUkZBQ0VfTkFNRSxcclxuICAgIHVzZUV4aXN0aW5nOiBmb3J3YXJkUmVmKCgpID0+IElucHV0Q29tYm9Cb3hDb21wb25lbnQpXHJcbiAgfSwge1xyXG4gICAgcHJvdmlkZTogQmFzZUlucHV0Q29tcG9uZW50LFxyXG4gICAgdXNlRXhpc3Rpbmc6IElucHV0Q29tYm9Cb3hDb21wb25lbnRcclxuICB9XSxcclxuICBlbmNhcHN1bGF0aW9uOiBWaWV3RW5jYXBzdWxhdGlvbi5Ob25lXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBJbnB1dENvbWJvQm94Q29tcG9uZW50IGV4dGVuZHMgQmFzZUlucHV0Q29tcG9uZW50PGFueT4ge1xyXG4gIEBWaWV3Q2hpbGQoXCJjb21ib1wiKVxyXG4gIHB1YmxpYyBjb21ibzogQ29tYm9Cb3hDb21wb25lbnQ7XHJcblxyXG4gIEBJbnB1dCgpXHJcbiAgcHVibGljIGNvbGxlY3Rpb246IE9iamVjdFtdIHwgc3RyaW5nW10gfCBudW1iZXJbXSB8IGJvb2xlYW5bXTtcclxuXHJcbiAgQElucHV0KClcclxuICBwdWJsaWMgZmllbGRzOiBPYmplY3Q7XHJcblxyXG4gIEBJbnB1dCgpXHJcbiAgcHVibGljIHNlbGVjdGVkOiBudW1iZXIgfCBzdHJpbmcgfCBib29sZWFuO1xyXG5cclxuICBASW5wdXQoKVxyXG4gIHB1YmxpYyBwbGFjZWhvbGRlcjogc3RyaW5nO1xyXG5cclxuICBASW5wdXQoKVxyXG4gIHB1YmxpYyBzaG9wUG9wdXA6IGJvb2xlYW4gPSB0cnVlO1xyXG5cclxuICBAT3V0cHV0KClcclxuICBwdWJsaWMgdmFsdWVDaGFuZ2U6IEV2ZW50RW1pdHRlcjxhbnk+ID0gbmV3IEV2ZW50RW1pdHRlcjxhbnk+KCk7XHJcblxyXG4gIEBIb3N0QmluZGluZyhcImNsYXNzLmNvLWlucHV0LWNvbWJvLWJveFwiKVxyXG4gIHB1YmxpYyBzaG93Q2xhc3MoKSB7XHJcbiAgICByZXR1cm4gdHJ1ZTtcclxuICB9XHJcblxyXG4gIGNvbnN0cnVjdG9yKFxyXG4gICAgQE9wdGlvbmFsKCkgcHVibGljIGZvcm1Db21wb25lbnQ6IEZvcm1Db21wb25lbnQsXHJcbiAgICBwcm90ZWN0ZWQgY2hhbmdlRGV0ZWN0b3I6IENoYW5nZURldGVjdG9yUmVmLFxyXG4gICAgcHJvdGVjdGVkIGNvbXBvbmVudEZhY3RvcnlSZXNvbHZlcjogQ29tcG9uZW50RmFjdG9yeVJlc29sdmVyLFxyXG4gICAgcHJvdGVjdGVkIGZvcm1Vc2VyQ2hhbmdlTGlzdGVuZXI/OiBGb3JtSW5wdXRVc2VyTW9kZWxDaGFuZ2VMaXN0ZW5lclNlcnZpY2UsXHJcbiAgICBwcm90ZWN0ZWQgbmdab25lV3JhcHBlcj86IE5nWm9uZVdyYXBwZXJTZXJ2aWNlLFxyXG4gICAgcHVibGljIGVsZW1lbnRSZWY/OiBFbGVtZW50UmVmLFxyXG4gICkge1xyXG4gICAgc3VwZXIoY2hhbmdlRGV0ZWN0b3IsIGNvbXBvbmVudEZhY3RvcnlSZXNvbHZlciwgZm9ybVVzZXJDaGFuZ2VMaXN0ZW5lciwgbmdab25lV3JhcHBlciwgZWxlbWVudFJlZik7XHJcbiAgICBzdXBlci5fbWFya0FzT25QdXNoKCk7XHJcbiAgfVxyXG5cclxuICBwdWJsaWMgb25Gb2N1cygpOiB2b2lkIHtcclxuICAgIGlmICh0aGlzLnNob3BQb3B1cCAmJiB0aGlzLm1vZGVsID09PSB1bmRlZmluZWQpIHtcclxuICAgICAgdGhpcy5jb21iby5zaG93UG9wdXAoKTtcclxuICAgIH1cclxuICB9XHJcbn1cclxuIl19
77
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5wdXQtY29tYm8tYm94LmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2NvcmVjb21wb25lbnRzL3NyYy9saWIvY29tcG9uZW50cy9pbnB1dC1jb21iby1ib3gvaW5wdXQtY29tYm8tYm94LmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQ0wsaUJBQWlCLEVBQ2pCLFNBQVMsRUFDVCx3QkFBd0IsRUFDeEIsVUFBVSxFQUFFLFlBQVksRUFDeEIsVUFBVSxFQUNWLFdBQVcsRUFDWCxLQUFLLEVBQ0wsUUFBUSxFQUFFLE1BQU0sRUFDaEIsU0FBUyxFQUNULGlCQUFpQixFQUNsQixNQUFNLGVBQWUsQ0FBQztBQUN2QixPQUFPLEVBQUMsa0JBQWtCLEVBQUMsTUFBTSw4QkFBOEIsQ0FBQztBQUNoRSxPQUFPLEVBQUMsdUNBQXVDLEVBQUMsTUFBTSw0REFBNEQsQ0FBQztBQUNuSCxPQUFPLEVBQUMsb0JBQW9CLEVBQUMsTUFBTSw0Q0FBNEMsQ0FBQztBQUNoRixPQUFPLEVBQUMsYUFBYSxFQUFDLE1BQU0sd0JBQXdCLENBQUM7QUFDckQsT0FBTyxFQUFDLHdCQUF3QixFQUFDLE1BQU0sa0NBQWtDLENBQUM7QUErQjFFLE1BQU0sT0FBTyxzQkFBdUIsU0FBUSxrQkFBdUI7SUEyQmpFLFlBQ3FCLGFBQTRCLEVBQ3JDLGNBQWlDLEVBQ2pDLHdCQUFrRCxFQUNsRCxzQkFBZ0UsRUFDaEUsYUFBb0MsRUFDdkMsVUFBdUI7UUFFOUIsS0FBSyxDQUFDLGNBQWMsRUFBRSx3QkFBd0IsRUFBRSxzQkFBc0IsRUFBRSxhQUFhLEVBQUUsVUFBVSxDQUFDLENBQUM7UUFQaEYsa0JBQWEsR0FBYixhQUFhLENBQWU7UUFDckMsbUJBQWMsR0FBZCxjQUFjLENBQW1CO1FBQ2pDLDZCQUF3QixHQUF4Qix3QkFBd0IsQ0FBMEI7UUFDbEQsMkJBQXNCLEdBQXRCLHNCQUFzQixDQUEwQztRQUNoRSxrQkFBYSxHQUFiLGFBQWEsQ0FBdUI7UUFDdkMsZUFBVSxHQUFWLFVBQVUsQ0FBYTtRQWhCekIsY0FBUyxHQUFZLElBQUksQ0FBQztRQUcxQixnQkFBVyxHQUFzQixJQUFJLFlBQVksRUFBTyxDQUFDO1FBZ0I5RCxLQUFLLENBQUMsYUFBYSxFQUFFLENBQUM7SUFDeEIsQ0FBQztJQWRNLFNBQVM7UUFDZCxPQUFPLElBQUksQ0FBQztJQUNkLENBQUM7SUFjTSxPQUFPO1FBQ1osSUFBSSxJQUFJLENBQUMsU0FBUyxJQUFJLElBQUksQ0FBQyxLQUFLLEtBQUssU0FBUyxFQUFFO1lBQzlDLElBQUksQ0FBQyxLQUFLLENBQUMsU0FBUyxFQUFFLENBQUM7U0FDeEI7SUFDSCxDQUFDOzs7WUF2RUYsU0FBUyxTQUFDO2dCQUNULFFBQVEsRUFBRSxvQkFBb0I7Z0JBQzlCLFFBQVEsRUFBRTs7Ozs7Ozs7Ozs7Ozs7OztHQWdCVDtnQkFDRCxTQUFTLEVBQUUsQ0FBQzt3QkFDVixPQUFPLEVBQUUsd0JBQXdCO3dCQUNqQyxXQUFXLEVBQUUsVUFBVSxDQUFDLEdBQUcsRUFBRSxDQUFDLHNCQUFzQixDQUFDO3FCQUN0RCxFQUFFO3dCQUNELE9BQU8sRUFBRSxrQkFBa0I7d0JBQzNCLFdBQVcsRUFBRSxzQkFBc0I7cUJBQ3BDLENBQUM7Z0JBQ0YsYUFBYSxFQUFFLGlCQUFpQixDQUFDLElBQUk7YUFDdEM7OztZQS9CTyxhQUFhLHVCQTREaEIsUUFBUTtZQTFFWCxpQkFBaUI7WUFFakIsd0JBQXdCO1lBVWxCLHVDQUF1QztZQUN2QyxvQkFBb0I7WUFWMUIsVUFBVTs7O29CQTRDVCxTQUFTLFNBQUMsT0FBTzt5QkFHakIsS0FBSztxQkFHTCxLQUFLO3VCQUdMLEtBQUs7MEJBR0wsS0FBSzt3QkFHTCxLQUFLOzBCQUdMLE1BQU07d0JBR04sV0FBVyxTQUFDLDBCQUEwQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7XHJcbiAgQ2hhbmdlRGV0ZWN0b3JSZWYsXHJcbiAgQ29tcG9uZW50LFxyXG4gIENvbXBvbmVudEZhY3RvcnlSZXNvbHZlcixcclxuICBFbGVtZW50UmVmLCBFdmVudEVtaXR0ZXIsXHJcbiAgZm9yd2FyZFJlZixcclxuICBIb3N0QmluZGluZyxcclxuICBJbnB1dCxcclxuICBPcHRpb25hbCwgT3V0cHV0LFxyXG4gIFZpZXdDaGlsZCxcclxuICBWaWV3RW5jYXBzdWxhdGlvblxyXG59IGZyb20gXCJAYW5ndWxhci9jb3JlXCI7XHJcbmltcG9ydCB7QmFzZUlucHV0Q29tcG9uZW50fSBmcm9tIFwiLi4vYmFzZS9iYXNlLWlucHV0LmNvbXBvbmVudFwiO1xyXG5pbXBvcnQge0Zvcm1JbnB1dFVzZXJNb2RlbENoYW5nZUxpc3RlbmVyU2VydmljZX0gZnJvbSBcIi4uLy4uL2NvcmUvc2VydmljZS9mb3JtLWlucHV0LXVzZXItY2hhbmdlLWxpc3RlbmVyLnNlcnZpY2VcIjtcclxuaW1wb3J0IHtOZ1pvbmVXcmFwcGVyU2VydmljZX0gZnJvbSBcIi4uLy4uL2NvcmUvc2VydmljZS9uZy16b25lLXdyYXBwZXIuc2VydmljZVwiO1xyXG5pbXBvcnQge0Zvcm1Db21wb25lbnR9IGZyb20gXCIuLi9mb3JtL2Zvcm0uY29tcG9uZW50XCI7XHJcbmltcG9ydCB7Q09NUE9ORU5UX0lOVEVSRkFDRV9OQU1FfSBmcm9tIFwiLi4vYmFzZS9jb21wb25lbnQtaW50ZXJmYWNlLW5hbWVcIjtcclxuaW1wb3J0IHtDb21ib0JveENvbXBvbmVudH0gZnJvbSBcIkBzeW5jZnVzaW9uL2VqMi1hbmd1bGFyLWRyb3Bkb3duc1wiO1xyXG5cclxuQENvbXBvbmVudCh7XHJcbiAgc2VsZWN0b3I6IFwiY28taW5wdXQtY29tYm8tYm94XCIsXHJcbiAgdGVtcGxhdGU6IGBcclxuICAgIDxlanMtY29tYm9ib3ggI2NvbWJvIFtkYXRhU291cmNlXT1cImNvbGxlY3Rpb25cIlxyXG4gICAgICAgICAgICAgICAgICBbZmllbGRzXT1cImZpZWxkc1wiXHJcbiAgICAgICAgICAgICAgICAgIFtkaXNhYmxlZF09XCJyZWFkb25seVwiXHJcbiAgICAgICAgICAgICAgICAgIFtwbGFjZWhvbGRlcl09XCJwbGFjZWhvbGRlclwiXHJcbiAgICAgICAgICAgICAgICAgIFthdXRvZmlsbF09XCJ0cnVlXCJcclxuICAgICAgICAgICAgICAgICAgW25nTW9kZWxdPVwibW9kZWxcIlxyXG4gICAgICAgICAgICAgICAgICAobmdNb2RlbENoYW5nZSk9XCJtb2RlbENoYW5nZS5lbWl0KCRldmVudClcIlxyXG4gICAgICAgICAgICAgICAgICAodmFsdWVDaGFuZ2UpPVwidmFsdWVDaGFuZ2UuZW1pdCgkZXZlbnQpXCJcclxuICAgICAgICAgICAgICAgICAgKGZvY3VzKT1cIm9uRm9jdXMoKVwiXHJcbiAgICAgICAgICAgICAgICAgIHNob3dDbGVhckJ1dHRvbj1cInRydWVcIlxyXG4gICAgICAgICAgICAgICAgICBmbG9hdExhYmVsVHlwZT1cIkF1dG9cIlxyXG4gICAgPlxyXG4gICAgPC9lanMtY29tYm9ib3g+XHJcbiAgICA8ZGl2IGNsYXNzPVwicmVxdWlyZWQtaW5kaWNhdG9yXCI+PC9kaXY+XHJcbiAgICA8bmctdGVtcGxhdGUgI3ZhbGlkYXRpb25FcnJvcj48L25nLXRlbXBsYXRlPlxyXG4gIGAsXHJcbiAgcHJvdmlkZXJzOiBbe1xyXG4gICAgcHJvdmlkZTogQ09NUE9ORU5UX0lOVEVSRkFDRV9OQU1FLFxyXG4gICAgdXNlRXhpc3Rpbmc6IGZvcndhcmRSZWYoKCkgPT4gSW5wdXRDb21ib0JveENvbXBvbmVudClcclxuICB9LCB7XHJcbiAgICBwcm92aWRlOiBCYXNlSW5wdXRDb21wb25lbnQsXHJcbiAgICB1c2VFeGlzdGluZzogSW5wdXRDb21ib0JveENvbXBvbmVudFxyXG4gIH1dLFxyXG4gIGVuY2Fwc3VsYXRpb246IFZpZXdFbmNhcHN1bGF0aW9uLk5vbmVcclxufSlcclxuZXhwb3J0IGNsYXNzIElucHV0Q29tYm9Cb3hDb21wb25lbnQgZXh0ZW5kcyBCYXNlSW5wdXRDb21wb25lbnQ8YW55PiB7XHJcbiAgQFZpZXdDaGlsZChcImNvbWJvXCIpXHJcbiAgcHVibGljIGNvbWJvOiBDb21ib0JveENvbXBvbmVudDtcclxuXHJcbiAgQElucHV0KClcclxuICBwdWJsaWMgY29sbGVjdGlvbjogT2JqZWN0W10gfCBzdHJpbmdbXSB8IG51bWJlcltdIHwgYm9vbGVhbltdO1xyXG5cclxuICBASW5wdXQoKVxyXG4gIHB1YmxpYyBmaWVsZHM6IE9iamVjdDtcclxuXHJcbiAgQElucHV0KClcclxuICBwdWJsaWMgc2VsZWN0ZWQ6IG51bWJlciB8IHN0cmluZyB8IGJvb2xlYW47XHJcblxyXG4gIEBJbnB1dCgpXHJcbiAgcHVibGljIHBsYWNlaG9sZGVyOiBzdHJpbmc7XHJcblxyXG4gIEBJbnB1dCgpXHJcbiAgcHVibGljIHNob3BQb3B1cDogYm9vbGVhbiA9IHRydWU7XHJcblxyXG4gIEBPdXRwdXQoKVxyXG4gIHB1YmxpYyB2YWx1ZUNoYW5nZTogRXZlbnRFbWl0dGVyPGFueT4gPSBuZXcgRXZlbnRFbWl0dGVyPGFueT4oKTtcclxuXHJcbiAgQEhvc3RCaW5kaW5nKFwiY2xhc3MuY28taW5wdXQtY29tYm8tYm94XCIpXHJcbiAgcHVibGljIHNob3dDbGFzcygpIHtcclxuICAgIHJldHVybiB0cnVlO1xyXG4gIH1cclxuXHJcbiAgY29uc3RydWN0b3IoXHJcbiAgICBAT3B0aW9uYWwoKSBwdWJsaWMgZm9ybUNvbXBvbmVudDogRm9ybUNvbXBvbmVudCxcclxuICAgIHByb3RlY3RlZCBjaGFuZ2VEZXRlY3RvcjogQ2hhbmdlRGV0ZWN0b3JSZWYsXHJcbiAgICBwcm90ZWN0ZWQgY29tcG9uZW50RmFjdG9yeVJlc29sdmVyOiBDb21wb25lbnRGYWN0b3J5UmVzb2x2ZXIsXHJcbiAgICBwcm90ZWN0ZWQgZm9ybVVzZXJDaGFuZ2VMaXN0ZW5lcj86IEZvcm1JbnB1dFVzZXJNb2RlbENoYW5nZUxpc3RlbmVyU2VydmljZSxcclxuICAgIHByb3RlY3RlZCBuZ1pvbmVXcmFwcGVyPzogTmdab25lV3JhcHBlclNlcnZpY2UsXHJcbiAgICBwdWJsaWMgZWxlbWVudFJlZj86IEVsZW1lbnRSZWYsXHJcbiAgKSB7XHJcbiAgICBzdXBlcihjaGFuZ2VEZXRlY3RvciwgY29tcG9uZW50RmFjdG9yeVJlc29sdmVyLCBmb3JtVXNlckNoYW5nZUxpc3RlbmVyLCBuZ1pvbmVXcmFwcGVyLCBlbGVtZW50UmVmKTtcclxuICAgIHN1cGVyLl9tYXJrQXNPblB1c2goKTtcclxuICB9XHJcblxyXG4gIHB1YmxpYyBvbkZvY3VzKCk6IHZvaWQge1xyXG4gICAgaWYgKHRoaXMuc2hvcFBvcHVwICYmIHRoaXMubW9kZWwgPT09IHVuZGVmaW5lZCkge1xyXG4gICAgICB0aGlzLmNvbWJvLnNob3dQb3B1cCgpO1xyXG4gICAgfVxyXG4gIH1cclxufVxyXG4iXX0=
@@ -11,7 +11,8 @@ export class PaginationComponent {
11
11
  // Emits the new page number.
12
12
  this.pageChange = new EventEmitter();
13
13
  this.showClass = true;
14
- this.pages = [];
14
+ this.totalItems = 1;
15
+ this.itemsPerPage = 20;
15
16
  this.changeSub = this._paginationService.change.subscribe((id) => {
16
17
  if (this.id === id) {
17
18
  this._updatePageLinks();
@@ -70,11 +71,12 @@ export class PaginationComponent {
70
71
  */
71
72
  _updatePageLinks() {
72
73
  let paginationInstance = this._paginationService.getInstance(this.id);
73
- this.pages = this.createPageArray(paginationInstance.currentPage, paginationInstance.itemsPerPage, paginationInstance.totalItems, this.maxSize);
74
74
  const correctedCurrentPage = this.outOfBoundCorrection(paginationInstance);
75
75
  if (correctedCurrentPage !== paginationInstance.currentPage) {
76
76
  this.setCurrentPage(correctedCurrentPage);
77
77
  }
78
+ this.totalItems = paginationInstance.totalItems;
79
+ this.itemsPerPage = paginationInstance.itemsPerPage;
78
80
  }
79
81
  getCurrentPage() {
80
82
  return this._paginationService.getCurrentPage(this.id);
@@ -97,61 +99,6 @@ export class PaginationComponent {
97
99
  }
98
100
  return instance.currentPage;
99
101
  }
100
- // Returns an array of IPage objects to use in the pagination controls.
101
- createPageArray(currentPage, itemsPerPage, totalItems, paginationRange) {
102
- // paginationRange could be a string if passed from attribute, so cast to number.
103
- paginationRange = +paginationRange;
104
- let pages = [];
105
- const totalPages = Math.ceil(totalItems / itemsPerPage);
106
- const halfWay = Math.ceil(paginationRange / 2);
107
- const isStart = currentPage <= halfWay;
108
- const isEnd = totalPages - halfWay < currentPage;
109
- const isMiddle = !isStart && !isEnd;
110
- let ellipsesNeeded = paginationRange < totalPages;
111
- let i = 1;
112
- while (i <= totalPages && i <= paginationRange) {
113
- let label;
114
- let pageNumber = this.calculatePageNumber(i, currentPage, paginationRange, totalPages);
115
- let openingEllipsesNeeded = (i === 2 && (isMiddle || isEnd));
116
- let closingEllipsesNeeded = (i === paginationRange - 1 && (isMiddle || isStart));
117
- if (ellipsesNeeded && (openingEllipsesNeeded || closingEllipsesNeeded)) {
118
- label = '...';
119
- }
120
- else {
121
- label = '' + pageNumber;
122
- }
123
- pages.push({
124
- label: label,
125
- value: pageNumber
126
- });
127
- i++;
128
- }
129
- return pages;
130
- }
131
- // Given the position in the sequence of pagination links [i], figure out what page number corresponds to that position.
132
- calculatePageNumber(i, currentPage, paginationRange, totalPages) {
133
- let halfWay = Math.ceil(paginationRange / 2);
134
- if (i === paginationRange) {
135
- return totalPages;
136
- }
137
- else if (i === 1) {
138
- return i;
139
- }
140
- else if (paginationRange < totalPages) {
141
- if (totalPages - halfWay < currentPage) {
142
- return totalPages - paginationRange + i;
143
- }
144
- else if (halfWay < currentPage) {
145
- return currentPage - halfWay + i;
146
- }
147
- else {
148
- return i;
149
- }
150
- }
151
- else {
152
- return i;
153
- }
154
- }
155
102
  }
156
103
  PaginationComponent.decorators = [
157
104
  { type: Component, args: [{
@@ -163,11 +110,12 @@ PaginationComponent.decorators = [
163
110
  </div>
164
111
 
165
112
  <co-pagination-bar
166
- [pages]="pages"
113
+ [currentPage]="getCurrentPage()"
114
+ [totalItems]="totalItems"
115
+ [itemsPerPage]="itemsPerPage"
167
116
  [directionLinks]="directionLinks"
168
117
  [previousLabel]="previousLabel"
169
118
  [nextLabel]="nextLabel"
170
- [currentPage]="getCurrentPage()"
171
119
  (previousClick)="goToPreviousPage()"
172
120
  (nextClick)="goToNextPage()"
173
121
  (pageClick)="setCurrentPage($event)"
@@ -191,4 +139,4 @@ PaginationComponent.propDecorators = {
191
139
  pageChange: [{ type: Output }],
192
140
  showClass: [{ type: HostBinding, args: ['class.co-pagination',] }]
193
141
  };
194
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"pagination.component.js","sourceRoot":"","sources":["../../../../../../projects/corecomponents/src/lib/components/pagination/pagination.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Component,\r\n  ElementRef,\r\n  EventEmitter, HostBinding,\r\n  Input,\r\n  OnChanges,\r\n  OnDestroy,\r\n  OnInit,\r\n  Output,\r\n  ViewChild,\r\n  ViewEncapsulation\r\n} from '@angular/core';\r\nimport {Subscription} from 'rxjs';\r\nimport { IPage } from \"../pagination-bar/pagination-bar.component\";\r\nimport {IPaginationInstance} from './pagination-instance';\r\nimport {PaginationService} from './pagination.service';\r\n\r\n@Component({\r\n  selector: 'co-pagination',\r\n  template: `\r\n    <div class=\"pagination-component-main-wrapper\" *ngIf=\"!shouldBeHidden()\">\r\n      <div>\r\n        <ng-content></ng-content>\r\n      </div>\r\n\r\n      <co-pagination-bar\r\n        [pages]=\"pages\"\r\n        [directionLinks]=\"directionLinks\"\r\n        [previousLabel]=\"previousLabel\"\r\n        [nextLabel]=\"nextLabel\"\r\n        [currentPage]=\"getCurrentPage()\"\r\n        (previousClick)=\"goToPreviousPage()\"\r\n        (nextClick)=\"goToNextPage()\"\r\n        (pageClick)=\"setCurrentPage($event)\"\r\n      ></co-pagination-bar>\r\n    </div>\r\n  `,\r\n  encapsulation: ViewEncapsulation.None\r\n})\r\nexport class PaginationComponent implements OnInit, OnChanges, OnDestroy {\r\n  @ViewChild('template')\r\n  public readonly template: ElementRef;\r\n\r\n  @Input()\r\n  public id: string;\r\n\r\n  @Input()\r\n  public maxSize: number = 7;\r\n\r\n  @Input()\r\n  public directionLinks: boolean = true;\r\n\r\n  @Input()\r\n  public previousLabel: string = 'Vorige pagina';\r\n\r\n  @Input()\r\n  public nextLabel: string = 'Volgende pagina';\r\n\r\n  @Input()\r\n  public autoHide: boolean = false;\r\n\r\n  // Emits the new page number.\r\n  @Output()\r\n  public readonly pageChange: EventEmitter<number> = new EventEmitter<number>();\r\n\r\n  @HostBinding('class.co-pagination')\r\n  public showClass: boolean = true;\r\n\r\n  public pages: IPage[] = [];\r\n\r\n  private changeSub: Subscription;\r\n\r\n  constructor(private _paginationService: PaginationService) {\r\n    this.changeSub = this._paginationService.change.subscribe((id: string) => {\r\n      if (this.id === id) {\r\n        this._updatePageLinks();\r\n      }\r\n    });\r\n  }\r\n\r\n  ngOnInit(): void {\r\n    if (!this.id) {\r\n      this.id = this._paginationService.DEFAULT_ID;\r\n    }\r\n    this._updatePageLinks();\r\n  }\r\n\r\n  ngOnChanges(): void {\r\n    this._updatePageLinks();\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    this.changeSub.unsubscribe();\r\n  }\r\n\r\n  public goToFirstPage(): void {\r\n    if (!this.isOnFirstPage()) {\r\n      this.setCurrentPage(1);\r\n    }\r\n  }\r\n\r\n  public goToPreviousPage(): void {\r\n    if (!this.isOnFirstPage()) {\r\n      this.setCurrentPage(this.getCurrentPage() - 1);\r\n    }\r\n  }\r\n\r\n  public goToNextPage(): void {\r\n    if (!this.isOnLastPage()) {\r\n      this.setCurrentPage(this.getCurrentPage() + 1);\r\n    }\r\n  }\r\n\r\n  public setCurrentPage(page: number): void {\r\n    this.pageChange.emit(page);\r\n  }\r\n\r\n  public isOnFirstPage(): boolean {\r\n    return this.getCurrentPage() === 1;\r\n  }\r\n\r\n  public isOnLastPage(): boolean {\r\n    return this.getLastPage() === this.getCurrentPage();\r\n  }\r\n\r\n  public shouldBeHidden(): boolean {\r\n    if (!this.autoHide) {\r\n      return false;\r\n    } else {\r\n      let instance: IPaginationInstance = this._paginationService.getInstance();\r\n      return (instance.totalItems <= instance.itemsPerPage);\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Updates the page links and checks that the current page is valid. Should run whenever the\r\n   * PaginationService.change stream emits a value matching the current ID, or when any of the\r\n   * input values changes.\r\n   */\r\n  private _updatePageLinks(): void {\r\n    let paginationInstance: IPaginationInstance = this._paginationService.getInstance(this.id);\r\n    this.pages = this.createPageArray(paginationInstance.currentPage, paginationInstance.itemsPerPage, paginationInstance.totalItems, this.maxSize);\r\n\r\n    const correctedCurrentPage: number = this.outOfBoundCorrection(paginationInstance);\r\n    if (correctedCurrentPage !== paginationInstance.currentPage) {\r\n      this.setCurrentPage(correctedCurrentPage);\r\n    }\r\n  }\r\n\r\n  public getCurrentPage(): number {\r\n    return this._paginationService.getCurrentPage(this.id);\r\n  }\r\n\r\n  public getLastPage(): number {\r\n    let instance: IPaginationInstance = this._paginationService.getInstance(this.id);\r\n    return Math.ceil(instance.totalItems / instance.itemsPerPage);\r\n  }\r\n\r\n  /**\r\n   * Checks that the instance.currentPage property is within bounds for the current page range.\r\n   * If not, return a correct value for currentPage, or the current value if OK.\r\n   */\r\n  private outOfBoundCorrection(instance: IPaginationInstance): number {\r\n    const totalPages: number = Math.ceil(instance.totalItems / instance.itemsPerPage);\r\n    if (totalPages < instance.currentPage && 0 < totalPages) {\r\n      return totalPages;\r\n    } else if (instance.currentPage < 1) {\r\n      return 1;\r\n    }\r\n\r\n    return instance.currentPage;\r\n  }\r\n\r\n  // Returns an array of IPage objects to use in the pagination controls.\r\n  private createPageArray(currentPage: number, itemsPerPage: number, totalItems: number, paginationRange: number): IPage[] {\r\n    // paginationRange could be a string if passed from attribute, so cast to number.\r\n    paginationRange = +paginationRange;\r\n    let pages: IPage[] = [];\r\n    const totalPages: number = Math.ceil(totalItems / itemsPerPage);\r\n    const halfWay: number = Math.ceil(paginationRange / 2);\r\n    const isStart: boolean = currentPage <= halfWay;\r\n    const isEnd: boolean = totalPages - halfWay < currentPage;\r\n    const isMiddle: boolean = !isStart && !isEnd;\r\n    let ellipsesNeeded: boolean = paginationRange < totalPages;\r\n    let i: number = 1;\r\n    while (i <= totalPages && i <= paginationRange) {\r\n      let label: string;\r\n      let pageNumber: number = this.calculatePageNumber(i, currentPage, paginationRange, totalPages);\r\n      let openingEllipsesNeeded: boolean = (i === 2 && (isMiddle || isEnd));\r\n      let closingEllipsesNeeded: boolean = (i === paginationRange - 1 && (isMiddle || isStart));\r\n      if (ellipsesNeeded && (openingEllipsesNeeded || closingEllipsesNeeded)) {\r\n        label = '...';\r\n      } else {\r\n        label = '' + pageNumber;\r\n      }\r\n      pages.push({\r\n        label: label,\r\n        value: pageNumber\r\n      });\r\n      i++;\r\n    }\r\n    return pages;\r\n  }\r\n\r\n  // Given the position in the sequence of pagination links [i], figure out what page number corresponds to that position.\r\n  private calculatePageNumber(i: number, currentPage: number, paginationRange: number, totalPages: number): number {\r\n    let halfWay: number = Math.ceil(paginationRange / 2);\r\n    if (i === paginationRange) {\r\n      return totalPages;\r\n    } else if (i === 1) {\r\n      return i;\r\n    } else if (paginationRange < totalPages) {\r\n      if (totalPages - halfWay < currentPage) {\r\n        return totalPages - paginationRange + i;\r\n      } else if (halfWay < currentPage) {\r\n        return currentPage - halfWay + i;\r\n      } else {\r\n        return i;\r\n      }\r\n    } else {\r\n      return i;\r\n    }\r\n  }\r\n}\r\n"]}
142
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"pagination.component.js","sourceRoot":"","sources":["../../../../../../projects/corecomponents/src/lib/components/pagination/pagination.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Component,\r\n  ElementRef,\r\n  EventEmitter,\r\n  HostBinding,\r\n  Input,\r\n  OnChanges,\r\n  OnDestroy,\r\n  OnInit,\r\n  Output,\r\n  ViewChild,\r\n  ViewEncapsulation\r\n} from '@angular/core';\r\nimport { Subscription } from 'rxjs';\r\nimport { IPaginationInstance } from './pagination-instance';\r\nimport { PaginationService } from './pagination.service';\r\n\r\n@Component({\r\n  selector: 'co-pagination',\r\n  template: `\r\n    <div class=\"pagination-component-main-wrapper\" *ngIf=\"!shouldBeHidden()\">\r\n      <div>\r\n        <ng-content></ng-content>\r\n      </div>\r\n\r\n      <co-pagination-bar\r\n        [currentPage]=\"getCurrentPage()\"\r\n        [totalItems]=\"totalItems\"\r\n        [itemsPerPage]=\"itemsPerPage\"\r\n        [directionLinks]=\"directionLinks\"\r\n        [previousLabel]=\"previousLabel\"\r\n        [nextLabel]=\"nextLabel\"\r\n        (previousClick)=\"goToPreviousPage()\"\r\n        (nextClick)=\"goToNextPage()\"\r\n        (pageClick)=\"setCurrentPage($event)\"\r\n      ></co-pagination-bar>\r\n    </div>\r\n  `,\r\n  encapsulation: ViewEncapsulation.None\r\n})\r\nexport class PaginationComponent implements OnInit, OnChanges, OnDestroy {\r\n  @ViewChild('template')\r\n  public readonly template: ElementRef;\r\n\r\n  @Input()\r\n  public id: string;\r\n\r\n  @Input()\r\n  public maxSize: number = 7;\r\n\r\n  @Input()\r\n  public directionLinks: boolean = true;\r\n\r\n  @Input()\r\n  public previousLabel: string = 'Vorige pagina';\r\n\r\n  @Input()\r\n  public nextLabel: string = 'Volgende pagina';\r\n\r\n  @Input()\r\n  public autoHide: boolean = false;\r\n\r\n  // Emits the new page number.\r\n  @Output()\r\n  public readonly pageChange: EventEmitter<number> = new EventEmitter<number>();\r\n\r\n  @HostBinding('class.co-pagination')\r\n  public showClass: boolean = true;\r\n\r\n  public totalItems: number = 1;\r\n  public itemsPerPage: number = 20;\r\n\r\n  private changeSub: Subscription;\r\n\r\n\r\n  constructor(private _paginationService: PaginationService) {\r\n    this.changeSub = this._paginationService.change.subscribe((id: string) => {\r\n      if (this.id === id) {\r\n        this._updatePageLinks();\r\n      }\r\n    });\r\n  }\r\n\r\n  ngOnInit(): void {\r\n    if (!this.id) {\r\n      this.id = this._paginationService.DEFAULT_ID;\r\n    }\r\n    this._updatePageLinks();\r\n  }\r\n\r\n  ngOnChanges(): void {\r\n    this._updatePageLinks();\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    this.changeSub.unsubscribe();\r\n  }\r\n\r\n  public goToFirstPage(): void {\r\n    if (!this.isOnFirstPage()) {\r\n      this.setCurrentPage(1);\r\n    }\r\n  }\r\n\r\n  public goToPreviousPage(): void {\r\n    if (!this.isOnFirstPage()) {\r\n      this.setCurrentPage(this.getCurrentPage() - 1);\r\n    }\r\n  }\r\n\r\n  public goToNextPage(): void {\r\n    if (!this.isOnLastPage()) {\r\n      this.setCurrentPage(this.getCurrentPage() + 1);\r\n    }\r\n  }\r\n\r\n  public setCurrentPage(page: number): void {\r\n    this.pageChange.emit(page);\r\n  }\r\n\r\n  public isOnFirstPage(): boolean {\r\n    return this.getCurrentPage() === 1;\r\n  }\r\n\r\n  public isOnLastPage(): boolean {\r\n    return this.getLastPage() === this.getCurrentPage();\r\n  }\r\n\r\n  public shouldBeHidden(): boolean {\r\n    if (!this.autoHide) {\r\n      return false;\r\n    } else {\r\n      let instance: IPaginationInstance = this._paginationService.getInstance();\r\n      return (instance.totalItems <= instance.itemsPerPage);\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Updates the page links and checks that the current page is valid. Should run whenever the\r\n   * PaginationService.change stream emits a value matching the current ID, or when any of the\r\n   * input values changes.\r\n   */\r\n  private _updatePageLinks(): void {\r\n    let paginationInstance: IPaginationInstance = this._paginationService.getInstance(this.id);\r\n\r\n    const correctedCurrentPage: number = this.outOfBoundCorrection(paginationInstance);\r\n    if (correctedCurrentPage !== paginationInstance.currentPage) {\r\n      this.setCurrentPage(correctedCurrentPage);\r\n    }\r\n\r\n    this.totalItems = paginationInstance.totalItems;\r\n    this.itemsPerPage = paginationInstance.itemsPerPage;\r\n  }\r\n\r\n  public getCurrentPage(): number {\r\n    return this._paginationService.getCurrentPage(this.id);\r\n  }\r\n\r\n  public getLastPage(): number {\r\n    let instance: IPaginationInstance = this._paginationService.getInstance(this.id);\r\n    return Math.ceil(instance.totalItems / instance.itemsPerPage);\r\n  }\r\n\r\n  /**\r\n   * Checks that the instance.currentPage property is within bounds for the current page range.\r\n   * If not, return a correct value for currentPage, or the current value if OK.\r\n   */\r\n  private outOfBoundCorrection(instance: IPaginationInstance): number {\r\n    const totalPages: number = Math.ceil(instance.totalItems / instance.itemsPerPage);\r\n    if (totalPages < instance.currentPage && 0 < totalPages) {\r\n      return totalPages;\r\n    } else if (instance.currentPage < 1) {\r\n      return 1;\r\n    }\r\n\r\n    return instance.currentPage;\r\n  }\r\n}\r\n"]}
@@ -85,4 +85,4 @@ PaginationService.decorators = [
85
85
  { type: Injectable }
86
86
  ];
87
87
  PaginationService.ctorParameters = () => [];
88
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"pagination.service.js","sourceRoot":"","sources":["../../../../../../projects/corecomponents/src/lib/components/pagination/pagination.service.ts"],"names":[],"mappings":"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","sourcesContent":["import {Injectable} from \"@angular/core\";\r\nimport {Subject} from \"rxjs\";\r\n\r\nimport {IPaginationInstance} from \"./pagination-instance\";\r\nimport {ObjectUtils} from \"../../core/utils/object-utils\";\r\n\r\n@Injectable()\r\nexport class PaginationService {\r\n    private static readonly DEFAULT_ID: string = \"DEFAULT_PAGINATION_ID\";\r\n\r\n    public change: Subject<string> = new Subject<string>();\r\n\r\n    public get DEFAULT_ID(): string {\r\n        return PaginationService.DEFAULT_ID;\r\n    }\r\n\r\n    private readonly instances: { [id: string]: IPaginationInstance } = {};\r\n\r\n    constructor() {\r\n    }\r\n\r\n    public register(instance: IPaginationInstance): void {\r\n        if (!instance.id) {\r\n            instance.id = PaginationService.DEFAULT_ID;\r\n        }\r\n\r\n        if (!this.instances[instance.id]) {\r\n            this.instances[instance.id] = instance;\r\n            this.change.next(instance.id);\r\n        } else {\r\n            let changed: boolean = this.updateInstance(instance);\r\n            if (changed) {\r\n                this.change.next(instance.id);\r\n            }\r\n        }\r\n    }\r\n\r\n    // Returns the current page number.\r\n    public getCurrentPage(id: string): number {\r\n        if (this.instances[id]) {\r\n            return this.instances[id].currentPage;\r\n        }\r\n    }\r\n\r\n    // Sets the current page number.\r\n    public setCurrentPage(id: string, page: number): void {\r\n        if (this.instances[id]) {\r\n            let instance: IPaginationInstance = this.instances[id];\r\n            let maxPage: number = Math.ceil(instance.totalItems / instance.itemsPerPage);\r\n            if (page <= maxPage && 1 <= page) {\r\n                this.instances[id].currentPage = page;\r\n                this.change.next(id);\r\n            }\r\n        }\r\n    }\r\n\r\n    // Sets the value of instance.totalItems\r\n    public setTotalItems(id: string, totalItems: number): void {\r\n        if (this.instances[id] && 0 <= totalItems) {\r\n            this.instances[id].totalItems = totalItems;\r\n            this.change.next(id);\r\n        }\r\n    }\r\n\r\n    // Sets the value of instance.itemsPerPage.\r\n    public setItemsPerPage(id: string, itemsPerPage: number): void {\r\n        if (this.instances[id]) {\r\n            this.instances[id].itemsPerPage = itemsPerPage;\r\n            this.change.next(id);\r\n        }\r\n    }\r\n\r\n    /**\r\n     * Returns a clone of the pagination instance object matching the id. If no\r\n     * id specified, returns the instance corresponding to the default id.\r\n     */\r\n    public getInstance(id: string = PaginationService.DEFAULT_ID): IPaginationInstance {\r\n        if (this.instances[id]) {\r\n            return ObjectUtils.GetShallowClone(this.instances[id]);\r\n        }\r\n        return <IPaginationInstance>{};\r\n    }\r\n\r\n    /**\r\n     * Check each property of the instance and update any that have changed. Return\r\n     * true if any changes were made, else return false.\r\n     */\r\n    private updateInstance(instance: IPaginationInstance): boolean {\r\n        let changed: boolean = false;\r\n        for (let prop in this.instances[instance.id]) {\r\n            if (instance[prop] !== this.instances[instance.id][prop]) {\r\n                this.instances[instance.id][prop] = instance[prop];\r\n                changed = true;\r\n            }\r\n        }\r\n        return changed;\r\n    }\r\n}"]}
88
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"pagination.service.js","sourceRoot":"","sources":["../../../../../../projects/corecomponents/src/lib/components/pagination/pagination.service.ts"],"names":[],"mappings":"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","sourcesContent":["import {Injectable} from \"@angular/core\";\r\nimport {Subject} from \"rxjs\";\r\n\r\nimport {IPaginationInstance} from \"./pagination-instance\";\r\nimport {ObjectUtils} from \"../../core/utils/object-utils\";\r\n\r\n@Injectable()\r\nexport class PaginationService {\r\n    private static readonly DEFAULT_ID: string = \"DEFAULT_PAGINATION_ID\";\r\n\r\n    public change: Subject<string> = new Subject<string>();\r\n\r\n    public get DEFAULT_ID(): string {\r\n        return PaginationService.DEFAULT_ID;\r\n    }\r\n\r\n    private readonly instances: { [id: string]: IPaginationInstance } = {};\r\n\r\n    constructor() {\r\n    }\r\n\r\n    public register(instance: IPaginationInstance): void {\r\n        if (!instance.id) {\r\n            instance.id = PaginationService.DEFAULT_ID;\r\n        }\r\n\r\n        if (!this.instances[instance.id]) {\r\n            this.instances[instance.id] = instance;\r\n            this.change.next(instance.id);\r\n        } else {\r\n            let changed: boolean = this.updateInstance(instance);\r\n            if (changed) {\r\n                this.change.next(instance.id);\r\n            }\r\n        }\r\n    }\r\n\r\n    // Returns the current page number.\r\n    public getCurrentPage(id: string): number {\r\n        if (this.instances[id]) {\r\n            return this.instances[id].currentPage;\r\n        }\r\n    }\r\n\r\n    // Sets the current page number.\r\n    public setCurrentPage(id: string, page: number): void {\r\n        if (this.instances[id]) {\r\n            let instance: IPaginationInstance = this.instances[id];\r\n            let maxPage: number = Math.ceil(instance.totalItems / instance.itemsPerPage);\r\n            if (page <= maxPage && 1 <= page) {\r\n                this.instances[id].currentPage = page;\r\n                this.change.next(id);\r\n            }\r\n        }\r\n    }\r\n\r\n    // Sets the value of instance.totalItems\r\n    public setTotalItems(id: string, totalItems: number): void {\r\n        if (this.instances[id] && 0 <= totalItems) {\r\n            this.instances[id].totalItems = totalItems;\r\n            this.change.next(id);\r\n        }\r\n    }\r\n\r\n    // Sets the value of instance.itemsPerPage.\r\n    public setItemsPerPage(id: string, itemsPerPage: number): void {\r\n        if (this.instances[id]) {\r\n            this.instances[id].itemsPerPage = itemsPerPage;\r\n            this.change.next(id);\r\n        }\r\n    }\r\n\r\n\r\n    /**\r\n     * Returns a clone of the pagination instance object matching the id. If no\r\n     * id specified, returns the instance corresponding to the default id.\r\n     */\r\n    public getInstance(id: string = PaginationService.DEFAULT_ID): IPaginationInstance {\r\n        if (this.instances[id]) {\r\n            return ObjectUtils.GetShallowClone(this.instances[id]);\r\n        }\r\n        return <IPaginationInstance>{};\r\n    }\r\n\r\n    /**\r\n     * Check each property of the instance and update any that have changed. Return\r\n     * true if any changes were made, else return false.\r\n     */\r\n    private updateInstance(instance: IPaginationInstance): boolean {\r\n        let changed: boolean = false;\r\n        for (let prop in this.instances[instance.id]) {\r\n            if (instance[prop] !== this.instances[instance.id][prop]) {\r\n                this.instances[instance.id][prop] = instance[prop];\r\n                changed = true;\r\n            }\r\n        }\r\n        return changed;\r\n    }\r\n}\r\n"]}
@@ -1,18 +1,30 @@
1
1
  import { Component, EventEmitter, HostBinding, Input, Output, ViewEncapsulation } from "@angular/core";
2
2
  export class PaginationBarComponent {
3
3
  constructor() {
4
- this.pages = [];
5
4
  this.directionLinks = true;
6
5
  this.previousLabel = 'Vorige pagina';
7
6
  this.nextLabel = 'Volgende pagina';
8
7
  this.currentPage = 1;
8
+ this.itemsPerPage = 20;
9
+ this.totalItems = 1;
10
+ this.paginationRange = 8;
9
11
  this.previousClick = new EventEmitter();
10
12
  this.nextClick = new EventEmitter();
11
13
  this.pageClick = new EventEmitter();
14
+ this.pages = [];
12
15
  }
13
16
  showClass() {
14
17
  return true;
15
18
  }
19
+ ngOnInit() {
20
+ this.totalPages = Math.ceil(this.totalItems / this.itemsPerPage);
21
+ this.pages = this._createPageArray();
22
+ }
23
+ ngOnChanges(changes) {
24
+ if (changes['currentPage'].currentValue !== changes['currentPage'].previousValue) {
25
+ this.pages = this._createPageArray();
26
+ }
27
+ }
16
28
  isOnFirstPage() {
17
29
  return this.currentPage === 1;
18
30
  }
@@ -29,6 +41,60 @@ export class PaginationBarComponent {
29
41
  this.currentPage = value;
30
42
  this.pageClick.emit(value);
31
43
  }
44
+ // Returns an array of IPage objects to use in the pagination controls.
45
+ _createPageArray() {
46
+ // paginationRange could be a string if passed from attribute, so cast to number.
47
+ this.paginationRange = +this.paginationRange;
48
+ let pages = [];
49
+ const halfWay = Math.ceil(this.paginationRange / 2);
50
+ const isStart = this.currentPage <= halfWay;
51
+ const isEnd = this.totalPages - halfWay < this.currentPage;
52
+ const isMiddle = !isStart && !isEnd;
53
+ let ellipsesNeeded = this.paginationRange < this.totalPages;
54
+ let i = 1;
55
+ while (i <= this.totalPages && i <= this.paginationRange) {
56
+ let label;
57
+ let pageNumber = this._calculatePageNumber(i);
58
+ let openingEllipsesNeeded = (i === 2 && (isMiddle || isEnd));
59
+ let closingEllipsesNeeded = (i === this.paginationRange - 1 && (isMiddle || isStart));
60
+ if (ellipsesNeeded && (openingEllipsesNeeded || closingEllipsesNeeded)) {
61
+ label = '...';
62
+ }
63
+ else {
64
+ label = '' + pageNumber;
65
+ }
66
+ pages.push({
67
+ label: label,
68
+ value: pageNumber
69
+ });
70
+ i++;
71
+ }
72
+ return pages;
73
+ }
74
+ // Given the position in the sequence of pagination links [i], figure out what page number corresponds to that position.
75
+ _calculatePageNumber(i) {
76
+ let halfWay = Math.ceil(this.paginationRange / 2);
77
+ if (i === this.paginationRange) {
78
+ return this.totalPages;
79
+ }
80
+ else if (i === 1) {
81
+ return i;
82
+ }
83
+ else if (this.paginationRange < this.totalPages) {
84
+ if (this.totalPages - halfWay < this.currentPage) {
85
+ return this.totalPages - this.paginationRange + i;
86
+ }
87
+ else if (halfWay < this.currentPage) {
88
+ return this.currentPage - halfWay + i;
89
+ }
90
+ else {
91
+ return i;
92
+ }
93
+ }
94
+ else {
95
+ return i;
96
+ }
97
+ }
32
98
  }
33
99
  PaginationBarComponent.decorators = [
34
100
  { type: Component, args: [{
@@ -50,14 +116,16 @@ PaginationBarComponent.decorators = [
50
116
  },] }
51
117
  ];
52
118
  PaginationBarComponent.propDecorators = {
53
- pages: [{ type: Input }],
54
119
  directionLinks: [{ type: Input }],
55
120
  previousLabel: [{ type: Input }],
56
121
  nextLabel: [{ type: Input }],
57
122
  currentPage: [{ type: Input }],
123
+ itemsPerPage: [{ type: Input }],
124
+ totalItems: [{ type: Input }],
125
+ paginationRange: [{ type: Input }],
58
126
  previousClick: [{ type: Output }],
59
127
  nextClick: [{ type: Output }],
60
128
  pageClick: [{ type: Output }],
61
129
  showClass: [{ type: HostBinding, args: ["class.co-pagination-bar",] }]
62
130
  };
63
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGFnaW5hdGlvbi1iYXIuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvY29yZWNvbXBvbmVudHMvc3JjL2xpYi9jb21wb25lbnRzL3BhZ2luYXRpb24tYmFyL3BhZ2luYXRpb24tYmFyLmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLFlBQVksRUFBRSxXQUFXLEVBQUUsS0FBSyxFQUFFLE1BQU0sRUFBRSxpQkFBaUIsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQXdCdkcsTUFBTSxPQUFPLHNCQUFzQjtJQWpCbkM7UUFvQlMsVUFBSyxHQUFZLEVBQUUsQ0FBQztRQUdwQixtQkFBYyxHQUFZLElBQUksQ0FBQztRQUcvQixrQkFBYSxHQUFXLGVBQWUsQ0FBQztRQUd4QyxjQUFTLEdBQVcsaUJBQWlCLENBQUM7UUFHdEMsZ0JBQVcsR0FBVyxDQUFDLENBQUM7UUFHeEIsa0JBQWEsR0FBdUIsSUFBSSxZQUFZLEVBQVEsQ0FBQztRQUc3RCxjQUFTLEdBQXVCLElBQUksWUFBWSxFQUFRLENBQUM7UUFHekQsY0FBUyxHQUFzQixJQUFJLFlBQVksRUFBTyxDQUFDO0lBMkJoRSxDQUFDO0lBeEJRLFNBQVM7UUFDZCxPQUFPLElBQUksQ0FBQztJQUNkLENBQUM7SUFFTSxhQUFhO1FBQ2xCLE9BQU8sSUFBSSxDQUFDLFdBQVcsS0FBSyxDQUFDLENBQUM7SUFDaEMsQ0FBQztJQUVNLFlBQVk7UUFDakIsT0FBTyxJQUFJLENBQUMsS0FBSyxDQUFDLE1BQU0sS0FBSyxJQUFJLENBQUMsV0FBVyxDQUFDO0lBQ2hELENBQUM7SUFFTSxlQUFlO1FBQ3BCLElBQUksQ0FBQyxhQUFhLENBQUMsSUFBSSxFQUFFLENBQUM7SUFDNUIsQ0FBQztJQUVNLFdBQVc7UUFDaEIsSUFBSSxDQUFDLFNBQVMsQ0FBQyxJQUFJLEVBQUUsQ0FBQztJQUN4QixDQUFDO0lBRU0sV0FBVyxDQUFDLEtBQVU7UUFDM0IsSUFBSSxDQUFDLFdBQVcsR0FBRyxLQUFLLENBQUM7UUFDekIsSUFBSSxDQUFDLFNBQVMsQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUM7SUFDN0IsQ0FBQzs7O1lBbkVGLFNBQVMsU0FBQztnQkFDVCxRQUFRLEVBQUUsbUJBQW1CO2dCQUM3QixRQUFRLEVBQUU7Ozs7Ozs7Ozs7OztLQVlQO2dCQUNILGFBQWEsRUFBRSxpQkFBaUIsQ0FBQyxJQUFJO2FBQ3RDOzs7b0JBR0UsS0FBSzs2QkFHTCxLQUFLOzRCQUdMLEtBQUs7d0JBR0wsS0FBSzswQkFHTCxLQUFLOzRCQUdMLE1BQU07d0JBR04sTUFBTTt3QkFHTixNQUFNO3dCQUdOLFdBQVcsU0FBQyx5QkFBeUIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIEV2ZW50RW1pdHRlciwgSG9zdEJpbmRpbmcsIElucHV0LCBPdXRwdXQsIFZpZXdFbmNhcHN1bGF0aW9uIH0gZnJvbSBcIkBhbmd1bGFyL2NvcmVcIjtcclxuXHJcbmV4cG9ydCBpbnRlcmZhY2UgSVBhZ2Uge1xyXG4gIGxhYmVsOiBzdHJpbmc7XHJcbiAgdmFsdWU6IGFueTtcclxufVxyXG5cclxuQENvbXBvbmVudCh7XHJcbiAgc2VsZWN0b3I6IFwiY28tcGFnaW5hdGlvbi1iYXJcIixcclxuICB0ZW1wbGF0ZTogYFxyXG4gICAgPHVsIGNsYXNzPVwicGFnaW5hdGlvblwiPlxyXG4gICAgICA8bGkgKm5nSWY9XCJkaXJlY3Rpb25MaW5rc1wiIGNsYXNzPVwicGFnaW5hdGlvbi1wcmV2aW91c1wiPlxyXG4gICAgICAgIDxhIChjbGljayk9XCJvblByZXZpb3VzQ2xpY2soKVwiIFtjbGFzcy5kaXNhYmxlZF09XCJpc09uRmlyc3RQYWdlKClcIj57eyBwcmV2aW91c0xhYmVsIH19PC9hPlxyXG4gICAgICA8L2xpPlxyXG4gICAgICA8bGkgKm5nRm9yPVwibGV0IHBhZ2Ugb2YgcGFnZXNcIiBbY2xhc3MuY3VycmVudF09XCJjdXJyZW50UGFnZSA9PT0gcGFnZS52YWx1ZVwiIChjbGljayk9XCJvblBhZ2VDbGljayhwYWdlLnZhbHVlKVwiPlxyXG4gICAgICAgIDxzcGFuPnt7cGFnZS5sYWJlbH19PC9zcGFuPlxyXG4gICAgICA8L2xpPlxyXG4gICAgICA8bGkgKm5nSWY9XCJkaXJlY3Rpb25MaW5rc1wiIGNsYXNzPVwicGFnaW5hdGlvbi1uZXh0XCI+XHJcbiAgICAgICAgPGEgKGNsaWNrKT1cIm9uTmV4dENsaWNrKClcIiBbY2xhc3MuZGlzYWJsZWRdPVwiaXNPbkxhc3RQYWdlKClcIj57eyBuZXh0TGFiZWwgfX08L2E+XHJcbiAgICAgIDwvbGk+XHJcbiAgICA8L3VsPlxyXG4gICAgYCxcclxuICBlbmNhcHN1bGF0aW9uOiBWaWV3RW5jYXBzdWxhdGlvbi5Ob25lXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBQYWdpbmF0aW9uQmFyQ29tcG9uZW50IHtcclxuXHJcbiAgQElucHV0KClcclxuICBwdWJsaWMgcGFnZXM6IElQYWdlW10gPSBbXTtcclxuXHJcbiAgQElucHV0KClcclxuICBwdWJsaWMgZGlyZWN0aW9uTGlua3M6IGJvb2xlYW4gPSB0cnVlO1xyXG5cclxuICBASW5wdXQoKVxyXG4gIHB1YmxpYyBwcmV2aW91c0xhYmVsOiBzdHJpbmcgPSAnVm9yaWdlIHBhZ2luYSc7XHJcblxyXG4gIEBJbnB1dCgpXHJcbiAgcHVibGljIG5leHRMYWJlbDogc3RyaW5nID0gJ1ZvbGdlbmRlIHBhZ2luYSc7XHJcblxyXG4gIEBJbnB1dCgpXHJcbiAgcHVibGljIGN1cnJlbnRQYWdlOiBudW1iZXIgPSAxO1xyXG5cclxuICBAT3V0cHV0KClcclxuICBwdWJsaWMgcHJldmlvdXNDbGljazogRXZlbnRFbWl0dGVyPHZvaWQ+ID0gbmV3IEV2ZW50RW1pdHRlcjx2b2lkPigpO1xyXG5cclxuICBAT3V0cHV0KClcclxuICBwdWJsaWMgbmV4dENsaWNrOiBFdmVudEVtaXR0ZXI8dm9pZD4gPSBuZXcgRXZlbnRFbWl0dGVyPHZvaWQ+KCk7XHJcblxyXG4gIEBPdXRwdXQoKVxyXG4gIHB1YmxpYyBwYWdlQ2xpY2s6IEV2ZW50RW1pdHRlcjxhbnk+ID0gbmV3IEV2ZW50RW1pdHRlcjxhbnk+KCk7XHJcblxyXG4gIEBIb3N0QmluZGluZyhcImNsYXNzLmNvLXBhZ2luYXRpb24tYmFyXCIpXHJcbiAgcHVibGljIHNob3dDbGFzcygpIHtcclxuICAgIHJldHVybiB0cnVlO1xyXG4gIH1cclxuXHJcbiAgcHVibGljIGlzT25GaXJzdFBhZ2UoKTogYm9vbGVhbiB7XHJcbiAgICByZXR1cm4gdGhpcy5jdXJyZW50UGFnZSA9PT0gMTtcclxuICB9XHJcblxyXG4gIHB1YmxpYyBpc09uTGFzdFBhZ2UoKTogYm9vbGVhbiB7XHJcbiAgICByZXR1cm4gdGhpcy5wYWdlcy5sZW5ndGggPT09IHRoaXMuY3VycmVudFBhZ2U7XHJcbiAgfVxyXG5cclxuICBwdWJsaWMgb25QcmV2aW91c0NsaWNrKCk6IHZvaWQge1xyXG4gICAgdGhpcy5wcmV2aW91c0NsaWNrLmVtaXQoKTtcclxuICB9XHJcblxyXG4gIHB1YmxpYyBvbk5leHRDbGljaygpOiB2b2lkIHtcclxuICAgIHRoaXMubmV4dENsaWNrLmVtaXQoKTtcclxuICB9XHJcblxyXG4gIHB1YmxpYyBvblBhZ2VDbGljayh2YWx1ZTogYW55KTogdm9pZCB7XHJcbiAgICB0aGlzLmN1cnJlbnRQYWdlID0gdmFsdWU7XHJcbiAgICB0aGlzLnBhZ2VDbGljay5lbWl0KHZhbHVlKTtcclxuICB9XHJcbn1cclxuIl19
131
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"pagination-bar.component.js","sourceRoot":"","sources":["../../../../../../projects/corecomponents/src/lib/components/pagination-bar/pagination-bar.component.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,SAAS,EACT,YAAY,EACZ,WAAW,EACX,KAAK,EAGL,MAAM,EAEN,iBAAiB,EAClB,MAAM,eAAe,CAAC;AAwBvB,MAAM,OAAO,sBAAsB;IAjBnC;QAoBS,mBAAc,GAAY,IAAI,CAAC;QAG/B,kBAAa,GAAW,eAAe,CAAC;QAGxC,cAAS,GAAW,iBAAiB,CAAC;QAGtC,gBAAW,GAAW,CAAC,CAAC;QAGxB,iBAAY,GAAW,EAAE,CAAC;QAG1B,eAAU,GAAW,CAAC,CAAC;QAGvB,oBAAe,GAAW,CAAC,CAAC;QAG5B,kBAAa,GAAuB,IAAI,YAAY,EAAQ,CAAC;QAG7D,cAAS,GAAuB,IAAI,YAAY,EAAQ,CAAC;QAGzD,cAAS,GAAsB,IAAI,YAAY,EAAO,CAAC;QAOvD,UAAK,GAAY,EAAE,CAAC;IAoF7B,CAAC;IAxFQ,SAAS;QACd,OAAO,IAAI,CAAC;IACd,CAAC;IAKM,QAAQ;QACb,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,YAAY,CAAC,CAAC;QACjE,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,gBAAgB,EAAE,CAAC;IACvC,CAAC;IAEM,WAAW,CAAC,OAAsB;QACvC,IAAI,OAAO,CAAC,aAAa,CAAC,CAAC,YAAY,KAAK,OAAO,CAAC,aAAa,CAAC,CAAC,aAAa,EAAE;YAChF,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,gBAAgB,EAAE,CAAC;SACtC;IACH,CAAC;IAEM,aAAa;QAClB,OAAO,IAAI,CAAC,WAAW,KAAK,CAAC,CAAC;IAChC,CAAC;IAEM,YAAY;QACjB,OAAO,IAAI,CAAC,KAAK,CAAC,MAAM,KAAK,IAAI,CAAC,WAAW,CAAC;IAChD,CAAC;IAEM,eAAe;QACpB,IAAI,CAAC,aAAa,CAAC,IAAI,EAAE,CAAC;IAC5B,CAAC;IAEM,WAAW;QAChB,IAAI,CAAC,SAAS,CAAC,IAAI,EAAE,CAAC;IACxB,CAAC;IAEM,WAAW,CAAC,KAAU;QAC3B,IAAI,CAAC,WAAW,GAAG,KAAK,CAAC;QACzB,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IAC7B,CAAC;IAED,uEAAuE;IAC/D,gBAAgB;QACtB,iFAAiF;QACjF,IAAI,CAAC,eAAe,GAAG,CAAC,IAAI,CAAC,eAAe,CAAC;QAC7C,IAAI,KAAK,GAAY,EAAE,CAAC;QACxB,MAAM,OAAO,GAAW,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,eAAe,GAAG,CAAC,CAAC,CAAC;QAC5D,MAAM,OAAO,GAAY,IAAI,CAAC,WAAW,IAAI,OAAO,CAAC;QACrD,MAAM,KAAK,GAAY,IAAI,CAAC,UAAU,GAAG,OAAO,GAAG,IAAI,CAAC,WAAW,CAAC;QACpE,MAAM,QAAQ,GAAY,CAAC,OAAO,IAAI,CAAC,KAAK,CAAC;QAC7C,IAAI,cAAc,GAAY,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC,UAAU,CAAC;QACrE,IAAI,CAAC,GAAW,CAAC,CAAC;QAClB,OAAO,CAAC,IAAI,IAAI,CAAC,UAAU,IAAI,CAAC,IAAI,IAAI,CAAC,eAAe,EAAE;YACxD,IAAI,KAAa,CAAC;YAClB,IAAI,UAAU,GAAW,IAAI,CAAC,oBAAoB,CAAC,CAAC,CAAC,CAAC;YACtD,IAAI,qBAAqB,GAAY,CAAC,CAAC,KAAK,CAAC,IAAI,CAAC,QAAQ,IAAI,KAAK,CAAC,CAAC,CAAC;YACtE,IAAI,qBAAqB,GAAY,CAAC,CAAC,KAAK,IAAI,CAAC,eAAe,GAAG,CAAC,IAAI,CAAC,QAAQ,IAAI,OAAO,CAAC,CAAC,CAAC;YAC/F,IAAI,cAAc,IAAI,CAAC,qBAAqB,IAAI,qBAAqB,CAAC,EAAE;gBACtE,KAAK,GAAG,KAAK,CAAC;aACf;iBAAM;gBACL,KAAK,GAAG,EAAE,GAAG,UAAU,CAAC;aACzB;YACD,KAAK,CAAC,IAAI,CAAC;gBACT,KAAK,EAAE,KAAK;gBACZ,KAAK,EAAE,UAAU;aAClB,CAAC,CAAC;YACH,CAAC,EAAE,CAAC;SACL;QACD,OAAO,KAAK,CAAC;IACf,CAAC;IAED,wHAAwH;IAChH,oBAAoB,CAAC,CAAS;QACpC,IAAI,OAAO,GAAW,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,eAAe,GAAG,CAAC,CAAC,CAAC;QAC1D,IAAI,CAAC,KAAK,IAAI,CAAC,eAAe,EAAE;YAC9B,OAAO,IAAI,CAAC,UAAU,CAAC;SACxB;aAAM,IAAI,CAAC,KAAK,CAAC,EAAE;YAClB,OAAO,CAAC,CAAC;SACV;aAAM,IAAI,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC,UAAU,EAAE;YACjD,IAAI,IAAI,CAAC,UAAU,GAAG,OAAO,GAAG,IAAI,CAAC,WAAW,EAAE;gBAChD,OAAO,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,eAAe,GAAG,CAAC,CAAC;aACnD;iBAAM,IAAI,OAAO,GAAG,IAAI,CAAC,WAAW,EAAE;gBACrC,OAAO,IAAI,CAAC,WAAW,GAAG,OAAO,GAAG,CAAC,CAAC;aACvC;iBAAM;gBACL,OAAO,CAAC,CAAC;aACV;SACF;aAAM;YACL,OAAO,CAAC,CAAC;SACV;IACH,CAAC;;;YAzIF,SAAS,SAAC;gBACT,QAAQ,EAAE,mBAAmB;gBAC7B,QAAQ,EAAE;;;;;;;;;;;;KAYP;gBACH,aAAa,EAAE,iBAAiB,CAAC,IAAI;aACtC;;;6BAGE,KAAK;4BAGL,KAAK;wBAGL,KAAK;0BAGL,KAAK;2BAGL,KAAK;yBAGL,KAAK;8BAGL,KAAK;4BAGL,MAAM;wBAGN,MAAM;wBAGN,MAAM;wBAGN,WAAW,SAAC,yBAAyB","sourcesContent":["import {\r\n  Component,\r\n  EventEmitter,\r\n  HostBinding,\r\n  Input,\r\n  OnChanges,\r\n  OnInit,\r\n  Output,\r\n  SimpleChanges,\r\n  ViewEncapsulation\r\n} from \"@angular/core\";\r\n\r\nexport interface IPage {\r\n  label: string;\r\n  value: any;\r\n}\r\n\r\n@Component({\r\n  selector: \"co-pagination-bar\",\r\n  template: `\r\n    <ul class=\"pagination\">\r\n      <li *ngIf=\"directionLinks\" class=\"pagination-previous\">\r\n        <a (click)=\"onPreviousClick()\" [class.disabled]=\"isOnFirstPage()\">{{ previousLabel }}</a>\r\n      </li>\r\n      <li *ngFor=\"let page of pages\" [class.current]=\"currentPage === page.value\" (click)=\"onPageClick(page.value)\">\r\n        <span>{{page.label}}</span>\r\n      </li>\r\n      <li *ngIf=\"directionLinks\" class=\"pagination-next\">\r\n        <a (click)=\"onNextClick()\" [class.disabled]=\"isOnLastPage()\">{{ nextLabel }}</a>\r\n      </li>\r\n    </ul>\r\n    `,\r\n  encapsulation: ViewEncapsulation.None\r\n})\r\nexport class PaginationBarComponent implements OnInit, OnChanges {\r\n\r\n  @Input()\r\n  public directionLinks: boolean = true;\r\n\r\n  @Input()\r\n  public previousLabel: string = 'Vorige pagina';\r\n\r\n  @Input()\r\n  public nextLabel: string = 'Volgende pagina';\r\n\r\n  @Input()\r\n  public currentPage: number = 1;\r\n\r\n  @Input()\r\n  public itemsPerPage: number = 20;\r\n\r\n  @Input()\r\n  public totalItems: number = 1;\r\n\r\n  @Input()\r\n  public paginationRange: number = 8;\r\n\r\n  @Output()\r\n  public previousClick: EventEmitter<void> = new EventEmitter<void>();\r\n\r\n  @Output()\r\n  public nextClick: EventEmitter<void> = new EventEmitter<void>();\r\n\r\n  @Output()\r\n  public pageClick: EventEmitter<any> = new EventEmitter<any>();\r\n\r\n  @HostBinding(\"class.co-pagination-bar\")\r\n  public showClass() {\r\n    return true;\r\n  }\r\n\r\n  public pages: IPage[] = [];\r\n  public totalPages: number;\r\n\r\n  public ngOnInit(): void {\r\n    this.totalPages = Math.ceil(this.totalItems / this.itemsPerPage);\r\n    this.pages = this._createPageArray();\r\n  }\r\n\r\n  public ngOnChanges(changes: SimpleChanges): void {\r\n    if (changes['currentPage'].currentValue !== changes['currentPage'].previousValue) {\r\n      this.pages = this._createPageArray();\r\n    }\r\n  }\r\n\r\n  public isOnFirstPage(): boolean {\r\n    return this.currentPage === 1;\r\n  }\r\n\r\n  public isOnLastPage(): boolean {\r\n    return this.pages.length === this.currentPage;\r\n  }\r\n\r\n  public onPreviousClick(): void {\r\n    this.previousClick.emit();\r\n  }\r\n\r\n  public onNextClick(): void {\r\n    this.nextClick.emit();\r\n  }\r\n\r\n  public onPageClick(value: any): void {\r\n    this.currentPage = value;\r\n    this.pageClick.emit(value);\r\n  }\r\n\r\n  // Returns an array of IPage objects to use in the pagination controls.\r\n  private _createPageArray(): IPage[] {\r\n    // paginationRange could be a string if passed from attribute, so cast to number.\r\n    this.paginationRange = +this.paginationRange;\r\n    let pages: IPage[] = [];\r\n    const halfWay: number = Math.ceil(this.paginationRange / 2);\r\n    const isStart: boolean = this.currentPage <= halfWay;\r\n    const isEnd: boolean = this.totalPages - halfWay < this.currentPage;\r\n    const isMiddle: boolean = !isStart && !isEnd;\r\n    let ellipsesNeeded: boolean = this.paginationRange < this.totalPages;\r\n    let i: number = 1;\r\n    while (i <= this.totalPages && i <= this.paginationRange) {\r\n      let label: string;\r\n      let pageNumber: number = this._calculatePageNumber(i);\r\n      let openingEllipsesNeeded: boolean = (i === 2 && (isMiddle || isEnd));\r\n      let closingEllipsesNeeded: boolean = (i === this.paginationRange - 1 && (isMiddle || isStart));\r\n      if (ellipsesNeeded && (openingEllipsesNeeded || closingEllipsesNeeded)) {\r\n        label = '...';\r\n      } else {\r\n        label = '' + pageNumber;\r\n      }\r\n      pages.push({\r\n        label: label,\r\n        value: pageNumber\r\n      });\r\n      i++;\r\n    }\r\n    return pages;\r\n  }\r\n\r\n  // Given the position in the sequence of pagination links [i], figure out what page number corresponds to that position.\r\n  private _calculatePageNumber(i: number): number {\r\n    let halfWay: number = Math.ceil(this.paginationRange / 2);\r\n    if (i === this.paginationRange) {\r\n      return this.totalPages;\r\n    } else if (i === 1) {\r\n      return i;\r\n    } else if (this.paginationRange < this.totalPages) {\r\n      if (this.totalPages - halfWay < this.currentPage) {\r\n        return this.totalPages - this.paginationRange + i;\r\n      } else if (halfWay < this.currentPage) {\r\n        return this.currentPage - halfWay + i;\r\n      } else {\r\n        return i;\r\n      }\r\n    } else {\r\n      return i;\r\n    }\r\n  }\r\n}\r\n"]}
@@ -5804,6 +5804,7 @@ InputComboBoxComponent.decorators = [
5804
5804
  template: `
5805
5805
  <ejs-combobox #combo [dataSource]="collection"
5806
5806
  [fields]="fields"
5807
+ [disabled]="readonly"
5807
5808
  [placeholder]="placeholder"
5808
5809
  [autofill]="true"
5809
5810
  [ngModel]="model"
@@ -9291,18 +9292,30 @@ SimpleGridComponent.propDecorators = {
9291
9292
 
9292
9293
  class PaginationBarComponent {
9293
9294
  constructor() {
9294
- this.pages = [];
9295
9295
  this.directionLinks = true;
9296
9296
  this.previousLabel = 'Vorige pagina';
9297
9297
  this.nextLabel = 'Volgende pagina';
9298
9298
  this.currentPage = 1;
9299
+ this.itemsPerPage = 20;
9300
+ this.totalItems = 1;
9301
+ this.paginationRange = 8;
9299
9302
  this.previousClick = new EventEmitter();
9300
9303
  this.nextClick = new EventEmitter();
9301
9304
  this.pageClick = new EventEmitter();
9305
+ this.pages = [];
9302
9306
  }
9303
9307
  showClass() {
9304
9308
  return true;
9305
9309
  }
9310
+ ngOnInit() {
9311
+ this.totalPages = Math.ceil(this.totalItems / this.itemsPerPage);
9312
+ this.pages = this._createPageArray();
9313
+ }
9314
+ ngOnChanges(changes) {
9315
+ if (changes['currentPage'].currentValue !== changes['currentPage'].previousValue) {
9316
+ this.pages = this._createPageArray();
9317
+ }
9318
+ }
9306
9319
  isOnFirstPage() {
9307
9320
  return this.currentPage === 1;
9308
9321
  }
@@ -9319,6 +9332,60 @@ class PaginationBarComponent {
9319
9332
  this.currentPage = value;
9320
9333
  this.pageClick.emit(value);
9321
9334
  }
9335
+ // Returns an array of IPage objects to use in the pagination controls.
9336
+ _createPageArray() {
9337
+ // paginationRange could be a string if passed from attribute, so cast to number.
9338
+ this.paginationRange = +this.paginationRange;
9339
+ let pages = [];
9340
+ const halfWay = Math.ceil(this.paginationRange / 2);
9341
+ const isStart = this.currentPage <= halfWay;
9342
+ const isEnd = this.totalPages - halfWay < this.currentPage;
9343
+ const isMiddle = !isStart && !isEnd;
9344
+ let ellipsesNeeded = this.paginationRange < this.totalPages;
9345
+ let i = 1;
9346
+ while (i <= this.totalPages && i <= this.paginationRange) {
9347
+ let label;
9348
+ let pageNumber = this._calculatePageNumber(i);
9349
+ let openingEllipsesNeeded = (i === 2 && (isMiddle || isEnd));
9350
+ let closingEllipsesNeeded = (i === this.paginationRange - 1 && (isMiddle || isStart));
9351
+ if (ellipsesNeeded && (openingEllipsesNeeded || closingEllipsesNeeded)) {
9352
+ label = '...';
9353
+ }
9354
+ else {
9355
+ label = '' + pageNumber;
9356
+ }
9357
+ pages.push({
9358
+ label: label,
9359
+ value: pageNumber
9360
+ });
9361
+ i++;
9362
+ }
9363
+ return pages;
9364
+ }
9365
+ // Given the position in the sequence of pagination links [i], figure out what page number corresponds to that position.
9366
+ _calculatePageNumber(i) {
9367
+ let halfWay = Math.ceil(this.paginationRange / 2);
9368
+ if (i === this.paginationRange) {
9369
+ return this.totalPages;
9370
+ }
9371
+ else if (i === 1) {
9372
+ return i;
9373
+ }
9374
+ else if (this.paginationRange < this.totalPages) {
9375
+ if (this.totalPages - halfWay < this.currentPage) {
9376
+ return this.totalPages - this.paginationRange + i;
9377
+ }
9378
+ else if (halfWay < this.currentPage) {
9379
+ return this.currentPage - halfWay + i;
9380
+ }
9381
+ else {
9382
+ return i;
9383
+ }
9384
+ }
9385
+ else {
9386
+ return i;
9387
+ }
9388
+ }
9322
9389
  }
9323
9390
  PaginationBarComponent.decorators = [
9324
9391
  { type: Component, args: [{
@@ -9340,11 +9407,13 @@ PaginationBarComponent.decorators = [
9340
9407
  },] }
9341
9408
  ];
9342
9409
  PaginationBarComponent.propDecorators = {
9343
- pages: [{ type: Input }],
9344
9410
  directionLinks: [{ type: Input }],
9345
9411
  previousLabel: [{ type: Input }],
9346
9412
  nextLabel: [{ type: Input }],
9347
9413
  currentPage: [{ type: Input }],
9414
+ itemsPerPage: [{ type: Input }],
9415
+ totalItems: [{ type: Input }],
9416
+ paginationRange: [{ type: Input }],
9348
9417
  previousClick: [{ type: Output }],
9349
9418
  nextClick: [{ type: Output }],
9350
9419
  pageClick: [{ type: Output }],
@@ -9567,7 +9636,8 @@ class PaginationComponent {
9567
9636
  // Emits the new page number.
9568
9637
  this.pageChange = new EventEmitter();
9569
9638
  this.showClass = true;
9570
- this.pages = [];
9639
+ this.totalItems = 1;
9640
+ this.itemsPerPage = 20;
9571
9641
  this.changeSub = this._paginationService.change.subscribe((id) => {
9572
9642
  if (this.id === id) {
9573
9643
  this._updatePageLinks();
@@ -9626,11 +9696,12 @@ class PaginationComponent {
9626
9696
  */
9627
9697
  _updatePageLinks() {
9628
9698
  let paginationInstance = this._paginationService.getInstance(this.id);
9629
- this.pages = this.createPageArray(paginationInstance.currentPage, paginationInstance.itemsPerPage, paginationInstance.totalItems, this.maxSize);
9630
9699
  const correctedCurrentPage = this.outOfBoundCorrection(paginationInstance);
9631
9700
  if (correctedCurrentPage !== paginationInstance.currentPage) {
9632
9701
  this.setCurrentPage(correctedCurrentPage);
9633
9702
  }
9703
+ this.totalItems = paginationInstance.totalItems;
9704
+ this.itemsPerPage = paginationInstance.itemsPerPage;
9634
9705
  }
9635
9706
  getCurrentPage() {
9636
9707
  return this._paginationService.getCurrentPage(this.id);
@@ -9653,61 +9724,6 @@ class PaginationComponent {
9653
9724
  }
9654
9725
  return instance.currentPage;
9655
9726
  }
9656
- // Returns an array of IPage objects to use in the pagination controls.
9657
- createPageArray(currentPage, itemsPerPage, totalItems, paginationRange) {
9658
- // paginationRange could be a string if passed from attribute, so cast to number.
9659
- paginationRange = +paginationRange;
9660
- let pages = [];
9661
- const totalPages = Math.ceil(totalItems / itemsPerPage);
9662
- const halfWay = Math.ceil(paginationRange / 2);
9663
- const isStart = currentPage <= halfWay;
9664
- const isEnd = totalPages - halfWay < currentPage;
9665
- const isMiddle = !isStart && !isEnd;
9666
- let ellipsesNeeded = paginationRange < totalPages;
9667
- let i = 1;
9668
- while (i <= totalPages && i <= paginationRange) {
9669
- let label;
9670
- let pageNumber = this.calculatePageNumber(i, currentPage, paginationRange, totalPages);
9671
- let openingEllipsesNeeded = (i === 2 && (isMiddle || isEnd));
9672
- let closingEllipsesNeeded = (i === paginationRange - 1 && (isMiddle || isStart));
9673
- if (ellipsesNeeded && (openingEllipsesNeeded || closingEllipsesNeeded)) {
9674
- label = '...';
9675
- }
9676
- else {
9677
- label = '' + pageNumber;
9678
- }
9679
- pages.push({
9680
- label: label,
9681
- value: pageNumber
9682
- });
9683
- i++;
9684
- }
9685
- return pages;
9686
- }
9687
- // Given the position in the sequence of pagination links [i], figure out what page number corresponds to that position.
9688
- calculatePageNumber(i, currentPage, paginationRange, totalPages) {
9689
- let halfWay = Math.ceil(paginationRange / 2);
9690
- if (i === paginationRange) {
9691
- return totalPages;
9692
- }
9693
- else if (i === 1) {
9694
- return i;
9695
- }
9696
- else if (paginationRange < totalPages) {
9697
- if (totalPages - halfWay < currentPage) {
9698
- return totalPages - paginationRange + i;
9699
- }
9700
- else if (halfWay < currentPage) {
9701
- return currentPage - halfWay + i;
9702
- }
9703
- else {
9704
- return i;
9705
- }
9706
- }
9707
- else {
9708
- return i;
9709
- }
9710
- }
9711
9727
  }
9712
9728
  PaginationComponent.decorators = [
9713
9729
  { type: Component, args: [{
@@ -9719,11 +9735,12 @@ PaginationComponent.decorators = [
9719
9735
  </div>
9720
9736
 
9721
9737
  <co-pagination-bar
9722
- [pages]="pages"
9738
+ [currentPage]="getCurrentPage()"
9739
+ [totalItems]="totalItems"
9740
+ [itemsPerPage]="itemsPerPage"
9723
9741
  [directionLinks]="directionLinks"
9724
9742
  [previousLabel]="previousLabel"
9725
9743
  [nextLabel]="nextLabel"
9726
- [currentPage]="getCurrentPage()"
9727
9744
  (previousClick)="goToPreviousPage()"
9728
9745
  (nextClick)="goToNextPage()"
9729
9746
  (pageClick)="setCurrentPage($event)"