Skip to content
role.component.ts 5.68 KiB
Newer Older
wangqinghua's avatar
wangqinghua committed
import {Component, EventEmitter, OnInit, Output} from '@angular/core';
import {
    AbstractControl,
    FormBuilder,
    FormControl,
    FormGroup,
    Validators
} from '@angular/forms';
import {SystemService} from '../../system.service';
wangqinghua's avatar
wangqinghua committed
import {NzMessageService, NzTreeNode} from 'ng-zorro-antd';
import {LayoutService} from '../../../layouts/layout.service';
wangqinghua's avatar
wangqinghua committed
import {CommonService} from '../../../shared/common/common.service';
wangqinghua's avatar
wangqinghua committed
import {OverAllService} from '../../../overAll/overAll.service';
wangqinghua's avatar
wangqinghua committed

@Component({
    selector: 'smart-role',
    templateUrl: './role.component.html',
wangqinghua's avatar
wangqinghua committed
    styles: [
            `
            .tree-div p {
                margin: 0;
            }`
    ]
wangqinghua's avatar
wangqinghua committed
})
export class RoleComponent implements OnInit {
    @Output() add = new EventEmitter<any>();

wangqinghua's avatar
wangqinghua committed
    title;
wangqinghua's avatar
wangqinghua committed
    isVisible = false;
    validateForm: FormGroup;
wangqinghua's avatar
wangqinghua committed
    menuList;

    nodes;
    nodeList;
wangqinghua's avatar
wangqinghua committed
    roleId;
wangqinghua's avatar
wangqinghua committed
    groupList = [];
    moduleList = [];   //菜单权限
    resourceList = [];   //主机分组权限
wangqinghua's avatar
wangqinghua committed

wangqinghua's avatar
wangqinghua committed
    constructor(private fb: FormBuilder, private message: NzMessageService, private overAllSer: OverAllService,
                private systemSer: SystemService, private layoutSer: LayoutService, private commonSer: CommonService) {
wangqinghua's avatar
wangqinghua committed
    }

    ngOnInit() {
wangqinghua's avatar
wangqinghua committed
        this.ininForm();
        this.getMenu();
wangqinghua's avatar
wangqinghua committed
        this.getGroup();
wangqinghua's avatar
wangqinghua committed
    }

wangqinghua's avatar
wangqinghua committed
    ininForm() {
wangqinghua's avatar
wangqinghua committed
        this.validateForm = this.fb.group({
            name: [null, [Validators.required]],
            status: [null, [Validators.required]],
wangqinghua's avatar
wangqinghua committed
            comment: [null, [Validators.required]],
wangqinghua's avatar
wangqinghua committed
        });
    }

wangqinghua's avatar
wangqinghua committed
    //获取菜单栏
wangqinghua's avatar
wangqinghua committed
    getMenu() {
wangqinghua's avatar
wangqinghua committed
        this.systemSer.getMenuBySeparation().subscribe(
wangqinghua's avatar
wangqinghua committed
            (res) => {
                if (res.errCode == 10000) {
                    this.menuList = this.commonSer.listToTree('id', 'parentId', res.data);
wangqinghua's avatar
wangqinghua committed
                    this.menuList.forEach(res => {
                        res.title = res.name;
                        res.key = res.id;
wangqinghua's avatar
wangqinghua committed
                        res.children.forEach((child) => {
wangqinghua's avatar
wangqinghua committed
                            child.title = child.name;
                            child.key = child.id;
                            child.isLeaf = true;
wangqinghua's avatar
wangqinghua committed
                        });
wangqinghua's avatar
wangqinghua committed
                    });
                    this.toNode(this.menuList);
                }
            }
wangqinghua's avatar
wangqinghua committed
        );
    }

    //获取分组
    getGroup() {
        this.groupList = [];
        this.overAllSer.findGroup().subscribe(
            (res) => {
                this.groupList = res.data;
                this.groupList.forEach(e => {
                    e.checked = false;
                });
            }
        );
wangqinghua's avatar
wangqinghua committed
    }

