2018-12-09 13:21:20 +00:00
|
|
|
<template>
|
|
|
|
<div id="app">
|
|
|
|
<nav class="navbar is-light has-shadow" role="navigation" aria-label="main navigation">
|
|
|
|
<div class="container">
|
|
|
|
<div class="navbar-brand">
|
|
|
|
<a class="navbar-item" href="/">
|
|
|
|
<h1>Agola</h1>
|
|
|
|
</a>
|
|
|
|
|
|
|
|
<a
|
|
|
|
role="button"
|
|
|
|
class="navbar-burger burger"
|
|
|
|
aria-label="menu"
|
|
|
|
aria-expanded="false"
|
|
|
|
data-target="navbarBasicExample"
|
|
|
|
>
|
|
|
|
<span aria-hidden="true"></span>
|
|
|
|
<span aria-hidden="true"></span>
|
|
|
|
<span aria-hidden="true"></span>
|
|
|
|
</a>
|
|
|
|
</div>
|
|
|
|
<div class="navbar-menu">
|
|
|
|
<div class="navbar-start"></div>
|
|
|
|
<div class="navbar-end">
|
2019-05-13 21:44:02 +00:00
|
|
|
<div
|
|
|
|
v-if="user"
|
|
|
|
class="navbar-item has-dropdown"
|
|
|
|
v-bind:class="{ 'is-active': createDropdownActive }"
|
|
|
|
>
|
|
|
|
<a class="navbar-link" @click="toggleCreateDropdown()">
|
|
|
|
<i class="mdi mdi-plus-box mdi-24px"/>
|
|
|
|
</a>
|
|
|
|
<div class="navbar-dropdown">
|
|
|
|
<router-link class="navbar-item" to="/neworganization">New Organization</router-link>
|
|
|
|
</div>
|
|
|
|
</div>
|
2019-05-13 21:27:53 +00:00
|
|
|
<div
|
|
|
|
v-if="user"
|
|
|
|
class="navbar-item has-dropdown"
|
|
|
|
v-bind:class="{ 'is-active': userDropdownActive }"
|
|
|
|
>
|
|
|
|
<a class="navbar-link" @click="toggleUserDropdown()">{{user.username}}</a>
|
2018-12-09 13:21:20 +00:00
|
|
|
<div class="navbar-dropdown">
|
|
|
|
<div class="navbar-item">
|
|
|
|
Logged as
|
|
|
|
<b>{{user.username}}</b>
|
|
|
|
</div>
|
|
|
|
<hr class="navbar-divider">
|
|
|
|
<router-link class="navbar-item" to="/logout">
|
|
|
|
<i class="mdi mdi-logout"></i>Logout
|
|
|
|
</router-link>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
<div v-else class="navbar-item">
|
2019-03-29 17:08:54 +00:00
|
|
|
<router-link class="button" to="/register">Sign up</router-link>
|
2018-12-09 13:21:20 +00:00
|
|
|
<router-link class="button" to="/login">Login</router-link>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</nav>
|
2019-05-13 14:29:47 +00:00
|
|
|
|
|
|
|
<div v-if="error" class="container">
|
|
|
|
<div class="message is-danger global-error-message">
|
|
|
|
<div class="message-body">
|
|
|
|
<nav class="level">
|
|
|
|
<div class="level-left">
|
|
|
|
<div class="level-item">
|
|
|
|
<p>Failed to fetch data: {{ error }}</p>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
<div class="level-right">
|
|
|
|
<div class="level-item">
|
|
|
|
<button class="button is-danger" @click="reload()">Retry</button>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</nav>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
<div v-else class="main-container container">
|
|
|
|
<router-view v-if="routerActive"></router-view>
|
2018-12-09 13:21:20 +00:00
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</template>
|
|
|
|
|
|
|
|
|
|
|
|
<script>
|
|
|
|
import { mapGetters } from "vuex";
|
|
|
|
|
|
|
|
export default {
|
|
|
|
name: "App",
|
|
|
|
components: {},
|
|
|
|
computed: {
|
2019-05-13 14:29:47 +00:00
|
|
|
...mapGetters(["error", "user"])
|
|
|
|
},
|
|
|
|
data() {
|
|
|
|
return {
|
2019-05-13 21:27:53 +00:00
|
|
|
routerActive: true,
|
2019-05-13 21:44:02 +00:00
|
|
|
userDropdownActive: false,
|
|
|
|
createDropdownActive: false
|
2019-05-13 14:29:47 +00:00
|
|
|
};
|
2018-12-09 13:21:20 +00:00
|
|
|
},
|
|
|
|
watch: {
|
|
|
|
user: function(user) {
|
|
|
|
if (user) {
|
|
|
|
this.$router.push({
|
|
|
|
name: "user",
|
|
|
|
params: { username: this.user.username }
|
|
|
|
});
|
|
|
|
}
|
2019-05-13 21:27:53 +00:00
|
|
|
},
|
|
|
|
$route: function() {
|
|
|
|
this.userDropdownActive = false;
|
2019-05-13 21:44:02 +00:00
|
|
|
this.createDropdownActive = false;
|
2018-12-09 13:21:20 +00:00
|
|
|
}
|
2019-05-13 14:29:47 +00:00
|
|
|
},
|
|
|
|
// method to reload current view from https://github.com/vuejs/vue-router/issues/296#issuecomment-356530037
|
|
|
|
methods: {
|
|
|
|
reload() {
|
|
|
|
this.$store.dispatch("setError", null);
|
|
|
|
this.routerActive = false;
|
|
|
|
this.$nextTick(() => (this.routerActive = true));
|
2019-05-13 21:27:53 +00:00
|
|
|
},
|
|
|
|
toggleUserDropdown() {
|
|
|
|
this.userDropdownActive = !this.userDropdownActive;
|
2019-05-13 21:44:02 +00:00
|
|
|
},
|
|
|
|
toggleCreateDropdown() {
|
|
|
|
this.createDropdownActive = !this.createDropdownActive;
|
2019-05-13 14:29:47 +00:00
|
|
|
}
|
2018-12-09 13:21:20 +00:00
|
|
|
}
|
|
|
|
};
|
|
|
|
</script>
|
|
|
|
|
|
|
|
<style lang="scss">
|
|
|
|
@import "@/css/main.scss";
|
|
|
|
|
|
|
|
.main-container {
|
|
|
|
margin-top: 2rem;
|
|
|
|
}
|
2019-05-13 14:29:47 +00:00
|
|
|
|
|
|
|
.global-error-message {
|
|
|
|
margin-top: 10rem;
|
|
|
|
}
|
2018-12-09 13:21:20 +00:00
|
|
|
</style>
|