Skip to content
home.component.html 9.97 KiB
Newer Older
wangqinghua's avatar
wangqinghua committed
<!--资源可用性统计-->
<div nz-row class="breadcrumbs">
    <div nz-col nzSpan="16">
        <nz-breadcrumb class="padding-8-0">
            <nz-breadcrumb-item>
                当前位置:首页
            </nz-breadcrumb-item>
        </nz-breadcrumb>
    </div>
    <div nz-col nzSpan="8" class="text-right">
wangqinghua's avatar
wangqinghua committed
        <button (click)="ngOnInit()" nz-button nzType="primary"><i class="anticon anticon-sync"></i></button>
wangqinghua's avatar
wangqinghua committed
        <smart-full-screen></smart-full-screen>
wangqinghua's avatar
wangqinghua committed
    </div>
</div>
wangqinghua's avatar
wangqinghua committed
<div>
    <nz-row [nzGutter]="10">
        <nz-col class="padding-10" nzSpan="12">
            <div nz-row class="host-item-title">
                <div nz-col nzSpan="12">运行情况统计</div>
                <div nz-col nzSpan="12">
                    <nz-select style="width: 200px;float: right" nzPlaceHolder="选择分组" [(ngModel)]="obj.leftGroupId"
                               (ngModelChange)="countGroupItem()">
                        <ng-container *ngFor="let item of groupList;let i = index;">
                            <nz-option [nzLabel]="item.name" [nzValue]="item.groupid"></nz-option>
                        </ng-container>
                    </nz-select>
wangqinghua's avatar
wangqinghua committed
                </div>
            </div>
wangqinghua's avatar
wangqinghua committed
            <div nz-row class="host-item-content">
                <div nz-col nzSpan="12">
                    <div echarts [options]="leftOneChart" style="height: 250px;width: 100%"></div>
                    <div class="flex-center">
                        <div class="flex-item round-tag tag-form">
                            <p>
                                <nz-tag class="tag-red" [nzColor]="color.red"></nz-tag>
                                <span class="margin-0-10">严重 {{leftOneData.high}}个,{{leftOneDataPre.highPer}}%</span>
                            </p>
                            <p>
                                <nz-tag class="tag-yellow" [nzColor]="color.yellow"></nz-tag>
                                <span class="margin-0-10">告警 {{leftOneData.warning}}个,{{leftOneDataPre.warningPer}}
                                    % </span>
                            </p>
                            <p>
                                <nz-tag class="tag-green" [nzColor]="color.green"></nz-tag>
                                <span class="margin-0-10">正常 {{leftOneData.normal}}个,{{leftOneDataPre.normalPer}}
                                    % </span>
                            </p>
                            <p>
                                <nz-tag class="tag-gray" [nzColor]="color.gray"></nz-tag>
                                <span class="margin-0-10">禁止 {{leftOneData.disabled}}个,{{leftOneDataPre.disabledPer}}
                                    %</span>
                            </p>
                        </div>
wangqinghua's avatar
wangqinghua committed
                    </div>
wangqinghua's avatar
wangqinghua committed
                </div>
wangqinghua's avatar
wangqinghua committed
                <div nz-col nzSpan="12">
                    <div echarts [options]="leftTwoChart" style="height: 250px;width: 100%"></div>
                    <div class="flex-center">
                        <div class="flex-item  round-tag tag-form">
                            <p>
wangqinghua's avatar
wangqinghua committed
                                <nz-tag class="tag-red" [nzColor]="color.red"></nz-tag>
wangqinghua's avatar
wangqinghua committed
                                <span class="margin-0-10">严重 {{leftTwoData.high}}个,{{leftTwoDataPre.highPer}}% </span>
                            </p>
                            <p>
wangqinghua's avatar
wangqinghua committed
                                <nz-tag class="tag-yellow" [nzColor]="color.yellow"></nz-tag>
