delivering.blade.php 28 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476
  1. @extends('layouts.app')
  2. @section('title')订单管理@endsection
  3. @section('content')
  4. @component('order.index.menu')@endcomponent
  5. <div class="container-fluid">
  6. <div style="min-width: 4070px;">
  7. <div id="list" class="d-none">
  8. <div id="form_div"></div>
  9. <div class="ml-3 form-inline">
  10. <span class="dropdown">
  11. <button type="button" class="btn btn-outline-dark btn-sm form-control-sm dropdown-toggle tooltipTarget" :class="[checkData.length>0?'btn-dark text-light':'']"
  12. data-toggle="dropdown" title="导出所有页将会以搜索条件得到的过滤结果,将其全部记录(每一页)导出">
  13. 导出Excel
  14. </button>
  15. <div class="dropdown-menu">
  16. <a class="dropdown-item" @click="orderExport(false)" href="javascript:">导出勾选内容</a>
  17. <a class="dropdown-item" @click="orderExport(true)" href="javascript:">导出所有页</a>
  18. </div>
  19. </span>
  20. @can('订单管理-批量备注')<button @click="modal()" type="button" class="btn btn-sm ml-2 btn-outline-primary">批量备注追加</button>@endcan
  21. @can('订单管理-编辑')
  22. <span class="btn btn-sm tooltipTarget ml-2" @click="freezeAll" style="cursor: pointer" title="订单的冻结条件要只局限在“创建订单”,“分配完成”,“拣货完成”,“播种完成”"
  23. :class="[checkData.length>0?'btn-dark':'btn-outline-dark']">冻结</span>
  24. <span class="btn btn-sm tooltipTarget ml-2" @click="deAllocationAll" style="cursor: pointer" title="订单的取消分配条件要只局限在“分配完成”或“部分分配”"
  25. :class="[checkData.length>0?'btn-dark':'btn-outline-dark']">取消分配</span>
  26. @endcan
  27. </div>
  28. <div class="modal fade " style="top: 20%" id="myModal" tabindex="-1" role="dialog" aria-labelledby="myModalLabel" aria-hidden="true">
  29. <div class="modal-dialog">
  30. <div class="modal-content">
  31. <div class="modal-header">
  32. <button type="button" class="close" data-dismiss="modal" aria-hidden="true">&times;</button>
  33. </div>
  34. <div class="modal-body">
  35. <input class="form-control" v-model="content" placeholder="注释内容">
  36. </div>
  37. <div class="modal-footer">
  38. <button type="button" class="btn btn-default" data-dismiss="modal">关闭</button>
  39. <button type="button" @click="batchComments()" class="btn btn-primary">批量备注追加</button>
  40. </div>
  41. </div><!-- /.modal-content -->
  42. </div><!-- /.modal -->
  43. </div>
  44. <table class="table table-sm table-striped table-bordered table-hover card-body mt-2 ml-3">
  45. <tr class="text-nowrap">
  46. <th>
  47. <label for="all">
  48. <input id="all" type="checkbox" @click="checkAll($event)">全选
  49. </label>
  50. </th>
  51. <th>序号</th>
  52. <th>编号</th>
  53. <th>订单状态</th>
  54. <th>接口下发时间</th>
  55. <th>店铺名称</th>
  56. <th>客户</th>
  57. <th>客户订单号</th>
  58. <th>承运人</th>
  59. <th>快递单号</th>
  60. <th>收货人名称</th>
  61. <th>收货人电话</th>
  62. <th>省</th>
  63. <th>市</th>
  64. <th>区</th>
  65. <th style="min-width:320px;">收货人地址</th>
  66. <th>波次编号</th>
  67. <th>仓库</th>
  68. <th>快递获取标记</th>
  69. <th>快递获取时间</th>
  70. <th style="min-width: 150px">产品代码</th>
  71. <th style="min-width: 150px">产品条码</th>
  72. <th style="min-width: 180px">产品名称</th>
  73. <th>订单数量</th>
  74. <th style="min-width: 150px">明细状态</th>
  75. <th>复核时间</th>
  76. <th style="min-width:260px;">备注</th>
  77. <th>接口取消标记</th>
  78. <th>拣货单打印标记</th>
  79. <th>接口回传标记</th>
  80. <th>接口回传异常备注</th>
  81. <th>订单冻结</th>
  82. <th>取消分配</th>
  83. </tr>
  84. <tr v-for="(order,i) in orders" @click="selectedColor(order.orderno)" :style="{'font-weight': order.orderno==selectedStyle?'bold':''}">
  85. <td>
  86. <input class="checkItem" type="checkbox" :value="order.orderno" v-model="checkData">
  87. </td>
  88. <td>@{{ i+1 }}</td>
  89. <td class="text-dark font-weight-bold text-nowrap">@{{ order.orderno }}</td>
  90. <td class="text-muted text-nowrap">@{{ order.ordercodename }}</td>
  91. <td class="text-nowrap">@{{ order.addtime }}</td>
  92. <td class="text-nowrap">@{{ order.issuepartyname }}</td>
  93. <td class="text-nowrap">@{{ order.customer_descr_c }}</td>
  94. <td class="text-nowrap">@{{ order.soreference1 }}</td>
  95. <td class="text-muted text-nowrap">@{{ order.carriername }}</td>
  96. <td class="text-nowrap">
  97. <div v-if="picktotraceidMap[order.orderno] && picktotraceidMap[order.orderno].length>1" class="text-center">
  98. <span v-for="picktotraceid in picktotraceidMap[order.orderno]" v-if="order.is_unfold">
  99. @{{ picktotraceid }}<br>
  100. </span>
  101. <button class="btn btn-sm btn-outline-info" :style="order.is_unfold ? 'opacity:0.7' : ''" @click="isUnfold(order)">
  102. <span v-if="order.is_unfold" class="mt-1">收起</span>
  103. <span v-else>分箱 @{{ picktotraceidMap[order.orderno].length }} 件,展开单号</span>
  104. </button>
  105. </div>
  106. <span v-else>@{{ order.soreference5 }}</span>
  107. </td>
  108. <td class="text-muted text-nowrap">@{{ order.c_contact }}</td>
  109. <td class="text-muted text-nowrap">@{{ order.c_tel2 }}</td>
  110. <td class="text-nowrap"> @{{ order.c_province }}</td>
  111. <td class="text-nowrap"> @{{ order.c_city }}</td>
  112. <td class="text-nowrap"> @{{ order.c_district }}</td>
  113. <td class="text-muted">@{{ order.c_address1 }}</td>
  114. <td class="text-nowrap">@{{ order.waveno }}</td>
  115. <td class="text-nowrap"> @{{ order.warehouseid }}</td>
  116. <td class="text-nowrap"><span v-if="order.edisendflag2=='Y'">是</span><span v-if="order.edisendflag2=='N'">否</span><span v-if="order.edisendflag2=='W'">错误</span></td>
  117. <td class="text-nowrap">@{{ order.edisendtime2 }}</td>
  118. <td colspan="6" class="text-center">
  119. <table v-if="commodities[order.orderno]&&commodities[order.orderno].length==1 || isBtn[order.orderno]" class="table text-nowrap table-sm">
  120. <tr v-for="oracleDOCOrderDetail in commodities[order.orderno]">
  121. <td><div style="width: 180px;overflow: hidden">@{{ oracleDOCOrderDetail.sku }}</div></td>
  122. <td><div style="width: 180px;overflow: hidden">@{{ oracleDOCOrderDetail.alternate_sku1 }}</div></td>
  123. <td><div :title="oracleDOCOrderDetail.descr_c" class="tooltipTarget" style="width: 180px;overflow: hidden">@{{ oracleDOCOrderDetail.descr_c }}</div></td>
  124. <td>@{{ oracleDOCOrderDetail.qtyordered }}</td>
  125. <td><div style="width: 180px;overflow: hidden">@{{ oracleDOCOrderDetail.orderdetailcodename }}</div></td>
  126. <td><div style="width: 180px;overflow: hidden">@{{ oracleDOCOrderDetail.checktime }}</div></td>
  127. </tr>
  128. <tr v-if="isBtn[order.orderno]">
  129. <td colspan="5">
  130. <b style="cursor:pointer;color: #4aa0e6;" @click="isBtn[order.orderno]=false;">点击收起明细</b>
  131. </td>
  132. </tr>
  133. </table>
  134. <b @click="unfold(order.orderno)" style="cursor:pointer;text-decoration: underline;color: #4aa0e6;" v-if="commodities[order.orderno]&&commodities[order.orderno].length>1 && !isBtn[order.orderno]">共有 @{{ commodities[order.orderno].length }} 件商品,点击展开</b>
  135. </td>
  136. <td>@{{ order.notes }}</td>
  137. <td>@{{ order.erpcancelflag }}</td>
  138. <td>@{{ order.picking_print_flag }}</td>
  139. <td>@{{ order.edisendflag }}</td>
  140. <td>@{{ order.ediremarks2}}</td>
  141. <td>
  142. @can('订单管理-编辑')
  143. <button v-if="order.releasestatus!=='H'" @click="freeze(order.orderno,order.waveno)" class="btn btn-sm btn-outline-dark text-nowrap"
  144. :disabled="!(order.ordercodename==='创建订单'||order.ordercodename==='分配完成'||order.ordercodename==='拣货完成'||order.ordercodename==='播种完成')">冻结</button>
  145. <button v-else @click="thaw(order.orderno,order.waveno)" class="btn btn-sm btn-outline-danger text-nowrap"
  146. :disabled="!(order.ordercodename==='创建订单'||order.ordercodename==='分配完成'||order.ordercodename==='拣货完成'||order.ordercodename==='播种完成')">解冻</button>
  147. @else
  148. @{{ order.releasestatus }}
  149. @endcan
  150. </td>
  151. <td>
  152. @can('订单管理-编辑')
  153. <button v-if="order.sostatus=='40'||'30'" @click="deAllocation(order.orderno,order.waveno)" class="btn btn-sm btn-outline-dark text-nowrap"
  154. {{-- :disabled="!(order.codename_c==='分配完成'||order.codename_c==='部分分配')">取消分配</button>--}}
  155. :disabled="!(order.sostatus==='40'|| order.sostatus==='30')">取消分配</button>
  156. @else
  157. @{{ order.sostatus }}
  158. @endcan
  159. </td>
  160. </tr>
  161. </table>
  162. <button type="button" @click="pageUp()" :readonly="page>1?false:true" class="btn btn-sm " :class="page>1?'btn-outline-info':''">上一页</button>
  163. <button type="button" @click="pageDown()" :readonly="page<maxPage?false:true" class="btn btn-sm m-3" :class="page<maxPage?'btn-outline-info':''">下一页</button>
  164. <input @keyup.enter="pageSkip($event)" class="form-control-sm ml-3 tooltipTarget" :placeholder="'当前页数:'+page+'/'+maxPage" title="去往指定页">
  165. <span class="text-muted m-1">共 @{{ sum }} 条</span>
  166. </div>
  167. </div>
  168. </div>
  169. @endsection
  170. @section('lastScript')
  171. <script type="text/javascript" src="{{asset('js/queryForm/export200804.js')}}"></script>
  172. <script type="text/javascript" src="{{asset('js/queryForm/queryForm200804.js')}}"></script>
  173. <script>
  174. new Vue({
  175. el:"#list",
  176. data:{
  177. page:Number('{{$page}}'),
  178. maxPage:1,
  179. sum:0,
  180. checkData:[],
  181. owners:[
  182. @foreach($customers as $customer)
  183. { name:'{{$customer->customerid}}',value:'{{$customer->descr_c}}' },
  184. @endforeach
  185. ],
  186. orders:{!! $orders !!},
  187. commodities:{!! $commodities !!},
  188. isBtn:{},
  189. content:'',
  190. codes:[
  191. @foreach($codes as $code)
  192. {name:'{{$code->code}}',value:'{{$code->codename_c}}'},
  193. @endforeach
  194. ],
  195. selectedStyle:'',
  196. picktotraceidMap:{!! $picktotraceids !!},
  197. },
  198. mounted:function () {
  199. $(".tooltipTarget").tooltip({'trigger':'hover'});
  200. $("#list").removeClass('d-none');
  201. if (this.orders.length>0){
  202. this.maxPage=Math.ceil(this.orders[0].counted/50);
  203. this.sum=this.orders[0].counted;
  204. }
  205. let data=[
  206. [ {name:'codename_c',type:'select',placeholder:'订单状态',data:this.codes},
  207. {name:'orderdate_start',type:'time',tip:['选择显示日期的起始时间','选择显示日期的起始时间']},
  208. {name:'orderno',type:'input',tip:'编号,糊模查找需要在左边打上%符号',placeholder: '编号'},
  209. {name:'carriername',type:'input',tip:'',placeholder:'承运人'},
  210. {name:['notes','addtime'],type:'input_select',tip:['右侧选择查询范围,默认为一天内','查询范围,范围越短搜索越快'],placeholder: ['客户',''],
  211. data:[{name:'31',value:'近一月'},{name:'92',value:'近三月'},{name:'183',value:'近半年'},{name:'366',value:'近一年'},{name:'0',value:'不限'},]},
  212. {name:'issuepartyname',type:'input',tip:'',placeholder: '店铺名称'},
  213. {name:'edisendflag2',type:'select',tip:'快递获取标记',placeholder: '快递获取标记',data:[{name:'Y',value:'是'},{name:'N',value:'否'},{name:'W',value:'错误'},]},
  214. {name:'edisendflag',type:'select',tip:'接口回传标记',placeholder: '接口回传标记',data:[{name:'Y',value:'Y'},{name:'N',value:'N'},{name:'W',value:'W'},{name:'R',value:'R'},]}
  215. ],
  216. [
  217. {name:'codename_c_end',type:'select',placeholder:'订单状态范围',data:this.codes},
  218. {name:'customerid',type:'select_multiple_select',tip:['输入关键词快速定位下拉列表,回车确定','选择要显示的客户'],
  219. placeholder:['货主','定位或多选货主'],data:this.owners},
  220. {name:'orderdate_end',type:'time',tip:['选择显示指定日期的结束时间','选择显示指定日期的结束时间']},
  221. {name:'soreference5',type:'input',tip:'可支持多快递单号,糊模查找需要在左边打上%符号',placeholder: '多快递单号'},
  222. {name:'soreference1',type:'input',tip:'客户订单号,糊模查找需要在左边打上%符号',placeholder: '客户订单号'},
  223. {name:'waveno',type:'input',tip:'波次编号,模糊查找需要在左边打上%的符号',placeholder: '波次编号'},
  224. {name:'alternate_sku1',type:'input',tip:'产品条码,模糊查找需要在左边打上%的符号',placeholder: '产品条码'},
  225. ],
  226. ];
  227. this.form = new query({
  228. el:"#form_div",
  229. condition:data,
  230. });
  231. this.form.init();
  232. },
  233. watch:{
  234. checkData:{
  235. handler(){
  236. if (this.checkData.length === this.orders.length){
  237. document.querySelector('#all').checked = true;
  238. }else {
  239. document.querySelector('#all').checked = false;
  240. }
  241. },
  242. deep:true
  243. }
  244. },
  245. methods:{
  246. pageUp(){
  247. if (this.page<=1)return;
  248. this.href(this.page-1);
  249. },
  250. pageDown(){
  251. if (this.page>=this.maxPage)return;
  252. this.href(this.page+1);
  253. },
  254. pageSkip(e){
  255. if (Number(e.target.value)<=0 || Number(e.target.value)>this.maxPage){
  256. tempTip.setDuration(2000);
  257. tempTip.show('页数不存在! ');
  258. return
  259. }
  260. this.href(e.target.value);
  261. },
  262. href(page){
  263. let url = document.URL;
  264. if (url.indexOf('page='+this.page) != -1){
  265. url = url.replace("page="+this.page,"page="+page);
  266. }else{
  267. if (url.indexOf('?') == -1) url += "?page="+page;
  268. else url += "&page="+page;
  269. }
  270. window.location.href=url;
  271. },
  272. //全选事件
  273. checkAll(e){
  274. if (e.target.checked){
  275. this.orders.forEach((el,i)=>{
  276. if (this.checkData.indexOf(el.orderno) == '-1'){
  277. this.checkData.push(el.orderno);
  278. }
  279. });
  280. }else {
  281. this.checkData = [];
  282. }
  283. },
  284. unfold(orderno){
  285. this.$set(this.isBtn,orderno,true);
  286. setTimeout(function () {
  287. $(".tooltipTarget").tooltip({'trigger':'hover'});
  288. },1);
  289. },
  290. orderExport(checkAllSign){
  291. let url = '{{url('order/index/delivering')}}';
  292. let token='{{ csrf_token() }}';
  293. excelExport(checkAllSign,this.checkData,url,this.sum,token);
  294. },
  295. modal(){
  296. $("#myModal").modal('show');
  297. },
  298. //批量冻结
  299. freezeAll:function(){
  300. let _this=this;
  301. if(_this.checkData.length===0){
  302. tempTip.show('没有勾选记录');
  303. return
  304. }
  305. if(!confirm("确定要标记所有勾选内容为'冻结'吗")){return;}
  306. axios.post('{{url('order/freezeAll')}}',{checkData:_this.checkData}).then(function(response){
  307. if(response.data.success){
  308. _this.orders.forEach(function(order){
  309. _this.checkData.forEach(function (checkedId) {
  310. if(order.orderno===checkedId){
  311. order.releasestatus='H';
  312. order.waveno='*';
  313. }
  314. });
  315. });
  316. tempTip.setDuration(1000);
  317. tempTip.showSuccess('标记勾选内容为冻结成功');
  318. }else{
  319. tempTip.setDuration(2500);
  320. tempTip.show('标记勾选内容冻结失败,错误:'+response.data.fail_info);
  321. }
  322. }).catch(function (e) {
  323. alert('网络连接错误:'+e);
  324. tempTip.setDuration(2500);
  325. tempTip.show('标记勾选内容冻结失败,网络连接错误:'+e);
  326. })
  327. },
  328. //批量取消分配
  329. deAllocationAll(){
  330. let _this=this;
  331. if(_this.checkData.length===0){
  332. tempTip.show('没有勾选记录');
  333. return
  334. }
  335. if(!confirm("确定要所有勾选内容'取消分配'吗")){return;}
  336. axios.post('{{url('order/deAllocationAll')}}',{checkData:_this.checkData}).then(function(response){
  337. if(response.data.success){
  338. _this.orders.forEach(function(order){
  339. _this.checkData.forEach(function (checkedId) {
  340. if(order.orderno===checkedId){
  341. order.sostatus='00';
  342. order.waveno='*';
  343. }
  344. });
  345. });
  346. tempTip.setDuration(1000);
  347. tempTip.showSuccess('标记勾选内容取消分配成功');
  348. window.location.reload();
  349. }else{
  350. tempTip.setDuration(2500);
  351. tempTip.show('标记勾选内容取消分配失败,错误:'+response.data.fail_info);
  352. }
  353. }).catch(function (e) {
  354. alert('网络连接错误:'+e);
  355. tempTip.setDuration(2500);
  356. tempTip.show('标记勾选内容取消分配失败,网络连接错误:'+e);
  357. })
  358. },
  359. batchComments(){
  360. let _this=this;
  361. if (this.checkData.length<1 || !this.content) {
  362. $("#myModal").modal('hide');
  363. tempTip.setDuration(3000);
  364. if (this.checkData.length<1) tempTip.showSuccess('没有勾选任何记录');
  365. else tempTip.showSuccess('没有输入任何内容');
  366. return;
  367. }
  368. axios.post('{{url('order/create/batchComments')}}',{checkData:this.checkData,content:this.content})
  369. .then(function (response) {
  370. let sign=[];
  371. _this.orders.every(function (order) {
  372. if (sign.length===response.data.length)return false;
  373. response.data.every(function (data) {
  374. if (order.orderno===data.orderno){
  375. order.notes=data.notes;
  376. sign.push(order.orderno);
  377. return false;
  378. }
  379. return true;
  380. });
  381. return true;
  382. });
  383. tempTip.setDuration(3000);
  384. tempTip.showSuccess('注释完毕!')
  385. _this.content='';
  386. }).catch(function (err) {
  387. tempTip.setDuration(4000);
  388. tempTip.show('网络错误:'+err)
  389. });
  390. $("#myModal").modal('hide');
  391. },
  392. selectedColor(orderno){
  393. if (orderno==this.selectedStyle){
  394. this.selectedStyle='';
  395. return;
  396. }
  397. this.selectedStyle=orderno;
  398. },
  399. freeze(orderno,waveno){
  400. if(!confirm('确定要冻结“'+orderno+'”吗?'))return;
  401. let _this=this;
  402. axios.post('{{url('order/freeze')}}',{orderno:orderno,waveno:waveno})
  403. .then(function (response) {
  404. if (response.data.success){
  405. _this.orders.some(function (order) {
  406. if (order.orderno===orderno){
  407. order.releasestatus='H';
  408. order.waveno='*';
  409. return true;
  410. }
  411. });
  412. tempTip.setDuration(3000);
  413. tempTip.showSuccess('订单已被冻结!');
  414. }
  415. }).catch(function (err) {
  416. tempTip.setDuration(3000);
  417. tempTip.show('网络异常:'+err);
  418. });
  419. },
  420. thaw(orderno,waveno){
  421. if(!confirm('确定要解冻“'+orderno+'”吗?'))return;
  422. let _this=this;
  423. axios.post('{{url('order/thaw')}}',{orderno:orderno,waveno:waveno})
  424. .then(function (response) {
  425. if (response.data.success){
  426. _this.orders.some(function (order) {
  427. if (order.orderno===orderno){
  428. order.releasestatus='N';
  429. return true;
  430. }
  431. });
  432. tempTip.setDuration(3000);
  433. tempTip.showSuccess('订单已成功解冻!');
  434. }
  435. }).catch(function (err) {
  436. tempTip.setDuration(3000);
  437. tempTip.show('网络异常:'+err);
  438. });
  439. },
  440. deAllocation(orderno,waveno){
  441. if(!confirm('确定要取消分配“'+orderno+'”吗?'))return;
  442. let _this=this;
  443. axios.post('{{url('order/deAllocation')}}',{orderno:orderno,waveno:waveno})
  444. .then(function (response) {
  445. if (response.data.success){
  446. _this.orders.some(function (order) {
  447. if (order.orderno===orderno){
  448. order.sostatus='00';
  449. order.waveno='*';
  450. return true;
  451. }
  452. });
  453. tempTip.setDuration(3000);
  454. tempTip.showSuccess('订单已被取消分配!');
  455. window.location.reload();
  456. }
  457. }).catch(function (err) {
  458. tempTip.setDuration(3000);
  459. tempTip.show('网络异常:'+err);
  460. });
  461. },
  462. isUnfold(order){
  463. if (!order.is_unfold){
  464. this.$set(order,'is_unfold',true);
  465. return
  466. }
  467. order.is_unfold=false;
  468. }
  469. },
  470. });
  471. </script>
  472. @endsection