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