delivering.blade.php 36 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595
  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. <button type="button" @click="thaw(checkData,true)" class="btn btn-sm btn-outline-danger tooltipTarget" title="解除已冻结订单">解冻</button>
  25. <span class="btn btn-sm tooltipTarget ml-2" @click="deAllocationAll" style="cursor: pointer" title="订单的取消分配条件要只局限在“分配完成”或“部分分配”"
  26. :class="[checkData.length>0?'btn-dark':'btn-outline-dark']">取消分配</span>
  27. <button type="button" @click="resetLogisticsGetMark()" class="btn btn-sm btn-outline-secondary">重置快递获取标记</button>
  28. @endcan
  29. @can('订单管理-订单问题件生成')<button @click="orderIssueTag()" type="button" class="btn btn-sm ml-2 btn-outline-primary ">标记问题件</button>@endcan
  30. </div>
  31. <div class="modal fade " style="top: 20%" id="myModal" tabindex="-1" role="dialog" aria-labelledby="myModalLabel" aria-hidden="true">
  32. <div class="modal-dialog">
  33. <div class="modal-content">
  34. <div class="modal-header">
  35. <button type="button" class="close" data-dismiss="modal" aria-hidden="true">&times;</button>
  36. </div>
  37. <div class="modal-body">
  38. <input class="form-control" v-model="content" placeholder="注释内容">
  39. </div>
  40. <div class="modal-footer">
  41. <button type="button" class="btn btn-default" data-dismiss="modal">关闭</button>
  42. <button type="button" @click="batchComments()" class="btn btn-primary">批量备注追加</button>
  43. </div>
  44. </div><!-- /.modal-content -->
  45. </div><!-- /.modal -->
  46. </div>
  47. <label for="all" id="cloneCheckAll" class="d-none">
  48. <input id="all" type="checkbox" @click="checkAll($event)">全选
  49. </label>
  50. <table class="table table-sm table-striped table-bordered table-hover card-body mt-2 ml-3 d-none" id="headerRoll"></table>
  51. <table class="table table-sm table-striped table-bordered table-hover card-body mt-2 ml-3" id="headerParent">
  52. <tr class="text-nowrap" id="header"></tr>
  53. <tr v-for="(order,i) in orders" @click="selectedColor(order.orderno)" :style="{'font-weight': order.orderno==selectedStyle?'bold':''}">
  54. <td>
  55. <input class="checkItem" type="checkbox" :value="order.orderno" v-model="checkData">
  56. </td>
  57. <td>@{{ i+1 }}</td>
  58. <td class="text-dark font-weight-bold text-nowrap">@{{ order.orderno }}</td>
  59. <td class="text-muted text-nowrap">@{{ order.ordercodename }}</td>
  60. <td class="text-nowrap">@{{ order.addtime }}</td>
  61. <td class="text-nowrap">@{{ order.issuepartyname }}</td>
  62. <td class="text-nowrap">@{{ order.customer_descr_c }}</td>
  63. <td class="text-nowrap">@{{ order.soreference1 }}</td>
  64. <td class="text-muted text-nowrap">@{{ order.carriername }}</td>
  65. <td class="text-nowrap">
  66. <div v-if="picktotraceidMap[order.orderno] && picktotraceidMap[order.orderno].length>1" class="text-center">
  67. <span v-for="picktotraceid in picktotraceidMap[order.orderno]" v-if="order.is_unfold">
  68. @{{ picktotraceid }}<br>
  69. </span>
  70. <button class="btn btn-sm btn-outline-info" :style="order.is_unfold ? 'opacity:0.7' : ''" @click="isUnfold(order)">
  71. <span v-if="order.is_unfold" class="mt-1">收起</span>
  72. <span v-else>分箱 @{{ picktotraceidMap[order.orderno].length }} 件,展开单号</span>
  73. </button>
  74. </div>
  75. <span v-else>@{{ order.soreference5 }}</span>
  76. </td>
  77. <td class="text-muted text-nowrap">@{{ order.c_contact }}</td>
  78. <td class="text-muted text-nowrap">@{{ order.c_tel2 }}</td>
  79. <td class="text-nowrap"> @{{ order.c_province }}</td>
  80. <td class="text-nowrap"> @{{ order.c_city }}</td>
  81. <td class="text-nowrap"> @{{ order.c_district }}</td>
  82. <td class="text-muted">@{{ order.c_address1 }}</td>
  83. <td class="text-nowrap">@{{ order.waveno }}</td>
  84. <td class="text-nowrap"> @{{ order.warehouseid }}</td>
  85. <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>
  86. <td class="text-nowrap">@{{ order.edisendtime2 }}</td>
  87. <td colspan="6" class="text-center">
  88. <table v-if="commodities[order.orderno]&&commodities[order.orderno].length==1 || isBtn[order.orderno]" class="table text-nowrap table-sm">
  89. <tr v-for="oracleDOCOrderDetail in commodities[order.orderno]">
  90. <td><div style="width: 180px;overflow: hidden">@{{ oracleDOCOrderDetail.sku }}</div></td>
  91. <td><div style="width: 180px;overflow: hidden">@{{ oracleDOCOrderDetail.alternate_sku1 }}</div></td>
  92. <td><div :title="oracleDOCOrderDetail.descr_c" class="tooltipTarget" style="width: 180px;overflow: hidden">@{{ oracleDOCOrderDetail.descr_c }}</div></td>
  93. <td>@{{ oracleDOCOrderDetail.qtyordered }}</td>
  94. <td><div style="width: 180px;overflow: hidden">@{{ oracleDOCOrderDetail.orderdetailcodename }}</div></td>
  95. <td><div style="width: 180px;overflow: hidden">@{{ oracleDOCOrderDetail.checktime }}</div></td>
  96. </tr>
  97. <tr v-if="isBtn[order.orderno]">
  98. <td colspan="6">
  99. <b style="cursor:pointer;color: #4aa0e6;" @click="isBtn[order.orderno]=false;">点击收起明细</b>
  100. </td>
  101. </tr>
  102. </table>
  103. <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>
  104. </td>
  105. <td>@{{ order.notes }}</td>
  106. <td>@{{ order.erpcancelflag }}</td>
  107. <td>@{{ order.picking_print_flag }}</td>
  108. <td>@{{ order.edisendflag }}</td>
  109. <td>@{{ order.ediremarks2}}</td>
  110. <td>
  111. @can('订单管理-编辑')
  112. <button v-if="order.releasestatus!=='H'" @click="freeze(order.orderno,order.waveno)" class="btn btn-sm btn-outline-dark text-nowrap"
  113. :disabled="!(order.ordercodename==='创建订单'||order.ordercodename==='分配完成'||order.ordercodename==='拣货完成'||order.ordercodename==='播种完成')">冻结</button>
  114. <button v-else @click="thaw(order.orderno,false,order)" class="btn btn-sm btn-outline-danger text-nowrap"
  115. :disabled="!(order.ordercodename==='创建订单'||order.ordercodename==='分配完成'||order.ordercodename==='拣货完成'||order.ordercodename==='播种完成')">解冻</button>
  116. @else
  117. @{{ order.releasestatus }}
  118. @endcan
  119. </td>
  120. <td>
  121. @can('订单管理-编辑')
  122. <button v-if="order.sostatus=='40'||'30'" @click="deAllocation(order.orderno,order.waveno)" class="btn btn-sm btn-outline-dark text-nowrap"
  123. {{-- :disabled="!(order.codename_c==='分配完成'||order.codename_c==='部分分配')">取消分配</button>--}}
  124. :disabled="!(order.sostatus==='40'|| order.sostatus==='30')">取消分配</button>
  125. @else
  126. @{{ order.sostatus }}
  127. @endcan
  128. </td>
  129. </tr>
  130. </table>
  131. <button type="button" @click="pageUp()" :readonly="page>1?false:true" class="btn btn-sm " :class="page>1?'btn-outline-info':''">上一页</button>
  132. <button type="button" @click="pageDown()" :readonly="maxPage == 0 ? false : (page<maxPage?false:true)" class="btn btn-sm m-3" :class="maxPage == 0 ? 'btn-outline-info' : (page<maxPage?'btn-outline-info':'')">下一页</button>
  133. <input @keyup.enter="pageSkip($event)" class="form-control-sm ml-3 tooltipTarget" :placeholder="pagePlaceholder" title="去往指定页">
  134. <span class="text-muted m-1" v-if="maxPage != 0">共 @{{ sum }} 条</span>
  135. </div>
  136. </div>
  137. </div>
  138. @endsection
  139. @section('lastScript')
  140. <script type="text/javascript" src="{{asset('js/queryForm/export200818a.js')}}"></script>
  141. <script type="text/javascript" src="{{asset('js/queryForm/queryForm200825.js')}}"></script>
  142. <script type="text/javascript" src="{{asset('js/queryForm/header200826b.js')}}"></script>
  143. <script>
  144. let vue=new Vue({
  145. el:"#list",
  146. data:{
  147. page:Number('{{$page}}'),
  148. paginate:Number('{{$request['paginate'] ?? 50}}'),
  149. maxPage:1,
  150. sum:0,
  151. checkData:[],
  152. owners:[
  153. @foreach($customers as $customer)
  154. { name:'{{$customer->customerid}}',value:'{{$customer->descr_c}}' },
  155. @endforeach
  156. ],
  157. orders:{!! $orders !!},
  158. commodities:{!! $commodities !!},
  159. isBtn:{},
  160. content:'',
  161. codes:[
  162. @foreach($codes as $code)
  163. {name:'{{$code->code}}',value:'{{$code->codename_c}}'},
  164. @endforeach
  165. ],
  166. selectedStyle:'',
  167. picktotraceidMap:{!! $picktotraceids !!},
  168. pagePlaceholder:"",
  169. },
  170. mounted:function () {
  171. $(".tooltipTarget").tooltip({'trigger':'hover'});
  172. $("#list").removeClass('d-none');
  173. if (this.orders.length>0){
  174. this.maxPage=Math.ceil(this.orders[0].counted/this.paginate);
  175. this.sum=this.orders[0].counted;
  176. }
  177. if (this.getQueryVariable('alternate_sku1')){
  178. this.maxPage=0;
  179. this.pagePlaceholder = '当前页数:'+this.page;
  180. }else{
  181. this.pagePlaceholder = '当前页数:'+this.page+'/'+this.maxPage;
  182. }
  183. let data=[
  184. [ {name:'codename_c',type:'select',placeholder:'订单状态',data:this.codes},
  185. {name:'orderdate_start',type:'time',tip:['选择显示日期的起始时间','选择显示日期的起始时间'],
  186. rules:{date_relevance:{date:['orderdate_start','orderdate_end'],relevance:'addtime',killing:'relevance',default:[31,92,183,366]}}},
  187. {name:'orderno',type:'input',tip:'编号,糊模查找需要在左边打上%符号',placeholder: '编号'},
  188. {name:'carriername',type:'input',tip:'',placeholder:'承运人'},
  189. {name:['notes','addtime'],type:'input_select',tip:['右侧选择查询范围,默认为一月内','查询范围,范围越短搜索越快'],placeholder: ['备注',''],
  190. data:[{name:'31',value:'近一月'},{name:'92',value:'近三月'},{name:'183',value:'近半年'},{name:'366',value:'近一年'},{name:'0',value:'不限'},],
  191. rules:[{son:{addtime:{default:'31',required_without_all_if:['orderdate_start','orderdate_end']}}},
  192. {date_relevance:{date:['orderdate_start','orderdate_end'],relevance:'addtime',killing:'relevance',default:[31,92,183,366]}}]},
  193. {name:'issuepartyname',type:'input',tip:'',placeholder: '店铺名称'},
  194. {name:'edisendflag2',type:'select',tip:'快递获取标记',placeholder: '快递获取标记',data:[{name:'Y',value:'是'},{name:'N',value:'否'},{name:'W',value:'错误'},]},
  195. {name:'edisendflag',type:'select',tip:'接口回传标记',placeholder: '接口回传标记',data:[{name:'Y',value:'Y'},{name:'N',value:'N'},{name:'W',value:'W'},{name:'R',value:'R'},]}
  196. ],
  197. [
  198. {name:'codename_c_end',type:'select',placeholder:'订单状态范围',data:this.codes},
  199. {name:'orderdate_end',type:'time',tip:['选择显示指定日期的结束时间','选择显示指定日期的结束时间'],
  200. rules:{date_relevance:{date:['orderdate_start','orderdate_end'],relevance:'addtime',killing:'date',default:[31,92,183,366]}}},
  201. {name:'customerid',type:'select_multiple_select',tip:['输入关键词快速定位下拉列表,回车确定','选择要显示的客户'],
  202. placeholder:['货主','定位或多选货主'],data:this.owners},
  203. {name:'soreference5',type:'input',tip:'可支持多快递单号,糊模查找需要在左边打上%符号',placeholder: '多快递单号'},
  204. {name:'soreference1',type:'input',tip:'客户订单号,糊模查找需要在左边打上%符号',placeholder: '客户订单号'},
  205. {name:'waveno',type:'input',tip:'波次编号,模糊查找需要在左边打上%的符号',placeholder: '波次编号'},
  206. {name:'alternate_sku1',type:'input',tip:'产品条码,模糊查找需要在左边打上%的符号',placeholder: '产品条码'},
  207. {name:'c_contact',type:'input',tip:'收货人名称:15天以内模糊搜索,15天以外精确搜索',placeholder:'收货人名称'},
  208. ],
  209. [
  210. {name:'c_tel2',type:'input',tip:'收货人电话:15天以内模糊搜索,15天以外精确搜索',placeholder:'收货人电话'},
  211. {name:'c_province',type:'input',tip:'省:15天以内模糊搜索,15天以外精确搜索',placeholder:'省'},
  212. {name:'c_city',type:'input',tip:'市:15天以内模糊搜索,15天以外精确搜索',placeholder:'市'},
  213. {name:'c_district',type:'input',tip:'区:15天以内模糊搜索,15天以外精确搜索',placeholder:'区'},
  214. {name:'releasestatus',type:'select',tip:'是否冻结冻结',placeholder:'是否冻结',data:[{name:'H',value:'是'},{name:'',value:'否'}]},
  215. {name:'checktime_start',type:'dateTime',tip:'选择显示复核时间的起始日期'},
  216. {name:'checktime_end',type:'dateTime',tip:'选择显示复核时间的结束日期'},
  217. ],
  218. ];
  219. this.form = new query({
  220. el:"#form_div",
  221. condition:data,
  222. });
  223. this.form.init();
  224. let column = [
  225. {name:'cloneCheckAll',customization:true,type:'checkAll',column:'orderno',
  226. dom:$('#cloneCheckAll').removeClass('d-none'), neglect: true},
  227. {name:'index',value: '序号', neglect: true},
  228. {name:'orderno',value: '编号'},
  229. {name:'ordercodename',value: '订单状态'},
  230. {name:'addtime',value: '接口下发时间'},
  231. {name:'issuepartyname',value: '店铺名称'},
  232. {name:'customer_descr_c',value: '客户'},
  233. {name:'soreference1',value: '客户订单号'},
  234. {name:'carriername',value: '承运人'},
  235. {name:'soreference5',value: '快递单号'},
  236. {name:'c_contact',value: '收货人名称'},
  237. {name:'c_tel2',value: '收货人电话'},
  238. {name:'c_province',value: '省'},
  239. {name:'c_city',value: '市'},
  240. {name:'c_district',value: '区'},
  241. {name:'c_address1',value: '收货人地址', style:"min-width:320px;"},
  242. {name:'waveno',value: '波次编号'},
  243. {name:'warehouseid',value: '仓库'},
  244. {name:'edisendflag2',value: '快递获取标记'},
  245. {name:'edisendtime2',value: '快递获取时间'},
  246. {name:'sku',value: '产品代码', neglect: true, style:"min-width: 150px"},
  247. {name:'alternate_sku1',value: '产品条码', neglect: true, style:"min-width: 150px"},
  248. {name:'descr_c',value: '产品名称', neglect: true, style:"min-width: 180px"},
  249. {name:'qtyordered',value: '订单数量', neglect: true},
  250. {name:'orderdetailcodename',value: '明细状态', neglect: true, style:"min-width: 150px"},
  251. {name:'checktime',value: '复核时间', neglect: true},
  252. {name:'notes',value: '备注', style:"min-width: 260px"},
  253. {name:'erpcancelflag',value: '接口取消标记'},
  254. {name:'picking_print_flag',value: '拣货单打印标记'},
  255. {name:'edisendflag',value: '接口回传标记'},
  256. {name:'ediremarks2',value: '接口回传异常备注'},
  257. {name:'update',value: '订单冻结', neglect: true},
  258. {name:'remove',value: '取消分配', neglect: true},
  259. ];
  260. let _this=this;
  261. setTimeout(function () {
  262. let header = new Header({
  263. el: "#header",
  264. column: column,
  265. data: _this.orders,
  266. restorationColumn: 'addtime',
  267. fixedTop:($('#form_div').height())+2,
  268. offset:0.5,
  269. vue:vue
  270. });
  271. header.init();
  272. },0);
  273. },
  274. watch:{
  275. checkData:{
  276. handler(){
  277. if (this.checkData.length === this.orders.length){
  278. document.querySelector('#all').checked = true;
  279. document.querySelector('#all_temp').checked = true;
  280. }else {
  281. document.querySelector('#all').checked = false;
  282. document.querySelector('#all_temp').checked = false;
  283. }
  284. },
  285. deep:true
  286. }
  287. },
  288. methods:{
  289. getQueryVariable(variable){
  290. let query = window.location.search.substring(1);
  291. let vars = query.split("&");
  292. for (let i=0;i<vars.length;i++) {
  293. let pair = vars[i].split("=");
  294. if(pair[0] == variable){return pair[1];}
  295. }
  296. return(false);
  297. },
  298. pageUp(){
  299. if (this.page<=1)return;
  300. this.href(this.page-1);
  301. },
  302. pageDown(){
  303. if (this.page>=this.maxPage && this.maxPage !== 0)return;
  304. this.href(this.page+1);
  305. },
  306. pageSkip(e){
  307. if (Number(e.target.value)<=0 || Number(e.target.value)>this.maxPage){
  308. tempTip.setDuration(2000);
  309. tempTip.show('页数不存在! ');
  310. return
  311. }
  312. this.href(e.target.value);
  313. },
  314. href(page){
  315. let url = document.URL;
  316. if (url.indexOf('page='+this.page) != -1){
  317. url = url.replace("page="+this.page,"page="+page);
  318. }else{
  319. if (url.indexOf('?') == -1) url += "?page="+page;
  320. else url += "&page="+page;
  321. }
  322. window.location.href=url;
  323. },
  324. //全选事件
  325. checkAll(e){
  326. if (e.target.checked){
  327. this.orders.forEach((el,i)=>{
  328. if (this.checkData.indexOf(el.orderno) == '-1'){
  329. this.checkData.push(el.orderno);
  330. }
  331. });
  332. }else {
  333. this.checkData = [];
  334. }
  335. },
  336. unfold(orderno){
  337. this.$set(this.isBtn,orderno,true);
  338. setTimeout(function () {
  339. $(".tooltipTarget").tooltip({'trigger':'hover'});
  340. },1);
  341. },
  342. orderExport(checkAllSign){
  343. let url = '{{url('order/index/delivering')}}';
  344. let token='{{ csrf_token() }}';
  345. excelExport(checkAllSign,this.checkData,url,this.sum,token);
  346. },
  347. modal(){
  348. $("#myModal").modal('show');
  349. },
  350. //批量冻结
  351. freezeAll:function(){
  352. let _this=this;
  353. if(_this.checkData.length===0){
  354. tempTip.show('没有勾选记录');
  355. return
  356. }
  357. if(!confirm("确定要标记所有勾选内容为'冻结'吗")){return;}
  358. axios.post('{{url('order/freezeAll')}}',{checkData:_this.checkData}).then(function(response){
  359. if(response.data.success){
  360. _this.orders.forEach(function(order){
  361. _this.checkData.forEach(function (checkedId) {
  362. if(order.orderno===checkedId){
  363. order.releasestatus='H';
  364. order.waveno='*';
  365. }
  366. });
  367. });
  368. tempTip.setDuration(1000);
  369. tempTip.showSuccess('标记勾选内容为冻结成功');
  370. }else{
  371. tempTip.setDuration(2500);
  372. tempTip.show('标记勾选内容冻结失败,错误:'+response.data.fail_info);
  373. }
  374. }).catch(function (e) {
  375. alert('网络连接错误:'+e);
  376. tempTip.setDuration(2500);
  377. tempTip.show('标记勾选内容冻结失败,网络连接错误:'+e);
  378. })
  379. },
  380. //批量取消分配
  381. deAllocationAll(){
  382. let _this=this;
  383. if(_this.checkData.length===0){
  384. tempTip.show('没有勾选记录');
  385. return
  386. }
  387. if(!confirm("确定要所有勾选内容'取消分配'吗")){return;}
  388. axios.post('{{url('order/deAllocationAll')}}',{checkData:_this.checkData}).then(function(response){
  389. if(response.data.success){
  390. _this.orders.forEach(function(order){
  391. _this.checkData.forEach(function (checkedId) {
  392. if(order.orderno===checkedId){
  393. order.sostatus='00';
  394. order.waveno='*';
  395. }
  396. });
  397. });
  398. tempTip.setDuration(1000);
  399. tempTip.showSuccess('标记勾选内容取消分配成功');
  400. window.location.reload();
  401. }else{
  402. tempTip.setDuration(2500);
  403. tempTip.show('标记勾选内容取消分配失败,错误:'+response.data.fail_info);
  404. }
  405. }).catch(function (e) {
  406. alert('网络连接错误:'+e);
  407. tempTip.setDuration(2500);
  408. tempTip.show('标记勾选内容取消分配失败,网络连接错误:'+e);
  409. })
  410. },
  411. batchComments(){
  412. let _this=this;
  413. if (this.checkData.length<1 || !this.content) {
  414. $("#myModal").modal('hide');
  415. tempTip.setDuration(3000);
  416. if (this.checkData.length<1) tempTip.showSuccess('没有勾选任何记录');
  417. else tempTip.showSuccess('没有输入任何内容');
  418. return;
  419. }
  420. axios.post('{{url('order/create/batchComments')}}',{checkData:this.checkData,content:this.content})
  421. .then(function (response) {
  422. let sign=[];
  423. _this.orders.every(function (order) {
  424. if (sign.length===response.data.length)return false;
  425. response.data.every(function (data) {
  426. if (order.orderno===data.orderno){
  427. order.notes=data.notes;
  428. sign.push(order.orderno);
  429. return false;
  430. }
  431. return true;
  432. });
  433. return true;
  434. });
  435. tempTip.setDuration(3000);
  436. tempTip.showSuccess('注释完毕!')
  437. _this.content='';
  438. }).catch(function (err) {
  439. tempTip.setDuration(4000);
  440. tempTip.show('网络错误:'+err)
  441. });
  442. $("#myModal").modal('hide');
  443. },
  444. selectedColor(orderno){
  445. if (orderno==this.selectedStyle){
  446. this.selectedStyle='';
  447. return;
  448. }
  449. this.selectedStyle=orderno;
  450. },
  451. freeze(orderno,waveno){
  452. if(!confirm('确定要冻结“'+orderno+'”吗?'))return;
  453. let _this=this;
  454. axios.post('{{url('order/freeze')}}',{orderno:orderno,waveno:waveno})
  455. .then(function (response) {
  456. if (response.data.success){
  457. _this.orders.some(function (order) {
  458. if (order.orderno===orderno){
  459. order.releasestatus='H';
  460. order.waveno='*';
  461. return true;
  462. }
  463. });
  464. tempTip.setDuration(3000);
  465. tempTip.showSuccess('订单已被冻结!');
  466. }
  467. }).catch(function (err) {
  468. tempTip.setDuration(3000);
  469. tempTip.show('网络异常:'+err);
  470. });
  471. },
  472. thaw(orderno, is_batch = false, order = null){
  473. if(!confirm('确定要解冻“'+orderno+'”吗?'))return;
  474. let _this=this;
  475. axios.post('{{url('order/thaw')}}',{orderno:orderno})
  476. .then(function (response) {
  477. if (response.data.success){
  478. if (is_batch){
  479. orderno.forEach(order_no =>{
  480. _this.orders.some(function (order) {
  481. if (order.orderno===order_no){
  482. order.releasestatus='N';
  483. return true;
  484. }
  485. });
  486. });
  487. }else{
  488. order.releasestatus = 'N';
  489. }
  490. tempTip.setDuration(3000);
  491. tempTip.showSuccess('订单已成功解冻!');
  492. }
  493. }).catch(function (err) {
  494. tempTip.setDuration(3000);
  495. tempTip.show('网络异常:'+err);
  496. });
  497. },
  498. deAllocation(orderno,waveno){
  499. if(!confirm('确定要取消分配“'+orderno+'”吗?'))return;
  500. let _this=this;
  501. axios.post('{{url('order/deAllocation')}}',{orderno:orderno,waveno:waveno})
  502. .then(function (response) {
  503. if (response.data.success){
  504. _this.orders.some(function (order) {
  505. if (order.orderno===orderno){
  506. order.sostatus='00';
  507. order.waveno='*';
  508. return true;
  509. }
  510. });
  511. tempTip.setDuration(3000);
  512. tempTip.showSuccess('订单已被取消分配!');
  513. window.location.reload();
  514. }
  515. }).catch(function (err) {
  516. tempTip.setDuration(3000);
  517. tempTip.show('网络异常:'+err);
  518. });
  519. },
  520. isUnfold(order){
  521. if (!order.is_unfold){
  522. this.$set(order,'is_unfold',true);
  523. return
  524. }
  525. order.is_unfold=false;
  526. },
  527. orderIssueTag(){
  528. // 标记问题单
  529. let _this = this;
  530. if( _this.checkData.length === 0){
  531. tempTip.show('没有勾选记录');
  532. return
  533. }
  534. tempTip.setDuration(99999);
  535. tempTip.waitingTip('处理中,请稍候')
  536. axios.post("{{url('apiLocal/order/issue/orderIssueTag')}}",{orderNos:_this.checkData}).then(function(res){
  537. tempTip.setDuration(5000)
  538. tempTip.cancelWaitingTip();
  539. if(res.data.success){
  540. tempTip.setDuration(3000);
  541. tempTip.showSuccess('已标记为问题件,稍后前往订单问题件查询页面');
  542. setTimeout(function(){
  543. window.location.href = "{{url('order/issue/index')}}";
  544. },1000);
  545. }else{
  546. tempTip.setDuration(4000);
  547. tempTip.show(res.data.fail_info);
  548. }
  549. }).catch(function(err){
  550. tempTip.setDuration(3000);
  551. tempTip.cancelWaitingTip();
  552. tempTip.show('网络链接异常'+err);
  553. })
  554. },
  555. //重置快递获取标记
  556. resetLogisticsGetMark(){
  557. if (this.checkData.length < 1){
  558. tempTip.setDuration(3000);
  559. tempTip.showSuccess('未选择任何单号');
  560. return
  561. }
  562. if (!confirm('确定要重置这些单的快递获取标记吗?'))return;
  563. let url = '{{url('order/resetLogisticsGetMark')}}';
  564. let _this = this;
  565. axios.post(url,{orderno : this.checkData})
  566. .then(function (response) {
  567. if (response.data.success){
  568. _this.checkData.forEach(orderno => {
  569. _this.orders.some(order => {
  570. if (order.orderno === orderno && order.edisendflag2 === 'W'){
  571. order.edisendflag2 = "N";
  572. return true;
  573. }
  574. });
  575. });
  576. tempTip.setDuration(2000);
  577. tempTip.showSuccess('重置快递获取标记成功!');
  578. } else{
  579. tempTip.setDuration(3000);
  580. tempTip.show(response.data.data);
  581. }
  582. }).catch(function (err) {
  583. tempTip.setDuration(3000);
  584. tempTip.show("网络错误:"+err)
  585. })
  586. }
  587. },
  588. });
  589. </script>
  590. @endsection