dailyLog.blade.php 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227
  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="modal" tabindex="-1" role="dialog" aria-labelledby="pasteDataTitle" aria-hidden="true">
  6. <div class="modal-dialog modal-dialog-centered modal-lg" role="document">
  7. <div class="modal-content">
  8. <div class="modal-header row form-inline">
  9. <input type="text" v-model="name" class="form-control form-control-sm col-5 offset-3" placeholder="搜索货主,点击下方块添加" />
  10. <button class="btn btn-sm btn-info col-2" @click="seekOwner()">搜索</button>
  11. <label class="col-2"></label>
  12. </div>
  13. <div class="modal-body container row" style="text-align:center">
  14. <div class="col-2 mt-2" v-for="owner in owners">
  15. <div class="tooltipTarget" style="border: 1px solid #aac7ea;height: 80px;text-align: center;line-height: 80px;border-radius: 4px;cursor: pointer;overflow: hidden"
  16. :style="[{'background': loggingOwners.includes(Number(owner.name)) ? '#00FF00' : ''},
  17. {'box-shadow' : seekOwners.includes(owner.name) ? '0px 0px 10px 5px rgba(0,0,0,0.9)' : ''}]"
  18. @click="addLoggingOwner( owner.name,owner.value )" :title="owner.value">@{{ owner.value }}</div>
  19. </div>
  20. </div>
  21. </div>
  22. </div>
  23. </div>
  24. <div class="card-header pt-0">
  25. <div id="form"></div>
  26. </div>
  27. <div class="w-100 ml-4 mt-0 mb-0">
  28. <span class="dropdown">
  29. <button class="btn btn-outline-dark btn-sm form-control-sm dropdown-toggle tooltipTarget"
  30. data-toggle="dropdown" title="导出所有页将会以搜索条件得到的过滤结果,将其全部记录(每一页)导出">
  31. 导出Excel
  32. </button>
  33. <div class="dropdown-menu">
  34. <a class="dropdown-item" @click="dailyLogExport(false)" href="javascript:">导出勾选内容</a>
  35. <a class="dropdown-item" @click="dailyLogExport(true)" href="javascript:">导出所有页</a>
  36. </div>
  37. </span>
  38. @can('库存管理-库存体积-管理监听货主')<button class="btn btn-outline-info btn-sm tooltipTarget mt-1" @click="openModal()">管理监听货主</button>@endcan
  39. </div>
  40. <div class="card-body pt-1">
  41. <table class="table table-sm text-nowrap table-striped table-bordered m-0 td-min-width-80" id="table">
  42. <tr v-for="(inventoryDailyLog,i) in inventoryDailyLogs" @click="selectedColor(i,$event)">
  43. <td>
  44. <label><input type="checkbox" :value="inventoryDailyLog.id"></label>
  45. </td>
  46. <td><span>@{{ i+1 }}</span></td>
  47. <td><span>@{{ inventoryDailyLog.owner_name }}</span></td>
  48. <td><span>@{{ inventoryDailyLog.created_at }}</span></td>
  49. <td><span>@{{ inventoryDailyLog.commodity_name }}</span></td>
  50. <td><span>@{{ inventoryDailyLog.commodity_sku }}</span></td>
  51. <td>
  52. <span v-if="inventoryDailyLog.commodity_barcodes && inventoryDailyLog.commodity_barcodes.length>0">
  53. <span v-if="inventoryDailyLog.commodity_barcodes.length==1">
  54. @{{ inventoryDailyLog.commodity_barcodes[0].code }}
  55. </span>
  56. <span v-if="inventoryDailyLog.commodity_barcodes.length>1">
  57. <small v-for="barcode in inventoryDailyLog.commodity_barcodes">@{{ barcode.code }}<br></small>
  58. </span>
  59. </span>
  60. </td>
  61. <td><span>@{{ inventoryDailyLog.depository_name }}</span></td>
  62. <td><span>@{{ inventoryDailyLog.amount }}</span></td>
  63. <td><span>@{{ inventoryDailyLog.commodity_length }}</span></td>
  64. <td><span>@{{ inventoryDailyLog.commodity_width }}</span></td>
  65. <td><span>@{{ inventoryDailyLog.commodity_height }}</span></td>
  66. <td><span>@{{ inventoryDailyLog.commodity_volumn }}</span></td>
  67. <td><span>@{{ inventoryDailyLog.volumn_occupied }}</span></td>
  68. <td><span>@{{ inventoryDailyLog.gross_weight }}</span></td>
  69. </tr>
  70. </table>
  71. {{$inventoryDailyLogs->appends($param)->links()}}
  72. </div>
  73. </div>
  74. @endsection
  75. @section('lastScript')
  76. <script type="text/javascript" src="{{mix('js/queryForm/export.js')}}"></script>
  77. <script type="text/javascript" src="{{mix('js/queryForm/queryForm.js')}}"></script>
  78. <script type="text/javascript" src="{{mix('js/queryForm/header.js')}}"></script>{{--新版2--}}
  79. <script>
  80. let vue = new Vue({
  81. el:"#container",
  82. data:{
  83. inventoryDailyLogs : [
  84. @foreach($inventoryDailyLogs as $inventoryDailyLog)
  85. {id:'{{$inventoryDailyLog->id}}',owner_name:'{{$inventoryDailyLog->owner ? $inventoryDailyLog->owner->name : ''}}',
  86. created_at:'{{$inventoryDailyLog->created_at}}', commodity_name:'{{$inventoryDailyLog->commodity ? $inventoryDailyLog->commodity->name : ''}}',
  87. commodity_sku:'{{$inventoryDailyLog->commodity ? $inventoryDailyLog->commodity->sku : ''}}',
  88. commodity_barcodes:[
  89. @foreach($inventoryDailyLog->commodity ? $inventoryDailyLog->commodity->barcodes ?? [] : [] as $barcode)
  90. {code:'{{$barcode->code}}'},
  91. @endforeach
  92. ],
  93. amount:'{{$inventoryDailyLog->amount}}', commodity_length:'{{$inventoryDailyLog->commodity ? $inventoryDailyLog->commodity->length : ''}}',
  94. commodity_width:'{{$inventoryDailyLog->commodity ? $inventoryDailyLog->commodity->width : ''}}',
  95. commodity_height:'{{$inventoryDailyLog->commodity ? $inventoryDailyLog->commodity->height : ''}}',
  96. commodity_volumn:'{{$inventoryDailyLog->commodity ? $inventoryDailyLog->commodity->volumn : ''}}',
  97. volumn_occupied:'{{$inventoryDailyLog->volumn_occupied}}',
  98. depository_name:'{{$inventoryDailyLog->depository ? $inventoryDailyLog->depository->name : ''}}',
  99. gross_weight:'{{$inventoryDailyLog->gross_weight}}'},
  100. @endforeach
  101. ],
  102. owners : [
  103. @foreach($owners as $owner)
  104. {name:"{{$owner->id}}",value:"{{$owner->name}}"},
  105. @endforeach
  106. ],
  107. name : "",
  108. loggingOwners : [],
  109. seekOwners : [],
  110. sum:{!! $inventoryDailyLogs->total() !!},
  111. selectTr:''
  112. },
  113. mounted(){
  114. $(".tooltipTarget").tooltip({'trigger': 'hover'});
  115. $("#container").removeClass('d-none');
  116. let data=[
  117. [
  118. {name:'created_at_start',type:'dateTime',tip:'选择创建日期的起始时间'},
  119. {
  120. name: 'owner', type: 'select_multiple_select', tip: ['输入关键词快速定位下拉列表,回车确定', '选择要显示的客户'],
  121. placeholder: ['货主', '定位或多选货主'], data: this.owners
  122. },
  123. ],
  124. [
  125. {name:'created_at_end',type:'dateTime',tip:'选择创建日期的结束时间'},
  126. ],
  127. ];
  128. this.form = new query({
  129. el:'#form',
  130. condition:data
  131. });
  132. this.form.init();
  133. let column = [
  134. {name:'index',value: '序号', neglect: true},
  135. {name:'owner_name',value: '货主'},
  136. {name: 'created_at', value: '日期'},
  137. {name: 'commodity_name', value: '商品名称'},
  138. {name:'commodity_sku',value: '商品编码'},
  139. {name: 'commodity_barcodes', value: '商品条码', neglect: true},
  140. {name: 'depository_name', value: '属性仓'},
  141. {name: 'amount', value: '在库数量', neglect: true},
  142. {name: 'commodity_length', value: '长', neglect: true},
  143. {name: 'commodity_width',value: '宽', neglect: true},
  144. {name: 'commodity_height', value: '高', neglect: true},
  145. {name: 'commodity_volumn', value: '体积', neglect: true},
  146. {name: 'volumn_occupied', value: '总占用体积', neglect: true},
  147. {name: 'gross_weight', value: '总毛重', neglect: true},
  148. ];
  149. new Header({
  150. el: "table",
  151. name: "dailyLog",
  152. column: column,
  153. data: this.inventoryDailyLogs,
  154. restorationColumn: 'id',
  155. fixedTop:($('#form').height())+2,
  156. }).init();
  157. },
  158. methods:{
  159. selectedColor(id,e){
  160. $('#headerParent tr[class=focusing]').removeClass('focusing')
  161. if (id==this.selectTr){
  162. this.selectTr='';
  163. return;
  164. }
  165. this.selectTr=id;
  166. $(e.target).parent('tr').addClass('focusing')
  167. },
  168. openModal(){
  169. let url = "{{url('inventory/statement/dailyLog/getLoggingOwner')}}";
  170. axios.post(url).then(res=>{
  171. this.loggingOwners = res.data;
  172. $("#modal").modal('show');
  173. });
  174. },
  175. seekOwner(){
  176. if (!this.name)return ;
  177. let name = this.name;
  178. let seekOwners = [];
  179. this.owners.forEach(function (owner) {
  180. if ((owner.value).indexOf(name) !== -1){
  181. seekOwners.push(owner.name);
  182. }
  183. });
  184. if (seekOwners.length > 0)this.seekOwners = seekOwners;
  185. },
  186. addLoggingOwner(owner_id,name){
  187. if (!owner_id){
  188. alert('选中记录异常!');
  189. return;
  190. }
  191. if (this.loggingOwners.includes(Number(owner_id))){
  192. return;
  193. }
  194. if (!confirm("确定要添加对“"+name+"”的监听吗?"))return;
  195. let url = "{{url('inventory/statement/dailyLog/addLoggingOwner')}}";
  196. axios.post(url,{
  197. owner_id:owner_id
  198. }).then(res=>{
  199. tempTip.setDuration(2000);
  200. tempTip.setIndex(1099);
  201. if (res.data.success){
  202. this.loggingOwners.push(Number(res.data.data));
  203. this.seekOwners = [];
  204. tempTip.showSuccess('成功添加对“'+name+"的记录监听");
  205. tempTip.setIndex(99);
  206. return;
  207. }
  208. tempTip.show(res.data.data);
  209. tempTip.setIndex(99);
  210. }).catch(err=>{
  211. tempTip.setDuration(3000);
  212. tempTip.setIndex(1099);
  213. tempTip.show('网络连接错误:'+err);
  214. tempTip.setIndex(99);
  215. });
  216. },
  217. dailyLogExport(checkAllSign){
  218. let url = '{{url('inventory/statement/dailyLog/export')}}';
  219. let token='{{ csrf_token() }}';
  220. excelExport(checkAllSign,checkData,url,this.sum,token);
  221. },
  222. },
  223. });
  224. </script>
  225. @endsection