Skip to content
check.component.ts 4 KiB
Newer Older
wangqinghua's avatar
wangqinghua committed
import {Component, EventEmitter, OnInit, Output} from '@angular/core';
import {FormBuilder, FormControl, FormGroup, Validators} from '@angular/forms';
import {NzFormatEmitEvent, NzMessageService, NzTreeNode} from 'ng-zorro-antd';
import {TopologyService} from '../../topology.service';
import {type} from 'os';
wangqinghua's avatar
wangqinghua committed

@Component({
    selector: 'smart-check',
    templateUrl: './check.component.html',
    styles: []
})
export class CheckComponent implements OnInit {
wangqinghua's avatar
wangqinghua committed
    @Output() done = new EventEmitter<any>();
wangqinghua's avatar
wangqinghua committed

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

wangqinghua's avatar
wangqinghua committed
    nodes;
    nodeList;
    selectId;
wangqinghua's avatar
wangqinghua committed
    fontSizeList = ['8','9','10','11','12','13','14','16','18','20','28','36','48','72'];
wangqinghua's avatar
wangqinghua committed

    constructor(private fb:FormBuilder,private topologySer:TopologyService,
                private message:NzMessageService) {
wangqinghua's avatar
wangqinghua committed
    }

    ngOnInit() {
wangqinghua's avatar
wangqinghua committed
        this.initForm();
wangqinghua's avatar
wangqinghua committed
        this.findTree();
wangqinghua's avatar
wangqinghua committed
    }

wangqinghua's avatar
wangqinghua committed
    initForm(){
        this.validateForm = this.fb.group({
            name:['',[Validators.required]],
wangqinghua's avatar
wangqinghua committed
            fontSize:['12',[Validators.required]],
wangqinghua's avatar
wangqinghua committed
        })
    }
wangqinghua's avatar
wangqinghua committed

wangqinghua's avatar
wangqinghua committed
    showAddModal() {
wangqinghua's avatar
wangqinghua committed
        this.isVisible = true;
        this.title = '添加监测点';
    }

    showEditModal() {
        this.title = '编辑监测点';
        this.isVisible = true;
    }

wangqinghua's avatar
wangqinghua committed
    //查询树
    findTree() {
        const data = {
            id: '',
            type: 'group'
        };
        this.topologySer.findTree(data).subscribe(
            (res) => {
                if (res.errCode == 10000) {
                    let option = res.data;
                    option.forEach(res => {
                        res.title = res.name;
                        res.key = res.id;
                    });
                    this.nodeList = option;
                    this.toNode(option);
                } else {
                    this.message.info(res.errMsg);
                }
            }
        );
    }

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

    //获取下级
    mouseAction(name: string, event: NzFormatEmitEvent) {
wangqinghua's avatar
wangqinghua committed

wangqinghua's avatar
wangqinghua committed
        let type;
        if(event.node.level == 0){
            type = "host";   //主机
        }
        if(event.node.level == 1){
wangqinghua's avatar
wangqinghua committed
            type = "item";  //监测点
wangqinghua's avatar
wangqinghua committed
        }
        const data = {
            'id': event.node.origin.id,
            'type': type
        };
        this.topologySer.findTree(data).subscribe(
            (res) => {
                if (res.data) {
                    const dataSet = res.data;
                    dataSet.forEach(res => {
                        res.title = res.name;
                        res.key = res.id;
wangqinghua's avatar
wangqinghua committed
                        if(event.node.level == 1){
                            res.isLeaf = true;
wangqinghua's avatar
wangqinghua committed
                        }
                    });
wangqinghua's avatar
wangqinghua committed

wangqinghua's avatar
wangqinghua committed
                    event.node.addChildren(dataSet);
                } else {
                    event.node.addChildren([]);
                    this.message.warning('该下级为空');
                }

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

    //选择树节点
wangqinghua's avatar
wangqinghua committed
    selectItem(event,node) {
        if (node.isChecked) {
            this.selectId = node.origin.id;   //主机
        } else {
           this.selectId = null;
        }
wangqinghua's avatar
wangqinghua committed
    }

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();
        }
        if(this.validateForm.invalid){
            return false;
        }
        if(this.title == "添加监测点"){
            this.create();
        }
        if(this.title == "编辑监测点"){
            this.update();
        }
    }

wangqinghua's avatar
wangqinghua committed
    create(){
        this.validateForm.addControl('id',new FormControl(this.selectId));
        const str = JSON.stringify(this.validateForm.value);
        this.isVisible = false;
        this.initForm();
        this.done.emit(str);
    }
wangqinghua's avatar
wangqinghua committed

    update(){}

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