Skip to content
basic-detail.component.ts 30.7 KiB
Newer Older
wangqinghua's avatar
wangqinghua committed
import {AfterViewInit, Component, ElementRef, OnInit, Renderer, ViewChild,} from '@angular/core';
wangqinghua's avatar
wangqinghua committed
import {ActivatedRoute, Router} from '@angular/router';
wangqinghua's avatar
wangqinghua committed
import {OverAllService} from '../../overAll.service';
import {FormBuilder, FormGroup, Validators} from '@angular/forms';
import {NzMessageService} from 'ng-zorro-antd';
import {BasiCheckComponent} from '../../../modal/basi-check/basi-check.component';
import {NzModalService} from 'ng-zorro-antd';
wangqinghua's avatar
wangqinghua committed
import {color, pageSize} from '../../../app.constants';
wangqinghua's avatar
wangqinghua committed
import {WarnListComponent} from '../../../modal/warn-list/warn-list.component';
wangqinghua's avatar
wangqinghua committed
import {DatePipe} from '@angular/common';
wangqinghua's avatar
wangqinghua committed
import {ThresholdComponent} from '../../../modal/threshold/threshold.component';
wangqinghua's avatar
wangqinghua committed

wangqinghua's avatar
wangqinghua committed
@Component({
wangqinghua's avatar
wangqinghua committed
    selector: 'jhi-basic-detail',
    templateUrl: './basic-detail.component.html',
    styles: [
wangqinghua's avatar
wangqinghua committed
            `
wangqinghua's avatar
wangqinghua committed
            .checkTags {
                position: absolute;
wangqinghua's avatar
wangqinghua committed
                top: 12px;
wangqinghua's avatar
wangqinghua committed
                left: 233px;
xiaowenjie's avatar
xiaowenjie committed
                z-index: 989;
wangqinghua's avatar
wangqinghua committed
            }
wangqinghua's avatar
wangqinghua committed

            .time-select {
wangqinghua's avatar
wangqinghua committed
                position: absolute;
                top: 55px;
                right: 15px;
                z-index: 999;
            }
wangqinghua's avatar
wangqinghua committed

            .select-border {
wangqinghua's avatar
wangqinghua committed
                border: 1px solid #6097b7;
                border-radius: 5px;
                padding: 2px;
                margin-right: 5px;
            }
wangqinghua's avatar
wangqinghua committed

            :host ::ng-deep .tabs-smart .ant-tabs-nav-scroll div.ant-tabs-tab:nth-child(3) {
wangqinghua's avatar
wangqinghua committed
                margin-right: 180px !important;
wangqinghua's avatar
wangqinghua committed
            }
wangqinghua's avatar
wangqinghua committed

            :host ::ng-deep .ant-radio-button-wrapper {
wangqinghua's avatar
wangqinghua committed
                margin: 4px;
            }
wangqinghua's avatar
wangqinghua committed
        `
    ]
wangqinghua's avatar
wangqinghua committed
})
wangqinghua's avatar
wangqinghua committed
export class BasicDetailComponent implements OnInit, AfterViewInit {
wangqinghua's avatar
wangqinghua committed
    @ViewChild('smartCheck') smartCheck: BasiCheckComponent;
wangqinghua's avatar
wangqinghua committed
    @ViewChild('smartThreshold') smartThreshold: ThresholdComponent;
wangqinghua's avatar
wangqinghua committed
    @ViewChild('thirdTabs') thirdTabs: ElementRef;
    @ViewChild('warnList') warnList: WarnListComponent;
wangqinghua's avatar
wangqinghua committed
    @ViewChild('colorEle') colorEle: ElementRef;
    @ViewChild('checkEle') checkEle: ElementRef;
wangqinghua's avatar
wangqinghua committed
    color = color;
wangqinghua's avatar
wangqinghua committed
    loading = false;
wangqinghua's avatar
wangqinghua committed
    hostId: string;
wangqinghua's avatar
wangqinghua committed
    tabNum = 0;
wangqinghua's avatar
wangqinghua committed
    hostName;
wangqinghua's avatar
wangqinghua committed
    realName;
wangqinghua's avatar
wangqinghua committed
    size = 'default';
wangqinghua's avatar
wangqinghua committed
    changeStates;
wangqinghua's avatar
wangqinghua committed
    chartOption1;
    responseTimeStr;
    losedStr;
    cpuUsedStr;
    usedStr;
    chartOption2;
    chartOption3;
    chartOption4;
    secondOptionLeft;
    secondOptionRight;
wangqinghua's avatar
wangqinghua committed
    dataSet: any[];
    panel1 = {active: true, name: '响应时间与丢包率', disabled: false};
wangqinghua's avatar
wangqinghua committed
    panel2 = {active: true, name: 'CPU使用率及内存使用率', disabled: false};
wangqinghua's avatar
wangqinghua committed
    panel3 = {active: true, name: '磁盘使用情况', disabled: false};
wangqinghua's avatar
wangqinghua committed

