delivering.blade.php 66 KB

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