agola-web/src/App.vue

178 lines
5.7 KiB
Vue
Raw Normal View History

2018-12-09 13:21:20 +00:00
<template>
<div id="app">
<nav class="bg-gray-800 p-3 text-white">
<div class="container flex items-center justify-between flex-wrap bg-gray-800">
<div class="mr-6">
<router-link
class="font-semibold flex items-center flex-shrink-0 text-xl tracking-tight"
to="/"
2018-12-09 13:21:20 +00:00
>
<img class="w-10 mr-2" src="/img/agola-logo-circle.svg">
Agola
</router-link>
2018-12-09 13:21:20 +00:00
</div>
<div class="block lg:hidden">
<button
class="flex items-center px-3 py-2 border rounded text-blue-200 border-blue-400 hover:text-white hover:border-white"
@click="navActive = !navActive"
>
<svg
class="fill-current h-3 w-3"
viewBox="0 0 20 20"
xmlns="http://www.w3.org/2000/svg"
>
<title>Menu</title>
<path d="M0 3h20v2H0V3zm0 6h20v2H0V9zm0 6h20v2H0v-2z"></path>
</svg>
</button>
</div>
<div
class="w-full block flex-grow lg:flex lg:items-center lg:w-auto"
:class="{'hidden' : !navActive}"
>
<div class="text-sm lg:flex-grow"></div>
<div v-if="user" class="relative mr-3">
<button
v-click-outside="() => createDropdownActive = false"
@click="createDropdownActive = !createDropdownActive"
class="relative flex items-center focus:outline-none"
>
<i class="mdi mdi-plus-box mdi-24px"/>
<i class="mdi mdi-chevron-down"></i>
</button>
<div
v-if="createDropdownActive"
class="z-10 origin-top-right absolute right-0 mt-2 w-64 bg-white rounded-lg border shadow-md py-2 text-dark"
>
<ul>
<li>
<router-link
class="block px-4 py-2 hover:bg-blue-500 hover:text-white"
to="/neworganization"
>New Organization</router-link>
</li>
</ul>
</div>
</div>
<div v-if="user" class="relative">
<div class="flex">
<button
v-click-outside="() => userDropdownActive = false"
@click="userDropdownActive = !userDropdownActive"
class="relative flex items-center focus:outline-none"
>
{{user.username}}
<i class="mdi mdi-chevron-down"></i>
</button>
</div>
<div
v-if="userDropdownActive"
class="z-10 origin-top-right absolute right-0 mt-2 w-64 bg-white rounded-lg border shadow-md py-2 text-dark"
>
<ul>
<li class="block px-4 py-2 border-b">
2018-12-09 13:21:20 +00:00
Logged as&nbsp;
<b>{{user.username}}</b>
</li>
<li>
<hr class="navbar-divider">
</li>
<li>
<router-link
class="block px-4 py-2 hover:bg-blue-500 hover:text-white"
:to="ownerSettingsLink('user', user.username)"
>
<i class="mr-1 mdi mdi-settings"/>
<span>User Settings</span>
</router-link>
</li>
<li>
<router-link
class="block px-4 py-2 hover:bg-blue-500 hover:text-white"
to="/logout"
>
<i class="mdi mdi-logout"></i>Logout
</router-link>
</li>
</ul>
2018-12-09 13:21:20 +00:00
</div>
</div>
<div v-else class="navbar-item">
<router-link class="btn btn-blue" to="/register">Sign up</router-link>
<router-link class="ml-2 btn btn-blue" to="/login">Login</router-link>
</div>
2018-12-09 13:21:20 +00:00
</div>
</div>
</nav>
<div v-if="error" class="container h-screen" role="alert">
<div v-if="error" class="h-full flex justify-center items-center" role="alert">
<div v-if="error" class="w-full" role="alert">
<div class="bg-red-500 text-white font-bold rounded-t px-4 py-2">Error</div>
<div class="border border-t-0 border-red-400 rounded-b bg-red-100 px-4 py-3 text-red-700">
<p class="mb-8">Failed to fetch data: {{ error }}</p>
<button class="btn btn-red" @click="reload()">Retry</button>
</div>
</div>
</div>
</div>
<div v-else class="container mt-6">
<router-view v-if="routerActive"></router-view>
2018-12-09 13:21:20 +00:00
</div>
</div>
</template>
<script>
import vClickOutside from "v-click-outside";
2018-12-09 13:21:20 +00:00
import { mapGetters } from "vuex";
import { ownerSettingsLink } from "@/util/link.js";
2018-12-09 13:21:20 +00:00
export default {
name: "App",
directives: {
clickOutside: vClickOutside.directive
},
2018-12-09 13:21:20 +00:00
components: {},
computed: {
...mapGetters(["error", "user"])
},
data() {
return {
routerActive: true,
navActive: false,
userDropdownActive: false,
createDropdownActive: false
};
2018-12-09 13:21:20 +00:00
},
watch: {
user: function(user) {
if (user) {
this.$router.push({
name: "user",
params: { username: this.user.username }
});
}
},
$route: function() {
this.userDropdownActive = false;
this.createDropdownActive = false;
2018-12-09 13:21:20 +00:00
}
},
// method to reload current view from https://github.com/vuejs/vue-router/issues/296#issuecomment-356530037
methods: {
ownerSettingsLink: ownerSettingsLink,
reload() {
this.$store.dispatch("setError", null);
this.routerActive = false;
this.$nextTick(() => (this.routerActive = true));
}
2018-12-09 13:21:20 +00:00
}
};
</script>
<style lang="scss">
</style>