inventoryCompare.blade.php 10 KB

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