delivering.blade.php 70 KB

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