    //监控点
    isBasicEdit;
wangqinghua's avatar
wangqinghua committed
    itemTypeValue;
wangqinghua's avatar
wangqinghua committed
    interfaceList: any[];
    itemTypeList: any[];
wangqinghua's avatar
wangqinghua committed

    //
wangqinghua's avatar
wangqinghua committed
    checkList: any[];
wangqinghua's avatar
wangqinghua committed
    isCheck = false;
    checkStatus = {
wangqinghua's avatar
wangqinghua committed
        warning: null,
        normal: null,
        disabled: null,
        high: null
wangqinghua's avatar
wangqinghua committed
    };
wangqinghua's avatar
wangqinghua committed

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

    //图表
    isGrapha = false;
wangqinghua's avatar
wangqinghua committed
    selectGraphadata;
wangqinghua's avatar
wangqinghua committed
    chartOptionGrapha;
wangqinghua's avatar
wangqinghua committed
    imageSelectDate = new Date();
wangqinghua's avatar
wangqinghua committed

wangqinghua's avatar
wangqinghua committed
    pageSize = pageSize;
wangqinghua's avatar
wangqinghua committed

    //分页--监控点
    pageIndex = 1;  //当前页数
wangqinghua's avatar
wangqinghua committed
    totalNum;   //总数据长度
    applicationId;    //分类ID

wangqinghua's avatar
wangqinghua committed
    //进出口流量-分页
    pageNum = 1;
wangqinghua's avatar
wangqinghua committed
    pageCount = 5;
wangqinghua's avatar
wangqinghua committed
    totalNumInOut;
wangqinghua's avatar
wangqinghua committed
    inOutLoading;
wangqinghua's avatar
wangqinghua committed

wangqinghua's avatar
wangqinghua committed
    //分页--告警
    warn_totalNum;
    warn_pageNum = 1;

wangqinghua's avatar
wangqinghua committed
    searchName;

wangqinghua's avatar
wangqinghua committed
    validateForm: FormGroup;

wangqinghua's avatar
wangqinghua committed
    isSpinning;  //刷新
wangqinghua's avatar
wangqinghua committed
    units;   //图表单位
wangqinghua's avatar
wangqinghua committed

wangqinghua's avatar
wangqinghua committed
    constructor(private routerInfo: ActivatedRoute, private message: NzMessageService,
wangqinghua's avatar
wangqinghua committed
                private overAllSer: OverAllService, private renderer: Renderer, private router: Router,
                private fb: FormBuilder, private modalService: NzModalService, private datePipe: DatePipe) {
wangqinghua's avatar
wangqinghua committed
        this.routerInfo.queryParams.subscribe(queryParams => {
            this.hostId = queryParams.hostId;
wangqinghua's avatar
wangqinghua committed
            this.overAllSer.findDetailed(this.hostId).subscribe(
wangqinghua's avatar
wangqinghua committed
                (res) => {
                    let data = res.data[0];
wangqinghua's avatar
wangqinghua committed
                    this.hostName = data.name;   //显示名
                    this.realName = data.host;   //主机名
                }
wangqinghua's avatar
wangqinghua committed
            );
wangqinghua's avatar
wangqinghua committed
        });
wangqinghua's avatar
wangqinghua committed
    }

    ngOnInit() {
wangqinghua's avatar
wangqinghua committed
        this.isSpinning = true;
        this.responseTime();
        this.losed();
        this.cpused();
        this.used();
        // this.inOutInfo();

        //监测点
        this.getList();

        //历史告警
        const obj = {};
        this.warnList.getList(obj);
        this.disks();
wangqinghua's avatar
wangqinghua committed
    }

