UNPKG

ng-zorro-antd

Version:

An enterprise-class UI components based on Ant Design and Angular

212 lines 19.8 kB
/* eslint-disable */ /** * Use of this source code is governed by an MIT-style license that can be * found in the LICENSE file at https://github.com/NG-ZORRO/ng-zorro-antd/blob/master/LICENSE */ import { NgTemplateOutlet } from '@angular/common'; import { ChangeDetectionStrategy, Component, EventEmitter, Input, Output, ViewEncapsulation } from '@angular/core'; import { NzIconModule } from 'ng-zorro-antd/icon'; import * as i0 from "@angular/core"; import * as i1 from "ng-zorro-antd/icon"; export class NzPaginationItemComponent { constructor() { this.active = false; this.index = null; this.disabled = false; this.direction = 'ltr'; this.type = null; this.itemRender = null; this.diffIndex = new EventEmitter(); this.gotoIndex = new EventEmitter(); this.title = null; } clickItem() { if (!this.disabled) { if (this.type === 'page') { this.gotoIndex.emit(this.index); } else { this.diffIndex.emit({ next: 1, prev: -1, prev_5: -5, next_5: 5 }[this.type]); } } } ngOnChanges(changes) { const { locale, index, type } = changes; if (locale || index || type) { this.title = { page: `${this.index}`, next: this.locale?.next_page, prev: this.locale?.prev_page, prev_5: this.locale?.prev_5, next_5: this.locale?.next_5 }[this.type]; } } static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.1.2", ngImport: i0, type: NzPaginationItemComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); } static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.1.2", type: NzPaginationItemComponent, isStandalone: true, selector: "li[nz-pagination-item]", inputs: { active: "active", locale: "locale", index: "index", disabled: "disabled", direction: "direction", type: "type", itemRender: "itemRender" }, outputs: { diffIndex: "diffIndex", gotoIndex: "gotoIndex" }, host: { listeners: { "click": "clickItem()" }, properties: { "class.ant-pagination-prev": "type === 'prev'", "class.ant-pagination-next": "type === 'next'", "class.ant-pagination-item": "type === 'page'", "class.ant-pagination-jump-prev": "type === 'prev_5'", "class.ant-pagination-jump-prev-custom-icon": "type === 'prev_5'", "class.ant-pagination-jump-next": "type === 'next_5'", "class.ant-pagination-jump-next-custom-icon": "type === 'next_5'", "class.ant-pagination-disabled": "disabled", "class.ant-pagination-item-active": "active", "attr.title": "title" } }, usesOnChanges: true, ngImport: i0, template: ` <ng-template #renderItemTemplate let-type let-page="page"> @switch (type) { @case ('page') { <a>{{ page }}</a> } @case ('prev') { <button type="button" [disabled]="disabled" [attr.title]="locale.prev_page" class="ant-pagination-item-link"> @if (direction === 'rtl') { <span nz-icon nzType="right"></span> } @else { <span nz-icon nzType="left"></span> } </button> } @case ('next') { <button type="button" [disabled]="disabled" [attr.title]="locale.next_page" class="ant-pagination-item-link"> @if (direction === 'rtl') { <span nz-icon nzType="left"></span> } @else { <span nz-icon nzType="right"></span> } </button> } @default { <a class="ant-pagination-item-link"> <div class="ant-pagination-item-container"> @switch (type) { @case ('prev_5') { @if (direction === 'rtl') { <span nz-icon nzType="double-right" class="ant-pagination-item-link-icon" ></span> } @else { <span nz-icon nzType="double-left" class="ant-pagination-item-link-icon"></span> } } @case ('next_5') { @if (direction === 'rtl') { <span nz-icon nzType="double-left" class="ant-pagination-item-link-icon"></span> } @else { <span nz-icon nzType="double-right" class="ant-pagination-item-link-icon"></span> } } } <span class="ant-pagination-item-ellipsis">•••</span> </div> </a> } } </ng-template> <ng-template [ngTemplateOutlet]="itemRender || renderItemTemplate" [ngTemplateOutletContext]="{ $implicit: type, page: index }" /> `, isInline: true, dependencies: [{ kind: "ngmodule", type: NzIconModule }, { kind: "directive", type: i1.NzIconDirective, selector: "[nz-icon]", inputs: ["nzSpin", "nzRotate", "nzType", "nzTheme", "nzTwotoneColor", "nzIconfont"], exportAs: ["nzIcon"] }, { kind: "directive", type: NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); } } i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.2", ngImport: i0, type: NzPaginationItemComponent, decorators: [{ type: Component, args: [{ selector: 'li[nz-pagination-item]', preserveWhitespaces: false, encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, template: ` <ng-template #renderItemTemplate let-type let-page="page"> @switch (type) { @case ('page') { <a>{{ page }}</a> } @case ('prev') { <button type="button" [disabled]="disabled" [attr.title]="locale.prev_page" class="ant-pagination-item-link"> @if (direction === 'rtl') { <span nz-icon nzType="right"></span> } @else { <span nz-icon nzType="left"></span> } </button> } @case ('next') { <button type="button" [disabled]="disabled" [attr.title]="locale.next_page" class="ant-pagination-item-link"> @if (direction === 'rtl') { <span nz-icon nzType="left"></span> } @else { <span nz-icon nzType="right"></span> } </button> } @default { <a class="ant-pagination-item-link"> <div class="ant-pagination-item-container"> @switch (type) { @case ('prev_5') { @if (direction === 'rtl') { <span nz-icon nzType="double-right" class="ant-pagination-item-link-icon" ></span> } @else { <span nz-icon nzType="double-left" class="ant-pagination-item-link-icon"></span> } } @case ('next_5') { @if (direction === 'rtl') { <span nz-icon nzType="double-left" class="ant-pagination-item-link-icon"></span> } @else { <span nz-icon nzType="double-right" class="ant-pagination-item-link-icon"></span> } } } <span class="ant-pagination-item-ellipsis">•••</span> </div> </a> } } </ng-template> <ng-template [ngTemplateOutlet]="itemRender || renderItemTemplate" [ngTemplateOutletContext]="{ $implicit: type, page: index }" /> `, host: { '[class.ant-pagination-prev]': `type === 'prev'`, '[class.ant-pagination-next]': `type === 'next'`, '[class.ant-pagination-item]': `type === 'page'`, '[class.ant-pagination-jump-prev]': `type === 'prev_5'`, '[class.ant-pagination-jump-prev-custom-icon]': `type === 'prev_5'`, '[class.ant-pagination-jump-next]': `type === 'next_5'`, '[class.ant-pagination-jump-next-custom-icon]': `type === 'next_5'`, '[class.ant-pagination-disabled]': 'disabled', '[class.ant-pagination-item-active]': 'active', '[attr.title]': 'title', '(click)': 'clickItem()' }, imports: [NzIconModule, NgTemplateOutlet], standalone: true }] }], propDecorators: { active: [{ type: Input }], locale: [{ type: Input }], index: [{ type: Input }], disabled: [{ type: Input }], direction: [{ type: Input }], type: [{ type: Input }], itemRender: [{ type: Input }], diffIndex: [{ type: Output }], gotoIndex: [{ type: Output }] } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"pagination-item.component.js","sourceRoot":"","sources":["../../../components/pagination/pagination-item.component.ts"],"names":[],"mappings":"AAAA,oBAAoB;AACpB;;;GAGG;AAEH,OAAO,EAAE,gBAAgB,EAAE,MAAM,iBAAiB,CAAC;AACnD,OAAO,EACL,uBAAuB,EACvB,SAAS,EACT,YAAY,EACZ,KAAK,EAEL,MAAM,EAGN,iBAAiB,EAClB,MAAM,eAAe,CAAC;AAGvB,OAAO,EAAE,YAAY,EAAE,MAAM,oBAAoB,CAAC;;;AAmFlD,MAAM,OAAO,yBAAyB;IAhFtC;QAiFW,WAAM,GAAG,KAAK,CAAC;QAEf,UAAK,GAA8B,IAAI,CAAC;QACxC,aAAQ,GAAG,KAAK,CAAC;QACjB,cAAS,GAAG,KAAK,CAAC;QAClB,SAAI,GAAmD,IAAI,CAAC;QAC5D,eAAU,GAAoD,IAAI,CAAC;QACzD,cAAS,GAAG,IAAI,YAAY,EAAU,CAAC;QACvC,cAAS,GAAG,IAAI,YAAY,EAAU,CAAC;QAC1D,UAAK,GAAkB,IAAI,CAAC;KAmC7B;IAjCC,SAAS;QACP,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE,CAAC;YACnB,IAAI,IAAI,CAAC,IAAI,KAAK,MAAM,EAAE,CAAC;gBACzB,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,IAAI,CAAC,KAAM,CAAC,CAAC;YACnC,CAAC;iBAAM,CAAC;gBACN,IAAI,CAAC,SAAS,CAAC,IAAI,CAEf;oBACE,IAAI,EAAE,CAAC;oBACP,IAAI,EAAE,CAAC,CAAC;oBACR,MAAM,EAAE,CAAC,CAAC;oBACV,MAAM,EAAE,CAAC;iBAEZ,CAAC,IAAI,CAAC,IAAK,CAAC,CACd,CAAC;YACJ,CAAC;QACH,CAAC;IACH,CAAC;IAED,WAAW,CAAC,OAAsB;QAChC,MAAM,EAAE,MAAM,EAAE,KAAK,EAAE,IAAI,EAAE,GAAG,OAAO,CAAC;QACxC,IAAI,MAAM,IAAI,KAAK,IAAI,IAAI,EAAE,CAAC;YAC5B,IAAI,CAAC,KAAK,GACR;gBACE,IAAI,EAAE,GAAG,IAAI,CAAC,KAAK,EAAE;gBACrB,IAAI,EAAE,IAAI,CAAC,MAAM,EAAE,SAAS;gBAC5B,IAAI,EAAE,IAAI,CAAC,MAAM,EAAE,SAAS;gBAC5B,MAAM,EAAE,IAAI,CAAC,MAAM,EAAE,MAAM;gBAC3B,MAAM,EAAE,IAAI,CAAC,MAAM,EAAE,MAAM;aAE9B,CAAC,IAAI,CAAC,IAAK,CAAC,CAAC;QAChB,CAAC;IACH,CAAC;8GA5CU,yBAAyB;kGAAzB,yBAAyB,i3BA3E1B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA0DT,2DAcS,YAAY,kNAAE,gBAAgB;;2FAG7B,yBAAyB;kBAhFrC,SAAS;mBAAC;oBACT,QAAQ,EAAE,wBAAwB;oBAClC,mBAAmB,EAAE,KAAK;oBAC1B,aAAa,EAAE,iBAAiB,CAAC,IAAI;oBACrC,eAAe,EAAE,uBAAuB,CAAC,MAAM;oBAC/C,QAAQ,EAAE;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA0DT;oBACD,IAAI,EAAE;wBACJ,6BAA6B,EAAE,iBAAiB;wBAChD,6BAA6B,EAAE,iBAAiB;wBAChD,6BAA6B,EAAE,iBAAiB;wBAChD,kCAAkC,EAAE,mBAAmB;wBACvD,8CAA8C,EAAE,mBAAmB;wBACnE,kCAAkC,EAAE,mBAAmB;wBACvD,8CAA8C,EAAE,mBAAmB;wBACnE,iCAAiC,EAAE,UAAU;wBAC7C,oCAAoC,EAAE,QAAQ;wBAC9C,cAAc,EAAE,OAAO;wBACvB,SAAS,EAAE,aAAa;qBACzB;oBACD,OAAO,EAAE,CAAC,YAAY,EAAE,gBAAgB,CAAC;oBACzC,UAAU,EAAE,IAAI;iBACjB;8BAEU,MAAM;sBAAd,KAAK;gBACG,MAAM;sBAAd,KAAK;gBACG,KAAK;sBAAb,KAAK;gBACG,QAAQ;sBAAhB,KAAK;gBACG,SAAS;sBAAjB,KAAK;gBACG,IAAI;sBAAZ,KAAK;gBACG,UAAU;sBAAlB,KAAK;gBACa,SAAS;sBAA3B,MAAM;gBACY,SAAS;sBAA3B,MAAM","sourcesContent":["/* eslint-disable */\n/**\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://github.com/NG-ZORRO/ng-zorro-antd/blob/master/LICENSE\n */\n\nimport { NgTemplateOutlet } from '@angular/common';\nimport {\n  ChangeDetectionStrategy,\n  Component,\n  EventEmitter,\n  Input,\n  OnChanges,\n  Output,\n  SimpleChanges,\n  TemplateRef,\n  ViewEncapsulation\n} from '@angular/core';\nimport { NzSafeAny } from 'ng-zorro-antd/core/types';\nimport { NzPaginationI18nInterface } from 'ng-zorro-antd/i18n';\nimport { NzIconModule } from 'ng-zorro-antd/icon';\nimport { PaginationItemRenderContext, PaginationItemType } from './pagination.types';\n\n@Component({\n  selector: 'li[nz-pagination-item]',\n  preserveWhitespaces: false,\n  encapsulation: ViewEncapsulation.None,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  template: `\n    <ng-template #renderItemTemplate let-type let-page=\"page\">\n      @switch (type) {\n        @case ('page') {\n          <a>{{ page }}</a>\n        }\n        @case ('prev') {\n          <button type=\"button\" [disabled]=\"disabled\" [attr.title]=\"locale.prev_page\" class=\"ant-pagination-item-link\">\n            @if (direction === 'rtl') {\n              <span nz-icon nzType=\"right\"></span>\n            } @else {\n              <span nz-icon nzType=\"left\"></span>\n            }\n          </button>\n        }\n        @case ('next') {\n          <button type=\"button\" [disabled]=\"disabled\" [attr.title]=\"locale.next_page\" class=\"ant-pagination-item-link\">\n            @if (direction === 'rtl') {\n              <span nz-icon nzType=\"left\"></span>\n            } @else {\n              <span nz-icon nzType=\"right\"></span>\n            }\n          </button>\n        }\n        @default {\n          <a class=\"ant-pagination-item-link\">\n            <div class=\"ant-pagination-item-container\">\n              @switch (type) {\n                @case ('prev_5') {\n                  @if (direction === 'rtl') {\n                    <span\n                      nz-icon\n                      nzType=\"double-right\"\n                      class=\"ant-pagination-item-link-icon\"\n                    ></span>\n                  } @else {\n                    <span nz-icon nzType=\"double-left\" class=\"ant-pagination-item-link-icon\"></span>\n                  }\n                }\n                @case ('next_5') {\n                  @if (direction === 'rtl') {\n                    <span nz-icon nzType=\"double-left\"\n                          class=\"ant-pagination-item-link-icon\"></span>\n                  } @else {\n                    <span nz-icon nzType=\"double-right\" class=\"ant-pagination-item-link-icon\"></span>\n                  }\n                }\n              }\n              <span class=\"ant-pagination-item-ellipsis\">•••</span>\n            </div>\n          </a>\n        }\n      }\n    </ng-template>\n    <ng-template\n      [ngTemplateOutlet]=\"itemRender || renderItemTemplate\"\n      [ngTemplateOutletContext]=\"{ $implicit: type, page: index }\"\n    />\n  `,\n  host: {\n    '[class.ant-pagination-prev]': `type === 'prev'`,\n    '[class.ant-pagination-next]': `type === 'next'`,\n    '[class.ant-pagination-item]': `type === 'page'`,\n    '[class.ant-pagination-jump-prev]': `type === 'prev_5'`,\n    '[class.ant-pagination-jump-prev-custom-icon]': `type === 'prev_5'`,\n    '[class.ant-pagination-jump-next]': `type === 'next_5'`,\n    '[class.ant-pagination-jump-next-custom-icon]': `type === 'next_5'`,\n    '[class.ant-pagination-disabled]': 'disabled',\n    '[class.ant-pagination-item-active]': 'active',\n    '[attr.title]': 'title',\n    '(click)': 'clickItem()'\n  },\n  imports: [NzIconModule, NgTemplateOutlet],\n  standalone: true\n})\nexport class NzPaginationItemComponent implements OnChanges {\n  @Input() active = false;\n  @Input() locale!: NzPaginationI18nInterface;\n  @Input() index: number | null | undefined = null;\n  @Input() disabled = false;\n  @Input() direction = 'ltr';\n  @Input() type: PaginationItemType | string | null | undefined = null;\n  @Input() itemRender: TemplateRef<PaginationItemRenderContext> | null = null;\n  @Output() readonly diffIndex = new EventEmitter<number>();\n  @Output() readonly gotoIndex = new EventEmitter<number>();\n  title: string | null = null;\n\n  clickItem(): void {\n    if (!this.disabled) {\n      if (this.type === 'page') {\n        this.gotoIndex.emit(this.index!);\n      } else {\n        this.diffIndex.emit(\n          (\n            {\n              next: 1,\n              prev: -1,\n              prev_5: -5,\n              next_5: 5\n            } as NzSafeAny\n          )[this.type!]\n        );\n      }\n    }\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    const { locale, index, type } = changes;\n    if (locale || index || type) {\n      this.title = (\n        {\n          page: `${this.index}`,\n          next: this.locale?.next_page,\n          prev: this.locale?.prev_page,\n          prev_5: this.locale?.prev_5,\n          next_5: this.locale?.next_5\n        } as NzSafeAny\n      )[this.type!];\n    }\n  }\n}\n"]}