Skip to content
alarm-modal.component.ts 6.17 KiB
Newer Older
wangqinghua's avatar
wangqinghua committed
import {Component, EventEmitter, OnInit, Output, ViewChild} from '@angular/core';
wangqinghua's avatar
wangqinghua committed
import {AlarmService} from '../../alarm/alarm.service';
import {FindUserComponent} from '../../alarm/modal/find-user/find-user.component';
wangqinghua's avatar
wangqinghua committed
import {NzFormatEmitEvent, NzMessageService, NzTreeComponent, NzTreeNode} from 'ng-zorro-antd';
import {OverAllService} from '../../overAll/overAll.service';
wangqinghua's avatar
wangqinghua committed

@Component({
wangqinghua's avatar
wangqinghua committed
    selector: 'smart-alarm-modal',
    templateUrl: './alarm-modal.component.html',
wangqinghua's avatar
wangqinghua committed
    styles: [
            `
            .tree-div {
wangqinghua's avatar
wangqinghua committed
                border: 1px solid #dadada;
                height: 200px;
                overflow: auto;
                margin-top: 10px;
wangqinghua's avatar
wangqinghua committed
            }
        `
    ]
wangqinghua's avatar
wangqinghua committed
})
export class AlarmModalComponent implements OnInit {
wangqinghua's avatar
wangqinghua committed
    @ViewChild('smartFindUser') smartFindUser: FindUserComponent;
    @ViewChild('nzTree') nzTree: NzTreeComponent;
wangqinghua's avatar
wangqinghua committed
    @Output() done = new EventEmitter<any>();
wangqinghua's avatar
wangqinghua committed

    modalTitle = '添加告警';
    tabNum = 0;
    isShow = false;
wangqinghua's avatar
wangqinghua committed
    nodes;
    nodeList;
wangqinghua's avatar
wangqinghua committed

wangqinghua's avatar
wangqinghua committed
    groupList;
wangqinghua's avatar
wangqinghua committed
    sendOption = [];
wangqinghua's avatar
wangqinghua committed
    objList;
wangqinghua's avatar
wangqinghua committed

wangqinghua's avatar
wangqinghua committed
    selectTreeList = [];
wangqinghua's avatar
wangqinghua committed
    validateForm;

wangqinghua's avatar
wangqinghua committed
    constructor(private alarmSer: AlarmService, private message: NzMessageService,
                private overAllSer: OverAllService) {
wangqinghua's avatar
wangqinghua committed
    }

    ngOnInit() {
        this.initForm();
        this.getSendFun();
wangqinghua's avatar
wangqinghua committed
        this.getACtion();
wangqinghua's avatar
wangqinghua committed
        this.getGroup();
wangqinghua's avatar
wangqinghua committed
        this.getZabbixObj();
wangqinghua's avatar
wangqinghua committed
    }
wangqinghua's avatar
wangqinghua committed

wangqinghua's avatar
wangqinghua committed
    //初始化
    initForm() {
wangqinghua's avatar
wangqinghua committed
        this.selectTreeList = [];
wangqinghua's avatar
wangqinghua committed
        this.validateForm = {
            name: null,
            alertGroupId: null,
wangqinghua's avatar
wangqinghua committed
            warn:0,
            serious:0,
            mediaTypeIds:[],
            def_longdata:null,
            r_longdata:null,
            r_shortdata:null,
            userIds:null,
wangqinghua's avatar
wangqinghua committed
        };
    }

wangqinghua's avatar
wangqinghua committed
    //获取告警目标
wangqinghua's avatar
wangqinghua committed
    getACtion() {
wangqinghua's avatar
wangqinghua committed
        this.overAllSer.findGroup().subscribe(
            (res) => {
                if (res.errCode == 10000) {
                    const dataSet = res.data;
                    dataSet.forEach(res => {
                        res.title = res.name;
                        res.key = res.groupid;
                    });
                    this.nodeList = dataSet;
                    this.toNode(dataSet);
                } else {
                    this.message.info(res.errMsg);
                }
            }
        );
    }

wangqinghua's avatar
wangqinghua committed
    //获取告警分组
    getGroup(){
        this.alarmSer.alertGroupFind().subscribe(
            (res) => {
                if (res.errCode == 10000) {
                    this.groupList = res.data;
                }
            }
        );
    }

wangqinghua's avatar
wangqinghua committed
    toNode(data) {
        this.nodes = data.map(res => {
            return new NzTreeNode(res);
        });
    }

