Mercurial > gemma
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 |
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 |
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 |
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 |
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 |
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> |