inventoryCompare.blade.php 11 KB

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