Skip to content
home.component.ts 20.8 KiB
Newer Older
wangqinghua's avatar
wangqinghua committed
import {AfterViewInit, Component, ElementRef, OnInit, Renderer2, ViewChild} from '@angular/core';
wangqinghua's avatar
wangqinghua committed
import { JhiEventManager } from 'ng-jhipster';
wangqinghua's avatar
wangqinghua committed
import { Account, Principal } from '../shared';
wangqinghua's avatar
wangqinghua committed
import {OverAllService} from '../overAll/overAll.service';
wangqinghua's avatar
wangqinghua committed
import {color, pageSize} from '../app.constants';
wangqinghua's avatar
wangqinghua committed
import {AlarmService} from '../alarm/alarm.service';
import {NzMessageService} from 'ng-zorro-antd';
wangqinghua's avatar
wangqinghua committed
import {LayoutService} from '../layouts/layout.service';
import {SelectGroupComponent} from '../modal/select-group/select-group.component';
wangqinghua's avatar
wangqinghua committed

@Component({
    selector: 'jhi-home',
    templateUrl: './home.component.html',
    styleUrls: [
        'home.css'
    ]

})
wangqinghua's avatar
wangqinghua committed
export class HomeComponent implements OnInit,AfterViewInit {
    @ViewChild('smartSelectGroup') smartSelectGroup:SelectGroupComponent;
    @ViewChild("leftDiv") leftDiv:ElementRef;
    @ViewChild("rightDiv") rightDiv:ElementRef;
wangqinghua's avatar
wangqinghua committed

wangqinghua's avatar
wangqinghua committed
    color = color;
wangqinghua's avatar
wangqinghua committed
    leftOneChart;
    leftTwoChart;
    rightOneChart;
    rightTwoChart;
wangqinghua's avatar
wangqinghua committed

wangqinghua's avatar
wangqinghua committed
    warnList= [];

wangqinghua's avatar
wangqinghua committed
    totalNum;
wangqinghua's avatar
wangqinghua committed
    groupList;

    pageNum = 1;
wangqinghua's avatar
wangqinghua committed
    pageCount = 10;
wangqinghua's avatar
wangqinghua committed
    loading = false;

wangqinghua's avatar
wangqinghua committed
    obj = {
        leftGroupId:null,
        alarmGroupId:null
    };

wangqinghua's avatar
wangqinghua committed
    leftOneData = {
wangqinghua's avatar
wangqinghua committed
        high:0,
        warning:0,
        normal:0,
        disabled:0,
wangqinghua's avatar
wangqinghua committed
    };
    leftOneDataPre = {
        highPer:0,
        warningPer:0,
        normalPer:0,
wangqinghua's avatar
wangqinghua committed
        disabledPer:0,
wangqinghua's avatar
wangqinghua committed
    };
wangqinghua's avatar
wangqinghua committed

wangqinghua's avatar
wangqinghua committed
    leftOneTotal = 0;
    leftTwoData  ={
        high:0,
        warning:0,
        normal:0,
        disabled:0,
wangqinghua's avatar
wangqinghua committed
    };
    leftTwoDataPre = {
        highPer:0,
        warningPer:0,
        normalPer:0,
wangqinghua's avatar
wangqinghua committed
        disabledPer:0,
wangqinghua's avatar
wangqinghua committed
    };
wangqinghua's avatar
wangqinghua committed

wangqinghua's avatar
wangqinghua committed
    leftTwoTotal = 0;
wangqinghua's avatar
wangqinghua committed

wangqinghua's avatar
wangqinghua committed
    rightTotal = 0;
wangqinghua's avatar
wangqinghua committed

wangqinghua's avatar
wangqinghua committed
    //我的关注
    followList;

wangqinghua's avatar
wangqinghua committed
    //资源设备数量
    deviceNo;

wangqinghua's avatar
wangqinghua committed
    constructor(
wangqinghua's avatar
wangqinghua committed
        private overAllSer:OverAllService,private message:NzMessageService,
wangqinghua's avatar
wangqinghua committed
        private alarmSer:AlarmService,private renderer:Renderer2,
        private layoutSer:LayoutService,
wangqinghua's avatar
wangqinghua committed
        private principal: Principal,
        private eventManager: JhiEventManager
    ) {
    }

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

wangqinghua's avatar
wangqinghua committed
        this.findGroupCount();
        this.findHostCount();
wangqinghua's avatar
wangqinghua committed

wangqinghua's avatar
wangqinghua committed
        this.getGroup();
wangqinghua's avatar
wangqinghua committed

