Skip to content
basic.component.ts 10.4 KiB
Newer Older
wangqinghua's avatar
wangqinghua committed
import {Component, OnInit, ViewChild} from '@angular/core';
import {OverAllService} from '../overAll.service';
import {NzModalService} from 'ng-zorro-antd';
import {NzMessageService} from 'ng-zorro-antd';
import {Router} from '@angular/router';
wangqinghua's avatar
wangqinghua committed
import {
    FormBuilder,
    FormGroup,
    Validators
} from '@angular/forms';
wangqinghua's avatar
wangqinghua committed
import {BasicEditComponent} from '../../modal/basic-edit/basic-edit.component';
import {BasiCheckComponent} from '../../modal/basi-check/basi-check.component';
import {CreateGroupComponent} from '../../modal/create-group/create-group.component';
import {EmitService} from '../../shared/event/eventEmitter';
wangqinghua's avatar
wangqinghua committed
import {PauseComponent} from '../../modal/pause/pause.component';
wangqinghua's avatar
wangqinghua committed

export interface TreeNodeInterface {
    host: any;
    name: string;
    age: number;
    level: number;
    expand: boolean;
    address: string;
    children?: TreeNodeInterface[];
}
wangqinghua's avatar
wangqinghua committed

wangqinghua's avatar
wangqinghua committed
@Component({
wangqinghua's avatar
wangqinghua committed
    selector: 'jhi-basic',
    templateUrl: './basic.component.html',
wangqinghua's avatar
wangqinghua committed
    styles: [
        `:host ::ng-deep .table-dropdown a{
           font-weight: 300;
        }`
    ]
wangqinghua's avatar
wangqinghua committed
})
export class BasicComponent implements OnInit {
    //组件
wangqinghua's avatar
wangqinghua committed
    @ViewChild('basicEdit') basicEdit: BasicEditComponent;
    @ViewChild('smartCheck') smartCheck: BasiCheckComponent;
    @ViewChild('smartCreateGroup') smartCreateGroup: CreateGroupComponent;
wangqinghua's avatar
wangqinghua committed
    @ViewChild('smartPause') smartPause:PauseComponent;
wangqinghua's avatar
wangqinghua committed

    //表格信息
    loading = false;

    selectedValue;
    isCheck = false;
    allChecked = false;
wangqinghua's avatar
wangqinghua committed
    interfaceList: any[];
wangqinghua's avatar
wangqinghua committed
    hostId;
    deviceNo;     //设备监控数

    isKey = false;
wangqinghua's avatar
wangqinghua committed
    keyList: any[];
wangqinghua's avatar
wangqinghua committed
    keyType = '1';

wangqinghua's avatar
wangqinghua committed
    constructor(private fb: FormBuilder, private overAllSer: OverAllService, private router: Router,
                private modalService: NzModalService, private message: NzMessageService,
                private emitService: EmitService) {
    }

    dataSet: any[];
wangqinghua's avatar
wangqinghua committed
    expandDataCache = {};
wangqinghua's avatar
wangqinghua committed
    ckeckObj: object;
wangqinghua's avatar
wangqinghua committed

    collapse(array: TreeNodeInterface[], data: TreeNodeInterface, $event: boolean): void {
        if ($event === false) {
            if (data.children) {
                data.children.forEach(d => {
                    const target = array.find(a => a.host === d.host);
                    target.expand = false;
                    this.collapse(array, target, false);
                });
            } else {
                return;
            }
        }
    }

wangqinghua's avatar
wangqinghua committed
    convertTreeToList(root: object, groupId: string): TreeNodeInterface[] {
wangqinghua's avatar
wangqinghua committed
        const stack = [];
        const array = [];
        const hashMap = {};
wangqinghua's avatar
wangqinghua committed
        stack.push({...root, level: 0, expand: false});
wangqinghua's avatar
wangqinghua committed
        while (stack.length !== 0) {
            const node = stack.pop();

            this.visitNode(node, hashMap, array);
            if (node.list) {
                for (let i = node.list.length - 1; i >= 0; i--) {
wangqinghua's avatar
wangqinghua committed
                    stack.push({...node.list[i], level: node.level + 1, expand: false, parent: node, gId: groupId, checked: false});
wangqinghua's avatar
wangqinghua committed
                }
            }
        }

        return array;
    }

