ng-zorro-antd
Version:
An enterprise-class UI components based on Ant Design and Angular
497 lines • 37.8 kB
JavaScript
/**
* @fileoverview added by tsickle
* Generated from: nz-th.component.ts
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
import * as tslib_1 from "tslib";
/**
* @license
* Copyright Alibaba.com All Rights Reserved.
*
* 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, ChangeDetectorRef, Component, EventEmitter, Input, Output, ViewChild, ViewEncapsulation } from '@angular/core';
import { Subject } from 'rxjs';
import { takeUntil } from 'rxjs/operators';
import { isNotNil, InputBoolean } from 'ng-zorro-antd/core';
import { NzDropdownMenuComponent } from 'ng-zorro-antd/dropdown';
import { NzI18nService } from 'ng-zorro-antd/i18n';
/**
* @record
*/
export function NzThItemInterface() { }
if (false) {
/** @type {?} */
NzThItemInterface.prototype.text;
/** @type {?} */
NzThItemInterface.prototype.value;
/** @type {?} */
NzThItemInterface.prototype.checked;
}
var NzThComponent = /** @class */ (function () {
function NzThComponent(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 {?}
*/
NzThComponent.prototype.updateSortValue = /**
* @return {?}
*/
function () {
if (this.nzShowSort) {
if (this.nzSort === 'ascend') {
this.setSortValue('descend');
}
else if (this.nzSort === 'descend') {
this.setSortValue(null);
}
else {
this.setSortValue('ascend');
}
}
};
/**
* @param {?} value
* @return {?}
*/
NzThComponent.prototype.setSortValue = /**
* @param {?} value
* @return {?}
*/
function (value) {
this.nzSort = value;
this.nzSortChangeWithKey.emit({ key: this.nzSortKey, value: this.nzSort });
this.nzSortChange.emit(this.nzSort);
};
Object.defineProperty(NzThComponent.prototype, "filterList", {
get: /**
* @return {?}
*/
function () {
return this.multipleFilterList.filter((/**
* @param {?} item
* @return {?}
*/
function (item) { return item.checked; })).map((/**
* @param {?} item
* @return {?}
*/
function (item) { return item.value; }));
},
enumerable: true,
configurable: true
});
Object.defineProperty(NzThComponent.prototype, "filterValue", {
/* tslint:disable-next-line:no-any */
get: /* tslint:disable-next-line:no-any */
/**
* @return {?}
*/
function () {
/** @type {?} */
var checkedFilter = this.singleFilterList.find((/**
* @param {?} item
* @return {?}
*/
function (item) { return item.checked; }));
return checkedFilter ? checkedFilter.value : null;
},
enumerable: true,
configurable: true
});
/**
* @return {?}
*/
NzThComponent.prototype.updateFilterStatus = /**
* @return {?}
*/
function () {
if (this.nzFilterMultiple) {
this.hasFilterValue = this.filterList.length > 0;
}
else {
this.hasFilterValue = isNotNil(this.filterValue);
}
};
/**
* @return {?}
*/
NzThComponent.prototype.search = /**
* @return {?}
*/
function () {
this.updateFilterStatus();
if (this.nzFilterMultiple) {
this.nzFilterChange.emit(this.filterList);
}
else {
this.nzFilterChange.emit(this.filterValue);
}
};
/**
* @return {?}
*/
NzThComponent.prototype.reset = /**
* @return {?}
*/
function () {
this.initMultipleFilterList(true);
this.initSingleFilterList(true);
this.hasFilterValue = false;
};
/**
* @param {?} filter
* @return {?}
*/
NzThComponent.prototype.checkMultiple = /**
* @param {?} filter
* @return {?}
*/
function (filter) {
filter.checked = !filter.checked;
};
/**
* @param {?} filter
* @return {?}
*/
NzThComponent.prototype.checkSingle = /**
* @param {?} filter
* @return {?}
*/
function (filter) {
this.singleFilterList.forEach((/**
* @param {?} item
* @return {?}
*/
function (item) { return (item.checked = item === filter); }));
};
/**
* @return {?}
*/
NzThComponent.prototype.hideDropDown = /**
* @return {?}
*/
function () {
this.nzDropdownMenuComponent.setVisibleStateWhen(false);
this.filterVisible = false;
};
/**
* @param {?} value
* @return {?}
*/
NzThComponent.prototype.dropDownVisibleChange = /**
* @param {?} value
* @return {?}
*/
function (value) {
this.filterVisible = value;
if (!value) {
this.search();
}
};
/**
* @param {?=} force
* @return {?}
*/
NzThComponent.prototype.initMultipleFilterList = /**
* @param {?=} force
* @return {?}
*/
function (force) {
var _this = this;
this.multipleFilterList = this.nzFilters.map((/**
* @param {?} item
* @return {?}
*/
function (item) {
/** @type {?} */
var checked = force ? false : !!item.byDefault;
if (checked) {
_this.hasDefaultFilter = true;
}
return { text: item.text, value: item.value, checked: checked };
}));
this.checkDefaultFilters();
};
/**
* @param {?=} force
* @return {?}
*/
NzThComponent.prototype.initSingleFilterList = /**
* @param {?=} force
* @return {?}
*/
function (force) {
var _this = this;
this.singleFilterList = this.nzFilters.map((/**
* @param {?} item
* @return {?}
*/
function (item) {
/** @type {?} */
var checked = force ? false : !!item.byDefault;
if (checked) {
_this.hasDefaultFilter = true;
}
return { text: item.text, value: item.value, checked: checked };
}));
this.checkDefaultFilters();
};
/**
* @return {?}
*/
NzThComponent.prototype.checkDefaultFilters = /**
* @return {?}
*/
function () {
if (!this.nzFilters || this.nzFilters.length === 0 || !this.hasDefaultFilter) {
return;
}
this.updateFilterStatus();
};
/**
* @return {?}
*/
NzThComponent.prototype.marForCheck = /**
* @return {?}
*/
function () {
this.cdr.markForCheck();
};
/**
* @return {?}
*/
NzThComponent.prototype.ngOnInit = /**
* @return {?}
*/
function () {
var _this = this;
this.i18n.localeChange.pipe(takeUntil(this.destroy$)).subscribe((/**
* @return {?}
*/
function () {
_this.locale = _this.i18n.getLocaleData('Table');
_this.cdr.markForCheck();
}));
};
/**
* @param {?} changes
* @return {?}
*/
NzThComponent.prototype.ngOnChanges = /**
* @param {?} changes
* @return {?}
*/
function (changes) {
if (changes.nzFilters) {
this.initMultipleFilterList();
this.initSingleFilterList();
this.updateFilterStatus();
}
if (changes.nzWidth) {
this.nzWidthChange$.next(this.nzWidth);
}
};
/**
* @return {?}
*/
NzThComponent.prototype.ngOnDestroy = /**
* @return {?}
*/
function () {
this.destroy$.next();
this.destroy$.complete();
};
NzThComponent.decorators = [
{ type: Component, args: [{
// tslint:disable-next-line:component-selector
selector: 'th:not(.nz-disable-th):not([mat-sort-header]):not([mat-header-cell])',
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<span class=\"ant-table-header-column\">\n <div [class.ant-table-column-sorters]=\"nzShowSort\" (click)=\"updateSortValue()\">\n <span class=\"ant-table-column-title\">\n <ng-container *ngIf=\"nzShowCheckbox && !nzShowRowSelection\">\n <ng-template [ngTemplateOutlet]=\"checkboxTemplate\"></ng-template>\n </ng-container>\n <div class=\"ant-table-selection\" *ngIf=\"nzShowRowSelection\">\n <ng-container *ngIf=\"nzShowCheckbox\">\n <ng-template [ngTemplateOutlet]=\"checkboxTemplate\"></ng-template>\n </ng-container>\n <div nz-dropdown class=\"ant-table-selection-down\" nzPlacement=\"bottomLeft\" [nzDropdownMenu]=\"selectionMenu\">\n <i nz-icon nzType=\"down\"></i>\n </div>\n <nz-dropdown-menu #selectionMenu=\"nzDropdownMenu\">\n <ul nz-menu class=\"ant-table-selection-menu\">\n <li nz-menu-item\n *ngFor=\"let selection of nzSelections\"\n (click)=\"selection.onSelect()\">{{selection.text}}</li>\n </ul>\n </nz-dropdown-menu>\n </div>\n <ng-content></ng-content>\n </span>\n <ng-content select=\"nz-dropdown\"></ng-content>\n <div class=\"ant-table-column-sorter\" *ngIf=\"nzShowSort\">\n <div class=\"ant-table-column-sorter-inner ant-table-column-sorter-inner-full\">\n <i nz-icon\n nzType=\"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 nzType=\"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 </div>\n</span>\n<ng-content select=\"[nz-dropdown]\"></ng-content>\n<ng-content select=\"[nz-th-extra]\"></ng-content>\n\n<ng-container *ngIf=\"nzShowFilter\">\n <i nz-icon\n nz-dropdown\n nzType=\"filter\"\n nzTheme=\"fill\"\n nzTrigger=\"click\"\n nzTableFilter\n [nzClickHide]=\"false\"\n [nzDropdownMenu]=\"filterMenu\"\n [class.ant-table-filter-selected]=\"hasFilterValue\"\n [class.ant-table-filter-open]=\"filterVisible\"\n (nzVisibleChange)=\"dropDownVisibleChange($event)\"></i>\n <nz-dropdown-menu #filterMenu=\"nzDropdownMenu\">\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>\n <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-menu>\n</ng-container>\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 = function () { return [
{ type: ChangeDetectorRef },
{ type: NzI18nService }
]; };
NzThComponent.propDecorators = {
nzDropdownMenuComponent: [{ type: ViewChild, args: [NzDropdownMenuComponent, { static: false },] }],
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);
return NzThComponent;
}());
export { NzThComponent };
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.nzDropdownMenuComponent;
/** @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/table/","sources":["nz-th.component.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Alibaba.com All Rights Reserved.\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 {\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  EventEmitter,\n  Input,\n  OnChanges,\n  OnDestroy,\n  OnInit,\n  Output,\n  SimpleChanges,\n  ViewChild,\n  ViewEncapsulation\n} from '@angular/core';\nimport { Subject } from 'rxjs';\nimport { takeUntil } from 'rxjs/operators';\n\nimport { isNotNil, InputBoolean } from 'ng-zorro-antd/core';\nimport { NzDropdownMenuComponent } from 'ng-zorro-antd/dropdown';\nimport { NzI18nInterface, NzI18nService } from 'ng-zorro-antd/i18n';\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):not([mat-sort-header]):not([mat-header-cell])',\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(NzDropdownMenuComponent, { static: false }) nzDropdownMenuComponent: NzDropdownMenuComponent;\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 = 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 | null>();\n  @Output() readonly nzSortChangeWithKey = new EventEmitter<{ key: string; value: string | null }>();\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 === 'ascend') {\n        this.setSortValue('descend');\n      } else if (this.nzSort === 'descend') {\n        this.setSortValue(null);\n      } else {\n        this.setSortValue('ascend');\n      }\n    }\n  }\n\n  setSortValue(value: 'ascend' | 'descend' | null): 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.nzDropdownMenuComponent.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  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"]}