    ngAfterViewInit() {
wangqinghua's avatar
wangqinghua committed
        this.checkEle.nativeElement.children[1].children[0].children[0].children[2].children[0].children[0].children[2].style.marginRight = this.colorEle.nativeElement.offsetWidth + 'px';
wangqinghua's avatar
wangqinghua committed
    }

    //平均响应时间
    responseTime() {
        this.overAllSer.responseTime(this.hostId).subscribe(
            (res) => {
                if (res.errCode == 10000) {
                    this.responseTimeStr = res.data.responseTime.toFixed(2);
                    const responseTime = this.responseTimeStr;
                    const other = 100 - this.responseTimeStr;
                    const data = [
                        {value: responseTime},
                        {value: other},
                        {
                            value: 100, name: '', tooltip: {
                                formatter: function(a) {
                                    return '';
                                }
                            }
                        }
                    ];
                    this.chartOption1 = {
                        title: {
                            text: '平均响应时间',
                            top: '5%',
                            left: '35%',
                            textStyle: {
                                color: '#999',
                                fontSize: 12,
                            }
                        },
                        tooltip: {
                            trigger: 'item',
                            show: false,
                            formatter: '{a} <br/>{b} : {c} ({d}%)'
                        },
                        color: ['#7eb6ea', '#eeeeee', 'transparent'],
                        series: [
                            {
                                type: 'pie',
                                startAngle: 180,
                                radius: ['50%', '85%'],
                                center: ['50%', '75%'],
                                hoverAnimation: true,
                                data: data,
                                itemStyle: {
                                    normal: {
                                        show: false,
                                        position: 'center'
                                    },
                                    emphasis: {
                                        shadowBlur: 10,
                                        shadowOffsetX: 0,
                                        shadowColor: 'rgba(0, 0, 0, 0.5)'
                                    }
                                },
                                labelLine: {
                                    normal: {
                                        show: false
                                    }
                                },
                            }
                        ]
                    };
                }
            }
        );
    }

    //丢包率
    losed() {
        this.overAllSer.losed(this.hostId).subscribe(
            (res) => {
                if (res.errCode == 10000) {
                    this.losedStr = res.data.losed;
                    const losed = res.data.losed;
                    const other = 100 - res.data.losed;
                    const data = [
                        {value: losed},
                        {value: other},
                        {
                            value: 100, name: '', tooltip: {
                                formatter: function(a) {
                                    return '';
                                }
                            }
                        }
                    ];
                    this.chartOption2 = {
                        title: {
                            text: '丢包率',
                            top: '5%',
                            left: '38%',
                            textStyle: {
                                color: '#999',
                                fontSize: 12,
                            }
                        },
                        tooltip: {
                            trigger: 'item',
                            show: false,
                            formatter: '{a} <br/>{b} : {c} ({d}%)'
                        },
                        color: ['#7eb6ea', '#eeeeee', 'transparent'],
                        series: [
                            {
                                type: 'pie',
                                startAngle: 180,
                                radius: ['50%', '85%'],
                                center: ['50%', '75%'],
                                hoverAnimation: true,
                                data: data,
                                itemStyle: {
                                    normal: {
                                        show: false,
                                        position: 'center'
                                    },
                                    emphasis: {
                                        shadowBlur: 10,
                                        shadowOffsetX: 0,
                                        shadowColor: 'rgba(0, 0, 0, 0.5)'
                                    }
                                },
                                labelLine: {
                                    normal: {
                                        show: false
                                    }
                                },
                            }
                        ]
                    };
                }
            }
        );
    }

