Skip to content
basi-check.component.ts 6.4 KiB
Newer Older
wangqinghua's avatar
wangqinghua committed
import {Component, EventEmitter, OnInit, Output, ViewChild} from '@angular/core';
wangqinghua's avatar
wangqinghua committed
import {OverAllService} from '../../overAll/overAll.service';
wangqinghua's avatar
wangqinghua committed
import {
wangqinghua's avatar
wangqinghua committed
    FormBuilder, FormControl,
wangqinghua's avatar
wangqinghua committed
    FormGroup,
    Validators
} from '@angular/forms';
wangqinghua's avatar
wangqinghua committed
import {NzMessageService} from 'ng-zorro-antd';
import {NewTypeComponent} from '../new-type/new-type.component';
wangqinghua's avatar
wangqinghua committed

@Component({
wangqinghua's avatar
wangqinghua committed
    selector: 'smart-basi-check',
    templateUrl: './basi-check.component.html',
wangqinghua's avatar
wangqinghua committed
    styles: [
            `.tag-button[disabled],
        .tag-button {
            width: 80%;
            height: 30px;
            color: rgba(0, 0, 0, 0.65);
            background-color: #fff;
            border-color: #d9d9d9;
wangqinghua's avatar
wangqinghua committed
        }
wangqinghua's avatar
wangqinghua committed

        :host ::ng-deep .ant-tabs-nav .ant-tabs-tab-disabled {
            color: rgba(0, 0, 0, .65);
wangqinghua's avatar
wangqinghua committed
        }
        `
wangqinghua's avatar
wangqinghua committed
    ]
wangqinghua's avatar
wangqinghua committed
})
export class BasiCheckComponent implements OnInit {
wangqinghua's avatar
wangqinghua committed
    @ViewChild('newType') newType: NewTypeComponent;
wangqinghua's avatar
wangqinghua committed
    @Output() done = new EventEmitter<any>();
wangqinghua's avatar
wangqinghua committed

    title;
wangqinghua's avatar
wangqinghua committed
    isCheck = false;
wangqinghua's avatar
wangqinghua committed
    isOkLoading = false;
wangqinghua's avatar
wangqinghua committed
    nzSize = 'large';
wangqinghua's avatar
wangqinghua committed
    hostId;   //主机ID
wangqinghua's avatar
wangqinghua committed
    hostName;   //主机name
wangqinghua's avatar
wangqinghua committed
    itemId;  //监控项id
wangqinghua's avatar
wangqinghua committed
    valueMapList = [];
wangqinghua's avatar
wangqinghua committed
    validateForm: FormGroup;
wangqinghua's avatar
wangqinghua committed
    checkList;  //监测点分类
    interval;    //间隔时长
wangqinghua's avatar
wangqinghua committed
    templateid;   //模版id
wangqinghua's avatar
wangqinghua committed

wangqinghua's avatar
wangqinghua committed
    tabNum: number;
wangqinghua's avatar
wangqinghua committed
    triggerObj = {
wangqinghua's avatar
wangqinghua committed
        condition: '',
        faultCondition: '',
        itemName: ''
wangqinghua's avatar
wangqinghua committed
    };
wangqinghua's avatar
wangqinghua committed

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

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

wangqinghua's avatar
wangqinghua committed
    initForm() {
wangqinghua's avatar
wangqinghua committed
        this.tabNum = 0;
wangqinghua's avatar
wangqinghua committed
        this.validateForm = this.fb.group({
wangqinghua's avatar
wangqinghua committed
            hostid: [this.hostId],
            name: [null, [Validators.required]],
wangqinghua's avatar
wangqinghua committed
            key: [null, [Validators.required]],
            valueType: [null, [Validators.required]],
wangqinghua's avatar
wangqinghua committed
            type: [null, [Validators.required]],
wangqinghua's avatar
wangqinghua committed
            units: [null, [Validators.required]],
wangqinghua's avatar
wangqinghua committed
            history: ['3600'],
wangqinghua's avatar
wangqinghua committed
            snmpCommunity: ['public'],
wangqinghua's avatar
wangqinghua committed
            delay: [null, [Validators.required]],
wangqinghua's avatar
wangqinghua committed
            interfaceid: [null],
wangqinghua's avatar
wangqinghua committed
            templateid:[null],
wangqinghua's avatar
wangqinghua committed
            description:[null],
wangqinghua's avatar
wangqinghua committed
        });
        this.triggerObj = {
wangqinghua's avatar
wangqinghua committed
            condition: '',
            faultCondition: '',
            itemName: ''
wangqinghua's avatar
wangqinghua committed
        };
wangqinghua's avatar
wangqinghua committed
    }

