Skip to content
ne-topology.component.ts 14.5 KiB
Newer Older
wangqinghua's avatar
wangqinghua committed
import {AfterViewChecked, AfterViewInit, Component, ElementRef, KeyValueDiffer, OnInit, ViewChild, KeyValueDiffers, DoCheck, OnDestroy} from '@angular/core';
wangqinghua's avatar
wangqinghua committed
import {TopologyService} from '../topology.service';
wangqinghua's avatar
wangqinghua committed
import {NzMessageService, NzModalService, UploadFile} from 'ng-zorro-antd';
wangqinghua's avatar
wangqinghua committed
import {DomSanitizer} from '@angular/platform-browser';
wangqinghua's avatar
wangqinghua committed
import {TopologyComponent} from '../model/topology/topology.component';
wangqinghua's avatar
wangqinghua committed
import {CheckComponent} from '../model/check/check.component';
import {DeviceComponent} from '../model/device/device.component';
wangqinghua's avatar
wangqinghua committed
import {SelectGroupComponent} from '../../modal/select-group/select-group.component';
wangqinghua's avatar
wangqinghua committed
import {LocalStorageService} from 'ngx-webstorage';
import {numberOfBytes} from 'ng-jhipster/src/directive/number-of-bytes';
import {LineComponent} from '../model/line/line.component';
import {NodeComponent} from '../model/node/node.component';
wangqinghua's avatar
wangqinghua committed

declare let editor: any;
wangqinghua's avatar
wangqinghua committed
declare var layui: any;
wangqinghua's avatar
wangqinghua committed

@Component({
    selector: 'smart-ne-topology',
    templateUrl: './ne-topology.component.html',
wangqinghua's avatar
wangqinghua committed
    styles: [
wangqinghua's avatar
wangqinghua committed
            `
            .layui-side-scroll {
                width: initial;
            }

            .layui-layout-right {
wangqinghua's avatar
wangqinghua committed
                color: #666666;
            }
wangqinghua's avatar
wangqinghua committed

wangqinghua's avatar
wangqinghua committed
            .layui-header span {
wangqinghua's avatar
wangqinghua committed
                margin-right: 15px;
                cursor: pointer;
            }
wangqinghua's avatar
wangqinghua committed
            .header-bar{
                line-height: 60px;
                color: #6097b7;
                padding: 0 20px;
                background-color: #ddd;
            }
wangqinghua's avatar
wangqinghua committed

            .tips {
wangqinghua's avatar
wangqinghua committed
                position: absolute;
                top: 10px;
                left: 20px;
                color: #ca0814;
                font-size: 20px;
            }
wangqinghua's avatar
wangqinghua committed

            .checkList {
wangqinghua's avatar
wangqinghua committed
                position: absolute;
                top: 10px;
                right: 20px;
                color: #666666;
                font-size: 20px;
            }
wangqinghua's avatar
wangqinghua committed
            .lineList{
                position: absolute;
                top: 5px;
                left: 20px;
                color: #6097b7;
                cursor: pointer;
            }
wangqinghua's avatar
wangqinghua committed

            .layui-form-label {
wangqinghua's avatar
wangqinghua committed
                width: 110px;
            }
wangqinghua's avatar
wangqinghua committed

            .minus {
wangqinghua's avatar
wangqinghua committed
                vertical-align: middle;
                color: red;
                font-size: 15px;
                margin-left: 12px;
                cursor: pointer;
            }
wangqinghua's avatar
wangqinghua committed
        `
    ]
wangqinghua's avatar
wangqinghua committed
})
wangqinghua's avatar
wangqinghua committed
export class NeTopologyComponent implements OnInit, DoCheck, AfterViewInit, OnDestroy {
wangqinghua's avatar
wangqinghua committed
    @ViewChild('topologyCanvas') topologyCanvas: ElementRef;
wangqinghua's avatar
wangqinghua committed
    @ViewChild('smartTopology') smartTopology: TopologyComponent;
    @ViewChild('smartCheck') smartCheck: CheckComponent;
    @ViewChild('smartSelectGroup') smartSelectGroup: SelectGroupComponent;
wangqinghua's avatar
wangqinghua committed
    @ViewChild('smartLine') smartLine: LineComponent;
    @ViewChild('smartNode') smartNode: NodeComponent;
wangqinghua's avatar
wangqinghua committed

