UNPKG

@spartacus/storefront

Version:

Spartacus Storefront is a package that you can include in your application, which allows you to add default storefront features.

108 lines 14.6 kB
import { ChangeDetectionStrategy, Component, EventEmitter, Input, Output, } from '@angular/core'; import { PaginationItemType } from './pagination.model'; import * as i0 from "@angular/core"; import * as i1 from "./pagination.builder"; import * as i2 from "@angular/router"; import * as i3 from "@angular/common"; /** * The `PaginationComponent` is a generic component that is used for * all lists in Spartacus that require pagination. The component supports * all common features, which can be configured or hidden by CSS. */ export class PaginationComponent { constructor(paginationBuilder, activatedRoute) { this.paginationBuilder = paginationBuilder; this.activatedRoute = activatedRoute; this.viewPageEvent = new EventEmitter(); this.pages = []; } get pagination() { return this._pagination; } set pagination(value) { this._pagination = value; this.render(value); } render(pagination) { if (!pagination) { return; } this.pages = this.paginationBuilder.paginate(pagination.totalPages, pagination.currentPage); } /** * Format aria-label based on pagination item type. * * @param label string * @param type PaginationItemType * @returns string */ getAriaLabel(label, type) { // Convert 'Start' to First, and 'End' to Last for a more natural screen read. type = type === PaginationItemType.START ? PaginationItemType.FIRST : type; type = type === PaginationItemType.END ? PaginationItemType.LAST : type; return type === PaginationItemType.PAGE ? `${type} ${label}` : `${type} ${PaginationItemType.PAGE}`; } /** * Indicates whether the given item is the current item. * * @param item PaginationItem * @returns boolean */ isCurrent(item) { return (item.type === PaginationItemType.PAGE && item.number === this.pagination.currentPage); } /** * Indicates whether the pagination item is inactive. This is used * to disabled a link or set the tabindex to `-1`. * * Defaults to true * * @param item PaginationItem * @returns returns -1 in case of a disabled */ isInactive(item) { return (!item.hasOwnProperty('number') || item.number === this.pagination.currentPage); } getQueryParams(item) { const queryParams = Object.assign({}, this.activatedRoute.snapshot.queryParams); if (this.queryParam && item.number < this.pagination.totalPages && !this.isCurrent(item)) { queryParams[this.queryParam] = item.number; } // omit the page number from the query parameters in case it's the default // to clean up the experience and avoid unnecessary polluting of the URL if (queryParams[this.queryParam] === this.defaultPage) { delete queryParams[this.queryParam]; } return queryParams; } pageChange(page) { this.viewPageEvent.emit(page.number); } } PaginationComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.0.5", ngImport: i0, type: PaginationComponent, deps: [{ token: i1.PaginationBuilder }, { token: i2.ActivatedRoute }], target: i0.ɵɵFactoryTarget.Component }); PaginationComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.0.5", type: PaginationComponent, selector: "cx-pagination", inputs: { pageRoute: "pageRoute", queryParam: "queryParam", defaultPage: "defaultPage", pagination: "pagination" }, outputs: { viewPageEvent: "viewPageEvent" }, ngImport: i0, template: "<a\n *ngFor=\"let item of pages\"\n [class]=\"item.type\"\n [class.disabled]=\"isInactive(item)\"\n [class.current]=\"isCurrent(item)\"\n [routerLink]=\"pageRoute\"\n [queryParams]=\"getQueryParams(item)\"\n [tabIndex]=\"isInactive(item) ? -1 : 0\"\n (click)=\"pageChange(item)\"\n [attr.aria-label]=\"getAriaLabel(item.label, item.type)\"\n>\n {{ item.label }}\n</a>\n", directives: [{ type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i2.RouterLinkWithHref, selector: "a[routerLink],area[routerLink]", inputs: ["routerLink", "target", "queryParams", "fragment", "queryParamsHandling", "preserveFragment", "skipLocationChange", "replaceUrl", "state", "relativeTo"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.0.5", ngImport: i0, type: PaginationComponent, decorators: [{ type: Component, args: [{ selector: 'cx-pagination', templateUrl: './pagination.component.html', changeDetection: ChangeDetectionStrategy.OnPush, }] }], ctorParameters: function () { return [{ type: i1.PaginationBuilder }, { type: i2.ActivatedRoute }]; }, propDecorators: { pageRoute: [{ type: Input }], queryParam: [{ type: Input }], defaultPage: [{ type: Input }], pagination: [{ type: Input }], viewPageEvent: [{ type: Output }] } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"pagination.component.js","sourceRoot":"","sources":["../../../../../../../projects/storefrontlib/shared/components/list-navigation/pagination/pagination.component.ts","../../../../../../../projects/storefrontlib/shared/components/list-navigation/pagination/pagination.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  Component,\n  EventEmitter,\n  Input,\n  Output,\n} from '@angular/core';\nimport { ActivatedRoute, Params } from '@angular/router';\nimport { PaginationModel } from '@spartacus/core';\nimport { PaginationBuilder } from './pagination.builder';\nimport { PaginationItem, PaginationItemType } from './pagination.model';\n\n/**\n * The `PaginationComponent` is a generic component that is used for\n * all lists in Spartacus that require pagination. The component supports\n * all common features, which can be configured or hidden by CSS.\n */\n@Component({\n  selector: 'cx-pagination',\n  templateUrl: './pagination.component.html',\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class PaginationComponent {\n  /** The (optional) pageRoute used for the anchor links created in the pagination   */\n  @Input() pageRoute: string;\n\n  /** The (optional) query parameter which is added to the page route.  */\n  @Input() queryParam: string;\n\n  /**\n   * Whenever there's a default page specified, the routing logic\n   * will omit the page number in routeLink or parameters.\n   */\n  @Input() defaultPage;\n\n  private _pagination: PaginationModel;\n  get pagination(): PaginationModel {\n    return this._pagination;\n  }\n  @Input() set pagination(value: PaginationModel) {\n    this._pagination = value;\n    this.render(value);\n  }\n\n  @Output() viewPageEvent: EventEmitter<number> = new EventEmitter<number>();\n\n  pages: PaginationItem[] = [];\n\n  constructor(\n    private paginationBuilder: PaginationBuilder,\n    private activatedRoute: ActivatedRoute\n  ) {}\n\n  protected render(pagination: PaginationModel): void {\n    if (!pagination) {\n      return;\n    }\n    this.pages = this.paginationBuilder.paginate(\n      pagination.totalPages,\n      pagination.currentPage\n    );\n  }\n\n  /**\n   * Format aria-label based on pagination item type.\n   *\n   * @param label string\n   * @param type PaginationItemType\n   * @returns string\n   */\n  getAriaLabel(label: string, type: PaginationItemType): string {\n    // Convert 'Start' to First, and 'End' to Last for a more natural screen read.\n    type = type === PaginationItemType.START ? PaginationItemType.FIRST : type;\n    type = type === PaginationItemType.END ? PaginationItemType.LAST : type;\n    return type === PaginationItemType.PAGE\n      ? `${type} ${label}`\n      : `${type} ${PaginationItemType.PAGE}`;\n  }\n\n  /**\n   * Indicates whether the given item is the current item.\n   *\n   * @param item PaginationItem\n   * @returns boolean\n   */\n  isCurrent(item: PaginationItem): boolean {\n    return (\n      item.type === PaginationItemType.PAGE &&\n      item.number === this.pagination.currentPage\n    );\n  }\n\n  /**\n   * Indicates whether the pagination item is inactive. This is used\n   * to disabled a link or set the tabindex to `-1`.\n   *\n   * Defaults to true\n   *\n   * @param item PaginationItem\n   * @returns returns -1 in case of a disabled\n   */\n  isInactive(item: PaginationItem): boolean {\n    return (\n      !item.hasOwnProperty('number') ||\n      item.number === this.pagination.currentPage\n    );\n  }\n\n  getQueryParams(item: PaginationItem): Params {\n    const queryParams = Object.assign(\n      {},\n      this.activatedRoute.snapshot.queryParams\n    );\n    if (\n      this.queryParam &&\n      item.number < this.pagination.totalPages &&\n      !this.isCurrent(item)\n    ) {\n      queryParams[this.queryParam] = item.number;\n    }\n    // omit the page number from the query parameters in case it's the default\n    // to clean up the experience and avoid unnecessary polluting of the URL\n    if (queryParams[this.queryParam] === this.defaultPage) {\n      delete queryParams[this.queryParam];\n    }\n    return queryParams;\n  }\n\n  pageChange(page: PaginationItem): void {\n    this.viewPageEvent.emit(page.number);\n  }\n}\n","<a\n  *ngFor=\"let item of pages\"\n  [class]=\"item.type\"\n  [class.disabled]=\"isInactive(item)\"\n  [class.current]=\"isCurrent(item)\"\n  [routerLink]=\"pageRoute\"\n  [queryParams]=\"getQueryParams(item)\"\n  [tabIndex]=\"isInactive(item) ? -1 : 0\"\n  (click)=\"pageChange(item)\"\n  [attr.aria-label]=\"getAriaLabel(item.label, item.type)\"\n>\n  {{ item.label }}\n</a>\n"]}