UNPKG

@catull/igniteui-angular

Version:

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

338 lines 31 kB
import { __decorate, __extends, __metadata, __param, __read, __spread } 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'; var IgxPaginatorComponent = /** @class */ (function (_super) { __extends(IgxPaginatorComponent, _super); function IgxPaginatorComponent(_displayDensityOptions) { var _this = _super.call(this, _displayDensityOptions) || this; _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(); return _this; } Object.defineProperty(IgxPaginatorComponent.prototype, "classCosy", { /** * Sets the class of the IgxPaginatorComponent based * on the provided displayDensity. */ get: function () { return this.displayDensity === DisplayDensity.cosy; }, enumerable: true, configurable: true }); Object.defineProperty(IgxPaginatorComponent.prototype, "classCompact", { get: function () { return this.displayDensity === DisplayDensity.compact; }, enumerable: true, configurable: true }); Object.defineProperty(IgxPaginatorComponent.prototype, "classComfortable", { get: function () { return this.displayDensity === DisplayDensity.comfortable; }, enumerable: true, configurable: true }); Object.defineProperty(IgxPaginatorComponent.prototype, "page", { /** * An @Input property, sets current page of the `IgxPaginatorComponent`. * The default is 0. * ```typescript * let page = this.paginator.page; * ``` * @memberof IgxPaginatorComponent */ get: function () { return this._page; }, set: function (value) { this._page = value; this.pageChange.emit(this._page); }, enumerable: true, configurable: true }); Object.defineProperty(IgxPaginatorComponent.prototype, "perPage", { /** * 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: function () { return this._perPage; }, set: function (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); }, enumerable: true, configurable: true }); Object.defineProperty(IgxPaginatorComponent.prototype, "totalRecords", { /** * An @Input property that sets the total records. * ```typescript * let totalRecords = this.paginator.totalRecords; * ``` * @memberof IgxPaginatorComponent */ get: function () { return this._totalRecords; }, set: function (value) { this._totalRecords = value; this.totalPages = Math.ceil(this.totalRecords / this.perPage); }, enumerable: true, configurable: true }); Object.defineProperty(IgxPaginatorComponent.prototype, "selectOptions", { /** * An @Input property that sets custom options in the select of the paginator * ```typescript * let options = this.paginator.selectOptions; * ``` * @memberof IgxPaginatorComponent */ get: function () { return this._selectOptions; }, set: function (value) { this._selectOptions = this.sortUniqueOptions(value, this._perPage); this.defaultSelectValues = __spread(this._selectOptions); }, enumerable: true, configurable: true }); Object.defineProperty(IgxPaginatorComponent.prototype, "isLastPage", { /** * Returns if the current page is the last page. * ```typescript * const lastPage = this.paginator.isLastPage; * ``` */ get: function () { return this.page + 1 >= this.totalPages; }, enumerable: true, configurable: true }); Object.defineProperty(IgxPaginatorComponent.prototype, "isFirstPage", { /** * Returns if the current page is the first page. * ```typescript * const lastPage = this.paginator.isFirstPage; * ``` */ get: function () { return this.page === 0; }, enumerable: true, configurable: true }); IgxPaginatorComponent.prototype.sortUniqueOptions = function (values, newOption) { return Array.from(new Set(__spread(values, [newOption]))).sort(function (a, b) { return a - b; }); }; /** * Sets DisplayDensity for the <select> inside the paginator * @hidden */ IgxPaginatorComponent.prototype.paginatorSelectDisplayDensity = function () { 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 */ IgxPaginatorComponent.prototype.nextPage = function () { 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 */ IgxPaginatorComponent.prototype.previousPage = function () { if (!this.isFirstPage) { this.page -= 1; } }; /** * Goes to the desired page index. * ```typescript * this.pagiantor.paginate(1); * ``` * @param val * @memberof IgxPaginatorComponent */ IgxPaginatorComponent.prototype.paginate = function (val) { if (val < 0 || val > this.totalPages - 1) { return; } this.page = val; }; IgxPaginatorComponent.ctorParameters = function () { return [ { 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); return IgxPaginatorComponent; }(DisplayDensityBase)); export { IgxPaginatorComponent }; var IgxPaginatorModule = /** @class */ (function () { function IgxPaginatorModule() { } IgxPaginatorModule = __decorate([ NgModule({ declarations: [IgxPaginatorComponent], exports: [IgxPaginatorComponent], imports: [CommonModule, IgxSelectModule, FormsModule, IgxIconModule, IgxButtonModule, IgxRippleModule] }) ], IgxPaginatorModule); return 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"]}