index.blade.php 40 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745
  1. @extends('layouts.app')
  2. @section('title')快递查询-包裹管理@endsection
  3. @section('head')
  4. <style>
  5. .package-logistic-index {
  6. position: relative;
  7. }
  8. /*备注容器*/
  9. .order-package-remarks {
  10. position: relative;
  11. }
  12. /*新建按钮*/
  13. .btn-create-remark {
  14. width: 25px;
  15. height: 25px;
  16. line-height: 25px;
  17. text-align: center;
  18. position: absolute;
  19. display: none;
  20. background-color: rgb(92, 141, 236);
  21. border: blue solid 1px;
  22. color: #111;
  23. box-shadow: 0 0 6px #4747f1;
  24. float: left;
  25. }
  26. .order-package-remarks:hover .btn-create-remark {
  27. display: block;
  28. }
  29. /*新建输入框*/
  30. .remark-input {
  31. height: 30px;
  32. line-height: 30px;
  33. padding-left: 16px;
  34. margin-left: 35px;
  35. box-shadow: 0 0 6px #fff6a1;
  36. border-radius: 5px;
  37. }
  38. /*删除按钮*/
  39. .order-package-remarks table .destroy {
  40. float: right;
  41. position: absolute;
  42. right: 0;
  43. padding: 0 !important;
  44. width: 29px !important;
  45. min-width: 30px !important;
  46. border: 0 solid transparent !important;
  47. }
  48. .remark-created_at {
  49. border-right: none !important;
  50. }
  51. .btn-destroy-remark {
  52. display: none;
  53. background-color: rgba(0, 0, 0, 0);
  54. border: red solid 1px;
  55. color: red;
  56. box-shadow: 0 0 6px #ac4a4a;
  57. }
  58. .order-package-remarks table:hover .btn-destroy-remark {
  59. display: block;
  60. }
  61. </style>
  62. @stop
  63. @section('content')
  64. <div id="list" class="d-none package-logistic-index">
  65. <div class="container-fluid">
  66. <div id="form_div"></div>
  67. <div class="ml-3 form-inline" id="btn">
  68. @can('包裹管理-快递-异常类型-编辑')
  69. <span class="dropdown">
  70. <button type="button"
  71. class="btn btn-outline-dark btn-sm form-control-sm dropdown-toggle tooltipTarget"
  72. data-toggle="dropdown" title="导出所有页将会以搜索条件得到的筛选结果,将其全部记录(每一页)导出">导出Excel
  73. </button>
  74. <div class="dropdown-menu">
  75. <a class="dropdown-item" @click="orderPackageExport(false)" href="javascript:">导出勾选内容</a>
  76. <a class="dropdown-item" @click="orderPackageExport(true)" href="javascript:">导出所有页</a>
  77. </div>
  78. </span>
  79. <span class="ml-1">
  80. <select class="form-control-sm ml-2" v-model="batchStatus">
  81. <option v-for="(value,index) in statuses" :value="value"
  82. :name="value" :key="index">@{{ value }}
  83. </option>
  84. </select>
  85. <button @click="batchStatusUpdate()" type="button"
  86. class="btn btn-sm ml-2 btn-outline-danger">批量状态修改
  87. </button>
  88. </span>
  89. <span class="ml-1">
  90. <select class="form-control-sm ml-2" v-model="batchExceptionStatus">
  91. <option v-for="(value,index) in exception_statuses" :value="value"
  92. :name="value" :key="index">@{{ value }}
  93. </option>
  94. </select>
  95. <button @click="batchExceptionStatusUpdate()" type="button"
  96. class="btn btn-sm ml-2 btn-outline-danger">批量异常状态修改
  97. </button>
  98. </span>
  99. <span class="ml-1">
  100. <!-- Button trigger modal -->
  101. <button
  102. type="button"
  103. class="btn btn-sm ml-2 btn-outline-info"
  104. data-toggle="modal" data-target="#staticBackdrop">
  105. 批量添加备注
  106. </button>
  107. </span>
  108. <span class="ml-1">
  109. <button type="button" class="btn btn-outline-dark btn-sm form-control-sm tooltipTarget"
  110. @click="copyLogisticNumber" style="background: #dad7e8;">复制快递单号</button>
  111. </span>
  112. {{-- 获取查询条件下的总条数--}}
  113. <span class="ml-1">
  114. <button type="button" class="btn btn-outline-success btn-sm form-control-sm tooltipTarget"
  115. @click="getTotal()"
  116. style="background: #dad7e8;">
  117. <span v-if="!total.loading">
  118. @{{ total.number===null?'获取总量':'总量:'+ total.number }}
  119. </span>
  120. <span v-else style="margin-left: 5px"><i class="fa fa-circle-o-notch fa-spin"></i>
  121. </span>
  122. </button>
  123. </span>
  124. @endcan
  125. </div>
  126. <table class="table table-striped table-bordered table-hover card-body td-min-width-80" id="table">
  127. <tr v-for="(package,i) in packages" @click="selectTr===i+1?selectTr=0:selectTr=i+1"
  128. :class="selectTr===i+1?'focusing' : ''">
  129. <td>
  130. <input class="checkItem" type="checkbox" :value="package.logistic_number">
  131. </td>
  132. <td>
  133. <span style="position:relative;line-height: 12px">
  134. @{{ i+1 }}
  135. <!-- 是否同步过 -->
  136. <span
  137. style="display: inline-block;width: 15px;height: 15px;border-radius: 50%;position: relative;top: 3px; margin-left: 3px;box-shadow: 0 0 3px #211f1f"
  138. :style="package.sync_routes_flag?'background-color:#4ed32d':'background-color:#e83939'"></span>
  139. <!-- 是否为问题件 -->
  140. <span class="badge badge-danger" v-if="package.order.issue">?</span>
  141. <!-- 是否关联工单 -->
  142. <span class="badge badge-info text-white" v-if="package.work_order">工</span>
  143. <!-- 是否手动修改 -->
  144. <span v-if="package.is_manual_update">
  145. <i class="fa fa-hand-paper-o" aria-hidden="true"
  146. style="color: red;margin-left: 5px"></i>
  147. </span>
  148. <!-- 延时发货图标 -->
  149. <span
  150. v-if="package.is_delay_deliver"
  151. style="margin-left: 5px">
  152. <i class="fa fa-circle-o-notch fa-spin"></i>
  153. </span>
  154. </span>
  155. </td>
  156. <td :style="package.exception_status=='单号异常'?'color:red':''">@{{ package.logistic_number }}</td>
  157. <td>@{{ package.status }}</td>
  158. <td>@{{ package.exception_status }}</td>
  159. <td>@{{ package.order != null ? package.order.logistic.name : '#' }}</td>
  160. <td>@{{ package.order != null ? package.order.owner.name : '#' }}</td>
  161. <td>@{{ package.order != null ? package.order.warehouse.name : '#' }}</td>
  162. <td>@{{ package.order != null ? package.order.province : '#' }}</td>
  163. <td>@{{ package.created_at }}</td>
  164. <td>@{{ package.sent_at }}</td>
  165. <td>@{{ package.received_at }}</td>
  166. <td>@{{ package.weighed_at }}</td>
  167. <td>
  168. <div v-if="package.order_package_express_route?.order_package_express_routes?.length>0"
  169. class="text-overflow-warp-200 up" :id="'route-'+i">
  170. <p v-for="route in package.order_package_express_route.order_package_express_routes">
  171. @{{ route.accept_address+"-"+ route.remark+"-"+route.accept_time}}
  172. </p>
  173. </div>
  174. <div class="text-overflow-warp-200 " v-if="package.order_package_express_route?.order_package_express_routes?.length>0 && !showList[i]">
  175. @{{ package.order_package_express_route.order_package_express_routes[0].accept_address+" "+ package.order_package_express_route.order_package_express_routes[0].remark+" "+package.order_package_express_route.order_package_express_routes[0].accept_time}}
  176. </div>
  177. <div v-if="package.order_package_express_route?.order_package_express_routes?.length>1" @click="showRoute(i)">
  178. <label class="text-center mt-0 p-0 cursor-pointer pull-left">
  179. <span class="fa" :class="package.isShowTransferStatus ? 'fa-angle-double-down' : 'fa-angle-double-right'"></span>
  180. &nbsp;<span v-if="showList[i]">收起</span>
  181. <span v-else>展开</span>&nbsp;
  182. @{{ package.order_package_express_route.order_package_express_routes.length }} 条
  183. </label>
  184. </div>
  185. </td>
  186. <!--退件状态-->
  187. <td>@{{ package.rejected_bill?'有':'无' }}</td>
  188. <td>@{{ package.order && package.order.oracle_d_o_c_order_header && package.order.oracle_d_o_c_order_header.notes }}</td>
  189. <td class="m-0 p-0 order-package-remarks" style="padding-left: 0 !important;padding-right: 0 !important">
  190. @can('包裹管理-快递-客服备注')
  191. <label :for="'create_remark_'+package.id" class="btn-create-remark" @click="package.input_remark=!package.input_remark">
  192. </label>
  193. <input :id="'create_remark_'+package.id" @keyup.enter="submitRemark(package)" v-model="remark" v-show="package.input_remark" type="text" class="remark-input">
  194. <table class="table m-0 p-0 ">
  195. <tr v-show="package.order_package_remarks.length > 0 && package.showMoreRemark===true" v-for="(item,index) of package.order_package_remarks" :key="item.id">
  196. <td :title="item.content" style="width: 100px;overflow:hidden !important;">@{{ item.content }}</td>
  197. <td class="text-secondary">@{{ item.user.name }}</td>
  198. <td class="text-secondary remark-created_at">@{{ item.created_at }}</td>
  199. <td class="destroy"><button class="btn-destroy-remark" @click="destroyRemark(package,item.id)">删</button></td>
  200. </tr>
  201. <tr v-show="(!package.showMoreRemark) && package.order_package_remarks.length > 0" >
  202. <td :title="package.order_package_remarks[0]? package.order_package_remarks[0].content:''" style="width: 100px;overflow:hidden !important;">@{{ package.order_package_remarks[0]?package.order_package_remarks[0].content:'' }}</td>
  203. <td class="text-secondary">@{{ package.order_package_remarks[0]?package.order_package_remarks[0].user.name:'' }}</td>
  204. <td class="text-secondary remark-created_at">@{{ package.order_package_remarks[0]?package.order_package_remarks[0].created_at:'' }}</td>
  205. <td class="destroy"><button class="btn-destroy-remark" @click="destroyRemark(package,package.order_package_remarks[0].id)">删</button></td>
  206. </tr>
  207. </table>
  208. <div
  209. class="float-left"
  210. @click="package.showMoreRemark = !package.showMoreRemark" v-show="package.order_package_remarks && package.order_package_remarks.length > 1">
  211. <label class="text-center mt-0 p-0 cursor-pointer pull-left">
  212. <span class="fa"
  213. :class="package.showMoreRemark ? 'fa-angle-double-down' : 'fa-angle-double-right'"></span>
  214. &nbsp;<span v-if="package.order_package_remarks && package.showMoreRemark">收起</span><span
  215. v-else>展开</span>&nbsp;@{{ package.order_package_remarks.length }} 条
  216. </label>
  217. </div>
  218. @endcan
  219. </td>
  220. <td class="text-overflow-warp-200"><span v-if="package.order && package.order.issue">@{{ package.order.issue.result_explain }}</span>
  221. </td>
  222. <td class="text-overflow-warp-200">
  223. <span v-if="package.order && package.order.issue && package.order.issue.issue_type">@{{ package.order.issue.issue_type.name }}</span>
  224. </td>
  225. <td class="text-overflow-warp-200">@{{ package.order && package.order.batch &&
  226. package.order.batch.wms_type }}
  227. </td>
  228. <td class="text-overflow-warp-200">@{{ package.order && package.order.oracle_d_o_c_order_header &&
  229. package.order.oracle_d_o_c_order_header.waveno }}
  230. </td>
  231. <td class="text-overflow-warp-200"><span
  232. v-if="package.order && package.order.issue && package.order.issue.logs.length >0"><span
  233. v-for="log in package.order.issue.logs">@{{ log.content }}<br></span></span></td>
  234. <td class="text-overflow-warp-200"><span
  235. v-if="package.order && package.order.issue && package.order.issue.logs.length >0"><span
  236. v-for="log in package.order.issue.logs">@{{ log && log.user && log.user.name }}<br></span></span>
  237. </td>
  238. <td class="text-overflow-warp-200"><span
  239. v-if="package.order && package.order.issue && package.order.issue.logs.length >0"><span
  240. v-for="log in package.order.issue.logs">@{{ log.created_at }}<br></span></span></td>
  241. </tr>
  242. </table>
  243. {{$orderPackages->appends($paginateParams)->links()}}
  244. <!-- 模态框 -->
  245. <div class="modal fade" id="staticBackdrop" data-backdrop="static" data-keyboard="false" tabindex="-1"
  246. aria-labelledby="staticBackdropLabel" aria-hidden="true" z-index="51">
  247. <div class="modal-dialog">
  248. <div class="modal-content">
  249. <div class="modal-header">
  250. <h5 class="modal-title" id="staticBackdropLabel">添加备注</h5>
  251. <button type="button" class="close" data-dismiss="modal" aria-label="Close">
  252. <span aria-hidden="true">&times;</span>
  253. </button>
  254. </div>
  255. <div class="modal-body">
  256. <div class="form-group">
  257. <textarea v-model="bench_remark" style="width:80%;margin: 0 auto;" class="form-control"
  258. id="exampleFormControlTextarea1" rows="3"></textarea>
  259. </div>
  260. </div>
  261. <div class="modal-footer">
  262. <button @click="bench_remark = ''" type="button" class="btn btn-secondary"
  263. data-dismiss="modal">关闭
  264. </button>
  265. <button @click="submitBenchRemark" type="button" class="btn btn-primary">提交</button>
  266. </div>
  267. </div>
  268. </div>
  269. </div>
  270. </div>
  271. <textarea id="clipboardDiv" style="opacity:0"></textarea>
  272. </div>
  273. @endsection
  274. @section('lastScript')
  275. <script type="text/javascript" src="{{mix('js/queryForm/export.js')}}"></script>
  276. <script type="text/javascript" src="{{mix('js/queryForm/queryForm.js')}}"></script>
  277. <script type="text/javascript" src="{{mix('js/queryForm/header.js')}}"></script>{{--新版2--}}
  278. <script>
  279. let vue = new Vue({
  280. el: "#list",
  281. data: {
  282. total: {
  283. number: null,
  284. loading: false
  285. },
  286. packages: [
  287. @foreach($orderPackages as $package)
  288. {!! $package !!},
  289. @endforeach
  290. ],
  291. logistics: [
  292. @foreach($logistics as $logistic)
  293. {
  294. name: '{{$logistic->id}}', value: '{{$logistic->name}}'
  295. },
  296. @endforeach
  297. ],
  298. owners: [
  299. @foreach($owners as $owner)
  300. {
  301. name: '{{$owner->id}}', value: '{{$owner->name}}'
  302. },
  303. @endforeach
  304. ],
  305. warehouses:[
  306. @foreach($warehouses as $warehouse)
  307. {
  308. name: '{{$warehouse->id}}', value: '{{$warehouse->name}}'
  309. },
  310. @endforeach
  311. ],
  312. showList: {},
  313. showRemarkList: {},
  314. selectTr: 0,
  315. statuses: [
  316. '生成订单',
  317. '已复核',
  318. '已称重',
  319. '已揽件',
  320. '在途',
  321. '派送中',
  322. '已签收',
  323. '其他',
  324. '返回中',
  325. ],
  326. exception_statuses: [
  327. '单号异常',
  328. '无法获取路由',
  329. '延迟发货',
  330. '疑似库内丢件',
  331. '在途异常',
  332. '揽件异常',
  333. '派送异常'
  334. ],
  335. batchStatus: null,
  336. batchExceptionStatus: null,
  337. remarkHover: null,
  338. remark: null,
  339. isShowRemarkInput: false,
  340. showBenchRemarkWrapper: false,
  341. bench_remark: '',
  342. },
  343. created() {
  344. $.each(this.packages, function (index, item) {
  345. item.isShowTransferStatus = false;
  346. item.isShowRemark = false;
  347. if (item.order_package_express_route != null && item.order_package_express_route.order_package_express_routes.length > 1) {
  348. item.order_package_express_route.order_package_express_routes.sort(function (item1, item2) {
  349. let date1 = new Date(item1.accept_time);
  350. let date2 = new Date(item2.accept_time);
  351. if (date1 - date2 > 0) return -1;
  352. if (date1 - date2 < 0) return 1;
  353. return 0;
  354. });
  355. }
  356. });
  357. },
  358. mounted() {
  359. $('#list').removeClass('d-none');
  360. let _this = this;
  361. $(".up").slideUp();
  362. let data = [
  363. [
  364. {name: 'logistic_number', type: 'input', tip: '可支持多快递单号,糊模查找需要在右边打上%符号', placeholder: '快递单号'},
  365. {name: 'remark', type: 'input', tip: '糊模查找需要在右边打上%符号', placeholder: '客服备注'},
  366. {name: 'result_explain', type: 'input', tip: '糊模查找需要在右边打上%符号', placeholder: '情况说明'},
  367. {
  368. name: 'status',
  369. type: 'select_multiple_select',
  370. tip: ['输入关键词快速定位下拉列表,回车确定', '选择要显示的状态'],
  371. placeholder: ['状态', '定位或多选状态'],
  372. data: [
  373. {name: '0', value: '空'},
  374. {name: '1', value: '生成订单'},
  375. {name: '2', value: '已复核'},
  376. {name: '3', value: '已称重'},
  377. {name: '4', value: '已揽件'},
  378. {name: '5', value: '在途'},
  379. {name: '6', value: '派送中'},
  380. {name: '7', value: '已签收'},
  381. {name: '8', value: '其他'},
  382. {name: '9', value: '返回中'},
  383. ]
  384. },
  385. {name: 'created_at_start', type: 'dateTime', tip: '选择显示创建时间的起始时间'},
  386. {name: 'sent_at_start', type: 'dateTime', tip: '选择显示复核时间的起始时间'},
  387. {
  388. name: 'is_weighed',
  389. type: 'select',
  390. tip: ['输入关键词快速定位下拉列表,回车确定', '选择要显示的状态'],
  391. placeholder: '是否称重',
  392. data: [{name: false, value: '无'}, {name: true, value: '已称重'}]
  393. },
  394. {name: 'received_at_start', type: 'dateTime', tip: '选择显示收货时间的起始时间'},
  395. {
  396. name: 'is_customer_service_remark',
  397. type: 'select',
  398. tip: ['输入关键词快速定位下拉列表,回车确定', '选择要显示的状态'],
  399. placeholder: ['客服备注'],
  400. data: [
  401. {name: '是', value: '是'},
  402. {name: '否', value: '否'},
  403. ]
  404. },
  405. {name: 'customer_service_remark_created_at_start', type: 'dateTime', tip: '选择显示客服备注时间的起始时间'},
  406. ],
  407. [
  408. {
  409. name: 'logistic',
  410. type: 'select_multiple_select',
  411. tip: ['输入关键词快速定位下拉列表,回车确定', '选择要显示的快递'],
  412. placeholder: ['快递', '定位或多选快递'],
  413. data: _this.logistics
  414. },
  415. {
  416. name: 'owner',
  417. type: 'select_multiple_select',
  418. tip: ['输入关键词快速定位下拉列表,回车确定', '选择要显示的货主'],
  419. placeholder: ['货主', '定位或多选货主'],
  420. data: _this.owners
  421. },
  422. {
  423. name: 'warehouse',
  424. type: 'select_multiple_select',
  425. tip: ['输入关键词快速定位下拉列表,回车确定', '选择要显示的货主'],
  426. placeholder: ['仓库', '定位或多选仓库'],
  427. data: _this.warehouses
  428. },
  429. {
  430. name: 'has_transfer_status',
  431. type: 'select',
  432. tip: ['输入关键词快速定位下拉列表,回车确定', '选择要显示的状态'],
  433. placeholder: '是否有物流信息',
  434. data: [{name: '是', value: '是'}, {name: '否', value: '否'}]
  435. },
  436. {
  437. name: 'sync_routes_flag',
  438. type: 'select',
  439. tip: ['输入关键词快速定位下拉列表,回车确定', '选择要显示的状态'],
  440. placeholder: '是否有查询记录',
  441. data: [{name: true, value: '是'}, {name: false, value: '否'}]
  442. },
  443. {name: 'created_at_end', type: 'dateTime', tip: '选择显示创建时间的截至时间'},
  444. {name: 'sent_at_end', type: 'dateTime', tip: '选择显示复核时间的截止时间'},
  445. {
  446. name: 'is_issue',
  447. type: 'select',
  448. tip: ['输入关键词快速定位下拉列表,回车确定', '选择要显示的状态'],
  449. placeholder: '是否为问题件',
  450. data: [{name: '是', value: '是'}, {name: '否', value: '否'}]
  451. },
  452. {name: 'received_at_end', type: 'dateTime', tip: '选择显示收货时间的截止时间'},
  453. {
  454. name: 'is_new_rejecting',
  455. type: 'select',
  456. tip: ['输入关键词快速定位下拉列表,回车确定', '选择要显示的状态'],
  457. placeholder: '退件状态',
  458. data: [{name: '无', value: '无'}, {name: '有', value: '有'}]
  459. },
  460. {name: 'customer_service_remark_created_at_end', type: 'dateTime', tip: '选择显示客服备注时间的起始时间'},
  461. ],
  462. [
  463. {
  464. name: 'issue_type_name',
  465. type: 'select',
  466. tip: ['输入关键词快速定位下拉列表,回车确定', '选择要显示的状态'],
  467. placeholder: '问题类型',
  468. data: [
  469. {name: '拦截', value: '拦截'},
  470. {name: '快递异常', value: '快递异常'},
  471. {name: '信息更改', value: '信息更改'},
  472. {name: '联系不上', value: '联系不上'},
  473. {name: '其他', value: '其他'},
  474. {name: '错漏发', value: '错漏发'},
  475. {name: '仓库问题', value: '仓库问题'},
  476. {name: '快递丢件', value: '快递丢件'},
  477. {name: '破损', value: '破损'},
  478. {name: '撤销丢件', value: '撤销丢件'},
  479. {name: '二次加工', value: '二次加工'},
  480. {name: '全检问题', value: '全检问题'},
  481. {name: '系统问题', value: '系统问题'},
  482. {name: '延迟发货', value: '延迟发货'},
  483. {name: '仓库丢件', value: '仓库丢件'},
  484. {name: '快递方式更改', value: '快递方式更改'},
  485. {name: '无记录', value: '无记录'},
  486. ]
  487. },
  488. {name: 'order_notes', type: 'input', tip: '糊模查找需要在右边打上%符号', placeholder: '订单备注'},
  489. {
  490. name: 'exception_status',
  491. type: 'select_multiple_select',
  492. tip: ['输入关键词快速定位下拉列表,回车确定', '选择要显示的异常'],
  493. placeholder: ['异常', '定位或多选异常'],
  494. data: [
  495. {name: '1', value: '单号异常'},
  496. {name: '2', value: '无法获取路由'},
  497. {name: '3', value: '延迟发货'},
  498. {name: '4', value: '疑似库内丢件'},
  499. {name: '5', value: '在途异常'},
  500. {name: '6', value: '揽件异常'},
  501. {name: '7', value: '派送异常'},
  502. ]
  503. },
  504. {name: 'default_date', type: 'checkbox', tip: '默认15天', data: [{name: 'ture', value: '默认15天'}]},
  505. {
  506. name: 'default_logistics',
  507. type: 'checkbox',
  508. tip: '默认承运商',
  509. data: [{name: 'ture', value: '默认承运商'}]
  510. },
  511. {name: 'virtual_receive', type: 'checkbox', tip: '虚拟揽收', data: [{name: 'ture', value: '虚拟揽收'}]},
  512. ]
  513. ];
  514. _this.form = new query({
  515. el: '#form_div',
  516. condition: data,
  517. appendDom: "btn",
  518. });
  519. _this.form.init();
  520. let column = [
  521. {name: 'index', value: '序号', neglect: true},
  522. {name: 'logistic_number', value: '单号'},
  523. {name: 'status', value: '状态'},
  524. {name: 'exception_status', value: '异常状态'},
  525. {name: 'logistic_name', value: '快递公司'},
  526. {name: 'owner_name', value: '货主'},
  527. {name: 'warehouse_name', value: '仓库'},
  528. {name: 'province', value: '省份'},
  529. {name: 'created_at', value: '订单生成日期'},
  530. {name: 'sent_at', value: '发出日期'},
  531. {name: 'received_at', value: '收货日期'},
  532. {name: 'weighed_at', value: '称重日期'},
  533. {name: 'transfer_status', value: '快递路由'},
  534. {name: 'is_new_rejecting', value: '退件状态'},
  535. {name: 'order_notes', value: '订单备注'},
  536. {name: 'remark', value: '客服备注'},
  537. {name: 'result_explain', value: '情况说明'},
  538. {name: 'issue_type', value: '问题类别'},
  539. {name: 'wms_type', value: '波次规则'},
  540. {name: 'wave_no', value: '波次号'},
  541. {name: 'content', value: '说明'},
  542. {name: 'operation_name', value: '操作者'},
  543. {name: 'operation_date', value: '时间'},
  544. ];
  545. new Header({
  546. el: "table",
  547. name: "package",
  548. column: column,
  549. data: this.packages,
  550. restorationColumn: 'addtime',
  551. fixedTop: ($('#form_div').height()) + ($('#btn').height()) + 1,
  552. }).init();
  553. },
  554. methods: {
  555. //获取查询条件下的总条数
  556. getTotal() {
  557. if (!this.total.loading) {
  558. this.total.loading = true
  559. let query = "{{ request()->getQueryString() }}";
  560. query = query.replace(/amp;/g, "");
  561. let url = "{{ url()->current() }}";
  562. url += `/getTotal?${query}`;
  563. axios.get(url).then(res => {
  564. this.$forceUpdate();
  565. let responseData = res.data;
  566. if (responseData.success) {
  567. this.total.number = responseData.data.total;
  568. this.total.loading = false
  569. tempTip.showSuccess('获取总量成功!');
  570. }
  571. }).catch(e => {
  572. this.total.loading = false
  573. tempTip.show(`获取异常请稍后再试!${e}`);
  574. });
  575. } else {
  576. tempTip.show(`点击过于频繁请稍后再试!${e}`);
  577. }
  578. },
  579. showRoute(id) {
  580. if (this.showList[id]) {
  581. this.$set(this.showList, id, false);
  582. $("#route-" + id).slideUp();
  583. } else {
  584. this.$set(this.showList, id, true);
  585. $("#route-" + id).slideDown();
  586. }
  587. this.$forceUpdate();
  588. },
  589. showRemarkItem(id) {
  590. if (this.showRemarkList[id]) {
  591. this.$set(this.showRemarkList, id, false);
  592. $("#remark-" + id).slideUp();
  593. } else {
  594. this.$set(this.showRemarkList, id, true);
  595. $("#remark-" + id).slideDown();
  596. }
  597. this.$forceUpdate();
  598. },
  599. batchStatusUpdate() {
  600. if (!confirm('是否却认操作')) return;
  601. let _this = this;
  602. if (checkData.length === 0) {
  603. tempTip.show('没有勾选记录');
  604. return
  605. }
  606. axios.put('{{url('package/logistic/batchUpdate')}}', {
  607. status: this.batchStatus,
  608. logistic_numbers: checkData
  609. }).then(() => {
  610. tempTip.setDuration(1000);
  611. tempTip.showSuccess('批量状态成功');
  612. location.reload();
  613. })
  614. },
  615. batchExceptionStatusUpdate() {
  616. if (!confirm('是否却认操作')) return;
  617. let _this = this;
  618. if (checkData.length === 0) {
  619. tempTip.show('没有勾选记录');
  620. return
  621. }
  622. axios.put('{{url('package/logistic/batchUpdate')}}', {
  623. exceptionStatus: this.batchExceptionStatus,
  624. logistic_numbers: checkData
  625. }).then(() => {
  626. tempTip.setDuration(1000);
  627. tempTip.showSuccess('批量异常状态成功');
  628. location.reload();
  629. })
  630. },
  631. submitBenchRemark() {
  632. let _this = this;
  633. if (checkData.length === 0) {
  634. tempTip.show('没有勾选记录');
  635. return
  636. }
  637. axios.post('{{url('apiLocal/package/logistic/benchRemark')}}', {
  638. remark: this.bench_remark,
  639. logistic_numbers: checkData
  640. }).then(() => {
  641. location.reload();
  642. })
  643. },
  644. submitRemark(orderPackage) {
  645. if (this.remark === null) {
  646. return
  647. }
  648. let url = '{{url('apiLocal/package/logistic/')}}';
  649. let _this = this;
  650. tempTip.setDuration(2000);
  651. tempTip.showSuccess('正在操作请稍后!');
  652. axios.put(url, {remark: _this.remark, orderPackageId: orderPackage.id}).then(response => {
  653. if (response.data.success) {
  654. orderPackage.order_package_remarks = response.data.data
  655. tempTip.setDuration(2000);
  656. tempTip.showSuccess('成功!');
  657. _this.remark = '';
  658. orderPackage.input_remark = false;
  659. } else {
  660. tempTip.setDuration(5000);
  661. tempTip.show(response.data.fail_info);
  662. }
  663. }).catch(function (err) {
  664. tempTip.setDuration(3000);
  665. tempTip.show("网络错误:" + err)
  666. });
  667. },
  668. destroyRemark(orderPackage, remarkId) {
  669. let url = '{{url('apiLocal/package/logistic/delete')}}';
  670. if (!confirm('是否却认删除', false)) {
  671. return;
  672. }
  673. ;
  674. let _this = this;
  675. tempTip.setDuration(2000);
  676. tempTip.showSuccess('正在操作请稍后!');
  677. axios.post(url, {orderPackageId: orderPackage.id, remarkId: remarkId}).then(response => {
  678. if (response.data.success) {
  679. orderPackage.order_package_remarks = response.data.data
  680. tempTip.setDuration(2000);
  681. tempTip.showSuccess('成功!');
  682. } else {
  683. tempTip.setDuration(5000);
  684. tempTip.show(response.data.fail_info);
  685. }
  686. }).catch(function (err) {
  687. tempTip.setDuration(3000);
  688. tempTip.show("网络错误:" + err)
  689. });
  690. },
  691. copyLogisticNumber() {
  692. if (checkData.length === 0) {
  693. tempTip.show('没有勾选');
  694. return;
  695. }
  696. this.copyText(checkData.join('\n'));
  697. },
  698. copyText(text) {
  699. try {
  700. $('#clipboardDiv').text(text).select().focus();
  701. document.execCommand("Copy");
  702. tempTip.setIndex(1052)
  703. tempTip.setDuration(2000)
  704. tempTip.showSuccess('复制成功')
  705. } catch (e) {
  706. tempTip.setIndex(1052)
  707. tempTip.setDuration(2000)
  708. tempTip.showSuccess('复制失败:' + e)
  709. }
  710. },
  711. orderPackageExport(sign) {
  712. let url = '{{url('package/logistic/export')}}';
  713. let token = '{{ csrf_token() }}';
  714. if (sign) {
  715. excelExport(true, checkData, url, this.total, token);
  716. } else {
  717. excelExport(false, checkData, url, null, token);
  718. }
  719. },
  720. },
  721. filters: {
  722. toObjected: function (value) {
  723. return JSON.parse(value);
  724. }
  725. },
  726. });
  727. </script>
  728. @endsection