    //下级
    mouseAction(name: string, event: NzFormatEmitEvent) {
        const index = <any>event.node.key - 1;
        const data = {
            'groupids': [event.node.origin.groupid],
            'hostExtend': {
                'superiorHostid': null
            }
        };
        this.overAllSer.findDetail(data).subscribe(
            (res) => {
                if (res.data) {
                    const dataSet = res.data;
                    dataSet.forEach(res => {
                        res.title = res.name;
                        res.key = res.groupid;
                        res.isLeaf = true;
                    });
                    event.node.addChildren(dataSet);
                    this.nodeList[index].children = dataSet;
                    this.nodeList[index].expanded = true;
                } else {
                    event.node.addChildren([]);
                    this.message.info('该分组下无资源');
                }

            }
        );
        setTimeout(_ => {
        }, 1000);
        // }
    }

    //选择树节点
    selectCheckTree(event: NzFormatEmitEvent) {
        if (event.node.isChecked) {
            this.selectTreeList.push(event.node.origin.hostid);
        } else {
            const index = this.selectTreeList.indexOf(event.node.origin.hostid);
            this.selectTreeList.splice(index, 1);
        }
    }

wangqinghua's avatar
wangqinghua committed
    //获取发送方式
    getSendFun() {
        this.alarmSer.mediaTypeFind({}).subscribe(
            (res) => {
                if (res.errCode == 10000) {
                    this.sendOption = res.data;
                    this.sendOption.forEach(res => {
                        res.label = res.description;
                        res.value = res.mediatypeid;
                        res.checked = false;
                    });
                }
            }
        );
    }
wangqinghua's avatar
wangqinghua committed

wangqinghua's avatar
wangqinghua committed
    //获取发送对象 zabbix
    getZabbixObj() {
        this.alarmSer.zUserFind({}).subscribe(
            (res) => {
                if (res.errCode == 10000) {
                    this.objList = res.data;
                }
            }
        );
wangqinghua's avatar
wangqinghua committed
    }

    showModal(data) {
        this.isShow = true;
    }
wangqinghua's avatar
wangqinghua committed

wangqinghua's avatar
wangqinghua committed
    handleEditCancel() {
        this.isShow = false;
wangqinghua's avatar
wangqinghua committed
    }

wangqinghua's avatar
wangqinghua committed
    tabsChange(index) {
        this.tabNum = index;
wangqinghua's avatar
wangqinghua committed
    }

wangqinghua's avatar
wangqinghua committed
    handEditleOk() {
wangqinghua's avatar
wangqinghua committed
        const optionArr = [];
        this.sendOption.forEach(res=>{
            if(res.checked){
                optionArr.push(res.value);
            }
        });
        if(this.validateForm.warn){
            this.validateForm.warn = 1;
        }else{
            this.validateForm.warn = 0
        }

        if(this.validateForm.serious){
            this.validateForm.serious = 1;
        }else{
            this.validateForm.serious = 0
        }

wangqinghua's avatar
wangqinghua committed
        const data = {
            name: this.validateForm.name,
wangqinghua's avatar
wangqinghua committed
            alertGroupId: this.validateForm.alertGroupId,
            warn:this.validateForm.warn,
            serious:this.validateForm.serious,
            mediaTypeIds:optionArr,
            userIds:this.validateForm.userIds,
            def_longdata:this.validateForm.def_longdata,
            r_longdata:this.validateForm.r_longdata,
            r_shortdata:this.validateForm.r_shortdata,
wangqinghua's avatar
wangqinghua committed
        };
        this.alarmSer.actionCreate(data).subscribe(
            (res) => {
wangqinghua's avatar
wangqinghua committed
                if(res.errCode == 10000){
                    this.isShow = false;
                    this.initForm();
                    this.done.emit();
                }
wangqinghua's avatar
wangqinghua committed
                this.message.info(res.errMsg);
            }
        );
wangqinghua's avatar
wangqinghua committed
    }

wangqinghua's avatar
wangqinghua committed
}