@ecip/auth
Version:
274 lines • 21.8 kB
JavaScript
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
import { Component, ViewChild } from '@angular/core';
import { ModalHelper } from '@delon/theme';
import { SFComponent, } from '@delon/form';
import { STComponent } from "@delon/abc";
import { NzMessageService } from "ng-zorro-antd";
import { AuthDataSourceEditComponent } from "./edit/dsedit.component";
import { DictService, DataSourceService } from "@ecip/service";
export class AuthDataSourceComponent {
/**
* @param {?} modalHelper
* @param {?} messageService
* @param {?} dataSourceService
* @param {?} dictService
*/
constructor(modalHelper, messageService, dataSourceService, dictService) {
this.modalHelper = modalHelper;
this.messageService = messageService;
this.dataSourceService = dataSourceService;
this.dictService = dictService;
this.url = 'api/v1/sysrDS';
this.selectedIds = [];
this.pageTitle = '数据源管理';
this.params = {};
this.schema = {
properties: {
dsName: {
type: 'string',
title: '数据源名称',
},
dbType: {
type: "string",
title: '数据库类型',
ui: {
widget: 'select',
width: 260,
notFoundContent: '没有数据',
dropdownMatchSelectWidth: false,
asyncData: (/**
* @return {?}
*/
() => this.dictService.getTypeList("dbType"))
}
},
ip: {
type: 'string',
title: '主机名',
},
dbName: {
type: 'string',
title: '数据库名',
},
},
};
this.columns = [
{
title: '编号',
type: 'checkbox',
index: 'id',
fixed: 'left',
width: '2%',
},
{
title: '数据源名称',
index: 'dsName',
fixed: 'left',
width: '10%'
},
{
title: '数据库类型',
index: 'dbType',
fixed: 'left',
width: '6%',
format: (/**
* @param {?} item
* @return {?}
*/
(item) => {
for (let pair of this.dbTypeList) {
if (item.dbType == pair.value) {
return pair.label;
}
}
return item.dbType;
})
},
{
title: '数据库名',
index: 'dbName',
fixed: 'left',
width: '8%'
},
{
title: 'URL',
index: 'url',
},
{
title: '主机名',
index: 'ip',
},
{
title: '端口号',
index: 'port',
},
{
title: '用户名',
index: 'username',
},
{
title: '操作',
fixed: 'right',
width: '9%',
buttons: [
{
text: '编辑',
icon: 'edit',
type: 'static',
component: AuthDataSourceEditComponent,
click: (/**
* @param {?} record
* @param {?} modal
* @return {?}
*/
(record, modal) => {
this.messageService.success("编辑成功");
this.st.load(-1, this.params);
}),
acl: { ability: ['datasource:edit'] }
},
{
text: '删除',
icon: 'delete',
type: 'del',
click: (/**
* @param {?} record
* @param {?} modal
* @param {?} component
* @return {?}
*/
(record, modal, component) => {
this.dataSourceService.deleteById(record.id).subscribe((/**
* @return {?}
*/
() => {
this.messageService.success("删除成功");
component.load(-1, this.params);
}));
}),
acl: { ability: ['datasource:remove'] }
}
],
}
];
}
/**
* @return {?}
*/
ngOnInit() {
this.dictService.getTypeList("dbType").subscribe((/**
* @param {?} res
* @return {?}
*/
res => {
this.dbTypeList = res;
}));
}
//即时监控选中项的ID列表
/**
* @param {?} e
* @return {?}
*/
checkboxChange(e) {
this.selectedIds = [];
for (let item of e) {
this.selectedIds.push(item.id);
}
}
//因为[formData]和st的params似乎不能绑定,所以手写了一个绑定数据的方法
/**
* @return {?}
*/
formBind() {
this.params = this.sf.value;
}
/**
* @return {?}
*/
multiDelete() {
//未选定任何一条
if (this.selectedIds.length == 0) {
this.messageService.warning("未选择任何记录");
}
else {
this.dataSourceService.multiDelete(this.selectedIds).subscribe((/**
* @return {?}
*/
() => {
this.messageService.success("删除成功");
this.st.load(-1, this.params);
}));
}
}
/**
* @return {?}
*/
create() {
this.modalHelper.createStatic(AuthDataSourceEditComponent, { isNew: true })
.subscribe((/**
* @return {?}
*/
() => {
this.messageService.success("创建成功");
this.st.load(-1, this.params);
}));
}
}
AuthDataSourceComponent.decorators = [
{ type: Component, args: [{
selector: 'app-auth-ds',
template: "<page-header [action]=\"phPhAction\">\r\n <ng-template #phPhAction>\r\n <button acl [acl-ability]=\"'datasource:add'\" nz-button nzType=\"primary\" (click)=\"create()\">\u65B0\u5EFA</button>\r\n <!--<button nz-button (click)=\"multiDelete()\">\u5220\u9664</button>-->\r\n </ng-template>\r\n</page-header>\r\n<nz-card>\r\n <sf #sf mode=\"search\" [schema]=\"schema\" (formSubmit)=\"formBind();st.load(1, params);\" (formReset)=\"formBind();st.reset(params)\"></sf>\r\n <st #st [data]=\"url\" [columns]=\"columns\" [scroll]=\"{x:'150%'}\" (change)=\"checkboxChange($event)\" [req]=\"{params: params}\" [page]=\"{front: false}\"></st>\r\n</nz-card>\r\n"
}] }
];
/** @nocollapse */
AuthDataSourceComponent.ctorParameters = () => [
{ type: ModalHelper },
{ type: NzMessageService },
{ type: DataSourceService },
{ type: DictService }
];
AuthDataSourceComponent.propDecorators = {
st: [{ type: ViewChild, args: ['st',] }],
sf: [{ type: ViewChild, args: ['sf',] }]
};
if (false) {
/** @type {?} */
AuthDataSourceComponent.prototype.url;
/** @type {?} */
AuthDataSourceComponent.prototype.selectedIds;
/** @type {?} */
AuthDataSourceComponent.prototype.pageTitle;
/** @type {?} */
AuthDataSourceComponent.prototype.params;
/** @type {?} */
AuthDataSourceComponent.prototype.dbTypeList;
/** @type {?} */
AuthDataSourceComponent.prototype.st;
/** @type {?} */
AuthDataSourceComponent.prototype.sf;
/** @type {?} */
AuthDataSourceComponent.prototype.schema;
/** @type {?} */
AuthDataSourceComponent.prototype.columns;
/**
* @type {?}
* @private
*/
AuthDataSourceComponent.prototype.modalHelper;
/**
* @type {?}
* @private
*/
AuthDataSourceComponent.prototype.messageService;
/** @type {?} */
AuthDataSourceComponent.prototype.dataSourceService;
/**
* @type {?}
* @private
*/
AuthDataSourceComponent.prototype.dictService;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ds.component.js","sourceRoot":"ng://@ecip/auth/","sources":["src/datasource/ds.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {AfterViewInit, Component, OnInit, ViewChild} from '@angular/core';\r\nimport {ModalHelper} from '@delon/theme';\r\nimport {SFComponent, SFSchema,} from '@delon/form';\r\nimport {STColumn, STComponent} from \"@delon/abc\";\r\nimport {NzMessageService} from \"ng-zorro-antd\";\r\nimport {AuthDataSourceEditComponent} from \"./edit/dsedit.component\";\r\nimport { DictService, DataSourceService } from \"@ecip/service\";\r\n\r\n@Component({\r\n  selector: 'app-auth-ds',\r\n  templateUrl: './ds.component.html',\r\n})\r\nexport class AuthDataSourceComponent implements OnInit{\r\n\r\n  url = 'api/v1/sysrDS';\r\n\r\n  selectedIds:string[] = [];\r\n\r\n  pageTitle = '数据源管理';\r\n\r\n  params:any= { };\r\n\r\n  dbTypeList:[any];\r\n\r\n  @ViewChild('st')\r\n  st: STComponent;\r\n\r\n  @ViewChild('sf')\r\n  sf: SFComponent;\r\n\r\n  schema: SFSchema = {\r\n    properties: {\r\n      dsName: {\r\n        type: 'string',\r\n        title: '数据源名称',\r\n      },\r\n      dbType: {\r\n        type: \"string\",\r\n        title: '数据库类型',\r\n        ui: {\r\n          widget: 'select',\r\n          width: 260,\r\n          notFoundContent: '没有数据',\r\n          dropdownMatchSelectWidth: false,\r\n          asyncData:()=>this.dictService.getTypeList(\"dbType\")\r\n        }\r\n      },\r\n      ip: {\r\n        type: 'string',\r\n        title: '主机名',\r\n      },\r\n      dbName: {\r\n        type: 'string',\r\n        title: '数据库名',\r\n      },\r\n    },\r\n  };\r\n\r\n  columns: STColumn[] = [\r\n    {\r\n      title: '编号',\r\n      type:'checkbox',\r\n      index:'id',\r\n      fixed:'left',\r\n      width: '2%',\r\n    },\r\n    {\r\n      title: '数据源名称',\r\n      index: 'dsName',\r\n      fixed:'left',\r\n      width: '10%'\r\n    },\r\n    {\r\n      title: '数据库类型',\r\n      index: 'dbType',\r\n      fixed:'left',\r\n      width: '6%',\r\n      format:(item:any)=>{\r\n        for(let pair of this.dbTypeList){\r\n          if(item.dbType == pair.value){\r\n            return pair.label;\r\n          }\r\n        }\r\n        return item.dbType;\r\n      }\r\n    },\r\n    {\r\n      title: '数据库名',\r\n      index: 'dbName',\r\n      fixed:'left',\r\n      width: '8%'\r\n    },\r\n    {\r\n      title: 'URL',\r\n      index: 'url',\r\n    },\r\n    {\r\n      title: '主机名',\r\n      index: 'ip',\r\n    },\r\n    {\r\n      title: '端口号',\r\n      index: 'port',\r\n    },\r\n    {\r\n      title: '用户名',\r\n      index: 'username',\r\n    },\r\n    {\r\n      title: '操作',\r\n      fixed:'right',\r\n      width: '9%',\r\n      buttons: [\r\n        {\r\n          text: '编辑',\r\n          icon: 'edit',\r\n          type: 'static',\r\n          component: AuthDataSourceEditComponent,\r\n          click: (record, modal) =>{\r\n            this.messageService.success(\"编辑成功\");\r\n            this.st.load(-1, this.params);\r\n          },\r\n          acl: { ability: ['datasource:edit'] }\r\n        },\r\n        {\r\n          text: '删除',\r\n          icon: 'delete',\r\n          type: 'del',\r\n          click: (record, modal, component) => {\r\n            this.dataSourceService.deleteById(record.id).subscribe(()=>{\r\n              this.messageService.success(\"删除成功\");\r\n              component.load(-1, this.params);\r\n            });\r\n          },\r\n          acl: { ability: ['datasource:remove'] }\r\n        }\r\n      ],\r\n    }\r\n  ];\r\n\r\n  constructor(private modalHelper: ModalHelper,\r\n              private messageService:NzMessageService,\r\n              public dataSourceService:DataSourceService,\r\n              private dictService:DictService) {}\r\n\r\n  ngOnInit(): void {\r\n    this.dictService.getTypeList(\"dbType\").subscribe(res=>{\r\n      this.dbTypeList = res;\r\n    })\r\n  }\r\n\r\n  //即时监控选中项的ID列表\r\n  checkboxChange(e: any[]) {\r\n    this.selectedIds = [];\r\n    for(let item of e){\r\n      this.selectedIds.push(item.id);\r\n    }\r\n  }\r\n\r\n  //因为[formData]和st的params似乎不能绑定，所以手写了一个绑定数据的方法\r\n  formBind() {\r\n    this.params = this.sf.value;\r\n  }\r\n\r\n  multiDelete(){\r\n    //未选定任何一条\r\n    if(this.selectedIds.length==0){\r\n      this.messageService.warning(\"未选择任何记录\");\r\n    }else{\r\n      this.dataSourceService.multiDelete(this.selectedIds).subscribe(()=>{\r\n        this.messageService.success(\"删除成功\");\r\n        this.st.load(-1, this.params);\r\n      });\r\n    }\r\n  }\r\n\r\n  create(){\r\n    this.modalHelper.createStatic(AuthDataSourceEditComponent, {isNew:true})\r\n      .subscribe(() => {\r\n        this.messageService.success(\"创建成功\");\r\n        this.st.load(-1, this.params);\r\n      });\r\n  }\r\n\r\n\r\n}\r\n"]}