UNPKG

ornamentum

Version:
401 lines 30.6 kB
/** * @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"]}