index.blade.php 9.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185
  1. @extends('layouts.app')
  2. @section('title')入库管理@endsection
  3. @section('content')
  4. <span id="nav2">
  5. @component('store.menu')@endcomponent
  6. @component('store.inStorage.menu')@endcomponent
  7. </span>
  8. <div class="d-none container-fluid" id="list">
  9. <div id="form_div"></div>
  10. <label for="all" class="d-none" id="cloneCheckAll">
  11. <input id="all" type="checkbox" @click="checkAll($event)">全选
  12. </label>
  13. <table class="table table-sm text-nowrap table-bordered d-none" id="headerRoll"></table>
  14. <table class="table table-striped table-sm text-nowrap table-hover" id="headerParent">
  15. <tr id="header"></tr>
  16. <tr v-for="(store,i) in stores" :id="'data-'+store.id">
  17. <td>
  18. <input class="checkItem" type="checkbox" :value="store.id" v-model="checkData">
  19. </td>
  20. <td>
  21. <button class="btn btn-sm btn-outline-info" v-if="!store.isOpenStoreItem" @click="openStoreItems(store,i,$event);store.isOpenStoreItem=true">查看明细</button>
  22. <button v-if="store.isOpenStoreItem" @click="closeStoreItems();store.isOpenStoreItem=false" class="btn btn-sm btn-dark">收起明细</button>
  23. </td>
  24. <td>@{{ i+1 }}</td>
  25. <td >@{{store.asn_code}}</td>
  26. <td class="text-muted">@{{store.warehouse.name}}</td>
  27. <td >@{{store.owner.name}}</td>
  28. <td >@{{store.stored_method}}</td>
  29. <td >@{{store.status}}</td>
  30. <td>@{{store.remark}}</td>
  31. <td class="text-muted">@{{store.created_at}}</td>
  32. </tr>
  33. <tr id="showStoreItem" v-show="store.store_items">
  34. <td colspan="2"></td>
  35. <td colspan="16">
  36. <table class="table-sm table-bordered table-condensed">
  37. <tr>
  38. <th>行号</th>
  39. <th>商品名称</th>
  40. <th>商品编码</th>
  41. <th>商品条码</th>
  42. <th>数量</th>
  43. <th>质量</th>
  44. <th>状态</th>
  45. <th>创建时间</th>
  46. </tr>
  47. <tr v-for="storeItem in store.store_items">
  48. <td>@{{ storeItem.asn_line_code }}</td>
  49. <td>@{{ storeItem.name }}</td>
  50. <td>@{{ storeItem.sku }}</td>
  51. <td>@{{ storeItem.barcode }}</td>
  52. <td>@{{ storeItem.amount }}</td>
  53. <td>@{{ storeItem.quality }}</td>
  54. <td>@{{ storeItem.status }}</td>
  55. <td class="text-muted">@{{ storeItem.created_at }}</td>
  56. </tr>
  57. </table>
  58. </td>
  59. </tr>
  60. </table>
  61. <div class="text-info h5 btn btn">{{$stores->count()}}/{{$stores->total()}}</div>
  62. {{$stores->links()}}
  63. </div>
  64. @endsection
  65. @section('lastScript')
  66. <script type="text/javascript" src="{{mix('js/queryForm/queryForm.js')}}"></script>
  67. <script type="text/javascript" src="{{mix('js/queryForm/header.js')}}"></script>
  68. <script>
  69. let vue = new Vue({
  70. el:'#list',
  71. data:{
  72. stores:[
  73. @foreach($stores as $store)
  74. {!! $store !!},
  75. @endforeach
  76. ],
  77. owners:[
  78. @foreach($owners as $owner)
  79. {name:'{{$owner->id}}',value:'{{$owner->name}}'},
  80. @endforeach
  81. ],
  82. warehouses:[
  83. @foreach($warehouses as $warehouse)
  84. {name:'{{$warehouse->id}}',value:'{{$warehouse->name}}'},
  85. @endforeach
  86. ],
  87. store:{},
  88. checkData:[]
  89. },
  90. mounted:function(){
  91. $(".tooltipTarget").tooltip({'trigger':'hover'});
  92. $('#list').removeClass('d-none');
  93. let _this = this;
  94. let data=[
  95. [
  96. {name:'created_at_start',type:'dateTime',tip:'选择显示指定日期的起始时间'},
  97. {name:'owner_id',type:'select_multiple_select',tip:['输入关键词快速定位下拉列表,回车确定','选择要显示的货主'],
  98. placeholder:['货主','定位或多选货主'],data:this.owners},
  99. {name:'warehouse_id',type:'select_multiple_select',tip:['输入关键词快速定位下拉列表,回车确定','选择要显示的仓库'],
  100. placeholder:['仓库','定位或多选仓库'],data:this.warehouses},
  101. ],
  102. [
  103. {name:'created_at_end',type:'dateTime',tip:'选择显示指定日期的结束时间'},
  104. {name:'asn_code',type:'input',tip:'进场编号:支持15天内模糊搜索,15天外精确搜索',placeholder: 'ASN单号'},
  105. {name:'status',type:'select',placeholder: '订单状态',data:[{name:'完全收货',value:'完全收货'},{name:'部分收货',value:'部分收货'},
  106. {name:'已码盘',value:'已码盘'},{name:'订单创建',value:'订单创建'},{name:'ASN关闭',value:'ASN关闭'},{name:'等待释放',value:'等待释放'},{name:'收货取消',value:'收货取消'}]},
  107. {name:'stored_method',type:'select',placeholder: '入库类型',data:[{name:'采购入库',value:'采购入库'},{name:'笕尚退货入库单',value:'笕尚退货入库单'},
  108. {name:'笕尚进仓入库单',value:'笕尚进仓入库单'},{name:'笕尚移仓入库单',value:'笕尚移仓入库单'},{name:'笕尚调整入库单',value:'笕尚调整入库单'},
  109. {name:'B2B入库',value:'B2B入库'},{name:'换货入库',value:'换货入库'}, {name:'初始化库存',value:'初始化库存'},{name:'调拨入库',value:'调拨入库'},
  110. {name:'虚拟入库',value:'虚拟入库'}, {name:'退货入库',value:'退货入库'}, {name:'其他入库',value:'其他入库'},
  111. ]},
  112. ],
  113. ];
  114. this.form = new query({
  115. el:"#form_div",
  116. condition:data,
  117. });
  118. this.form.init();
  119. let column = [
  120. {name:'cloneCheckAll',customization:true,type:'checkAll',column:'id',
  121. dom:$('#cloneCheckAll').removeClass('d-none'), neglect: true},
  122. {name:'',value: '操作', neglect: true},
  123. {name:'index',value: '序号', neglect: true},
  124. {name:'asn_code',value: 'ASN编号'},
  125. {name:'warehouse_name',value: '仓库'},
  126. {name:'owner_name',value: '货主'},
  127. {name:'stored_method',value: '入库类型'},
  128. {name:'status',value: '状态'},
  129. {name:'remark',value: '备注'},
  130. {name:'created_at',value: '生成时间'},
  131. ];
  132. setTimeout(function () {
  133. let header = new Header({
  134. el: "#header",
  135. column: column,
  136. data: _this.stores,
  137. restorationColumn: 'id',
  138. vue:vue,
  139. });
  140. header.init();
  141. },0);
  142. },
  143. watch:{
  144. checkData:{
  145. handler(){
  146. if (this.checkData.length === this.stores.length){
  147. document.querySelector('#all').checked = true;
  148. document.querySelector('#all_temp').checked = true;
  149. }else {
  150. document.querySelector('#all').checked = false;
  151. document.querySelector('#all_temp').checked = false;
  152. }
  153. },
  154. deep:true
  155. }
  156. },
  157. methods:{
  158. openStoreItems(store,i,e){
  159. let _this=this;
  160. let id=store.id;
  161. _this.store=store;
  162. let showStoreItem=$('#showStoreItem');
  163. $("#data-" + id).after(showStoreItem);
  164. },
  165. closeStoreItems(){
  166. let _this=this;
  167. _this.store={};
  168. },
  169. checkAll(e){
  170. if (e.target.checked){
  171. this.stores.forEach((el,i)=>{
  172. if (this.checkData.indexOf(el.id) == '-1'){
  173. this.checkData.push(el.id);
  174. }
  175. });
  176. }else {
  177. this.checkData = [];
  178. }
  179. },
  180. }
  181. });
  182. </script>
  183. @endsection