        this.getMyFollow();
wangqinghua's avatar
wangqinghua committed

        this.findSize();
wangqinghua's avatar
wangqinghua committed
    }

    ngAfterViewInit(){
       let rightHeight = this.rightDiv.nativeElement.clientHeight;
        this.renderer.setStyle(this.leftDiv.nativeElement,"height",rightHeight +"px");
wangqinghua's avatar
wangqinghua committed
    }

wangqinghua's avatar
wangqinghua committed
    //我的关注
    getMyFollow(){
        this.layoutSer.myFollow().subscribe(
            (res)=>{
wangqinghua's avatar
wangqinghua committed
                this.followList = res.data;
wangqinghua's avatar
wangqinghua committed
                if(this.followList.length > 0 ){
                    let dataStyle = {
                        normal: {
                            label: {
                                show: false
                            },
                            labelLine: {
                                show: false
                            },
                            shadowBlur: 40,
                            borderWidth: 10,
                            shadowColor: 'rgba(0, 0, 0, 0)' //边框阴影
                        }
                    };
                    let placeHolderStyle = {
                        normal: {
                            color: '#eee',
                            label: {
                                show: false
                            },
                            labelLine: {
                                show: false
                            }
                        },
                        emphasis: {
                            color: '#393d50'
                        }
                    };
                    this.followList.forEach(e=>{
                        e.option = {
                            backgroundColor: '#fff',
                            title: {
                                text: '',
                                x: 'center',
                                y: 'center',
                                textStyle: {
                                    fontWeight: 'normal',
                                    fontSize: 24,
                                    color: "red",
                                }
                            },
                            tooltip: {
                                trigger: 'item',
                                show: true,
                                formatter: "{b} : <br/>{d}%",
                                backgroundColor: 'rgba(0,0,0,0.7)', // 背景
                                padding: [8, 10], //内边距
                                extraCssText: 'box-shadow: 0 0 3px rgba(255, 255, 255, 0.4);', //添加阴影
                            },

                            series: [{
                                name: 'CPU使用率',
                                type: 'pie',
                                clockWise: false,
                                radius: [50, 58],
wangqinghua's avatar
wangqinghua committed
                                center:['30%','50%'],
wangqinghua's avatar
wangqinghua committed
                                itemStyle: dataStyle,
                                hoverAnimation: false,
                                startAngle: 90,
                                label:{
                                    borderRadius:'10',
                                },
                                data: [{
                                    value: e.cpu,
wangqinghua's avatar
wangqinghua committed
                                    name: 'CPU使用率',
                                    itemStyle: {
                                        normal: {
                                            color: "#f09363"
                                        }
                                    }
wangqinghua's avatar
wangqinghua committed
                                },
                                    {
                                        value: 100 - e.cpu,
                                        name: '',
                                        tooltip: {
                                            show: false
                                        },
                                        itemStyle: placeHolderStyle
                                    },
                                ]
                            },
                                {
                                    name: '内存使用率',
                                    type: 'pie',
                                    clockWise: false,
                                    radius: [35, 43],
wangqinghua's avatar
wangqinghua committed
                                    center:['30%','50%'],
wangqinghua's avatar
wangqinghua committed
                                    itemStyle: dataStyle,
                                    hoverAnimation: false,
                                    startAngle: 90,
                                    data: [{
wangqinghua's avatar
wangqinghua committed
                                        value: e.memory,
wangqinghua's avatar
wangqinghua committed
                                        name: '内存使用率',
                                        itemStyle: {
                                            normal: {
                                                color: "#80ba78"
                                            }
                                        }
wangqinghua's avatar
wangqinghua committed
                                    },
                                        {
wangqinghua's avatar
wangqinghua committed
                                            value: 100 - e.memory,
wangqinghua's avatar
wangqinghua committed
                                            name: '',
                                            tooltip: {
                                                show: false
                                            },
                                            itemStyle: placeHolderStyle
                                        },
                                    ]
                                },
wangqinghua's avatar
wangqinghua committed
                                // {
                                //     name: '带宽使用率',
                                //     type: 'pie',
                                //     clockWise: false,
                                //     radius: [20, 28],
                                //     center:['30%','50%'],
                                //     itemStyle: dataStyle,
                                //     hoverAnimation: false,
                                //     startAngle: 90,
                                //     data: [{
                                //         value: e.lose,
                                //         name: '带宽使用率',
                                //         itemStyle: {
                                //             normal: {
                                //                 color: "#73b6e4"
                                //             }
                                //         }
                                //     },
                                //         {
                                //             value: 100 - e.lose,
                                //             name: '',
                                //             tooltip: {
                                //                 show: false
                                //             },
                                //             itemStyle: placeHolderStyle
                                //         },
                                //     ]
                                // }
wangqinghua's avatar
wangqinghua committed
                            ]
                        };
                    })
                }
wangqinghua's avatar
wangqinghua committed
            }
        )
wangqinghua's avatar
wangqinghua committed
    }