    visitNode(node: TreeNodeInterface, hashMap: object, array: TreeNodeInterface[]): void {
wangqinghua's avatar
wangqinghua committed
        if (!hashMap[node.host]) {
            hashMap[node.host] = true;
wangqinghua's avatar
wangqinghua committed
            array.push(node);
        }
    }

    submitForm(): void {
        // for (const i in this.validateForm.controls) {
        //     this.validateForm.controls[ i ].markAsDirty();
        //     this.validateForm.controls[ i ].updateValueAndValidity();
        // }
    }

    ngOnInit(): void {
        this.selectedValue = 'group';
        this.select();
        // this.findList();
        this.findSize();
    }

    //添加资源  ,name-分组名称,id-分组id
wangqinghua's avatar
wangqinghua committed
    showBasicEditModal(item) {
wangqinghua's avatar
wangqinghua committed
        console.log(item);
wangqinghua's avatar
wangqinghua committed
        this.basicEdit.showModal(item.hostId, item.name, item.id);
wangqinghua's avatar
wangqinghua committed
    }

    //编辑资源 name--分组名称,gId-当前分组的id
wangqinghua's avatar
wangqinghua committed
    editBasicModal(item) {
wangqinghua's avatar
wangqinghua committed
        console.log(item);
wangqinghua's avatar
wangqinghua committed
        this.basicEdit.editModal(item.hostid, item.name, item.gId);
wangqinghua's avatar
wangqinghua committed
    }

    //添加监测点
wangqinghua's avatar
wangqinghua committed
    showBasicCheckModal(hostid) {
        this.smartCheck.showCheckModal(hostid);
wangqinghua's avatar
wangqinghua committed
    }

    //列表
wangqinghua's avatar
wangqinghua committed
    findList() {
wangqinghua's avatar
wangqinghua committed
        const data = {};
        this.overAllSer.find(data).subscribe(
wangqinghua's avatar
wangqinghua committed
            (res) => {
                if (res.data) {
wangqinghua's avatar
wangqinghua committed
                    this.dataSet = res.data;
wangqinghua's avatar
wangqinghua committed
                } else {
wangqinghua's avatar
wangqinghua committed
                    this.message.info(res.errMsg);
                }

            }
wangqinghua's avatar
wangqinghua committed
        );
wangqinghua's avatar
wangqinghua committed
    }