    //新增
wangqinghua's avatar
wangqinghua committed
    showAddModal(hostId, hostName,title) {
        this.title = title;
wangqinghua's avatar
wangqinghua committed
        this.isCheck = true;
        this.hostId = hostId;
        this.hostName = hostName;
wangqinghua's avatar
wangqinghua committed
        // this.getItemType();
wangqinghua's avatar
wangqinghua committed
    }

wangqinghua's avatar
wangqinghua committed
    //编辑
wangqinghua's avatar
wangqinghua committed
    showEditModal(hostId, id, hostName,templateid,title) {
        this.title = title;
wangqinghua's avatar
wangqinghua committed
        this.hostId = hostId;
wangqinghua's avatar
wangqinghua committed
        this.templateid = templateid;
wangqinghua's avatar
wangqinghua committed
        this.isCheck = true;
wangqinghua's avatar
wangqinghua committed
        this.itemId = id;
wangqinghua's avatar
wangqinghua committed
        this.hostName = hostName;
wangqinghua's avatar
wangqinghua committed
        this.overAllSer.findItemDetail(id).subscribe(
            (res) => {
wangqinghua's avatar
wangqinghua committed
                const data = res.data[0];
                data.type += '';
wangqinghua's avatar
wangqinghua committed
                data.valueType += '';
                // if(data.applications){
                //     data.applications = data.applications.map(e=>{
                //         return e.applicationid;
                //     });
                // }
wangqinghua's avatar
wangqinghua committed
                this.validateForm.patchValue(data);
wangqinghua's avatar
wangqinghua committed
            }
        );
wangqinghua's avatar
wangqinghua committed

wangqinghua's avatar
wangqinghua committed
        // this.getItemType();
wangqinghua's avatar
wangqinghua committed
    }

    //获取监测点分类
wangqinghua's avatar
wangqinghua committed
    getItemType() {
wangqinghua's avatar
wangqinghua committed
        //监测点分类
        const data = {
wangqinghua's avatar
wangqinghua committed
            'hostids': [this.hostId]
wangqinghua's avatar
wangqinghua committed
        };
wangqinghua's avatar
wangqinghua committed
        this.overAllSer.findItemType(data).subscribe(
wangqinghua's avatar
wangqinghua committed
            (res) => {
wangqinghua's avatar
wangqinghua committed
                this.checkList = res.data;
            }
wangqinghua's avatar
wangqinghua committed
        );
wangqinghua's avatar
wangqinghua committed
    }

