inventoryCompare.blade.php 15 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280
  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" :class="[checkData.length>0?'btn-dark text-light':'']"
  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. <label for="all" class="d-none" id="cloneCheckAll">
  95. <input id="all" type="checkbox" @click="checkAll($event)">全选
  96. </label>
  97. <table class="table table-sm text-nowrap table-bordered d-none" id="headerRoll"></table>
  98. <table class="table table-sm text-nowrap table-striped table-bordered m-0" id="headerParent">
  99. <tr class="p-0" id="header"></tr>
  100. <tr v-for="(inventoryCompare,i) in inventoryCompares">
  101. <td>
  102. <input type="checkbox" :value="inventoryCompare.id" v-model="checkData">
  103. </td>
  104. <td>@{{ i+1 }}</td>
  105. <td>@{{ inventoryCompare.owner_name }}</td>
  106. <td>@{{ inventoryCompare.mission_code }}</td>
  107. <td>@{{ inventoryCompare.created_at }}</td>
  108. <td>@{{ inventoryCompare.commodity_name }}</td>
  109. <td>@{{ inventoryCompare.commodity_sku }}</td>
  110. <td>
  111. <span v-if="inventoryCompare.commodity_barcodes && inventoryCompare.commodity_barcodes.length>0">
  112. <span v-if="inventoryCompare.commodity_barcodes.length==1">
  113. @{{ inventoryCompare.commodity_barcodes[0].code }}
  114. </span>
  115. <span v-if="inventoryCompare.commodity_barcodes.length>1">
  116. <small v-for="barcode in inventoryCompare.commodity_barcodes">@{{ barcode.code }}<br></small>
  117. </span>
  118. </span>
  119. </td>
  120. <td>@{{ inventoryCompare.custom_location }}</td>
  121. <td>@{{ inventoryCompare.quality }}</td>
  122. <td>@{{ inventoryCompare.amount_in_sys }}</td>
  123. <td>@{{ inventoryCompare.amount_in_compare }}</td>
  124. <td>@{{ inventoryCompare.differ }}</td>
  125. </tr>
  126. </table>
  127. {{$inventoryCompares->appends($param)->links()}}
  128. </div>
  129. </div>
  130. @endsection
  131. @section('lastScript')
  132. <script type="text/javascript" src="{{asset('js/queryForm/export200818a.js')}}"></script>
  133. <script type="text/javascript" src="{{asset('js/queryForm/queryForm200914.js')}}"></script>
  134. <script type="text/javascript" src="{{asset('js/queryForm/header200826b.js')}}"></script>
  135. <script>
  136. let vue = new Vue({
  137. el:"#container",
  138. data:{
  139. {{--inventoryCompares:{!! $inventoryCompares->toJson() !!}['data'],--}}
  140. inventoryCompares : [
  141. @foreach($inventoryCompares as $inventoryCompare)
  142. {id:'{{$inventoryCompare->id}}',owner_name:'{{$inventoryCompare->owner ? $inventoryCompare->owner->name : ''}}',
  143. created_at:'{{$inventoryCompare->created_at}}', commodity_name:'{{$inventoryCompare->commodity ? $inventoryCompare->commodity->name : ''}}',
  144. commodity_sku:'{{$inventoryCompare->commodity ? $inventoryCompare->commodity->sku : ''}}',
  145. commodity_barcodes:[
  146. @foreach($inventoryCompare->commodity ? $inventoryCompare->commodity->barcodes ?? [] : [] as $barcode)
  147. {code:'{{$barcode->code}}'},
  148. @endforeach
  149. ],
  150. custom_location:'{{$inventoryCompare->custom_location}}', quality:'{{$inventoryCompare->quality}}', amount_in_sys:'{{$inventoryCompare->amount_in_sys}}',
  151. amount_in_compare:'{{$inventoryCompare->amount_in_compare}}',
  152. differ:'{{$inventoryCompare->differ}}', mission_code:'{{$inventoryCompare->mission_code}}',
  153. },
  154. @endforeach
  155. ],
  156. differ:[
  157. {name:'全部',value:'全部'},{name:'有',value:'有'},{name:'无',value:'无'},
  158. ],
  159. owners : [
  160. @foreach($owners as $owner)
  161. {name:"{{$owner->id}}",value:"{{$owner->name}}"},
  162. @endforeach
  163. ],
  164. checkData:[],
  165. fakeOwners:'',
  166. isSubmit:false,
  167. },
  168. watch:{
  169. checkData:{
  170. handler(){
  171. if (this.checkData.length === this.inventoryCompares.length){
  172. document.querySelector('#all').checked = true;
  173. document.querySelector('#all_temp').checked = true;
  174. }else {
  175. document.querySelector('#all').checked = false;
  176. document.querySelector('#all_temp').checked = false;
  177. }
  178. },
  179. deep:true
  180. }
  181. },
  182. mounted(){
  183. $(".tooltipTarget").tooltip({'trigger': 'hover'});
  184. $("#container").removeClass('d-none');
  185. this.fakeOwners = this.owners;
  186. let data=[
  187. [
  188. {name:'date_start',type:'dateTime',tip:'选择创建日期的起始时间'},
  189. {name:'mission_code',type:'input',tip:'任务号:糊模查找需要在左边打上%符号',placeholder: '任务号'},
  190. {
  191. name: 'owner_id', type: 'select_multiple_select', tip: ['输入关键词快速定位下拉列表,回车确定', '选择要显示的客户'],
  192. placeholder: ['货主', '定位或多选货主'], data: this.owners
  193. },
  194. ],
  195. [
  196. {name:'date_end',type:'dateTime',tip:'选择创建日期的结束时间'},
  197. {name: 'differ', type: 'select', placeholder: '差值', data: this.differ},
  198. ],
  199. ];
  200. this.form = new query({
  201. el:'#form',
  202. condition:data,
  203. });
  204. this.form.init();
  205. let column = [
  206. {name:'cloneCheckAll',customization:true,type:'checkAll',column:'id',
  207. dom:$('#cloneCheckAll').removeClass('d-none'), neglect: true},
  208. {name:'index',value: '序号', neglect: true},
  209. {name:'owner_name',value: '货主'},
  210. {name:'mission_code',value: '任务号'},
  211. {name: 'created_at', value: '生成时间'},
  212. {name: 'commodity_name', value: '商品名称'},
  213. {name:'commodity_sku',value: '商品编码'},
  214. {name: 'commodity_barcodes', value: '商品条码', neglect: true},
  215. {name: 'amount', value: '属性仓', neglect: true},
  216. {name: 'quality', value: '质量状态', neglect: true},
  217. {name: 'amount_in_sys',value: '宝时库存', neglect: true},
  218. {name: 'amount_in_compare', value: '参考库存', neglect: true},
  219. {name: 'differ', value: '差值', neglect: true},
  220. ];
  221. let _this = this;
  222. setTimeout(function () {
  223. let header = new Header({
  224. el: "#header",
  225. column: column,
  226. data: _this.inventoryCompares,
  227. restorationColumn: 'id',
  228. fixedTop:($('#form').height())+2,
  229. vue:vue
  230. });
  231. header.init();
  232. },0);
  233. },
  234. methods:{
  235. //全选事件
  236. checkAll(e) {
  237. if (e.target.checked) {
  238. this.inventoryCompares.forEach((el) => {
  239. if (!el.id) this.checkData.push(el.id);
  240. if (el.id && this.checkData.indexOf(el.id) === -1) {
  241. this.checkData.push(el.id);
  242. }
  243. });
  244. } else {
  245. this.checkData = [];
  246. }
  247. },
  248. importExcel(){
  249. $('#importExcel').modal('show');
  250. },
  251. submitFrom(){
  252. let _this=this;
  253. _this.isSubmit=true;
  254. },
  255. flushView(){
  256. window.location.reload();
  257. },
  258. inventoryCompareExport(checkAllSign){
  259. let url = '{{url('inventory/statement/inventoryCompare/export')}}'
  260. let token='{{ csrf_token() }}';
  261. excelExport(checkAllSign,this.checkData,url,this.sum,token);
  262. },
  263. // 定位货主(e){
  264. // let target = $(e.target).val();
  265. // if(target === ''){
  266. // this.fakeOwners = this.owners;
  267. // }else{
  268. // this.fakeOwners = this.fakeOwners.filter(function(map){
  269. // return map.value.includes(target) ;
  270. // })
  271. // }
  272. // },
  273. },
  274. });
  275. </script>
  276. @endsection