delivering.blade.php 69 KB

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