    //cup使用率
    cpused() {
        const data = {
            hostId: this.hostId,
        };
        this.overAllSer.cupUsed(data).subscribe(
            (res) => {
                if (res.errCode == 10000) {
                    this.cpuUsedStr = res.data.cpuUsed;
                    const losed = res.data.cpuUsed;
                    const other = 100 - res.data.cpuUsed;
                    const data = [
                        {value: losed},
                        {value: other},
                        {
                            value: 100, name: '', tooltip: {
                                formatter: function(a) {
                                    return '';
                                }
                            }
                        }
                    ];
                    this.chartOption3 = {
                        title: {
                            text: 'CPU使用率',
                            top: '5%',
                            left: '38%',
                            textStyle: {
                                color: '#999',
                                fontSize: 12,
                            }
                        },
                        tooltip: {
                            trigger: 'item',
                            show: false,
                            formatter: '{a} <br/>{b} : {c} ({d}%)'
                        },
                        color: ['#7eb6ea', '#eeeeee', 'transparent'],
                        series: [
                            {
                                type: 'pie',
                                startAngle: 180,
                                radius: ['50%', '85%'],
                                center: ['50%', '75%'],
                                hoverAnimation: true,
                                data: data,
                                itemStyle: {
                                    normal: {
                                        show: false,
                                        position: 'center'
                                    },
                                    emphasis: {
                                        shadowBlur: 10,
                                        shadowOffsetX: 0,
                                        shadowColor: 'rgba(0, 0, 0, 0.5)'
                                    }
                                },
                                labelLine: {
                                    normal: {
                                        show: false
                                    }
                                },
                            }
                        ]
                    };
                }
            }
        );
    }

    //内存使用率
    used() {
        const data = {
            hostId: this.hostId,
        };
        this.overAllSer.used(data).subscribe(
            (res) => {
                if (res.errCode == 10000) {
                    this.usedStr = res.data.used;
                    const used = res.data.used;
                    const other = 100 - res.data.used;
                    const data = [
                        {value: used},
                        {value: other},
                        {
                            value: 100, name: '', tooltip: {
                                formatter: function(a) {
                                    return '';
                                }
                            }
                        }
                    ];
                    this.chartOption4 = {
                        title: {
                            text: '内存使用率',
                            top: '5%',
                            left: '38%',
                            textStyle: {
                                color: '#999',
                                fontSize: 12,
                            }
                        },
                        tooltip: {
                            trigger: 'item',
                            show: false,
                            formatter: '{a} <br/>{b} : {c} ({d}%)'
                        },
                        color: ['#7eb6ea', '#eeeeee', 'transparent'],
                        series: [
                            {
                                type: 'pie',
                                startAngle: 180,
                                radius: ['50%', '85%'],
                                center: ['50%', '75%'],
                                hoverAnimation: true,
                                data: data,
                                itemStyle: {
                                    normal: {
                                        show: false,
                                        position: 'center'
                                    },
                                    emphasis: {
                                        shadowBlur: 10,
                                        shadowOffsetX: 0,
                                        shadowColor: 'rgba(0, 0, 0, 0.5)'
                                    }
                                },
                                labelLine: {
                                    normal: {
                                        show: false
                                    }
                                },
                            }
                        ]
                    };
                } else {
                    this.message.info(res.errMsg);
                }

            }
        );
    }