wangqinghua's avatar
wangqinghua committed
                                <span class="margin-0-10">告警 {{leftTwoData.warning}}个,{{leftTwoDataPre.warningPer}}
                                    % </span>
                            </p>
                            <p>
                                <nz-tag class="tag-green" [nzColor]="color.green"></nz-tag>
                                <span class="margin-0-10">正常 {{leftTwoData.normal}}个,{{leftTwoDataPre.normalPer}}
                                    % </span>
                            </p>
                            <p>
                                <nz-tag class="tag-gray" [nzColor]="color.gray"></nz-tag>
                                <span class="margin-0-10">禁止 {{leftTwoData.disabled}}个,{{leftTwoDataPre.disabledPer}}
                                    %</span>
wangqinghua's avatar
wangqinghua committed
                            </p>
wangqinghua's avatar
wangqinghua committed
                        </div>
                    </div>
wangqinghua's avatar
wangqinghua committed
                </div>
            </div>
wangqinghua's avatar
wangqinghua committed
        </nz-col>
wangqinghua's avatar
wangqinghua committed
        <nz-col class="padding-10" nzSpan="12" style="position: relative">
wangqinghua's avatar
wangqinghua committed
            <div class="host-item-title">告警总数趋势</div>
wangqinghua's avatar
wangqinghua committed
            <div class="time-group" style="top: 18px;">
                <nz-select style="width: 150px;" nzPlaceHolder="选择时间" [(ngModel)]="timeTypeTrend"
                           (ngModelChange)="changeTrend($event)">
                    <ng-container *ngFor="let time of timeList">
                        <nz-option [nzLabel]="time.label" [nzValue]="time.value"></nz-option>
                    </ng-container>
                </nz-select>
            </div>
wangqinghua's avatar
wangqinghua committed
            <div class="host-item-content">
wangqinghua's avatar
wangqinghua committed
                <ng-container *ngIf="noData">
                    <div class="img-noData" style="min-height: 400px">
                        <div class="noData" title="暂无数据"></div>
                    </div>
                </ng-container>
wangqinghua's avatar
wangqinghua committed
                <ng-container *ngIf="!noData">
wangqinghua's avatar
wangqinghua committed
                    <nz-spin [nzSpinning]="isTrendLoading">
                        <div echarts [options]="charTrendOption" style="height: 360px;width: 100%"></div>
                    </nz-spin>
                </ng-container>
wangqinghua's avatar
wangqinghua committed
            </div>
        </nz-col>
wangqinghua's avatar
wangqinghua committed
    </nz-row>

    <nz-row [nzGutter]="10">
wangqinghua's avatar
wangqinghua committed
        <nz-col class="padding-10" nzSpan="12">
            <div class="host-item-title">运行情况统计</div>
            <div class="host-item-table" style="height: 500px">
                <nz-row class="text-center table-title">
                    <nz-col nzSpan="3">状态</nz-col>
                    <nz-col nzSpan="7">资源名称</nz-col>
                    <nz-col nzSpan="7">CPU利用率</nz-col>
                    <nz-col nzSpan="7">内存利用率</nz-col>
                </nz-row>
wangqinghua's avatar
wangqinghua committed
                <ng-container *ngFor="let flow of countOrderList;">
wangqinghua's avatar
wangqinghua committed
                    <nz-row class="table-content">
                        <nz-col class="text-center" nzSpan="3">状态</nz-col>
wangqinghua's avatar
wangqinghua committed
                        <nz-col nzSpan="7">{{flow.name}}</nz-col>
wangqinghua's avatar
wangqinghua committed
                        <nz-col nzSpan="7">
                            <div class="width-host">
                                <div class="space" [style.width]="flow.cpuUseRate + '%'"></div>
                            </div>
                        </nz-col>
                        <nz-col nzSpan="7">
                            <div class="width-host">
                                <div class="space" [style.width]="flow.vmUseRate + '%'"></div>
                            </div>
                        </nz-col>
wangqinghua's avatar
wangqinghua committed
                    </nz-row>
                </ng-container>
            </div>
        </nz-col>
        <nz-col class="padding-10" nzSpan="12">
            <div class="host-item-title">资源数量统计</div>
            <div class="host-item-content" style="height: 500px">
