UNPKG

ng-zorro-antd

Version:

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

101 lines 12.4 kB
/** * 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 { ChangeDetectionStrategy, Component, EventEmitter, Input, Output, ViewEncapsulation } from '@angular/core'; export class NzPaginationItemComponent { constructor() { this.active = false; this.index = null; this.disabled = false; 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) { var _a, _b, _c, _d; const { locale, index, type } = changes; if (locale || index || type) { this.title = { page: `${this.index}`, next: (_a = this.locale) === null || _a === void 0 ? void 0 : _a.next_page, prev: (_b = this.locale) === null || _b === void 0 ? void 0 : _b.prev_page, prev_5: (_c = this.locale) === null || _c === void 0 ? void 0 : _c.prev_5, next_5: (_d = this.locale) === null || _d === void 0 ? void 0 : _d.next_5 }[this.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"> <ng-container [ngSwitch]="type"> <a *ngSwitchCase="'page'">{{ page }}</a> <button [disabled]="disabled" class="ant-pagination-item-link" *ngSwitchCase="'prev'"><i nz-icon nzType="left"></i></button> <button [disabled]="disabled" class="ant-pagination-item-link" *ngSwitchCase="'next'"><i nz-icon nzType="right"></i></button> <ng-container *ngSwitchDefault> <a class="ant-pagination-item-link" [ngSwitch]="type"> <div class="ant-pagination-item-container" *ngSwitchDefault> <ng-container [ngSwitch]="type"> <i *ngSwitchCase="'prev_5'" nz-icon nzType="double-left" class="ant-pagination-item-link-icon"></i> <i *ngSwitchCase="'next_5'" nz-icon nzType="double-right" class="ant-pagination-item-link-icon"></i> </ng-container> <span class="ant-pagination-item-ellipsis">•••</span> </div> </a> </ng-container> </ng-container> </ng-template> <ng-template [ngTemplateOutlet]="itemRender || renderItemTemplate" [ngTemplateOutletContext]="{ $implicit: type, page: index }" ></ng-template> `, 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()' } },] } ]; NzPaginationItemComponent.propDecorators = { active: [{ type: Input }], locale: [{ type: Input }], index: [{ type: Input }], disabled: [{ 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":"/home/vsts/work/1/s/components/pagination/","sources":["pagination-item.component.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAEH,OAAO,EACL,uBAAuB,EACvB,SAAS,EACT,YAAY,EACZ,KAAK,EAEL,MAAM,EAGN,iBAAiB,EAClB,MAAM,eAAe,CAAC;AAgDvB,MAAM,OAAO,yBAAyB;IA3CtC;QA+CW,WAAM,GAAG,KAAK,CAAC;QAEf,UAAK,GAAkB,IAAI,CAAC;QAC5B,aAAQ,GAAG,KAAK,CAAC;QACjB,SAAI,GAAuC,IAAI,CAAC;QAChD,eAAU,GAAoD,IAAI,CAAC;QACzD,cAAS,GAAG,IAAI,YAAY,EAAU,CAAC;QACvC,cAAS,GAAG,IAAI,YAAY,EAAU,CAAC;QAC1D,UAAK,GAAkB,IAAI,CAAC;IA6B9B,CAAC;IA5BC,SAAS;QACP,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE;YAClB,IAAI,IAAI,CAAC,IAAI,KAAK,MAAM,EAAE;gBACxB,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,IAAI,CAAC,KAAM,CAAC,CAAC;aAClC;iBAAM;gBACL,IAAI,CAAC,SAAS,CAAC,IAAI,CAChB;oBACC,IAAI,EAAE,CAAC;oBACP,IAAI,EAAE,CAAC,CAAC;oBACR,MAAM,EAAE,CAAC,CAAC;oBACV,MAAM,EAAE,CAAC;iBACI,CAAC,IAAI,CAAC,IAAK,CAAC,CAC5B,CAAC;aACH;SACF;IACH,CAAC;IACD,WAAW,CAAC,OAAsB;;QAChC,MAAM,EAAE,MAAM,EAAE,KAAK,EAAE,IAAI,EAAE,GAAG,OAAO,CAAC;QACxC,IAAI,MAAM,IAAI,KAAK,IAAI,IAAI,EAAE;YAC3B,IAAI,CAAC,KAAK,GAAI;gBACZ,IAAI,EAAE,GAAG,IAAI,CAAC,KAAK,EAAE;gBACrB,IAAI,QAAE,IAAI,CAAC,MAAM,0CAAE,SAAS;gBAC5B,IAAI,QAAE,IAAI,CAAC,MAAM,0CAAE,SAAS;gBAC5B,MAAM,QAAE,IAAI,CAAC,MAAM,0CAAE,MAAM;gBAC3B,MAAM,QAAE,IAAI,CAAC,MAAM,0CAAE,MAAM;aACd,CAAC,IAAI,CAAC,IAAK,CAAC,CAAC;SAC7B;IACH,CAAC;;;YAnFF,SAAS,SAAC;gBACT,QAAQ,EAAE,wBAAwB;gBAClC,mBAAmB,EAAE,KAAK;gBAC1B,aAAa,EAAE,iBAAiB,CAAC,IAAI;gBACrC,eAAe,EAAE,uBAAuB,CAAC,MAAM;gBAC/C,QAAQ,EAAE;;;;;;;;;;;;;;;;;;;;;;;GAuBT;gBACD,IAAI,EAAE;oBACJ,6BAA6B,EAAE,iBAAiB;oBAChD,6BAA6B,EAAE,iBAAiB;oBAChD,6BAA6B,EAAE,iBAAiB;oBAChD,kCAAkC,EAAE,mBAAmB;oBACvD,8CAA8C,EAAE,mBAAmB;oBACnE,kCAAkC,EAAE,mBAAmB;oBACvD,8CAA8C,EAAE,mBAAmB;oBACnE,iCAAiC,EAAE,UAAU;oBAC7C,qCAAqC,EAAE,QAAQ;oBAC/C,cAAc,EAAE,OAAO;oBACvB,SAAS,EAAE,aAAa;iBACzB;aACF;;;qBAKE,KAAK;qBACL,KAAK;oBACL,KAAK;uBACL,KAAK;mBACL,KAAK;yBACL,KAAK;wBACL,MAAM;wBACN,MAAM","sourcesContent":["/**\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 {\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 { 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      <ng-container [ngSwitch]=\"type\">\n        <a *ngSwitchCase=\"'page'\">{{ page }}</a>\n        <button [disabled]=\"disabled\" class=\"ant-pagination-item-link\" *ngSwitchCase=\"'prev'\"><i nz-icon nzType=\"left\"></i></button>\n        <button [disabled]=\"disabled\" class=\"ant-pagination-item-link\" *ngSwitchCase=\"'next'\"><i nz-icon nzType=\"right\"></i></button>\n        <ng-container *ngSwitchDefault>\n          <a class=\"ant-pagination-item-link\" [ngSwitch]=\"type\">\n            <div class=\"ant-pagination-item-container\" *ngSwitchDefault>\n              <ng-container [ngSwitch]=\"type\">\n                <i *ngSwitchCase=\"'prev_5'\" nz-icon nzType=\"double-left\" class=\"ant-pagination-item-link-icon\"></i>\n                <i *ngSwitchCase=\"'next_5'\" nz-icon nzType=\"double-right\" class=\"ant-pagination-item-link-icon\"></i>\n              </ng-container>\n              <span class=\"ant-pagination-item-ellipsis\">•••</span>\n            </div>\n          </a>\n        </ng-container>\n      </ng-container>\n    </ng-template>\n    <ng-template\n      [ngTemplateOutlet]=\"itemRender || renderItemTemplate\"\n      [ngTemplateOutletContext]=\"{ $implicit: type, page: index }\"\n    ></ng-template>\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})\nexport class NzPaginationItemComponent implements OnChanges {\n  static ngAcceptInputType_type: PaginationItemType | string | null | undefined;\n  static ngAcceptInputType_index: number | null | undefined;\n\n  @Input() active = false;\n  @Input() locale!: NzPaginationI18nInterface;\n  @Input() index: number | null = null;\n  @Input() disabled = false;\n  @Input() type: PaginationItemType | string | null = 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  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            next: 1,\n            prev: -1,\n            prev_5: -5,\n            next_5: 5\n          } as NzSafeAny)[this.type!]\n        );\n      }\n    }\n  }\n  ngOnChanges(changes: SimpleChanges): void {\n    const { locale, index, type } = changes;\n    if (locale || index || type) {\n      this.title = ({\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)[this.type!];\n    }\n  }\n}\n"]}