    //选择分组
wangqinghua's avatar
wangqinghua committed
    select() {
wangqinghua's avatar
wangqinghua committed
        this.loading = true;
wangqinghua's avatar
wangqinghua committed
        if (this.selectedValue == 'group') {
wangqinghua's avatar
wangqinghua committed
            this.overAllSer.findGroup().subscribe(
wangqinghua's avatar
wangqinghua committed
                (res) => {
wangqinghua's avatar
wangqinghua committed
                    this.loading = false;
wangqinghua's avatar
wangqinghua committed
                    if (res.errCode == 10000) {
wangqinghua's avatar
wangqinghua committed
                        this.dataSet = res.data;
                        // this.dataSet = this.dataSet.filter(d => d.list);     //过滤无list的
wangqinghua's avatar
wangqinghua committed
                        for (let i = 0; i < this.dataSet.length; i++) {
                            this.dataSet[i].host = i;
                            this.dataSet[i].checked = false;
wangqinghua's avatar
wangqinghua committed
                        }
                        console.log(this.dataSet);
wangqinghua's avatar
wangqinghua committed
                        this.toTree();
                    } else {
wangqinghua's avatar
wangqinghua committed
                        this.message.info(res.errMsg);
                    }
                }
wangqinghua's avatar
wangqinghua committed
            );
        } else if (this.selectedValue == 'type') {
wangqinghua's avatar
wangqinghua committed
            this.overAllSer.findType().subscribe(
wangqinghua's avatar
wangqinghua committed
                (res) => {
wangqinghua's avatar
wangqinghua committed
                    this.loading = false;
wangqinghua's avatar
wangqinghua committed
                    if (res.errCode == 10000) {
wangqinghua's avatar
wangqinghua committed
                        this.dataSet = res.data;
                        // this.dataSet = this.dataSet.filter(d => d.list);     //过滤无list的
wangqinghua's avatar
wangqinghua committed
                        for (let i = 0; i < this.dataSet.length; i++) {
wangqinghua's avatar
wangqinghua committed
                            this.dataSet[i].host = i;
                            this.dataSet[i].checked = false;
                        }
                        console.log(this.dataSet);
                        this.toTree();
wangqinghua's avatar
wangqinghua committed
                    } else {
wangqinghua's avatar
wangqinghua committed
                        this.message.info(res.errMsg);
                    }
                }
wangqinghua's avatar
wangqinghua committed
            );
        } else if (this.selectedValue == 'all') {
wangqinghua's avatar
wangqinghua committed
            this.findList();
        }
    }

wangqinghua's avatar
wangqinghua committed
    toTree() {
wangqinghua's avatar
wangqinghua committed
        this.dataSet.forEach(item => {
wangqinghua's avatar
wangqinghua committed
            this.expandDataCache[item.host] = this.convertTreeToList(item, item.id);
wangqinghua's avatar
wangqinghua committed
        });
    }

    //全选

wangqinghua's avatar
wangqinghua committed
    checkAll(e) {
wangqinghua's avatar
wangqinghua committed

    }

    //删除资源
wangqinghua's avatar
wangqinghua committed
    showDeleteConfirm(data) {
wangqinghua's avatar
wangqinghua committed
        this.modalService.confirm({
wangqinghua's avatar
wangqinghua committed
            nzTitle: '删除',
            nzContent: '<b style="color: red;">确认删除该资源吗?</b>',
            nzOkText: '确定',
            nzOkType: 'danger',
            nzOnOk: () => {
wangqinghua's avatar
wangqinghua committed
                this.overAllSer.deleteHostGet(data.hostid).subscribe(
wangqinghua's avatar
wangqinghua committed
                    (res) => {
                        if (res.errCode == 10000) {
wangqinghua's avatar
wangqinghua committed
                            this.message.info('删除成功');
                            this.select();
wangqinghua's avatar
wangqinghua committed
                        } else {
wangqinghua's avatar
wangqinghua committed
                            this.message.info(res.errMsg);
                        }
                    }
wangqinghua's avatar
wangqinghua committed
                );
wangqinghua's avatar
wangqinghua committed
            },
            nzCancelText: '取消',
wangqinghua's avatar
wangqinghua committed
            nzOnCancel: () => console.log('Cancel')
wangqinghua's avatar
wangqinghua committed
        });
    }

    //添加分组
wangqinghua's avatar
wangqinghua committed
    showGroupModal() {
wangqinghua's avatar
wangqinghua committed
        this.smartCreateGroup.showModal();
    }