wangqinghua's avatar
wangqinghua committed
    //获取分组
    getGroup() {
        this.overAllSer.findGroup().subscribe(
            (res) => {
wangqinghua's avatar
wangqinghua committed
                if(res.data){
                    this.groupList = res.data;
                    this.obj.leftGroupId = this.groupList[0].groupid;
                    this.countGroupItem();
                }
wangqinghua's avatar
wangqinghua committed
            }
        );
    }

wangqinghua's avatar
wangqinghua committed
    //主机组中统计
    countGroupItem(){
        this.layoutSer.findHostCountByStatusByGroup(this.obj.leftGroupId).subscribe(
            (res)=>{
wangqinghua's avatar
wangqinghua committed
                this.leftOneData = res.data;
wangqinghua's avatar
wangqinghua committed
                this.setLeftOne(res.data);
            }
        );
        this.layoutSer.findItemStatisticsByGroupid(this.obj.leftGroupId).subscribe(
            (res)=>{
                this.leftTwoData = res.data;
                this.setLeftTwo(res.data);
            }
        )
    }

    setLeftOne(data){
wangqinghua's avatar
wangqinghua committed
        this.leftOneDataPre = {
            highPer:0,
            warningPer:0,
            normalPer:0,
            disabledPer:0,
        };
wangqinghua's avatar
wangqinghua committed
        this.leftOneTotal = data.disabled + data.high + data.normal + data.warning;
wangqinghua's avatar
wangqinghua committed

wangqinghua's avatar
wangqinghua committed
        if(this.leftOneData.high > 0){
            let a:any = (this.leftOneData.high / this.leftOneTotal)* 100;
            this.leftOneDataPre.highPer = a.toFixed(2);
        }

        if(this.leftOneData.warning > 0){
            let b:any = ( (this.leftOneData.warning / this.leftOneTotal)* 100 );
            this.leftOneDataPre.warningPer = b .toFixed(2);
        }
wangqinghua's avatar
wangqinghua committed

wangqinghua's avatar
wangqinghua committed
        if(this.leftOneData.normal > 0){
            let c:any = ( (this.leftOneData.normal / this.leftOneTotal)* 100);
            this.leftOneDataPre.normalPer = c .toFixed(2);
        }

        if(this.leftOneData.disabled > 0){
            let d:any = ( (this.leftOneData.disabled / this.leftOneTotal)* 100 );
            this.leftOneDataPre.disabledPer = d .toFixed(2);
        }
wangqinghua's avatar
wangqinghua committed

wangqinghua's avatar
wangqinghua committed
        this.leftOneChart =
            {
                title: {
wangqinghua's avatar
wangqinghua committed
                    text: "" +this.leftOneTotal+'\n设备',
wangqinghua's avatar
wangqinghua committed
                    x: '41%',
wangqinghua's avatar
wangqinghua committed
                    y: '40%',
                    itemGap: 50,
                    textStyle: {
wangqinghua's avatar
wangqinghua committed
                        color: '#333',
                        fontSize: 18,
wangqinghua's avatar
wangqinghua committed
                        fontWeight: 'normal',
                    },
                    subtextStyle: {
                        color: '#de4751',
                        fontSize: 12
                    }
                },
                tooltip: {
                    trigger: 'item',
                    formatter: "{a} <br/>{b} : {c} ({d}%)"
                },

                series: [
                    {
wangqinghua's avatar
wangqinghua committed
                        name:"设备",
wangqinghua's avatar
wangqinghua committed
                        type: 'pie',
                        clockWise: true,
wangqinghua's avatar
wangqinghua committed
                        center: ["46%", "50%"],
wangqinghua's avatar
wangqinghua committed
                        radius: ['40%', '60%'],
wangqinghua's avatar
wangqinghua committed
                        color: ['#f93215', '#ff8400', '#2fb35b', '#a0a0a0'],
wangqinghua's avatar
wangqinghua committed
                        label: {
                            normal: {
                                show: false,
                                position: 'center'
                            }
                        },
                        labelLine: {
                            normal: {
                                show: false
                            }
                        },
                        data: [
wangqinghua's avatar
wangqinghua committed
                            {value: data.high, name: '严重'},
wangqinghua's avatar
wangqinghua committed
                            {value: data.warning, name: '告警'},
wangqinghua's avatar
wangqinghua committed
                            {value: data.normal, name: '正常'},
wangqinghua's avatar
wangqinghua committed
                            {value: data.disabled, name: '禁止'},
wangqinghua's avatar
wangqinghua committed
                        ],
                        itemStyle: {
                            emphasis: {
                                shadowBlur: 10,
                                shadowOffsetX: 0,
                                shadowColor: 'rgba(0, 0, 0, 0.5)'
                            }
                        }
                    }
                ]
            };
    }

