uptime-kuma/src/layouts/Layout.vue

218 lines
5.7 KiB
Vue
Raw Normal View History

2021-06-25 09:55:49 -04:00
<template>
2021-08-10 03:02:46 -04:00
<div :class="classes">
<div v-if="! $root.socket.connected && ! $root.socket.firstConnect" class="lost-connection">
<div class="container-fluid">
{{ $root.connectionErrorMsg }}
</div>
2021-06-25 09:55:49 -04:00
</div>
<!-- Desktop header -->
<header v-if="! $root.isMobile" class="d-flex flex-wrap justify-content-center py-3 mb-3 border-bottom">
<router-link to="/dashboard" class="d-flex align-items-center mb-3 mb-md-0 me-md-auto text-dark text-decoration-none">
<object class="bi me-2 ms-4" width="40" height="40" data="/icon.svg" alt="Logo" />
<span class="fs-4 title">Uptime Kuma</span>
</router-link>
2021-08-21 07:50:22 -04:00
<a v-if="hasNewVersion" target="_blank" href="https://github.com/louislam/uptime-kuma/releases" class="btn btn-info me-3">
2021-08-24 04:44:58 -04:00
<font-awesome-icon icon="arrow-alt-circle-up" /> {{ $t("New Update") }}
2021-08-21 07:50:22 -04:00
</a>
<ul class="nav nav-pills">
<li class="nav-item">
<router-link to="/dashboard" class="nav-link">
2021-08-24 04:44:58 -04:00
<font-awesome-icon icon="tachometer-alt" /> {{ $t("Dashboard") }}
</router-link>
</li>
<li class="nav-item">
<router-link to="/settings" class="nav-link">
2021-08-24 04:44:58 -04:00
<font-awesome-icon icon="cog" /> {{ $t("Settings") }}
</router-link>
</li>
</ul>
</header>
<!-- Mobile header -->
<header v-else class="d-flex flex-wrap justify-content-center pt-2 pb-2 mb-3">
<router-link to="/dashboard" class="d-flex align-items-center text-dark text-decoration-none">
<object class="bi" width="40" height="40" data="/icon.svg" />
<span class="fs-4 title ms-2">Uptime Kuma</span>
</router-link>
</header>
<main>
<!-- Add :key to disable vue router re-use the same component -->
<router-view v-if="$root.loggedIn" :key="$route.fullPath" />
<Login v-if="! $root.loggedIn && $root.allowLoginDialog" />
</main>
<footer>
<div class="container-fluid">
Uptime Kuma -
{{ $t("Version") }}: {{ $root.info.version }} -
<a href="https://github.com/louislam/uptime-kuma/releases" target="_blank" rel="noopener">{{ $t("Check Update On GitHub") }}</a>
</div>
</footer>
<!-- Mobile Only -->
<div v-if="$root.isMobile" style="width: 100%;height: 60px;" />
<nav v-if="$root.isMobile" class="bottom-nav">
2021-08-19 06:12:52 -04:00
<router-link to="/dashboard" class="nav-link">
<div><font-awesome-icon icon="tachometer-alt" /></div>
2021-08-24 04:44:58 -04:00
{{ $t("Dashboard") }}
</router-link>
2021-08-19 06:12:52 -04:00
<router-link to="/list" class="nav-link">
<div><font-awesome-icon icon="list" /></div>
{{ $t("List") }}
2021-08-19 06:12:52 -04:00
</router-link>
2021-08-19 06:12:52 -04:00
<router-link to="/add" class="nav-link">
<div><font-awesome-icon icon="plus" /></div>
{{ $t("Add") }}
</router-link>
2021-08-19 06:12:52 -04:00
<router-link to="/settings" class="nav-link">
<div><font-awesome-icon icon="cog" /></div>
2021-08-24 04:44:58 -04:00
{{ $t("Settings") }}
</router-link>
</nav>
</div>
2021-06-25 09:55:49 -04:00
</template>
<script>
import Login from "../components/Login.vue";
2021-08-21 07:50:22 -04:00
import compareVersions from "compare-versions";
2021-06-25 09:55:49 -04:00
export default {
2021-08-10 03:02:46 -04:00
2021-06-25 09:55:49 -04:00
components: {
2021-07-27 13:47:13 -04:00
Login,
2021-07-11 03:23:28 -04:00
},
2021-08-10 03:02:46 -04:00
2021-07-11 03:23:28 -04:00
data() {
2021-07-27 13:47:13 -04:00
return {}
2021-06-25 09:55:49 -04:00
},
2021-08-10 03:02:46 -04:00
computed: {
// Theme or Mobile
classes() {
const classes = {};
classes[this.$root.theme] = true;
classes["mobile"] = this.$root.isMobile;
return classes;
2021-08-21 07:50:22 -04:00
},
hasNewVersion() {
if (this.$root.info.latestVersion && this.$root.info.version) {
return compareVersions(this.$root.info.latestVersion, this.$root.info.version) >= 1;
} else {
return false;
}
},
2021-08-10 03:02:46 -04:00
},
2021-06-25 09:55:49 -04:00
watch: {
2021-08-19 06:12:52 -04:00
$route(to, from) {
2021-06-25 09:55:49 -04:00
this.init();
2021-07-27 13:47:13 -04:00
},
},
2021-08-10 03:02:46 -04:00
2021-07-27 13:47:13 -04:00
mounted() {
this.init();
2021-06-25 09:55:49 -04:00
},
2021-08-10 03:02:46 -04:00
2021-06-25 09:55:49 -04:00
methods: {
init() {
if (this.$route.name === "root") {
this.$router.push("/dashboard")
}
2021-07-11 03:23:28 -04:00
},
2021-07-27 13:47:13 -04:00
},
2021-08-10 03:02:46 -04:00
2021-06-25 09:55:49 -04:00
}
</script>
<style lang="scss" scoped>
2021-07-11 03:23:28 -04:00
@import "../assets/vars.scss";
2021-06-25 09:55:49 -04:00
2021-07-11 03:23:28 -04:00
.bottom-nav {
z-index: 1000;
position: fixed;
bottom: 0;
height: 60px;
width: 100%;
left: 0;
2021-07-13 00:16:11 -04:00
background-color: #fff;
2021-07-11 03:23:28 -04:00
box-shadow: 0 15px 47px 0 rgba(0, 0, 0, 0.05), 0 5px 14px 0 rgba(0, 0, 0, 0.05);
text-align: center;
white-space: nowrap;
2021-07-27 04:52:44 -04:00
padding: 0 10px;
2021-06-25 09:55:49 -04:00
2021-07-11 03:23:28 -04:00
a {
text-align: center;
width: 25%;
display: inline-block;
height: 100%;
padding: 8px 10px 0;
font-size: 13px;
color: #c1c1c1;
overflow: hidden;
text-decoration: none;
2021-06-30 09:04:58 -04:00
2021-07-11 03:23:28 -04:00
&.router-link-exact-active {
color: $primary;
font-weight: bold;
}
div {
font-size: 20px;
}
2021-06-30 09:04:58 -04:00
}
2021-07-11 03:23:28 -04:00
}
2021-08-08 13:58:56 -04:00
main {
min-height: calc(100vh - 160px)
}
2021-07-11 03:23:28 -04:00
.title {
font-weight: bold;
}
.nav {
margin-right: 25px;
}
.lost-connection {
padding: 5px;
background-color: crimson;
color: white;
}
2021-07-13 06:08:12 -04:00
footer {
color: #AAA;
font-size: 13px;
2021-07-27 04:52:44 -04:00
margin-top: 10px;
padding-bottom: 30px;
2021-07-13 06:08:12 -04:00
margin-left: 10px;
2021-07-17 04:12:05 -04:00
text-align: center;
2021-07-11 03:23:28 -04:00
}
2021-07-13 06:08:12 -04:00
.dark {
header {
background-color: #161B22;
border-bottom-color: #161B22 !important;
span {
color: #F0F6FC;
}
}
.bottom-nav {
background-color: $dark-bg;
}
}
2021-06-25 09:55:49 -04:00
</style>