mirror of
https://github.com/1Panel-dev/1Panel.git
synced 2025-01-19 16:29:17 +08:00
feat: 概览、监控等界面增加单位区分显示 (#1440)
This commit is contained in:
parent
dbeaaa49f3
commit
14f7435f82
@ -5,6 +5,7 @@
|
|||||||
import { onMounted, onUnmounted, nextTick, watch } from 'vue';
|
import { onMounted, onUnmounted, nextTick, watch } from 'vue';
|
||||||
import * as echarts from 'echarts';
|
import * as echarts from 'echarts';
|
||||||
import { GlobalStore } from '@/store';
|
import { GlobalStore } from '@/store';
|
||||||
|
import { computeSizeFromKBs, computeSizeFromMB } from '@/utils/util';
|
||||||
const globalStore = GlobalStore();
|
const globalStore = GlobalStore();
|
||||||
const props = defineProps({
|
const props = defineProps({
|
||||||
id: {
|
id: {
|
||||||
@ -99,8 +100,29 @@ function initChart() {
|
|||||||
trigger: 'axis',
|
trigger: 'axis',
|
||||||
formatter: function (datas: any) {
|
formatter: function (datas: any) {
|
||||||
let res = datas[0].name + '<br/>';
|
let res = datas[0].name + '<br/>';
|
||||||
|
switch (props.option.formatStr) {
|
||||||
|
case 'KB/s':
|
||||||
for (const item of datas) {
|
for (const item of datas) {
|
||||||
res += item.marker + ' ' + item.seriesName + ':' + item.data + props.option.formatStr + '<br/>';
|
res += item.marker + ' ' + item.seriesName + ':' + computeSizeFromKBs(item.data) + '<br/>';
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
case 'MB':
|
||||||
|
for (const item of datas) {
|
||||||
|
res += item.marker + ' ' + item.seriesName + ':' + computeSizeFromMB(item.data) + '<br/>';
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
for (const item of datas) {
|
||||||
|
res +=
|
||||||
|
item.marker +
|
||||||
|
' ' +
|
||||||
|
item.seriesName +
|
||||||
|
':' +
|
||||||
|
item.data +
|
||||||
|
props.option.formatStr +
|
||||||
|
'<br/>';
|
||||||
|
}
|
||||||
|
break;
|
||||||
}
|
}
|
||||||
return res;
|
return res;
|
||||||
},
|
},
|
||||||
|
@ -129,6 +129,21 @@ export function computeSize(size: number): string {
|
|||||||
return (size / Math.pow(num, 4)).toFixed(2) + ' TB';
|
return (size / Math.pow(num, 4)).toFixed(2) + ' TB';
|
||||||
}
|
}
|
||||||
|
|
||||||
|
export function computeSizeFromMB(size: number): string {
|
||||||
|
const num = 1024.0;
|
||||||
|
if (size < num) return size + ' MB';
|
||||||
|
if (size < Math.pow(num, 2)) return (size / num).toFixed(2) + ' GB';
|
||||||
|
return (size / Math.pow(num, 3)).toFixed(2) + ' TB';
|
||||||
|
}
|
||||||
|
|
||||||
|
export function computeSizeFromKBs(size: number): string {
|
||||||
|
const num = 1024.0;
|
||||||
|
if (size < num) return size + ' KB/s';
|
||||||
|
if (size < Math.pow(num, 2)) return (size / num).toFixed(2) + ' MB/s';
|
||||||
|
if (size < Math.pow(num, 3)) return (size / Math.pow(num, 2)).toFixed(2) + ' GB/s';
|
||||||
|
return (size / Math.pow(num, 3)).toFixed(2) + ' TB/s';
|
||||||
|
}
|
||||||
|
|
||||||
let icons = new Map([
|
let icons = new Map([
|
||||||
['.zip', 'p-file-zip'],
|
['.zip', 'p-file-zip'],
|
||||||
['.gz', 'p-file-zip'],
|
['.gz', 'p-file-zip'],
|
||||||
|
@ -144,7 +144,7 @@ import { ref, reactive, onMounted, onBeforeUnmount, computed } from 'vue';
|
|||||||
import * as echarts from 'echarts';
|
import * as echarts from 'echarts';
|
||||||
import { loadMonitor, getNetworkOptions } from '@/api/modules/monitor';
|
import { loadMonitor, getNetworkOptions } from '@/api/modules/monitor';
|
||||||
import { Monitor } from '@/api/interface/monitor';
|
import { Monitor } from '@/api/interface/monitor';
|
||||||
import { dateFormatWithoutYear } from '@/utils/util';
|
import { computeSizeFromKBs, dateFormatWithoutYear } from '@/utils/util';
|
||||||
import i18n from '@/lang';
|
import i18n from '@/lang';
|
||||||
import MonitorRouter from '@/views/host/monitor/index.vue';
|
import MonitorRouter from '@/views/host/monitor/index.vue';
|
||||||
import { GlobalStore } from '@/store';
|
import { GlobalStore } from '@/store';
|
||||||
@ -380,9 +380,15 @@ function initCharts(chartName: string, xDatas: any, yDatas: any, yTitle: string,
|
|||||||
trigger: 'axis',
|
trigger: 'axis',
|
||||||
formatter: function (datas: any) {
|
formatter: function (datas: any) {
|
||||||
let res = datas[0].name + '<br/>';
|
let res = datas[0].name + '<br/>';
|
||||||
|
if (chartName !== 'loadNetworkChart') {
|
||||||
for (const item of datas) {
|
for (const item of datas) {
|
||||||
res += item.marker + ' ' + item.seriesName + ':' + item.data + formatStr + '<br/>';
|
res += item.marker + ' ' + item.seriesName + ':' + item.data + formatStr + '<br/>';
|
||||||
}
|
}
|
||||||
|
} else {
|
||||||
|
for (const item of datas) {
|
||||||
|
res += item.marker + ' ' + item.seriesName + ':' + computeSizeFromKBs(item.data) + '<br/>';
|
||||||
|
}
|
||||||
|
}
|
||||||
return res;
|
return res;
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
@ -574,7 +580,7 @@ function initIOCharts(item: Monitor.MonitorData) {
|
|||||||
item.seriesName === i18n.global.t('monitor.read') ||
|
item.seriesName === i18n.global.t('monitor.read') ||
|
||||||
item.seriesName === i18n.global.t('monitor.write')
|
item.seriesName === i18n.global.t('monitor.write')
|
||||||
) {
|
) {
|
||||||
res += item.marker + ' ' + item.seriesName + ':' + item.data + ' KB/s' + '<br/>';
|
res += item.marker + ' ' + item.seriesName + ':' + computeSizeFromKBs(item.data) + '<br/>';
|
||||||
}
|
}
|
||||||
if (item.seriesName === i18n.global.t('monitor.readWriteCount')) {
|
if (item.seriesName === i18n.global.t('monitor.readWriteCount')) {
|
||||||
res +=
|
res +=
|
||||||
|
Loading…
x
Reference in New Issue
Block a user