jormungandr-bite/src/client/app/admin/views/cpu-memory.vue

170 lines
2.8 KiB
Vue
Raw Normal View History

2018-08-17 13:52:06 -06:00
<template>
<div class="zyknedwtlthezamcjlolyusmipqmjgxz">
2018-11-02 22:30:57 -06:00
<div>
<header>
<span>CPU <span>{{ cpuP }}%</span></span>
<span v-if="meta">{{ meta.cpu.model }}</span>
</header>
<div ref="cpu"></div>
</div>
<div>
<header>
<span>MEM <span>{{ memP }}%</span></span>
</header>
<div ref="mem"></div>
</div>
2018-08-17 13:52:06 -06:00
</div>
</template>
<script lang="ts">
import Vue from 'vue';
2018-11-02 11:06:34 -06:00
import * as ApexCharts from 'apexcharts';
2018-08-17 13:52:06 -06:00
export default Vue.extend({
props: ['connection'],
2018-11-02 11:06:34 -06:00
2018-08-17 13:52:06 -06:00
data() {
return {
stats: [],
2018-11-02 11:06:34 -06:00
cpuChart: null,
memChart: null,
2018-08-17 13:52:06 -06:00
cpuP: '',
2018-11-02 22:30:57 -06:00
memP: '',
meta: null
2018-08-17 13:52:06 -06:00
};
},
2018-11-02 11:06:34 -06:00
watch: {
stats(stats) {
this.cpuChart.updateSeries([{
data: stats.map((x, i) => ({ x: i, y: x.cpu_usage }))
}]);
this.memChart.updateSeries([{
data: stats.map((x, i) => ({ x: i, y: (x.mem.used / x.mem.total) }))
}]);
}
},
2018-08-17 13:52:06 -06:00
mounted() {
2018-11-02 22:30:57 -06:00
(this as any).os.getMeta().then(meta => {
this.meta = meta;
});
2018-08-17 13:52:06 -06:00
this.connection.on('stats', this.onStats);
this.connection.on('statsLog', this.onStatsLog);
2018-10-09 00:08:31 -06:00
this.connection.send('requestLog', {
2018-10-13 04:25:59 -06:00
id: Math.random().toString().substr(2, 8),
length: 200
2018-08-17 13:52:06 -06:00
});
2018-11-02 11:06:34 -06:00
const chartOpts = {
chart: {
type: 'area',
2018-11-02 12:08:41 -06:00
height: 200,
2018-11-02 11:06:34 -06:00
animations: {
dynamicAnimation: {
enabled: false
}
},
toolbar: {
show: false
2018-11-02 22:30:57 -06:00
},
zoom: {
enabled: false
2018-11-02 11:06:34 -06:00
}
},
dataLabels: {
enabled: false
},
grid: {
clipMarkers: false,
},
stroke: {
curve: 'straight',
width: 2
},
2018-11-02 22:30:57 -06:00
tooltip: {
enabled: false
},
2018-11-02 11:06:34 -06:00
series: [{
data: []
}],
xaxis: {
type: 'numeric',
labels: {
show: false
2018-11-02 22:30:57 -06:00
},
tooltip: {
enabled: false
2018-11-02 11:06:34 -06:00
}
},
yaxis: {
show: false,
min: 0,
max: 1
}
};
2018-11-02 22:30:57 -06:00
this.cpuChart = new ApexCharts(this.$refs.cpu, chartOpts);
this.memChart = new ApexCharts(this.$refs.mem, chartOpts);
2018-11-02 11:06:34 -06:00
this.cpuChart.render();
this.memChart.render();
2018-08-17 13:52:06 -06:00
},
2018-11-02 11:06:34 -06:00
2018-08-17 13:52:06 -06:00
beforeDestroy() {
this.connection.off('stats', this.onStats);
this.connection.off('statsLog', this.onStatsLog);
},
2018-11-02 11:06:34 -06:00
2018-08-17 13:52:06 -06:00
methods: {
onStats(stats) {
this.stats.push(stats);
if (this.stats.length > 200) this.stats.shift();
2018-08-17 13:52:06 -06:00
this.cpuP = (stats.cpu_usage * 100).toFixed(0);
this.memP = (stats.mem.used / stats.mem.total * 100).toFixed(0);
},
2018-11-02 11:06:34 -06:00
2018-08-17 13:52:06 -06:00
onStatsLog(statsLog) {
statsLog.reverse().forEach(stats => this.onStats(stats));
2018-08-17 13:52:06 -06:00
}
}
});
</script>
<style lang="stylus" scoped>
2018-09-28 04:59:19 -06:00
.zyknedwtlthezamcjlolyusmipqmjgxz
2018-11-02 11:06:34 -06:00
display flex
> div
2018-08-17 13:52:06 -06:00
display block
2018-11-02 11:06:34 -06:00
flex 1
2018-11-02 22:30:57 -06:00
padding 20px 16px 0 16px
2018-11-02 11:06:34 -06:00
box-shadow 0 2px 4px rgba(0, 0, 0, 0.1)
background var(--face)
border-radius 8px
2018-08-17 13:52:06 -06:00
&:first-child
2018-11-02 11:06:34 -06:00
margin-right 16px
2018-08-17 13:52:06 -06:00
2018-11-02 22:30:57 -06:00
> header
display flex
padding 0 4px
margin-bottom -8px
color #555
font-size 14px
> span
&:last-child
margin-left auto
opacity 0.7
> span
opacity 0.7
> div
margin-bottom -8px
2018-08-17 13:52:06 -06:00
</style>