index.blade.php 6.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126
  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 id="form_div"></div>
  11. <div class="card-body">
  12. @if(Session::has('successTip'))
  13. <div class="alert alert-success h1">{{Session::get('successTip')}}</div>
  14. @endif
  15. <div id="list">
  16. <table class="table table-bordered table-sm d-none" id="headerRoll"></table>
  17. <table class="table table-striped table-sm" id="headerParent">
  18. <tr id="header"></tr>
  19. <tr v-for="user in users">
  20. <td class="text-muted">@{{user.id}}</td>
  21. <td>@{{user.name}}</td>
  22. <td>
  23. <span class="text-danger" v-if="user.isSuperAdmin">超级管理员</span>
  24. <ul v-if="user.roles.length>0" class="list-group">
  25. <li v-for="role in user.roles" style="list-style: none">@{{ role.name }}</li>
  26. </ul>
  27. </td>
  28. <td><span v-if="user.workgroup&&user.workgroup.length>0">@{{ user.workgroup[0].name }}</span></td>
  29. <td>
  30. <ul v-if="user.carriers.length>0" class="list-group">
  31. <li v-for="carrier in user.carriers" style="list-style: none">@{{ carrier.name }}</li>
  32. </ul>
  33. </td>
  34. <td>@{{user.email}}</td>
  35. <td class="text-muted">@{{user.created_at}}</td>
  36. <td>
  37. @can('用户-编辑')
  38. <button class="btn btn-sm btn-outline-primary" @click="edit(user.id)">改</button> @endcan
  39. @can('用户-删除')
  40. <button class="btn btn-sm btn-outline-dark" @click="destroy(user)">删</button> @endcan
  41. </td>
  42. </tr>
  43. </table>
  44. {{$users->links()}}
  45. </div>
  46. </div>
  47. </div>
  48. </div>
  49. @endsection
  50. @section('lastScript')
  51. <script type="text/javascript" src="{{asset('js/queryForm/queryForm200818a.js')}}"></script>
  52. <script type="text/javascript" src="{{asset('js/queryForm/header200819.js')}}"></script>
  53. <script>
  54. new Vue({
  55. el:"#list",
  56. data:{
  57. users:[
  58. @foreach( $users as $user )
  59. {id:'{{$user->id}}',name:'{{$user->name}}',email:'{{$user->email}}',
  60. isSuperAdmin:'{{$user->isSuperAdmin}}',
  61. roles:{!! $user->roles !!},carriers:{!! $user->carriers !!},workgroup:{!! $user->userWorkgroups !!},created_at:'{{$user->created_at}}'},
  62. @endforeach
  63. ],
  64. form:'',
  65. },
  66. mounted:function(){
  67. let data = [[{name:'name',type:'input',tip:'用户名:可在两侧添加百分号(%)进行模糊搜索',placeholder:'用户名'},
  68. {name:'role',type:'input',tip:'角色名:可在两侧添加百分号(%)进行模糊搜索',placeholder:'角色名'}]];
  69. this.form = new query({
  70. el: '#form_div',
  71. condition: data,
  72. })
  73. this.form.init();
  74. let column = [
  75. {name:'id',value: 'ID'},
  76. {name:'name',value: '用户名'},
  77. {name:'role_name',value: '角色', neglect: true},
  78. {name:'workgroup_name',value: '工作组', neglect: true},
  79. {name:'carrier_name',value: '配置承运商', neglect: true},
  80. {name:'email',value: '邮件地址'},
  81. {name:'created_at',value: '创建时间'},
  82. {name:'operation',value: '操作', neglect: true},
  83. ];
  84. let header = new Header({
  85. column: column,
  86. data: this.users,
  87. restorationColumn: 'id',
  88. is_restorationColumn_asc:true,
  89. });
  90. header.init();
  91. },
  92. methods:{
  93. edit:function(id){
  94. location.href = "{{url('maintenance/user')}}/"+id+"/edit";
  95. },
  96. destroy:function(user){
  97. if(!confirm('确定要删除用户“' + user.name + '”吗?'))return;
  98. let data=this;
  99. let url = "{{url('maintenance/user')}}/"+user.id;
  100. axios.delete(url,{id:user.id})
  101. .then(function (response) {
  102. if(response.data.success){
  103. for (let i = 0; i < data.users.length; i++) {
  104. if (data.users[i].id===user.id){
  105. data.users.splice(i,1);
  106. break;
  107. }
  108. }
  109. tempTip.setDuration(1000);
  110. tempTip.showSuccess('删除用户"'+user.name+'"成功!')
  111. }else{
  112. tempTip.setDuration(1000);
  113. tempTip.show('删除用户"'+user.name+'"失败!')
  114. }
  115. })
  116. .catch(function (err) {
  117. tempTip.setDuration(3000);
  118. tempTip.show('删除用户失败!'+'网络错误:' + err)
  119. });
  120. },
  121. }
  122. });
  123. </script>
  124. @endsection