    //添加
wangqinghua's avatar
wangqinghua committed
    handleCheckOk() {
wangqinghua's avatar
wangqinghua committed
        const list = ['0','1','3','4','6','10','12','13','14','16','17'];
        if(list.indexOf(this.validateForm.value.type) > -1){
            this.validateForm.get('type').setValidators(Validators.required);
        }
wangqinghua's avatar
wangqinghua committed
        for (let i in this.validateForm.controls) {
            this.validateForm.controls[i].markAsDirty();
            this.validateForm.controls[i].updateValueAndValidity();
wangqinghua's avatar
wangqinghua committed
        }
wangqinghua's avatar
wangqinghua committed
        if (this.validateForm.invalid) {
            this.message.error('请输入必填信息');
wangqinghua's avatar
wangqinghua committed
            return false;
        }
wangqinghua's avatar
wangqinghua committed
        this.validateForm.value.hostid = this.hostId;
wangqinghua's avatar
wangqinghua committed
        this.isOkLoading = true;
wangqinghua's avatar
wangqinghua committed
        if (this.title == '添加监测点' || this.title == "添加模版监测点") {
wangqinghua's avatar
wangqinghua committed
            this.create();
wangqinghua's avatar
wangqinghua committed
        }
wangqinghua's avatar
wangqinghua committed
        if (this.title == '编辑监测点' || this.title == "编辑模版监测点") {
wangqinghua's avatar
wangqinghua committed
            this.update();
wangqinghua's avatar
wangqinghua committed
        }
    }

wangqinghua's avatar
wangqinghua committed
    create() {
wangqinghua's avatar
wangqinghua committed
        this.overAllSer.create(this.validateForm.value).subscribe(
wangqinghua's avatar
wangqinghua committed
            (res) => {
wangqinghua's avatar
wangqinghua committed
                if (res.errCode == 10000) {
wangqinghua's avatar
wangqinghua committed
                    this.message.success('创建监测点成功');
wangqinghua's avatar
wangqinghua committed
                    this.done.emit();
wangqinghua's avatar
wangqinghua committed
                    this.tabNum = 1;
wangqinghua's avatar
wangqinghua committed
                    this.initForm();
wangqinghua's avatar
wangqinghua committed
                    this.isCheck = false;
wangqinghua's avatar
wangqinghua committed
                }
wangqinghua's avatar
wangqinghua committed
                this.isOkLoading = false;
wangqinghua's avatar
wangqinghua committed
            },
            (err) => {
wangqinghua's avatar
wangqinghua committed
                this.message.error('系统错误');
wangqinghua's avatar
wangqinghua committed
            }
        );
    }

wangqinghua's avatar
wangqinghua committed
    //修改监控项
wangqinghua's avatar
wangqinghua committed
    update() {
wangqinghua's avatar
wangqinghua committed
        this.validateForm.patchValue({
            templateid:this.templateid
        })
wangqinghua's avatar
wangqinghua committed
        this.validateForm.addControl('itemid', new FormControl(this.itemId));
wangqinghua's avatar
wangqinghua committed
        this.overAllSer.itemUpdata(this.validateForm.value).subscribe(
wangqinghua's avatar
wangqinghua committed
            (res) => {
                if (res.errCode == 10000) {
wangqinghua's avatar
wangqinghua committed
                    this.message.success('修改监测点成功');
wangqinghua's avatar
wangqinghua committed
                    this.done.emit();
wangqinghua's avatar
wangqinghua committed
                    this.tabNum = 1;
wangqinghua's avatar
wangqinghua committed
                    this.initForm();
wangqinghua's avatar
wangqinghua committed
                    this.isCheck = false;
wangqinghua's avatar
wangqinghua committed
                }
wangqinghua's avatar
wangqinghua committed
                this.isOkLoading = false;
wangqinghua's avatar
wangqinghua committed
            },
wangqinghua's avatar
wangqinghua committed
            (err) => {
wangqinghua's avatar
wangqinghua committed
                this.message.error('系统错误');
wangqinghua's avatar
wangqinghua committed
            }
wangqinghua's avatar
wangqinghua committed
        );
wangqinghua's avatar
wangqinghua committed
    }

    handleCheckCancel(): void {
        this.isCheck = false;
wangqinghua's avatar
wangqinghua committed
        this.initForm();
wangqinghua's avatar
wangqinghua committed
    }

    //新增分类
wangqinghua's avatar
wangqinghua committed
    showTypeModal() {
        this.newType.showModal('新建分类');
wangqinghua's avatar
wangqinghua committed
    }

    //添加分类
wangqinghua's avatar
wangqinghua committed
    addItemType(data) {
wangqinghua's avatar
wangqinghua committed
        const obj = {
wangqinghua's avatar
wangqinghua committed
            hostid: this.hostId,
            name: data
        };
wangqinghua's avatar
wangqinghua committed
        this.overAllSer.createItemType(obj).subscribe(
wangqinghua's avatar
wangqinghua committed
            (res) => {
                if (res.errCode == 10000) {
wangqinghua's avatar
wangqinghua committed
                    this.message.success('添加成功');
wangqinghua's avatar
wangqinghua committed
                    // this.getItemType();
wangqinghua's avatar
wangqinghua committed
                }
            }
wangqinghua's avatar
wangqinghua committed
        );
wangqinghua's avatar
wangqinghua committed
    }

wangqinghua's avatar
wangqinghua committed
    getKey(keyValue): void {
wangqinghua's avatar
wangqinghua committed
        const d = {
wangqinghua's avatar
wangqinghua committed
            key: keyValue
wangqinghua's avatar
wangqinghua committed
        };
wangqinghua's avatar
wangqinghua committed
        this.validateForm.patchValue(d);
wangqinghua's avatar
wangqinghua committed
    }
}