sharkey/packages/client/src/widgets/server-metric/index.vue

84 lines
1.9 KiB
Vue
Raw Normal View History

2021-01-03 22:38:32 +09:00
<template>
<MkContainer :show-header="props.showHeader" :naked="props.transparent">
<template #header><i class="fas fa-server"></i>{{ $ts._widgets.serverMetric }}</template>
2021-11-19 19:36:12 +09:00
<template #func><button class="_button" @click="toggleView()"><i class="fas fa-sort"></i></button></template>
2021-01-03 22:38:32 +09:00
2021-11-19 19:36:12 +09:00
<div v-if="meta" class="mkw-serverMetric">
2021-01-03 22:38:32 +09:00
<XCpuMemory v-if="props.view === 0" :connection="connection" :meta="meta"/>
<XNet v-if="props.view === 1" :connection="connection" :meta="meta"/>
<XCpu v-if="props.view === 2" :connection="connection" :meta="meta"/>
<XMemory v-if="props.view === 3" :connection="connection" :meta="meta"/>
<XDisk v-if="props.view === 4" :connection="connection" :meta="meta"/>
</div>
</MkContainer>
</template>
<script lang="ts">
import { defineComponent, markRaw } from 'vue';
2021-01-03 22:38:32 +09:00
import define from '../define';
2021-11-12 02:02:25 +09:00
import MkContainer from '@/components/ui/container.vue';
2021-01-03 22:38:32 +09:00
import XCpuMemory from './cpu-mem.vue';
import XNet from './net.vue';
import XCpu from './cpu.vue';
import XMemory from './mem.vue';
import XDisk from './disk.vue';
2021-11-12 02:02:25 +09:00
import * as os from '@/os';
import { stream } from '@/stream';
2021-01-03 22:38:32 +09:00
const widget = define({
name: 'serverMetric',
props: () => ({
showHeader: {
type: 'boolean',
default: true,
},
transparent: {
type: 'boolean',
default: false,
},
view: {
type: 'number',
default: 0,
hidden: true,
},
})
});
export default defineComponent({
components: {
MkContainer,
XCpuMemory,
XNet,
XCpu,
XMemory,
XDisk,
},
2021-11-19 19:36:12 +09:00
extends: widget,
2021-01-03 22:38:32 +09:00
data() {
return {
meta: null,
connection: null,
};
},
created() {
os.api('server-info', {}).then(res => {
this.meta = res;
});
this.connection = markRaw(stream.useChannel('serverStats'));
2021-01-03 22:38:32 +09:00
},
unmounted() {
this.connection.dispose();
},
methods: {
toggleView() {
if (this.props.view == 4) {
this.props.view = 0;
} else {
this.props.view++;
}
this.save();
},
}
});
</script>