delivering.blade.php 54 KB

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