    dataSet;
    isVisible = false;
    image;
wangqinghua's avatar
wangqinghua committed

wangqinghua's avatar
wangqinghua committed
    topoId;
wangqinghua's avatar
wangqinghua committed
    name;
wangqinghua's avatar
wangqinghua committed
    refreshRete;
wangqinghua's avatar
wangqinghua committed
    options;
wangqinghua's avatar
wangqinghua committed
    lineType;  //线条类型
wangqinghua's avatar
wangqinghua committed

wangqinghua's avatar
wangqinghua committed
    checkJson = [];
wangqinghua's avatar
wangqinghua committed
    fileList: UploadFile[] = [];
wangqinghua's avatar
wangqinghua committed
    isDevice;

wangqinghua's avatar
wangqinghua committed
    private customerDifferLink: KeyValueDiffer<string, any>;
    private customerDifferNode: KeyValueDiffer<string, any>;
    node = {
        value:''
    };
    line = {
        value:''
wangqinghua's avatar
wangqinghua committed
    };
wangqinghua's avatar
wangqinghua committed

wangqinghua's avatar
wangqinghua committed
    constructor(private topologySer: TopologyService, private message: NzMessageService, private localStorage:LocalStorageService,private differs: KeyValueDiffers,
wangqinghua's avatar
wangqinghua committed
                private sanitizer: DomSanitizer, private modalSer: NzModalService) {
wangqinghua's avatar
wangqinghua committed

wangqinghua's avatar
wangqinghua committed
    }

    ngOnInit() {
wangqinghua's avatar
wangqinghua committed

        this.customerDifferLink = this.differs.find(this.line).create();
        this.customerDifferNode = this.differs.find(this.node).create();

wangqinghua's avatar
wangqinghua committed
        this.getList();
wangqinghua's avatar
wangqinghua committed
        this.getTypeList();
wangqinghua's avatar
wangqinghua committed
    }

    ngAfterViewInit() {
        this.loadCanvas();
    }

    ngDoCheck(){
wangqinghua's avatar
wangqinghua committed
        this.node.value =  localStorage.getItem('node');
        this.line.value =  localStorage.getItem('line');
        const changesLine = this.customerDifferLink.diff(this.line);
        const changesNode = this.customerDifferNode.diff(this.node);
        if (changesLine && changesLine['_appendAfter'].currentValue == "true") {
            const arr = localStorage.getItem('linkHostIds');
            console.log(arr);
           this.smartLine.showModal(arr);
wangqinghua's avatar
wangqinghua committed
        }
wangqinghua's avatar
wangqinghua committed
        if (changesNode && changesNode['_appendAfter'].currentValue == "true") {
            this.smartNode.showModal();
wangqinghua's avatar
wangqinghua committed
        }
wangqinghua's avatar
wangqinghua committed
    }

wangqinghua's avatar
wangqinghua committed
    ngOnDestroy(){
        localStorage.setItem("line",'false');
        localStorage.setItem("node",'false');
    }

wangqinghua's avatar
wangqinghua committed
    //选择线条类型
    changeLine(e){
        switch (e) {
            case"1":{
                editor.lineType='line';
                break;
            }
            case"2":{
                editor.lineType='foldLine';
                editor.config.linkDirection='horizontal';
                break;
            }
            case"3":{
                editor.lineType='foldLine';
                editor.config.linkDirection='Vertical';
                break;
            }
            case"4":{
                editor.lineType='flexLine';
                editor.config.linkDirection='horizontal';
                break;
            }
            case"5":{
                editor.lineType='flexLine';
                editor.config.linkDirection='Vertical';
                break;
            }
        }
    }

wangqinghua's avatar
wangqinghua committed
    //一级分类
    getTypeList(){
        this.topologySer.findTreeWithWeb().subscribe(
            (res)=>{
                if(res.errCode == 10000){
                    this.options = res.data;
                }else{
                    this.message.error(res.errMSg);
                }
            }
        )
    }

wangqinghua's avatar
wangqinghua committed
    //新增拓扑图
    addTopo() {
wangqinghua's avatar
wangqinghua committed
        this.smartTopology.showAddMOodal();
wangqinghua's avatar
wangqinghua committed
    }
wangqinghua's avatar
wangqinghua committed

wangqinghua's avatar
wangqinghua committed
    //编辑拓扑图
    editTopo() {
wangqinghua's avatar
wangqinghua committed
        if (!this.topoId) {
            this.message.warning('请选择需要编辑的拓扑图');
wangqinghua's avatar
wangqinghua committed
            return false;
wangqinghua's avatar
wangqinghua committed
        }
wangqinghua's avatar
wangqinghua committed
        this.smartTopology.showEditModal(this.topoId);
wangqinghua's avatar
wangqinghua committed
    }

