@catull/igniteui-angular
Version:
Ignite UI for Angular is a dependency-free Angular toolkit for building modern web apps
296 lines • 28.4 kB
JavaScript
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> of </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"]}