delivering.blade.php 64 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102
  1. @extends('layouts.app')
  2. @section('title')查询-订单管理@endsection
  3. @section('content')
  4. <div class="container-fluid">
  5. <div style="min-width: 4120px;">{{--4070--}}
  6. <div id="list" class="d-none">
  7. <div id="form_div"></div>
  8. <div class="ml-3 form-inline" id="btn">
  9. <div class="dropdown">
  10. <button type="button" class="btn btn-outline-dark btn-sm form-control-sm dropdown-toggle tooltipTarget"
  11. data-toggle="dropdown" title="导出所有页将会以搜索条件得到的筛选结果,将其全部记录(每一页)导出">
  12. 导出Excel
  13. </button>
  14. <div class="dropdown-menu">
  15. <a class="dropdown-item" @click="orderExport(false)" href="javascript:">导出勾选内容</a>
  16. <a class="dropdown-item" @click="orderExport(true)" href="javascript:">导出所有页</a>
  17. </div>
  18. </div>
  19. <div class="custom-control custom-checkbox ml-1">
  20. <input type="checkbox" class="custom-control-input" id="customCheck" name="is_merge" v-model="is_merge">
  21. <label class="custom-control-label" for="customCheck">导出是否格式化</label>
  22. </div>
  23. @can('订单管理-批量备注')<button @click="modal()" type="button" class="btn btn-sm ml-2 btn-outline-primary">批量备注追加</button>@endcan
  24. @can('订单管理-编辑')
  25. <span class="btn btn-sm btn-outline-dark tooltipTarget ml-1" @click="freezeAll" style="cursor: pointer" title="订单的冻结条件要只局限在“创建订单”,“分配完成”,“拣货完成”,“播种完成”">冻结</span>
  26. <button type="button" @click="thaw(null,true)" class="btn btn-sm btn-outline-danger tooltipTarget ml-1" title="解除已冻结订单" style="opacity: 0.7">解冻</button>
  27. <span class="btn btn-sm btn-outline-dark tooltipTarget ml-1" @click="deAllocationAll" style="cursor: pointer" title="订单的取消分配条件要只局限在“分配完成”或“部分分配”">取消分配</span>
  28. <button type="button" @click="resetLogisticsGetMark()" class="btn btn-sm ml-1 btn-outline-success">重置快递获取标记</button>
  29. <button type="button" @click="resetInterfaceReturnMark()" class="btn btn-sm ml-1 btn-outline-secondary">重置接口回传标记</button>
  30. @endcan
  31. @can('订单管理-订单-生成问题件')<button @click="orderIssueTag()" type="button" class="btn btn-sm ml-1 btn-outline-primary">标记问题件</button>@endcan
  32. @can('订单管理-订单-生成退货单')
  33. <button class="btn btn-sm btn-outline-dark ml-1"@click="isRejectedBillExist()"
  34. style="opacity: 0.7">生成退货单</button>
  35. @endcan
  36. <button class="btn btn-sm ml-1 btn-primary" @click="copyLogisticNumber()">复制快递单号</button>
  37. @can('订单管理-订单-生成工单')
  38. <button class="btn btn-sm ml-1 btn-outline-success" @click="showInterceptModel()">生成工单</button>
  39. @endcan
  40. @can('订单管理-订单-一键回传')
  41. <button class="btn btn-sm ml-1 btn-success tooltipTarget" title="订单一键回传必须满足条件:订单状态为“分配完成,部分拣货,拣货完成,播种完成”;订单未冻结;订单有快递单号"
  42. @click="manualBack()">一键回传</button>
  43. @endcan
  44. </div>
  45. <div class="modal fade " style="top: 20%" id="myModal" tabindex="-1" role="dialog" aria-labelledby="myModalLabel" aria-hidden="true">
  46. <div class="modal-dialog">
  47. <div class="modal-content">
  48. <div class="modal-header">
  49. <button type="button" class="close" data-dismiss="modal" aria-hidden="true">&times;</button>
  50. </div>
  51. <div class="modal-body">
  52. <input class="form-control" v-model="content" placeholder="注释内容">
  53. </div>
  54. <div class="modal-footer">
  55. <button type="button" class="btn btn-default" data-dismiss="modal">关闭</button>
  56. <button type="button" @click="batchComments()" class="btn btn-primary">批量备注追加</button>
  57. </div>
  58. </div><!-- /.modal-content -->
  59. </div><!-- /.modal -->
  60. </div>
  61. <table class="table table-striped table-bordered table-hover card-body td-min-width-80" id="table">
  62. <tr v-for="(order,i) in orders" @click="selectedColor(order.orderno)" :style="{'background-color': order.orderno==selectedStyle?'#aac7ea':''}">
  63. <td>
  64. <input class="checkItem" type="checkbox" :value="order.orderno">
  65. </td>
  66. <td class="text-nowrap">
  67. <span>@{{ i+1 }}</span><span v-show="order.is_order_issue" class="badge badge-pill badge-danger">问题件</span>
  68. </td>
  69. <td class="text-dark font-weight-bold text-nowrap"><span>@{{ order.orderno }}</span></td>
  70. <td class="text-muted text-nowrap"><span>@{{ order.ordercodename }}</span></td>
  71. <td class="text-nowrap"><span>@{{ order.addtime }}</span></td>
  72. <td class="text-nowrap"><span>@{{ order.issuepartyname }}</span></td>
  73. <td class="text-nowrap"><span>@{{ order.customer_descr_c }}</span></td>
  74. <td class="text-nowrap"><span>@{{ order.soreference1 }}</span></td>
  75. <td class="text-muted text-nowrap"><span>@{{ order.carriername }}</span></td>
  76. <td class="text-nowrap">
  77. <div v-if="picktotraceidMap[order.orderno] && picktotraceidMap[order.orderno].length>1" class="text-center">
  78. <span v-for="(picktotraceid,key) in picktotraceidMap[order.orderno]" v-if="order.is_unfold">
  79. @{{ isDB(order.carriername) ? (order.code5+'#'+(key+1)) : picktotraceid }}<br>
  80. </span>
  81. <button class="btn btn-sm btn-outline-info" :style="order.is_unfold ? 'opacity:0.7' : ''" @click="isUnfold(order)">
  82. <span v-if="order.is_unfold" class="mt-1">收起</span>
  83. <span v-else>分箱 @{{ picktotraceidMap[order.orderno].length }} 件,展开单号</span>
  84. </button>
  85. </div>
  86. <span v-else>@{{ order.soreference5 }}</span>
  87. </td>
  88. <td class="text-muted text-wrap text-letter">
  89. <div class="text-overflow-warp-200 warp-min-200" :class="order.is_encryption ? 'text-danger' : ''"><span v-if="order.is_encryption">*加密*</span><span v-else>@{{ order.c_contact }}</span></div>
  90. </td>
  91. <td class="text-muted text-wrap text-letter">
  92. <div class="text-overflow-warp-200 warp-min-200" :class="order.is_encryption ? 'text-danger' : ''"><span v-if="order.is_encryption">*加密*</span><span v-else>@{{ order.c_tel2?order.c_tel2:order.c_tel1 }}</span></div>
  93. </td>
  94. <td class="text-nowrap"><span> @{{ order.c_province }}</span></td>
  95. <td class="text-nowrap"><span> @{{ order.c_city }}</span></td>
  96. <td class="text-nowrap"><div class="text-overflow-warp-200 warp-min-200">@{{ order.c_district }}</div></td>
  97. <td class="text-muted text-wrap text-letter"><div class="text-overflow-warp-200 warp-min-200" :class="order.is_encryption ? 'text-danger' : ''"><span v-if="order.is_encryption">*加密*</span><span v-else>@{{ order.c_address1 }}</span></div></td>
  98. <td class="text-nowrap"><span>@{{ order.waveno }}</span></td>
  99. <td class="text-nowrap"><span> @{{ order.warehouseid }}</span></td>
  100. <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>
  101. <td class="text-nowrap"><span>@{{ order.edisendtime2 }}</span></td>
  102. <td class="text-center" style="min-width: 900px">
  103. <div :class="commodities[order.orderno]&&commodities[order.orderno].length==1 ? '' : 'up'" :id="'order-'+i">
  104. <div v-for="oracleDOCOrderDetail in commodities[order.orderno]" class="row">
  105. <div class="col-2 border border-1">@{{ oracleDOCOrderDetail.sku }}</div>
  106. <div class="col-2 border border-1">@{{ oracleDOCOrderDetail.alternate_sku1 }}</div>
  107. <div class="col-2 border border-1" @dblclick.stop="replaceText(i)">
  108. <div class="w-100" :class="order.replaceText ? 'text-overflow-warp-100' : 'text-overflow-replace-100 cursor-pointer'">@{{ oracleDOCOrderDetail.descr_c }}</div>
  109. </div>
  110. <div class="col-1 border border-1">@{{ oracleDOCOrderDetail.qtyordered }}</div>
  111. <div class="col-2 border border-1">@{{ oracleDOCOrderDetail.lotnum }}</div>
  112. <div class="col-1 m-0 p-0 border border-1">@{{ oracleDOCOrderDetail.orderdetailcodename }}</div>
  113. <div class="col-2 border border-1">@{{ oracleDOCOrderDetail.checktime }}</div>
  114. </div>
  115. </div>
  116. <div class="row text-center cursor-pointer" v-if="commodities[order.orderno]&&commodities[order.orderno].length>1">
  117. <b @click="unfold(i)" class="col-12 cursor-pointer" v-if="!upList[i]">共有 @{{ commodities[order.orderno].length }} 件商品,点击展开</b>
  118. <b class="col-12" @click="unfold(i)" v-else>点击收起明细</b>
  119. </div>
  120. </td>
  121. <td><span>@{{ order.notes }}</span></td>
  122. <td><span>@{{ order.manualflag}}</span></td>
  123. <td><span>@{{ order.erpcancelflag }}</span></td>
  124. <td><span>@{{ order.picking_print_flag }}</span></td>
  125. <td><span>@{{ order.edisendflag }}</span></td>
  126. <td><span>@{{ order.ediremarks2}}</span></td>
  127. <td>
  128. @can('订单管理-编辑')
  129. <button v-if="order.releasestatus!=='H'" @click="freeze(order.orderno,order.waveno)" class="btn btn-sm btn-outline-dark text-nowrap"
  130. :disabled="!(order.ordercodename==='创建订单'||order.ordercodename==='分配完成'||order.ordercodename==='拣货完成'||order.ordercodename==='播种完成')">冻结</button>
  131. <button v-else @click="thaw(order.orderno,false,order)" class="btn btn-sm btn-outline-danger text-nowrap"
  132. :disabled="!(order.ordercodename==='创建订单'||order.ordercodename==='分配完成'||order.ordercodename==='拣货完成'||order.ordercodename==='播种完成')">解冻</button>
  133. @else
  134. <span>@{{ order.releasestatus }}</span>
  135. @endcan
  136. </td>
  137. <td>
  138. @can('订单管理-编辑')
  139. <button v-if="order.sostatus=='40'||'30'" @click="deAllocation(order.orderno,order.waveno)" class="btn btn-sm btn-outline-dark text-nowrap"
  140. :disabled="!(order.sostatus==='40'|| order.sostatus==='30')">取消分配</button>
  141. @else
  142. <span>@{{ order.sostatus }}</span>
  143. @endcan
  144. </td>
  145. </tr>
  146. </table>
  147. <button type="button" @click="pageUp()" :readonly="page>1?false:true" class="btn btn-sm " :class="page>1?'btn-outline-info':''">上一页</button>
  148. <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>
  149. <input @keyup.enter="pageSkip($event)" class="form-control-sm ml-3 tooltipTarget" placeholder="此处输入页数" title="去往指定页">
  150. <span class="text-muted m-1">@{{ pagePlaceholder }}</span>
  151. <span class="text-muted m-1" v-if="maxPage != 0">共 @{{ sum }} 条</span>
  152. <div class="modal fade " id="checkModal" tabindex="-1" role="dialog" aria-labelledby="checkModalLabel" aria-hidden="true">
  153. <div class="modal-dialog modal-dialog-centered">
  154. <div class="modal-content">
  155. <div class="modal-header">
  156. <h5 class="modal-title" id="checkModalLabel">标记问题件提示</h5>
  157. <button type="button" class="close" data-dismiss="modal" aria-label="Close"
  158. @click="changeRemark">
  159. <span aria-hidden="true">&times;</span>
  160. </button>
  161. </div>
  162. <div class="modal-body">
  163. <div class="alert" id="alert-message">
  164. @{{ message.checkOrderIssueMessage }}
  165. </div>
  166. </div>
  167. <div class="modal-footer">
  168. <button type="button" class="btn btn-secondary" data-dismiss="modal"
  169. @click="message.checkOrderIssueMessage=''">关闭
  170. </button>
  171. </div>
  172. </div>
  173. </div>
  174. </div>
  175. <div class="modal fade " id="exampleModal" tabindex="-1" role="dialog" aria-labelledby="exampleModalLabel"
  176. aria-hidden="true">
  177. <div class="modal-dialog modal-dialog-centered modal-xl">
  178. <div class="modal-content">
  179. <div class="modal-header">
  180. <h5 class="modal-title" id="exampleModalLabel">输入问题件信息</h5>
  181. <button type="button" class="close" data-dismiss="modal" aria-label="Close"
  182. @click="changeRemark">
  183. <span aria-hidden="true">&times;</span>
  184. </button>
  185. </div>
  186. <div class="modal-body">
  187. <div class="form-group row m-0 p-0">
  188. <label class="col-md-1 col-sm-2 text-right">问题类别</label>
  189. <select name="order_issues_type_id" v-model="typeId" class="form-control col-4" id="orderIssueType" @focus="focusOnModal($event)" >
  190. <option value></option>
  191. <option v-for="type in orderIssueType" :value="type.id">@{{ type.name }}</option>
  192. </select>
  193. <label class="col-md-1 col-sm-2 text-right">
  194. 快递
  195. </label>
  196. <div class="col-4">
  197. <textarea class="form-control m-0">@{{ tagOrder.logisticInfo }}</textarea>
  198. <button type="button" class="btn btn-sm btn-outline-primary" @click="copyLogisticInfo">复制</button>
  199. </div>
  200. </div>
  201. <div class="form-group row m-0">
  202. <label class="col-md-1 col-sm-2 text-right">情况说明</label>
  203. <label for="result_explain"></label>
  204. <textarea name="result_explain" v-model="result_explain" class="form-control col-4" id="result_explain" ></textarea>
  205. <label class="col-md-1 col-sm-2 text-right">
  206. 商家
  207. </label>
  208. <div class="col-4">
  209. <textarea class="form-control m-0 row">@{{ tagOrder.merchantInfo }}</textarea>
  210. <button type="button" class="btn btn-sm btn-outline-primary" @click="copyMerchantInfo">复制</button>
  211. </div>
  212. </div>
  213. </div>
  214. <div class="modal-footer">
  215. <button type="button" class="btn btn-sm btn-secondary" data-dismiss="modal"
  216. @click="changeRemark">关闭
  217. </button>
  218. <button type="button" class="btn btn-sm btn-primary" @click="orderIssueTagSubmit">提交</button>
  219. </div>
  220. </div>
  221. </div>
  222. </div>
  223. @can('订单管理-订单-生成工单')
  224. @include('order.index._work_order_modal')
  225. @endcan
  226. <textarea id="clipboardDiv" style="opacity:0"></textarea>
  227. </div>
  228. </div>
  229. </div>
  230. @endsection
  231. @section('lastScript')
  232. <script type="text/javascript" src="{{mix('js/queryForm/export.js')}}"></script>
  233. <script type="text/javascript" src="{{mix('js/queryForm/queryForm.js')}}"></script>
  234. <script type="text/javascript" src="{{mix('js/queryForm/header.js')}}"></script>{{--新版2--}}
  235. <script>
  236. let vue=new Vue({
  237. el:"#list",
  238. data:{
  239. page:Number('{{$page}}'),
  240. paginate:Number('{{$request['paginate'] ?? 50}}'),
  241. maxPage:1,
  242. sum:0,
  243. owners:[
  244. @foreach($customers as $customer)
  245. { name:'{{$customer->customerid}}',value:'{{$customer->descr_c}}' },
  246. @endforeach
  247. ],
  248. logistics:[
  249. @foreach($logistics as $logistic)
  250. { name:'{{$logistic->name}}',value:'{{$logistic->name}}' },
  251. @endforeach
  252. ],
  253. orders:{!! $orders !!},
  254. commodities:{!! $commodities !!},
  255. content:'',
  256. codes:[
  257. @foreach($codes as $code)
  258. {name:'{{$code->code}}',value:'{{$code->codename_c}}'},
  259. @endforeach
  260. ],
  261. selectedStyle:'',
  262. picktotraceidMap:{!! $picktotraceids !!},
  263. pagePlaceholder:"",
  264. typeId:'',
  265. result_explain:'',
  266. orderIssueType:{!! $orderIssueType !!},
  267. is_merge : false,
  268. message:{
  269. checkOrderIssueMessage:'',
  270. },
  271. tagOrders:[],
  272. tagOrder:{
  273. logisticInfo:'',
  274. merchantInfo:'',
  275. },
  276. upList:{},
  277. workOrder:{
  278. types:['拦截','快递异常','信息更改','错漏发', '破损'],
  279. orderIssueType:0,
  280. grad:1,
  281. remark:{
  282. name:null, // 联系人
  283. phone:null, // 联系号码
  284. province:null, // 省
  285. city:null, // 市
  286. district:null, // 区
  287. adder:null, // 详细地址
  288. info:null,
  289. },
  290. },
  291. grads:[
  292. {name:'一般',value:'1'},
  293. {name:'重要',value:'2'},
  294. {name:'紧急',value:'3'},
  295. {name:'重要且紧急',value:'4'},
  296. ]
  297. },
  298. mounted:function () {
  299. this.initData();
  300. $(".up").slideUp();
  301. $(".tooltipTarget").tooltip({'trigger':'hover'});
  302. $("#list").removeClass('d-none');
  303. if (this.orders.length>0){
  304. this.maxPage=Math.ceil(this.orders[0].counted/this.paginate);
  305. this.sum=this.orders[0].counted;
  306. }
  307. if (this.getQueryVariable('alternate_sku1')){
  308. this.maxPage=0;
  309. this.pagePlaceholder = '当前页数:'+this.page;
  310. }else{
  311. this.pagePlaceholder = '当前页数:'+this.page+'/'+this.maxPage;
  312. }
  313. let data=[
  314. [ {name:'codename_c',type:'select',placeholder:'订单状态',data:this.codes},
  315. {name:'orderdate_start',type:'time',tip:['选择显示日期的起始时间','选择显示日期的起始时间'],
  316. rules:{date_relevance:{date:['orderdate_start','orderdate_end'],relevance:'addtime',killing:'relevance',default:[31,92,183,366]}}},
  317. {name:'orderno',type:'input',tip:'可支持多SO号,糊模查找需要在左边打上%符号',placeholder: 'SO号'},
  318. {name:'carriername',type:'select_multiple_select',tip:['输入关键词快速定位下拉列表,回车确定','选择要显示的承运人'],
  319. placeholder:['承运人','定位或多选承运人'],data:this.logistics},
  320. {name:['notes','addtime'],type:'input_select',tip:['右侧选择查询范围,默认为一月内','查询范围,范围越短搜索越快'],placeholder: ['备注',''],
  321. data:[{name:'31',value:'近一月'},{name:'92',value:'近三月'},{name:'183',value:'近半年'},{name:'366',value:'近一年'},{name:'0',value:'不限'},],
  322. rules:{son:{addtime:{default:'31',required_without_all_if:['orderdate_start','orderdate_end']}},
  323. date_relevance:{date:['orderdate_start','orderdate_end'],relevance:'addtime',killing:'date',default:[31,92,183,366]}}},
  324. {name:'issuepartyname',type:'input',tip:'糊模查找需要在左边打上%符号',placeholder: '店铺名称'},
  325. {name:'edisendflag2',type:'select',tip:'快递获取标记',placeholder: '快递获取标记',data:[{name:'Y',value:'是'},{name:'N',value:'否'},{name:'W',value:'错误'},]},
  326. {name:'edisendflag',type:'select',tip:'接口回传标记',placeholder: '接口回传标记',data:[{name:'Y',value:'Y'},{name:'N',value:'N'},{name:'W',value:'W'},{name:'R',value:'R'},]}
  327. ],
  328. [
  329. {name:'codename_c_end',type:'select',placeholder:'订单状态范围',data:this.codes},
  330. {name:'orderdate_end',type:'time',tip:['选择显示指定日期的结束时间','选择显示指定日期的结束时间'],
  331. rules:{date_relevance:{date:['orderdate_start','orderdate_end'],relevance:'addtime',killing:'relevance',default:[31,92,183,366]}}},
  332. {name:'customerid',type:'select_multiple_select',tip:['输入关键词快速定位下拉列表,回车确定','选择要显示的客户'],
  333. placeholder:['货主','定位或多选货主'],data:this.owners},
  334. {name:'soreference5',type:'input',tip:'可支持多快递单号,糊模查找需要在左边打上%符号',placeholder: '多快递单号'},
  335. {name:'soreference1',type:'input',tip:'支持多客户订单号精确和模糊查找,糊模查找需要在右边打上%符号,多单号可用逗号或者空格分隔',placeholder: '客户订单号'},
  336. {name:'waveno',type:'input',tip:'可支持多波次编号,模糊查找需要在左边打上%的符号',placeholder: '波次编号'},
  337. {name:'alternate_sku1',type:'input',tip:'产品条码,模糊查找需要在左边打上%的符号',placeholder: '产品条码'},
  338. {name:'c_contact',type:'input',tip:'可支持多收货人名称:15天以内模糊搜索,15天以外精确搜索',placeholder:'收货人名称'},
  339. ],
  340. [
  341. {name:'c_tel2',type:'input',tip:'收货人电话:15天以内模糊搜索,15天以外精确搜索',placeholder:'收货人电话'},
  342. {name:'c_province',type:'input',tip:'省:15天以内模糊搜索,15天以外精确搜索',placeholder:'省'},
  343. {name:'c_city',type:'input',tip:'市:15天以内模糊搜索,15天以外精确搜索',placeholder:'市'},
  344. {name:'c_district',type:'input',tip:'区:15天以内模糊搜索,15天以外精确搜索',placeholder:'区'},
  345. {name:'releasestatus',type:'select',tip:'是否冻结冻结',placeholder:'是否冻结',data:[{name:'H',value:'是'},{name:'',value:'否'}]},
  346. {name:'checktime_start',type:'time',tip:['选择显示复核时间的起始日期',"选择显示复核时间的起始时间"]},
  347. {name:'checktime_end',type:'time',tip:['选择显示复核时间的结束日期','选择显示复核时间的结束时间']},
  348. {name: 'is_display_all', type: 'checkbox', tip: '是否隐藏装箱完成以后的状态', data: [{name: 'ture', value: '隐藏完成状态'}]},
  349. ],
  350. [
  351. {name:'restrict_time',type:'select',tip:'查询限定时间范围',placeholder:'查询时间范围',data:[{name:'1',value:'一天内'},{name:'7',value:'一周内'},{name:"30",value:"一月内"},{name:"90",value:"本季度"}]},
  352. {name:'manualflag',type:'select',tip:'是否人工回传',placeholder:'是否人工回传',data:[{name:'Y',value:'是'},{name:'N',value:'否'}]},
  353. ],
  354. ];
  355. this.form = new query({
  356. el:"#form_div",
  357. condition:data,
  358. appendDom : "btn",
  359. });
  360. this.form.init();
  361. let column = [
  362. {name:'index',value: '序号', neglect: true},
  363. {name:'orderno',value: '编号'},
  364. {name:'ordercodename',value: '订单状态'},
  365. {name:'addtime',value: '接口下发时间'},
  366. {name:'issuepartyname',value: '店铺名称'},
  367. {name:'customer_descr_c',value: '客户'},
  368. {name:'soreference1',value: '客户订单号'},
  369. {name:'carriername',value: '承运人'},
  370. {name:'soreference5',value: '快递单号'},
  371. {name:'c_contact',value: '收货人名称'},
  372. {name:'c_tel2',value: '收货人电话'},
  373. {name:'c_province',value: '省'},
  374. {name:'c_city',value: '市'},
  375. {name:'c_district',value: '区'},
  376. {name:'c_address1',value: '收货人地址'},
  377. {name:'waveno',value: '波次编号'},
  378. {name:'warehouseid',value: '仓库'},
  379. {name:'edisendflag2',value: '快递获取标记'},
  380. {name:'edisendtime2',value: '快递获取时间'},
  381. {name:"commodity", type:"multi",title:"商品信息",rows:[
  382. {value:"商品编码",col:"2"},
  383. {value:"商品条码",col:"2"},
  384. {value:"商品名称",col:"2"},
  385. {value:"订单数量",col:"1"},
  386. {value:"批次号",col:"2"},
  387. {value:"明细状态",col:"1"},
  388. {value:"复核时间",col:"2"}
  389. ]},
  390. {name:'notes',value: '备注'},
  391. {name:'manualflag',value: '人工回传标记'},
  392. {name:'erpcancelflag',value: '接口取消标记'},
  393. {name:'picking_print_flag',value: '拣货单打印标记'},
  394. {name:'edisendflag',value: '接口回传标记'},
  395. {name:'ediremarks2',value: '接口回传异常备注'},
  396. {name:'update',value: '订单冻结', neglect: true},
  397. {name:'remove',value: '取消分配', neglect: true},
  398. ];
  399. new Header({
  400. el: "table",
  401. name:"order",
  402. column: column,
  403. data: this.orders,
  404. restorationColumn: 'addtime',
  405. fixedTop:($('#form_div').height())+($('#btn').height())+1,
  406. }).init();
  407. },
  408. watch:{
  409. result_explain:function(){
  410. this.setLogisticInfo();
  411. this.setMerchantInfo();
  412. }
  413. },
  414. methods:{
  415. initData(){
  416. this.orders.forEach((order)=>{
  417. if (order.c_contact && order.c_contact.length>50 && order.c_contact.substring(0,3)==='~Ag')order.is_encryption = true;
  418. });
  419. let start = "{{$request["orderdate_start"] ?? ''}}";
  420. let end = "{{$request["orderdate_end"] ?? ''}}";
  421. let time = "{{$request["restrict_time"] ?? ''}}";
  422. if (start && end && time){
  423. this.changeURLParam("orderdate_start",start);
  424. this.changeURLParam("orderdate_end",end);
  425. this.changeURLParam("restrict_time",time);
  426. }
  427. },
  428. changeURLParam(name, value) {
  429. let url = document.URL, resultUrl = ''
  430. let reg = new RegExp('(^|&)' + name + '=([^&]*)(&|$)', 'i')
  431. let r = window.location.search.substr(1).match(reg);
  432. let replaceText = name + '=' + value;
  433. if (r != null) {
  434. let tmp = url.replace(name + '=' + r[2], replaceText);
  435. resultUrl = (tmp);
  436. } else {
  437. if (url.match('[\?]')) {
  438. resultUrl = url + '&' + replaceText;
  439. }
  440. else {
  441. resultUrl = url + '?' + replaceText;
  442. }
  443. }
  444. history.replaceState(null, null, resultUrl)
  445. },
  446. getQueryVariable(variable){
  447. let query = window.location.search.substring(1);
  448. let vars = query.split("&");
  449. for (let i=0;i<vars.length;i++) {
  450. let pair = vars[i].split("=");
  451. if(pair[0] == variable){return pair[1];}
  452. }
  453. return(false);
  454. },
  455. pageUp(){
  456. if (this.page<=1)return;
  457. this.href(this.page-1);
  458. },
  459. pageDown(){
  460. if (this.page>=this.maxPage && this.maxPage !== 0)return;
  461. this.href(this.page+1);
  462. },
  463. pageSkip(e){
  464. if (Number(e.target.value)<=0 || Number(e.target.value)>this.maxPage){
  465. tempTip.setDuration(2000);
  466. tempTip.show('页数不存在! ');
  467. return
  468. }
  469. this.href(e.target.value);
  470. },
  471. href(page){
  472. let url = document.URL;
  473. if (url.indexOf('page='+this.page) !== -1){
  474. url = url.replace("page="+this.page,"page="+page);
  475. }else{
  476. if (url.indexOf('?') === -1) url += "?page="+page;
  477. else url += "&page="+page;
  478. }
  479. window.location.href=url;
  480. },
  481. unfold(index){
  482. this.$set(this.upList,index,this.upList[index] ? !this.upList[index] : true);
  483. $("#order-"+index).slideToggle();
  484. },
  485. orderExport(checkAllSign){
  486. let url = '{{url('order/index/export')}}';
  487. let token='{{ csrf_token() }}';
  488. excelExport(checkAllSign,checkData,url,this.sum,token,{is_merge : this.is_merge});
  489. },
  490. modal(){
  491. $("#myModal").modal('show');
  492. },
  493. //批量冻结
  494. freezeAll:function(){
  495. let _this=this;
  496. if(checkData.length===0){
  497. tempTip.show('没有勾选记录');
  498. return
  499. }
  500. if(!confirm("确定要标记所有勾选内容为'冻结'吗")){return;}
  501. axios.post('{{url('order/freezeAll')}}',{checkData:checkData}).then(function(response){
  502. if(response.data.success){
  503. _this.orders.forEach(function(order){
  504. checkData.forEach(function (checkedId) {
  505. if(order.orderno===checkedId){
  506. order.releasestatus='H';
  507. order.waveno='*';
  508. }
  509. });
  510. });
  511. tempTip.setDuration(1000);
  512. tempTip.showSuccess('标记勾选内容为冻结成功');
  513. }else{
  514. tempTip.setDuration(2500);
  515. tempTip.show('标记勾选内容冻结失败,错误:'+response.data.fail_info);
  516. }
  517. }).catch(function (e) {
  518. tempTip.setDuration(2500);
  519. tempTip.show('标记勾选内容冻结失败,网络连接错误:'+e);
  520. })
  521. },
  522. //批量取消分配
  523. deAllocationAll(){
  524. let _this=this;
  525. if(checkData.length===0){
  526. tempTip.show('没有勾选记录');
  527. return
  528. }
  529. if(!confirm("确定要所有勾选内容'取消分配'吗")){return;}
  530. axios.post('{{url('order/deAllocationAll')}}',{checkData:checkData}).then(function(response){
  531. if(response.data.success){
  532. _this.orders.forEach(function(order){
  533. checkData.forEach(function (checkedId) {
  534. if(order.orderno===checkedId){
  535. order.sostatus='00';
  536. order.waveno='*';
  537. }
  538. });
  539. });
  540. tempTip.setDuration(1000);
  541. tempTip.showSuccess('标记勾选内容取消分配成功');
  542. window.location.reload();
  543. }else{
  544. tempTip.setDuration(2500);
  545. tempTip.show('标记勾选内容取消分配失败,错误:'+response.data.fail_info);
  546. }
  547. }).catch(function (e) {
  548. tempTip.setDuration(2500);
  549. tempTip.show('标记勾选内容取消分配失败,网络连接错误:'+e);
  550. })
  551. },
  552. batchComments(){
  553. let _this=this;
  554. if (checkData.length<1 || !this.content) {
  555. $("#myModal").modal('hide');
  556. tempTip.setDuration(3000);
  557. if (checkData.length<1) tempTip.showSuccess('没有勾选任何记录');
  558. else tempTip.showSuccess('没有输入任何内容');
  559. return;
  560. }
  561. axios.post('{{url('order/create/batchComments')}}',{checkData:checkData,content:this.content})
  562. .then(function (response) {
  563. let sign=[];
  564. _this.orders.every(function (order) {
  565. if (sign.length===response.data.length)return false;
  566. response.data.every(function (data) {
  567. if (order.orderno===data.orderno){
  568. order.notes=data.notes;
  569. sign.push(order.orderno);
  570. return false;
  571. }
  572. return true;
  573. });
  574. return true;
  575. });
  576. tempTip.setDuration(3000);
  577. tempTip.showSuccess('注释完毕!')
  578. _this.content='';
  579. }).catch(function (err) {
  580. tempTip.setDuration(4000);
  581. tempTip.show('网络错误:'+err)
  582. });
  583. $("#myModal").modal('hide');
  584. },
  585. selectedColor(orderno){
  586. if (orderno==this.selectedStyle) return;
  587. this.selectedStyle=orderno;
  588. },
  589. freeze(orderno,waveno){
  590. if(!confirm('确定要冻结“'+orderno+'”吗?'))return;
  591. let _this=this;
  592. axios.post('{{url('order/freeze')}}',{orderno:orderno,waveno:waveno})
  593. .then(function (response) {
  594. if (response.data.success){
  595. _this.orders.some(function (order) {
  596. if (order.orderno===orderno){
  597. order.releasestatus='H';
  598. order.waveno='*';
  599. return true;
  600. }
  601. });
  602. tempTip.setDuration(3000);
  603. tempTip.showSuccess('订单已被冻结!');
  604. }
  605. }).catch(function (err) {
  606. tempTip.setDuration(3000);
  607. tempTip.show('网络异常:'+err);
  608. });
  609. },
  610. thaw(orderno = null, is_batch = false, order = null){
  611. if (!orderno)orderno = checkData;
  612. if(!confirm('确定要解冻“'+orderno+'”吗?'))return;
  613. let _this=this;
  614. axios.post('{{url('order/thaw')}}',{orderno:orderno})
  615. .then(function (response) {
  616. if (response.data.success){
  617. if (is_batch){
  618. orderno.forEach(order_no =>{
  619. _this.orders.some(function (order) {
  620. if (order.orderno===order_no){
  621. order.releasestatus='N';
  622. return true;
  623. }
  624. });
  625. });
  626. }else{
  627. order.releasestatus = 'N';
  628. }
  629. tempTip.setDuration(3000);
  630. tempTip.showSuccess('订单已成功解冻!');
  631. }
  632. }).catch(function (err) {
  633. tempTip.setDuration(3000);
  634. tempTip.show('网络异常:'+err);
  635. });
  636. },
  637. deAllocation(orderno,waveno){
  638. if(!confirm('确定要取消分配“'+orderno+'”吗?'))return;
  639. let _this=this;
  640. axios.post('{{url('order/deAllocation')}}',{orderno:orderno,waveno:waveno})
  641. .then(function (response) {
  642. if (response.data.success){
  643. _this.orders.some(function (order) {
  644. if (order.orderno===orderno){
  645. order.sostatus='00';
  646. order.waveno='*';
  647. return true;
  648. }
  649. });
  650. tempTip.setDuration(3000);
  651. tempTip.showSuccess('订单已被取消分配!');
  652. window.location.reload();
  653. }
  654. }).catch(function (err) {
  655. tempTip.setDuration(3000);
  656. tempTip.show('网络异常:'+err);
  657. });
  658. },
  659. isUnfold(order){
  660. if (!order.is_unfold){
  661. this.$set(order,'is_unfold',true);
  662. return;
  663. }
  664. order.is_unfold=false;
  665. },
  666. orderIssueTag(){
  667. if( checkData.length === 0){
  668. tempTip.setDuration(2000);
  669. tempTip.show('没有勾选记录');
  670. return;
  671. }
  672. this.isExistByOrderNos();
  673. },
  674. orderIssueTagSubmit(){
  675. if(this.typeId === ''){
  676. $("#orderIssueType").addClass('is-invalid'); return;
  677. }else{
  678. $("#result_explain #result_explain").removeClass('is-invalid');
  679. $("#exampleModal").modal('hide');
  680. }
  681. let _this = this;
  682. tempTip.setDuration(1999);
  683. tempTip.waitingTip('处理中,请稍候');
  684. let data = {orderNos:checkData,typeId: this.typeId,result_explain:this.result_explain};
  685. axios.post("{{url('apiLocal/order/issue/orderIssueTag')}}",data).then(function(res){
  686. tempTip.setDuration(5000);
  687. tempTip.cancelWaitingTip();
  688. if(res.data.success){
  689. tempTip.setDuration(3000);
  690. tempTip.showSuccess('已标记为问题件');
  691. _this.orders.forEach(item=>{
  692. if (checkData.includes(item.orderno))item.is_order_issue = true;
  693. });
  694. }else{
  695. if(res.data.exitsOrderNos){
  696. _this.message.checkOrderIssueMessage = res.data.fail_info+res.data.exitsOrderNos;
  697. $("#checkModal").modal('show');
  698. }else{
  699. tempTip.setDuration(3000);
  700. tempTip.show(res.data.fail_info);
  701. }
  702. }
  703. }).catch(function(err){
  704. tempTip.setDuration(3000);
  705. tempTip.cancelWaitingTip();
  706. tempTip.show('网络链接异常'+err);
  707. })
  708. },
  709. //重置快递获取标记
  710. resetLogisticsGetMark(){
  711. if (checkData.length < 1){
  712. tempTip.setDuration(3000);
  713. tempTip.showSuccess('未选择任何单号');
  714. return
  715. }
  716. if (!confirm('确定要重置这些单的快递获取标记吗?'))return;
  717. let url = '{{url('order/resetLogisticsGetMark')}}';
  718. let _this = this;
  719. axios.post(url,{orderno : checkData})
  720. .then(function (response) {
  721. if (response.data.success){
  722. checkData.forEach(orderno => {
  723. _this.orders.some(order => {
  724. if (order.orderno === orderno && order.edisendflag2 === 'W'){
  725. order.edisendflag2 = "N";
  726. return true;
  727. }
  728. });
  729. });
  730. tempTip.setDuration(2000);
  731. tempTip.showSuccess('重置快递获取标记成功!');
  732. } else{
  733. tempTip.setDuration(3000);
  734. tempTip.show(response.data.data);
  735. }
  736. }).catch(function (err) {
  737. tempTip.setDuration(3000);
  738. tempTip.show("网络错误:"+err)
  739. })
  740. },
  741. resetInterfaceReturnMark(){
  742. if (checkData.length < 1){
  743. tempTip.setDuration(3000);
  744. tempTip.showSuccess('未选择任何单号');
  745. return
  746. }
  747. if (!confirm('确定要重置接口回传标记吗?'))return;
  748. let url = '{{url('order/resetInterfaceReturnMark')}}';
  749. let _this = this;
  750. axios.post(url,{orderno : checkData}).then(function (response) {
  751. if (response.data.success){
  752. checkData.forEach(orderno => {
  753. _this.orders.some(order => {
  754. if (order.orderno === orderno){
  755. order.edisendflag = "N";
  756. return true;
  757. }
  758. });
  759. });
  760. tempTip.setDuration(2000);
  761. tempTip.showSuccess('重置接口回传标记成功!');
  762. } else{
  763. tempTip.setDuration(5000);
  764. tempTip.show(response.data.fail_info);
  765. }
  766. }).catch(function (err) {
  767. tempTip.setDuration(3000);
  768. tempTip.show("网络错误:"+err)
  769. });
  770. },
  771. changeRemark(){
  772. this.typeId ='';
  773. this.result_explain ='';
  774. },
  775. focusOnModal(e){
  776. $(e.target).removeClass('is-invalid');
  777. },
  778. isRejectedBillExist(){
  779. if(checkData.length===0){
  780. tempTip.show('没有勾选记录');
  781. return
  782. }
  783. tempTip.confirm("是否要生成“"+checkData+"”的退货单?",()=> {
  784. let _this = this;
  785. let arr = [];
  786. window.tempTip.setDuration(9999);
  787. window.tempTip.waitingTip("生成中,请稍等......")
  788. this.orders.forEach(order=> {
  789. if (checkData.includes(order.orderno))arr.push(order.soreference1);
  790. });
  791. axios.post('{{url('order/isRejectedBillExist')}}',{data:arr})
  792. .then(function (response) {
  793. if (!response.data.success){
  794. tempTip.confirm(response.data.data+',已存在,是否仍要生成退货单?',function () {
  795. _this.createRejectedBill();
  796. window.tempTip.cancelWaitingTip();
  797. },function (){
  798. window.tempTip.cancelWaitingTip();
  799. });
  800. return;
  801. }
  802. _this.createRejectedBill();
  803. }).catch(function (error) {
  804. tempTip.setDuration(3000);
  805. tempTip.cancelWaitingTip();
  806. tempTip.show('网络错误:'+error);
  807. });
  808. });
  809. },
  810. createRejectedBill() {
  811. let url = '{{url('order/createRejectedBill')}}';
  812. axios.post(url,{data:checkData})
  813. .then(res=>{
  814. if (res.data.success){
  815. tempTip.cancelWaitingTip();
  816. tempTip.setDuration(2000);
  817. tempTip.showSuccess("生成退货单成功!");
  818. }else{
  819. tempTip.cancelWaitingTip();
  820. tempTip.setDuration(3000);
  821. tempTip.show(res.data.data);
  822. }
  823. })
  824. .catch(err=>{
  825. tempTip.cancelWaitingTip();
  826. tempTip.setDuration(3000);
  827. tempTip.show('网络错误:'+err);
  828. });
  829. },
  830. isExistByOrderNos(){
  831. let orderNos = checkData;
  832. let data = {orderNos:orderNos};
  833. let _this = this;
  834. axios.post("{{url('apiLocal/order/issue/isExistByOrderNo')}}",data).then(function(res){
  835. if(res.data.success){
  836. _this.getTagOrder(orderNos);
  837. $("#exampleModal").modal('show')
  838. }else{
  839. _this.message.checkOrderIssueMessage = res.data.fail_info
  840. $("#checkModal").modal('show')
  841. }
  842. }).catch(function(error){
  843. tempTip.setDuration(3000)
  844. tempTip.show('网络异常:'+error)
  845. })
  846. },
  847. replaceText(index){
  848. this.$set(this.orders[index],"replaceText",true);
  849. },
  850. getTagOrder(orderNos){
  851. this.tagOrders = [];
  852. if(orderNos.length === 0 ){this.tagOrders =[];return ;}
  853. if(this.orders.length === 0 ){this.tagOrders =[];return ;}
  854. for (let i = 0; i < this.orders.length; i++) {
  855. let order = this.orders[i];
  856. let orderno =order.orderno;
  857. if(orderNos.includes(orderno)){
  858. this.tagOrders.push(this.orders[i])
  859. }
  860. }
  861. this.setLogisticInfo();
  862. this.setMerchantInfo();
  863. },
  864. setLogisticInfo(){
  865. let content = ''
  866. let _this = this
  867. this.tagOrders.forEach(order=>{
  868. content+=_this.getOrderLogisticNumbers(order);
  869. let tel=order.c_tel2?order.c_tel2:order.c_tel1;
  870. content+=' '+order.c_contact+tel+order.c_province+order.c_city+' '+order.c_district+order.c_address1+'\n'+_this.result_explain+"\n"
  871. })
  872. this.tagOrder.logisticInfo = content
  873. },
  874. setMerchantInfo(){
  875. let content = ''
  876. let _this = this
  877. this.tagOrders.forEach(order=>{
  878. content+=order.issuepartyname+' '+order.customer_descr_c+' '+order.soreference1+' '+_this.getOrderLogisticNumbers(order)
  879. content += '\n'+_this.result_explain+ "\n"
  880. })
  881. this.tagOrder.merchantInfo = content
  882. },
  883. copyLogisticInfo(){
  884. this.copyText(this.tagOrder.logisticInfo)
  885. },
  886. copyLogisticNumber(){
  887. let text="";
  888. checkData.forEach((code,i)=>{
  889. if(this.picktotraceidMap[code] && this.picktotraceidMap[code].length>1){
  890. this.picktotraceidMap[code].forEach((number,j)=>{
  891. text += number+"\r\n";
  892. });
  893. }else {
  894. this.orders.some(order=>{
  895. if (order.orderno == code){
  896. if (order.soreference5) {
  897. text += order.soreference5+"\r\n";
  898. }
  899. return true;
  900. }
  901. });
  902. }
  903. });
  904. text.substring(0,text.lastIndexOf("\r\n",text));
  905. if (!text)text = " ";
  906. this.copyText(text)
  907. },
  908. copyMerchantInfo(){
  909. this.copyText(this.tagOrder.merchantInfo)
  910. },
  911. copyText(text){
  912. try {
  913. $('#clipboardDiv').text(text).select().focus();
  914. document.execCommand("Copy");
  915. tempTip.setIndex(1052)
  916. tempTip.setDuration(2000)
  917. tempTip.showSuccess('复制成功')
  918. } catch (e) {
  919. tempTip.setIndex(1052)
  920. tempTip.setDuration(2000)
  921. tempTip.showSuccess('复制失败:'+e)
  922. }
  923. },
  924. getOrderLogisticNumbers(order){
  925. let char = '';
  926. let picktotraceids = this.picktotraceidMap[order.orderno];
  927. if($.type(picktotraceids) ==='array'){
  928. picktotraceids.forEach(function(picktotraceid,index,array){
  929. if(array.length ===index+1)char+=picktotraceid;
  930. else char+=picktotraceid+','
  931. });
  932. }else {char+=order.soreference5}
  933. return char;
  934. },
  935. showInterceptModel(){
  936. this.workOrder.grad = 1;
  937. if (checkData.length < 1) {
  938. window.tempTip.show('未选中任何订单');
  939. return;
  940. }
  941. this.workOrder.orderIssueType = null;
  942. this.workOrder.info = null;
  943. $('#intercept-modal').modal('show');
  944. },
  945. checkOrderIssue(name){ //
  946. let types = this.orderIssueType.filter(item=>{
  947. return item.name === name;
  948. });
  949. if (types.length === 0 ) return false;
  950. return this.workOrder.orderIssueType === types[0].id
  951. },
  952. buildWorkOrder(){ // 生成工单
  953. let url = '{{route('workOrder.storeApi')}}';
  954. let data = {};
  955. switch (this.workOrder.orderIssueType){
  956. case "信息更改":
  957. if (checkData.length === 1){
  958. data = [{
  959. order_no:checkData[0],
  960. order_issue_type:"信息更改",
  961. grad:1,
  962. remark: this.workOrder.remark.info,
  963. }];
  964. break;
  965. }
  966. window.tempTip.show('不能批量创建信息修改工单');
  967. return;
  968. case "拦截":
  969. case "快递异常":
  970. case "错漏发":
  971. case "破损":
  972. data = checkData.map(item=>{
  973. return {
  974. order_no: item,
  975. grad:1,
  976. order_issue_type:this.workOrder.orderIssueType,
  977. remark:this.workOrder.remark.info,
  978. };
  979. });
  980. break;
  981. default:
  982. data = checkData.map(item=>{
  983. return {
  984. order_no: item,
  985. grad:1,
  986. order_issue_type:null,
  987. remark:this.workOrder.remark.info,
  988. };
  989. });
  990. break;
  991. }
  992. window.tempTip.setIndex(1999);
  993. window.axios.post(url,{params:data}).then(res=>{
  994. if (res.data.success){
  995. window.tempTip.showSuccess('工单生成成功');
  996. $('#intercept-modal').modal('hide');
  997. } else {
  998. window.tempTip.show(res.data.message ? res.data.message : '工单创建异常');
  999. }
  1000. }).catch(err=>{
  1001. window.tempTip.show(err)
  1002. });
  1003. },
  1004. changeReceiveInfo() {
  1005. let url = '{{url('apiLocal/workOrder/editOrderReceiveInfo')}}';
  1006. let data = {
  1007. order_nos:checkData[0],
  1008. grad:this.grad,
  1009. remake:`${this.remark.name} ${this.remark.phone} ${this.remark.province} ${this.remark.city} ${this.remark.city} ${this.remark.district} ${this.remark.adder}`,
  1010. };
  1011. console.log(data);
  1012. window.tempTip.setIndex('1999');
  1013. window.axios.post(url,data).then(res=>{
  1014. if (res.data.success){
  1015. window.tempTip.showSuccess('生成修改工单成功');
  1016. $('#intercept-modal').modal('hide');
  1017. } else{
  1018. window.tempTip.show(res.data.message);
  1019. }
  1020. }).catch(err=>{
  1021. window.tempTip.show(err);
  1022. });
  1023. },
  1024. manualBack(){
  1025. let _this=this;
  1026. let orders=[];
  1027. let fail=[];
  1028. let isGreater=false;
  1029. const start = new Date(new Date(new Date().toLocaleDateString()).getTime()+16*60*60*1000+30*60*1000);
  1030. if(checkData.length===0){tempTip.show('没有勾选记录');return;}
  1031. _this.orders.forEach(function(order){
  1032. if (new Date(new Date(order.addtime).getTime())>start) isGreater=true;
  1033. checkData.forEach(function (checkedId) {
  1034. if(order.orderno===checkedId){
  1035. if (order.soreference5 //存在快递单号
  1036. && order.releasestatus!='H' //订单未冻结
  1037. && order.manualflag=='N' //订单未回传
  1038. && (order.sostatus=='40' ||
  1039. order.sostatus=='50' ||
  1040. order.sostatus=='60' ||
  1041. order.sostatus=='61')) //订单状态为 分配完成,部分拣货,拣货完成,或播种完成
  1042. {orders.push(order.orderno);}else {fail.push(order.orderno)}
  1043. }
  1044. });
  1045. });
  1046. let failText='';
  1047. fail.forEach(function (item){
  1048. failText += item + ','
  1049. });
  1050. if (isGreater){
  1051. if (!confirm('订单中包含16:30以后推送的订单,有超时揽收风险,是否确定操作?')) return;
  1052. }else {
  1053. if (!confirm('提前回传订单将无法取消,是否确定操作?')) return;
  1054. }
  1055. let url = '{{url('order/manualBack')}}';
  1056. window.axios.post(url, {ordernos:orders})
  1057. .then(res => {
  1058. if (res.data.success) {
  1059. _this.orders.forEach(function (order){
  1060. res.data.successNo.forEach(function (success_item){
  1061. if (order.orderno==success_item)order.manualflag='Y';
  1062. })
  1063. })
  1064. res.data.failNo.forEach(function (item){
  1065. failText += item + ','
  1066. });
  1067. if (failText.length > 0) {
  1068. failText = failText.substr(0,failText.length - 1);
  1069. }
  1070. window.tempTip.setDuration(4000);
  1071. window.tempTip.showSuccess('回传成功!'+' 单号:'+failText+'不满足回传条件,系统已自动筛除');
  1072. this.$forceUpdate();
  1073. return;
  1074. }
  1075. window.tempTip.setDuration(3000);
  1076. window.tempTip.show('人工回传失败');
  1077. }).catch(err => {
  1078. window.tempTip.setDuration(3000);
  1079. window.tempTip.show("网络错误:" + err);
  1080. })
  1081. },
  1082. isDB(item){
  1083. if(item.indexOf('德邦') == -1 || item.indexOf('京东') == -1) return false;
  1084. return true;
  1085. }
  1086. },
  1087. });
  1088. </script>
  1089. @endsection