    //删除分组
wangqinghua's avatar
wangqinghua committed
    showDeleteGroupConfirm(item) {
wangqinghua's avatar
wangqinghua committed
        this.modalService.confirm({
wangqinghua's avatar
wangqinghua committed
            nzTitle: '删除',
            nzContent: '<b style="color: red;">确认删除该分组吗?</b>',
            nzOkText: '确定',
            nzOkType: 'danger',
            nzOnOk: () => {
                const data = {params: []};
wangqinghua's avatar
wangqinghua committed
                data.params.push(item.id);
                this.overAllSer.deleteGroup(data).subscribe(
wangqinghua's avatar
wangqinghua committed
                    (res) => {
                        if (res.errCode == 10000) {
wangqinghua's avatar
wangqinghua committed
                            this.message.info('删除成功');
                            this.select();
wangqinghua's avatar
wangqinghua committed
                        } else {
wangqinghua's avatar
wangqinghua committed
                            this.message.info(res.errMsg);
                        }
                    }
wangqinghua's avatar
wangqinghua committed
                );
wangqinghua's avatar
wangqinghua committed
            },
            nzCancelText: '取消',
wangqinghua's avatar
wangqinghua committed
            nzOnCancel: () => console.log('Cancel')
wangqinghua's avatar
wangqinghua committed
        });
    }

wangqinghua's avatar
wangqinghua committed
    handleOk(e) {
wangqinghua's avatar
wangqinghua committed
        this.select();
    }

wangqinghua's avatar
wangqinghua committed
    //获取下级list
    getChildren(item) {
wangqinghua's avatar
wangqinghua committed
        const data = {
wangqinghua's avatar
wangqinghua committed
            'groupids': [item.groupid],
            'hostExtend': {
                'superiorHostid': null
wangqinghua's avatar
wangqinghua committed
            }
        };
        this.overAllSer.findDetail(data).subscribe(
wangqinghua's avatar
wangqinghua committed
            (res) => {
                this.dataSet[item.host].list = res.data;
                this.toTree();
            }
        );
    }

wangqinghua's avatar
wangqinghua committed
    //根据设备类型查询主机资源
    getChildrenType(item){
wangqinghua's avatar
wangqinghua committed
        const data = {
            type:item.equipmentType
        }
        this.overAllSer.findHostByType(data).subscribe(
wangqinghua's avatar
wangqinghua committed
            (res) => {
                this.dataSet[item.host].list = res.data;
                this.toTree();
            }
        );
    }

wangqinghua's avatar
wangqinghua committed
    //查看详情
    goDetail(item){
wangqinghua's avatar
wangqinghua committed
        let type = 0;
wangqinghua's avatar
wangqinghua committed
        if(item.hostExtend){
            if(item.hostExtend.equipmentType == '交换机'){
                type = 1;
            }
        }
        this.router.navigate(['app/main/basic-detail'],{
            queryParams:{
                hostId:item.hostid,
                type:type
wangqinghua's avatar
wangqinghua committed
            }
wangqinghua's avatar
wangqinghua committed
        })
wangqinghua's avatar
wangqinghua committed
    }

    //监控设备数
wangqinghua's avatar
wangqinghua committed
    findSize() {
wangqinghua's avatar
wangqinghua committed
        this.overAllSer.findSize().subscribe(
wangqinghua's avatar
wangqinghua committed
            (res) => {
wangqinghua's avatar
wangqinghua committed
                this.deviceNo = res.data.size;
            }
wangqinghua's avatar
wangqinghua committed
        );
wangqinghua's avatar
wangqinghua committed
    }

wangqinghua's avatar
wangqinghua committed
    //临时暂停
    showTempStop(item){
        this.smartPause.showModal(item.hostid);
    }
wangqinghua's avatar
wangqinghua committed

    openHost(item){
        this.modalService.confirm({
            nzTitle: '监控',
            nzContent: '确定开启监控设备'+item.name + '',
            nzOkText: '确定',
            nzCancelText: '取消',
            nzOnOk: () => {
                let params1 = 0;
                if(item.status == 1){
                    params1 = 0;
                }
                const params2 = item.hostid;
                this.overAllSer.stopOrOpen(params1,params2).subscribe(
                    (res) => {
                        if (res.errCode == 10000) {
                            this.message.info('修改成功');
                            this.select();
                        } else {
                            this.message.info(res.errMsg);
                        }
                    }
                );
            },
            nzOnCancel: () => console.log('Cancel')
        });
    }
wangqinghua's avatar
wangqinghua committed
}