Mercurial > gemma
view client/src/views/Users.vue @ 379:0a9aaf21f69f
feat: usermanagement
Togglable userdetails card
author | Thomas Junk <thomas.junk@intevation.de> |
---|---|
date | Fri, 10 Aug 2018 14:49:29 +0200 |
parents | e42f42eb9353 |
children | e7d5383bc358 |
line wrap: on
line source
<template> <div class="main d-flex"> <Sidebar v-bind:isOverlay="false"></Sidebar> <div class="d-flex content flex-column"> <div> <h1>User Management</h1> </div> <div class="d-flex flex-row"> <div class="userlist shadow"> <div class="card"> <div class="card-header text-white bg-info mb-3"> users </div> <div class="card-body"> <table class="table table-hover"> <thead> <tr> <th scope="col">Username</th> <th scope="col">Country</th> <th scope="col">Email</th> <th scope="col">Role</th> </tr> </thead> <tbody> <tr v-for="user in users" :key="user.user" @click="selectUser(user.user)"> <td>{{ user.user }}</td> <td>{{ user.country }}</td> <td>{{ user.email}}</td> <td>{{ user.role }}</td> </tr> </tbody> </table> </div> </div> </div> <Userdetail v-if="isUserDetailsVisible"></Userdetail> </div> </div> </div> </template> <style lang="scss"> @import "../assets/application.scss"; .main { height: 100vh; } .content { margin-top: $large-offset; margin-left: auto; margin-right: auto; } .userlist { margin-top: $large-offset; width: 50vw; margin-right: $large-offset; } .shadow { box-shadow: $basic-shadow-light !important; } .table th, td { border-top: 0px !important; } .table td { cursor: pointer; } </style> <script> import Sidebar from "../components/Sidebar"; import Userdetail from "../components/Userdetail"; import store from "../store"; import { mapGetters } from "vuex"; import app from "../main"; export default { name: "userview", data() { return {}; }, components: { Sidebar, Userdetail }, computed: { ...mapGetters("usermanagement", ["users", "isUserDetailsVisible"]) }, methods: { selectUser(name) { const user = this.$store.getters["usermanagement/getUserByName"](name); this.$store.commit("usermanagement/setCurrentUser", user); } }, beforeRouteEnter(to, from, next) { store .dispatch("usermanagement/loadUsers") .then(next) .catch(error => { const { status, data } = error.response; app.$toast.error({ title: "Backend Error", message: `${status}: ${data}` }); }); } }; </script>