    //磁盘使用率
    disks() {
        const data = {
            hostId: this.hostId,
        };
        this.overAllSer.disks(data).subscribe(
            (res) => {
                if (res.errCode == 10000) {
                    this.secondOptionLeft = {
                        grid: {
                            left: '8%',
                            right: '0',
                            bottom: '1%',
                            containLabel: true
                        },
                        tooltip: {
                            trigger: 'axis',
                        },
                        xAxis: {
                            type: 'value',
                            show: false,
                        },
                        yAxis: {
                            triggerEvent: true,
                            type: 'category',
                            axisTick: {
                                show: false
                            },
                            axisLine: {
                                show: false,
                            },
                            // 分割线设置
                            splitLine: {
                                show: true,  //显示分割线
                            },
                            data: res.data.disks.map((item) => {
                                return item.name;
                            }),
wangqinghua's avatar
wangqinghua committed
                            axisLabel: res.data.disks.map((item) => {
wangqinghua's avatar
wangqinghua committed
                                let data = item.name;
wangqinghua's avatar
wangqinghua committed
                                if (data.length > 5) {
                                    data = data.substring(0, 4) + '..';
wangqinghua's avatar
wangqinghua committed
                                }
                                return data;
                            }),
                        },
                        color: ['#ed7a7b', '#f2f2f2'],
                        series: [
                            {
                                name: '已使用',
                                type: 'bar',
                                stack: '总空间',
                                label: {
                                    normal: {
                                        show: true,
                                        position: 'insideRight',
                                        formatter: (obj) => {
                                            const item = (res.data.disks[obj.dataIndex].used / (1024 * 1024 * 1024)).toFixed(2);
                                            return item + 'G';
                                        }
                                    }
                                },
                                itemStyle: {
                                    normal: {
                                        color: '#0D5DCB'
                                    },
                                },
                                data: res.data.disks.map((item) => {
wangqinghua's avatar
wangqinghua committed
                                    const pre = ((item.used / item.total) * 100).toFixed(2);  //已使用百分比
wangqinghua's avatar
wangqinghua committed
                                    return pre;
                                })
                            },
                            {
                                name: '剩余空间',
                                type: 'bar',
                                stack: '总空间',
                                label: {
                                    normal: {
                                        show: true,
                                        position: 'insideRight',
                                        formatter: (obj) => {
                                            const cut = (res.data.disks[obj.dataIndex].total - res.data.disks[obj.dataIndex].used);
                                            const item = (cut / (1024 * 1024 * 1024)).toFixed(2);
                                            return item + 'G';
                                        }
                                    }
                                },
                                itemStyle: {
                                    normal: {
                                        color: '#bfbfbf'
                                    },
                                },
                                data: res.data.disks.map((item) => {
wangqinghua's avatar
wangqinghua committed
                                    const pre = ((item.total - item.used) / (item.total) * 100).toFixed(2); //剩余百分比
wangqinghua's avatar
wangqinghua committed
                                    return pre;
                                })
                            },
                        ]
                    };

                    let total = res.data.disks.map((item) => {
                        return item.total;
                    });
                    total = this.add(total);

                    let used = res.data.disks.map((item) => {
                        return item.used;
                    });
                    used = this.add(used);

                    const arr = [
                        {
wangqinghua's avatar
wangqinghua committed
                            name: '已使用',
                            value: used,
wangqinghua's avatar
wangqinghua committed
                        },
                        {
wangqinghua's avatar
wangqinghua committed
                            name: '未使用',
                            value: total,
wangqinghua's avatar
wangqinghua committed
                        }
                    ];

                    this.secondOptionRight = {
                        title: {
                            text: '磁盘总体使用占比',
                            x: 'center'
                        },
                        tooltip: {
                            trigger: 'item',
                            formatter: '{a} <br/>{b} : {c} ({d}%)'
                        },
wangqinghua's avatar
wangqinghua committed
                        color: ['#3194e0', '#bfbfbf'],
wangqinghua's avatar
wangqinghua committed
                        series: [
                            {
                                name: '',
                                type: 'pie',
                                radius: '55%',
                                center: ['50%', '60%'],
                                data: arr,
                                itemStyle: {
                                    normal: {
                                        label: {
                                            position: 'inner',
                                            show: true,
                                            formatter: '{b} : {c} ({d}%)'
                                        },
                                        labelLine: {show: true}
                                    }
                                },
                                labelLine: {
                                    normal: {
                                        show: false
                                    }
                                },
                            }
                        ]
                    };

                } else {
                    this.message.info(res.errMsg);
                }
                this.isSpinning = false;
            }
        );
    }

    add(arr) {
        let total = 0;
        for (let i = 0; i < arr.length; i++) {
            total += arr[i];
        }
        return (total / 1024 / 1024 / 1024).toFixed(2);
    }

    //进出口流量-SNMP
    inOutInfo() {
        this.inOutLoading = true;
        const data = {
wangqinghua's avatar
wangqinghua committed
            obj: {
                hostid: Number(this.hostId)
wangqinghua's avatar
wangqinghua committed
            },
wangqinghua's avatar
wangqinghua committed
            pageNum: this.pageNum,
            pageCount: this.pageCount
        };
wangqinghua's avatar
wangqinghua committed
        this.overAllSer.inOutInfoSnmp(data).subscribe(
            (res) => {
                if (res.errCode == 10000) {
                    this.dataSet = res.data.data;
                    this.inOutLoading = false;
                    this.totalNumInOut = res.data.totalNum;
wangqinghua's avatar
wangqinghua committed
                } else {
wangqinghua's avatar
wangqinghua committed
                    this.message.info(res.errMsg);
                }
            }
        );
    }

