Skip to content
strategy.component.ts 7.63 KiB
Newer Older
wangqinghua's avatar
wangqinghua committed
import {Component, EventEmitter, OnInit, Output} from '@angular/core';
import {FormBuilder} from '@angular/forms';
import {Router} from '@angular/router';
import {JhiMainComponent} from '../../layouts';
import {NzMessageService, NzModalService} from 'ng-zorro-antd';
import {OverAllService} from '../../overAll/overAll.service';
wangqinghua's avatar
wangqinghua committed

@Component({
wangqinghua's avatar
wangqinghua committed
    selector: 'smart-strategy',
    templateUrl: './strategy.component.html',
    styles: []
wangqinghua's avatar
wangqinghua committed
})
export class StrategyComponent implements OnInit {

wangqinghua's avatar
wangqinghua committed
    @Output() done = new EventEmitter<any>();
    isVisible = false;
    title;
    tabNum = 0;
    nzSize = 'large';
wangqinghua's avatar
wangqinghua committed

wangqinghua's avatar
wangqinghua committed
    validateForm;
    tempId;   //模版Id
    templateList = [];  //模版组
wangqinghua's avatar
wangqinghua committed
    templatesResoure;  //old模版
wangqinghua's avatar
wangqinghua committed

    tempList;  //模版

    //宏
    macroTYpe = 'macro';      //宏tabs
    mainHost = 'hostType1';      //主机tabs
wangqinghua's avatar
wangqinghua committed
    macroList1 = [];
    macroList2 = [];      //配置宏数组
wangqinghua's avatar
wangqinghua committed

    constructor(private fb: FormBuilder, private overAllSer: OverAllService, private router: Router,
                private modalService: NzModalService, private message: NzMessageService, private main: JhiMainComponent) {
    }

    ngOnInit() {
        this.getTemplateGroup();
        this.getTemplate();
        this.initForm();
    }

    initForm() {
wangqinghua's avatar
wangqinghua committed
        this.tabNum = 0;
wangqinghua's avatar
wangqinghua committed
        this.templateList.forEach(e => {
            e.checked = false;
        });
        this.macroList1 = [];
        this.macroList2 = [];
wangqinghua's avatar
wangqinghua committed
        this.validateForm = {
            host: null,
            name: null,
            groups: [],
            templates: [],
            macros: [],
            hosts: [],
        };
    }

    //获取模版组
    getTemplateGroup() {
        this.templateList = [];
wangqinghua's avatar
wangqinghua committed
        this.overAllSer.getEditGroups(1).subscribe(
wangqinghua's avatar
wangqinghua committed
            (res) => {
                const list = res.data;
                list.forEach(e => {
                    const gObj = {
                        label: e.name, value: e.groupid, checked: false
                    };
                    this.templateList.push(gObj);
                });
            }
        );
    }

    //获取模版
    getTemplate() {
        this.tempList = [];
        this.overAllSer.templates().subscribe(
            (res) => {
                this.tempList = res.data;
            }
        );
    }

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

    showAddModal(title): void {
        this.isVisible = true;
        this.title = title;
    }

wangqinghua's avatar
wangqinghua committed
    showEditModal(title, id) {
wangqinghua's avatar
wangqinghua committed
        this.isVisible = true;
        this.title = title;
        this.tempId = id;
        const data = {
wangqinghua's avatar
wangqinghua committed
            templateids: [this.tempId]
        };
wangqinghua's avatar
wangqinghua committed
        this.overAllSer.findTemplates(data).subscribe(
wangqinghua's avatar
wangqinghua committed
            (res) => {
wangqinghua's avatar
wangqinghua committed
                const data = res.data[0];
                this.validateForm.host = data.host;
                this.validateForm.name = data.name;
wangqinghua's avatar
wangqinghua committed
                if (data.groups) {
wangqinghua's avatar
wangqinghua committed
                    //所在组回显
wangqinghua's avatar
wangqinghua committed
                    this.templateList.forEach(e1 => {
                        data.groups.forEach(e2 => {
                            if (e1.value == e2.groupid) {
wangqinghua's avatar
wangqinghua committed
                                e1.checked = true;
                            }
wangqinghua's avatar
wangqinghua committed
                        });
wangqinghua's avatar
wangqinghua committed
                    });
                }

wangqinghua's avatar
wangqinghua committed
                if (data.parentTemplates) {
wangqinghua's avatar
wangqinghua committed
                    //模版回显
wangqinghua's avatar
wangqinghua committed
                    let tempArr = [];
                    tempArr = data.parentTemplates.map(e => {
wangqinghua's avatar
wangqinghua committed
                        return e.templateid;
wangqinghua's avatar
wangqinghua committed
                    });
wangqinghua's avatar
wangqinghua committed
                    this.validateForm.templates = tempArr;
                    this.templatesResoure = tempArr;
wangqinghua's avatar
wangqinghua committed
                }
wangqinghua's avatar
wangqinghua committed
                if(data.macros){
                    //宏回显
                    let macroArr = [];
                    macroArr = data.macros.map(e=>{
                        const d = {
                            macro:e.macro,
                            value:e.value,
                        };
                        return d;
                    })
                    this.macroList1 = macroArr;
                }
wangqinghua's avatar
wangqinghua committed
            }
wangqinghua's avatar
wangqinghua committed
        );
wangqinghua's avatar
wangqinghua committed
    }

wangqinghua's avatar
wangqinghua committed
    check() {
wangqinghua's avatar
wangqinghua committed
        const han = /.*[\u4e00-\u9fa5]+.*$/;
        if (han.test(this.validateForm.host)) {
wangqinghua's avatar
wangqinghua committed
            this.message.error('模版真实名称不能输入中文');
wangqinghua's avatar
wangqinghua committed
            return false;
wangqinghua's avatar
wangqinghua committed
        };
wangqinghua's avatar
wangqinghua committed
        return true;
    }

