annotate client/src/views/Users.vue @ 551:89bc8111563a

refac: Layout adjustments
author Thomas Junk <thomas.junk@intevation.de>
date Fri, 31 Aug 2018 14:12:00 +0200
parents b91791664554
children 09d8e5483851
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
278
9c1dfadb53aa feat: usermanagement - route established and secured
Thomas Junk <thomas.junk@intevation.de>
parents:
diff changeset
1 <template>
542
505656a9947f refac: layout refactored
Thomas Junk <thomas.junk@intevation.de>
parents: 428
diff changeset
2 <div class="main d-flex flex-column">
379
0a9aaf21f69f feat: usermanagement
Thomas Junk <thomas.junk@intevation.de>
parents: 376
diff changeset
3 <div class="d-flex content flex-column">
542
505656a9947f refac: layout refactored
Thomas Junk <thomas.junk@intevation.de>
parents: 428
diff changeset
4 <div class="d-flex flex-row">
505656a9947f refac: layout refactored
Thomas Junk <thomas.junk@intevation.de>
parents: 428
diff changeset
5 <div :class="userlistStyle">
505656a9947f refac: layout refactored
Thomas Junk <thomas.junk@intevation.de>
parents: 428
diff changeset
6 <div class="card">
505656a9947f refac: layout refactored
Thomas Junk <thomas.junk@intevation.de>
parents: 428
diff changeset
7 <div class="card-header shadow-sm text-white bg-info mb-3">
505656a9947f refac: layout refactored
Thomas Junk <thomas.junk@intevation.de>
parents: 428
diff changeset
8 Users
505656a9947f refac: layout refactored
Thomas Junk <thomas.junk@intevation.de>
parents: 428
diff changeset
9 </div>
505656a9947f refac: layout refactored
Thomas Junk <thomas.junk@intevation.de>
parents: 428
diff changeset
10 <div class="card-body">
505656a9947f refac: layout refactored
Thomas Junk <thomas.junk@intevation.de>
parents: 428
diff changeset
11 <table id="datatable" :class="tableStyle">
505656a9947f refac: layout refactored
Thomas Junk <thomas.junk@intevation.de>
parents: 428
diff changeset
12 <thead>
505656a9947f refac: layout refactored
Thomas Junk <thomas.junk@intevation.de>
parents: 428
diff changeset
13 <tr>
505656a9947f refac: layout refactored
Thomas Junk <thomas.junk@intevation.de>
parents: 428
diff changeset
14 <th scope="col" @click="sortBy('user')">
505656a9947f refac: layout refactored
Thomas Junk <thomas.junk@intevation.de>
parents: 428
diff changeset
15 <span>Username&nbsp;
505656a9947f refac: layout refactored
Thomas Junk <thomas.junk@intevation.de>
parents: 428
diff changeset
16 <i v-if="sortCriterion=='user'" class="fa fa-angle-down"></i>
505656a9947f refac: layout refactored
Thomas Junk <thomas.junk@intevation.de>
parents: 428
diff changeset
17 </span>
505656a9947f refac: layout refactored
Thomas Junk <thomas.junk@intevation.de>
parents: 428
diff changeset
18 </th>
505656a9947f refac: layout refactored
Thomas Junk <thomas.junk@intevation.de>
parents: 428
diff changeset
19 <th scope="col" @click="sortBy('country')">
505656a9947f refac: layout refactored
Thomas Junk <thomas.junk@intevation.de>
parents: 428
diff changeset
20 <span>Country&nbsp;
505656a9947f refac: layout refactored
Thomas Junk <thomas.junk@intevation.de>
parents: 428
diff changeset
21 <i v-if="sortCriterion=='country'" class="fa fa-angle-down"></i>
505656a9947f refac: layout refactored
Thomas Junk <thomas.junk@intevation.de>
parents: 428
diff changeset
22 </span>
505656a9947f refac: layout refactored
Thomas Junk <thomas.junk@intevation.de>
parents: 428
diff changeset
23 </th>
505656a9947f refac: layout refactored
Thomas Junk <thomas.junk@intevation.de>
parents: 428
diff changeset
24 <th scope="col" @click="sortBy('email')">
505656a9947f refac: layout refactored
Thomas Junk <thomas.junk@intevation.de>
parents: 428
diff changeset
25 <span>Email&nbsp;
505656a9947f refac: layout refactored
Thomas Junk <thomas.junk@intevation.de>
parents: 428
diff changeset
26 <i v-if="sortCriterion=='email'" class="fa fa-angle-down"></i>
505656a9947f refac: layout refactored
Thomas Junk <thomas.junk@intevation.de>
parents: 428
diff changeset
27 </span>
505656a9947f refac: layout refactored
Thomas Junk <thomas.junk@intevation.de>
parents: 428
diff changeset
28 </th>
505656a9947f refac: layout refactored
Thomas Junk <thomas.junk@intevation.de>
parents: 428
diff changeset
29 <th scope="col" @click="sortBy('role')">
505656a9947f refac: layout refactored
Thomas Junk <thomas.junk@intevation.de>
parents: 428
diff changeset
30 <span>Role&nbsp;
505656a9947f refac: layout refactored
Thomas Junk <thomas.junk@intevation.de>
parents: 428
diff changeset
31 <i v-if="sortCriterion=='role'" class="fa fa-angle-down"></i>
505656a9947f refac: layout refactored
Thomas Junk <thomas.junk@intevation.de>
parents: 428
diff changeset
32 </span>
505656a9947f refac: layout refactored
Thomas Junk <thomas.junk@intevation.de>
parents: 428
diff changeset
33 </th>
505656a9947f refac: layout refactored
Thomas Junk <thomas.junk@intevation.de>
parents: 428
diff changeset
34 <th scope="col"></th>
505656a9947f refac: layout refactored
Thomas Junk <thomas.junk@intevation.de>
parents: 428
diff changeset
35 </tr>
505656a9947f refac: layout refactored
Thomas Junk <thomas.junk@intevation.de>
parents: 428
diff changeset
36 </thead>
505656a9947f refac: layout refactored
Thomas Junk <thomas.junk@intevation.de>
parents: 428
diff changeset
37 <tbody>
505656a9947f refac: layout refactored
Thomas Junk <thomas.junk@intevation.de>
parents: 428
diff changeset
38 <tr v-for="user in users" :key="user.user" @click="selectUser(user.user)">
505656a9947f refac: layout refactored
Thomas Junk <thomas.junk@intevation.de>
parents: 428
diff changeset
39 <td>{{ user.user }}</td>
505656a9947f refac: layout refactored
Thomas Junk <thomas.junk@intevation.de>
parents: 428
diff changeset
40 <td>{{ user.country }}</td>
505656a9947f refac: layout refactored
Thomas Junk <thomas.junk@intevation.de>
parents: 428
diff changeset
41 <td>{{ user.email}}</td>
505656a9947f refac: layout refactored
Thomas Junk <thomas.junk@intevation.de>
parents: 428
diff changeset
42 <td>{{ user.role }}</td>
505656a9947f refac: layout refactored
Thomas Junk <thomas.junk@intevation.de>
parents: 428
diff changeset
43 <td>
505656a9947f refac: layout refactored
Thomas Junk <thomas.junk@intevation.de>
parents: 428
diff changeset
44 <i @click="deleteUser(user.user)" class="fa fa-trash-o"></i>
505656a9947f refac: layout refactored
Thomas Junk <thomas.junk@intevation.de>
parents: 428
diff changeset
45 </td>
505656a9947f refac: layout refactored
Thomas Junk <thomas.junk@intevation.de>
parents: 428
diff changeset
46 </tr>
505656a9947f refac: layout refactored
Thomas Junk <thomas.junk@intevation.de>
parents: 428
diff changeset
47 </tbody>
505656a9947f refac: layout refactored
Thomas Junk <thomas.junk@intevation.de>
parents: 428
diff changeset
48 </table>
505656a9947f refac: layout refactored
Thomas Junk <thomas.junk@intevation.de>
parents: 428
diff changeset
49 </div>
551
89bc8111563a refac: Layout adjustments
Thomas Junk <thomas.junk@intevation.de>
parents: 546
diff changeset
50 <div class="d-flex flex-row pagination">
89bc8111563a refac: Layout adjustments
Thomas Junk <thomas.junk@intevation.de>
parents: 546
diff changeset
51 <i @click=" prevPage " v-if="this.currentPage!=1 " class="backwards btn btn-sm btn-light align-self-center pages fa fa-caret-left "></i> {{this.currentPage}} / {{this.pages}}
89bc8111563a refac: Layout adjustments
Thomas Junk <thomas.junk@intevation.de>
parents: 546
diff changeset
52 <i @click="nextPage " class="forwards btn btn-sm btn-light align-self-center pages fa fa-caret-right "></i>
542
505656a9947f refac: layout refactored
Thomas Junk <thomas.junk@intevation.de>
parents: 428
diff changeset
53 </div>
551
89bc8111563a refac: Layout adjustments
Thomas Junk <thomas.junk@intevation.de>
parents: 546
diff changeset
54 <div class="adduser ">
89bc8111563a refac: Layout adjustments
Thomas Junk <thomas.junk@intevation.de>
parents: 546
diff changeset
55 <button @click="addUser " class="btn btn-info pull-right shadow-sm ">Add User</button>
375
112527683ee9 Backed out changeset 2c58906649be
Thomas Junk <thomas.junk@intevation.de>
parents: 373
diff changeset
56 </div>
293
85b653d4380c style: Table is now rendered as a card.
Thomas Junk <thomas.junk@intevation.de>
parents: 290
diff changeset
57 </div>
542
505656a9947f refac: layout refactored
Thomas Junk <thomas.junk@intevation.de>
parents: 428
diff changeset
58 </div>
551
89bc8111563a refac: Layout adjustments
Thomas Junk <thomas.junk@intevation.de>
parents: 546
diff changeset
59 <Userdetail v-if="isUserDetailsVisible "></Userdetail>
289
aee175e3f82c feat: Listing of users on management page
Thomas Junk <thomas.junk@intevation.de>
parents: 278
diff changeset
60 </div>
278
9c1dfadb53aa feat: usermanagement - route established and secured
Thomas Junk <thomas.junk@intevation.de>
parents:
diff changeset
61 </div>
9c1dfadb53aa feat: usermanagement - route established and secured
Thomas Junk <thomas.junk@intevation.de>
parents:
diff changeset
62 </div>
9c1dfadb53aa feat: usermanagement - route established and secured
Thomas Junk <thomas.junk@intevation.de>
parents:
diff changeset
63 </template>
9c1dfadb53aa feat: usermanagement - route established and secured
Thomas Junk <thomas.junk@intevation.de>
parents:
diff changeset
64
9c1dfadb53aa feat: usermanagement - route established and secured
Thomas Junk <thomas.junk@intevation.de>
parents:
diff changeset
65 <style lang="scss">
289
aee175e3f82c feat: Listing of users on management page
Thomas Junk <thomas.junk@intevation.de>
parents: 278
diff changeset
66 @import "../assets/application.scss";
278
9c1dfadb53aa feat: usermanagement - route established and secured
Thomas Junk <thomas.junk@intevation.de>
parents:
diff changeset
67 .main {
9c1dfadb53aa feat: usermanagement - route established and secured
Thomas Junk <thomas.junk@intevation.de>
parents:
diff changeset
68 height: 100vh;
9c1dfadb53aa feat: usermanagement - route established and secured
Thomas Junk <thomas.junk@intevation.de>
parents:
diff changeset
69 }
9c1dfadb53aa feat: usermanagement - route established and secured
Thomas Junk <thomas.junk@intevation.de>
parents:
diff changeset
70
551
89bc8111563a refac: Layout adjustments
Thomas Junk <thomas.junk@intevation.de>
parents: 546
diff changeset
71 .backwards {
89bc8111563a refac: Layout adjustments
Thomas Junk <thomas.junk@intevation.de>
parents: 546
diff changeset
72 margin-right: 0.5rem;
89bc8111563a refac: Layout adjustments
Thomas Junk <thomas.junk@intevation.de>
parents: 546
diff changeset
73 }
89bc8111563a refac: Layout adjustments
Thomas Junk <thomas.junk@intevation.de>
parents: 546
diff changeset
74
89bc8111563a refac: Layout adjustments
Thomas Junk <thomas.junk@intevation.de>
parents: 546
diff changeset
75 .forwards {
89bc8111563a refac: Layout adjustments
Thomas Junk <thomas.junk@intevation.de>
parents: 546
diff changeset
76 margin-left: 0.5rem;
89bc8111563a refac: Layout adjustments
Thomas Junk <thomas.junk@intevation.de>
parents: 546
diff changeset
77 }
89bc8111563a refac: Layout adjustments
Thomas Junk <thomas.junk@intevation.de>
parents: 546
diff changeset
78
278
9c1dfadb53aa feat: usermanagement - route established and secured
Thomas Junk <thomas.junk@intevation.de>
parents:
diff changeset
79 .content {
293
85b653d4380c style: Table is now rendered as a card.
Thomas Junk <thomas.junk@intevation.de>
parents: 290
diff changeset
80 margin-top: $large-offset;
85b653d4380c style: Table is now rendered as a card.
Thomas Junk <thomas.junk@intevation.de>
parents: 290
diff changeset
81 margin-left: auto;
85b653d4380c style: Table is now rendered as a card.
Thomas Junk <thomas.junk@intevation.de>
parents: 290
diff changeset
82 margin-right: auto;
289
aee175e3f82c feat: Listing of users on management page
Thomas Junk <thomas.junk@intevation.de>
parents: 278
diff changeset
83 }
aee175e3f82c feat: Listing of users on management page
Thomas Junk <thomas.junk@intevation.de>
parents: 278
diff changeset
84
389
e7d5383bc358 feat: Primitive validation and error messages
Thomas Junk <thomas.junk@intevation.de>
parents: 379
diff changeset
85 .adduser {
e7d5383bc358 feat: Primitive validation and error messages
Thomas Junk <thomas.junk@intevation.de>
parents: 379
diff changeset
86 margin-right: $offset;
e7d5383bc358 feat: Primitive validation and error messages
Thomas Junk <thomas.junk@intevation.de>
parents: 379
diff changeset
87 padding-bottom: $offset;
e7d5383bc358 feat: Primitive validation and error messages
Thomas Junk <thomas.junk@intevation.de>
parents: 379
diff changeset
88 }
e7d5383bc358 feat: Primitive validation and error messages
Thomas Junk <thomas.junk@intevation.de>
parents: 379
diff changeset
89
289
aee175e3f82c feat: Listing of users on management page
Thomas Junk <thomas.junk@intevation.de>
parents: 278
diff changeset
90 .userlist {
551
89bc8111563a refac: Layout adjustments
Thomas Junk <thomas.junk@intevation.de>
parents: 546
diff changeset
91 margin-top: $topbarheight;
389
e7d5383bc358 feat: Primitive validation and error messages
Thomas Junk <thomas.junk@intevation.de>
parents: 379
diff changeset
92 margin-right: $offset;
422
9869bc03155e refactor: Brushed up UI and added comfort
Thomas Junk <thomas.junk@intevation.de>
parents: 413
diff changeset
93 min-width: 520px;
278
9c1dfadb53aa feat: usermanagement - route established and secured
Thomas Junk <thomas.junk@intevation.de>
parents:
diff changeset
94 }
389
e7d5383bc358 feat: Primitive validation and error messages
Thomas Junk <thomas.junk@intevation.de>
parents: 379
diff changeset
95
551
89bc8111563a refac: Layout adjustments
Thomas Junk <thomas.junk@intevation.de>
parents: 546
diff changeset
96 .pagination {
89bc8111563a refac: Layout adjustments
Thomas Junk <thomas.junk@intevation.de>
parents: 546
diff changeset
97 margin-left: auto;
89bc8111563a refac: Layout adjustments
Thomas Junk <thomas.junk@intevation.de>
parents: 546
diff changeset
98 margin-right: auto;
89bc8111563a refac: Layout adjustments
Thomas Junk <thomas.junk@intevation.de>
parents: 546
diff changeset
99 }
389
e7d5383bc358 feat: Primitive validation and error messages
Thomas Junk <thomas.junk@intevation.de>
parents: 379
diff changeset
100 .userlistsmall {
400
cb233a5a2ecd fix: Fixed country validation on submit
Thomas Junk <thomas.junk@intevation.de>
parents: 389
diff changeset
101 width: 35vw;
389
e7d5383bc358 feat: Primitive validation and error messages
Thomas Junk <thomas.junk@intevation.de>
parents: 379
diff changeset
102 }
e7d5383bc358 feat: Primitive validation and error messages
Thomas Junk <thomas.junk@intevation.de>
parents: 379
diff changeset
103
e7d5383bc358 feat: Primitive validation and error messages
Thomas Junk <thomas.junk@intevation.de>
parents: 379
diff changeset
104 .userlistextended {
e7d5383bc358 feat: Primitive validation and error messages
Thomas Junk <thomas.junk@intevation.de>
parents: 379
diff changeset
105 width: 70vw;
e7d5383bc358 feat: Primitive validation and error messages
Thomas Junk <thomas.junk@intevation.de>
parents: 379
diff changeset
106 }
e7d5383bc358 feat: Primitive validation and error messages
Thomas Junk <thomas.junk@intevation.de>
parents: 379
diff changeset
107
422
9869bc03155e refactor: Brushed up UI and added comfort
Thomas Junk <thomas.junk@intevation.de>
parents: 413
diff changeset
108 .table {
9869bc03155e refactor: Brushed up UI and added comfort
Thomas Junk <thomas.junk@intevation.de>
parents: 413
diff changeset
109 width: 90% !important;
9869bc03155e refactor: Brushed up UI and added comfort
Thomas Junk <thomas.junk@intevation.de>
parents: 413
diff changeset
110 margin: auto;
9869bc03155e refactor: Brushed up UI and added comfort
Thomas Junk <thomas.junk@intevation.de>
parents: 413
diff changeset
111 }
9869bc03155e refactor: Brushed up UI and added comfort
Thomas Junk <thomas.junk@intevation.de>
parents: 413
diff changeset
112
428
d7a06b9fffc9 feat: Usability for usermanagement improved.
Thomas Junk <thomas.junk@intevation.de>
parents: 427
diff changeset
113 .table th,
d7a06b9fffc9 feat: Usability for usermanagement improved.
Thomas Junk <thomas.junk@intevation.de>
parents: 427
diff changeset
114 .pages {
422
9869bc03155e refactor: Brushed up UI and added comfort
Thomas Junk <thomas.junk@intevation.de>
parents: 413
diff changeset
115 cursor: pointer;
293
85b653d4380c style: Table is now rendered as a card.
Thomas Junk <thomas.junk@intevation.de>
parents: 290
diff changeset
116 }
294
c57b0b230452 style: Remove bootstrap standard lines
Thomas Junk <thomas.junk@intevation.de>
parents: 293
diff changeset
117
c57b0b230452 style: Remove bootstrap standard lines
Thomas Junk <thomas.junk@intevation.de>
parents: 293
diff changeset
118 .table th,
c57b0b230452 style: Remove bootstrap standard lines
Thomas Junk <thomas.junk@intevation.de>
parents: 293
diff changeset
119 td {
389
e7d5383bc358 feat: Primitive validation and error messages
Thomas Junk <thomas.junk@intevation.de>
parents: 379
diff changeset
120 font-size: 0.9rem;
294
c57b0b230452 style: Remove bootstrap standard lines
Thomas Junk <thomas.junk@intevation.de>
parents: 293
diff changeset
121 border-top: 0px !important;
422
9869bc03155e refactor: Brushed up UI and added comfort
Thomas Junk <thomas.junk@intevation.de>
parents: 413
diff changeset
122 text-align: left;
9869bc03155e refactor: Brushed up UI and added comfort
Thomas Junk <thomas.junk@intevation.de>
parents: 413
diff changeset
123 padding: 0.5rem !important;
294
c57b0b230452 style: Remove bootstrap standard lines
Thomas Junk <thomas.junk@intevation.de>
parents: 293
diff changeset
124 }
300
af29878be602 feat: User table selectable
Thomas Junk <thomas.junk@intevation.de>
parents: 299
diff changeset
125
af29878be602 feat: User table selectable
Thomas Junk <thomas.junk@intevation.de>
parents: 299
diff changeset
126 .table td {
389
e7d5383bc358 feat: Primitive validation and error messages
Thomas Junk <thomas.junk@intevation.de>
parents: 379
diff changeset
127 font-size: 0.9rem;
300
af29878be602 feat: User table selectable
Thomas Junk <thomas.junk@intevation.de>
parents: 299
diff changeset
128 cursor: pointer;
af29878be602 feat: User table selectable
Thomas Junk <thomas.junk@intevation.de>
parents: 299
diff changeset
129 }
422
9869bc03155e refactor: Brushed up UI and added comfort
Thomas Junk <thomas.junk@intevation.de>
parents: 413
diff changeset
130
9869bc03155e refactor: Brushed up UI and added comfort
Thomas Junk <thomas.junk@intevation.de>
parents: 413
diff changeset
131 tr span {
9869bc03155e refactor: Brushed up UI and added comfort
Thomas Junk <thomas.junk@intevation.de>
parents: 413
diff changeset
132 display: flex;
9869bc03155e refactor: Brushed up UI and added comfort
Thomas Junk <thomas.junk@intevation.de>
parents: 413
diff changeset
133 }
278
9c1dfadb53aa feat: usermanagement - route established and secured
Thomas Junk <thomas.junk@intevation.de>
parents:
diff changeset
134 </style>
9c1dfadb53aa feat: usermanagement - route established and secured
Thomas Junk <thomas.junk@intevation.de>
parents:
diff changeset
135
9c1dfadb53aa feat: usermanagement - route established and secured
Thomas Junk <thomas.junk@intevation.de>
parents:
diff changeset
136 <script>
356
dc8052b60485 feat: User detail card added
Thomas Junk <thomas.junk@intevation.de>
parents: 300
diff changeset
137 import Userdetail from "../components/Userdetail";
289
aee175e3f82c feat: Listing of users on management page
Thomas Junk <thomas.junk@intevation.de>
parents: 278
diff changeset
138 import store from "../store";
aee175e3f82c feat: Listing of users on management page
Thomas Junk <thomas.junk@intevation.de>
parents: 278
diff changeset
139 import { mapGetters } from "vuex";
413
a9440a4826aa refactor: display errormessages refactored to own lib
Thomas Junk <thomas.junk@intevation.de>
parents: 406
diff changeset
140 import { displayError } from "../lib/errors.js";
289
aee175e3f82c feat: Listing of users on management page
Thomas Junk <thomas.junk@intevation.de>
parents: 278
diff changeset
141
278
9c1dfadb53aa feat: usermanagement - route established and secured
Thomas Junk <thomas.junk@intevation.de>
parents:
diff changeset
142 export default {
9c1dfadb53aa feat: usermanagement - route established and secured
Thomas Junk <thomas.junk@intevation.de>
parents:
diff changeset
143 name: "userview",
375
112527683ee9 Backed out changeset 2c58906649be
Thomas Junk <thomas.junk@intevation.de>
parents: 373
diff changeset
144 data() {
427
e4b961315e9f feat: Pagination added to usermanagement
Thomas Junk <thomas.junk@intevation.de>
parents: 422
diff changeset
145 return {
e4b961315e9f feat: Pagination added to usermanagement
Thomas Junk <thomas.junk@intevation.de>
parents: 422
diff changeset
146 sortCriterion: "user",
e4b961315e9f feat: Pagination added to usermanagement
Thomas Junk <thomas.junk@intevation.de>
parents: 422
diff changeset
147 pageSize: 10,
e4b961315e9f feat: Pagination added to usermanagement
Thomas Junk <thomas.junk@intevation.de>
parents: 422
diff changeset
148 currentPage: 1
e4b961315e9f feat: Pagination added to usermanagement
Thomas Junk <thomas.junk@intevation.de>
parents: 422
diff changeset
149 };
375
112527683ee9 Backed out changeset 2c58906649be
Thomas Junk <thomas.junk@intevation.de>
parents: 373
diff changeset
150 },
278
9c1dfadb53aa feat: usermanagement - route established and secured
Thomas Junk <thomas.junk@intevation.de>
parents:
diff changeset
151 components: {
551
89bc8111563a refac: Layout adjustments
Thomas Junk <thomas.junk@intevation.de>
parents: 546
diff changeset
152 Userdetail
289
aee175e3f82c feat: Listing of users on management page
Thomas Junk <thomas.junk@intevation.de>
parents: 278
diff changeset
153 },
aee175e3f82c feat: Listing of users on management page
Thomas Junk <thomas.junk@intevation.de>
parents: 278
diff changeset
154 computed: {
422
9869bc03155e refactor: Brushed up UI and added comfort
Thomas Junk <thomas.junk@intevation.de>
parents: 413
diff changeset
155 ...mapGetters("usermanagement", ["isUserDetailsVisible"]),
9869bc03155e refactor: Brushed up UI and added comfort
Thomas Junk <thomas.junk@intevation.de>
parents: 413
diff changeset
156 users() {
9869bc03155e refactor: Brushed up UI and added comfort
Thomas Junk <thomas.junk@intevation.de>
parents: 413
diff changeset
157 let users = [...this.$store.getters["usermanagement/users"]];
9869bc03155e refactor: Brushed up UI and added comfort
Thomas Junk <thomas.junk@intevation.de>
parents: 413
diff changeset
158 users.sort((a, b) => {
9869bc03155e refactor: Brushed up UI and added comfort
Thomas Junk <thomas.junk@intevation.de>
parents: 413
diff changeset
159 if (
9869bc03155e refactor: Brushed up UI and added comfort
Thomas Junk <thomas.junk@intevation.de>
parents: 413
diff changeset
160 a[this.sortCriterion].toLowerCase() <
9869bc03155e refactor: Brushed up UI and added comfort
Thomas Junk <thomas.junk@intevation.de>
parents: 413
diff changeset
161 b[this.sortCriterion].toLowerCase()
9869bc03155e refactor: Brushed up UI and added comfort
Thomas Junk <thomas.junk@intevation.de>
parents: 413
diff changeset
162 )
9869bc03155e refactor: Brushed up UI and added comfort
Thomas Junk <thomas.junk@intevation.de>
parents: 413
diff changeset
163 return -1;
9869bc03155e refactor: Brushed up UI and added comfort
Thomas Junk <thomas.junk@intevation.de>
parents: 413
diff changeset
164 if (
9869bc03155e refactor: Brushed up UI and added comfort
Thomas Junk <thomas.junk@intevation.de>
parents: 413
diff changeset
165 a[this.sortCriterion].toLowerCase() >
9869bc03155e refactor: Brushed up UI and added comfort
Thomas Junk <thomas.junk@intevation.de>
parents: 413
diff changeset
166 b[this.sortCriterion].toLowerCase()
9869bc03155e refactor: Brushed up UI and added comfort
Thomas Junk <thomas.junk@intevation.de>
parents: 413
diff changeset
167 )
9869bc03155e refactor: Brushed up UI and added comfort
Thomas Junk <thomas.junk@intevation.de>
parents: 413
diff changeset
168 return 1;
9869bc03155e refactor: Brushed up UI and added comfort
Thomas Junk <thomas.junk@intevation.de>
parents: 413
diff changeset
169 return 0;
9869bc03155e refactor: Brushed up UI and added comfort
Thomas Junk <thomas.junk@intevation.de>
parents: 413
diff changeset
170 });
427
e4b961315e9f feat: Pagination added to usermanagement
Thomas Junk <thomas.junk@intevation.de>
parents: 422
diff changeset
171 const start = (this.currentPage - 1) * this.pageSize;
e4b961315e9f feat: Pagination added to usermanagement
Thomas Junk <thomas.junk@intevation.de>
parents: 422
diff changeset
172 return users.slice(start, start + this.pageSize);
e4b961315e9f feat: Pagination added to usermanagement
Thomas Junk <thomas.junk@intevation.de>
parents: 422
diff changeset
173 },
e4b961315e9f feat: Pagination added to usermanagement
Thomas Junk <thomas.junk@intevation.de>
parents: 422
diff changeset
174 pages() {
e4b961315e9f feat: Pagination added to usermanagement
Thomas Junk <thomas.junk@intevation.de>
parents: 422
diff changeset
175 let users = [...this.$store.getters["usermanagement/users"]];
e4b961315e9f feat: Pagination added to usermanagement
Thomas Junk <thomas.junk@intevation.de>
parents: 422
diff changeset
176 return Math.ceil(users.length / this.pageSize);
422
9869bc03155e refactor: Brushed up UI and added comfort
Thomas Junk <thomas.junk@intevation.de>
parents: 413
diff changeset
177 },
9869bc03155e refactor: Brushed up UI and added comfort
Thomas Junk <thomas.junk@intevation.de>
parents: 413
diff changeset
178 tableStyle() {
9869bc03155e refactor: Brushed up UI and added comfort
Thomas Junk <thomas.junk@intevation.de>
parents: 413
diff changeset
179 return {
9869bc03155e refactor: Brushed up UI and added comfort
Thomas Junk <thomas.junk@intevation.de>
parents: 413
diff changeset
180 table: true,
9869bc03155e refactor: Brushed up UI and added comfort
Thomas Junk <thomas.junk@intevation.de>
parents: 413
diff changeset
181 "table-hover": true,
428
d7a06b9fffc9 feat: Usability for usermanagement improved.
Thomas Junk <thomas.junk@intevation.de>
parents: 427
diff changeset
182 "table-sm": this.isUserDetailsVisible,
d7a06b9fffc9 feat: Usability for usermanagement improved.
Thomas Junk <thomas.junk@intevation.de>
parents: 427
diff changeset
183 fadeIn: true,
d7a06b9fffc9 feat: Usability for usermanagement improved.
Thomas Junk <thomas.junk@intevation.de>
parents: 427
diff changeset
184 animated: true
422
9869bc03155e refactor: Brushed up UI and added comfort
Thomas Junk <thomas.junk@intevation.de>
parents: 413
diff changeset
185 };
9869bc03155e refactor: Brushed up UI and added comfort
Thomas Junk <thomas.junk@intevation.de>
parents: 413
diff changeset
186 },
389
e7d5383bc358 feat: Primitive validation and error messages
Thomas Junk <thomas.junk@intevation.de>
parents: 379
diff changeset
187 userlistStyle() {
e7d5383bc358 feat: Primitive validation and error messages
Thomas Junk <thomas.junk@intevation.de>
parents: 379
diff changeset
188 return {
e7d5383bc358 feat: Primitive validation and error messages
Thomas Junk <thomas.junk@intevation.de>
parents: 379
diff changeset
189 userlist: true,
e7d5383bc358 feat: Primitive validation and error messages
Thomas Junk <thomas.junk@intevation.de>
parents: 379
diff changeset
190 shadow: true,
e7d5383bc358 feat: Primitive validation and error messages
Thomas Junk <thomas.junk@intevation.de>
parents: 379
diff changeset
191 userlistsmall: this.isUserDetailsVisible,
e7d5383bc358 feat: Primitive validation and error messages
Thomas Junk <thomas.junk@intevation.de>
parents: 379
diff changeset
192 userlistextended: !this.isUserDetailsVisible
e7d5383bc358 feat: Primitive validation and error messages
Thomas Junk <thomas.junk@intevation.de>
parents: 379
diff changeset
193 };
e7d5383bc358 feat: Primitive validation and error messages
Thomas Junk <thomas.junk@intevation.de>
parents: 379
diff changeset
194 }
289
aee175e3f82c feat: Listing of users on management page
Thomas Junk <thomas.junk@intevation.de>
parents: 278
diff changeset
195 },
375
112527683ee9 Backed out changeset 2c58906649be
Thomas Junk <thomas.junk@intevation.de>
parents: 373
diff changeset
196 methods: {
428
d7a06b9fffc9 feat: Usability for usermanagement improved.
Thomas Junk <thomas.junk@intevation.de>
parents: 427
diff changeset
197 tween() {},
427
e4b961315e9f feat: Pagination added to usermanagement
Thomas Junk <thomas.junk@intevation.de>
parents: 422
diff changeset
198 nextPage() {
428
d7a06b9fffc9 feat: Usability for usermanagement improved.
Thomas Junk <thomas.junk@intevation.de>
parents: 427
diff changeset
199 if (this.currentPage < this.pages) {
d7a06b9fffc9 feat: Usability for usermanagement improved.
Thomas Junk <thomas.junk@intevation.de>
parents: 427
diff changeset
200 document.querySelector("#datatable").classList.add("fadeOut");
d7a06b9fffc9 feat: Usability for usermanagement improved.
Thomas Junk <thomas.junk@intevation.de>
parents: 427
diff changeset
201 setTimeout(() => {
d7a06b9fffc9 feat: Usability for usermanagement improved.
Thomas Junk <thomas.junk@intevation.de>
parents: 427
diff changeset
202 document.querySelector("#datatable").classList.remove("fadeOut");
d7a06b9fffc9 feat: Usability for usermanagement improved.
Thomas Junk <thomas.junk@intevation.de>
parents: 427
diff changeset
203 this.currentPage += 1;
d7a06b9fffc9 feat: Usability for usermanagement improved.
Thomas Junk <thomas.junk@intevation.de>
parents: 427
diff changeset
204 }, 10);
d7a06b9fffc9 feat: Usability for usermanagement improved.
Thomas Junk <thomas.junk@intevation.de>
parents: 427
diff changeset
205 }
427
e4b961315e9f feat: Pagination added to usermanagement
Thomas Junk <thomas.junk@intevation.de>
parents: 422
diff changeset
206 return;
e4b961315e9f feat: Pagination added to usermanagement
Thomas Junk <thomas.junk@intevation.de>
parents: 422
diff changeset
207 },
e4b961315e9f feat: Pagination added to usermanagement
Thomas Junk <thomas.junk@intevation.de>
parents: 422
diff changeset
208 prevPage() {
428
d7a06b9fffc9 feat: Usability for usermanagement improved.
Thomas Junk <thomas.junk@intevation.de>
parents: 427
diff changeset
209 if (this.currentPage > 0) {
d7a06b9fffc9 feat: Usability for usermanagement improved.
Thomas Junk <thomas.junk@intevation.de>
parents: 427
diff changeset
210 document.querySelector("#datatable").classList.add("fadeOut");
d7a06b9fffc9 feat: Usability for usermanagement improved.
Thomas Junk <thomas.junk@intevation.de>
parents: 427
diff changeset
211 setTimeout(() => {
d7a06b9fffc9 feat: Usability for usermanagement improved.
Thomas Junk <thomas.junk@intevation.de>
parents: 427
diff changeset
212 document.querySelector("#datatable").classList.remove("fadeOut");
d7a06b9fffc9 feat: Usability for usermanagement improved.
Thomas Junk <thomas.junk@intevation.de>
parents: 427
diff changeset
213 this.currentPage -= 1;
d7a06b9fffc9 feat: Usability for usermanagement improved.
Thomas Junk <thomas.junk@intevation.de>
parents: 427
diff changeset
214 }, 10);
d7a06b9fffc9 feat: Usability for usermanagement improved.
Thomas Junk <thomas.junk@intevation.de>
parents: 427
diff changeset
215 }
427
e4b961315e9f feat: Pagination added to usermanagement
Thomas Junk <thomas.junk@intevation.de>
parents: 422
diff changeset
216 return;
e4b961315e9f feat: Pagination added to usermanagement
Thomas Junk <thomas.junk@intevation.de>
parents: 422
diff changeset
217 },
422
9869bc03155e refactor: Brushed up UI and added comfort
Thomas Junk <thomas.junk@intevation.de>
parents: 413
diff changeset
218 sortBy(criterion) {
9869bc03155e refactor: Brushed up UI and added comfort
Thomas Junk <thomas.junk@intevation.de>
parents: 413
diff changeset
219 this.sortCriterion = criterion;
9869bc03155e refactor: Brushed up UI and added comfort
Thomas Junk <thomas.junk@intevation.de>
parents: 413
diff changeset
220 },
400
cb233a5a2ecd fix: Fixed country validation on submit
Thomas Junk <thomas.junk@intevation.de>
parents: 389
diff changeset
221 deleteUser(name) {
406
40e7ab3df32c feat: Basic CRUD for usermanagement etd
Thomas Junk <thomas.junk@intevation.de>
parents: 400
diff changeset
222 this.$store
40e7ab3df32c feat: Basic CRUD for usermanagement etd
Thomas Junk <thomas.junk@intevation.de>
parents: 400
diff changeset
223 .dispatch("usermanagement/deleteUser", { name: name })
40e7ab3df32c feat: Basic CRUD for usermanagement etd
Thomas Junk <thomas.junk@intevation.de>
parents: 400
diff changeset
224 .then(() => {
40e7ab3df32c feat: Basic CRUD for usermanagement etd
Thomas Junk <thomas.junk@intevation.de>
parents: 400
diff changeset
225 this.submitted = false;
40e7ab3df32c feat: Basic CRUD for usermanagement etd
Thomas Junk <thomas.junk@intevation.de>
parents: 400
diff changeset
226 this.$store.dispatch("usermanagement/loadUsers").catch(error => {
40e7ab3df32c feat: Basic CRUD for usermanagement etd
Thomas Junk <thomas.junk@intevation.de>
parents: 400
diff changeset
227 const { status, data } = error.response;
413
a9440a4826aa refactor: display errormessages refactored to own lib
Thomas Junk <thomas.junk@intevation.de>
parents: 406
diff changeset
228 displayError({
406
40e7ab3df32c feat: Basic CRUD for usermanagement etd
Thomas Junk <thomas.junk@intevation.de>
parents: 400
diff changeset
229 title: "Backend Error",
546
b91791664554 refac: Errorhandling and formatting
Thomas Junk <thomas.junk@intevation.de>
parents: 542
diff changeset
230 message: `${status}: ${data.message || data}`
406
40e7ab3df32c feat: Basic CRUD for usermanagement etd
Thomas Junk <thomas.junk@intevation.de>
parents: 400
diff changeset
231 });
40e7ab3df32c feat: Basic CRUD for usermanagement etd
Thomas Junk <thomas.junk@intevation.de>
parents: 400
diff changeset
232 });
40e7ab3df32c feat: Basic CRUD for usermanagement etd
Thomas Junk <thomas.junk@intevation.de>
parents: 400
diff changeset
233 })
40e7ab3df32c feat: Basic CRUD for usermanagement etd
Thomas Junk <thomas.junk@intevation.de>
parents: 400
diff changeset
234 .catch(error => {
40e7ab3df32c feat: Basic CRUD for usermanagement etd
Thomas Junk <thomas.junk@intevation.de>
parents: 400
diff changeset
235 const { status, data } = error.response;
413
a9440a4826aa refactor: display errormessages refactored to own lib
Thomas Junk <thomas.junk@intevation.de>
parents: 406
diff changeset
236 displayError({
406
40e7ab3df32c feat: Basic CRUD for usermanagement etd
Thomas Junk <thomas.junk@intevation.de>
parents: 400
diff changeset
237 title: "Backend Error",
546
b91791664554 refac: Errorhandling and formatting
Thomas Junk <thomas.junk@intevation.de>
parents: 542
diff changeset
238 message: `${status}: ${data.message || data}`
406
40e7ab3df32c feat: Basic CRUD for usermanagement etd
Thomas Junk <thomas.junk@intevation.de>
parents: 400
diff changeset
239 });
40e7ab3df32c feat: Basic CRUD for usermanagement etd
Thomas Junk <thomas.junk@intevation.de>
parents: 400
diff changeset
240 });
400
cb233a5a2ecd fix: Fixed country validation on submit
Thomas Junk <thomas.junk@intevation.de>
parents: 389
diff changeset
241 },
389
e7d5383bc358 feat: Primitive validation and error messages
Thomas Junk <thomas.junk@intevation.de>
parents: 379
diff changeset
242 addUser() {
e7d5383bc358 feat: Primitive validation and error messages
Thomas Junk <thomas.junk@intevation.de>
parents: 379
diff changeset
243 this.$store.commit("usermanagement/clearCurrentUser");
e7d5383bc358 feat: Primitive validation and error messages
Thomas Junk <thomas.junk@intevation.de>
parents: 379
diff changeset
244 this.$store.commit("usermanagement/setUserDetailsVisible");
e7d5383bc358 feat: Primitive validation and error messages
Thomas Junk <thomas.junk@intevation.de>
parents: 379
diff changeset
245 },
375
112527683ee9 Backed out changeset 2c58906649be
Thomas Junk <thomas.junk@intevation.de>
parents: 373
diff changeset
246 selectUser(name) {
112527683ee9 Backed out changeset 2c58906649be
Thomas Junk <thomas.junk@intevation.de>
parents: 373
diff changeset
247 const user = this.$store.getters["usermanagement/getUserByName"](name);
376
e42f42eb9353 refactor: Userdetails refactored to card model
Thomas Junk <thomas.junk@intevation.de>
parents: 375
diff changeset
248 this.$store.commit("usermanagement/setCurrentUser", user);
375
112527683ee9 Backed out changeset 2c58906649be
Thomas Junk <thomas.junk@intevation.de>
parents: 373
diff changeset
249 }
112527683ee9 Backed out changeset 2c58906649be
Thomas Junk <thomas.junk@intevation.de>
parents: 373
diff changeset
250 },
289
aee175e3f82c feat: Listing of users on management page
Thomas Junk <thomas.junk@intevation.de>
parents: 278
diff changeset
251 beforeRouteEnter(to, from, next) {
295
22deb76dff2c feat: Added vue2-toastr
Thomas Junk <thomas.junk@intevation.de>
parents: 294
diff changeset
252 store
22deb76dff2c feat: Added vue2-toastr
Thomas Junk <thomas.junk@intevation.de>
parents: 294
diff changeset
253 .dispatch("usermanagement/loadUsers")
22deb76dff2c feat: Added vue2-toastr
Thomas Junk <thomas.junk@intevation.de>
parents: 294
diff changeset
254 .then(next)
299
6b4df87a7ccc refactor: console.log removed. Backend error while fetching users.
Thomas Junk <thomas.junk@intevation.de>
parents: 295
diff changeset
255 .catch(error => {
6b4df87a7ccc refactor: console.log removed. Backend error while fetching users.
Thomas Junk <thomas.junk@intevation.de>
parents: 295
diff changeset
256 const { status, data } = error.response;
413
a9440a4826aa refactor: display errormessages refactored to own lib
Thomas Junk <thomas.junk@intevation.de>
parents: 406
diff changeset
257 displayError({
373
7e7e978d1cac Backed out changeset 1a2ef18e464d
Thomas Junk <thomas.junk@intevation.de>
parents: 366
diff changeset
258 title: "Backend Error",
413
a9440a4826aa refactor: display errormessages refactored to own lib
Thomas Junk <thomas.junk@intevation.de>
parents: 406
diff changeset
259 message: `${status}: ${data}`
295
22deb76dff2c feat: Added vue2-toastr
Thomas Junk <thomas.junk@intevation.de>
parents: 294
diff changeset
260 });
22deb76dff2c feat: Added vue2-toastr
Thomas Junk <thomas.junk@intevation.de>
parents: 294
diff changeset
261 });
389
e7d5383bc358 feat: Primitive validation and error messages
Thomas Junk <thomas.junk@intevation.de>
parents: 379
diff changeset
262 },
e7d5383bc358 feat: Primitive validation and error messages
Thomas Junk <thomas.junk@intevation.de>
parents: 379
diff changeset
263 beforeRouteLeave(to, from, next) {
e7d5383bc358 feat: Primitive validation and error messages
Thomas Junk <thomas.junk@intevation.de>
parents: 379
diff changeset
264 store.commit("usermanagement/clearCurrentUser");
e7d5383bc358 feat: Primitive validation and error messages
Thomas Junk <thomas.junk@intevation.de>
parents: 379
diff changeset
265 store.commit("usermanagement/setUserDetailsInvisible");
e7d5383bc358 feat: Primitive validation and error messages
Thomas Junk <thomas.junk@intevation.de>
parents: 379
diff changeset
266 next();
278
9c1dfadb53aa feat: usermanagement - route established and secured
Thomas Junk <thomas.junk@intevation.de>
parents:
diff changeset
267 }
9c1dfadb53aa feat: usermanagement - route established and secured
Thomas Junk <thomas.junk@intevation.de>
parents:
diff changeset
268 };
9c1dfadb53aa feat: usermanagement - route established and secured
Thomas Junk <thomas.junk@intevation.de>
parents:
diff changeset
269 </script>