wangqinghua's avatar
wangqinghua committed
    setLeftTwo(data){
wangqinghua's avatar
wangqinghua committed
        this.leftTwoDataPre = {
            highPer:0,
            warningPer:0,
            normalPer:0,
            disabledPer:0,
        };
wangqinghua's avatar
wangqinghua committed
        this.leftTwoTotal = data.disabled + data.high + data.normal + data.warning;
wangqinghua's avatar
wangqinghua committed
        if(this.leftTwoData.high > 0){
            let w:any = ( (this.leftTwoData.high / this.leftTwoTotal)*100 );
            this.leftTwoDataPre.highPer = w.toFixed(2);
        }

        if(this.leftTwoData.warning > 0){
            let x:any = ( (this.leftTwoData.warning / this.leftTwoTotal)*100 );
            this.leftTwoDataPre.warningPer = x .toFixed(2);
        }

        if(this.leftTwoData.normal > 0){
            let y:any = ( (this.leftTwoData.normal / this.leftTwoTotal)*100 );
            this.leftTwoDataPre.normalPer = y.toFixed(2);
        }

        if(this.leftTwoData.disabled > 0){
            let z:any = ( (this.leftTwoData.disabled / this.leftTwoTotal)*100);
            this.leftTwoDataPre.disabledPer = z.toFixed(2);
        }
wangqinghua's avatar
wangqinghua committed

wangqinghua's avatar
wangqinghua committed
        this.leftTwoChart =
            {
                title: {
wangqinghua's avatar
wangqinghua committed
                    text: this.leftTwoTotal+'\n监测点',
wangqinghua's avatar
wangqinghua committed
                    x: '41%',
wangqinghua's avatar
wangqinghua committed
                    y: '40%',
                    itemGap: 50,
                    textStyle: {
wangqinghua's avatar
wangqinghua committed
                        color: '#333',
                        fontSize: 18,
wangqinghua's avatar
wangqinghua committed
                        fontWeight: 'normal',
                    },
                    subtextStyle: {
                        color: '#de4751',
                        fontSize: 12
                    }
                },
                tooltip: {
                    trigger: 'item',
                    formatter: "{a} <br/>{b} : {c} ({d}%)"
                },

                series: [
                    {
wangqinghua's avatar
wangqinghua committed
                        name:"监测点",
wangqinghua's avatar
wangqinghua committed
                        type: 'pie',
                        clockWise: true,
wangqinghua's avatar
wangqinghua committed
                        center: ["47%", "50%"],
wangqinghua's avatar
wangqinghua committed
                        radius: ['40%', '60%'],
wangqinghua's avatar
wangqinghua committed
                        color: ['#f93215', '#ff8400', '#2fb35b', '#a0a0a0'],
wangqinghua's avatar
wangqinghua committed
                        label: {
                            normal: {
                                show: false,
                                position: 'center'
                            }
                        },
                        labelLine: {
                            normal: {
                                show: false
                            }
                        },
                        data: [
wangqinghua's avatar
wangqinghua committed
                            {value: data.high, name: '严重'},
wangqinghua's avatar
wangqinghua committed
                            {value: data.warning, name: '告警'},
wangqinghua's avatar
wangqinghua committed
                            {value: data.normal, name: '正常'},
wangqinghua's avatar
wangqinghua committed
                            {value: data.disabled, name: '禁止'},
wangqinghua's avatar
wangqinghua committed
                        ],
                        itemStyle: {
                            emphasis: {
                                shadowBlur: 10,
                                shadowOffsetX: 0,
                                shadowColor: 'rgba(0, 0, 0, 0.5)'
                            }
                        }
                    }
                ]
            };
wangqinghua's avatar
wangqinghua committed
    }

    findGroupCount(){
wangqinghua's avatar
wangqinghua committed
        this.layoutSer.findGroupCount().subscribe(
wangqinghua's avatar
wangqinghua committed
            (res)=>{
wangqinghua's avatar
wangqinghua committed
                if(res.data.length > 0){
                    this.rightTotal = res.data.length;
                    this.rightOneChart = {
                        tooltip : {
                            trigger: 'item',
                            formatter: "{a} <br/>{b} : {c} ({d}%)"
                        },
wangqinghua's avatar
wangqinghua committed

wangqinghua's avatar
wangqinghua committed
                        series : [
                            {
wangqinghua's avatar
wangqinghua committed
                                name: '',
wangqinghua's avatar
wangqinghua committed
                                type: 'pie',
                                radius : '55%',
                                center: ['50%', '60%'],
                                data:res.data.map(e=>{
                                    const arr = {
                                        value:e.count,
                                        name:e.name
                                    };
                                    return arr;
                                }),
                                itemStyle: {
                                    emphasis: {
                                        shadowBlur: 10,
                                        shadowOffsetX: 0,
                                        shadowColor: 'rgba(0, 0, 0, 0.5)'
                                    }
wangqinghua's avatar
wangqinghua committed
                                }
                            }
wangqinghua's avatar
wangqinghua committed
                        ]
                    };
                }
wangqinghua's avatar
wangqinghua committed
            }
        )
    }

    findHostCount(){
wangqinghua's avatar
wangqinghua committed
        this.layoutSer.findHostCount().subscribe(
wangqinghua's avatar
wangqinghua committed
            (res)=>{
wangqinghua's avatar
wangqinghua committed
                if(res.data && res.data.length > 0){
                    this.rightTwoChart = {
                        tooltip : {
                            trigger: 'item',
                            formatter: "{a} <br/>{b} : {c} ({d}%)"
                        },
wangqinghua's avatar
wangqinghua committed

wangqinghua's avatar
wangqinghua committed
                        series : [
                            {
wangqinghua's avatar
wangqinghua committed
                                name: '',
wangqinghua's avatar
wangqinghua committed
                                type: 'pie',
                                radius : '55%',
                                center: ['50%', '60%'],
                                data:res.data.map(e=>{
                                    const arr = {
                                        value:e.count,
                                        name:e.name
                                    }
                                    return arr;
                                }),
                                itemStyle: {
                                    emphasis: {
                                        shadowBlur: 10,
                                        shadowOffsetX: 0,
                                        shadowColor: 'rgba(0, 0, 0, 0.5)'
                                    }
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
    //监控设备数
    findSize() {
        this.overAllSer.findSize().subscribe(
            (res) => {
                this.deviceNo = res.data.size;
            }
        );
    }

wangqinghua's avatar
wangqinghua committed
    //获取告警分组
    getAlarmList(){
        const data = {
            pageNum: this.pageNum,
            pageCount: this.pageCount,
            obj:{
wangqinghua's avatar
wangqinghua committed
                isWaring:'yes',
wangqinghua's avatar
wangqinghua committed
                groupid: this.obj.alarmGroupId,
wangqinghua's avatar
wangqinghua committed
            }
wangqinghua's avatar
wangqinghua committed
        };
wangqinghua's avatar
wangqinghua committed
        this.alarmSer.eventFind(data).subscribe(
            (res) => {
                if(res.errCode == 10000){
                    if(res.data){
                        this.warnList = res.data.data;
                        this.totalNum = res.data.totalNum;
                    }
                }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

wangqinghua's avatar
wangqinghua committed
    showAddFollow(){
        this.smartSelectGroup.showAddModal("选择资源")
    }

wangqinghua's avatar
wangqinghua committed
    change(e){
        this.pageNum = e;
        this.getAlarmList();
wangqinghua's avatar
wangqinghua committed
    }
wangqinghua's avatar
wangqinghua committed

    //设置关注
    getItem(e){
        const data = {
            resourceIds:e.map(res=>{
wangqinghua's avatar
wangqinghua committed
                return res+"";
wangqinghua's avatar
wangqinghua committed
            })
wangqinghua's avatar
wangqinghua committed
        };
wangqinghua's avatar
wangqinghua committed
        this.layoutSer.addFollow(data).subscribe(
            (res)=>{
                if(res.errCode == 10000){
                    this.message.success("添加关注成功");
wangqinghua's avatar
wangqinghua committed
                    this.getMyFollow();
wangqinghua's avatar
wangqinghua committed
                }else{
                    this.message.error(res.errMsg);
                }
            }
        )
    }

    //取消关注
wangqinghua's avatar
wangqinghua committed
    cancel(index,item){
        this.followList.splice(index,1);
wangqinghua's avatar
wangqinghua committed
        const data = {
wangqinghua's avatar
wangqinghua committed
            resourceIds:[item.hostId+""]
        };
wangqinghua's avatar
wangqinghua committed
        this.layoutSer.unFollow(data).subscribe(
            (res)=>{
                if(res.errCode == 10000){
                    this.getMyFollow();
                    this.message.success('取消关注成功');
                }else{
                    this.message.error(res.errMsg);
                }
            }
        )
    }
wangqinghua's avatar
wangqinghua committed
}