    handleOk() {
wangqinghua's avatar
wangqinghua committed
        if (!this.check()) {
wangqinghua's avatar
wangqinghua committed
            return false;
        }
        const arr = [];
wangqinghua's avatar
wangqinghua committed
        this.templateList.forEach(e => {
            if (e.checked) {
wangqinghua's avatar
wangqinghua committed
                const d = {
wangqinghua's avatar
wangqinghua committed
                    groupid: e.value
                };
wangqinghua's avatar
wangqinghua committed
                arr.push(d);
            }
        });
wangqinghua's avatar
wangqinghua committed
        if (this.macroTYpe == 'macroExpand') {
            this.validateForm.macros = this.macroList2;
        }
        if (this.macroTYpe == 'macro') {
            this.validateForm.macros = this.macroList1;
        }
        if (this.title == '添加模版') {
wangqinghua's avatar
wangqinghua committed
            this.create(arr);
        }
wangqinghua's avatar
wangqinghua committed
        if (this.title == '编辑模版') {
wangqinghua's avatar
wangqinghua committed
            this.update(arr);
        }
    }

wangqinghua's avatar
wangqinghua committed
    create(arr) {
wangqinghua's avatar
wangqinghua committed
        const data = {
            host: this.validateForm.host,
            name: this.validateForm.name,
            groups: arr,
wangqinghua's avatar
wangqinghua committed
            templates: this.validateForm.templates.map(e => {
wangqinghua's avatar
wangqinghua committed
                const d = {
wangqinghua's avatar
wangqinghua committed
                    templateid: e
                };
wangqinghua's avatar
wangqinghua committed
                return d;
            }),
wangqinghua's avatar
wangqinghua committed
            macros: this.validateForm.macros,
wangqinghua's avatar
wangqinghua committed
            hosts: [],
        };
        this.overAllSer.createTemplates(data).subscribe(
wangqinghua's avatar
wangqinghua committed
            (res) => {
                if (res.errCode == 10000) {
                    this.message.success('添加模版成功');
wangqinghua's avatar
wangqinghua committed
                    this.initForm();
                    this.done.emit();
                    this.isVisible = false;
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
    }

wangqinghua's avatar
wangqinghua committed
    update(arr) {
wangqinghua's avatar
wangqinghua committed
        //比较监控模版是否发生变化
        const clearArr = [];
        this.templatesResoure.forEach(res => {
            if (this.validateForm.templates.indexOf(res) == -1) {
                const d = {
                    templateid:res
                }
                clearArr.push(d);
            }
        });
wangqinghua's avatar
wangqinghua committed
        const data = {
wangqinghua's avatar
wangqinghua committed
            templateid: this.tempId,   //模版id
wangqinghua's avatar
wangqinghua committed
            host: this.validateForm.host,
            name: this.validateForm.name,
            groups: arr,
wangqinghua's avatar
wangqinghua committed
            templates: this.validateForm.templates.map(e => {
wangqinghua's avatar
wangqinghua committed
                const d = {
wangqinghua's avatar
wangqinghua committed
                    templateid: e
                };
wangqinghua's avatar
wangqinghua committed
                return d;
            }),
wangqinghua's avatar
wangqinghua committed
            templates_clear:clearArr,
            macros: this.validateForm.macros,
wangqinghua's avatar
wangqinghua committed
            hosts: [],
wangqinghua's avatar
wangqinghua committed
        };
wangqinghua's avatar
wangqinghua committed
        this.overAllSer.updateTemplates(data).subscribe(
wangqinghua's avatar
wangqinghua committed
            (res) => {
                if (res.errCode == 10000) {
                    this.message.success('修改模版成功');
wangqinghua's avatar
wangqinghua committed
                    this.initForm();
                    this.done.emit();
                    this.isVisible = false;
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
    }

    handleCancel(): void {
        this.isVisible = false;
        this.initForm();
    }

    //新增宏
    addMacro1() {
        const data = {
            macro: '{$SNMP_COMMUNITY}',
            value: 'public',
        };
        this.macroList1.push(data);
    }

    //移除宏
    deleteMacro1(index) {
        this.macroList1.splice(index, 1);
    }

    //新增主机宏
    addMacro2() {
        const data = {
            macro: '{$SNMP_COMMUNITY}',
            value: 'public',
        };
        this.macroList2.push(data);
    }

    //移除主机宏
    deleteMacro2(index) {
        this.macroList2.splice(index, 1);
    }
wangqinghua's avatar
wangqinghua committed

}