index.blade.php 4.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102
  1. @extends('layouts.app')
  2. @section('title')用户@endsection
  3. @section('content')
  4. <span id="nav2">
  5. @component('maintenance.menu')@endcomponent
  6. @component('maintenance.user.menu')@endcomponent
  7. </span>
  8. <div class="container-fluid">
  9. <div class="card">
  10. <div class="card-body">
  11. @if(Session::has('successTip'))
  12. <div class="alert alert-success h1">{{Session::get('successTip')}}</div>
  13. @endif
  14. <table class="table table-striped table-sm" id="list">
  15. <tr>
  16. <th>ID</th>
  17. <th>用户名</th>
  18. <th>角色</th>
  19. <th>工作组</th>
  20. <th>配置承运商</th>
  21. <th>邮件地址</th>
  22. <th>创建时间</th>
  23. <th>操作</th>
  24. </tr>
  25. <tr v-for="user in users">
  26. <td class="text-muted">@{{user.id}}</td>
  27. <td>@{{user.name}}</td>
  28. <td>
  29. <span class="text-danger" v-if="user.isSuperAdmin">超级管理员</span>
  30. <ul v-if="user.roles.length>0" class="list-group">
  31. <li v-for="role in user.roles" style="list-style: none">@{{ role.name }}</li>
  32. </ul>
  33. </td>
  34. <td><span v-if="user.workgroup&&user.workgroup.length>0">@{{ user.workgroup[0].name }}</span></td>
  35. <td>
  36. <ul v-if="user.carriers.length>0" class="list-group">
  37. <li v-for="carrier in user.carriers" style="list-style: none">@{{ carrier.name }}</li>
  38. </ul>
  39. </td>
  40. <td>@{{user.email}}</td>
  41. <td class="text-muted">@{{user.created_at}}</td>
  42. <td>
  43. @can('用户-编辑')
  44. <button class="btn btn-sm btn-outline-primary" @click="edit(user.id)">改</button> @endcan
  45. @can('用户-删除')
  46. <button class="btn btn-sm btn-outline-dark" @click="destroy(user)">删</button> @endcan
  47. </td>
  48. </tr>
  49. </table>
  50. {{$users->links()}}
  51. </div>
  52. </div>
  53. </div>
  54. @endsection
  55. @section('lastScript')
  56. <script>
  57. new Vue({
  58. el:"#list",
  59. data:{
  60. users:[
  61. @foreach( $users as $user )
  62. {id:'{{$user->id}}',name:'{{$user->name}}',email:'{{$user->email}}',
  63. isSuperAdmin:'{{$user->isSuperAdmin}}',
  64. roles:{!! $user->roles !!},carriers:{!! $user->carriers !!},workgroup:{!! $user->userWorkgroups !!},created_at:'{{$user->created_at}}'},
  65. @endforeach
  66. ],
  67. },
  68. methods:{
  69. edit:function(id){
  70. location.href = "{{url('maintenance/user')}}/"+id+"/edit";
  71. },
  72. destroy:function(user){
  73. if(!confirm('确定要删除用户“' + user.name + '”吗?')){return};
  74. let data=this;
  75. let url = "{{url('maintenance/user')}}/"+user.id;
  76. axios.delete(url,{id:user.id})
  77. .then(function (response) {
  78. if(response.data.success){
  79. for (let i = 0; i < data.users.length; i++) {
  80. if (data.users[i].id===user.id){
  81. data.users.splice(i,1);
  82. break;
  83. }
  84. }
  85. tempTip.setDuration(1000);
  86. tempTip.showSuccess('删除用户"'+user.name+'"成功!')
  87. }else{
  88. tempTip.setDuration(1000);
  89. tempTip.show('删除用户"'+user.name+'"失败!')
  90. }
  91. })
  92. .catch(function (err) {
  93. tempTip.setDuration(3000);
  94. tempTip.show('删除用户失败!'+'网络错误:' + err)
  95. });
  96. },
  97. }
  98. });
  99. </script>
  100. @endsection