    toNode(data) {
        this.nodes = data.map(res => {
            return new NzTreeNode(res);
        });
    }

wangqinghua's avatar
wangqinghua committed
    //获取所有分组

wangqinghua's avatar
wangqinghua committed
    showAddModal(): void {
        this.title = '新增角色';
wangqinghua's avatar
wangqinghua committed
        this.isVisible = true;
    }

wangqinghua's avatar
wangqinghua committed
    showEditModal(id) {
        this.title = '编辑角色';
wangqinghua's avatar
wangqinghua committed
        this.isVisible = true;
wangqinghua's avatar
wangqinghua committed
        this.roleId = id;
wangqinghua's avatar
wangqinghua committed
        this.systemSer.getRole(id).subscribe(
wangqinghua's avatar
wangqinghua committed
            (res) => {
                if (res.errCode == 10000) {
wangqinghua's avatar
wangqinghua committed
                    const data = res.data.role;
wangqinghua's avatar
wangqinghua committed
                    data.status += '';
wangqinghua's avatar
wangqinghua committed
                    this.validateForm.patchValue(data);
                }
            }
wangqinghua's avatar
wangqinghua committed
        );
wangqinghua's avatar
wangqinghua committed
    }

wangqinghua's avatar
wangqinghua committed
    handleCancel(): void {
        this.isVisible = false;
    }

wangqinghua's avatar
wangqinghua committed
    handleOk() {
wangqinghua's avatar
wangqinghua committed
        for (let i in this.validateForm.controls) {
wangqinghua's avatar
wangqinghua committed
            this.validateForm.controls[i].markAsDirty();
            this.validateForm.controls[i].updateValueAndValidity();
        }
wangqinghua's avatar
wangqinghua committed

wangqinghua's avatar
wangqinghua committed
        if (this.validateForm.invalid) {
            return false;
        }
wangqinghua's avatar
wangqinghua committed

wangqinghua's avatar
wangqinghua committed
        let resourceArr = [];
        this.resourceList.forEach(e=>{
            if(e.checked){
                resourceArr.push(e.id);
            }
        })

        if (this.title == '新增角色') {
            this.create(resourceArr);
wangqinghua's avatar
wangqinghua committed
        }
wangqinghua's avatar
wangqinghua committed
        if (this.title == '编辑角色') {
            this.update(resourceArr);
wangqinghua's avatar
wangqinghua committed
        }
    }

    //新增
wangqinghua's avatar
wangqinghua committed
    create(resourceArr) {
wangqinghua's avatar
wangqinghua committed
        const data = {
wangqinghua's avatar
wangqinghua committed
            role: {
                name: this.validateForm.value.name,
                status: this.validateForm.value.status,
                comment: this.validateForm.value.comment,
wangqinghua's avatar
wangqinghua committed
            },
wangqinghua's avatar
wangqinghua committed
            modules: this.moduleList,
            resources: resourceArr
wangqinghua's avatar
wangqinghua committed
        };
        this.systemSer.addRole(data).subscribe(
wangqinghua's avatar
wangqinghua committed
            (res) => {
                if (res.errCode == 10000) {
                    this.isVisible = false;
                    this.add.emit();
wangqinghua's avatar
wangqinghua committed
                    this.ininForm();
                    this.message.success('新增成功');
wangqinghua's avatar
wangqinghua committed
                } else {
wangqinghua's avatar
wangqinghua committed
                    this.message.error(res.errMsg);
                }
            }
        );
    }

    //编辑
wangqinghua's avatar
wangqinghua committed
    update(resourceArr) {
wangqinghua's avatar
wangqinghua committed
        const data = {
wangqinghua's avatar
wangqinghua committed
            role: {
                id: this.roleId,
                name: this.validateForm.value.name,
                status: this.validateForm.value.status,
                comment: this.validateForm.value.comment,
wangqinghua's avatar
wangqinghua committed
            },
wangqinghua's avatar
wangqinghua committed
            modules: this.moduleList,
            resources: resourceArr
wangqinghua's avatar
wangqinghua committed
        };
        this.systemSer.editRole(data).subscribe(
            (res) => {
                if (res.errCode == 10000) {
                    this.isVisible = false;
                    this.add.emit();
                    this.ininForm();
                    this.message.success('修改成功');
wangqinghua's avatar
wangqinghua committed
                } else {
wangqinghua's avatar
wangqinghua committed
                    this.message.error(res.errMsg);
wangqinghua's avatar
wangqinghua committed
                }
            }
        );
    }

wangqinghua's avatar
wangqinghua committed
    selectCheckTree(e) {
        if (e.node.isChecked) {
            this.moduleList.push(e.node.key);
        } else {
            const index = this.moduleList.indexOf(e.node.key);
            this.moduleList.splice(index, 1);
        }
wangqinghua's avatar
wangqinghua committed
    }
wangqinghua's avatar
wangqinghua committed
}