index.blade.php 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225
  1. @extends('layouts.app')
  2. @section('title')查询-用户@endsection
  3. @section('content')
  4. <div class="container-fluid">
  5. <div class="card">
  6. <div id="form_div"></div>
  7. <div class="card-body">
  8. @if(Session::has('successTip'))
  9. <div class="alert alert-success h1">{{Session::get('successTip')}}</div>
  10. @endif
  11. <div id="list">
  12. @include("maintenance.user._resetPwd")
  13. @include("maintenance.user._allocationOwner")
  14. <table class="table table-striped table-sm td-min-width-80" id="table">
  15. <tr v-for="(user,i) in users" @click="selectTr===i+1?selectTr=0:selectTr=i+1" :class="selectTr===i+1?'focusing' : ''">
  16. <td class="text-muted"><span>@{{user.id}}</span></td>
  17. <td><span>@{{user.name}}</span></td>
  18. <td>
  19. <span class="text-danger" v-if="user.isSuperAdmin">超级管理员</span>
  20. <ul v-if="user.roles.length>0" class="list-group">
  21. <li v-for="role in user.roles" style="list-style: none">@{{ role.name }}</li>
  22. </ul>
  23. </td>
  24. <td><span v-if="user.work_groups && user.work_groups.length>0">
  25. <p v-for="group in user.work_groups">
  26. @{{ group.name }}
  27. </p>
  28. </span></td>
  29. <td>
  30. <ul v-if="user.logistics.length>0" class="list-group">
  31. <li v-for="logistic in user.logistics" style="list-style: none">@{{ logistic.name }}</li>
  32. </ul>
  33. </td>
  34. <td>
  35. <ul v-if="user.suppliers.length>0" class="list-group">
  36. <li v-for="supplier in user.suppliers" style="list-style: none">@{{ supplier.name }}</li>
  37. </ul>
  38. </td>
  39. <td><span>@{{user.email}}</span></td>
  40. <td class="text-muted"><span>@{{user.created_at}}</span></td>
  41. <td>
  42. @can('用户-编辑')
  43. <button class="btn btn-sm btn-warning" @click="openResetPwdModal(user)">重置密码</button>
  44. <button class="btn btn-sm btn-info ml-1" @click="allocationOwner(user)">分配货主</button>
  45. <button class="btn btn-sm btn-outline-primary ml-1" @click="edit(user.id)">改</button> @endcan
  46. @can('用户-删除')
  47. <button class="btn btn-sm btn-outline-dark" @click="destroy(user)">删</button> @endcan
  48. </td>
  49. </tr>
  50. </table>
  51. {{$users->links()}}
  52. </div>
  53. </div>
  54. </div>
  55. </div>
  56. @endsection
  57. @section('lastScript')
  58. <script>
  59. </script>
  60. <script type="text/javascript" src="{{mix('js/queryForm/queryForm.js')}}"></script>
  61. <script type="text/javascript" src="{{mix('js/queryForm/header.js')}}"></script>{{--新版2--}}
  62. <script>
  63. new Vue({
  64. el:"#list",
  65. data:{
  66. users:{!! $users->toJson() !!}['data'],
  67. form:'',
  68. owners:[
  69. @foreach($owners as $owner)
  70. {name:'{{$owner->id}}',value:'{{$owner->name}}'},
  71. @endforeach
  72. ],
  73. selectTr:0,
  74. user:{},
  75. switchStatus:false,
  76. switchOwner:[],
  77. },
  78. mounted:function(){
  79. let data = [
  80. [{name:'name',type:'input',tip:'用户名:可在两侧添加百分号(%)进行模糊搜索',placeholder:'用户名'},
  81. {name:'role',type:'input',tip:'可支持多角色名,模糊搜索可在两侧添加百分号(%)进行',placeholder:'角色名'},
  82. {name:'owners',type:'select_multiple_select',tip:['输入关键词快速定位下拉列表,回车确定','选择要显示的客户'],
  83. placeholder:['货主','定位或多选货主'],data:this.owners},
  84. ]
  85. ];
  86. this.form = new query({
  87. el: '#form_div',
  88. condition: data,
  89. });
  90. this.form.init();
  91. let column = [
  92. {name:'id',value: 'ID'},
  93. {name:'name',value: '用户名'},
  94. {name:'role_name',value: '角色', neglect: true},
  95. {name:'workgroup_name',value: '工作组', neglect: true},
  96. {name:'carrier_name',value: '配置承运商', neglect: true},
  97. {name:'supplier_name',value: '配置供应商', neglect: true},
  98. {name:'email',value: '邮件地址'},
  99. {name:'created_at',value: '创建时间'},
  100. {name:'operation',value: '操作', neglect: true},
  101. ];
  102. new Header({
  103. el:"table",
  104. name:"user",
  105. column: column,
  106. data: this.users,
  107. fixedTop: ($('#form_div').height())+2,
  108. isRestorationColumnAsc:true,
  109. isCheckAllBox:false,
  110. }).init();
  111. },
  112. methods:{
  113. edit:function(id){
  114. location.href = "{{url('maintenance/user')}}/"+id+"/edit";
  115. },
  116. destroy:function(user){
  117. if(!confirm('确定要删除用户“' + user.name + '”吗?'))return;
  118. let data=this;
  119. let url = "{{url('maintenance/user')}}/"+user.id;
  120. axios.delete(url,{id:user.id})
  121. .then(function (response) {
  122. if(response.data.success){
  123. for (let i = 0; i < data.users.length; i++) {
  124. if (data.users[i].id===user.id){
  125. data.users.splice(i,1);
  126. break;
  127. }
  128. }
  129. tempTip.setDuration(1000);
  130. tempTip.showSuccess('删除用户"'+user.name+'"成功!')
  131. }else{
  132. tempTip.setDuration(1000);
  133. tempTip.show('删除用户"'+user.name+'"失败!')
  134. }
  135. })
  136. .catch(function (err) {
  137. tempTip.setDuration(3000);
  138. tempTip.show('删除用户失败!'+'网络错误:' + err)
  139. });
  140. },
  141. openResetPwdModal(user){
  142. this.user = user;
  143. $("#modal").modal("show");
  144. },
  145. resetPwd(){
  146. window.tempTip.setIndex(1099);
  147. window.tempTip.setDuration(3000);
  148. if (this.user.pwd.length<6){
  149. window.tempTip.show("密码最少为六位");
  150. return;
  151. }
  152. if (this.user.pwd!==this.user.rePwd){
  153. window.tempTip.show("两次密码输入不一致");
  154. return;
  155. }
  156. window.tempTip.postBasicRequest("{{url('maintenance/user/resetPassword')}}",this.user,()=>{
  157. $("#modal").modal("hide");
  158. return "已重置用户:“"+this.user.name+"”的密码";
  159. },true);
  160. },
  161. allocationOwner(user){
  162. this.switchOwner = [];
  163. this._updateOwnerShow(this.switchStatus);
  164. this.user = user;
  165. if (!user.owners){
  166. window.tempTip.postBasicRequest("{{url('maintenance/user/getOwners')}}", {id:user.id},res=>{
  167. this.user.owners = res;
  168. this.switchOwner = res ? res : [];
  169. });
  170. }else{
  171. this.switchOwner = user.owners;
  172. }
  173. $("#allocation-owner").modal('show');
  174. },
  175. changeSwitchStatus(){
  176. if (!this.user.owners || this.user.owners.length===0){
  177. this._updateOwnerShow(this.switchStatus);
  178. }else{
  179. this.owners.forEach(owner=>{
  180. owner.hide = this.switchStatus && !(this.isExist(this.user.owners,owner.name) && this.switchStatus);
  181. });
  182. this.$forceUpdate();
  183. }
  184. },
  185. _updateOwnerShow(isHide){
  186. this.owners.forEach(owner=>{
  187. owner.hide = isHide;
  188. })
  189. this.$forceUpdate();
  190. },
  191. seekOwner(e){
  192. let val = e.target.value;
  193. this.owners.forEach(owner=>{
  194. if (owner.value.indexOf(val) > -1){
  195. owner.hide = !((this.switchStatus && this.isExist(this.user.owners,owner.name)) || !this.switchStatus);
  196. }else{
  197. owner.hide = true;
  198. }
  199. })
  200. this.$forceUpdate();
  201. },
  202. executeAllocation(){
  203. window.tempTip.postBasicRequest("{{url('maintenance/user/bindOwner')}}", {id:this.user.id,owners:this.switchOwner},()=>{
  204. this.user.owners = this.switchOwner;
  205. return "绑定成功";
  206. },true);
  207. },
  208. isExist(arr, tar){
  209. return arr.some(val=>{
  210. return val == tar;
  211. });
  212. },
  213. cloneTarget(){
  214. let val = $("#seek-owner").val();
  215. window.tempTip.postBasicRequest("{{url('maintenance/user/cloneBindOwner')}}", {id:this.user.id,target:val},()=>{
  216. return "克隆成功";
  217. },true);
  218. },
  219. }
  220. });
  221. </script>
  222. @endsection