@colijnit/corecomponents_v12 12.0.44 → 12.0.47
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 +404 -1
- package/bundles/colijnit-corecomponents_v12.umd.js.map +1 -1
- package/colijnit-corecomponents_v12.d.ts +2 -0
- package/colijnit-corecomponents_v12.metadata.json +1 -1
- package/esm2015/colijnit-corecomponents_v12.js +3 -1
- package/esm2015/lib/components/input-date-range-picker/input-date-range-picker.component.js +4 -1
- package/esm2015/lib/components/pagination/paginate.pipe.js +106 -0
- package/esm2015/lib/components/pagination/pagination-instance.js +2 -0
- package/esm2015/lib/components/pagination/pagination.component.js +194 -0
- package/esm2015/lib/components/pagination/pagination.module.js +26 -0
- package/esm2015/lib/components/pagination/pagination.service.js +88 -0
- package/esm2015/public-api.js +3 -1
- package/fesm2015/colijnit-corecomponents_v12.js +406 -1
- package/fesm2015/colijnit-corecomponents_v12.js.map +1 -1
- package/lib/components/co-dialog/style/_material-definition.scss +1 -1
- package/lib/components/input-date-range-picker/input-date-range-picker.component.d.ts +1 -0
- package/lib/components/pagination/paginate.pipe.d.ts +18 -0
- package/lib/components/pagination/pagination-instance.d.ts +14 -0
- package/lib/components/pagination/pagination.component.d.ts +46 -0
- package/lib/components/pagination/pagination.module.d.ts +2 -0
- package/lib/components/pagination/pagination.service.d.ts +24 -0
- package/lib/components/pagination/style/_layout.scss +87 -0
- package/lib/components/pagination/style/_material-definition.scss +6 -0
- package/lib/components/pagination/style/_theme.scss +5 -0
- package/lib/components/pagination/style/material.scss +5 -0
- package/package.json +1 -1
- package/public-api.d.ts +2 -0
|
@@ -10,6 +10,8 @@ export { BaseGridComponent as ɵq } from './lib/components/grid/base/base-grid.c
|
|
|
10
10
|
export { BaseInlineEditGridComponent as ɵo } from './lib/components/grid/base/base-inline-edit-grid.component';
|
|
11
11
|
export { BaseSelectionGridComponent as ɵn } from './lib/components/grid/base/base-selection-grid.component';
|
|
12
12
|
export { BaseToolbarGridComponent as ɵp } from './lib/components/grid/base/base-toolbar-grid.component';
|
|
13
|
+
export { PaginatePipe as ɵbg } from './lib/components/pagination/paginate.pipe';
|
|
14
|
+
export { PaginationService as ɵbf } from './lib/components/pagination/pagination.service';
|
|
13
15
|
export { PopupShowerService as ɵx } from './lib/components/popup/service/popup-shower.service';
|
|
14
16
|
export { BaseSimpleGridComponent as ɵy } from './lib/components/simple-grid/base-simple-grid.component';
|
|
15
17
|
export { SimpleGridCellComponent as ɵba } from './lib/components/simple-grid/simple-grid-cell.component';
|
|
@@ -32,4 +34,4 @@ export { AppendPipe as ɵs } from './lib/pipes/append.pipe';
|
|
|
32
34
|
export { AppendPipeModule as ɵr } from './lib/pipes/append.pipe.module';
|
|
33
35
|
export { PrependPipe as ɵbc } from './lib/pipes/prepend.pipe';
|
|
34
36
|
export { PrependPipeModule as ɵbb } from './lib/pipes/prepend.pipe.module';
|
|
35
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
37
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29saWpuaXQtY29yZWNvbXBvbmVudHNfdjEyLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vcHJvamVjdHMvY29yZWNvbXBvbmVudHMvc3JjL2NvbGlqbml0LWNvcmVjb21wb25lbnRzX3YxMi50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7R0FFRztBQUVILGNBQWMsY0FBYyxDQUFDO0FBRTdCLE9BQU8sRUFBQyxrQkFBa0IsSUFBSSxFQUFFLEVBQUMsTUFBTSw0Q0FBNEMsQ0FBQztBQUNwRixPQUFPLEVBQUMsVUFBVSxJQUFJLEVBQUUsRUFBQyxNQUFNLG1DQUFtQyxDQUFDO0FBQ25FLE9BQU8sRUFBQyxzQkFBc0IsSUFBSSxFQUFFLEVBQUMsTUFBTSwrREFBK0QsQ0FBQztBQUMzRyxPQUFPLEVBQUMsbUJBQW1CLElBQUksRUFBRSxFQUFDLE1BQU0sNERBQTRELENBQUM7QUFDckcsT0FBTyxFQUFDLGlCQUFpQixJQUFJLEVBQUUsRUFBQyxNQUFNLGdEQUFnRCxDQUFDO0FBQ3ZGLE9BQU8sRUFBQywyQkFBMkIsSUFBSSxFQUFFLEVBQUMsTUFBTSw0REFBNEQsQ0FBQztBQUM3RyxPQUFPLEVBQUMsMEJBQTBCLElBQUksRUFBRSxFQUFDLE1BQU0sMERBQTBELENBQUM7QUFDMUcsT0FBTyxFQUFDLHdCQUF3QixJQUFJLEVBQUUsRUFBQyxNQUFNLHdEQUF3RCxDQUFDO0FBQ3RHLE9BQU8sRUFBQyxZQUFZLElBQUksR0FBRyxFQUFDLE1BQU0sMkNBQTJDLENBQUM7QUFDOUUsT0FBTyxFQUFDLGlCQUFpQixJQUFJLEdBQUcsRUFBQyxNQUFNLGdEQUFnRCxDQUFDO0FBQ3hGLE9BQU8sRUFBQyxrQkFBa0IsSUFBSSxFQUFFLEVBQUMsTUFBTSxxREFBcUQsQ0FBQztBQUM3RixPQUFPLEVBQUMsdUJBQXVCLElBQUksRUFBRSxFQUFDLE1BQU0seURBQXlELENBQUM7QUFDdEcsT0FBTyxFQUFDLHVCQUF1QixJQUFJLEdBQUcsRUFBQyxNQUFNLHlEQUF5RCxDQUFDO0FBQ3ZHLE9BQU8sRUFBQyx3QkFBd0IsSUFBSSxFQUFFLEVBQUMsTUFBTSw4REFBOEQsQ0FBQztBQUM1RyxPQUFPLEVBQUMscUJBQXFCLElBQUksRUFBRSxFQUFDLE1BQU0sMkRBQTJELENBQUM7QUFDdEcsT0FBTyxFQUFDLFlBQVksSUFBSSxFQUFFLEVBQUMsTUFBTSw4Q0FBOEMsQ0FBQztBQUNoRixPQUFPLEVBQUMsdUNBQXVDLElBQUksRUFBRSxFQUFDLE1BQU0sNERBQTRELENBQUM7QUFDekgsT0FBTyxFQUFDLG9CQUFvQixJQUFJLEVBQUUsRUFBQyxNQUFNLDRDQUE0QyxDQUFDO0FBQ3RGLE9BQU8sRUFBQyx5QkFBeUIsSUFBSSxHQUFHLEVBQUMsTUFBTSw0REFBNEQsQ0FBQztBQUM1RyxPQUFPLEVBQUMscUJBQXFCLElBQUksR0FBRyxFQUFDLE1BQU0sdURBQXVELENBQUM7QUFDbkcsT0FBTyxFQUFDLDBCQUEwQixJQUFJLEVBQUUsRUFBQyxNQUFNLGtFQUFrRSxDQUFDO0FBQ2xILE9BQU8sRUFBQyxpQkFBaUIsSUFBSSxFQUFFLEVBQUMsd0JBQXdCLElBQUksRUFBRSxFQUFDLE1BQU0sMENBQTBDLENBQUM7QUFDaEgsT0FBTyxFQUFDLFlBQVksSUFBSSxFQUFFLEVBQUMsTUFBTSx1Q0FBdUMsQ0FBQztBQUN6RSxPQUFPLEVBQUMseUJBQXlCLElBQUksRUFBRSxFQUFDLE1BQU0sbURBQW1ELENBQUM7QUFDbEcsT0FBTyxFQUFDLHFCQUFxQixJQUFJLEVBQUUsRUFBQyxNQUFNLDhDQUE4QyxDQUFDO0FBQ3pGLE9BQU8sRUFBQyxzQkFBc0IsSUFBSSxFQUFFLEVBQUMsTUFBTSxnREFBZ0QsQ0FBQztBQUM1RixPQUFPLEVBQUMsa0JBQWtCLElBQUksRUFBRSxFQUFDLE1BQU0saURBQWlELENBQUM7QUFDekYsT0FBTyxFQUFDLGVBQWUsSUFBSSxFQUFFLEVBQUMsTUFBTSw4Q0FBOEMsQ0FBQztBQUNuRixPQUFPLEVBQUMsVUFBVSxJQUFJLEVBQUUsRUFBQyxNQUFNLHlCQUF5QixDQUFDO0FBQ3pELE9BQU8sRUFBQyxnQkFBZ0IsSUFBSSxFQUFFLEVBQUMsTUFBTSxnQ0FBZ0MsQ0FBQztBQUN0RSxPQUFPLEVBQUMsV0FBVyxJQUFJLEdBQUcsRUFBQyxNQUFNLDBCQUEwQixDQUFDO0FBQzVELE9BQU8sRUFBQyxpQkFBaUIsSUFBSSxHQUFHLEVBQUMsTUFBTSxpQ0FBaUMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogR2VuZXJhdGVkIGJ1bmRsZSBpbmRleC4gRG8gbm90IGVkaXQuXG4gKi9cblxuZXhwb3J0ICogZnJvbSAnLi9wdWJsaWMtYXBpJztcblxuZXhwb3J0IHtCYXNlSW5wdXRDb21wb25lbnQgYXMgybVtfSBmcm9tICcuL2xpYi9jb21wb25lbnRzL2Jhc2UvYmFzZS1pbnB1dC5jb21wb25lbnQnO1xuZXhwb3J0IHtCYXNlTW9kdWxlIGFzIMm1an0gZnJvbSAnLi9saWIvY29tcG9uZW50cy9iYXNlL2Jhc2UubW9kdWxlJztcbmV4cG9ydCB7Q29tbWl0QnV0dG9uc0NvbXBvbmVudCBhcyDJtXd9IGZyb20gJy4vbGliL2NvbXBvbmVudHMvYmFzZS9jb21taXQtYnV0dG9ucy9jb21taXQtYnV0dG9ucy5jb21wb25lbnQnO1xuZXhwb3J0IHtDb21taXRCdXR0b25zTW9kdWxlIGFzIMm1dn0gZnJvbSAnLi9saWIvY29tcG9uZW50cy9iYXNlL2NvbW1pdC1idXR0b25zL2NvbW1pdC1idXR0b25zLm1vZHVsZSc7XG5leHBvcnQge0Jhc2VHcmlkQ29tcG9uZW50IGFzIMm1cX0gZnJvbSAnLi9saWIvY29tcG9uZW50cy9ncmlkL2Jhc2UvYmFzZS1ncmlkLmNvbXBvbmVudCc7XG5leHBvcnQge0Jhc2VJbmxpbmVFZGl0R3JpZENvbXBvbmVudCBhcyDJtW99IGZyb20gJy4vbGliL2NvbXBvbmVudHMvZ3JpZC9iYXNlL2Jhc2UtaW5saW5lLWVkaXQtZ3JpZC5jb21wb25lbnQnO1xuZXhwb3J0IHtCYXNlU2VsZWN0aW9uR3JpZENvbXBvbmVudCBhcyDJtW59IGZyb20gJy4vbGliL2NvbXBvbmVudHMvZ3JpZC9iYXNlL2Jhc2Utc2VsZWN0aW9uLWdyaWQuY29tcG9uZW50JztcbmV4cG9ydCB7QmFzZVRvb2xiYXJHcmlkQ29tcG9uZW50IGFzIMm1cH0gZnJvbSAnLi9saWIvY29tcG9uZW50cy9ncmlkL2Jhc2UvYmFzZS10b29sYmFyLWdyaWQuY29tcG9uZW50JztcbmV4cG9ydCB7UGFnaW5hdGVQaXBlIGFzIMm1Ymd9IGZyb20gJy4vbGliL2NvbXBvbmVudHMvcGFnaW5hdGlvbi9wYWdpbmF0ZS5waXBlJztcbmV4cG9ydCB7UGFnaW5hdGlvblNlcnZpY2UgYXMgybViZn0gZnJvbSAnLi9saWIvY29tcG9uZW50cy9wYWdpbmF0aW9uL3BhZ2luYXRpb24uc2VydmljZSc7XG5leHBvcnQge1BvcHVwU2hvd2VyU2VydmljZSBhcyDJtXh9IGZyb20gJy4vbGliL2NvbXBvbmVudHMvcG9wdXAvc2VydmljZS9wb3B1cC1zaG93ZXIuc2VydmljZSc7XG5leHBvcnQge0Jhc2VTaW1wbGVHcmlkQ29tcG9uZW50IGFzIMm1eX0gZnJvbSAnLi9saWIvY29tcG9uZW50cy9zaW1wbGUtZ3JpZC9iYXNlLXNpbXBsZS1ncmlkLmNvbXBvbmVudCc7XG5leHBvcnQge1NpbXBsZUdyaWRDZWxsQ29tcG9uZW50IGFzIMm1YmF9IGZyb20gJy4vbGliL2NvbXBvbmVudHMvc2ltcGxlLWdyaWQvc2ltcGxlLWdyaWQtY2VsbC5jb21wb25lbnQnO1xuZXhwb3J0IHtWYWxpZGF0aW9uRXJyb3JDb21wb25lbnQgYXMgybV1fSBmcm9tICcuL2xpYi9jb21wb25lbnRzL3ZhbGlkYXRpb24tZXJyb3IvdmFsaWRhdGlvbi1lcnJvci5jb21wb25lbnQnO1xuZXhwb3J0IHtWYWxpZGF0aW9uRXJyb3JNb2R1bGUgYXMgybV0fSBmcm9tICcuL2xpYi9jb21wb25lbnRzL3ZhbGlkYXRpb24tZXJyb3IvdmFsaWRhdGlvbi1lcnJvci5tb2R1bGUnO1xuZXhwb3J0IHtJbnB1dEJvb2xlYW4gYXMgybVpfSBmcm9tICcuL2xpYi9jb3JlL2RlY29yYXRvci9pbnB1dC1ib29sZWFuLmRlY29yYXRvcic7XG5leHBvcnQge0Zvcm1JbnB1dFVzZXJNb2RlbENoYW5nZUxpc3RlbmVyU2VydmljZSBhcyDJtWt9IGZyb20gJy4vbGliL2NvcmUvc2VydmljZS9mb3JtLWlucHV0LXVzZXItY2hhbmdlLWxpc3RlbmVyLnNlcnZpY2UnO1xuZXhwb3J0IHtOZ1pvbmVXcmFwcGVyU2VydmljZSBhcyDJtWx9IGZyb20gJy4vbGliL2NvcmUvc2VydmljZS9uZy16b25lLXdyYXBwZXIuc2VydmljZSc7XG5leHBvcnQge0NsaWNrT3V0c2lkZU1hc3RlclNlcnZpY2UgYXMgybViZX0gZnJvbSAnLi9saWIvZGlyZWN0aXZlcy9jbGlja291dHNpZGUvY2xpY2stb3V0c2lkZS1tYXN0ZXIuc2VydmljZSc7XG5leHBvcnQge0NsaWNrT3V0c2lkZURpcmVjdGl2ZSBhcyDJtWJkfSBmcm9tICcuL2xpYi9kaXJlY3RpdmVzL2NsaWNrb3V0c2lkZS9jbGljay1vdXRzaWRlLmRpcmVjdGl2ZSc7XG5leHBvcnQge09ic2VydmVWaXNpYmlsaXR5RGlyZWN0aXZlIGFzIMm1en0gZnJvbSAnLi9saWIvZGlyZWN0aXZlcy9vYnNlcnZlLXZpc2liaWxpdHkvb2JzZXJ2ZS12aXNpYmlsaXR5LmRpcmVjdGl2ZSc7XG5leHBvcnQge0NvUmlwcGxlRGlyZWN0aXZlIGFzIMm1YyxNRF9SSVBQTEVfR0xPQkFMX09QVElPTlMgYXMgybVifSBmcm9tICcuL2xpYi9kaXJlY3RpdmVzL3JpcHBsZS9yaXBwbGUuZGlyZWN0aXZlJztcbmV4cG9ydCB7UmlwcGxlTW9kdWxlIGFzIMm1YX0gZnJvbSAnLi9saWIvZGlyZWN0aXZlcy9yaXBwbGUvcmlwcGxlLm1vZHVsZSc7XG5leHBvcnQge0NvU2Nyb2xsRGlzcGF0Y2hlclNlcnZpY2UgYXMgybVlfSBmcm9tICcuL2xpYi9kaXJlY3RpdmVzL3JpcHBsZS9zY3JvbGwtZGlzcGF0Y2hlci5zZXJ2aWNlJztcbmV4cG9ydCB7Q29TY3JvbGxhYmxlRGlyZWN0aXZlIGFzIMm1Zn0gZnJvbSAnLi9saWIvZGlyZWN0aXZlcy9yaXBwbGUvc2Nyb2xsYWJsZS5kaXJlY3RpdmUnO1xuZXhwb3J0IHtDb1ZpZXdwb3J0UnVsZXJTZXJ2aWNlIGFzIMm1ZH0gZnJvbSAnLi9saWIvZGlyZWN0aXZlcy9yaXBwbGUvdmlld3BvcnQtcnVsZXIuc2VydmljZSc7XG5leHBvcnQge1N0b3BDbGlja0RpcmVjdGl2ZSBhcyDJtWh9IGZyb20gJy4vbGliL2RpcmVjdGl2ZXMvc3RvcGNsaWNrL3N0b3AtY2xpY2suZGlyZWN0aXZlJztcbmV4cG9ydCB7U3RvcENsaWNrTW9kdWxlIGFzIMm1Z30gZnJvbSAnLi9saWIvZGlyZWN0aXZlcy9zdG9wY2xpY2svc3RvcC1jbGljay5tb2R1bGUnO1xuZXhwb3J0IHtBcHBlbmRQaXBlIGFzIMm1c30gZnJvbSAnLi9saWIvcGlwZXMvYXBwZW5kLnBpcGUnO1xuZXhwb3J0IHtBcHBlbmRQaXBlTW9kdWxlIGFzIMm1cn0gZnJvbSAnLi9saWIvcGlwZXMvYXBwZW5kLnBpcGUubW9kdWxlJztcbmV4cG9ydCB7UHJlcGVuZFBpcGUgYXMgybViY30gZnJvbSAnLi9saWIvcGlwZXMvcHJlcGVuZC5waXBlJztcbmV4cG9ydCB7UHJlcGVuZFBpcGVNb2R1bGUgYXMgybViYn0gZnJvbSAnLi9saWIvcGlwZXMvcHJlcGVuZC5waXBlLm1vZHVsZSc7Il19
|
|
@@ -10,6 +10,7 @@ export class InputDateRangePickerComponent extends BaseInputComponent {
|
|
|
10
10
|
this.dateRangeChange = new EventEmitter();
|
|
11
11
|
this.close = new EventEmitter();
|
|
12
12
|
this.select = new EventEmitter();
|
|
13
|
+
this.cleared = new EventEmitter();
|
|
13
14
|
}
|
|
14
15
|
showClass() {
|
|
15
16
|
return true;
|
|
@@ -33,6 +34,7 @@ InputDateRangePickerComponent.decorators = [
|
|
|
33
34
|
(ngModelChange)="rangeChange()"
|
|
34
35
|
(close)="close.next($event)"
|
|
35
36
|
(select)="select.next($event)"
|
|
37
|
+
(cleared)="cleared.next($event)"
|
|
36
38
|
[(startDate)]="startDate"
|
|
37
39
|
[(endDate)]="endDate"
|
|
38
40
|
></ejs-daterangepicker>
|
|
@@ -52,6 +54,7 @@ InputDateRangePickerComponent.propDecorators = {
|
|
|
52
54
|
dateRangeChange: [{ type: Output }],
|
|
53
55
|
close: [{ type: Output }],
|
|
54
56
|
select: [{ type: Output }],
|
|
57
|
+
cleared: [{ type: Output }],
|
|
55
58
|
showClass: [{ type: HostBinding, args: ["class.co-input-date-range-picker",] }]
|
|
56
59
|
};
|
|
57
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
60
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5wdXQtZGF0ZS1yYW5nZS1waWNrZXIuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvY29yZWNvbXBvbmVudHMvc3JjL2xpYi9jb21wb25lbnRzL2lucHV0LWRhdGUtcmFuZ2UtcGlja2VyL2lucHV0LWRhdGUtcmFuZ2UtcGlja2VyLmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUMsU0FBUyxFQUFFLFlBQVksRUFBRSxXQUFXLEVBQUUsS0FBSyxFQUFFLE1BQU0sRUFBRSxpQkFBaUIsRUFBQyxNQUFNLGVBQWUsQ0FBQztBQUNyRyxPQUFPLEVBQUMsa0JBQWtCLEVBQUMsTUFBTSw4QkFBOEIsQ0FBQztBQXFCaEUsTUFBTSxPQUFPLDZCQUE4QixTQUFRLGtCQUF3QjtJQW5CM0U7O1FBc0JTLGVBQVUsR0FBVyxZQUFZLENBQUM7UUFHbEMsZ0JBQVcsR0FBVyxFQUFFLENBQUM7UUFTekIsb0JBQWUsR0FBdUIsSUFBSSxZQUFZLEVBQVEsQ0FBQztRQUcvRCxrQkFBYSxHQUF1QixJQUFJLFlBQVksRUFBUSxDQUFDO1FBRzdELG9CQUFlLEdBQXlCLElBQUksWUFBWSxFQUFVLENBQUM7UUFHbkUsVUFBSyxHQUFxQixJQUFJLFlBQVksRUFBTSxDQUFDO1FBR2pELFdBQU0sR0FBcUIsSUFBSSxZQUFZLEVBQU0sQ0FBQztRQUdsRCxZQUFPLEdBQXFCLElBQUksWUFBWSxFQUFNLENBQUM7SUFlNUQsQ0FBQztJQVpRLFNBQVM7UUFDZCxPQUFPLElBQUksQ0FBQztJQUNkLENBQUM7SUFFTSxXQUFXO1FBQ2hCLElBQUksQ0FBQyxlQUFlLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxTQUFTLENBQUMsQ0FBQztRQUMxQyxJQUFJLENBQUMsYUFBYSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsT0FBTyxDQUFDLENBQUM7UUFFdEMsSUFBSSxJQUFJLENBQUMsU0FBUyxJQUFJLElBQUksQ0FBQyxPQUFPLEVBQUU7WUFDbEMsSUFBSSxDQUFDLGVBQWUsQ0FBQyxJQUFJLENBQUMsQ0FBQyxJQUFJLENBQUMsU0FBUyxFQUFFLElBQUksQ0FBQyxPQUFPLENBQUMsQ0FBQyxDQUFDO1NBQzNEO0lBQ0gsQ0FBQzs7O1lBL0RGLFNBQVMsU0FBQztnQkFDVCxRQUFRLEVBQUUscUJBQXFCO2dCQUMvQixRQUFRLEVBQUU7Ozs7Ozs7Ozs7Ozs7O0dBY1Q7Z0JBQ0QsYUFBYSxFQUFFLGlCQUFpQixDQUFDLElBQUk7YUFDdEM7Ozt5QkFHRSxLQUFLOzBCQUdMLEtBQUs7d0JBR0wsS0FBSztzQkFHTCxLQUFLOzhCQUdMLE1BQU07NEJBR04sTUFBTTs4QkFHTixNQUFNO29CQUdOLE1BQU07cUJBR04sTUFBTTtzQkFHTixNQUFNO3dCQUdOLFdBQVcsU0FBQyxrQ0FBa0MiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge0NvbXBvbmVudCwgRXZlbnRFbWl0dGVyLCBIb3N0QmluZGluZywgSW5wdXQsIE91dHB1dCwgVmlld0VuY2Fwc3VsYXRpb259IGZyb20gXCJAYW5ndWxhci9jb3JlXCI7XHJcbmltcG9ydCB7QmFzZUlucHV0Q29tcG9uZW50fSBmcm9tIFwiLi4vYmFzZS9iYXNlLWlucHV0LmNvbXBvbmVudFwiO1xyXG5cclxuQENvbXBvbmVudCh7XHJcbiAgc2VsZWN0b3I6IFwiY28taW5wdXQtZGF0ZS1yYW5nZVwiLFxyXG4gIHRlbXBsYXRlOiBgXHJcbiAgICA8ZWpzLWRhdGVyYW5nZXBpY2tlclxyXG4gICAgICBbZm9ybWF0XT1cImRhdGVGb3JtYXRcIlxyXG4gICAgICBbcGxhY2Vob2xkZXJdPVwicGxhY2Vob2xkZXJcIlxyXG4gICAgICBbbmdNb2RlbF09XCJtb2RlbFwiXHJcbiAgICAgIChuZ01vZGVsQ2hhbmdlKT1cInJhbmdlQ2hhbmdlKClcIlxyXG4gICAgICAoY2xvc2UpPVwiY2xvc2UubmV4dCgkZXZlbnQpXCJcclxuICAgICAgKHNlbGVjdCk9XCJzZWxlY3QubmV4dCgkZXZlbnQpXCJcclxuICAgICAgKGNsZWFyZWQpPVwiY2xlYXJlZC5uZXh0KCRldmVudClcIlxyXG4gICAgICBbKHN0YXJ0RGF0ZSldPVwic3RhcnREYXRlXCJcclxuICAgICAgWyhlbmREYXRlKV09XCJlbmREYXRlXCJcclxuICAgID48L2Vqcy1kYXRlcmFuZ2VwaWNrZXI+XHJcbiAgICA8ZGl2IGNsYXNzPVwicmVxdWlyZWQtaW5kaWNhdG9yXCI+PC9kaXY+XHJcbiAgICA8bmctdGVtcGxhdGUgI3ZhbGlkYXRpb25FcnJvcj48L25nLXRlbXBsYXRlPlxyXG4gIGAsXHJcbiAgZW5jYXBzdWxhdGlvbjogVmlld0VuY2Fwc3VsYXRpb24uTm9uZVxyXG59KVxyXG5leHBvcnQgY2xhc3MgSW5wdXREYXRlUmFuZ2VQaWNrZXJDb21wb25lbnQgZXh0ZW5kcyBCYXNlSW5wdXRDb21wb25lbnQ8RGF0ZT4ge1xyXG5cclxuICBASW5wdXQoKVxyXG4gIHB1YmxpYyBkYXRlRm9ybWF0OiBzdHJpbmcgPSBcImRkLU1NLXl5eXlcIjtcclxuXHJcbiAgQElucHV0KClcclxuICBwdWJsaWMgcGxhY2Vob2xkZXI6IHN0cmluZyA9IFwiXCI7XHJcblxyXG4gIEBJbnB1dCgpXHJcbiAgcHVibGljIHN0YXJ0RGF0ZTogRGF0ZTtcclxuXHJcbiAgQElucHV0KClcclxuICBwdWJsaWMgZW5kRGF0ZTogRGF0ZTtcclxuXHJcbiAgQE91dHB1dCgpXHJcbiAgcHVibGljIHN0YXJ0RGF0ZUNoYW5nZTogRXZlbnRFbWl0dGVyPERhdGU+ID0gbmV3IEV2ZW50RW1pdHRlcjxEYXRlPigpO1xyXG5cclxuICBAT3V0cHV0KClcclxuICBwdWJsaWMgZW5kRGF0ZUNoYW5nZTogRXZlbnRFbWl0dGVyPERhdGU+ID0gbmV3IEV2ZW50RW1pdHRlcjxEYXRlPigpO1xyXG5cclxuICBAT3V0cHV0KClcclxuICBwdWJsaWMgZGF0ZVJhbmdlQ2hhbmdlOiBFdmVudEVtaXR0ZXI8RGF0ZVtdPiA9IG5ldyBFdmVudEVtaXR0ZXI8RGF0ZVtdPigpO1xyXG5cclxuICBAT3V0cHV0KClcclxuICBwdWJsaWMgY2xvc2U6IEV2ZW50RW1pdHRlcjx7fT4gPSBuZXcgRXZlbnRFbWl0dGVyPHt9PigpO1xyXG5cclxuICBAT3V0cHV0KClcclxuICBwdWJsaWMgc2VsZWN0OiBFdmVudEVtaXR0ZXI8e30+ID0gbmV3IEV2ZW50RW1pdHRlcjx7fT4oKTtcclxuXHJcbiAgQE91dHB1dCgpXHJcbiAgcHVibGljIGNsZWFyZWQ6IEV2ZW50RW1pdHRlcjx7fT4gPSBuZXcgRXZlbnRFbWl0dGVyPHt9PigpO1xyXG5cclxuICBASG9zdEJpbmRpbmcoXCJjbGFzcy5jby1pbnB1dC1kYXRlLXJhbmdlLXBpY2tlclwiKVxyXG4gIHB1YmxpYyBzaG93Q2xhc3MoKTogYm9vbGVhbiB7XHJcbiAgICByZXR1cm4gdHJ1ZTtcclxuICB9XHJcblxyXG4gIHB1YmxpYyByYW5nZUNoYW5nZSgpOiB2b2lkIHtcclxuICAgIHRoaXMuc3RhcnREYXRlQ2hhbmdlLmVtaXQodGhpcy5zdGFydERhdGUpO1xyXG4gICAgdGhpcy5lbmREYXRlQ2hhbmdlLmVtaXQodGhpcy5lbmREYXRlKTtcclxuXHJcbiAgICBpZiAodGhpcy5zdGFydERhdGUgJiYgdGhpcy5lbmREYXRlKSB7XHJcbiAgICAgIHRoaXMuZGF0ZVJhbmdlQ2hhbmdlLmVtaXQoW3RoaXMuc3RhcnREYXRlLCB0aGlzLmVuZERhdGVdKTtcclxuICAgIH1cclxuICB9XHJcbn1cclxuIl19
|
|
@@ -0,0 +1,106 @@
|
|
|
1
|
+
import { Pipe } from "@angular/core";
|
|
2
|
+
import { PaginationService } from "./pagination.service";
|
|
3
|
+
const LARGE_NUMBER = 999999999;
|
|
4
|
+
export class PaginatePipe {
|
|
5
|
+
constructor(paginateService) {
|
|
6
|
+
this.paginateService = paginateService;
|
|
7
|
+
// store the values from the last time the pipe
|
|
8
|
+
this.state = {};
|
|
9
|
+
}
|
|
10
|
+
transform(collection, args) {
|
|
11
|
+
// When an observable is passed through the AsyncPipe, it will output
|
|
12
|
+
// `null` until the subscription resolves. In this case, we want to
|
|
13
|
+
// use the cached data from the `state` object to prevent the NgFor
|
|
14
|
+
// from flashing empty until the real values arrive.
|
|
15
|
+
if (!(collection instanceof Array)) {
|
|
16
|
+
let _id = args.id || this.paginateService.DEFAULT_ID;
|
|
17
|
+
if (this.state[_id]) {
|
|
18
|
+
return this.state[_id].slice;
|
|
19
|
+
}
|
|
20
|
+
else {
|
|
21
|
+
return collection;
|
|
22
|
+
}
|
|
23
|
+
}
|
|
24
|
+
let serverSideMode = args.totalItems !== undefined;
|
|
25
|
+
let instance = this._createInstance(collection, args);
|
|
26
|
+
let id = instance.id;
|
|
27
|
+
let start;
|
|
28
|
+
let end;
|
|
29
|
+
let perPage = instance.itemsPerPage;
|
|
30
|
+
this.paginateService.register(instance);
|
|
31
|
+
if (!serverSideMode && collection instanceof Array) {
|
|
32
|
+
perPage = perPage || LARGE_NUMBER;
|
|
33
|
+
start = (instance.currentPage - 1) * perPage;
|
|
34
|
+
end = start + perPage;
|
|
35
|
+
let isIdentical = this._stateIsIdentical(id, collection, start, end);
|
|
36
|
+
if (isIdentical) {
|
|
37
|
+
return this.state[id].slice;
|
|
38
|
+
}
|
|
39
|
+
else {
|
|
40
|
+
let slice = collection.slice(start, end);
|
|
41
|
+
this._saveState(id, collection, slice, start, end);
|
|
42
|
+
this.paginateService.change.next(id);
|
|
43
|
+
return slice;
|
|
44
|
+
}
|
|
45
|
+
}
|
|
46
|
+
// save the state for server-side collection to avoid null
|
|
47
|
+
// flash as new data loads.
|
|
48
|
+
this._saveState(id, collection, collection, start, end);
|
|
49
|
+
return collection;
|
|
50
|
+
}
|
|
51
|
+
// Create an IPaginationInstance object, using defaults for any optional properties not supplied.
|
|
52
|
+
_createInstance(collection, args) {
|
|
53
|
+
let config = args;
|
|
54
|
+
this._checkConfig(config);
|
|
55
|
+
return {
|
|
56
|
+
id: config.id || this.paginateService.DEFAULT_ID,
|
|
57
|
+
itemsPerPage: config.itemsPerPage || 0,
|
|
58
|
+
currentPage: config.currentPage || 1,
|
|
59
|
+
totalItems: config.totalItems || collection.length
|
|
60
|
+
};
|
|
61
|
+
}
|
|
62
|
+
// Ensure the argument passed to the filter contains the required properties.
|
|
63
|
+
_checkConfig(config) {
|
|
64
|
+
const required = ["itemsPerPage", "currentPage"];
|
|
65
|
+
const missing = required.filter((prop) => !config.hasOwnProperty(prop));
|
|
66
|
+
if (0 < missing.length) {
|
|
67
|
+
throw new Error(`PaginatePipe: Argument is missing the following required properties: ${missing.join(", ")}`);
|
|
68
|
+
}
|
|
69
|
+
}
|
|
70
|
+
/**
|
|
71
|
+
* To avoid returning a brand new array each time the pipe is run, we store the state of the sliced
|
|
72
|
+
* array for a given id. This means that the next time the pipe is run on this collection & id, we just
|
|
73
|
+
* need to check that the collection, start and end points are all identical, and if so, return the
|
|
74
|
+
* last sliced array.
|
|
75
|
+
*/
|
|
76
|
+
_saveState(id, collection, slice, start, end) {
|
|
77
|
+
this.state[id] = {
|
|
78
|
+
collection,
|
|
79
|
+
size: collection.length,
|
|
80
|
+
slice,
|
|
81
|
+
start,
|
|
82
|
+
end
|
|
83
|
+
};
|
|
84
|
+
}
|
|
85
|
+
// For a given id, returns true if the collection, size, start and end values are identical.
|
|
86
|
+
_stateIsIdentical(id, collection, start, end) {
|
|
87
|
+
let state = this.state[id];
|
|
88
|
+
if (!state) {
|
|
89
|
+
return false;
|
|
90
|
+
}
|
|
91
|
+
return state.collection === collection &&
|
|
92
|
+
state.size === collection.length &&
|
|
93
|
+
state.start === start &&
|
|
94
|
+
state.end === end;
|
|
95
|
+
}
|
|
96
|
+
}
|
|
97
|
+
PaginatePipe.decorators = [
|
|
98
|
+
{ type: Pipe, args: [{
|
|
99
|
+
name: 'paginate',
|
|
100
|
+
pure: false
|
|
101
|
+
},] }
|
|
102
|
+
];
|
|
103
|
+
PaginatePipe.ctorParameters = () => [
|
|
104
|
+
{ type: PaginationService }
|
|
105
|
+
];
|
|
106
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"paginate.pipe.js","sourceRoot":"","sources":["../../../../../../projects/corecomponents/src/lib/components/pagination/paginate.pipe.ts"],"names":[],"mappings":"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","sourcesContent":["import {Pipe, PipeTransform} from \"@angular/core\";\r\n\r\nimport {PaginationService} from \"./pagination.service\";\r\nimport {IPaginationInstance} from \"./pagination-instance\";\r\n\r\nconst LARGE_NUMBER: number = 999999999;\r\n\r\ninterface IPipeState {\r\n    collection: any[];\r\n    size: number;\r\n    start: number;\r\n    end: number;\r\n    slice: any[];\r\n}\r\n\r\n@Pipe({\r\n    name: 'paginate',\r\n    pure: false\r\n})\r\nexport class PaginatePipe implements PipeTransform {\r\n\r\n    // store the values from the last time the pipe\r\n    private state: { [id: string]: IPipeState } = {};\r\n\r\n    constructor(private paginateService: PaginationService) {\r\n    }\r\n\r\n    public transform(collection: any[], args: any): any {\r\n        // When an observable is passed through the AsyncPipe, it will output\r\n        // `null` until the subscription resolves. In this case, we want to\r\n        // use the cached data from the `state` object to prevent the NgFor\r\n        // from flashing empty until the real values arrive.\r\n        if (!(collection instanceof Array)) {\r\n            let _id: any = args.id || this.paginateService.DEFAULT_ID;\r\n            if (this.state[_id]) {\r\n                return this.state[_id].slice;\r\n            } else {\r\n                return collection;\r\n            }\r\n        }\r\n\r\n        let serverSideMode: boolean = args.totalItems !== undefined;\r\n        let instance: IPaginationInstance = this._createInstance(collection, args);\r\n        let id: string = instance.id;\r\n        let start: number;\r\n        let end: number;\r\n        let perPage: number = instance.itemsPerPage;\r\n\r\n        this.paginateService.register(instance);\r\n\r\n        if (!serverSideMode && collection instanceof Array) {\r\n            perPage = perPage || LARGE_NUMBER;\r\n            start = (instance.currentPage - 1) * perPage;\r\n            end = start + perPage;\r\n\r\n            let isIdentical: boolean = this._stateIsIdentical(id, collection, start, end);\r\n            if (isIdentical) {\r\n                return this.state[id].slice;\r\n            } else {\r\n                let slice: any[] = collection.slice(start, end);\r\n                this._saveState(id, collection, slice, start, end);\r\n                this.paginateService.change.next(id);\r\n                return slice;\r\n            }\r\n        }\r\n\r\n        // save the state for server-side collection to avoid null\r\n        // flash as new data loads.\r\n        this._saveState(id, collection, collection, start, end);\r\n        return collection;\r\n    }\r\n\r\n    // Create an IPaginationInstance object, using defaults for any optional properties not supplied.\r\n    private _createInstance(collection: any[], args: any): IPaginationInstance {\r\n        let config: any = args;\r\n        this._checkConfig(config);\r\n\r\n        return {\r\n            id: config.id || this.paginateService.DEFAULT_ID,\r\n            itemsPerPage: config.itemsPerPage || 0,\r\n            currentPage: config.currentPage || 1,\r\n            totalItems: config.totalItems || collection.length\r\n        };\r\n    }\r\n\r\n    // Ensure the argument passed to the filter contains the required properties.\r\n    private _checkConfig(config: any): void {\r\n        const required: String[] = [\"itemsPerPage\", \"currentPage\"];\r\n        const missing: String[] = required.filter((prop: any) => !config.hasOwnProperty(prop));\r\n        if (0 < missing.length) {\r\n            throw new Error(`PaginatePipe: Argument is missing the following required properties: ${missing.join(\", \")}`);\r\n        }\r\n    }\r\n\r\n    /**\r\n     * To avoid returning a brand new array each time the pipe is run, we store the state of the sliced\r\n     * array for a given id. This means that the next time the pipe is run on this collection & id, we just\r\n     * need to check that the collection, start and end points are all identical, and if so, return the\r\n     * last sliced array.\r\n     */\r\n    private _saveState(id: string, collection: any[], slice: any[], start: number, end: number): void {\r\n        this.state[id] = {\r\n            collection,\r\n            size: collection.length,\r\n            slice,\r\n            start,\r\n            end\r\n        };\r\n    }\r\n\r\n    // For a given id, returns true if the collection, size, start and end values are identical.\r\n    private _stateIsIdentical(id: string, collection: any[], start: number, end: number): boolean {\r\n        let state: any = this.state[id];\r\n        if (!state) {\r\n            return false;\r\n        }\r\n        return state.collection === collection &&\r\n            state.size === collection.length &&\r\n            state.start === start &&\r\n            state.end === end;\r\n    }\r\n}"]}
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
export {};
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGFnaW5hdGlvbi1pbnN0YW5jZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2NvcmVjb21wb25lbnRzL3NyYy9saWIvY29tcG9uZW50cy9wYWdpbmF0aW9uL3BhZ2luYXRpb24taW5zdGFuY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbIi8vIFJlcHJlc2VudHMgYSBwYWdpbmF0aW9uIGluc3RhbmNlOiB0aGUgY29uZmlndXJhdGlvbiBvYmplY3QgZm9yIGEgc2luZ2xlIHBhZ2luYXRpb24gY29tcG9uZW50LlxyXG5leHBvcnQgaW50ZXJmYWNlIElQYWdpbmF0aW9uSW5zdGFuY2Uge1xyXG4gICAgLy8gQW4gb3B0aW9uYWwgSUQgZm9yIHRoZSBwYWdpbmF0aW9uIGluc3RhbmNlLiBPbmx5IHVzZWZ1bCBpZiB5b3Ugd2lzaCB0byBoYXZlIG1vcmUgdGhhbiBvbmNlIGluc3RhbmNlIGF0IGEgdGltZSBpbiBhIGdpdmVuIGNvbXBvbmVudC5cclxuICAgIGlkPzogc3RyaW5nO1xyXG4gICAgLy8gVGhlIG51bWJlciBvZiBpdGVtcyBwZXIgcGFnaW5hdGVkIHBhZ2UuXHJcbiAgICBpdGVtc1BlclBhZ2U6IG51bWJlcjtcclxuICAgIC8vIFRoZSBjdXJyZW50IChhY3RpdmUpIHBhZ2UuXHJcbiAgICBjdXJyZW50UGFnZTogbnVtYmVyO1xyXG4gICAgLyoqXHJcbiAgICAgKiBUaGUgdG90YWwgbnVtYmVyIG9mIGl0ZW1zIGluIHRoZSBjb2xsZWN0aW9uLiBPbmx5IHVzZWZ1bCB3aGVuXHJcbiAgICAgKiBkb2luZyBzZXJ2ZXItc2lkZSBwYWdpbmcsIHdoZXJlIHRoZSBjb2xsZWN0aW9uIHNpemUgaXMgbGltaXRlZFxyXG4gICAgICogdG8gYSBzaW5nbGUgcGFnZSByZXR1cm5lZCBieSB0aGUgc2VydmVyIEFQSS5cclxuICAgICAqXHJcbiAgICAgKiBGb3IgaW4tbWVtb3J5IHBhZ2luZywgdGhpcyBwcm9wZXJ0eSBzaG91bGQgbm90IGJlIHNldCwgYXMgaXRcclxuICAgICAqIHdpbGwgYmUgYXV0b21hdGljYWxseSBzZXQgdG8gdGhlIHZhbHVlIG9mICBjb2xsZWN0aW9uLmxlbmd0aC5cclxuICAgICAqL1xyXG4gICAgdG90YWxJdGVtcz86IG51bWJlcjtcclxufSJdfQ==
|
|
@@ -0,0 +1,194 @@
|
|
|
1
|
+
import { Component, EventEmitter, HostBinding, Input, Output, ViewChild, ViewEncapsulation } from '@angular/core';
|
|
2
|
+
import { PaginationService } from './pagination.service';
|
|
3
|
+
export class PaginationComponent {
|
|
4
|
+
constructor(_paginationService) {
|
|
5
|
+
this._paginationService = _paginationService;
|
|
6
|
+
this.maxSize = 7;
|
|
7
|
+
this.directionLinks = true;
|
|
8
|
+
this.previousLabel = 'Vorige pagina';
|
|
9
|
+
this.nextLabel = 'Volgende pagina';
|
|
10
|
+
this.autoHide = false;
|
|
11
|
+
// Emits the new page number.
|
|
12
|
+
this.pageChange = new EventEmitter();
|
|
13
|
+
this.showClass = true;
|
|
14
|
+
this.pages = [];
|
|
15
|
+
this.changeSub = this._paginationService.change.subscribe((id) => {
|
|
16
|
+
if (this.id === id) {
|
|
17
|
+
this._updatePageLinks();
|
|
18
|
+
}
|
|
19
|
+
});
|
|
20
|
+
}
|
|
21
|
+
ngOnInit() {
|
|
22
|
+
if (!this.id) {
|
|
23
|
+
this.id = this._paginationService.DEFAULT_ID;
|
|
24
|
+
}
|
|
25
|
+
this._updatePageLinks();
|
|
26
|
+
}
|
|
27
|
+
ngOnChanges() {
|
|
28
|
+
this._updatePageLinks();
|
|
29
|
+
}
|
|
30
|
+
ngOnDestroy() {
|
|
31
|
+
this.changeSub.unsubscribe();
|
|
32
|
+
}
|
|
33
|
+
goToFirstPage() {
|
|
34
|
+
if (!this.isOnFirstPage()) {
|
|
35
|
+
this.setCurrentPage(1);
|
|
36
|
+
}
|
|
37
|
+
}
|
|
38
|
+
goToPreviousPage() {
|
|
39
|
+
if (!this.isOnFirstPage()) {
|
|
40
|
+
this.setCurrentPage(this.getCurrentPage() - 1);
|
|
41
|
+
}
|
|
42
|
+
}
|
|
43
|
+
goToNextPage() {
|
|
44
|
+
if (!this.isOnLastPage()) {
|
|
45
|
+
this.setCurrentPage(this.getCurrentPage() + 1);
|
|
46
|
+
}
|
|
47
|
+
}
|
|
48
|
+
setCurrentPage(page) {
|
|
49
|
+
this.pageChange.emit(page);
|
|
50
|
+
}
|
|
51
|
+
isOnFirstPage() {
|
|
52
|
+
return this.getCurrentPage() === 1;
|
|
53
|
+
}
|
|
54
|
+
isOnLastPage() {
|
|
55
|
+
return this.getLastPage() === this.getCurrentPage();
|
|
56
|
+
}
|
|
57
|
+
shouldBeHidden() {
|
|
58
|
+
if (!this.autoHide) {
|
|
59
|
+
return false;
|
|
60
|
+
}
|
|
61
|
+
else {
|
|
62
|
+
let instance = this._paginationService.getInstance();
|
|
63
|
+
return (instance.totalItems <= instance.itemsPerPage);
|
|
64
|
+
}
|
|
65
|
+
}
|
|
66
|
+
/**
|
|
67
|
+
* Updates the page links and checks that the current page is valid. Should run whenever the
|
|
68
|
+
* PaginationService.change stream emits a value matching the current ID, or when any of the
|
|
69
|
+
* input values changes.
|
|
70
|
+
*/
|
|
71
|
+
_updatePageLinks() {
|
|
72
|
+
let paginationInstance = this._paginationService.getInstance(this.id);
|
|
73
|
+
this.pages = this.createPageArray(paginationInstance.currentPage, paginationInstance.itemsPerPage, paginationInstance.totalItems, this.maxSize);
|
|
74
|
+
const correctedCurrentPage = this.outOfBoundCorrection(paginationInstance);
|
|
75
|
+
if (correctedCurrentPage !== paginationInstance.currentPage) {
|
|
76
|
+
this.setCurrentPage(correctedCurrentPage);
|
|
77
|
+
}
|
|
78
|
+
}
|
|
79
|
+
getCurrentPage() {
|
|
80
|
+
return this._paginationService.getCurrentPage(this.id);
|
|
81
|
+
}
|
|
82
|
+
getLastPage() {
|
|
83
|
+
let instance = this._paginationService.getInstance(this.id);
|
|
84
|
+
return Math.ceil(instance.totalItems / instance.itemsPerPage);
|
|
85
|
+
}
|
|
86
|
+
/**
|
|
87
|
+
* Checks that the instance.currentPage property is within bounds for the current page range.
|
|
88
|
+
* If not, return a correct value for currentPage, or the current value if OK.
|
|
89
|
+
*/
|
|
90
|
+
outOfBoundCorrection(instance) {
|
|
91
|
+
const totalPages = Math.ceil(instance.totalItems / instance.itemsPerPage);
|
|
92
|
+
if (totalPages < instance.currentPage && 0 < totalPages) {
|
|
93
|
+
return totalPages;
|
|
94
|
+
}
|
|
95
|
+
else if (instance.currentPage < 1) {
|
|
96
|
+
return 1;
|
|
97
|
+
}
|
|
98
|
+
return instance.currentPage;
|
|
99
|
+
}
|
|
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
|
+
}
|
|
156
|
+
PaginationComponent.decorators = [
|
|
157
|
+
{ type: Component, args: [{
|
|
158
|
+
selector: 'co-pagination',
|
|
159
|
+
template: `
|
|
160
|
+
<div class="pagination-component-main-wrapper" *ngIf="!shouldBeHidden()">
|
|
161
|
+
<div>
|
|
162
|
+
<ng-content></ng-content>
|
|
163
|
+
</div>
|
|
164
|
+
<ul class="pagination">
|
|
165
|
+
<li *ngIf="directionLinks" class="pagination-previous">
|
|
166
|
+
<a (click)="goToPreviousPage()" [class.disabled]="isOnFirstPage()">{{ previousLabel }}</a>
|
|
167
|
+
</li>
|
|
168
|
+
<li *ngFor="let page of pages" [class.current]="getCurrentPage() === page.value" (click)="setCurrentPage(page.value)">
|
|
169
|
+
<span>{{page.label}}</span>
|
|
170
|
+
</li>
|
|
171
|
+
<li *ngIf="directionLinks" class="pagination-next">
|
|
172
|
+
<a (click)="goToNextPage()" [class.disabled]="isOnLastPage()">{{ nextLabel }}</a>
|
|
173
|
+
</li>
|
|
174
|
+
</ul>
|
|
175
|
+
</div>
|
|
176
|
+
`,
|
|
177
|
+
encapsulation: ViewEncapsulation.None
|
|
178
|
+
},] }
|
|
179
|
+
];
|
|
180
|
+
PaginationComponent.ctorParameters = () => [
|
|
181
|
+
{ type: PaginationService }
|
|
182
|
+
];
|
|
183
|
+
PaginationComponent.propDecorators = {
|
|
184
|
+
template: [{ type: ViewChild, args: ['template',] }],
|
|
185
|
+
id: [{ type: Input }],
|
|
186
|
+
maxSize: [{ type: Input }],
|
|
187
|
+
directionLinks: [{ type: Input }],
|
|
188
|
+
previousLabel: [{ type: Input }],
|
|
189
|
+
nextLabel: [{ type: Input }],
|
|
190
|
+
autoHide: [{ type: Input }],
|
|
191
|
+
pageChange: [{ type: Output }],
|
|
192
|
+
showClass: [{ type: HostBinding, args: ['class.co-pagination',] }]
|
|
193
|
+
};
|
|
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\n\r\nimport {IPaginationInstance} from './pagination-instance';\r\nimport {PaginationService} from './pagination.service';\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',\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      <ul class=\"pagination\">\r\n        <li *ngIf=\"directionLinks\" class=\"pagination-previous\">\r\n          <a (click)=\"goToPreviousPage()\" [class.disabled]=\"isOnFirstPage()\">{{ previousLabel }}</a>\r\n        </li>\r\n        <li *ngFor=\"let page of pages\" [class.current]=\"getCurrentPage() === page.value\" (click)=\"setCurrentPage(page.value)\">\r\n          <span>{{page.label}}</span>\r\n        </li>\r\n        <li *ngIf=\"directionLinks\" class=\"pagination-next\">\r\n          <a (click)=\"goToNextPage()\" [class.disabled]=\"isOnLastPage()\">{{ nextLabel }}</a>\r\n        </li>\r\n      </ul>\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  private 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"]}
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
import { NgModule } from "@angular/core";
|
|
2
|
+
import { CommonModule } from "@angular/common";
|
|
3
|
+
import { PaginationComponent } from "./pagination.component";
|
|
4
|
+
import { PaginatePipe } from "./paginate.pipe";
|
|
5
|
+
import { PaginationService } from "./pagination.service";
|
|
6
|
+
export class PaginationModule {
|
|
7
|
+
}
|
|
8
|
+
PaginationModule.decorators = [
|
|
9
|
+
{ type: NgModule, args: [{
|
|
10
|
+
imports: [
|
|
11
|
+
CommonModule
|
|
12
|
+
],
|
|
13
|
+
providers: [
|
|
14
|
+
PaginationService
|
|
15
|
+
],
|
|
16
|
+
declarations: [
|
|
17
|
+
PaginationComponent,
|
|
18
|
+
PaginatePipe
|
|
19
|
+
],
|
|
20
|
+
exports: [
|
|
21
|
+
PaginationComponent,
|
|
22
|
+
PaginatePipe
|
|
23
|
+
]
|
|
24
|
+
},] }
|
|
25
|
+
];
|
|
26
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGFnaW5hdGlvbi5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jb3JlY29tcG9uZW50cy9zcmMvbGliL2NvbXBvbmVudHMvcGFnaW5hdGlvbi9wYWdpbmF0aW9uLm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUMsUUFBUSxFQUFDLE1BQU0sZUFBZSxDQUFDO0FBQ3ZDLE9BQU8sRUFBQyxZQUFZLEVBQUMsTUFBTSxpQkFBaUIsQ0FBQztBQUU3QyxPQUFPLEVBQUMsbUJBQW1CLEVBQUMsTUFBTSx3QkFBd0IsQ0FBQztBQUMzRCxPQUFPLEVBQUMsWUFBWSxFQUFDLE1BQU0saUJBQWlCLENBQUM7QUFDN0MsT0FBTyxFQUFDLGlCQUFpQixFQUFDLE1BQU0sc0JBQXNCLENBQUM7QUFrQnZELE1BQU0sT0FBTyxnQkFBZ0I7OztZQWhCNUIsUUFBUSxTQUFDO2dCQUNOLE9BQU8sRUFBRTtvQkFDTCxZQUFZO2lCQUNmO2dCQUNELFNBQVMsRUFBRTtvQkFDUCxpQkFBaUI7aUJBQ3BCO2dCQUNELFlBQVksRUFBRTtvQkFDVixtQkFBbUI7b0JBQ25CLFlBQVk7aUJBQ2Y7Z0JBQ0QsT0FBTyxFQUFFO29CQUNMLG1CQUFtQjtvQkFDbkIsWUFBWTtpQkFDZjthQUNKIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtOZ01vZHVsZX0gZnJvbSBcIkBhbmd1bGFyL2NvcmVcIjtcclxuaW1wb3J0IHtDb21tb25Nb2R1bGV9IGZyb20gXCJAYW5ndWxhci9jb21tb25cIjtcclxuXHJcbmltcG9ydCB7UGFnaW5hdGlvbkNvbXBvbmVudH0gZnJvbSBcIi4vcGFnaW5hdGlvbi5jb21wb25lbnRcIjtcclxuaW1wb3J0IHtQYWdpbmF0ZVBpcGV9IGZyb20gXCIuL3BhZ2luYXRlLnBpcGVcIjtcclxuaW1wb3J0IHtQYWdpbmF0aW9uU2VydmljZX0gZnJvbSBcIi4vcGFnaW5hdGlvbi5zZXJ2aWNlXCI7XHJcblxyXG5ATmdNb2R1bGUoe1xyXG4gICAgaW1wb3J0czogW1xyXG4gICAgICAgIENvbW1vbk1vZHVsZVxyXG4gICAgXSxcclxuICAgIHByb3ZpZGVyczogW1xyXG4gICAgICAgIFBhZ2luYXRpb25TZXJ2aWNlXHJcbiAgICBdLFxyXG4gICAgZGVjbGFyYXRpb25zOiBbXHJcbiAgICAgICAgUGFnaW5hdGlvbkNvbXBvbmVudCxcclxuICAgICAgICBQYWdpbmF0ZVBpcGVcclxuICAgIF0sXHJcbiAgICBleHBvcnRzOiBbXHJcbiAgICAgICAgUGFnaW5hdGlvbkNvbXBvbmVudCxcclxuICAgICAgICBQYWdpbmF0ZVBpcGVcclxuICAgIF1cclxufSlcclxuZXhwb3J0IGNsYXNzIFBhZ2luYXRpb25Nb2R1bGUge1xyXG59XHJcbiJdfQ==
|
|
@@ -0,0 +1,88 @@
|
|
|
1
|
+
import { Injectable } from "@angular/core";
|
|
2
|
+
import { Subject } from "rxjs";
|
|
3
|
+
import { ObjectUtils } from "../../core/utils/object-utils";
|
|
4
|
+
export class PaginationService {
|
|
5
|
+
constructor() {
|
|
6
|
+
this.change = new Subject();
|
|
7
|
+
this.instances = {};
|
|
8
|
+
}
|
|
9
|
+
get DEFAULT_ID() {
|
|
10
|
+
return PaginationService.DEFAULT_ID;
|
|
11
|
+
}
|
|
12
|
+
register(instance) {
|
|
13
|
+
if (!instance.id) {
|
|
14
|
+
instance.id = PaginationService.DEFAULT_ID;
|
|
15
|
+
}
|
|
16
|
+
if (!this.instances[instance.id]) {
|
|
17
|
+
this.instances[instance.id] = instance;
|
|
18
|
+
this.change.next(instance.id);
|
|
19
|
+
}
|
|
20
|
+
else {
|
|
21
|
+
let changed = this.updateInstance(instance);
|
|
22
|
+
if (changed) {
|
|
23
|
+
this.change.next(instance.id);
|
|
24
|
+
}
|
|
25
|
+
}
|
|
26
|
+
}
|
|
27
|
+
// Returns the current page number.
|
|
28
|
+
getCurrentPage(id) {
|
|
29
|
+
if (this.instances[id]) {
|
|
30
|
+
return this.instances[id].currentPage;
|
|
31
|
+
}
|
|
32
|
+
}
|
|
33
|
+
// Sets the current page number.
|
|
34
|
+
setCurrentPage(id, page) {
|
|
35
|
+
if (this.instances[id]) {
|
|
36
|
+
let instance = this.instances[id];
|
|
37
|
+
let maxPage = Math.ceil(instance.totalItems / instance.itemsPerPage);
|
|
38
|
+
if (page <= maxPage && 1 <= page) {
|
|
39
|
+
this.instances[id].currentPage = page;
|
|
40
|
+
this.change.next(id);
|
|
41
|
+
}
|
|
42
|
+
}
|
|
43
|
+
}
|
|
44
|
+
// Sets the value of instance.totalItems
|
|
45
|
+
setTotalItems(id, totalItems) {
|
|
46
|
+
if (this.instances[id] && 0 <= totalItems) {
|
|
47
|
+
this.instances[id].totalItems = totalItems;
|
|
48
|
+
this.change.next(id);
|
|
49
|
+
}
|
|
50
|
+
}
|
|
51
|
+
// Sets the value of instance.itemsPerPage.
|
|
52
|
+
setItemsPerPage(id, itemsPerPage) {
|
|
53
|
+
if (this.instances[id]) {
|
|
54
|
+
this.instances[id].itemsPerPage = itemsPerPage;
|
|
55
|
+
this.change.next(id);
|
|
56
|
+
}
|
|
57
|
+
}
|
|
58
|
+
/**
|
|
59
|
+
* Returns a clone of the pagination instance object matching the id. If no
|
|
60
|
+
* id specified, returns the instance corresponding to the default id.
|
|
61
|
+
*/
|
|
62
|
+
getInstance(id = PaginationService.DEFAULT_ID) {
|
|
63
|
+
if (this.instances[id]) {
|
|
64
|
+
return ObjectUtils.GetShallowClone(this.instances[id]);
|
|
65
|
+
}
|
|
66
|
+
return {};
|
|
67
|
+
}
|
|
68
|
+
/**
|
|
69
|
+
* Check each property of the instance and update any that have changed. Return
|
|
70
|
+
* true if any changes were made, else return false.
|
|
71
|
+
*/
|
|
72
|
+
updateInstance(instance) {
|
|
73
|
+
let changed = false;
|
|
74
|
+
for (let prop in this.instances[instance.id]) {
|
|
75
|
+
if (instance[prop] !== this.instances[instance.id][prop]) {
|
|
76
|
+
this.instances[instance.id][prop] = instance[prop];
|
|
77
|
+
changed = true;
|
|
78
|
+
}
|
|
79
|
+
}
|
|
80
|
+
return changed;
|
|
81
|
+
}
|
|
82
|
+
}
|
|
83
|
+
PaginationService.DEFAULT_ID = "DEFAULT_PAGINATION_ID";
|
|
84
|
+
PaginationService.decorators = [
|
|
85
|
+
{ type: Injectable }
|
|
86
|
+
];
|
|
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}"]}
|