inventoryCompare.blade.php 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212
  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. <div class="col-8 offset-2">
  44. <input type="submit" class="btn btn-success form-control" @click="submitFrom" value="执行导入">
  45. </div>
  46. </div>
  47. <div class="form-group row">
  48. <div class="col-8 offset-2">
  49. <span v-if="isSubmit" class="btn btn-sm btn-outline-info" @click="flushView">刷新页面</span>
  50. </div>
  51. </div>
  52. </form>
  53. </div>
  54. </div>
  55. </div>
  56. </div>
  57. <div class="card-header pt-0">
  58. <div id="form"></div>
  59. </div>
  60. <div class="w-100 ml-4 mt-0 mb-0">
  61. <span class="dropdown ">
  62. <button class="btn btn-outline-dark btn-sm form-control-sm dropdown-toggle tooltipTarget"
  63. data-toggle="dropdown" title="导出所有页将会以搜索条件得到的过滤结果,将其全部记录(每一页)导出">
  64. 导出Excel
  65. </button>
  66. <div class="dropdown-menu">
  67. <a class="dropdown-item" @click="inventoryCompareExport(false)" href="javascript:">导出勾选内容</a>
  68. <a class="dropdown-item" @click="inventoryCompareExport(true)" href="javascript:">导出所有页</a>
  69. </div>
  70. </span>
  71. <span>
  72. <button class="btn btn-outline-info btn-sm form-control-sm tooltipTarget" title="导入Excel生成库存对比" @click="importExcel">导入</button>
  73. </span>
  74. </div>
  75. <div class="card-body pt-1">
  76. <table class="table table-sm text-nowrap table-striped table-bordered m-0 td-min-width-80" id="table">
  77. <tr v-for="(inventoryCompare,i) in inventoryCompares">
  78. <td>
  79. <input type="checkbox" :value="inventoryCompare.id">
  80. </td>
  81. <td><span>@{{ i+1 }}</span></td>
  82. <td><span>@{{ inventoryCompare.owner_name }}</span></td>
  83. <td><span>@{{ inventoryCompare.mission_code }}</span></td>
  84. <td><span>@{{ inventoryCompare.created_at }}</span></td>
  85. <td><span>@{{ inventoryCompare.commodity_name }}</span></td>
  86. <td><span>@{{ inventoryCompare.commodity_sku }}</span></td>
  87. <td>
  88. <span v-if="inventoryCompare.commodity_barcodes && inventoryCompare.commodity_barcodes.length>0">
  89. <span v-if="inventoryCompare.commodity_barcodes.length==1">
  90. @{{ inventoryCompare.commodity_barcodes[0].code }}
  91. </span>
  92. <span v-if="inventoryCompare.commodity_barcodes.length>1">
  93. <small v-for="barcode in inventoryCompare.commodity_barcodes">@{{ barcode.code }}<br></small>
  94. </span>
  95. </span>
  96. </td>
  97. <td><span>@{{ inventoryCompare.custom_location }}</span></td>
  98. <td><span>@{{ inventoryCompare.quality }}</span></td>
  99. <td><span>@{{ inventoryCompare.amount_in_sys }}</span></td>
  100. <td><span>@{{ inventoryCompare.amount_in_compare }}</span></td>
  101. <td><span>@{{ inventoryCompare.differ }}</span></td>
  102. </tr>
  103. </table>
  104. <div class="text-info h5 btn btn">{{$inventoryCompares->count()}}/@{{ sum }}</div>
  105. {{$inventoryCompares->appends($param)->links()}}
  106. </div>
  107. </div>
  108. @endsection
  109. @section('lastScript')
  110. <script type="text/javascript" src="{{mix('js/queryForm/export.js')}}"></script>
  111. <script type="text/javascript" src="{{mix('js/queryForm/queryForm.js')}}"></script>
  112. <script type="text/javascript" src="{{mix('js/queryForm/header.js')}}"></script>{{--新版2--}}
  113. <script>
  114. let vue = new Vue({
  115. el:"#container",
  116. data:{
  117. inventoryCompares : [
  118. @foreach($inventoryCompares as $inventoryCompare)
  119. {id:'{{$inventoryCompare->id}}',owner_name:'{{$inventoryCompare->owner ? $inventoryCompare->owner->name : ''}}',
  120. created_at:'{{$inventoryCompare->created_at}}', commodity_name:'{{$inventoryCompare->commodity ? $inventoryCompare->commodity->name : ''}}',
  121. commodity_sku:'{{$inventoryCompare->commodity ? $inventoryCompare->commodity->sku : ''}}',
  122. commodity_barcodes:[
  123. @foreach($inventoryCompare->commodity ? $inventoryCompare->commodity->barcodes ?? [] : [] as $barcode)
  124. {code:'{{$barcode->code}}'},
  125. @endforeach
  126. ],
  127. custom_location:'{{$inventoryCompare->custom_location}}', quality:'{{$inventoryCompare->quality}}', amount_in_sys:'{{$inventoryCompare->amount_in_sys}}',
  128. amount_in_compare:'{{$inventoryCompare->amount_in_compare}}',
  129. differ:'{{$inventoryCompare->differ}}', mission_code:'{{$inventoryCompare->mission_code}}',
  130. },
  131. @endforeach
  132. ],
  133. differ:[
  134. {name:'全部',value:'全部'},{name:'有',value:'有'},{name:'无',value:'无'},
  135. ],
  136. owners : [
  137. @foreach($owners as $owner)
  138. {name:"{{$owner->id}}",value:"{{$owner->name}}"},
  139. @endforeach
  140. ],
  141. sum:{!! $inventoryCompares->total() !!},
  142. fakeOwners:'',
  143. isSubmit:false,
  144. },
  145. mounted(){
  146. $(".tooltipTarget").tooltip({'trigger': 'hover'});
  147. $("#container").removeClass('d-none');
  148. this.fakeOwners = this.owners;
  149. let data=[
  150. [
  151. {name:'date_start',type:'dateTime',tip:'选择创建日期的起始时间'},
  152. {name:'mission_code',type:'input',tip:'可支持多任务号,糊模查找需要在右边打上%符号',placeholder: '任务号'},
  153. {
  154. name: 'owner_id', type: 'select_multiple_select', tip: ['输入关键词快速定位下拉列表,回车确定', '选择要显示的客户'],
  155. placeholder: ['货主', '定位或多选货主'], data: this.owners
  156. },
  157. ],
  158. [
  159. {name:'date_end',type:'dateTime',tip:'选择创建日期的结束时间'},
  160. {name: 'differ', type: 'select', placeholder: '差值', data: this.differ},
  161. ],
  162. ];
  163. this.form = new query({
  164. el:'#form',
  165. condition:data,
  166. });
  167. this.form.init();
  168. let column = [
  169. {name:'index',value: '序号', neglect: true},
  170. {name:'owner_name',value: '货主'},
  171. {name:'mission_code',value: '任务号'},
  172. {name: 'created_at', value: '生成时间'},
  173. {name: 'commodity_name', value: '商品名称'},
  174. {name:'commodity_sku',value: '商品编码'},
  175. {name: 'commodity_barcodes', value: '商品条码', neglect: true},
  176. {name: 'amount', value: '属性仓', neglect: true},
  177. {name: 'quality', value: '质量状态', neglect: true},
  178. {name: 'amount_in_sys',value: '宝时库存', neglect: true},
  179. {name: 'amount_in_compare', value: '参考库存', neglect: true},
  180. {name: 'differ', value: '差值', neglect: true},
  181. ];
  182. new Header({
  183. el: "table",
  184. name: "inventoryCompare",
  185. column: column,
  186. data: this.inventoryCompares,
  187. fixedTop:($('#form').height())+2,
  188. }).init();
  189. },
  190. methods:{
  191. importExcel(){
  192. $('#importExcel').modal('show');
  193. },
  194. submitFrom(){
  195. let _this=this;
  196. _this.isSubmit=true;
  197. },
  198. flushView(){
  199. window.location.reload();
  200. },
  201. inventoryCompareExport(checkAllSign){
  202. let url = '{{url('inventory/statement/inventoryCompare/export')}}'
  203. let token='{{ csrf_token() }}';
  204. excelExport(checkAllSign,checkData,url,this.sum,token);
  205. },
  206. },
  207. });
  208. </script>
  209. @endsection