<template> <div class="shadow-box monitor-list mb-3" :class="{ scrollbar: scrollbar }"> <div v-if="Object.keys($root.monitorList).length === 0" class="text-center mt-3"> {{ $t("No Monitors, please") }} <router-link to="/add">{{ $t("add one") }}</router-link> </div> <router-link v-for="(item, index) in sortedMonitorList" :key="index" :to="monitorURL(item.id)" class="item" :class="{ 'disabled': ! item.active }"> <div class="row"> <div class="col-6 col-md-8 small-padding" :class="{ 'monitorItem': $root.userHeartbeatBar == 'bottom' || $root.userHeartbeatBar == 'none' }"> <div class="info"> <Uptime :monitor="item" type="24" :pill="true" /> {{ item.name }} </div> </div> <div v-show="$root.userHeartbeatBar == 'normal'" :key="$root.userHeartbeatBar" class="col-6 col-md-4"> <HeartbeatBar size="small" :monitor-id="item.id" /> </div> </div> <div v-if="$root.userHeartbeatBar == 'bottom'" class="row"> <div class="col-12"> <HeartbeatBar size="small" :monitor-id="item.id" /> </div> </div> </router-link> </div> </template> <script> import HeartbeatBar from "../components/HeartbeatBar.vue"; import Uptime from "../components/Uptime.vue"; export default { components: { Uptime, HeartbeatBar, }, props: { scrollbar: { type: Boolean, }, }, computed: { sortedMonitorList() { let result = Object.values(this.$root.monitorList); result.sort((m1, m2) => { if (m1.active !== m2.active) { if (m1.active === 0) { return 1; } if (m2.active === 0) { return -1; } } if (m1.weight !== m2.weight) { if (m1.weight > m2.weight) { return -1; } if (m1.weight < m2.weight) { return 1; } } return m1.name.localeCompare(m2.name); }) return result; }, }, methods: { monitorURL(id) { return "/dashboard/" + id; }, }, } </script> <style lang="scss" scoped> @import "../assets/vars.scss"; .small-padding { padding-left: 5px !important; padding-right: 5px !important; } .monitorItem { width: 100%; } </style>