UNPKG

@ecip/auth

Version:
274 lines 21.8 kB
/** * @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"]}