geminis-ng
Version:
This library was generated with [Angular CLI](https://github.com/angular/angular-cli) version 8.2.14.
194 lines • 25.6 kB
JavaScript
import { Component, ContentChildren, EventEmitter, Input, Output, ViewChild } from '@angular/core';
import { NzModalService } from 'ng-zorro-antd/modal';
import { NzTableComponent } from 'ng-zorro-antd/table';
import { GnTableColumnDirective } from './table-column.directive';
import { HttpClient } from '@angular/common/http';
import { GnObjectUtils, pipeTypes } from 'geminis-ng-core';
import { GnMessageService } from '../message-service/message-service';
import { RemoteDataStrategy } from './RemoteDataStrategy';
import { LocalDataStrategy } from './LocalDataStrategy';
export class GnTableComponent {
constructor(http, modalService, messageService) {
this.http = http;
this.modalService = modalService;
this.messageService = messageService;
this.dataStrategies = {};
this.includes = [];
this.sorts = [];
this.data = [];
this.dataTotal = 0;
this.pageIndex = 1;
this.pageSize = 10;
this.showPagination = true;
this.showSizeChanger = true;
this.autoLoadData = true;
this.selectionMode = 'multi';
this.dataStrategy = 'remote';
this.dataSaved = new EventEmitter();
this.dataDeleted = new EventEmitter();
this.dataLoaded = new EventEmitter();
this.selectionStatus = {};
this.selected = [];
this.selectedKeys = [];
this.isSelected = false;
this.isAllSelected = false;
this.isSomeSelected = false;
this.isSingleSelected = false;
this.editData = null;
this.isLoading = false;
this.dataStrategies.remote = new RemoteDataStrategy(this);
this.dataStrategies.local = new LocalDataStrategy(this);
}
getValue(row, key) {
return GnObjectUtils.getValue(row, key);
}
getValueWithPipe(row, key, pipe, pipeArgs) {
if (!pipe) {
return this.getValue(row, key);
}
const pipeTransform = pipeTypes[pipe];
if (!pipeTransform) {
throw new Error('管道[' + pipe + ']未注册');
}
const value = this.getValue(row, key);
return pipeTransform.transform(value, pipeArgs);
}
loadData() {
this.isLoading = true;
return this.dataStrategies[this.dataStrategy].load()
.then((resp) => {
this.data = resp === null || resp === void 0 ? void 0 : resp.content;
this.dataTotal = resp === null || resp === void 0 ? void 0 : resp.totalElements;
this.dataLoaded.emit(this.data);
return this.data;
})
.catch(error => {
this.messageService.error('获取数据错误');
throw error;
})
.finally(() => {
this.isLoading = false;
});
}
loadDataAndCleanSelection() {
this.changeAllSelectStatus(false);
this.loadData();
}
deleteData(url, id) {
this.modalService.confirm({
nzContent: '确定删除所选数据?',
nzOnOk: () => {
this.isLoading = true;
return this.dataStrategies[this.dataStrategy].delete(url, id)
.then(() => {
this.messageService.success('删除数据成功');
this.dataDeleted.emit();
})
.catch(err => {
this.messageService.error('删除数据错误');
console.error(err);
})
.finally(() => {
this.isLoading = false;
this.loadDataAndCleanSelection();
});
}
}, 'confirm');
}
deleteSelectedData() {
this.deleteData(this.url, this.selectedKeys);
}
refreshSelectionStatus() {
this.selected = this.data.filter(item => this.selectionStatus[this.getValue(item, this.dataKey)]);
this.selectedKeys = this.selected.map(item => this.getValue(item, this.dataKey));
this.isSelected = this.selectedKeys.length > 0;
this.isAllSelected = this.isSelected && this.selectedKeys.length === this.data.length;
this.isSomeSelected = this.isSelected && this.selectedKeys.length < this.data.length;
this.isSingleSelected = this.selectedKeys.length === 1;
this.selectedKey = this.isSelected ? this.selectedKeys[0] : null;
this.selectedOne = this.isSelected ? this.selected[0] : null;
}
changeSelectStatus(key) {
if (this.selectionMode === 'none') {
return;
}
if (this.selectionMode === 'single') {
this.selectionStatus = {};
}
this.selectionStatus[key] = !this.selectionStatus[key];
this.refreshSelectionStatus();
}
changeAllSelectStatus(selected) {
this.data.forEach(item => this.selectionStatus[this.getValue(item, this.dataKey)] = selected);
this.refreshSelectionStatus();
}
selectOne(dataKey) {
this.select([dataKey]);
}
select(dataKeys) {
this.changeAllSelectStatus(false);
dataKeys.forEach(dataKey => this.selectionStatus[dataKey] = true);
this.refreshSelectionStatus();
}
ngOnInit() {
if (this.autoLoadData) {
this.loadData();
}
}
refreshData(data) {
this.data = data;
this.dataTotal = data.length;
}
startEdit(data) {
this.editData = data;
}
endEdit() {
this.isLoading = true;
this.dataStrategies[this.dataStrategy].save(this.url, this.editData)
.then((resp) => {
this.dataSaved.emit(this.editData);
this.editData = null;
})
.catch(error => {
this.messageService.error('更新数据错误');
throw error;
})
.finally(() => {
this.isLoading = false;
});
}
}
GnTableComponent.decorators = [
{ type: Component, args: [{
selector: 'gn-table',
template: "<nz-table\n [nzData]=\"data\"\n [nzLoading]=\"isLoading\"\n [nzFrontPagination]=\"false\"\n [nzShowPagination]=\"showPagination\"\n [nzTotal]=\"dataTotal\"\n [nzShowTotal]=\"totalTemplate\"\n [(nzPageIndex)]=\"pageIndex\"\n [(nzPageSize)]=\"pageSize\"\n (nzPageIndexChange)=\"loadData()\"\n [nzShowSizeChanger]=\"showSizeChanger\"\n (nzPageSizeChange)=\"loadData()\">\n <thead>\n <tr>\n <th class=\"selection\"\n *ngIf=\"selectionMode === 'multi'\"\n nzShowCheckbox\n [nzChecked]=\"isAllSelected\"\n [nzIndeterminate]=\"isSomeSelected\"\n (nzCheckedChange)=\"changeAllSelectStatus($event)\"></th>\n <th class=\"selection\"\n *ngIf=\"selectionMode === 'single'\"></th>\n <th *ngFor=\"let header of columns\" [innerHTML]=\"header.title\"></th>\n </tr>\n </thead>\n <tbody>\n <tr *ngFor=\"let row of data\" (click)=\"changeSelectStatus(getValue(row,dataKey))\">\n <td nzShowCheckbox *ngIf=\"selectionMode !== 'none'\"\n [(nzChecked)]=\"selectionStatus[getValue(row,dataKey)]\"\n (nzCheckedChange)=\"selectionMode === 'single'?selectOne(getValue(row,dataKey)):refreshSelectionStatus()\"></td>\n <td *ngFor=\"let body of columns\">\n <ng-container\n *ngIf=\"!body.templateRef; else template\">{{getValueWithPipe(row, body.id, body.pipe, body.pipeArgs)}}</ng-container>\n <ng-template #template [ngTemplateOutlet]=\"body.templateRef\"\n [ngTemplateOutletContext]=\"{ $implicit: row }\"></ng-template>\n </td>\n </tr>\n </tbody>\n <ng-template #totalTemplate let-total>\u5171 {{ total }} \u6761\u8BB0\u5F55</ng-template>\n</nz-table>\n",
styles: [".selection{max-width:5rem}"]
},] }
];
GnTableComponent.ctorParameters = () => [
{ type: HttpClient },
{ type: NzModalService },
{ type: GnMessageService }
];
GnTableComponent.propDecorators = {
nzTable: [{ type: ViewChild, args: [NzTableComponent, { static: true },] }],
url: [{ type: Input }],
includes: [{ type: Input }],
filterGroup: [{ type: Input }],
sorts: [{ type: Input }],
data: [{ type: Input }],
dataKey: [{ type: Input }],
dataTotal: [{ type: Input }],
pageIndex: [{ type: Input }],
pageSize: [{ type: Input }],
showPagination: [{ type: Input }],
showSizeChanger: [{ type: Input }],
autoLoadData: [{ type: Input }],
selectionMode: [{ type: Input }],
dataStrategy: [{ type: Input }],
dataSaved: [{ type: Output }],
dataDeleted: [{ type: Output }],
dataLoaded: [{ type: Output }],
columns: [{ type: ContentChildren, args: [GnTableColumnDirective,] }]
};
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table.component.js","sourceRoot":"","sources":["../../../../projects/geminis-ng/src/table/table.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {Component, ContentChildren, EventEmitter, Input, OnInit, Output, QueryList, ViewChild} from '@angular/core';\nimport {NzModalService} from 'ng-zorro-antd/modal';\nimport {NzTableComponent} from 'ng-zorro-antd/table';\nimport {GnTableColumnDirective} from './table-column.directive';\nimport {HttpClient} from '@angular/common/http';\nimport {GnObjectUtils, pipeTypes} from 'geminis-ng-core';\nimport {GnMessageService} from '../message-service/message-service';\nimport {DataStrategy} from './DataStrategy';\nimport {RemoteDataStrategy} from './RemoteDataStrategy';\nimport {LocalDataStrategy} from './LocalDataStrategy';\n\n@Component({\n  selector: 'gn-table',\n  templateUrl: './table.component.html',\n  styleUrls: ['./table.component.css']\n})\nexport class GnTableComponent implements OnInit {\n\n  private dataStrategies: { [key: string]: DataStrategy } = {};\n\n  @ViewChild(NzTableComponent, {static: true}) nzTable: NzTableComponent;\n\n  @Input() url: string;\n  @Input() includes: string[] = [];\n  @Input() filterGroup: any;\n  @Input() sorts: any[] = [];\n\n  @Input() data: any[] = [];\n  @Input() dataKey: string;\n  @Input() dataTotal = 0;\n\n  @Input() pageIndex = 1;\n  @Input() pageSize = 10;\n  @Input() showPagination = true;\n  @Input() showSizeChanger = true;\n\n  @Input() autoLoadData = true;\n\n  @Input() selectionMode: 'none' | 'single' | 'multi' = 'multi';\n\n  @Input() dataStrategy: 'remote' | 'local' = 'remote';\n\n\n  @Output() dataSaved = new EventEmitter();\n  @Output() dataDeleted = new EventEmitter();\n  @Output() dataLoaded = new EventEmitter();\n\n  selectionStatus: { [key: string]: boolean } = {};\n  selected: any[] = [];\n  selectedKeys: any[] = [];\n  selectedKey: any;\n  selectedOne: any;\n  isSelected = false;\n  isAllSelected = false;\n  isSomeSelected = false;\n  isSingleSelected = false;\n  editData: any = null;\n\n  isLoading = false;\n\n  @ContentChildren(GnTableColumnDirective) columns: QueryList<GnTableColumnDirective>;\n\n  constructor(public http: HttpClient,\n              public modalService: NzModalService,\n              public messageService: GnMessageService) {\n    this.dataStrategies.remote = new RemoteDataStrategy(this);\n    this.dataStrategies.local = new LocalDataStrategy(this);\n  }\n\n  getValue(row: any, key: string): any {\n    return GnObjectUtils.getValue(row, key);\n  }\n\n  getValueWithPipe(row: any, key: string, pipe: string, pipeArgs: any[]): any {\n    if (!pipe) {\n      return this.getValue(row, key);\n    }\n\n    const pipeTransform = pipeTypes[pipe];\n    if (!pipeTransform) {\n      throw new Error('管道[' + pipe + ']未注册');\n    }\n\n    const value = this.getValue(row, key);\n    return pipeTransform.transform(value, pipeArgs);\n  }\n\n  loadData(): Promise<any> {\n    this.isLoading = true;\n    return this.dataStrategies[this.dataStrategy].load()\n      .then((resp: any) => {\n        this.data = resp?.content;\n        this.dataTotal = resp?.totalElements;\n        this.dataLoaded.emit(this.data);\n        return this.data;\n      })\n      .catch(error => {\n        this.messageService.error('获取数据错误');\n        throw error;\n      })\n      .finally(() => {\n        this.isLoading = false;\n      });\n  }\n\n  loadDataAndCleanSelection(): void {\n    this.changeAllSelectStatus(false);\n    this.loadData();\n  }\n\n  deleteData(url: string, id: any[]): void {\n    this.modalService.confirm({\n      nzContent: '确定删除所选数据？',\n      nzOnOk: () => {\n        this.isLoading = true;\n        return this.dataStrategies[this.dataStrategy].delete(url, id)\n          .then(() => {\n            this.messageService.success('删除数据成功');\n            this.dataDeleted.emit();\n          })\n          .catch(err => {\n            this.messageService.error('删除数据错误');\n            console.error(err);\n          })\n          .finally(() => {\n            this.isLoading = false;\n            this.loadDataAndCleanSelection();\n          });\n      }\n    }, 'confirm');\n  }\n\n  deleteSelectedData(): void {\n    this.deleteData(this.url, this.selectedKeys);\n  }\n\n  refreshSelectionStatus(): void {\n    this.selected = this.data.filter(item => this.selectionStatus[this.getValue(item, this.dataKey)]);\n    this.selectedKeys = this.selected.map(item => this.getValue(item, this.dataKey));\n    this.isSelected = this.selectedKeys.length > 0;\n    this.isAllSelected = this.isSelected && this.selectedKeys.length === this.data.length;\n    this.isSomeSelected = this.isSelected && this.selectedKeys.length < this.data.length;\n    this.isSingleSelected = this.selectedKeys.length === 1;\n    this.selectedKey = this.isSelected ? this.selectedKeys[0] : null;\n    this.selectedOne = this.isSelected ? this.selected[0] : null;\n  }\n\n  changeSelectStatus(key: any): void {\n    if (this.selectionMode === 'none') {\n      return;\n    }\n    if (this.selectionMode === 'single') {\n      this.selectionStatus = {};\n    }\n    this.selectionStatus[key] = !this.selectionStatus[key];\n    this.refreshSelectionStatus();\n  }\n\n  changeAllSelectStatus(selected: boolean): void {\n    this.data.forEach(item => this.selectionStatus[this.getValue(item, this.dataKey)] = selected);\n    this.refreshSelectionStatus();\n  }\n\n  selectOne(dataKey: any): void {\n    this.select([dataKey]);\n  }\n\n  select(dataKeys: any[]): void {\n    this.changeAllSelectStatus(false);\n    dataKeys.forEach(dataKey => this.selectionStatus[dataKey] = true);\n    this.refreshSelectionStatus();\n  }\n\n  ngOnInit(): void {\n    if (this.autoLoadData) {\n      this.loadData();\n    }\n  }\n\n  refreshData(data: any[]): void {\n    this.data = data;\n    this.dataTotal = data.length;\n  }\n\n  startEdit(data: any): void {\n    this.editData = data;\n  }\n\n  endEdit(): void {\n    this.isLoading = true;\n    this.dataStrategies[this.dataStrategy].save(this.url, this.editData)\n      .then((resp: any) => {\n        this.dataSaved.emit(this.editData);\n        this.editData = null;\n      })\n      .catch(error => {\n        this.messageService.error('更新数据错误');\n        throw error;\n      })\n      .finally(() => {\n        this.isLoading = false;\n      });\n  }\n}\n"]}