delivering.blade.php 52 KB

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