ornamentum
Version:
Angular Toolkit
401 lines • 30.6 kB
JavaScript
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
import { Component, ElementRef, ViewChild } from '@angular/core';
import { debounceTime } from 'rxjs/operators';
import { DataFetchMode } from '../../models/data-fetch-mode.enum';
import { DataTableConfigService } from '../../services/data-table-config.service';
import { DataTableDataStateService } from '../../services/data-table-data-state.service';
import { DataTableEventStateService } from '../../services/data-table-event.service';
import { ResizeService } from '../../../utility/services/resize.service';
/**
* Data table pagination component. Render data table paginator widget.
*/
var DataTablePaginationComponent = /** @class */ (function () {
function DataTablePaginationComponent(config, dataStateService, eventStateService, resizeService) {
this.config = config;
this.dataStateService = dataStateService;
this.eventStateService = eventStateService;
this.resizeService = resizeService;
this.isMobile = false;
}
/**
* Set mobile mode state.
*/
/**
* Set mobile mode state.
* @private
* @return {?}
*/
DataTablePaginationComponent.prototype.setMobileModeState = /**
* Set mobile mode state.
* @private
* @return {?}
*/
function () {
this.isMobile = this.paginationContainer.nativeElement.clientWidth < 767;
};
/**
* First page click event handler.
*/
/**
* First page click event handler.
* @return {?}
*/
DataTablePaginationComponent.prototype.firstPageClick = /**
* First page click event handler.
* @return {?}
*/
function () {
this.config.offset = 0;
this.eventStateService.dataFetchStream.emit(DataFetchMode.SOFT_LOAD);
};
/**
* Previous page click event handler.
*/
/**
* Previous page click event handler.
* @return {?}
*/
DataTablePaginationComponent.prototype.previousPageClick = /**
* Previous page click event handler.
* @return {?}
*/
function () {
this.config.offset = this.config.offset - Math.min(this.config.limit, this.config.offset);
this.eventStateService.dataFetchStream.emit(DataFetchMode.SOFT_LOAD);
};
/**
* Next page click event handler.
*/
/**
* Next page click event handler.
* @return {?}
*/
DataTablePaginationComponent.prototype.nextPageClick = /**
* Next page click event handler.
* @return {?}
*/
function () {
this.config.offset = this.config.offset + this.config.limit;
this.eventStateService.dataFetchStream.emit(DataFetchMode.SOFT_LOAD);
};
/**
* Last page click event handler.
*/
/**
* Last page click event handler.
* @return {?}
*/
DataTablePaginationComponent.prototype.lastPageClick = /**
* Last page click event handler.
* @return {?}
*/
function () {
this.config.offset = (this.maxPage - 1) * this.config.limit;
this.eventStateService.dataFetchStream.emit(DataFetchMode.SOFT_LOAD);
};
Object.defineProperty(DataTablePaginationComponent.prototype, "maxPage", {
/**
* Get maximum page count.
*/
get: /**
* Get maximum page count.
* @return {?}
*/
function () {
return Math.ceil(this.dataStateService.itemCount / this.config.limit);
},
enumerable: true,
configurable: true
});
Object.defineProperty(DataTablePaginationComponent.prototype, "page", {
/**
* Get page number.
*/
get: /**
* Get page number.
* @return {?}
*/
function () {
return Math.floor(this.config.offset / this.config.limit) + 1;
},
enumerable: true,
configurable: true
});
/**
* Check limit invalid status. True if limit is invalid.
* @param element Limit input DOM element.
* @return Invalid status.
*/
/**
* Check limit invalid status. True if limit is invalid.
* @param {?} element Limit input DOM element.
* @return {?} Invalid status.
*/
DataTablePaginationComponent.prototype.isInvalidLimit = /**
* Check limit invalid status. True if limit is invalid.
* @param {?} element Limit input DOM element.
* @return {?} Invalid status.
*/
function (element) {
/** @type {?} */
var limit = Number(element.value);
return element.value === '' || limit > this.config.maxLimit || limit < 1;
};
/**
* On page size change event handler.
* @param element HTML input element.
*/
/**
* On page size change event handler.
* @param {?} element HTML input element.
* @return {?}
*/
DataTablePaginationComponent.prototype.onPageSizeChange = /**
* On page size change event handler.
* @param {?} element HTML input element.
* @return {?}
*/
function (element) {
if (this.isInvalidLimit(element)) {
element.value = String(this.config.limit);
return;
}
/** @type {?} */
var limit = Number(element.value);
if (this.config.limit !== limit) {
this.config.offset = 0;
this.config.limit = limit;
this.eventStateService.dataFetchStream.emit(DataFetchMode.SOFT_LOAD);
}
};
/**
* On page size revert event handler.
* @param element HTML input element.
*/
/**
* On page size revert event handler.
* @param {?} element HTML input element.
* @return {?}
*/
DataTablePaginationComponent.prototype.onPageSizeRevert = /**
* On page size revert event handler.
* @param {?} element HTML input element.
* @return {?}
*/
function (element) {
element.value = String(this.config.limit);
};
/**
* Is invalid page index; True if page index is invalid.
* @param element Page index DOM element.
* @return Invalid status.
*/
/**
* Is invalid page index; True if page index is invalid.
* @param {?} element Page index DOM element.
* @return {?} Invalid status.
*/
DataTablePaginationComponent.prototype.isInvalidPageIndex = /**
* Is invalid page index; True if page index is invalid.
* @param {?} element Page index DOM element.
* @return {?} Invalid status.
*/
function (element) {
/** @type {?} */
var page = Number(element.value);
return element.value === '' || page > this.maxPage || page < 1;
};
/**
* On page size change event handler.
* @param element HTML input element.
*/
/**
* On page size change event handler.
* @param {?} element HTML input element.
* @return {?}
*/
DataTablePaginationComponent.prototype.onPageIndexChange = /**
* On page size change event handler.
* @param {?} element HTML input element.
* @return {?}
*/
function (element) {
if (this.isInvalidPageIndex(element)) {
element.value = String(this.page);
return;
}
/** @type {?} */
var page = Number(element.value);
if (this.page !== page) {
this.config.offset = (page - 1) * this.config.limit;
this.eventStateService.dataFetchStream.emit(DataFetchMode.SOFT_LOAD);
}
};
/**
* On page size revert event handler.
* @param element HTML input element.
*/
/**
* On page size revert event handler.
* @param {?} element HTML input element.
* @return {?}
*/
DataTablePaginationComponent.prototype.onPageIndexRevert = /**
* On page size revert event handler.
* @param {?} element HTML input element.
* @return {?}
*/
function (element) {
element.value = String(this.page);
};
Object.defineProperty(DataTablePaginationComponent.prototype, "hasPrevious", {
/**
* Get previous page availability status.
*/
get: /**
* Get previous page availability status.
* @return {?}
*/
function () {
return this.config.offset <= 0;
},
enumerable: true,
configurable: true
});
Object.defineProperty(DataTablePaginationComponent.prototype, "hasNext", {
/**
* Get next page availability status.
*/
get: /**
* Get next page availability status.
* @return {?}
*/
function () {
return this.config.offset + this.config.limit >= this.dataStateService.itemCount;
},
enumerable: true,
configurable: true
});
Object.defineProperty(DataTablePaginationComponent.prototype, "startRowIndex", {
/**
* Get start row index.
*/
get: /**
* Get start row index.
* @return {?}
*/
function () {
return this.config.offset + 1;
},
enumerable: true,
configurable: true
});
Object.defineProperty(DataTablePaginationComponent.prototype, "endRowIndex", {
/**
* Get end row index.
*/
get: /**
* Get end row index.
* @return {?}
*/
function () {
return Math.min(this.config.offset + this.config.limit, this.dataStateService.itemCount);
},
enumerable: true,
configurable: true
});
/**
* Prevent invalid key press.
* @param event Keyboard event argument object.
*/
/**
* Prevent invalid key press.
* @param {?} event Keyboard event argument object.
* @return {?}
*/
DataTablePaginationComponent.prototype.preventInvalidKeyPress = /**
* Prevent invalid key press.
* @param {?} event Keyboard event argument object.
* @return {?}
*/
function (event) {
if ((event.key >= '0' && event.key <= '9') ||
event.key === 'ArrowLeft' ||
event.key === 'ArrowRight' ||
event.key === 'Delete' ||
event.key === 'Backspace' ||
event.key === 'Escape' ||
event.key === 'Enter') {
return;
}
else {
event.preventDefault();
}
};
/**
* component init lifecycle event handler.
*/
/**
* component init lifecycle event handler.
* @return {?}
*/
DataTablePaginationComponent.prototype.ngOnInit = /**
* component init lifecycle event handler.
* @return {?}
*/
function () {
var _this = this;
this.setMobileModeState();
this.resizeService.resize.pipe(debounceTime(200)).subscribe((/**
* @return {?}
*/
function () {
_this.setMobileModeState();
}));
};
DataTablePaginationComponent.decorators = [
{ type: Component, args: [{
selector: 'ng-data-table-pagination',
template: "<div class=\"ng-data-table-pagination-container\" #paginationContainer>\n <div class=\"ng-data-table-pagination-range\" [hidden]=\"isMobile\">\n {{ config.translations.pagination.rangeKey }} <span [textContent]=\"startRowIndex\"></span>\n -<span [textContent]=\"endRowIndex\"></span>\n {{ config.translations.pagination.rangeSeparator }}\n <span [textContent]=\"dataStateService.itemCount\"></span>\n </div>\n <div class=\"ng-data-table-pagination-controllers\" [class.sm-controllers]=\"isMobile\">\n <div class=\"ng-data-table-pagination-limit\">\n <div class=\"ng-data-table-pagination-input-container\">\n <label class=\"ng-data-table-pagination-input-label\">{{ config.translations.pagination.limit }}</label>\n <input\n #limitInput\n type=\"number\"\n class=\"ng-data-table-pagination-input\"\n min=\"1\"\n step=\"1\"\n [attr.max]=\"config.maxLimit\"\n [class.ng-data-table-input-error]=\"isInvalidLimit(limitInput)\"\n [ngModel]=\"config.limit\"\n required\n (keypress)=\"preventInvalidKeyPress($event)\"\n (keyup.enter)=\"onPageSizeChange(limitInput)\"\n (keyup.esc)=\"onPageSizeRevert(limitInput)\"\n />\n </div>\n </div>\n <div class=\"ng-data-table-pagination-pages\">\n <button\n [disabled]=\"hasPrevious\"\n (click)=\"firstPageClick()\"\n [title]=\"config.translations.pagination.firstTooltip\"\n class=\"ng-data-table-action-button ng-data-table-pagination-firstpage\"\n ></button>\n <button\n [disabled]=\"hasPrevious\"\n (click)=\"previousPageClick()\"\n [title]=\"config.translations.pagination.previousTooltip\"\n class=\"ng-data-table-action-button ng-data-table-pagination-prevpage\"\n ></button>\n <div class=\"ng-data-table-pagination-page\">\n <div class=\"ng-data-table-pagination-input-container\">\n <input\n #pageInput\n type=\"number\"\n class=\"ng-data-table-pagination-input\"\n min=\"1\"\n step=\"1\"\n [attr.max]=\"maxPage\"\n [class.ng-data-table-input-error]=\"isInvalidPageIndex(pageInput)\"\n [ngModel]=\"page\"\n required\n (keypress)=\"preventInvalidKeyPress($event)\"\n (keyup.enter)=\"onPageIndexChange(pageInput)\"\n (keyup.esc)=\"onPageIndexRevert(pageInput)\"\n />\n <div class=\"ng-data-table-pagination-input-label\">\n <span>/ </span>\n <span [textContent]=\"maxPage\"></span>\n </div>\n </div>\n </div>\n <button\n [disabled]=\"hasNext\"\n (click)=\"nextPageClick()\"\n [title]=\"config.translations.pagination.nextTooltip\"\n class=\"ng-data-table-action-button ng-data-table-pagination-nextpage\"\n ></button>\n <button\n [disabled]=\"hasNext\"\n (click)=\"lastPageClick()\"\n [title]=\"config.translations.pagination.lastTooltip\"\n class=\"ng-data-table-action-button ng-data-table-pagination-lastpage\"\n ></button>\n </div>\n </div>\n</div>\n"
}] }
];
/** @nocollapse */
DataTablePaginationComponent.ctorParameters = function () { return [
{ type: DataTableConfigService },
{ type: DataTableDataStateService },
{ type: DataTableEventStateService },
{ type: ResizeService }
]; };
DataTablePaginationComponent.propDecorators = {
paginationContainer: [{ type: ViewChild, args: ['paginationContainer', { static: true },] }]
};
return DataTablePaginationComponent;
}());
export { DataTablePaginationComponent };
if (false) {
/**
* @type {?}
* @private
*/
DataTablePaginationComponent.prototype.paginationContainer;
/** @type {?} */
DataTablePaginationComponent.prototype.isMobile;
/** @type {?} */
DataTablePaginationComponent.prototype.config;
/** @type {?} */
DataTablePaginationComponent.prototype.dataStateService;
/**
* @type {?}
* @private
*/
DataTablePaginationComponent.prototype.eventStateService;
/**
* @type {?}
* @private
*/
DataTablePaginationComponent.prototype.resizeService;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"data-table-pagination.component.js","sourceRoot":"ng://ornamentum/","sources":["data-table/components/data-table-pagination/data-table-pagination.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, ElementRef, OnInit, ViewChild } from '@angular/core';\n\nimport { debounceTime } from 'rxjs/operators';\n\nimport { DataFetchMode } from '../../models/data-fetch-mode.enum';\n\nimport { DataTableConfigService } from '../../services/data-table-config.service';\nimport { DataTableDataStateService } from '../../services/data-table-data-state.service';\nimport { DataTableEventStateService } from '../../services/data-table-event.service';\nimport { ResizeService } from '../../../utility/services/resize.service';\n\n/**\n * Data table pagination component. Render data table paginator widget.\n */\n@Component({\n  selector: 'ng-data-table-pagination',\n  templateUrl: './data-table-pagination.component.html'\n})\nexport class DataTablePaginationComponent implements OnInit {\n  @ViewChild('paginationContainer', { static: true })\n  private paginationContainer: ElementRef<HTMLElement>;\n\n  public isMobile = false;\n\n  constructor(\n    public config: DataTableConfigService,\n    public dataStateService: DataTableDataStateService,\n    private eventStateService: DataTableEventStateService,\n    private resizeService: ResizeService\n  ) {}\n\n  /**\n   * Set mobile mode state.\n   */\n  private setMobileModeState(): void {\n    this.isMobile = this.paginationContainer.nativeElement.clientWidth < 767;\n  }\n\n  /**\n   * First page click event handler.\n   */\n  public firstPageClick(): void {\n    this.config.offset = 0;\n    this.eventStateService.dataFetchStream.emit(DataFetchMode.SOFT_LOAD);\n  }\n\n  /**\n   * Previous page click event handler.\n   */\n  public previousPageClick(): void {\n    this.config.offset = this.config.offset - Math.min(this.config.limit, this.config.offset);\n    this.eventStateService.dataFetchStream.emit(DataFetchMode.SOFT_LOAD);\n  }\n\n  /**\n   * Next page click event handler.\n   */\n  public nextPageClick(): void {\n    this.config.offset = this.config.offset + this.config.limit;\n    this.eventStateService.dataFetchStream.emit(DataFetchMode.SOFT_LOAD);\n  }\n\n  /**\n   * Last page click event handler.\n   */\n  public lastPageClick(): void {\n    this.config.offset = (this.maxPage - 1) * this.config.limit;\n    this.eventStateService.dataFetchStream.emit(DataFetchMode.SOFT_LOAD);\n  }\n\n  /**\n   * Get maximum page count.\n   */\n  public get maxPage(): number {\n    return Math.ceil(this.dataStateService.itemCount / this.config.limit);\n  }\n\n  /**\n   * Get page number.\n   */\n  public get page(): number {\n    return Math.floor(this.config.offset / this.config.limit) + 1;\n  }\n\n  /**\n   * Check limit invalid status. True if limit is invalid.\n   * @param element Limit input DOM element.\n   * @return Invalid status.\n   */\n  public isInvalidLimit(element: HTMLInputElement): boolean {\n    const limit = Number(element.value);\n    return element.value === '' || limit > this.config.maxLimit || limit < 1;\n  }\n\n  /**\n   * On page size change event handler.\n   * @param element HTML input element.\n   */\n  public onPageSizeChange(element: HTMLInputElement): void {\n    if (this.isInvalidLimit(element)) {\n      element.value = String(this.config.limit);\n      return;\n    }\n\n    const limit = Number(element.value);\n    if (this.config.limit !== limit) {\n      this.config.offset = 0;\n      this.config.limit = limit;\n      this.eventStateService.dataFetchStream.emit(DataFetchMode.SOFT_LOAD);\n    }\n  }\n\n  /**\n   * On page size revert event handler.\n   * @param element HTML input element.\n   */\n  public onPageSizeRevert(element: HTMLInputElement): void {\n    element.value = String(this.config.limit);\n  }\n\n  /**\n   * Is invalid page index; True if page index is invalid.\n   * @param element Page index DOM element.\n   * @return Invalid status.\n   */\n  public isInvalidPageIndex(element: HTMLInputElement): boolean {\n    const page = Number(element.value);\n    return element.value === '' || page > this.maxPage || page < 1;\n  }\n\n  /**\n   * On page size change event handler.\n   * @param element HTML input element.\n   */\n  public onPageIndexChange(element: HTMLInputElement): void {\n    if (this.isInvalidPageIndex(element)) {\n      element.value = String(this.page);\n      return;\n    }\n\n    const page = Number(element.value);\n    if (this.page !== page) {\n      this.config.offset = (page - 1) * this.config.limit;\n      this.eventStateService.dataFetchStream.emit(DataFetchMode.SOFT_LOAD);\n    }\n  }\n\n  /**\n   * On page size revert event handler.\n   * @param element HTML input element.\n   */\n  public onPageIndexRevert(element: HTMLInputElement): void {\n    element.value = String(this.page);\n  }\n\n  /**\n   * Get previous page availability status.\n   */\n  public get hasPrevious(): boolean {\n    return this.config.offset <= 0;\n  }\n\n  /**\n   * Get next page availability status.\n   */\n  public get hasNext(): boolean {\n    return this.config.offset + this.config.limit >= this.dataStateService.itemCount;\n  }\n\n  /**\n   * Get start row index.\n   */\n  public get startRowIndex(): number {\n    return this.config.offset + 1;\n  }\n\n  /**\n   * Get end row index.\n   */\n  public get endRowIndex(): number {\n    return Math.min(this.config.offset + this.config.limit, this.dataStateService.itemCount);\n  }\n\n  /**\n   * Prevent invalid key press.\n   * @param event Keyboard event argument object.\n   */\n  public preventInvalidKeyPress(event: KeyboardEvent): void {\n    if (\n      (event.key >= '0' && event.key <= '9') ||\n      event.key === 'ArrowLeft' ||\n      event.key === 'ArrowRight' ||\n      event.key === 'Delete' ||\n      event.key === 'Backspace' ||\n      event.key === 'Escape' ||\n      event.key === 'Enter'\n    ) {\n      return;\n    } else {\n      event.preventDefault();\n    }\n  }\n\n  /**\n   * component init lifecycle event handler.\n   */\n  public ngOnInit(): void {\n    this.setMobileModeState();\n\n    this.resizeService.resize.pipe(debounceTime(200)).subscribe(() => {\n      this.setMobileModeState();\n    });\n  }\n}\n"]}