inventoryCompare.blade.php 13 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230
  1. @extends('layouts.app')
  2. @section('title')库存对比-库存管理@endsection
  3. @section('content')
  4. @component('inventory.statement.menu')@endcomponent
  5. <div class="d-none card" id="container">
  6. <div class="modal fade" id="importExcel" tabindex="-1" role="dialog" aria-labelledby="exampleModalLabel" aria-hidden="true">
  7. <div class="modal-dialog">
  8. <div class="modal-content">
  9. <div class="modal-header">
  10. <h5 class="modal-title" id="exampleModalLabel">导入相关excel</h5>
  11. <button type="button" class="close" data-dismiss="modal" aria-label="Close">
  12. <span aria-hidden="true">&times;</span>
  13. </button>
  14. </div>
  15. <div class="modal-body">
  16. <form method="POST" id="submitFrom" action="{{ url('inventory/inventoryCompare/import/excel') }}" enctype="multipart/form-data" target="_blank">
  17. @csrf
  18. <div class="form-group row text-center">
  19. <div class="col-12 text-danger">
  20. 注意:导入字段头必须有以下字段名在第一行表头行,不分顺序:<br>
  21. 产品编码,数量,属性仓<br>
  22. </div>
  23. <div class="col-12 text-info ">
  24. 导入时间随文件大小可能达数十分钟以上,请耐心等候
  25. <hr>
  26. </div>
  27. </div>
  28. <div class="form-group row">
  29. <label for="sku" class="col-2 col-form-label text-right">选择EXCEL</label>
  30. <div class="col-8">
  31. <div class="form-control">
  32. <input type="file" class="form-control-file @error('file') is-invalid @enderror"
  33. name="file" value="{{ old('file') }}" required>
  34. @error('file')
  35. <span class="invalid-feedback" role="alert">
  36. <strong>{{ $message }}</strong>
  37. </span>
  38. @enderror
  39. </div>
  40. </div>
  41. </div>
  42. {{-- <div class="form-group row">--}}
  43. {{-- <label for="sku" class="col-2 col-form-label text-right">选择货主</label>--}}
  44. {{-- <div class="col-3">--}}
  45. {{-- <select name="owner_id" id="owner_id" class="form-control @error('owner_id') is-invalid @enderror">--}}
  46. {{-- <option value="">货主</option>--}}
  47. {{-- <option v-for="owner in fakeOwners" :value="owner.name">@{{ owner.value }}</option>--}}
  48. {{-- </select>--}}
  49. {{-- @error('owner_id')--}}
  50. {{-- <span class="invalid-feedback" role="alert">--}}
  51. {{-- <strong>{{ $message }}</strong>--}}
  52. {{-- </span>--}}
  53. {{-- @enderror--}}
  54. {{-- </div>--}}
  55. {{-- <div class="col-5">--}}
  56. {{-- <input placeholder="定位货主" id="ownerName" autocomplete="off" class="form-control" @change="定位货主($event)">--}}
  57. {{-- </div>--}}
  58. {{-- </div>--}}
  59. <div class="form-group row">
  60. <div class="col-8 offset-2">
  61. <input type="submit" class="btn btn-success form-control" @click="submitFrom" value="执行导入">
  62. </div>
  63. </div>
  64. <div class="form-group row">
  65. <div class="col-8 offset-2">
  66. <span v-if="isSubmit" class="btn btn-sm btn-outline-info" @click="flushView">刷新页面</span>
  67. </div>
  68. </div>
  69. </form>
  70. </div>
  71. </div>
  72. </div>
  73. </div>
  74. <div class="card-header pt-0">
  75. <div id="form"></div>
  76. </div>
  77. <div class="w-100 ml-4 mt-0 mb-0">
  78. <span class="dropdown ">
  79. <button class="btn btn-outline-dark btn-sm form-control-sm dropdown-toggle tooltipTarget"
  80. data-toggle="dropdown" title="导出所有页将会以搜索条件得到的过滤结果,将其全部记录(每一页)导出">
  81. 导出Excel
  82. </button>
  83. <div class="dropdown-menu">
  84. <a class="dropdown-item" @click="inventoryCompareExport(false)" href="javascript:">导出勾选内容</a>
  85. <a class="dropdown-item" @click="inventoryCompareExport(true)" href="javascript:">导出所有页</a>
  86. </div>
  87. </span>
  88. <span>
  89. <button class="btn btn-outline-dark btn-sm form-control-sm tooltipTarget" title="导入Excel生成库存对比" @click="importExcel">导入</button>
  90. </span>
  91. </div>
  92. </span>
  93. <div class="card-body pt-1">
  94. <table class="table table-sm text-nowrap table-striped table-bordered m-0" id="table">
  95. <tr v-for="(inventoryCompare,i) in inventoryCompares">
  96. <td>
  97. <input type="checkbox" :value="inventoryCompare.id">
  98. </td>
  99. <td>@{{ i+1 }}</td>
  100. <td>@{{ inventoryCompare.owner_name }}</td>
  101. <td>@{{ inventoryCompare.mission_code }}</td>
  102. <td>@{{ inventoryCompare.created_at }}</td>
  103. <td>@{{ inventoryCompare.commodity_name }}</td>
  104. <td>@{{ inventoryCompare.commodity_sku }}</td>
  105. <td>
  106. <span v-if="inventoryCompare.commodity_barcodes && inventoryCompare.commodity_barcodes.length>0">
  107. <span v-if="inventoryCompare.commodity_barcodes.length==1">
  108. @{{ inventoryCompare.commodity_barcodes[0].code }}
  109. </span>
  110. <span v-if="inventoryCompare.commodity_barcodes.length>1">
  111. <small v-for="barcode in inventoryCompare.commodity_barcodes">@{{ barcode.code }}<br></small>
  112. </span>
  113. </span>
  114. </td>
  115. <td>@{{ inventoryCompare.custom_location }}</td>
  116. <td>@{{ inventoryCompare.quality }}</td>
  117. <td>@{{ inventoryCompare.amount_in_sys }}</td>
  118. <td>@{{ inventoryCompare.amount_in_compare }}</td>
  119. <td>@{{ inventoryCompare.differ }}</td>
  120. </tr>
  121. </table>
  122. <div class="text-info h5 btn btn">{{$inventoryCompares->count()}}/@{{ sum }}</div>
  123. {{$inventoryCompares->appends($param)->links()}}
  124. </div>
  125. </div>
  126. @endsection
  127. @section('lastScript')
  128. <script type="text/javascript" src="{{mix('js/queryForm/export.js')}}"></script>
  129. <script type="text/javascript" src="{{mix('js/queryForm/queryForm.js')}}"></script>
  130. <script type="text/javascript" src="{{mix('js/queryForm/header.js')}}"></script>{{--新版--}}
  131. <script>
  132. let vue = new Vue({
  133. el:"#container",
  134. data:{
  135. inventoryCompares : [
  136. @foreach($inventoryCompares as $inventoryCompare)
  137. {id:'{{$inventoryCompare->id}}',owner_name:'{{$inventoryCompare->owner ? $inventoryCompare->owner->name : ''}}',
  138. created_at:'{{$inventoryCompare->created_at}}', commodity_name:'{{$inventoryCompare->commodity ? $inventoryCompare->commodity->name : ''}}',
  139. commodity_sku:'{{$inventoryCompare->commodity ? $inventoryCompare->commodity->sku : ''}}',
  140. commodity_barcodes:[
  141. @foreach($inventoryCompare->commodity ? $inventoryCompare->commodity->barcodes ?? [] : [] as $barcode)
  142. {code:'{{$barcode->code}}'},
  143. @endforeach
  144. ],
  145. custom_location:'{{$inventoryCompare->custom_location}}', quality:'{{$inventoryCompare->quality}}', amount_in_sys:'{{$inventoryCompare->amount_in_sys}}',
  146. amount_in_compare:'{{$inventoryCompare->amount_in_compare}}',
  147. differ:'{{$inventoryCompare->differ}}', mission_code:'{{$inventoryCompare->mission_code}}',
  148. },
  149. @endforeach
  150. ],
  151. differ:[
  152. {name:'全部',value:'全部'},{name:'有',value:'有'},{name:'无',value:'无'},
  153. ],
  154. owners : [
  155. @foreach($owners as $owner)
  156. {name:"{{$owner->id}}",value:"{{$owner->name}}"},
  157. @endforeach
  158. ],
  159. sum:{!! $inventoryCompares->total() !!},
  160. fakeOwners:'',
  161. isSubmit:false,
  162. },
  163. mounted(){
  164. $(".tooltipTarget").tooltip({'trigger': 'hover'});
  165. $("#container").removeClass('d-none');
  166. this.fakeOwners = this.owners;
  167. let data=[
  168. [
  169. {name:'date_start',type:'dateTime',tip:'选择创建日期的起始时间'},
  170. {name:'mission_code',type:'input',tip:'任务号:糊模查找需要在左边打上%符号',placeholder: '任务号'},
  171. {
  172. name: 'owner_id', type: 'select_multiple_select', tip: ['输入关键词快速定位下拉列表,回车确定', '选择要显示的客户'],
  173. placeholder: ['货主', '定位或多选货主'], data: this.owners
  174. },
  175. ],
  176. [
  177. {name:'date_end',type:'dateTime',tip:'选择创建日期的结束时间'},
  178. {name: 'differ', type: 'select', placeholder: '差值', data: this.differ},
  179. ],
  180. ];
  181. this.form = new query({
  182. el:'#form',
  183. condition:data,
  184. });
  185. this.form.init();
  186. let column = [
  187. {name:'index',value: '序号', neglect: true},
  188. {name:'owner_name',value: '货主'},
  189. {name:'mission_code',value: '任务号'},
  190. {name: 'created_at', value: '生成时间'},
  191. {name: 'commodity_name', value: '商品名称'},
  192. {name:'commodity_sku',value: '商品编码'},
  193. {name: 'commodity_barcodes', value: '商品条码', neglect: true},
  194. {name: 'amount', value: '属性仓', neglect: true},
  195. {name: 'quality', value: '质量状态', neglect: true},
  196. {name: 'amount_in_sys',value: '宝时库存', neglect: true},
  197. {name: 'amount_in_compare', value: '参考库存', neglect: true},
  198. {name: 'differ', value: '差值', neglect: true},
  199. ];
  200. new Header({
  201. el: "table",
  202. column: column,
  203. data: this.inventoryCompares,
  204. fixedTop:($('#form').height())+2,
  205. }).init();
  206. },
  207. methods:{
  208. importExcel(){
  209. $('#importExcel').modal('show');
  210. },
  211. submitFrom(){
  212. let _this=this;
  213. _this.isSubmit=true;
  214. },
  215. flushView(){
  216. window.location.reload();
  217. },
  218. inventoryCompareExport(checkAllSign){
  219. let url = '{{url('inventory/statement/inventoryCompare/export')}}'
  220. let token='{{ csrf_token() }}';
  221. excelExport(checkAllSign,checkData,url,this.sum,token);
  222. },
  223. },
  224. });
  225. </script>
  226. @endsection