wangqinghua's avatar
wangqinghua committed
                <!--                <div echarts [options]="rightOneChart" style="height: 250px;width: 100%"></div>-->
wangqinghua's avatar
wangqinghua committed
                <div echarts [options]="rightTwoChart" style="height: 250px;width: 100%"></div>
            </div>
        </nz-col>
wangqinghua's avatar
wangqinghua committed
    </nz-row>
    <nz-row [nzGutter]="10">
wangqinghua's avatar
wangqinghua committed
        <nz-col class="padding-10" nzSpan="12">
            <div class="host-item-title">接口流量排行</div>
            <div class="host-item-table" style="height: 500px">
                <nz-row class="text-center table-title">
wangqinghua's avatar
wangqinghua committed
                    <nz-col nzSpan="8">资源名称</nz-col>
                    <nz-col nzSpan="8">发送流量</nz-col>
                    <nz-col nzSpan="8">接受流量</nz-col>
wangqinghua's avatar
wangqinghua committed
                </nz-row>
wangqinghua's avatar
wangqinghua committed
                <ng-container *ngFor="let flow of flowListNum;">
wangqinghua's avatar
wangqinghua committed
                    <nz-row class="table-content">
wangqinghua's avatar
wangqinghua committed
                        <nz-col nzSpan="8">{{flow.name}}</nz-col>
                        <nz-col nzSpan="8">{{flow.send}}</nz-col>
                        <nz-col nzSpan="8">{{flow.receive}}</nz-col>
wangqinghua's avatar
wangqinghua committed
                    </nz-row>
                </ng-container>
            </div>
        </nz-col>
        <nz-col class="padding-10" nzSpan="12">
            <div class="host-item-title">接口指标排行</div>
            <div class="host-item-table" style="height: 500px">
                <nz-row class="text-center table-title">
wangqinghua's avatar
wangqinghua committed
                    <nz-col nzSpan="8">资源名称</nz-col>
wangqinghua's avatar
wangqinghua committed
                    <nz-col nzSpan="16">发送利用率</nz-col>
wangqinghua's avatar
wangqinghua committed
                </nz-row>
wangqinghua's avatar
wangqinghua committed
                <ng-container *ngFor="let flow of flowListPre">
wangqinghua's avatar
wangqinghua committed
                    <nz-row class="table-content">
wangqinghua's avatar
wangqinghua committed
                        <nz-col nzSpan="8">{{flow.name}}</nz-col>
wangqinghua's avatar
wangqinghua committed
                        <nz-col nzSpan="16">
                            <div class="width-host">
                                <div class="space" [style.width]="flow.useRate *100 + '%'"></div>
                            </div>
                        </nz-col>
wangqinghua's avatar
wangqinghua committed
                    </nz-row>
                </ng-container>
            </div>
        </nz-col>
wangqinghua's avatar
wangqinghua committed
    </nz-row>
    <nz-row [nzGutter]="10">
wangqinghua's avatar
wangqinghua committed
        <nz-col class="padding-10" nzSpan="24">
wangqinghua's avatar
wangqinghua committed
            <div class="host-item-title">网络拓扑图</div>
wangqinghua's avatar
wangqinghua committed
            <div class="time-group" style="top: 18px;">
                <nz-select style="width: 200px;" nzPlaceHolder="选择拓扑图" [(ngModel)]="topoId"
                           (ngModelChange)="getDetail($event)">
wangqinghua's avatar
wangqinghua committed
                    <ng-container *ngFor="let item of dataSet">
                        <nz-option [nzLabel]="item.name" [nzValue]="item.id"></nz-option>
                    </ng-container>
                </nz-select>
            </div>
            <div class="host-item-content">
wangqinghua's avatar
wangqinghua committed
                <smart-topology-view #smartTopologyView></smart-topology-view>
wangqinghua's avatar
wangqinghua committed
            </div>
        </nz-col>
wangqinghua's avatar
wangqinghua committed
    </nz-row>
wangqinghua's avatar
wangqinghua committed
</div>