index.blade.php 8.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177
  1. @extends('layouts.app')
  2. @section('title')单位@endsection
  3. @section('content')
  4. <div class="container-fluid" id="list" @drop="drop($event)" @dragover="dragover($event, false)">
  5. <div class="modal fade" tabindex="-1" role="dialog" id="modal">
  6. <div class="modal-dialog modal-lg modal-dialog-centered">
  7. <div class="modal-content">
  8. <div class="modal-header">
  9. <button type="button" class="close" data-dismiss="modal">&times;</button>
  10. </div>
  11. <div class="modal-body">
  12. <div class="row">
  13. <label class="col-2 offset-1" for="name">名称</label>
  14. <input class="col-7 form-control form-control-sm" :class="errors.name ? 'is-invalid' : ''" id="name" type="text" v-model="unit.name">
  15. <span class="invalid-feedback mt-0 offset-3" role="alert" v-if="errors.name">
  16. <strong>@{{ errors.name[0] }}</strong>
  17. </span>
  18. </div>
  19. </div>
  20. <div class="modal-footer">
  21. <button type="button" class="btn btn-success" @click="submitUnit()">提交</button>
  22. </div>
  23. </div>
  24. </div>
  25. </div>
  26. <div class="card">
  27. <div class="card-body">
  28. @can("计量单位-录入")<button class="btn btn-outline-info mb-1 mr-3" @click="openModal()"><span class="fa fa-plus"></span>&nbsp;新&nbsp;&nbsp;增</button>@endcan
  29. @can("计量单位-录入")<button class="btn border border-2 mb-1 mr-3" :class="isSaveSort ? 'btn-success' : 'text-secondary'" :disabled="!isSaveSort" @click="sort()"> 保 存 </button>@endcan
  30. <table class="table table-striped table-sm">
  31. <tr>
  32. <th>ID</th>
  33. <th>计量单位名称</th>
  34. <th>录入时间</th>
  35. <th>操作</th>
  36. </tr>
  37. <tbody id="parent">
  38. <tr v-for="(u,i) in units" draggable="true" :id="'unit-'+u.id" :data-order="u.sequence" :data-id="u.id"
  39. @click="selectTr===i+1?selectTr=0:selectTr=i+1" :class="selectTr===i+1?'focusing' : ''"
  40. @drop="drop($event)" @dragover="dragover($event)" @dragstart="dragstart(u.id)" style="cursor: move">
  41. <td class="text-muted">@{{u.id}}</td>
  42. <td>@{{u.name}}</td>
  43. <td class="text-muted">@{{u.created_at}}</td>
  44. <td>
  45. @can('计量单位-编辑')
  46. <button class="btn btn-sm btn-outline-primary" @click="openModal(u)">改</button> @endcan
  47. @can('计量单位-删除')
  48. <button class="btn btn-sm btn-outline-dark" @click="destroy(u)">删</button> @endcan
  49. </td>
  50. </tr>
  51. <tr id="dragover-container" class="border-dashed-red" v-if="isDragover" @drop="drop($event)" @dragover="dragover($event,false)">
  52. <td colspan='4' class='text-secondary'><div class='w-100 text-center'>拖拽至此</div></td>
  53. </tr>
  54. </tbody>
  55. </table>
  56. {{$units->links()}}
  57. </div>
  58. </div>
  59. </div>
  60. @endsection
  61. @section('lastScript')
  62. <script>
  63. new Vue({
  64. el:"#list",
  65. data:{
  66. units:[
  67. @foreach( $units as $unit)
  68. {id:'{{$unit->id}}',name:'{{$unit->name}}',created_at:'{{$unit->created_at}}',sequence:'{{$unit->sequence}}'},
  69. @endforeach
  70. ],
  71. selectTr:0,
  72. unit:{},
  73. errors:{},
  74. dragoverId:"",
  75. isDragover : false,
  76. isSaveSort : false,
  77. },
  78. methods:{
  79. edit:function(id){
  80. location.href = "{{url('maintenance/unit')}}/"+id+"/edit";
  81. },
  82. destroy:function(unit){
  83. if(!confirm('确定要删除单位“' + unit.name + '”吗?'))return;
  84. let data=this;
  85. let url = "{{url('maintenance/unit')}}/"+unit.id;
  86. window.axios.delete(url,{id:unit.id})
  87. .then(function (response) {
  88. if(response.data.success){
  89. for (let i = 0; i < data.units.length; i++) {
  90. if (data.units[i].id===unit.id){
  91. data.units.splice(i,1);
  92. break;
  93. }
  94. }
  95. tempTip.setDuration(1000);
  96. tempTip.showSuccess('删除单位"'+unit.name+'"成功!')
  97. }else{
  98. tempTip.setDuration(1000);
  99. tempTip.show('删除单位"'+unit.name+'"失败!')
  100. }
  101. }).catch(function (err) {
  102. tempTip.setDuration(3000);
  103. tempTip.show('删除单位失败!'+'网络错误:' + err);
  104. });
  105. },
  106. openModal(unit = null){
  107. if (unit) this.unit={id:unit.id,name:unit.name};
  108. else this.tag={id:"",name:""};
  109. $("#modal").modal("show");
  110. },
  111. submitUnit(){
  112. let url="{{url('maintenance/unit/save')}}";
  113. let msg=this.unit.id ? "成功修改单位“"+this.unit.name+"”" : "成功新增单位“"+this.unit.name+"”";
  114. window.tempTip.postBasicRequest(url,this.unit,(res)=>{
  115. if(res && res.errors){
  116. this.errors = res.errors;
  117. return '';
  118. }
  119. if (this.unit.id){
  120. this.units.some((unit)=> {
  121. if (unit.id === this.unit.id){
  122. unit.name = this.unit.name;
  123. return true;
  124. }
  125. });
  126. }else this.units.unshift({
  127. id:res.id,
  128. name:res.name,
  129. created_at:res.created_at,
  130. });
  131. $("#modal").modal("hide");
  132. return msg;
  133. },true);
  134. },
  135. dragover(e, isAllow = true){
  136. e.preventDefault();
  137. e.stopPropagation();
  138. if (isAllow) e.currentTarget.after(document.getElementById("dragover-container"))
  139. },
  140. dragstart(id){
  141. $("#unit-"+id).after($("#dragover-container"));
  142. this.dragoverId = id;
  143. this.isDragover = true;
  144. },
  145. drop(e){
  146. e.preventDefault();
  147. e.stopPropagation();
  148. $("#dragover-container").after($("#unit-"+this.dragoverId));
  149. this.dragoverId = "";
  150. this.isDragover = false;
  151. this.isSaveSort = true;
  152. },
  153. sort(){
  154. let parent = document.getElementById("parent").children;
  155. let update = [["id","sequence"]];
  156. for (let i=0;i<parent.length;i++){
  157. let order = parent[i].getAttribute("data-order");
  158. let id = parent[i].getAttribute("data-id");
  159. if (id && order !== i+1)update.push({id:id,sequence:i+1});
  160. }
  161. if (update.length > 1){
  162. let url = "{{url('maintenance/unit/sort')}}";
  163. window.tempTip.postBasicRequest(url,{"update":update},res=>{
  164. this.isSaveSort = false;
  165. return "";
  166. });
  167. }else this.isSaveSort = false;
  168. },
  169. }
  170. });
  171. </script>
  172. @endsection