@ecip/permission
Version:
404 lines • 37.4 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 { STComponent } from '@delon/abc';
import { NzMessageService } from 'ng-zorro-antd';
import { PermissionRoleEditComponent } from "./edit/edit.component";
import { PermissionRoleViewComponent } from "./view/view.component";
import { TreeService } from "@ecip/shared";
import { PermissionRoleUserComponent } from "./user/role.user.component";
import { AppsService, ResourceService, RoleService } from "@ecip/service";
export class PermissionRoleComponent {
/**
* @param {?} modal
* @param {?} msgSrv
* @param {?} roleService
* @param {?} resourceService
* @param {?} treeService
* @param {?} appsService
*/
constructor(modal, msgSrv, roleService, resourceService, treeService, appsService) {
this.modal = modal;
this.msgSrv = msgSrv;
this.roleService = roleService;
this.resourceService = resourceService;
this.treeService = treeService;
this.appsService = appsService;
this.url = `api/v1/sysrRole/list`;
this.searchSchema = {
properties: {
id: {
type: 'string',
title: '编号'
}
}
};
this.columns = [
// { title: '编号', index: 'id' },
{ title: '', index: 'id', type: 'radio' },
// { title: '应用系统', index: 'appId' },
{ title: '角色名称', index: 'roleName' },
{ title: '编码', index: 'code' },
{ title: '角色状态', index: 'statusText' },
// { title: '排序', index: 'sortNum' },
// { title: '创建时间', type: 'date', index: 'createTime' },
{
title: '操作',
width: '100px',
buttons: [
{ text: '删除', type: 'del', click: (/**
* @param {?} item
* @return {?}
*/
(item) => {
//删除
this.roleService.deleteById(item.id).subscribe((/**
* @param {?} res
* @return {?}
*/
res => {
this.msgSrv.success('删除成功');
this.st.reload();
}));
}),
acl: { ability: ['permission:remove'] }
},
{
text: '',
children: [
{ text: '查看', type: 'static', component: PermissionRoleViewComponent, click: 'reload', acl: { ability: ['role:view'] } },
{ text: '编辑', type: 'none',
click: (/**
* @param {?} record
* @return {?}
*/
(record) => {
this.modal
.createStatic(PermissionRoleEditComponent, { appId: this.appId, record: record })
.subscribe((/**
* @return {?}
*/
() => this.st.reload()));
}),
acl: { ability: ['role:edit'] }
},
{ text: '人员', type: 'static', component: PermissionRoleUserComponent, click: 'reload', acl: { ability: ['member:choose'] } }
],
},
]
}
];
this.appId = -1;
this.data = [];
this.dataList = []; //所有节点数组
//所有节点数组
this.expandDataCache = {};
this.allChecked = false;
this.indeterminate = false;
this.listOfSelection = [
{
text: '全选',
onSelect: (/**
* @return {?}
*/
() => {
this.checkAll(true);
})
},
{
text: '全不选',
onSelect: (/**
* @return {?}
*/
() => {
this.checkAll(false);
})
}
];
}
/**
* @param {?=} $event
* @return {?}
*/
refreshStatus($event) {
if (!this.selectedRole) {
this.msgSrv.warning('请选择角色');
return;
}
/** @type {?} */
const allChecked = this.dataList.every((/**
* @param {?} value
* @return {?}
*/
value => value.checked === true));
/** @type {?} */
const allUnChecked = this.dataList.every((/**
* @param {?} value
* @return {?}
*/
value => !value.checked));
this.allChecked = allChecked;
this.indeterminate = (!allChecked) && (!allUnChecked);
}
/**
* @param {?} value
* @return {?}
*/
checkAll(value) {
if (!this.selectedRole) {
this.msgSrv.warning('请选择要授权的角色');
return;
}
this.dataList.forEach((/**
* @param {?} data
* @return {?}
*/
data => {
if (!data.disabled) {
data.checked = value;
}
}));
this.refreshStatus();
}
/**
* @param {?} value
* @return {?}
*/
expandAll(value) {
this.dataList.forEach((/**
* @param {?} data
* @return {?}
*/
data => {
data.expand = value;
}));
}
/**
* @return {?}
*/
ngOnInit() {
this.st.req.params = { appId: this.appId };
this.appsService.getList().subscribe((/**
* @param {?} appList
* @return {?}
*/
appList => {
this.appList = appList;
}));
this.appChange();
}
/**
* @return {?}
*/
appChange() {
this.selectedRole = null;
this.st.reload({ appId: this.appId });
this.resourceService.findTree({ appId: this.appId }).subscribe((/**
* @param {?} res
* @return {?}
*/
(res) => {
this.data = res;
this.data.forEach((/**
* @param {?} item
* @return {?}
*/
item => {
this.expandDataCache[item.id] = TreeService.convertTreeToList(item);
this.dataList = [...this.dataList, ...this.expandDataCache[item.id]];
}));
}));
}
/**
* @return {?}
*/
add() {
this.modal
.createStatic(PermissionRoleEditComponent, { appId: this.appId })
.subscribe((/**
* @return {?}
*/
() => this.st.reload({ appId: this.appId })));
}
/**
* @param {?} item
* @return {?}
*/
radioChange(item) {
if (!item.radio) {
return;
}
item = item.radio;
this.selectedRole = item;
this.roleService.findResource(item.id).subscribe((/**
* @param {?} res
* @return {?}
*/
(res) => {
this.dataList.forEach((/**
* @param {?} _item
* @return {?}
*/
_item => {
if (res.includes(_item.id)) {
_item.assign = '已授权';
}
else {
_item.assign = '未授权';
}
}));
}));
}
/**
* @return {?}
*/
assign() {
if (!this.selectedRole) {
this.msgSrv.warning('请选择要授权的角色');
return;
}
console.log('assign');
/** @type {?} */
let resourceIds = this.getCheckIds();
if (resourceIds.length == 0) {
this.msgSrv.warning('请选择要授权的资源');
return;
}
this.roleService.saveResource(this.selectedRole.id, resourceIds).subscribe((/**
* @param {?} res
* @return {?}
*/
res => {
this.msgSrv.success('授权成功');
// this.dataList.filter(item => item.).checked = true;
this.dataList.forEach((/**
* @param {?} item
* @return {?}
*/
item => {
if (item.checked === true) {
item.assign = '已授权';
}
}));
}));
}
/**
* @return {?}
*/
cancel() {
if (!this.selectedRole) {
this.msgSrv.warning('请选择要取消授权的角色');
return;
}
console.log('cancel');
/** @type {?} */
let resourceIds = this.getCheckIds();
if (resourceIds.length == 0) {
this.msgSrv.warning('请选择要取消授权的资源');
return;
}
this.roleService.deleteResource(this.selectedRole.id, resourceIds).subscribe((/**
* @param {?} res
* @return {?}
*/
res => {
this.msgSrv.success('取消授权成功');
// this.dataList.filter(item => item.).checked = true;
this.dataList.forEach((/**
* @param {?} item
* @return {?}
*/
item => {
if (item.checked === true) {
item.assign = '未授权';
}
}));
}));
}
/**
* @return {?}
*/
getCheckIds() {
/** @type {?} */
let checkIds = [];
this.dataList.forEach((/**
* @param {?} item
* @return {?}
*/
item => {
if (item.checked === true) {
checkIds.push(item.id);
}
}));
return checkIds;
}
}
PermissionRoleComponent.decorators = [
{ type: Component, args: [{
selector: 'app-permission-role',
template: "<page-header [action]=\"phPhAction\">\r\n <ng-template #phPhAction>\r\n <button acl [acl-ability]=\"'role:add'\" (click)=\"add()\" nz-button nzType=\"primary\">\u65B0\u5EFA</button>\r\n </ng-template>\r\n</page-header>\r\n<nz-card>\r\n <div nz-row>\r\n <div nz-col nzSpan=\"12\">\r\n <!--<sf mode=\"search\" [schema]=\"searchSchema\" (formSubmit)=\"st.reset($event)\" (formReset)=\"st.reset($event)\"></sf>-->\r\n <nz-affix [nzOffsetTop]=\"80\">\r\n <form nz-form [nzLayout]=\"'inline'\">\r\n <!--<nz-form-item> <nz-col class=\"ant-form-item-control-wrapper\"> <div class=\"ant-form-item-control\"> <button nz-popconfirm nzTitle=\"\u786E\u8BA4\u6388\u6743\u5417?\" (nzOnConfirm)=\"assign()\" nz-button nzType=\"primary\">\u6388\u6743</button> <button nz-popconfirm nzTitle=\"\u786E\u8BA4\u53D6\u6D88\u6388\u6743\u5417?\" (nzOnConfirm)=\"cancel()\" nz-button nzType=\"warning\">\u53D6\u6D88\u6388\u6743</button> </div> </nz-col> </nz-form-item>-->\r\n <nz-form-item>\r\n <nz-form-label>\u7CFB\u7EDF</nz-form-label>\r\n <nz-col class=\"ant-form-item-control-wrapper\">\r\n <div class=\"ant-form-item-control\">\r\n <nz-select style=\"width: 240px\" name=\"appId\" nzShowSearch [(ngModel)]=\"appId\" (ngModelChange)=\"appChange()\">\r\n <nz-option *ngFor=\"let option of appList\" [nzLabel]=\"option.appName\" [nzValue]=\"option.appId\"></nz-option>\r\n </nz-select>\r\n </div>\r\n </nz-col>\r\n </nz-form-item>\r\n </form>\r\n </nz-affix>\r\n <st #st [data]=\"url\" [columns]=\"columns\" (change)=\"radioChange($event)\"></st>\r\n </div>\r\n <div nz-col nzSpan=\"11\" nzOffset=\"1\">\r\n <nz-affix [nzOffsetTop]=\"80\">\r\n <form nz-form [nzLayout]=\"'inline'\">\r\n <nz-form-item>\r\n <nz-col class=\"ant-form-item-control-wrapper\">\r\n <div class=\"ant-form-item-control\">\r\n <button acl [acl-ability]=\"'permission:add'\" nz-popconfirm nzTitle=\"\u786E\u8BA4\u6388\u6743\u5417?\" (nzOnConfirm)=\"assign()\" nz-button nzType=\"primary\">\u6388\u6743</button>\r\n <button acl [acl-ability]=\"'permission:remove'\" nz-popconfirm nzTitle=\"\u786E\u8BA4\u53D6\u6D88\u6388\u6743\u5417?\" (nzOnConfirm)=\"cancel()\" nz-button nzType=\"warning\">\u53D6\u6D88\u6388\u6743</button>\r\n </div>\r\n </nz-col>\r\n </nz-form-item>\r\n <nz-form-item>\r\n <nz-col class=\"ant-form-item-control-wrapper\">\r\n <div class=\"ant-form-item-control\">\r\n <nz-dropdown>\r\n <button nz-button nz-dropdown>\r\n \u64CD\u4F5C\r\n <i class=\"anticon anticon-down\"></i>\r\n </button>\r\n <ul nz-menu>\r\n <li (click)=\"expandAll(true)\" nz-menu-item>\r\n <a>\u5C55\u5F00\u6240\u6709</a>\r\n </li>\r\n <li (click)=\"expandAll(false)\" nz-menu-item>\r\n <a>\u6536\u8D77\u6240\u6709</a>\r\n </li>\r\n </ul>\r\n </nz-dropdown>\r\n </div>\r\n </nz-col>\r\n </nz-form-item>\r\n </form>\r\n </nz-affix>\r\n <nz-table #nzTable [nzData]=\"data\" [nzShowPagination]=\"false\" [nzFrontPagination]=\"false\" [nzBordered]=\"true\">\r\n <thead>\r\n <tr>\r\n <th nzShowCheckbox [(nzChecked)]=\"allChecked\" [nzIndeterminate]=\"indeterminate\" nzShowRowSelection [nzSelections]=\"listOfSelection\" (nzCheckedChange)=\"checkAll($event)\"></th>\r\n <th>\u8D44\u6E90\u540D\u79F0</th>\r\n <!--<th nzWidth=\"30%\">\u6743\u9650\u6807\u5FD7</th>-->\r\n <th>\u542F\u7528\u72B6\u6001</th>\r\n <th>\u6388\u6743\u72B6\u6001</th>\r\n </tr>\r\n </thead>\r\n <tbody>\r\n <ng-template ngFor let-data [ngForOf]=\"nzTable.data\">\r\n <ng-template ngFor let-item [ngForOf]=\"expandDataCache[data.id]\">\r\n <tr *ngIf=\"(item.parent&&item.parent.expand)||!(item.parent)\">\r\n <td nzShowCheckbox [(nzChecked)]=\"item.checked\" (nzCheckedChange)=\"refreshStatus($event)\"></td>\r\n <td [nzIndentSize]=\"item.level*20\" [nzShowExpand]=\"!!item.children\" [(nzExpand)]=\"item.expand\" (nzExpandChange)=\"treeService.collapse(expandDataCache[data.id],item,$event)\">{{item.rsrcName}}</td>\r\n <!--<td>{{item.permission}}</td>-->\r\n <td>{{item.rsrcStatusText}}</td>\r\n <td>{{item.assign}}</td>\r\n </tr>\r\n </ng-template>\r\n </ng-template>\r\n </tbody>\r\n </nz-table>\r\n </div>\r\n </div>\r\n</nz-card>",
styles: [":host ::ng-deep .ant-table-wrapper{margin-top:16px}"]
}] }
];
/** @nocollapse */
PermissionRoleComponent.ctorParameters = () => [
{ type: ModalHelper },
{ type: NzMessageService },
{ type: RoleService },
{ type: ResourceService },
{ type: TreeService },
{ type: AppsService }
];
PermissionRoleComponent.propDecorators = {
st: [{ type: ViewChild, args: ['st',] }]
};
if (false) {
/** @type {?} */
PermissionRoleComponent.prototype.url;
/** @type {?} */
PermissionRoleComponent.prototype.searchSchema;
/** @type {?} */
PermissionRoleComponent.prototype.st;
/** @type {?} */
PermissionRoleComponent.prototype.columns;
/** @type {?} */
PermissionRoleComponent.prototype.appId;
/** @type {?} */
PermissionRoleComponent.prototype.appList;
/** @type {?} */
PermissionRoleComponent.prototype.selectedRole;
/** @type {?} */
PermissionRoleComponent.prototype.data;
/** @type {?} */
PermissionRoleComponent.prototype.dataList;
/** @type {?} */
PermissionRoleComponent.prototype.expandDataCache;
/** @type {?} */
PermissionRoleComponent.prototype.allChecked;
/** @type {?} */
PermissionRoleComponent.prototype.indeterminate;
/** @type {?} */
PermissionRoleComponent.prototype.listOfSelection;
/**
* @type {?}
* @private
*/
PermissionRoleComponent.prototype.modal;
/**
* @type {?}
* @private
*/
PermissionRoleComponent.prototype.msgSrv;
/** @type {?} */
PermissionRoleComponent.prototype.roleService;
/** @type {?} */
PermissionRoleComponent.prototype.resourceService;
/** @type {?} */
PermissionRoleComponent.prototype.treeService;
/** @type {?} */
PermissionRoleComponent.prototype.appsService;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"role.component.js","sourceRoot":"ng://@ecip/permission/","sources":["src/role/role.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {Component, OnDestroy, OnInit, ViewChild} from '@angular/core';\r\nimport { _HttpClient, ModalHelper } from '@delon/theme';\r\nimport { STColumn, STComponent } from '@delon/abc';\r\nimport { SFSchema } from '@delon/form';\r\nimport {NzMessageService} from 'ng-zorro-antd';\r\nimport {PermissionRoleEditComponent} from \"./edit/edit.component\";\r\nimport {PermissionRoleViewComponent} from \"./view/view.component\";\r\nimport {TreeService} from \"@ecip/shared\";\r\nimport {PermissionRoleUserComponent} from \"./user/role.user.component\";\r\nimport {AppsService, ResourceService, RoleService} from \"@ecip/service\";\r\n\r\n@Component({\r\n  selector: 'app-permission-role',\r\n  templateUrl: './role.component.html',\r\n  styleUrls: ['./role.component.less']\r\n})\r\nexport class PermissionRoleComponent implements OnInit {\r\n  url = `api/v1/sysrRole/list`;\r\n  searchSchema: SFSchema = {\r\n    properties: {\r\n      id: {\r\n        type: 'string',\r\n        title: '编号'\r\n      }\r\n    }\r\n  };\r\n  @ViewChild('st') st: STComponent;\r\n  columns: STColumn[] = [\r\n    // { title: '编号', index: 'id' },\r\n    { title: '', index: 'id', type: 'radio' },\r\n    // { title: '应用系统', index: 'appId' },\r\n    { title: '角色名称', index: 'roleName' },\r\n    { title: '编码', index: 'code' },\r\n    { title: '角色状态', index: 'statusText' },\r\n    // { title: '排序', index: 'sortNum' },\r\n    // { title: '创建时间', type: 'date', index: 'createTime' },\r\n    {\r\n      title: '操作',\r\n      width: '100px',\r\n      buttons: [\r\n        { text: '删除', type: 'del', click: (item: any) => {\r\n            //删除\r\n            this.roleService.deleteById(item.id).subscribe(res => {\r\n              this.msgSrv.success('删除成功');\r\n              this.st.reload();\r\n            });\r\n          },\r\n          acl: { ability: ['permission:remove'] }\r\n        },\r\n        {\r\n          text: '',\r\n          children: [\r\n            { text: '查看', type: 'static', component: PermissionRoleViewComponent, click: 'reload', acl: { ability: ['role:view'] } },\r\n            { text: '编辑', type: 'none',\r\n              click: (record: any) => {\r\n                this.modal\r\n                  .createStatic(PermissionRoleEditComponent, {appId: this.appId, record: record})\r\n                  .subscribe(() => this.st.reload());\r\n              },\r\n              acl: { ability: ['role:edit'] }\r\n            },\r\n            { text: '人员', type: 'static', component: PermissionRoleUserComponent, click: 'reload', acl: { ability: ['member:choose'] } }\r\n          ],\r\n        },\r\n      ]\r\n    }\r\n  ];\r\n\r\n  appId = -1;\r\n  appList;\r\n\r\n  selectedRole: any;\r\n  data:any = [];\r\n  dataList:any = []; //所有节点数组\r\n  expandDataCache = {};\r\n\r\n  allChecked = false;\r\n  indeterminate = false;\r\n  listOfSelection = [\r\n    {\r\n      text    : '全选',\r\n      onSelect: () => {\r\n        this.checkAll(true);\r\n      }\r\n    },\r\n    {\r\n      text    : '全不选',\r\n      onSelect: () => {\r\n        this.checkAll(false);\r\n      }\r\n    }\r\n  ];\r\n\r\n  refreshStatus($event ?: any): void {\r\n    if (!this.selectedRole) {\r\n      this.msgSrv.warning('请选择角色');\r\n      return;\r\n    }\r\n\r\n    const allChecked = this.dataList.every(value => value.checked === true);\r\n    const allUnChecked = this.dataList.every(value => !value.checked);\r\n    this.allChecked = allChecked;\r\n    this.indeterminate = (!allChecked) && (!allUnChecked);\r\n  }\r\n\r\n  checkAll(value: boolean): void {\r\n    if (!this.selectedRole) {\r\n      this.msgSrv.warning('请选择要授权的角色');\r\n      return;\r\n    }\r\n    this.dataList.forEach(data => {\r\n      if (!data.disabled) {\r\n        data.checked = value;\r\n      }\r\n    });\r\n    this.refreshStatus();\r\n  }\r\n\r\n  expandAll(value: boolean): void {\r\n    this.dataList.forEach(data => {\r\n      data.expand = value;\r\n    });\r\n  }\r\n\r\n  constructor(private modal: ModalHelper, private msgSrv: NzMessageService,\r\n              public roleService: RoleService, public resourceService: ResourceService,\r\n              public treeService: TreeService, public appsService: AppsService, ) { }\r\n\r\n  ngOnInit() {\r\n    this.st.req.params = {appId: this.appId};\r\n    this.appsService.getList().subscribe(appList => {\r\n      this.appList = appList;\r\n    });\r\n    this.appChange();\r\n  }\r\n\r\n  appChange() {\r\n    this.selectedRole = null;\r\n    this.st.reload({appId: this.appId});\r\n    this.resourceService.findTree({appId: this.appId}).subscribe((res:any) => {\r\n      this.data = res;\r\n      this.data.forEach(item => {\r\n        this.expandDataCache[ item.id ] = TreeService.convertTreeToList(item);\r\n        this.dataList = [...this.dataList, ...this.expandDataCache[item.id]];\r\n      });\r\n    });\r\n  }\r\n\r\n  add() {\r\n    this.modal\r\n      .createStatic(PermissionRoleEditComponent, {appId: this.appId})\r\n      .subscribe(() => this.st.reload({appId: this.appId}));\r\n  }\r\n\r\n  radioChange(item: any) {\r\n    if (!item.radio) {\r\n      return;\r\n    }\r\n    item = item.radio;\r\n    this.selectedRole = item;\r\n    this.roleService.findResource(item.id).subscribe((res:string[]) => {\r\n      this.dataList.forEach(_item => {\r\n        if (res.includes(_item.id)) {\r\n          _item.assign = '已授权';\r\n        } else {\r\n          _item.assign = '未授权';\r\n        }\r\n      });\r\n    });\r\n  }\r\n\r\n  assign() {\r\n    if (!this.selectedRole) {\r\n      this.msgSrv.warning('请选择要授权的角色');\r\n      return;\r\n    }\r\n    console.log('assign');\r\n    let resourceIds = this.getCheckIds();\r\n    if (resourceIds.length == 0) {\r\n      this.msgSrv.warning('请选择要授权的资源');\r\n      return;\r\n    }\r\n    this.roleService.saveResource(this.selectedRole.id, resourceIds).subscribe(res => {\r\n      this.msgSrv.success('授权成功');\r\n      // this.dataList.filter(item => item.).checked = true;\r\n      this.dataList.forEach(item => {\r\n        if (item.checked === true) {\r\n          item.assign = '已授权';\r\n        }\r\n      });\r\n    });\r\n  }\r\n\r\n  cancel() {\r\n    if (!this.selectedRole) {\r\n      this.msgSrv.warning('请选择要取消授权的角色');\r\n      return;\r\n    }\r\n    console.log('cancel');\r\n    let resourceIds = this.getCheckIds();\r\n    if (resourceIds.length == 0) {\r\n      this.msgSrv.warning('请选择要取消授权的资源');\r\n      return;\r\n    }\r\n    this.roleService.deleteResource(this.selectedRole.id, resourceIds).subscribe(res => {\r\n      this.msgSrv.success('取消授权成功');\r\n      // this.dataList.filter(item => item.).checked = true;\r\n      this.dataList.forEach(item => {\r\n        if (item.checked === true) {\r\n          item.assign = '未授权';\r\n        }\r\n      });\r\n    });\r\n  }\r\n\r\n  getCheckIds():string[] {\r\n    let checkIds = [];\r\n    this.dataList.forEach(item => {\r\n      if (item.checked === true) {\r\n        checkIds.push(item.id);\r\n      }\r\n    });\r\n    return checkIds;\r\n  }\r\n\r\n}\r\n"]}