index.blade.php 6.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141
  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-striped table-sm td-min-width-80" id="table">
  17. <tr v-for="(user,i) in users" @click="selectTr===i+1?selectTr=0:selectTr=i+1" :class="selectTr===i+1?'focusing' : ''">
  18. <td><input class="checkItem" type="checkbox" :value="user.id"></td>
  19. <td class="text-muted"><span>@{{user.id}}</span></td>
  20. <td><span>@{{user.name}}</span></td>
  21. <td>
  22. <span class="text-danger" v-if="user.isSuperAdmin">超级管理员</span>
  23. <ul v-if="user.roles.length>0" class="list-group">
  24. <li v-for="role in user.roles" style="list-style: none">@{{ role.name }}</li>
  25. </ul>
  26. </td>
  27. <td><span v-if="user.workgroup&&user.workgroup.length>0">@{{ user.workgroup[0].name }}</span></td>
  28. <td>
  29. <ul v-if="user.logistics.length>0" class="list-group">
  30. <li v-for="logistic in user.logistics" style="list-style: none">@{{ logistic.name }}</li>
  31. </ul>
  32. </td>
  33. <td>
  34. <ul v-if="user.suppliers.length>0" class="list-group">
  35. <li v-for="supplier in user.suppliers" style="list-style: none">@{{ supplier.name }}</li>
  36. </ul>
  37. </td>
  38. <td><span>@{{user.email}}</span></td>
  39. <td class="text-muted"><span>@{{user.created_at}}</span></td>
  40. <td>
  41. @can('用户-编辑')
  42. <button class="btn btn-sm btn-outline-primary" @click="edit(user.id)">改</button> @endcan
  43. @can('用户-删除')
  44. <button class="btn btn-sm btn-outline-dark" @click="destroy(user)">删</button> @endcan
  45. </td>
  46. </tr>
  47. </table>
  48. {{$users->links()}}
  49. </div>
  50. </div>
  51. </div>
  52. </div>
  53. @endsection
  54. @section('lastScript')
  55. <script>
  56. </script>
  57. <script type="text/javascript" src="{{mix('js/queryForm/queryForm.js')}}"></script>
  58. <script type="text/javascript" src="{{mix('js/queryForm/header.js')}}"></script>{{--新版2--}}
  59. <script>
  60. new Vue({
  61. el:"#list",
  62. data:{
  63. users:{!! $users->toJson() !!}['data'],
  64. form:'',
  65. owners:[
  66. @foreach($owners as $owner)
  67. {name:'{{$owner->id}}',value:'{{$owner->name}}'},
  68. @endforeach
  69. ],
  70. selectTr:0
  71. },
  72. mounted:function(){
  73. let data = [
  74. [{name:'user',type:'input',tip:'用户名:可在两侧添加百分号(%)进行模糊搜索',placeholder:'用户名'},
  75. {name:'role',type:'input',tip:'可支持多角色名,模糊搜索可在两侧添加百分号(%)进行',placeholder:'角色名'},
  76. {name:'owner_id',type:'select_multiple_select',tip:['输入关键词快速定位下拉列表,回车确定','选择要显示的客户'],
  77. placeholder:['货主','定位或多选货主'],data:this.owners},
  78. ]
  79. ];
  80. this.form = new query({
  81. el: '#form_div',
  82. condition: data,
  83. });
  84. this.form.init();
  85. let column = [
  86. {name:'id',value: 'ID'},
  87. {name:'name',value: '用户名'},
  88. {name:'role_name',value: '角色', neglect: true},
  89. {name:'workgroup_name',value: '工作组', neglect: true},
  90. {name:'carrier_name',value: '配置承运商', neglect: true},
  91. {name:'supplier_name',value: '配置供应商', neglect: true},
  92. {name:'email',value: '邮件地址'},
  93. {name:'created_at',value: '创建时间'},
  94. {name:'operation',value: '操作', neglect: true},
  95. ];
  96. new Header({
  97. el:"table",
  98. name:"user",
  99. column: column,
  100. data: this.users,
  101. fixedTop: ($('#form_div').height())+2,
  102. isRestorationColumnAsc:true,
  103. isCheckAllBox:false,
  104. }).init();
  105. },
  106. methods:{
  107. edit:function(id){
  108. location.href = "{{url('maintenance/user')}}/"+id+"/edit";
  109. },
  110. destroy:function(user){
  111. if(!confirm('确定要删除用户“' + user.name + '”吗?'))return;
  112. let data=this;
  113. let url = "{{url('maintenance/user')}}/"+user.id;
  114. axios.delete(url,{id:user.id})
  115. .then(function (response) {
  116. if(response.data.success){
  117. for (let i = 0; i < data.users.length; i++) {
  118. if (data.users[i].id===user.id){
  119. data.users.splice(i,1);
  120. break;
  121. }
  122. }
  123. tempTip.setDuration(1000);
  124. tempTip.showSuccess('删除用户"'+user.name+'"成功!')
  125. }else{
  126. tempTip.setDuration(1000);
  127. tempTip.show('删除用户"'+user.name+'"失败!')
  128. }
  129. })
  130. .catch(function (err) {
  131. tempTip.setDuration(3000);
  132. tempTip.show('删除用户失败!'+'网络错误:' + err)
  133. });
  134. },
  135. }
  136. });
  137. </script>
  138. @endsection