Skip to content
home.component.ts 11.5 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';
import { 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
import {Router} from '@angular/router';
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("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= [];

    totalNum;
    groupList;

    pageNum = 1;
    pageCount = 10;
    loading = false;

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

wangqinghua's avatar
wangqinghua committed
    leftOneData = {
wangqinghua's avatar
wangqinghua committed
        serious:0,
wangqinghua's avatar
wangqinghua committed
        waring:0,
wangqinghua's avatar
wangqinghua committed
        normal:0,
wangqinghua's avatar
wangqinghua committed
        disable:0,
wangqinghua's avatar
wangqinghua committed
    };
    leftOneDataPre = {
wangqinghua's avatar
wangqinghua committed
        seriousPer:0,
wangqinghua's avatar
wangqinghua committed
        warningPer:0,
        normalPer:0,
wangqinghua's avatar
wangqinghua committed
        disablePer:0,
wangqinghua's avatar
wangqinghua committed
    };
wangqinghua's avatar
wangqinghua committed

wangqinghua's avatar
wangqinghua committed
    leftOneTotal = 0;
wangqinghua's avatar
wangqinghua committed
    leftTwoData  ={
wangqinghua's avatar
wangqinghua committed
        serious:0,
wangqinghua's avatar
wangqinghua committed
        waring:0,
wangqinghua's avatar
wangqinghua committed
        normal:0,
wangqinghua's avatar
wangqinghua committed
        disable:0,
wangqinghua's avatar
wangqinghua committed
    };
    leftTwoDataPre = {
wangqinghua's avatar
wangqinghua committed
        seriousPer:0,
wangqinghua's avatar
wangqinghua committed
        warningPer:0,
        normalPer:0,
wangqinghua's avatar
wangqinghua committed
        disablePer: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
    //资源设备数量
    deviceNo;
wangqinghua's avatar
wangqinghua committed

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

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

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

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

    //查看详情
    goToDetail(item) {
        this.router.navigate(['app/main/basic-detail'], {
            queryParams: {
                hostId: item.hostid,
                name: item.hostname,
                hostName: item.hostname
            }
        });
    }

wangqinghua's avatar
wangqinghua committed
    //获取分组
    getGroup() {
        this.overAllSer.findGroup().subscribe(
            (res) => {
wangqinghua's avatar
wangqinghua committed
                if(res.data){
wangqinghua's avatar
wangqinghua committed
                    this.groupList = res.data.data;
wangqinghua's avatar
wangqinghua committed
                    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 = {
wangqinghua's avatar
wangqinghua committed
            seriousPer:0,
wangqinghua's avatar
wangqinghua committed
            warningPer:0,
            normalPer:0,
wangqinghua's avatar
wangqinghua committed
            disablePer:0,
wangqinghua's avatar
wangqinghua committed
        };
wangqinghua's avatar
wangqinghua committed
        this.leftOneTotal = data.total;
wangqinghua's avatar
wangqinghua committed

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

wangqinghua's avatar
wangqinghua committed
        if(this.leftOneData.waring > 0){
            let b:any = ( (this.leftOneData.waring / this.leftOneTotal)* 100 );
wangqinghua's avatar
wangqinghua committed
            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);
        }

wangqinghua's avatar
wangqinghua committed
        if(this.leftOneData.disable > 0){
            let d:any = ( (this.leftOneData.disable / this.leftOneTotal)* 100 );
            this.leftOneDataPre.disablePer = d .toFixed(2);
wangqinghua's avatar
wangqinghua committed
        }
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: {
                        color: '#333',
wangqinghua's avatar
wangqinghua committed
                        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.serious, 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.disable, 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 = {
wangqinghua's avatar
wangqinghua committed
            seriousPer:0,
wangqinghua's avatar
wangqinghua committed
            warningPer:0,
            normalPer:0,
wangqinghua's avatar
wangqinghua committed
            disablePer:0,
wangqinghua's avatar
wangqinghua committed
        };
wangqinghua's avatar
wangqinghua committed
        this.leftTwoTotal = data.total;
        if(this.leftTwoData.serious > 0){
            let w:any = ( (this.leftTwoData.serious / this.leftTwoTotal)*100 );
            this.leftTwoDataPre.seriousPer = w.toFixed(2);
wangqinghua's avatar
wangqinghua committed
        }

wangqinghua's avatar
wangqinghua committed
        if(this.leftTwoData.waring > 0){
            let x:any = ( (this.leftTwoData.waring / this.leftTwoTotal)*100 );
wangqinghua's avatar
wangqinghua committed
            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);
        }

wangqinghua's avatar
wangqinghua committed
        if(this.leftTwoData.disable > 0){
            let z:any = ( (this.leftTwoData.disable / this.leftTwoTotal)*100);
            this.leftTwoDataPre.disablePer = z.toFixed(2);
wangqinghua's avatar
wangqinghua committed
        }
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: {
                        color: '#333',
wangqinghua's avatar
wangqinghua committed
                        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.serious, 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.disable, name: '禁止'},
wangqinghua's avatar
wangqinghua committed
                        ],
                        itemStyle: {
                            emphasis: {
                                shadowBlur: 10,
                                shadowOffsetX: 0,
                                shadowColor: 'rgba(0, 0, 0, 0.5)'
                            }
                        }
                    }
                ]
            };
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 = {
wangqinghua's avatar
wangqinghua committed
                                        value:e.hostcount,
wangqinghua's avatar
wangqinghua committed
                                        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
    getAlarmList() {
wangqinghua's avatar
wangqinghua committed
        this.loading = true;
wangqinghua's avatar
wangqinghua committed
        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) => {
wangqinghua's avatar
wangqinghua committed
                if (res.errCode == 10000) {
                    if (res.data) {
wangqinghua's avatar
wangqinghua committed
                        this.warnList = res.data.data;
                        this.totalNum = res.data.totalNum;
                    }
                }
wangqinghua's avatar
wangqinghua committed
                this.loading = false;
wangqinghua's avatar
wangqinghua committed
            }
        );
wangqinghua's avatar
wangqinghua committed
    }
wangqinghua's avatar
wangqinghua committed

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