UNPKG

@catull/igniteui-angular

Version:

Ignite UI for Angular is a dependency-free Angular toolkit for building modern web apps

296 lines 28.4 kB
import { __decorate, __metadata, __param } from "tslib"; import { CommonModule } from '@angular/common'; import { FormsModule } from '@angular/forms'; import { Component, Input, Output, NgModule, Optional, Inject, EventEmitter, HostBinding } from '@angular/core'; import { CurrentResourceStrings } from '../core/i18n/resources'; import { DisplayDensityToken, DisplayDensityBase, DisplayDensity } from '../core/displayDensity'; import { IgxSelectModule } from '../select/index'; import { IgxIconModule } from '../icon/index'; import { IgxButtonModule } from '../directives/button/button.directive'; import { IgxRippleModule } from '../directives/ripple/ripple.directive'; let IgxPaginatorComponent = class IgxPaginatorComponent extends DisplayDensityBase { constructor(_displayDensityOptions) { super(_displayDensityOptions); this._displayDensityOptions = _displayDensityOptions; this._page = 0; this.defaultSelectValues = [5, 10, 15, 25, 50, 100, 500]; this._perPage = 15; /** * An @Input property that sets if the pager in the paginator should be enabled. * ```html * <igx-paginator [pagerEnabled]="true"></igx-paginator> * ``` * @memberof IgxPaginatorComponent */ this.pagerEnabled = true; /** * An @Input property that sets if the pager in the paginator should be hidden. * ```html * <igx-paginator [pagerHidden]="true"></igx-paginator> * ``` * @memberof IgxPaginatorComponent */ this.pagerHidden = false; /** * An @Input property that sets if the dropdown in the paginator should be enabled. * ```html * <igx-paginator [dropdownEnabled]="true"></igx-paginator> * ``` * @memberof IgxPaginatorComponent */ this.dropdownEnabled = true; /** * An @Input property that sets if the dropdown in the paginator should be hidden. * ```html * <igx-paginator [dropdownHidden]="true"></igx-paginator> * ``` * @memberof IgxPaginatorComponent */ this.dropdownHidden = false; /** * An @Input property, sets number of label of the select. * The default is 'Items per page' localized string. * ```html * <igx-paginator label="My custom label"></igx-paginator> * ``` * @memberof IgxPaginatorComponent */ this.selectLabel = CurrentResourceStrings.PaginatorResStrings.igx_paginator_label; /** *An event that is emitted when the select in the `IgxPaginatorComponent` changes its value. */ this.perPageChange = new EventEmitter(); /** *An event that is emitted when the paginating is used. */ this.pageChange = new EventEmitter(); } /** * Sets the class of the IgxPaginatorComponent based * on the provided displayDensity. */ get classCosy() { return this.displayDensity === DisplayDensity.cosy; } get classCompact() { return this.displayDensity === DisplayDensity.compact; } get classComfortable() { return this.displayDensity === DisplayDensity.comfortable; } /** * An @Input property, sets current page of the `IgxPaginatorComponent`. * The default is 0. * ```typescript * let page = this.paginator.page; * ``` * @memberof IgxPaginatorComponent */ get page() { return this._page; } set page(value) { this._page = value; this.pageChange.emit(this._page); } /** * An @Input property, sets number of visible items per page in the `IgxPaginatorComponent`. * The default is 15. * ```typescript * let itemsPerPage = this.paginator.perPage; * ``` * @memberof IgxPaginatorComponent */ get perPage() { return this._perPage; } set perPage(value) { this._perPage = Number(value); this.perPageChange.emit(this._perPage); this._selectOptions = this.sortUniqueOptions(this.defaultSelectValues, this._perPage); this.totalPages = Math.ceil(this.totalRecords / this._perPage); } /** * An @Input property that sets the total records. * ```typescript * let totalRecords = this.paginator.totalRecords; * ``` * @memberof IgxPaginatorComponent */ get totalRecords() { return this._totalRecords; } set totalRecords(value) { this._totalRecords = value; this.totalPages = Math.ceil(this.totalRecords / this.perPage); } /** * An @Input property that sets custom options in the select of the paginator * ```typescript * let options = this.paginator.selectOptions; * ``` * @memberof IgxPaginatorComponent */ get selectOptions() { return this._selectOptions; } set selectOptions(value) { this._selectOptions = this.sortUniqueOptions(value, this._perPage); this.defaultSelectValues = [...this._selectOptions]; } /** * Returns if the current page is the last page. * ```typescript * const lastPage = this.paginator.isLastPage; * ``` */ get isLastPage() { return this.page + 1 >= this.totalPages; } /** * Returns if the current page is the first page. * ```typescript * const lastPage = this.paginator.isFirstPage; * ``` */ get isFirstPage() { return this.page === 0; } sortUniqueOptions(values, newOption) { return Array.from(new Set([...values, newOption])).sort((a, b) => a - b); } /** * Sets DisplayDensity for the <select> inside the paginator * @hidden */ paginatorSelectDisplayDensity() { if (this.displayDensity === DisplayDensity.comfortable) { return DisplayDensity.cosy; } return DisplayDensity.compact; } /** * Goes to the next page of the `IgxPaginatorComponent`, if the paginator is not already at the last page. * ```typescript * this.paginator.nextPage(); * ``` * @memberof IgxPaginatorComponent */ nextPage() { if (!this.isLastPage) { this.page += 1; } } /** * Goes to the previous page of the `IgxPaginatorComponent`, if the paginator is not already at the first page. * ```typescript * this.paginator.previousPage(); * ``` * @memberof IgxPaginatorComponent */ previousPage() { if (!this.isFirstPage) { this.page -= 1; } } /** * Goes to the desired page index. * ```typescript * this.pagiantor.paginate(1); * ``` * @param val * @memberof IgxPaginatorComponent */ paginate(val) { if (val < 0 || val > this.totalPages - 1) { return; } this.page = val; } }; IgxPaginatorComponent.ctorParameters = () => [ { type: undefined, decorators: [{ type: Optional }, { type: Inject, args: [DisplayDensityToken,] }] } ]; __decorate([ HostBinding('class.igx-paginator--cosy'), __metadata("design:type", Boolean), __metadata("design:paramtypes", []) ], IgxPaginatorComponent.prototype, "classCosy", null); __decorate([ HostBinding('class.igx-paginator--compact'), __metadata("design:type", Boolean), __metadata("design:paramtypes", []) ], IgxPaginatorComponent.prototype, "classCompact", null); __decorate([ HostBinding('class.igx-paginator'), __metadata("design:type", Boolean), __metadata("design:paramtypes", []) ], IgxPaginatorComponent.prototype, "classComfortable", null); __decorate([ Input(), __metadata("design:type", Number), __metadata("design:paramtypes", [Number]) ], IgxPaginatorComponent.prototype, "page", null); __decorate([ Input(), __metadata("design:type", Number), __metadata("design:paramtypes", [Number]) ], IgxPaginatorComponent.prototype, "perPage", null); __decorate([ Input(), __metadata("design:type", Number), __metadata("design:paramtypes", [Number]) ], IgxPaginatorComponent.prototype, "totalRecords", null); __decorate([ Input(), __metadata("design:type", Array), __metadata("design:paramtypes", [Array]) ], IgxPaginatorComponent.prototype, "selectOptions", null); __decorate([ Input(), __metadata("design:type", Object) ], IgxPaginatorComponent.prototype, "pagerEnabled", void 0); __decorate([ Input(), __metadata("design:type", Object) ], IgxPaginatorComponent.prototype, "pagerHidden", void 0); __decorate([ Input(), __metadata("design:type", Object) ], IgxPaginatorComponent.prototype, "dropdownEnabled", void 0); __decorate([ Input(), __metadata("design:type", Object) ], IgxPaginatorComponent.prototype, "dropdownHidden", void 0); __decorate([ Input(), __metadata("design:type", Object) ], IgxPaginatorComponent.prototype, "selectLabel", void 0); __decorate([ Output(), __metadata("design:type", Object) ], IgxPaginatorComponent.prototype, "perPageChange", void 0); __decorate([ Output(), __metadata("design:type", Object) ], IgxPaginatorComponent.prototype, "pageChange", void 0); IgxPaginatorComponent = __decorate([ Component({ selector: 'igx-paginator', template: "<div class=\"igx-paginator__select\" [hidden]=\"dropdownHidden\">\n <label class=\"igx-paginator__label\">{{ selectLabel }}</label>\n <div class=\"igx-paginator__select-input\">\n <igx-select [(ngModel)]=\"perPage\" [displayDensity]=\"paginatorSelectDisplayDensity()\" type=\"border\"\n [disabled]=\"!dropdownEnabled\">\n <igx-select-item [value]=\"val\" *ngFor=\"let val of selectOptions\">\n {{val}}\n </igx-select-item>\n </igx-select>\n </div>\n</div>\n<div class=\"igx-paginator__pager\" [hidden]=\"pagerHidden\">\n <button [disabled]=\"isFirstPage || !pagerEnabled ? true: false\" (click)=\"paginate(0)\" igxButton=\"icon\" igxRipple igxRippleCentered=\"true\">\n <igx-icon fontSet=\"material\">first_page</igx-icon>\n </button>\n <button [disabled]=\"isFirstPage || !pagerEnabled ? true: false\" (click)=\"previousPage()\" igxButton=\"icon\" igxRipple igxRippleCentered=\"true\">\n <igx-icon fontSet=\"material\">chevron_left</igx-icon>\n </button>\n <div class='igx-paginator__pager-text'>\n <span>{{ page + 1 }}</span>\n <span>&nbsp;of&nbsp;</span>\n <span>{{ totalPages }}</span>\n </div>\n <button [disabled]=\"isLastPage || !pagerEnabled ? true: false\" (click)=\"nextPage()\" igxRipple igxRippleCentered=\"true\" igxButton=\"icon\">\n <igx-icon fontSet=\"material\">chevron_right</igx-icon>\n </button>\n <button [disabled]=\"isLastPage || !pagerEnabled ? true: false\" (click)=\"paginate(totalPages - 1)\" igxButton=\"icon\" igxRipple\n igxRippleCentered=\"true\">\n <igx-icon fontSet=\"material\">last_page</igx-icon>\n </button>\n</div>\n" }), __param(0, Optional()), __param(0, Inject(DisplayDensityToken)), __metadata("design:paramtypes", [Object]) ], IgxPaginatorComponent); export { IgxPaginatorComponent }; let IgxPaginatorModule = class IgxPaginatorModule { }; IgxPaginatorModule = __decorate([ NgModule({ declarations: [IgxPaginatorComponent], exports: [IgxPaginatorComponent], imports: [CommonModule, IgxSelectModule, FormsModule, IgxIconModule, IgxButtonModule, IgxRippleModule] }) ], IgxPaginatorModule); export { IgxPaginatorModule }; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"paginator.component.js","sourceRoot":"ng://igniteui-angular/","sources":["lib/paginator/paginator.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\nimport { FormsModule } from '@angular/forms';\nimport { Component, Input, Output, NgModule, Optional, Inject, EventEmitter, HostBinding } from '@angular/core';\nimport { CurrentResourceStrings } from '../core/i18n/resources';\nimport { IDisplayDensityOptions, DisplayDensityToken, DisplayDensityBase, DisplayDensity } from '../core/displayDensity';\nimport { IgxSelectModule } from '../select/index';\nimport { IgxIconModule } from '../icon/index';\nimport { IgxButtonModule } from '../directives/button/button.directive';\nimport { IgxRippleModule } from '../directives/ripple/ripple.directive';\n\n@Component({\n    selector: 'igx-paginator',\n    templateUrl: 'paginator.component.html',\n})\nexport class IgxPaginatorComponent extends DisplayDensityBase {\n\n    /**\n     * Total pages calculated from totalRecords and perPage\n     */\n    public totalPages: number;\n    protected _page = 0;\n    protected _totalRecords: number;\n    protected _selectOptions;\n    private defaultSelectValues = [5, 10, 15, 25, 50, 100, 500];\n    protected _perPage = 15;\n\n    /**\n     * Sets the class of the IgxPaginatorComponent based\n     * on the provided displayDensity.\n     */\n    @HostBinding('class.igx-paginator--cosy')\n    public get classCosy(): boolean {\n        return this.displayDensity === DisplayDensity.cosy;\n    }\n\n    @HostBinding('class.igx-paginator--compact')\n    public get classCompact(): boolean {\n        return this.displayDensity === DisplayDensity.compact;\n    }\n\n    @HostBinding('class.igx-paginator')\n    public get classComfortable(): boolean {\n        return this.displayDensity === DisplayDensity.comfortable;\n    }\n\n    /**\n   * An @Input property, sets current page of the `IgxPaginatorComponent`.\n   * The default is 0.\n   * ```typescript\n   * let page = this.paginator.page;\n   * ```\n   * @memberof IgxPaginatorComponent\n   */\n    @Input()\n    public get page() {\n        return this._page;\n    }\n\n    public set page(value: number) {\n        this._page = value;\n        this.pageChange.emit(this._page);\n    }\n\n    /**\n   * An @Input property, sets number of visible items per page in the `IgxPaginatorComponent`.\n   * The default is 15.\n   * ```typescript\n   * let itemsPerPage = this.paginator.perPage;\n   * ```\n   * @memberof IgxPaginatorComponent\n   */\n    @Input()\n    public get perPage() {\n        return this._perPage;\n    }\n\n    public set perPage(value: number) {\n        this._perPage = Number(value);\n        this.perPageChange.emit(this._perPage);\n        this._selectOptions = this.sortUniqueOptions(this.defaultSelectValues, this._perPage);\n        this.totalPages = Math.ceil(this.totalRecords / this._perPage);\n    }\n\n    /**\n    * An @Input property that sets the total records.\n    * ```typescript\n    * let totalRecords = this.paginator.totalRecords;\n    * ```\n    * @memberof IgxPaginatorComponent\n    */\n    @Input()\n    public get totalRecords() {\n        return this._totalRecords;\n    }\n\n    public set totalRecords(value: number) {\n        this._totalRecords = value;\n        this.totalPages = Math.ceil(this.totalRecords / this.perPage);\n    }\n\n    /**\n    * An @Input property that sets custom options in the select of the paginator\n    * ```typescript\n    * let options = this.paginator.selectOptions;\n    * ```\n    * @memberof IgxPaginatorComponent\n    */\n    @Input()\n    public get selectOptions() {\n        return this._selectOptions;\n    }\n\n    public set selectOptions(value: Array<number>) {\n        this._selectOptions = this.sortUniqueOptions(value, this._perPage);\n        this.defaultSelectValues = [...this._selectOptions];\n    }\n    /**\n    * An @Input property that sets if the pager in the paginator should be enabled.\n    * ```html\n    * <igx-paginator [pagerEnabled]=\"true\"></igx-paginator>\n    * ```\n    * @memberof IgxPaginatorComponent\n    */\n    @Input()\n    public pagerEnabled = true;\n\n    /**\n    * An @Input property that sets if the pager in the paginator should be hidden.\n    * ```html\n    * <igx-paginator [pagerHidden]=\"true\"></igx-paginator>\n    * ```\n    * @memberof IgxPaginatorComponent\n    */\n    @Input()\n    public pagerHidden = false;\n\n    /**\n    * An @Input property that sets if the dropdown in the paginator should be enabled.\n    * ```html\n    * <igx-paginator [dropdownEnabled]=\"true\"></igx-paginator>\n    * ```\n    * @memberof IgxPaginatorComponent\n    */\n    @Input()\n    public dropdownEnabled = true;\n\n    /**\n    * An @Input property that sets if the dropdown in the paginator should be hidden.\n    * ```html\n    * <igx-paginator [dropdownHidden]=\"true\"></igx-paginator>\n    * ```\n    * @memberof IgxPaginatorComponent\n    */\n    @Input()\n    public dropdownHidden = false;\n\n    /**\n    * An @Input property, sets number of label of the select.\n    * The default is 'Items per page' localized string.\n    * ```html\n    * <igx-paginator label=\"My custom label\"></igx-paginator>\n    * ```\n    * @memberof IgxPaginatorComponent\n    */\n    @Input()\n    public selectLabel = CurrentResourceStrings.PaginatorResStrings.igx_paginator_label;\n\n    /**\n     *An event that is emitted when the select in the `IgxPaginatorComponent` changes its value.\n    */\n    @Output()\n    public perPageChange = new EventEmitter<number>();\n    /**\n     *An event that is emitted when the paginating is used.\n    */\n    @Output()\n    public pageChange = new EventEmitter<number>();\n\n    constructor(@Optional() @Inject(DisplayDensityToken) protected _displayDensityOptions: IDisplayDensityOptions\n    ) {\n        super(_displayDensityOptions);\n    }\n\n    /**\n     * Returns if the current page is the last page.\n     * ```typescript\n     * const lastPage = this.paginator.isLastPage;\n     * ```\n     */\n    get isLastPage(): boolean {\n        return this.page + 1 >= this.totalPages;\n    }\n\n    /**\n     * Returns if the current page is the first page.\n     * ```typescript\n     * const lastPage = this.paginator.isFirstPage;\n     * ```\n     */\n    get isFirstPage(): boolean {\n        return this.page === 0;\n    }\n\n    private sortUniqueOptions(values: Array<number>, newOption: number): number[] {\n        return Array.from(new Set([...values, newOption])).sort((a, b) => a - b);\n    }\n\n    /**\n     * Sets DisplayDensity for the <select> inside the paginator\n     * @hidden\n     */\n    public paginatorSelectDisplayDensity(): string {\n        if (this.displayDensity === DisplayDensity.comfortable) {\n            return DisplayDensity.cosy;\n        }\n        return DisplayDensity.compact;\n    }\n    /**\n     * Goes to the next page of the `IgxPaginatorComponent`, if the paginator is not already at the last page.\n     * ```typescript\n     * this.paginator.nextPage();\n     * ```\n\t * @memberof IgxPaginatorComponent\n     */\n    public nextPage(): void {\n        if (!this.isLastPage) {\n            this.page += 1;\n        }\n    }\n    /**\n     * Goes to the previous page of the `IgxPaginatorComponent`, if the paginator is not already at the first page.\n     * ```typescript\n     * this.paginator.previousPage();\n     * ```\n\t * @memberof IgxPaginatorComponent\n     */\n    public previousPage(): void {\n        if (!this.isFirstPage) {\n            this.page -= 1;\n        }\n    }\n    /**\n     * Goes to the desired page index.\n     * ```typescript\n     * this.pagiantor.paginate(1);\n     * ```\n     * @param val\n     * @memberof IgxPaginatorComponent\n     */\n    public paginate(val: number): void {\n        if (val < 0 || val > this.totalPages - 1) {\n            return;\n        }\n        this.page = val;\n    }\n}\n\n@NgModule({\n    declarations: [IgxPaginatorComponent],\n    exports: [IgxPaginatorComponent],\n    imports: [CommonModule, IgxSelectModule, FormsModule, IgxIconModule, IgxButtonModule, IgxRippleModule]\n})\nexport class IgxPaginatorModule { }\n"]}