mirror of
https://github.com/louislam/uptime-kuma.git
synced 2024-11-28 01:04:05 +00:00
Add $root.username
This commit is contained in:
parent
17d4003e5c
commit
cb55e23718
3 changed files with 16 additions and 18 deletions
|
@ -4,7 +4,7 @@
|
||||||
<!-- Change Password -->
|
<!-- Change Password -->
|
||||||
<template v-if="!settings.disableAuth">
|
<template v-if="!settings.disableAuth">
|
||||||
<p>
|
<p>
|
||||||
{{ $t("Current User") }}: <strong>{{ username }}</strong>
|
{{ $t("Current User") }}: <strong>{{ $root.username }}</strong>
|
||||||
<button v-if="! settings.disableAuth" id="logout-btn" class="btn btn-danger ms-4 me-2 mb-2" @click="$root.logout">{{ $t("Logout") }}</button>
|
<button v-if="! settings.disableAuth" id="logout-btn" class="btn btn-danger ms-4 me-2 mb-2" @click="$root.logout">{{ $t("Logout") }}</button>
|
||||||
</p>
|
</p>
|
||||||
|
|
||||||
|
@ -269,7 +269,6 @@ export default {
|
||||||
|
|
||||||
data() {
|
data() {
|
||||||
return {
|
return {
|
||||||
username: "",
|
|
||||||
invalidPassword: false,
|
invalidPassword: false,
|
||||||
password: {
|
password: {
|
||||||
currentPassword: "",
|
currentPassword: "",
|
||||||
|
@ -297,10 +296,6 @@ export default {
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
|
|
||||||
mounted() {
|
|
||||||
this.loadUsername();
|
|
||||||
},
|
|
||||||
|
|
||||||
methods: {
|
methods: {
|
||||||
savePassword() {
|
savePassword() {
|
||||||
if (this.password.newPassword !== this.password.repeatNewPassword) {
|
if (this.password.newPassword !== this.password.repeatNewPassword) {
|
||||||
|
@ -319,14 +314,6 @@ export default {
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
|
||||||
loadUsername() {
|
|
||||||
const jwtPayload = this.$root.getJWTPayload();
|
|
||||||
|
|
||||||
if (jwtPayload) {
|
|
||||||
this.username = jwtPayload.username;
|
|
||||||
}
|
|
||||||
},
|
|
||||||
|
|
||||||
disableAuth() {
|
disableAuth() {
|
||||||
this.settings.disableAuth = true;
|
this.settings.disableAuth = true;
|
||||||
|
|
||||||
|
|
|
@ -34,11 +34,11 @@
|
||||||
<li v-if="$root.loggedIn" class="nav-item">
|
<li v-if="$root.loggedIn" class="nav-item">
|
||||||
<div class="dropdown dropdown-profile-pic">
|
<div class="dropdown dropdown-profile-pic">
|
||||||
<div type="button" class="nav-link" data-bs-toggle="dropdown">
|
<div type="button" class="nav-link" data-bs-toggle="dropdown">
|
||||||
<div class="profile-pic">L</div>
|
<div class="profile-pic">{{ $root.usernameFirstChar }}</div>
|
||||||
<font-awesome-icon icon="angle-down" />
|
<font-awesome-icon icon="angle-down" />
|
||||||
</div>
|
</div>
|
||||||
<ul class="dropdown-menu">
|
<ul class="dropdown-menu">
|
||||||
<li><span class="dropdown-item-text">Signed in as <strong>louislamlouislam</strong></span></li>
|
<li><span class="dropdown-item-text">Signed in as <strong>{{ $root.username }}</strong></span></li>
|
||||||
<li><hr class="dropdown-divider"></li>
|
<li><hr class="dropdown-divider"></li>
|
||||||
<li>
|
<li>
|
||||||
<router-link to="/settings" class="dropdown-item" :class="{ active: $route.path.includes('settings') }">
|
<router-link to="/settings" class="dropdown-item" :class="{ active: $route.path.includes('settings') }">
|
||||||
|
|
|
@ -28,6 +28,7 @@ export default {
|
||||||
connectCount: 0,
|
connectCount: 0,
|
||||||
initedSocketIO: false,
|
initedSocketIO: false,
|
||||||
},
|
},
|
||||||
|
username: null,
|
||||||
remember: (localStorage.remember !== "0"),
|
remember: (localStorage.remember !== "0"),
|
||||||
allowLoginDialog: false, // Allowed to show login dialog, but "loggedIn" have to be true too. This exists because prevent the login dialog show 0.1s in first before the socket server auth-ed.
|
allowLoginDialog: false, // Allowed to show login dialog, but "loggedIn" have to be true too. This exists because prevent the login dialog show 0.1s in first before the socket server auth-ed.
|
||||||
loggedIn: false,
|
loggedIn: false,
|
||||||
|
@ -102,6 +103,7 @@ export default {
|
||||||
|
|
||||||
socket.on("autoLogin", (monitorID, data) => {
|
socket.on("autoLogin", (monitorID, data) => {
|
||||||
this.loggedIn = true;
|
this.loggedIn = true;
|
||||||
|
this.username = "No Auth";
|
||||||
this.storage().token = "autoLogin";
|
this.storage().token = "autoLogin";
|
||||||
this.allowLoginDialog = false;
|
this.allowLoginDialog = false;
|
||||||
});
|
});
|
||||||
|
@ -233,7 +235,6 @@ export default {
|
||||||
if (token !== "autoLogin") {
|
if (token !== "autoLogin") {
|
||||||
this.loginByToken(token);
|
this.loginByToken(token);
|
||||||
} else {
|
} else {
|
||||||
|
|
||||||
// Timeout if it is not actually auto login
|
// Timeout if it is not actually auto login
|
||||||
setTimeout(() => {
|
setTimeout(() => {
|
||||||
if (! this.loggedIn) {
|
if (! this.loggedIn) {
|
||||||
|
@ -241,7 +242,6 @@ export default {
|
||||||
this.$root.storage().removeItem("token");
|
this.$root.storage().removeItem("token");
|
||||||
}
|
}
|
||||||
}, 5000);
|
}, 5000);
|
||||||
|
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
this.allowLoginDialog = true;
|
this.allowLoginDialog = true;
|
||||||
|
@ -305,6 +305,7 @@ export default {
|
||||||
this.storage().token = res.token;
|
this.storage().token = res.token;
|
||||||
this.socket.token = res.token;
|
this.socket.token = res.token;
|
||||||
this.loggedIn = true;
|
this.loggedIn = true;
|
||||||
|
this.username = this.getJWTPayload()?.username;
|
||||||
|
|
||||||
// Trigger Chrome Save Password
|
// Trigger Chrome Save Password
|
||||||
history.pushState({}, "");
|
history.pushState({}, "");
|
||||||
|
@ -322,6 +323,7 @@ export default {
|
||||||
this.logout();
|
this.logout();
|
||||||
} else {
|
} else {
|
||||||
this.loggedIn = true;
|
this.loggedIn = true;
|
||||||
|
this.username = this.getJWTPayload()?.username;
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
},
|
},
|
||||||
|
@ -331,6 +333,7 @@ export default {
|
||||||
this.storage().removeItem("token");
|
this.storage().removeItem("token");
|
||||||
this.socket.token = null;
|
this.socket.token = null;
|
||||||
this.loggedIn = false;
|
this.loggedIn = false;
|
||||||
|
this.username = null;
|
||||||
this.clearData();
|
this.clearData();
|
||||||
},
|
},
|
||||||
|
|
||||||
|
@ -398,6 +401,14 @@ export default {
|
||||||
|
|
||||||
computed: {
|
computed: {
|
||||||
|
|
||||||
|
usernameFirstChar() {
|
||||||
|
if (typeof this.username == "string" && this.username.length >= 1) {
|
||||||
|
return this.username.charAt(0).toUpperCase();
|
||||||
|
} else {
|
||||||
|
return "🐻";
|
||||||
|
}
|
||||||
|
},
|
||||||
|
|
||||||
lastHeartbeatList() {
|
lastHeartbeatList() {
|
||||||
let result = {};
|
let result = {};
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue