source: resources/views/dashboard/users/index.blade.php@ 8fdb18e

Last change on this file since 8fdb18e was 9b4689a, checked in by Berat Kjufliju <kufliju@…>, 3 years ago

bug fixes

  • Property mode set to 100644
File size: 21.1 KB
Line 
1@extends('layouts.app')
2
3@section("title", "SaveSpace - Users")
4
5@section('head')
6 <!-- Datatable -->
7{{-- <link rel="stylesheet" href="{{ url('vendors/dataTable/dataTables.min.css') }}" type="text/css">--}}
8
9@endsection
10
11@section('content')
12
13 <div class="page-header justify-content-between">
14 <nav aria-label="breadcrumb" class="d-flex align-items-start">
15 <ol class="breadcrumb">
16 <li class="breadcrumb-item">
17 <a href="{{ url('/') }}">Dashboard</a>
18 </li>
19 <li class="breadcrumb-item active" aria-current="page">Users</li>
20 </ol>
21 </nav>
22 <div class="dropdown">
23 @if(auth()->user()->hasPermission('manage_all_users'))
24 <a href="javascript:void(0)" data-toggle="modal" data-target="#createModal" class="btn btn-primary text-white">
25 New
26 </a>
27 @endif
28 @if(auth()->user()->hasPermission('export_data'))
29 <a href="{{ route('dashboard.users.export') }}" class="btn btn-success text-white">
30 Export
31 </a>
32 @endif
33 </div>
34 </div>
35
36 <div class="row">
37 <div class="col-md-12">
38 <div class="card">
39 <div class="card-body">
40 <div class="table-responsive">
41 <table id="user-list" class="table">
42 <thead>
43 <tr>
44 <th></th>
45 <th>State</th>
46 <th>Username</th>
47 <th>Name</th>
48 <th>Created by</th>
49 <th>Created at</th>
50 <th>Updated at</th>
51 <th>Status</th>
52 <th>Actions</th>
53 </tr>
54 </thead>
55 <tbody>
56 @foreach($users as $user)
57 <tr>
58 <td></td>
59 <td>
60 @if($user->is_confirmed)
61 @if ($user->is_active)
62 <span class="badge bg-success-bright text-success">Active</span>
63 @else
64 <span class="badge bg-danger-bright text-danger">Blocked</span>
65 @endif
66 @else
67 <span class="badge bg-warning-bright text-warning">New user</span>
68 @endif
69 </td>
70 <td>
71 <figure class="avatar avatar-sm mr-2">
72 @if($user->avatar==NULL)
73 <img src="{{ url('assets/media/images/user.png') }}" class="rounded-circle" alt="avatar">
74 @else
75 <img src="{{url('uploads/users/' . $user->avatar)}}" class="rounded-circle" alt="avatar">
76 @endif
77 </figure>
78 {{$user->username}}
79 </td>
80 <td>{{$user->name .' '. $user->surname}}
81 <div class="font-weight-light p-1">{{$user->role->name}}</div>
82 <div class="font-weight-light p-1">{{$user->email}}</div>
83 <div class="font-weight-light p-1">{{$user->phone_number}}</div>
84 </td>
85 <td>{{ $user->getCreatedByName() }}</td>
86 <td>{{ date('d.m.Y - H:i', strtotime($user->created_at)) }}</td>
87 @if($user->updated_at==NULL)
88 <td>/</td>
89 @else
90 <td>{{ date('d.m.Y - H:i', strtotime($user->updated_at)) }}</td>
91 @endif
92 <td>
93 @if(Cache::has('is_online' . $user->id))
94 <span data-toggle="tooltip" data-placement="bottom" title="{{ $user->last_seen }}" style="cursor: pointer;" class="text-success">Online</span>
95 @else
96 <span data-toggle="tooltip" data-placement="bottom" title="{{ $user->last_seen }}" class="text-secondary">Offline</span>
97 @endif
98 </td>
99 @if(auth()->user()->hasPermission('manage_all_users'))
100 @if($user->hasRole("Referent") || $user->hasRole("Viewer") && $user->is_confirmed)
101 <td>
102 <a href="javascript:void(0)" class="text-secondary" data-toggle="modal" data-target="#editModal_{{$user->id}}" title="Edit">
103 <i class="ti-pencil"></i>
104 </a>
105 <a href="javascript:void(0)" class="text-danger ml-2" data-toggle="modal" data-target="#deleteModal_{{$user->id}}" title="Delete">
106 <i class="ti-trash"></i>
107 </a>
108 </td>
109 @else
110 <td>/</td>
111 @endif
112 @else
113 <td></td>
114 @endif
115 </tr>
116
117 <div class="modal fade" id="editModal_{{$user->id}}" tabindex="-1" role="dialog" aria-hidden="true">
118 <div class="modal-dialog modal-dialog-centered modal-lg" role="document">
119 <div class="modal-content">
120 <div class="modal-header">
121 <h5 class="modal-title" id="exampleModalCenterTitle">Edit user</h5>
122 <button type="button" class="close" data-dismiss="modal" aria-label="Close">
123 <i class="ti-close"></i>
124 </button>
125 </div>
126 <div class="modal-body">
127 <form action="{{ route("dashboard.users.edit", ["id" =>$user->id]) }}" method="post" accept-charset="utf-8" enctype='multipart/form-data'>
128 @method("patch")
129 @csrf
130 <div class="row">
131 <div class="col-md-6">
132 <div class="form-group">
133 <label>Name</label>
134 <input type="text" name="name" value="{{ $user->name }}" minlength="2" maxlength="30" pattern="[a-zA-Zа-шА-Ш._\s]+" class="form-control" placeholder="Name" required>
135 </div>
136 </div>
137 <div class="col-md-6">
138 <div class="form-group">
139 <label>Surname</label>
140 <input type="text" name="surname" value="{{$user->surname}}" minlength="2" maxlength="30" pattern="[a-zA-Zа-шА-Ш._\s]+" class="form-control" placeholder="Surname" required>
141 </div>
142 </div>
143 </div>
144 <div class="row">
145 <div class="col-md-6">
146 <div class="form-group">
147 <label class="form-label">Username</label>
148 <input type="text" name="username" value="{{ $user->username }}" minlength="5" maxlength="30" class="form-control" placeholder="Username" required>
149 </div>
150 </div>
151 <div class="col-md-6">
152 <div class="form-group">
153 <label class="form-label">Role</label>
154
155 <select class="form-control" name="userRole" required>
156 @foreach($roles as $role)
157 <option value="{{ $role->id }}" {{ $user->role_id == $role->id ? "selected" : "" }}>{{ $role->name }}</option>
158 @endforeach
159 </select>
160 </div>
161 </div>
162 </div>
163 <div class="row">
164 <div class="col-md-6">
165 <div class="form-group">
166 <label>Email</label>
167 <input type="email" name="email" value="{{ $user->email }}" maxlength="50" class="form-control" placeholder="E-mail" required>
168 </div>
169 </div>
170 <div class="col-md-6">
171 <div class="form-group">
172 <label class="form-label">Phone Number</label>
173 <input type="text" name="phone_number" value="{{ $user->phone_number }}" class="form-control" placeholder="Phone number" autocomplete="off" required>
174 </div>
175 </div>
176 </div>
177 <div class="row">
178 <div class="col-md-5">
179 <div class="form-group">
180 <label>Avatar</label>
181 <input type="file" name="avatar" value="{{ $user->avatar }}" class="form-control" accept="image/*">
182 </div>
183 </div>
184 <div class="col-md-1">
185 <div class="form-group">
186 <label>Current</label>
187 <figure class="avatar avatar-sm mr-2">
188 @if($user->avatar==NULL)
189 <img src="{{ url('assets/media/images/user.png') }}" class="rounded-circle" alt="avatar">
190 @else
191 <img src="{{url('uploads/users/' . $user->avatar)}}" class="rounded-circle" alt="avatar">
192 @endif
193 </figure>
194 </div>
195 </div>
196 </div>
197 <div class="modal-footer">
198 <button type="button" class="btn btn-secondary" data-dismiss="modal">Close
199 </button>
200 <button type="submit" class="btn btn-primary">Save changes</button>
201 </div>
202 </form>
203 </div>
204
205 </div>
206 </div>
207 </div>
208
209 <div class="modal fade" id="deleteModal_{{$user->id}}" tabindex="-1" role="dialog" aria-hidden="true">
210 <div class="modal-dialog modal-dialog-centered" role="document">
211 <div class="modal-content">
212 <div class="modal-header">
213 <h5 class="modal-title" id="exampleModalCenterTitle">Delete confirmation</h5>
214 <button type="button" class="close" data-dismiss="modal" aria-label="Close">
215 <i class="ti-close"></i>
216 </button>
217 </div>
218 <div class="modal-body">
219 <form action="{{ route("dashboard.users.destroy", $user->id) }}" method="POST">
220 @csrf
221 @method('DELETE')
222 <p>Are you sure you want to delete user {{$user->username}} ?</p>
223 <p>Number of folders created: <a href="{{ route("dashboard.folders.index", ['id' => $user->id]) }}" class="text-linkedin">{{\App\Models\Folder::where('user_id', $user->id)->count()}}</a></p>
224 <div class="modal-footer">
225 <button type="button" class="btn btn-secondary" data-dismiss="modal">Close
226 </button>
227 <button type="submit" class="btn btn-primary">Save changes</button>
228 </div>
229 </form>
230 </div>
231
232 </div>
233 </div>
234 </div>
235
236 @endforeach
237 </tbody>
238 </table>
239
240 </div>
241 </div>
242 </div>
243 </div>
244 </div>
245
246
247 <div class="modal fade" id="createModal" tabindex="-1" role="dialog" aria-hidden="true">
248 <div class="modal-dialog modal-dialog-centered modal-lg" role="document">
249 <div class="modal-content">
250 <div class="modal-header">
251 <h5 class="modal-title" id="exampleModalCenterTitle">Create user</h5>
252 <button type="button" class="close" data-dismiss="modal" aria-label="Close">
253 <i class="ti-close"></i>
254 </button>
255 </div>
256 <div class="modal-body">
257 <form action="{{ route("dashboard.users.store") }}" method="post" accept-charset="utf-8" enctype='multipart/form-data'>
258 @csrf
259 <div class="row">
260 <div class="col-md-6">
261 <div class="form-group">
262 <label>Name</label>
263 <input type="text" name="name" value="{{ old('name') }}" minlength="2" maxlength="25" pattern="[a-zA-Zа-шА-Ш._\s]+" class="form-control" placeholder="Name" required>
264 </div>
265 </div>
266 <div class="col-md-6">
267 <div class="form-group">
268 <label>Surname</label>
269 <input type="text" name="surname" value="{{ old('surname') }}" minlength="2" maxlength="25" pattern="[a-zA-Zа-шА-Ш._\s]+" class="form-control" placeholder="Surname" required>
270 </div>
271 </div>
272 </div>
273 <div class="row">
274 <div class="col-md-6">
275 <div class="form-group">
276 <label class="form-label">Username</label>
277 <input type="text" name="username" value="{{ old('username') }}" minlength="5" maxlength="30" class="form-control" placeholder="Username" required>
278 </div>
279 </div>
280 <div class="col-md-6">
281 <div class="form-group">
282 <label class="form-label">Role</label>
283 <select class="form-control" name="userRole" required>
284 @foreach ($roles as $role)
285 <option value="{{ $role->id }}" {{ (old("userRole") == $role->id ? "selected" : "" ) }}>{{ $role->name }}</option>
286 @endforeach
287 </select>
288 </div>
289 </div>
290 </div>
291 <div class="row">
292 <div class="col-md-6">
293 <div class="form-group">
294 <label>Email</label>
295 <input type="email" name="email" value="{{ old('email') }}" class="form-control" placeholder="E-mail" required>
296 </div>
297 </div>
298 <div class="col-md-6">
299 <div class="form-group">
300 <label class="form-label">Phone Number</label>
301 <input type="text" name="phone_number" value="{{ old('phone_number') }}" class="form-control" placeholder="Phone number" autocomplete="off" required>
302 </div>
303 </div>
304 </div>
305 <div class="row">
306 <div class="col-md-6">
307 <div class="form-group">
308 <label>Avatar</label>
309 <input type="file" name="avatar" value="{{ old('avatar') }}" class="form-control" accept="image/*">
310 </div>
311 </div>
312 </div>
313 <div class="modal-footer">
314 <button type="button" class="btn btn-secondary" data-dismiss="modal">Close
315 </button>
316 <button type="submit" class="btn btn-primary">Save changes</button>
317 </div>
318 </form>
319 </div>
320 </div>
321 </div>
322 </div>
323
324
325
326@endsection
327
328@section('script')
329 @yield('script')
330 <script src="{{ url('assets/js/examples/pages/user-list.js') }}"></script>
331@endsection
Note: See TracBrowser for help on using the repository browser.