    //进出口流量 翻页
wangqinghua's avatar
wangqinghua committed
    changeInoutInfo(e) {
wangqinghua's avatar
wangqinghua committed
        this.pageNum = e;
        // this.inOutInfo();
    }

    //添加监测点
    showCheckModal() {
wangqinghua's avatar
wangqinghua committed
        this.smartCheck.showAddModal(this.hostId, this.realName, '添加监测点');
wangqinghua's avatar
wangqinghua committed
    }

    //编辑监测点
wangqinghua's avatar
wangqinghua committed
    showEditModal(item) {
        this.smartCheck.showEditModal(this.hostId, item.itemid, this.realName, item.templateid, '编辑监测点');
wangqinghua's avatar
wangqinghua committed
    }

    //添加阈值
wangqinghua's avatar
wangqinghua committed
    showAddThresholdModal(item) {
        this.smartThreshold.showAddModal('添加阈值', item.itemid, this.realName);
wangqinghua's avatar
wangqinghua committed
    }

    //编辑阈值
wangqinghua's avatar
wangqinghua committed
    showEditThresholdModal(item) {
        this.smartThreshold.showEditModal('编辑阈值', item.itemid, this.hostId, this.realName);
wangqinghua's avatar
wangqinghua committed
    }

    //添加or编辑监测点 之后
wangqinghua's avatar
wangqinghua committed
    getList() {
wangqinghua's avatar
wangqinghua committed
        this.getCheckList();
        this.findItemType();
    }

    handleKeyCancel() {
        this.isKey = false;
    }

    handleKeyOk() {
        this.isKey = false;
    }

    //监测点列表
    getCheckList() {
        this.getCheckStatus();
        this.loading = true;
        const data = {
            pageNum: this.pageIndex,
            pageCount: pageSize,
wangqinghua's avatar
wangqinghua committed
            obj: {
wangqinghua's avatar
wangqinghua committed
                applicationid: this.applicationId,
                hostid: this.hostId,
wangqinghua's avatar
wangqinghua committed
                priorityName: this.changeStates,
                name: this.searchName
wangqinghua's avatar
wangqinghua committed
            }
        };
        this.overAllSer.findCheckByType(data).subscribe(
            (res) => {
                this.checkList = res.data.data;
                this.totalNum = res.data.totalNum;
                this.loading = false;
            }
        );
    }

wangqinghua's avatar
wangqinghua committed
    changeState(state) {
wangqinghua's avatar
wangqinghua committed
        this.tabNum = 1;
        this.changeStates = state;
        this.getCheckList();
    }

    //分页
    change(e) {
        this.pageIndex = e;
        this.getCheckList();
    }

    changeType(item) {
        this.pageIndex = 1;
wangqinghua's avatar
wangqinghua committed
        if (item.name == '全部') {
wangqinghua's avatar
wangqinghua committed
            this.changeStates = null;
        }
        this.applicationId = item.applicationid;
        this.getCheckList();
    }

    //监测点状态
    getCheckStatus() {
        this.overAllSer.findItemCount(this.hostId).subscribe(
            (res) => {
wangqinghua's avatar
wangqinghua committed
                if (res.errCode == 10000) {
wangqinghua's avatar
wangqinghua committed
                    this.checkStatus = res.data;
                }
            }
        );
    }

    //删除监测点
    deleteCheckItem(item) {
        this.modalService.confirm({
            nzTitle: '删除',
            nzContent: '<b style="color: red;">确认删除该监测点吗?</b>',
            nzOkText: '确定',
            nzOkType: 'danger',
            nzOnOk: () => {
                const data = {
wangqinghua's avatar
wangqinghua committed
                    itemids: [item.itemid],
                    templateid: item.templateid
wangqinghua's avatar
wangqinghua committed
                };
                this.overAllSer.deleteItem(data).subscribe(
                    (res) => {
                        if (res.errCode == 10000) {
                            this.message.success('删除成功');
                            this.getCheckList();
                        } else {
                            this.message.error(res.errMsg);
                        }
                    }
                );
            },
            nzCancelText: '取消',
            nzOnCancel: () => console.log('Cancel')
        });
    }