    //添加监测点
wangqinghua's avatar
wangqinghua committed
    addCheck() {
        if (!this.topoId) {
            this.message.warning('请选择需要编辑的拓扑图');
wangqinghua's avatar
wangqinghua committed
            return false;
        }
wangqinghua's avatar
wangqinghua committed
        this.smartCheck.showAddModal();
    }

    //添加设备
wangqinghua's avatar
wangqinghua committed
    addDevice() {
        if (!this.topoId) {
            this.message.warning('请选择需要编辑的拓扑图');
wangqinghua's avatar
wangqinghua committed
            return false;
        }
wangqinghua's avatar
wangqinghua committed
        this.smartSelectGroup.showAddModal('添加设备');
wangqinghua's avatar
wangqinghua committed
    }

    //获取设备图片
wangqinghua's avatar
wangqinghua committed
    setImg(e) {
wangqinghua's avatar
wangqinghua committed
        const data = {
            hostIds:e
        }
        this.topologySer.findByHostIdOrWeb(data).subscribe(
            (res)=>{
wangqinghua's avatar
wangqinghua committed
                editor.utils.addNode(res.data[0].url, '图片',e[0]);
wangqinghua's avatar
wangqinghua committed
            }
        )
wangqinghua's avatar
wangqinghua committed
    }

wangqinghua's avatar
wangqinghua committed
    //获取列表
    getList() {
wangqinghua's avatar
wangqinghua committed
        this.topologySer.findAll().subscribe(
wangqinghua's avatar
wangqinghua committed
            (res) => {
                if (res.errCode == 10000) {
                    this.dataSet = res.data;
                } else {
wangqinghua's avatar
wangqinghua committed
                    this.message.create('error', res.errMsg);
wangqinghua's avatar
wangqinghua committed
                }
            }
        );
    }

wangqinghua's avatar
wangqinghua committed
    //编辑
    update() {
wangqinghua's avatar
wangqinghua committed
        const json = {
wangqinghua's avatar
wangqinghua committed
            topology: editor.saveTopology(),
            check: this.checkJson
wangqinghua's avatar
wangqinghua committed
        };
wangqinghua's avatar
wangqinghua committed
        let data = {
            id: this.topoId,
wangqinghua's avatar
wangqinghua committed
            json: JSON.stringify(json),
wangqinghua's avatar
wangqinghua committed
            refreshRete: this.refreshRete,
            name: this.name
wangqinghua's avatar
wangqinghua committed
        };
        this.topologySer.update(data).subscribe(
            (res) => {
                if (res.errCode == 10000) {
wangqinghua's avatar
wangqinghua committed
                    this.message.success('编辑成功');
                    editor.utils.editTopology();
wangqinghua's avatar
wangqinghua committed
                    this.getList();
                } 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
    //load
    loadCanvas() {
        editor.loadTopology('','', 'img/backimg.png');
    }

wangqinghua's avatar
wangqinghua committed
    //查询单个
wangqinghua's avatar
wangqinghua committed
    getDetail(id) {
wangqinghua's avatar
wangqinghua committed
        this.topologySer.findItem(id).subscribe(
wangqinghua's avatar
wangqinghua committed
            (res) => {
                if (res.errCode == 10000) {
wangqinghua's avatar
wangqinghua committed
                    if (res.data.json.length > 0) {
wangqinghua's avatar
wangqinghua committed
                        let json = JSON.parse(res.data.json);
wangqinghua's avatar
wangqinghua committed
                        if(json.topology){
wangqinghua's avatar
wangqinghua committed
                            this.viewTopology(JSON.parse(json.topology));
wangqinghua's avatar
wangqinghua committed
                            // this.smartJtopo.loadTopologyByJson(JSON.parse(json.topology), 'img/backimg.png');
wangqinghua's avatar
wangqinghua committed
                            this.checkJson = json.check;
                        }else{
                            editor.utils.clearTopology();
                            this.checkJson = [];
                        }
wangqinghua's avatar
wangqinghua committed
                    } else {
wangqinghua's avatar
wangqinghua committed
                        editor.utils.clearTopology();
                        this.checkJson = [];
wangqinghua's avatar
wangqinghua committed
                    }
wangqinghua's avatar
wangqinghua committed
                    this.name = res.data.name;
wangqinghua's avatar
wangqinghua committed
                    this.refreshRete = res.data.refreshRete;
wangqinghua's avatar
wangqinghua committed
                    this.topoId = res.data.id;
wangqinghua's avatar
wangqinghua committed
                    this.findItemStatus();
wangqinghua's avatar
wangqinghua committed
                }
wangqinghua's avatar
wangqinghua committed
                editor.utils.editTopology();
wangqinghua's avatar
wangqinghua committed
            }
        );
    }
wangqinghua's avatar
wangqinghua committed

wangqinghua's avatar
wangqinghua committed
    //回显拓扑图
    viewTopology(topologyJson){
        console.log(topologyJson);
        const arr = topologyJson.childs[0].childs;
        const list = [];
wangqinghua's avatar
wangqinghua committed
        const hostIds = [];
wangqinghua's avatar
wangqinghua committed
        arr.forEach(e=>{
wangqinghua's avatar
wangqinghua committed
            if(e.elementType == 'link' && e.itemId && e.itemId.length > 0){
wangqinghua's avatar
wangqinghua committed
                const data = {
                    itemIdIn:e.itemId.split(',')[0],
                    itemIdOut:e.itemId.split(',')[1],
                    linkId:e.id
                };
                list.push(data);
            }
        });
wangqinghua's avatar
wangqinghua committed
        arr.forEach(e=>{
            if(e.elementType == 'node' && e.hostId){
                hostIds.push(e.hostId);
            }
        });

        if(hostIds.length > 0){
            const res = {
                hostIds : hostIds
            };
            this.topologySer.findElementStatus(res).subscribe(
                (res)=>{
                    //status -1=未监控, 0=正常, 1=告警, 2=严重, 3=未分类
                    const resData = res.data;
                    resData.forEach(e1=>{
                        arr.forEach(e2=>{
                            if(e1.elementId == e2.hostId){
                                if(e1.status == 0){
                                }
                                if(e1.status == 1){
xiaowenjie's avatar
xiaowenjie committed
                                    e2.alarm = e1.description;
                                    e2.fontColor='0,0,0';
                                    e2.alarmAlpha=0.9;
wangqinghua's avatar
wangqinghua committed
                                }
                                if(e1.status == 2){
wangqinghua's avatar
wangqinghua committed
                                    // e2.alarm = "严重";
wangqinghua's avatar
wangqinghua committed
                                }
                            }
                        })
                    });
                    console.log('告警')
                    console.log(topologyJson)
                    editor.loadTopologyByJson(topologyJson, 'img/backimg.png');
                }
            )
        }

wangqinghua's avatar
wangqinghua committed
        if(list.length > 0){   //有流量监控-->查询流量监控
            const data = {
                "list" : list
            };
            this.topologySer.findFlow(data).subscribe(
                (res)=>{
                    const response = res.data;
                    response.forEach(e1=>{
                        arr.forEach(e2=>{
                            if(e1.linkId == e2.id){
                                e2.text = "进口流量:"+e1.valueIn+e1.units+" 出口流量:"+e1.valueOut+e1.units;
                            }
                        })
                    });
wangqinghua's avatar
wangqinghua committed
                    console.log('进口流量')
                    console.log(topologyJson)
wangqinghua's avatar
wangqinghua committed
                    editor.loadTopologyByJson(topologyJson, 'img/backimg.png');
                }
            )
        }else{   //无流量监控
            editor.loadTopologyByJson(topologyJson, 'img/backimg.png');
wangqinghua's avatar
wangqinghua committed
        }
    }

wangqinghua's avatar
wangqinghua committed
    //查询监控点状态
wangqinghua's avatar
wangqinghua committed
    findItemStatus() {
wangqinghua's avatar
wangqinghua committed
        const data = {
wangqinghua's avatar
wangqinghua committed
            httpTestIds: this.checkJson.map(e => {
wangqinghua's avatar
wangqinghua committed
                return e.id;
            })
        };
        this.topologySer.findElementStatus(data).subscribe(
wangqinghua's avatar
wangqinghua committed
            (res) => {
wangqinghua's avatar
wangqinghua committed

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

wangqinghua's avatar
wangqinghua committed
    //删除拓扑图
    deleteTopo() {
wangqinghua's avatar
wangqinghua committed
        if (!this.topoId) {
wangqinghua's avatar
wangqinghua committed
            this.message.warning('请选择需要删除的拓扑图');
wangqinghua's avatar
wangqinghua committed
            return false;
        }
        this.modalSer.confirm({
                nzTitle: '删除',
                nzContent: '<b style="color: red;">确认删除该拓扑图吗?</b>',
                nzOkText: '确定',
                nzOkType: 'danger',
                nzOnOk: () => {
wangqinghua's avatar
wangqinghua committed
                    const data = {
                        id:this.topoId
                    }
                    this.topologySer.delete(data).subscribe(
wangqinghua's avatar
wangqinghua committed
                        (res) => {
                            if (res.errCode == 10000) {
                                this.topoId = null;
wangqinghua's avatar
wangqinghua committed
                                this.message.success('删除成功');
wangqinghua's avatar
wangqinghua committed
                                this.getList();
                            } else {
wangqinghua's avatar
wangqinghua committed
                                this.message.error(res.errMsg);
wangqinghua's avatar
wangqinghua committed
                            }
                        }
                    );
                },
                nzCancelText: '取消',
                nzOnCancel: () => console.log('Cancel')
wangqinghua's avatar
wangqinghua committed
            }
wangqinghua's avatar
wangqinghua committed
        );
wangqinghua's avatar
wangqinghua committed
    }

wangqinghua's avatar
wangqinghua committed
    //设置监测点
wangqinghua's avatar
wangqinghua committed
    setCheckList(event) {
wangqinghua's avatar
wangqinghua committed
        console.log(event);
        this.checkJson.push(JSON.parse(event));
    }

wangqinghua's avatar
wangqinghua committed
    //删除监测点
wangqinghua's avatar
wangqinghua committed
    deleteCheck(index) {
        this.checkJson.splice(index, 1);
wangqinghua's avatar
wangqinghua committed
    }

wangqinghua's avatar
wangqinghua committed
    //添加图片-----start
wangqinghua's avatar
wangqinghua committed
    showAddImg() {
        if (!this.topoId) {
            this.message.warning('请选择需要编辑的拓扑图');
wangqinghua's avatar
wangqinghua committed
            return false;
        }
wangqinghua's avatar
wangqinghua committed
        this.isVisible = true;
    }

    beforeUpload = (file: UploadFile): boolean => {
wangqinghua's avatar
wangqinghua committed
        const isLt2M = file.size / 1024 < 300;
wangqinghua's avatar
wangqinghua committed
        if (!isLt2M) {
            this.message.error('图标必须小于300kb!');
wangqinghua's avatar
wangqinghua committed
        } else {
wangqinghua's avatar
wangqinghua committed
            this.fileList.push(file);
        }
        return false;
    };

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

wangqinghua's avatar
wangqinghua committed
    handleOk() {
        if (this.fileList.length == 0) {
            this.message.warning('请选择图片');
wangqinghua's avatar
wangqinghua committed
            return false;
        }
        const formData = new FormData();
wangqinghua's avatar
wangqinghua committed
        this.fileList.forEach((file: any) => {
            formData.append('file', file);
wangqinghua's avatar
wangqinghua committed
        });
wangqinghua's avatar
wangqinghua committed
        this.topologySer.addPic(formData).subscribe(
wangqinghua's avatar
wangqinghua committed
            (res) => {
                if (res.errCode == 10000) {
wangqinghua's avatar
wangqinghua committed
                    this.isVisible = false;
wangqinghua's avatar
wangqinghua committed
                    editor.utils.addNode(res.data, 'text');
wangqinghua's avatar
wangqinghua committed
                    this.fileList = [];
wangqinghua's avatar
wangqinghua committed
                } else {
                    this.message.error('添加失败');
wangqinghua's avatar
wangqinghua committed
                }
            }
wangqinghua's avatar
wangqinghua committed
        );
wangqinghua's avatar
wangqinghua committed
    }
wangqinghua's avatar
wangqinghua committed

wangqinghua's avatar
wangqinghua committed
}