UNPKG

ng-zorro-antd

Version:

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

425 lines 33.8 kB
/** * @fileoverview added by tsickle * @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ import * as tslib_1 from "tslib"; import { ChangeDetectionStrategy, ChangeDetectorRef, Component, EventEmitter, Input, Output, ViewChild, ViewEncapsulation } from '@angular/core'; import { Subject } from 'rxjs'; import { takeUntil } from 'rxjs/operators'; import { isNotNil } from '../core/util/check'; import { InputBoolean } from '../core/util/convert'; import { NzDropDownComponent } from '../dropdown/nz-dropdown.component'; import { NzI18nService } from '../i18n/nz-i18n.service'; /** * @record */ export function NzThItemInterface() { } if (false) { /** @type {?} */ NzThItemInterface.prototype.text; /** @type {?} */ NzThItemInterface.prototype.value; /** @type {?} */ NzThItemInterface.prototype.checked; } export class NzThComponent { /** * @param {?} cdr * @param {?} i18n */ constructor(cdr, i18n) { this.cdr = cdr; this.i18n = i18n; this.hasFilterValue = false; this.filterVisible = false; this.multipleFilterList = []; this.singleFilterList = []; /* tslint:disable-next-line:no-any */ this.locale = (/** @type {?} */ ({})); this.nzWidthChange$ = new Subject(); this.destroy$ = new Subject(); this.hasDefaultFilter = false; /* tslint:disable-next-line:no-any */ this.nzSelections = []; this.nzChecked = false; this.nzDisabled = false; this.nzIndeterminate = false; this.nzFilterMultiple = true; this.nzSort = null; this.nzFilters = []; this.nzExpand = false; this.nzShowCheckbox = false; this.nzCustomFilter = false; this.nzShowSort = false; this.nzShowFilter = false; this.nzShowRowSelection = false; this.nzCheckedChange = new EventEmitter(); this.nzSortChange = new EventEmitter(); this.nzSortChangeWithKey = new EventEmitter(); /* tslint:disable-next-line:no-any */ this.nzFilterChange = new EventEmitter(); } /** * @return {?} */ updateSortValue() { if (this.nzShowSort) { if (this.nzSort === 'descend') { this.setSortValue('ascend'); } else if (this.nzSort === 'ascend') { this.setSortValue(null); } else { this.setSortValue('descend'); } } } /** * @param {?} value * @return {?} */ setSortValue(value) { this.nzSort = value; this.nzSortChangeWithKey.emit({ key: this.nzSortKey, value: this.nzSort }); this.nzSortChange.emit(this.nzSort); } /** * @return {?} */ get filterList() { return this.multipleFilterList.filter((/** * @param {?} item * @return {?} */ item => item.checked)).map((/** * @param {?} item * @return {?} */ item => item.value)); } /* tslint:disable-next-line:no-any */ /** * @return {?} */ get filterValue() { /** @type {?} */ const checkedFilter = this.singleFilterList.find((/** * @param {?} item * @return {?} */ item => item.checked)); return checkedFilter ? checkedFilter.value : null; } /** * @return {?} */ updateFilterStatus() { if (this.nzFilterMultiple) { this.hasFilterValue = this.filterList.length > 0; } else { this.hasFilterValue = isNotNil(this.filterValue); } } /** * @return {?} */ search() { this.updateFilterStatus(); if (this.nzFilterMultiple) { this.nzFilterChange.emit(this.filterList); } else { this.nzFilterChange.emit(this.filterValue); } } /** * @return {?} */ reset() { this.initMultipleFilterList(true); this.initSingleFilterList(true); this.hasFilterValue = false; } /** * @param {?} filter * @return {?} */ checkMultiple(filter) { filter.checked = !filter.checked; } /** * @param {?} filter * @return {?} */ checkSingle(filter) { this.singleFilterList.forEach((/** * @param {?} item * @return {?} */ item => item.checked = item === filter)); } /** * @return {?} */ hideDropDown() { this.nzDropDownComponent.setVisibleStateWhen(false); this.filterVisible = false; } /** * @param {?} value * @return {?} */ dropDownVisibleChange(value) { this.filterVisible = value; if (!value) { this.search(); } } /** * @param {?=} force * @return {?} */ initMultipleFilterList(force) { this.multipleFilterList = this.nzFilters.map((/** * @param {?} item * @return {?} */ item => { /** @type {?} */ const checked = force ? false : !!item.byDefault; if (checked) { this.hasDefaultFilter = true; } return { text: item.text, value: item.value, checked }; })); this.checkDefaultFilters(); } /** * @param {?=} force * @return {?} */ initSingleFilterList(force) { this.singleFilterList = this.nzFilters.map((/** * @param {?} item * @return {?} */ item => { /** @type {?} */ const checked = force ? false : !!item.byDefault; if (checked) { this.hasDefaultFilter = true; } return { text: item.text, value: item.value, checked }; })); this.checkDefaultFilters(); } /** * @return {?} */ checkDefaultFilters() { if (!this.nzFilters || this.nzFilters.length === 0 || !this.hasDefaultFilter) { return; } this.updateFilterStatus(); } /** * @return {?} */ marForCheck() { this.cdr.markForCheck(); } /** * @return {?} */ ngOnInit() { this.i18n.localeChange.pipe(takeUntil(this.destroy$)).subscribe((/** * @return {?} */ () => { this.locale = this.i18n.getLocaleData('Table'); this.cdr.markForCheck(); })); } /** * @param {?} changes * @return {?} */ ngOnChanges(changes) { if (changes.nzFilters) { this.initMultipleFilterList(); this.initSingleFilterList(); this.updateFilterStatus(); } if (changes.nzWidth) { this.nzWidthChange$.next(this.nzWidth); } } /** * @return {?} */ ngOnDestroy() { this.destroy$.next(); this.destroy$.complete(); } } NzThComponent.decorators = [ { type: Component, args: [{ // tslint:disable-next-line:component-selector selector: 'th:not(.nz-disable-th)', preserveWhitespaces: false, encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, template: "<ng-template #checkboxTemplate>\n <label nz-checkbox\n [class.ant-table-selection-select-all-custom]=\"nzShowRowSelection\"\n [(ngModel)]=\"nzChecked\"\n [nzDisabled]=\"nzDisabled\"\n [nzIndeterminate]=\"nzIndeterminate\"\n (ngModelChange)=\"nzCheckedChange.emit($event)\">\n </label>\n</ng-template>\n<div [class.ant-table-column-sorters]=\"nzShowSort\" (click)=\"updateSortValue()\">\n <div class=\"ant-table-selection\" *ngIf=\"nzShowRowSelection\">\n <ng-container *ngIf=\"nzShowCheckbox\">\n <ng-template [ngTemplateOutlet]=\"checkboxTemplate\"></ng-template>\n </ng-container>\n <nz-dropdown nzPlacement=\"bottomLeft\">\n <div nz-dropdown class=\"ant-table-selection-down\">\n <i nz-icon type=\"down\"></i>\n </div>\n <ul nz-menu class=\"ant-table-selection-menu\">\n <li nz-menu-item *ngFor=\"let selection of nzSelections\" (click)=\"selection.onSelect()\">{{selection.text}}</li>\n </ul>\n </nz-dropdown>\n </div>\n <ng-container *ngIf=\"nzShowCheckbox && !nzShowRowSelection\">\n <ng-template [ngTemplateOutlet]=\"checkboxTemplate\"></ng-template>\n </ng-container>\n <ng-content></ng-content>\n <div class=\"ant-table-column-sorter\" *ngIf=\"nzShowSort\">\n <i nz-icon\n type=\"caret-up\"\n class=\"ant-table-column-sorter-up\"\n [class.on]=\"nzSort == 'ascend'\"\n [class.off]=\"nzSort != 'ascend'\"></i>\n <i nz-icon\n type=\"caret-down\"\n class=\"ant-table-column-sorter-down\"\n [class.on]=\"nzSort == 'descend'\"\n [class.off]=\"nzSort != 'descend'\"></i>\n </div>\n</div>\n<nz-dropdown nzTrigger=\"click\" *ngIf=\"nzShowFilter\" [nzClickHide]=\"false\" nzTableFilter (nzVisibleChange)=\"dropDownVisibleChange($event)\">\n <i nz-icon type=\"filter\" theme=\"fill\" [class.ant-table-filter-selected]=\"hasFilterValue\" [class.ant-table-filter-open]=\"filterVisible\" nz-dropdown></i>\n <ul nz-menu>\n <ng-container *ngIf=\"nzFilterMultiple\">\n <li nz-menu-item *ngFor=\"let filter of multipleFilterList\" (click)=\"checkMultiple(filter)\">\n <label nz-checkbox [ngModel]=\"filter.checked\" (ngModelChange)=\"checkMultiple(filter)\"></label><span>{{filter.text}}</span>\n </li>\n </ng-container>\n <ng-container *ngIf=\"!nzFilterMultiple\">\n <li nz-menu-item *ngFor=\"let filter of singleFilterList\" (click)=\"checkSingle(filter)\">\n <label nz-radio [ngModel]=\"filter.checked\" (ngModelChange)=\"checkSingle(filter)\">{{filter.text}}</label>\n </li>\n </ng-container>\n </ul>\n <div class=\"ant-table-filter-dropdown-btns\">\n <a class=\"ant-table-filter-dropdown-link confirm\" (click)=\"hideDropDown()\">\n <span>{{ locale.filterConfirm }}</span>\n </a>\n <a class=\"ant-table-filter-dropdown-link clear\" (click)=\"reset();hideDropDown()\">\n <span>{{ locale.filterReset }}</span>\n </a>\n </div>\n</nz-dropdown>\n", host: { '[class.ant-table-column-has-actions]': 'nzShowFilter || nzShowSort || nzCustomFilter', '[class.ant-table-column-has-filters]': 'nzShowFilter || nzCustomFilter', '[class.ant-table-column-has-sorters]': 'nzShowSort', '[class.ant-table-selection-column-custom]': 'nzShowRowSelection', '[class.ant-table-selection-column]': 'nzShowCheckbox', '[class.ant-table-expand-icon-th]': 'nzExpand', '[class.ant-table-th-left-sticky]': 'nzLeft', '[class.ant-table-th-right-sticky]': 'nzRight', '[class.ant-table-column-sort]': `nzSort === 'descend' || nzSort === 'ascend'`, '[style.left]': 'nzLeft', '[style.right]': 'nzRight', '[style.text-align]': 'nzAlign' } }] } ]; /** @nocollapse */ NzThComponent.ctorParameters = () => [ { type: ChangeDetectorRef }, { type: NzI18nService } ]; NzThComponent.propDecorators = { nzDropDownComponent: [{ type: ViewChild, args: [NzDropDownComponent,] }], nzSelections: [{ type: Input }], nzChecked: [{ type: Input }], nzDisabled: [{ type: Input }], nzIndeterminate: [{ type: Input }], nzSortKey: [{ type: Input }], nzFilterMultiple: [{ type: Input }], nzWidth: [{ type: Input }], nzLeft: [{ type: Input }], nzRight: [{ type: Input }], nzAlign: [{ type: Input }], nzSort: [{ type: Input }], nzFilters: [{ type: Input }], nzExpand: [{ type: Input }], nzShowCheckbox: [{ type: Input }], nzCustomFilter: [{ type: Input }], nzShowSort: [{ type: Input }], nzShowFilter: [{ type: Input }], nzShowRowSelection: [{ type: Input }], nzCheckedChange: [{ type: Output }], nzSortChange: [{ type: Output }], nzSortChangeWithKey: [{ type: Output }], nzFilterChange: [{ type: Output }] }; tslib_1.__decorate([ InputBoolean(), tslib_1.__metadata("design:type", Object) ], NzThComponent.prototype, "nzExpand", void 0); tslib_1.__decorate([ InputBoolean(), tslib_1.__metadata("design:type", Object) ], NzThComponent.prototype, "nzShowCheckbox", void 0); tslib_1.__decorate([ InputBoolean(), tslib_1.__metadata("design:type", Object) ], NzThComponent.prototype, "nzCustomFilter", void 0); tslib_1.__decorate([ InputBoolean(), tslib_1.__metadata("design:type", Object) ], NzThComponent.prototype, "nzShowSort", void 0); tslib_1.__decorate([ InputBoolean(), tslib_1.__metadata("design:type", Object) ], NzThComponent.prototype, "nzShowFilter", void 0); tslib_1.__decorate([ InputBoolean(), tslib_1.__metadata("design:type", Object) ], NzThComponent.prototype, "nzShowRowSelection", void 0); if (false) { /** @type {?} */ NzThComponent.prototype.hasFilterValue; /** @type {?} */ NzThComponent.prototype.filterVisible; /** @type {?} */ NzThComponent.prototype.multipleFilterList; /** @type {?} */ NzThComponent.prototype.singleFilterList; /** @type {?} */ NzThComponent.prototype.locale; /** @type {?} */ NzThComponent.prototype.nzWidthChange$; /** * @type {?} * @private */ NzThComponent.prototype.destroy$; /** * @type {?} * @private */ NzThComponent.prototype.hasDefaultFilter; /** @type {?} */ NzThComponent.prototype.nzDropDownComponent; /** @type {?} */ NzThComponent.prototype.nzSelections; /** @type {?} */ NzThComponent.prototype.nzChecked; /** @type {?} */ NzThComponent.prototype.nzDisabled; /** @type {?} */ NzThComponent.prototype.nzIndeterminate; /** @type {?} */ NzThComponent.prototype.nzSortKey; /** @type {?} */ NzThComponent.prototype.nzFilterMultiple; /** @type {?} */ NzThComponent.prototype.nzWidth; /** @type {?} */ NzThComponent.prototype.nzLeft; /** @type {?} */ NzThComponent.prototype.nzRight; /** @type {?} */ NzThComponent.prototype.nzAlign; /** @type {?} */ NzThComponent.prototype.nzSort; /** @type {?} */ NzThComponent.prototype.nzFilters; /** @type {?} */ NzThComponent.prototype.nzExpand; /** @type {?} */ NzThComponent.prototype.nzShowCheckbox; /** @type {?} */ NzThComponent.prototype.nzCustomFilter; /** @type {?} */ NzThComponent.prototype.nzShowSort; /** @type {?} */ NzThComponent.prototype.nzShowFilter; /** @type {?} */ NzThComponent.prototype.nzShowRowSelection; /** @type {?} */ NzThComponent.prototype.nzCheckedChange; /** @type {?} */ NzThComponent.prototype.nzSortChange; /** @type {?} */ NzThComponent.prototype.nzSortChangeWithKey; /** @type {?} */ NzThComponent.prototype.nzFilterChange; /** * @type {?} * @private */ NzThComponent.prototype.cdr; /** * @type {?} * @private */ NzThComponent.prototype.i18n; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"nz-th.component.js","sourceRoot":"ng://ng-zorro-antd/","sources":["table/nz-th.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  EventEmitter,\n  Input,\n  OnChanges, OnDestroy, OnInit,\n  Output,\n  SimpleChanges,\n  ViewChild,\n  ViewEncapsulation\n} from '@angular/core';\nimport { Subject } from 'rxjs';\nimport { takeUntil } from 'rxjs/operators';\nimport { isNotNil } from '../core/util/check';\nimport { InputBoolean } from '../core/util/convert';\nimport { NzDropDownComponent } from '../dropdown/nz-dropdown.component';\nimport { NzI18nInterface } from '../i18n/nz-i18n.interface';\nimport { NzI18nService } from '../i18n/nz-i18n.service';\n\n/* tslint:disable-next-line:no-any */\nexport type NzThFilterType = Array<{ text: string; value: any; byDefault?: boolean }>;\n\nexport interface NzThItemInterface {\n  text: string;\n  /* tslint:disable-next-line:no-any */\n  value: any;\n  checked: boolean;\n}\n\n@Component({\n  // tslint:disable-next-line:component-selector\n  selector           : 'th:not(.nz-disable-th)',\n  preserveWhitespaces: false,\n  encapsulation      : ViewEncapsulation.None,\n  changeDetection    : ChangeDetectionStrategy.OnPush,\n  templateUrl        : './nz-th.component.html',\n  host               : {\n    '[class.ant-table-column-has-actions]'     : 'nzShowFilter || nzShowSort || nzCustomFilter',\n    '[class.ant-table-column-has-filters]'     : 'nzShowFilter || nzCustomFilter',\n    '[class.ant-table-column-has-sorters]'     : 'nzShowSort',\n    '[class.ant-table-selection-column-custom]': 'nzShowRowSelection',\n    '[class.ant-table-selection-column]'       : 'nzShowCheckbox',\n    '[class.ant-table-expand-icon-th]'         : 'nzExpand',\n    '[class.ant-table-th-left-sticky]'         : 'nzLeft',\n    '[class.ant-table-th-right-sticky]'        : 'nzRight',\n    '[class.ant-table-column-sort]'            : `nzSort === 'descend' || nzSort === 'ascend'`,\n    '[style.left]'                             : 'nzLeft',\n    '[style.right]'                            : 'nzRight',\n    '[style.text-align]'                       : 'nzAlign'\n  }\n})\nexport class NzThComponent implements OnChanges, OnInit, OnDestroy {\n  hasFilterValue = false;\n  filterVisible = false;\n  multipleFilterList: NzThItemInterface[] = [];\n  singleFilterList: NzThItemInterface[] = [];\n  /* tslint:disable-next-line:no-any */\n  locale: NzI18nInterface['Table'] = {} as NzI18nInterface['Table'];\n  nzWidthChange$ = new Subject();\n  private destroy$ = new Subject();\n  private hasDefaultFilter = false;\n  @ViewChild(NzDropDownComponent) nzDropDownComponent: NzDropDownComponent;\n  /* tslint:disable-next-line:no-any */\n  @Input() nzSelections: Array<{ text: string, onSelect(...args: any[]): any; }> = [];\n  @Input() nzChecked = false;\n  @Input() nzDisabled = false;\n  @Input() nzIndeterminate = false;\n  @Input() nzSortKey: string;\n  @Input() nzFilterMultiple = true;\n  @Input() nzWidth: string;\n  @Input() nzLeft: string;\n  @Input() nzRight: string;\n  @Input() nzAlign: 'left' | 'right' | 'center';\n  @Input() nzSort: 'ascend' | 'descend' = null;\n  @Input() nzFilters: NzThFilterType = [];\n  @Input() @InputBoolean() nzExpand = false;\n  @Input() @InputBoolean() nzShowCheckbox = false;\n  @Input() @InputBoolean() nzCustomFilter = false;\n  @Input() @InputBoolean() nzShowSort = false;\n  @Input() @InputBoolean() nzShowFilter = false;\n  @Input() @InputBoolean() nzShowRowSelection = false;\n  @Output() readonly nzCheckedChange = new EventEmitter<boolean>();\n  @Output() readonly nzSortChange = new EventEmitter<string>();\n  @Output() readonly nzSortChangeWithKey = new EventEmitter<{ key: string, value: string }>();\n  /* tslint:disable-next-line:no-any */\n  @Output() readonly nzFilterChange = new EventEmitter<any[] | any>();\n\n  updateSortValue(): void {\n    if (this.nzShowSort) {\n      if (this.nzSort === 'descend') {\n        this.setSortValue('ascend');\n      } else if (this.nzSort === 'ascend') {\n        this.setSortValue(null);\n      } else {\n        this.setSortValue('descend');\n      }\n    }\n  }\n\n  setSortValue(value: 'ascend' | 'descend'): void {\n    this.nzSort = value;\n    this.nzSortChangeWithKey.emit({ key: this.nzSortKey, value: this.nzSort });\n    this.nzSortChange.emit(this.nzSort);\n  }\n\n  get filterList(): NzThItemInterface[] {\n    return this.multipleFilterList.filter(item => item.checked).map(item => item.value);\n  }\n\n  /* tslint:disable-next-line:no-any */\n  get filterValue(): any {\n    const checkedFilter = this.singleFilterList.find(item => item.checked);\n    return checkedFilter ? checkedFilter.value : null;\n  }\n\n  updateFilterStatus(): void {\n    if (this.nzFilterMultiple) {\n      this.hasFilterValue = this.filterList.length > 0;\n    } else {\n      this.hasFilterValue = isNotNil(this.filterValue);\n    }\n  }\n\n  search(): void {\n    this.updateFilterStatus();\n    if (this.nzFilterMultiple) {\n      this.nzFilterChange.emit(this.filterList);\n    } else {\n      this.nzFilterChange.emit(this.filterValue);\n    }\n  }\n\n  reset(): void {\n    this.initMultipleFilterList(true);\n    this.initSingleFilterList(true);\n    this.hasFilterValue = false;\n  }\n\n  checkMultiple(filter: NzThItemInterface): void {\n    filter.checked = !filter.checked;\n  }\n\n  checkSingle(filter: NzThItemInterface): void {\n    this.singleFilterList.forEach(item => item.checked = item === filter);\n  }\n\n  hideDropDown(): void {\n    this.nzDropDownComponent.setVisibleStateWhen(false);\n    this.filterVisible = false;\n  }\n\n  dropDownVisibleChange(value: boolean): void {\n    this.filterVisible = value;\n    if (!value) {\n      this.search();\n    }\n  }\n\n  initMultipleFilterList(force?: boolean): void {\n    this.multipleFilterList = this.nzFilters.map(item => {\n      const checked = force ? false : !!item.byDefault;\n      if (checked) {\n        this.hasDefaultFilter = true;\n      }\n      return { text: item.text, value: item.value, checked };\n    });\n    this.checkDefaultFilters();\n  }\n\n  initSingleFilterList(force?: boolean): void {\n    this.singleFilterList = this.nzFilters.map(item => {\n      const checked = force ? false : !!item.byDefault;\n      if (checked) {\n        this.hasDefaultFilter = true;\n      }\n      return { text: item.text, value: item.value, checked };\n    });\n    this.checkDefaultFilters();\n  }\n\n  checkDefaultFilters(): void {\n    if (!this.nzFilters || this.nzFilters.length === 0 || !this.hasDefaultFilter) {\n      return;\n    }\n    this.updateFilterStatus();\n  }\n\n  marForCheck(): void {\n    this.cdr.markForCheck();\n  }\n\n  constructor(private cdr: ChangeDetectorRef, private i18n: NzI18nService) {\n  }\n\n  ngOnInit(): void {\n    this.i18n.localeChange.pipe(takeUntil(this.destroy$)).subscribe(() => {\n      this.locale = this.i18n.getLocaleData('Table');\n      this.cdr.markForCheck();\n    });\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if (changes.nzFilters) {\n      this.initMultipleFilterList();\n      this.initSingleFilterList();\n      this.updateFilterStatus();\n    }\n    if (changes.nzWidth) {\n      this.nzWidthChange$.next(this.nzWidth);\n    }\n  }\n\n  ngOnDestroy(): void {\n    this.destroy$.next();\n    this.destroy$.complete();\n  }\n}\n"]}