    //图表
    showImageModal(data) {
        this.isGrapha = true;
        this.selectGraphadata = data;

        this.getGraphDate();
    }

    //获取图表数据
wangqinghua's avatar
wangqinghua committed
    getGraphDate() {
wangqinghua's avatar
wangqinghua committed
        const data = {
wangqinghua's avatar
wangqinghua committed
            date: this.datePipe.transform(this.imageSelectDate, 'yyyy-MM-dd'),
wangqinghua's avatar
wangqinghua committed
            itemid: this.selectGraphadata.itemid
        };
        this.overAllSer.findGraphData(data).subscribe(
            (res) => {
                if (res.errCode == 10000 && res.data.length > 0) {
                    const result = res.data;
                    this.chartOptionGrapha = {
                        title: {
                            text: this.selectGraphadata.name
                        },
                        tooltip: {
                            trigger: 'axis'
                        },
                        xAxis: {
                            data: result.map((item) => {
                                return item.time;
                            })
                        },
                        yAxis: {
                            splitLine: {
                                show: false
                            },
wangqinghua's avatar
wangqinghua committed
                            axisLabel: {   //Y轴数据
                                formatter: (value) => {
                                    return value + ' ' + this.selectGraphadata.units;   //负数取绝对值变正数
wangqinghua's avatar
wangqinghua committed
                                },
                            },
                        },
                        dataZoom: [{
                            startValue: '2014-06-01'
                        }, {
                            type: 'inside'
                        }],
                        series: {
                            type: 'line',
                            data: result.map((item) => {
wangqinghua's avatar
wangqinghua committed
                                return item.value;
wangqinghua's avatar
wangqinghua committed
                            }),

                        }
                    };
                }
            }
        );
    }

    handleImageCancel() {
        this.isGrapha = false;
        this.chartOptionGrapha = null;
    }

    //监控项分类
    findItemType() {
        const data = {
            'hostids': []
        };
        data.hostids.push(this.hostId);
        this.overAllSer.findItemType(data).subscribe(
            (res) => {
                this.itemTypeList = res.data;
                const data = {
wangqinghua's avatar
wangqinghua committed
                    applicationid: '',
                    name: '全部'
wangqinghua's avatar
wangqinghua committed
                };
wangqinghua's avatar
wangqinghua committed
                if (null != res.data) {
wangqinghua's avatar
wangqinghua committed
                    this.itemTypeList.unshift(data);
                }
                this.itemTypeValue = '';

            }
        );
wangqinghua's avatar
wangqinghua committed
    }

wangqinghua's avatar
wangqinghua committed
    //停止/启用监控项  0  启用   1停止
    updateItem(itemid, status) {
        const data = {
            'status': status,
            'itemid': itemid
        };
        this.modalService.confirm({
            nzTitle: '',
            nzContent: '<b style="color: red;">确认修改监控项状态吗?</b>',
            nzOkText: '确定',
            nzOkType: 'danger',
            nzOnOk: () => {
                this.overAllSer.itemUpdate(data).subscribe(
                    (res) => {
                        if (res.errCode == 10000) {
                            this.getCheckList();
                        }
                        this.message.info(res.errMsg);
                    }
                );
            },
            nzCancelText: '取消',
            nzOnCancel: () => console.log('Cancel')
        });
    }

    //删除单个资源
    showDeleteConfirm() {
        this.modalService.confirm({
            nzTitle: '删除',
            nzContent: '<b style="color: red;">确认删除该资源吗?</b>',
            nzOkText: '确定',
            nzOkType: 'danger',
            nzOnOk: () => {
                const data = {
wangqinghua's avatar
wangqinghua committed
                    hostids: []
wangqinghua's avatar
wangqinghua committed
                };
                data.hostids.push(this.hostId);
                this.overAllSer.deleteHostPost(data).subscribe(
                    (res) => {
                        if (res.errCode == 10000) {
                            this.message.success('删除成功');
                            this.router.navigate(['app/main/basic']);
                        } else {
                            this.message.error(res.errMsg);
                        }
                    }
                );
            },
            nzCancelText: '取消',
            nzOnCancel: () => console.log('Cancel')
        });
    }
wangqinghua's avatar
wangqinghua committed
}
wangqinghua's avatar
wangqinghua committed