Mercurial > gemma
view client/src/views/Users.vue @ 375:112527683ee9
Backed out changeset 2c58906649be
author | Thomas Junk <thomas.junk@intevation.de> |
---|---|
date | Fri, 10 Aug 2018 11:21:58 +0200 |
parents | 7e7e978d1cac |
children | e42f42eb9353 |
line wrap: on
line source
<template> <div class="main d-flex"> <Sidebar v-bind:isOverlay="false"></Sidebar> <div class="d-flex flex-row content"> <div class="d-flex flex-column"> <div> <h1>User Management</h1> </div> <div class="userlist shadow"> <div class="card" style="width: 85rem;"> <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-bind:currentUser="currentUser"></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; } .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 { currentUser: null }; }, components: { Sidebar, Userdetail }, computed: { ...mapGetters("usermanagement", ["users"]) }, methods: { selectUser(name) { const user = this.$store.getters["usermanagement/getUserByName"](name); this.currentUser = 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>