index.blade.php 81 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405140614071408140914101411141214131414141514161417141814191420142114221423142414251426142714281429143014311432143314341435143614371438143914401441144214431444144514461447144814491450145114521453145414551456145714581459146014611462146314641465146614671468146914701471147214731474147514761477147814791480148114821483148414851486148714881489149014911492149314941495149614971498149915001501150215031504150515061507
  1. @extends("layouts.app")
  2. @section('title','处理工单')
  3. @section("content")
  4. <div class="container-fluid d-none" id="list">
  5. <div>
  6. <div class="">
  7. <div id="form_div" style="min-width: 1220px;"></div>
  8. <div class="form-inline mt-1" id="btn">
  9. @can('订单管理-订单问题件生成')
  10. <button type="button"
  11. class="ml-1 btn btn-outline-dark btn-sm form-control-sm tooltipTarget"
  12. @click="createOrderIssue(null,false)" style="background: #dad7e8;">生成问题件
  13. </button>
  14. @endcan
  15. @can('订单管理-订单问题件生成')
  16. <button type="button"
  17. class="ml-1 btn btn-outline-primary btn-sm form-control-sm tooltipTarget"
  18. @click="exportText()">导出文本
  19. </button>
  20. @endcan
  21. @can('订单管理-工单处理-审核')
  22. @endcan
  23. <button type="button"
  24. class="ml-1 btn btn-outline-dark btn-sm form-control-sm tooltipTarget"
  25. @click="copyLogisticNumber()" style="background: #dad7e8;">批量复制单号
  26. </button>
  27. @can('订单管理-工单处理-审核')
  28. <button type="button"
  29. class="ml-1 btn btn-outline-success btn-sm form-control-sm tooltipTarget"
  30. @click="showEditIssueType">批量修改问题件类型
  31. </button>
  32. @endcan
  33. </div>
  34. <div>
  35. <table class="table table-sm table-striped table-hover table-bordered td-min-width-80 " id="table">
  36. <tbody>
  37. <template v-for="(item,i) in workOrders">
  38. <tr @click="selectTr===i+1?selectTr=0:selectTr=i+1" :class="selectTr===i+1?'focusing' : ''">
  39. <td>
  40. <label><input type="checkbox" :value="item.id"></label>
  41. </td>
  42. <td>
  43. <span v-text="item.id"></span>
  44. <a :href="'{{url("order/issue/index")}}'+'?orderCode='+item.orderno"
  45. target="order/issue/index?addtime=15">
  46. <span v-show="item.is_issue_order" class="badge badge-primary">问题件</span>
  47. </a>
  48. <span v-if="item.work_order_status === 1" class="badge badge-dark">
  49. </span>
  50. </td>
  51. <td>
  52. @can('订单管理-订单问题件生成')
  53. <button class="btn btn-sm btn-outline-primary"
  54. v-show="!item.is_issue_order "
  55. @click="createOrderIssue(item,true)">生成问题件
  56. </button>
  57. @endcan
  58. @can('订单管理-工单处理-货主编辑')
  59. <button class="btn btn-sm"
  60. style="background-color: #42a887;color: #FFFFFF;border-color: #378d72"
  61. v-if="isOwnerDispose(item)"
  62. @click="ownerShowEdit(item,i)">
  63. <span v-if="item.stats==='待货主完结'">商家完结</span>
  64. <span v-else>商家处理</span>
  65. </button>
  66. @endcan
  67. @can('订单管理-工单处理-承运商编辑')
  68. <button class="btn btn-sm"
  69. style="background-color:#e06538;color: #FFFFFF;border-color: #9a3d23"
  70. v-if="isLogisticDispose(item)"
  71. @click="logisticShowEdit(item,i)">
  72. 快递处理
  73. </button>
  74. @endcan
  75. @can('订单管理-工单处理-宝时编辑')
  76. <button class="btn btn-sm"
  77. style="background-color: #38b1e0;color: #FFFFFF;border-color:#90acb6;"
  78. v-if="isBaoShiHandler(item)"
  79. @click="baoShiShowEdit(item,i)">
  80. 宝时处理
  81. </button>
  82. <button class="btn btn-sm "
  83. style="background-color: #54c337;color: #FFFFFF;border-color:#90acb6;"
  84. v-if="isBaoShiReview(item)"
  85. @click="baoShiShowEdit(item,i)">
  86. 终审
  87. </button>
  88. @endcan
  89. </td>
  90. <td>
  91. @can('订单管理-工单处理-审核')
  92. <select class="form-control form-control-sm"
  93. :disabled="item.status === '完成'"
  94. :value="item.order_issue_type_id"
  95. @change="changeIssueType(item,$event)">
  96. <option value="0"></option>
  97. <option v-for="type in orderIssueTypes"
  98. :value="type.name"
  99. v-text="type.value">
  100. </option>
  101. </select>
  102. @else
  103. <span v-text="item.issue_type_name"></span>
  104. @endcan
  105. </td>
  106. <td>
  107. <span v-text="item.created_at"></span>
  108. </td>
  109. <td>
  110. <span v-text="item.status"></span>
  111. </td>
  112. <td>
  113. <span v-text="item.owner? item.owner.name : ''"></span>
  114. </td>
  115. <td>
  116. <span v-text="item.order? item.order.client_code : ''"></span>
  117. </td>
  118. <td>
  119. <div v-for="data in (item.order? item.order.packages : [])">
  120. <span v-text="data.logistic_number"></span>
  121. </div>
  122. </td>
  123. <td>
  124. <span v-text="item.logistic ? item.logistic.name : ''"></span>
  125. </td>
  126. <td>
  127. <span v-text="item.creator ? item.creator.name : ''"></span>
  128. </td>
  129. <td>
  130. <span v-text="item.result_explain ? item.result_explain: item.remark"></span>
  131. </td>
  132. <td class="log-td" colspan=""
  133. v-on:mouseover="showAddBtn($event)"
  134. v-on:mouseleave="hideAddBtn($event)">
  135. @include('order.workOrder._issue_logs')
  136. </td>
  137. <td class="container">
  138. <div class="row">
  139. @can('订单管理-工单处理-删除')
  140. <div class="col-1 ">
  141. <div class="header-alert">
  142. <button type="button"
  143. class="btn btn-sm btn-outline-danger"
  144. @click="destroy(item,i)">
  145. 删除
  146. </button>
  147. </div>
  148. </div>
  149. @endcan
  150. <div class="col-6 m-0 ">
  151. @include('order.workOrder._work_order_details')
  152. </div>
  153. <div @can('订单管理-工单处理-删除') class="col-5 m-0"
  154. @else class="col-6 p-0" @endcan>
  155. @include('order.workOrder._work_order_log')
  156. </div>
  157. </div>
  158. </td>
  159. </template>
  160. </tbody>
  161. </table>
  162. {{ $workOrders->withQueryString()->links() }}
  163. </div>
  164. </div>
  165. @can('订单管理-工单处理-审核')
  166. {{-- @include('order.workOrder._edit_issue_type')--}}
  167. @endcan
  168. @include('order.workOrder._bao_shi_review_modal')
  169. @include('order.workOrder._bao_shi_fill_work_order_modal')
  170. @include('order.workOrder._logistic_fill_work_order_modal')
  171. @include('order.workOrder._owner_fill_work_order_modal')
  172. </div>
  173. </div>
  174. @endsection()
  175. @section("lastScript")
  176. <script type="text/javascript" src="{{asset('js/queryForm/queryForm.js')}}"></script>
  177. <script type="text/javascript" src="{{mix('js/queryForm/header.js')}}"></script>
  178. <style>
  179. .fade-enter-active {
  180. transition: opacity .3s;
  181. }
  182. .fade-leave-active {
  183. transition: opacity .1s;
  184. }
  185. .fade-enter, .fade-leave-to {
  186. opacity: 0;
  187. }
  188. .image-div {
  189. }
  190. .image-w {
  191. width: 100%;
  192. }
  193. </style>
  194. <script>
  195. const orderIssueVue = new Vue({
  196. methods:{
  197. tagIssueLog(log) { // 标记问题件log不可见
  198. let url = '{{route('order.issue.log.tagApi')}}';
  199. let data = {id: log.id};
  200. if (!confirm('是否标记当前记录客户不可见')) return;
  201. window.axios.post(url, data).then(res => {
  202. if (res.data.success) {
  203. window.tempTip.showSuccess('标记成功');
  204. log.tag = 1;
  205. } else {
  206. window.tempTip.show(res.data.message ? res.data.message : '标记出现异常');
  207. }
  208. }).catch(err => {
  209. window.tempTip.show(err);
  210. });
  211. },
  212. addOrderIssueLog(id,order_issue_id, logs){
  213. let idInput = $('#' + id + ' :input[name="id"]');
  214. let contentInput = $('#' + id + ' :input[name="content"]');
  215. if (!contentInput.val()) {
  216. contentInput.addClass('is-invalid').focus();
  217. return;
  218. }
  219. contentInput.removeClass('is-invalid');
  220. let tag = document.getElementById(order_issue_id + '_log_check').checked;
  221. let url = '{{route('order.issue.log.storeApi')}}';
  222. let data = {id: idInput.val(), content: contentInput.val(), tag: tag ? 1 : 0};
  223. window.tempTip.waitingTip("处理中");
  224. window.axios.post(url, data).then(function (res) {
  225. window.tempTip.cancelWaitingTip();
  226. if (res.data.success) {
  227. logs.unshift(res.data.data);
  228. contentInput.val('');
  229. $('#' + id).hide();
  230. vue.successTempTip('添加成功');
  231. return;
  232. }
  233. vue.errorTempTip(res.data.fail_info);
  234. }).catch(function (err) {
  235. window.tempTip.cancelWaitingTip();
  236. vue.errorTempTip('网络异常:' + err);
  237. });
  238. },
  239. destroyLog(log,issue_logs,logIndex) { // 删除处理日志
  240. if (!confirm('是否删除当前记录')) return;
  241. if (log.type === '创建') {
  242. tempTip.show('创建记录不能删除');
  243. return;
  244. }
  245. let url = "{{route("order.issue.log.destroyApi")}}";
  246. let data = {id: log.id};
  247. window.tempTip.setIndex('1999');
  248. window.axios.post(url, data).then(res => {
  249. if (res.data.success) {
  250. issue_logs.splice(logIndex,1);
  251. tempTip.setDuration(1500);
  252. tempTip.showSuccess('删除成功');
  253. } else {
  254. tempTip.setDuration(2000);
  255. tempTip.show('删除失败:' + res.data.fail_info);
  256. }
  257. }).catch(err => {
  258. tempTip.setDuration(2500);
  259. tempTip.show('网络异常:' + err);
  260. });
  261. },
  262. }
  263. });
  264. let vue = new Vue({
  265. el: "#list",
  266. data: {
  267. orderIssueVue:orderIssueVue,
  268. workOrders: {!! $workOrders->toJson() !!}['data'],
  269. form: null,
  270. logistics: [
  271. @foreach($logistics as $logistic)
  272. {
  273. name: {{$logistic->id}}, value: '{{$logistic->name}}'
  274. },
  275. @endforeach
  276. ],
  277. orderIssueTypes: [
  278. @foreach($orderIssueTypes as $type)
  279. {
  280. name: '{{$type->id}}', value: "{{$type->name}}"
  281. },
  282. @endforeach
  283. ],
  284. owners: [
  285. @foreach($owners as $owner)
  286. {
  287. name: '{{$owner->id}}', value: '{{$owner->name}}'
  288. },
  289. @endforeach
  290. ],
  291. workOrder: {
  292. id: null,
  293. detail_id: null,
  294. reissue_logistic_number: null, // 补发单号
  295. logistic_number: null, // 丢件快递单号
  296. refundImages: [], // 退款图
  297. dealImages: [], // 交易图
  298. },
  299. logisticEditWorkOrder: {
  300. id: null,
  301. issue_type_name: null,
  302. detail_id: null,
  303. reissue_logistic_number: null, // 补发单号
  304. logistic_number: null, // 丢件快递单号
  305. commodities: [],
  306. },
  307. baoShiEditWorkOrder: {
  308. id: null,
  309. issue_type_name: null,
  310. detail_id: null,
  311. reissue_logistic_number: null, // 补发单号
  312. logistic_number: null, // 丢件快递单号
  313. commodities: [],
  314. },
  315. ownerEditWorKOrder: {
  316. id: null,
  317. issue_type_name: null,
  318. detail_id: null,
  319. price: null,
  320. reissue_logistic_number: null, // 补发单号
  321. logistic_number: null, // 丢件快递单号
  322. refundImages: [], // 退款图
  323. dealImages: [], // 交易图
  324. commodities: [],
  325. },
  326. fillWorkOrder: {
  327. id: null,
  328. issue_type_name: null,
  329. detail_id: null,
  330. reissue_logistic_number: null, // 补发单号
  331. logistic_number: null, // 丢件快递单号
  332. refundImages: [], // 退款图
  333. dealImages: [], // 交易图
  334. commodities: [],
  335. },
  336. workOrderStatus: ['创建', '信息已填写', '快递已处理', '工单完成'],
  337. reviewWorkOrder: {
  338. id: null,
  339. issue_type_name: null,
  340. detail_id: null,
  341. commodities: [],
  342. },
  343. selectTr: null, // table 行
  344. selectDetailId: null, // 详情
  345. selectCreateOrderIssueLog: null,// 创建问题件处理信息
  346. selectOrderIssueLog: null, // 问题件处理信息
  347. selectOrderIssue: null, // 问题件
  348. selectIssueType: '',
  349. selectLog: null, // 工单日志
  350. selectIndex: null, // 选中工单
  351. filePrefix: "{{asset("/storage")}}",
  352. damagedResults: ['核实破损', '核实未破损'],
  353. mistakeResults: ['核实少发', '核实多发', '核实未错漏发'],
  354. processResults: ['核实破损', '核实未破损'],
  355. mistakeProcessResults: ['少发', '多发,客户买下', '多发,客户退回', '少发,不补发', '核实未错漏发'],
  356. damagedProcessResults: ['赔偿', '不赔偿'],
  357. expressAbnormalProcessResults: ['赔偿', '不赔偿'],
  358. lossProcessResults: ['赔偿', '不赔偿'],
  359. expressAbnormalLogisticProcessResults: ['已拦截', '已催件'],
  360. processResultInfo: {
  361. "少发": {'0': '宝时补发(商家不做单)'},
  362. "多发,客户买下": {'0': '商家做出库单(物流选自提,宝时不发货)'},
  363. "多发,客户退回": {'0': '客户自行退回(提供退回单号)', '1': '宝时上门取件(提供寄件信息,地址,联系人,电话)'},
  364. '少发,不补发': {'0': '商家做入库单,选择明细和数量'},
  365. '核实未错漏发': {'0': ''},
  366. },
  367. },
  368. mounted() {
  369. let data = [[
  370. {name: 'created_at_start', type: 'time', tip: ['工单创建开始日期', '时间']},
  371. {name: 'created_at_end', type: 'time', tip: ['工单创建结束日期', '时间']},
  372. {
  373. name: 'logistic',
  374. type: 'select_multiple_select',
  375. data: this.logistics,
  376. tip: ['输入关键词快速定位下拉列表,回车确定', '选择要显示的承运商'],
  377. placeholder: ['承运商', '定位或多选承运商']
  378. },
  379. @can('订单管理-订单问题件生成')
  380. {
  381. name: 'owner',
  382. type: 'select_multiple_select',
  383. data: this.owners,
  384. tip: ['输入关键词快速定位下拉列表,回车确定', '选择要显示的货主'],
  385. placeholder: ['货主', '定位或多选货主']
  386. },
  387. @endcan
  388. {
  389. name: 'logistic_number', type: 'input', placeholder: '快递单号'
  390. },
  391. {
  392. name: 'is_issue_order',
  393. type: 'select',
  394. placeholder: '问题件',
  395. data: [{name: 'true', value: '有'}, {name: 'false', value: '无'}]
  396. },
  397. {name: 'creator', type: 'input', placeholder: '创建人'},
  398. ], [
  399. {name: 'review_at_start', type: 'time', tip: ['终审开始日期', '时间']},
  400. {name: 'review_at_end', type: 'time', tip: ['终审结束日期', '时间']},
  401. {name: 'order_issue_type', type: 'select', placeholder: '问题件类型', data: this.orderIssueTypes},
  402. {name: 'client_code', type: 'input', placeholder: '客户订单号'},
  403. {
  404. name: 'status', type: 'select', placeholder: '工单当前处理人',
  405. data: [{name: '宝时处理', value: '宝时处理'},
  406. {name: '货主处理', value: '货主处理'},
  407. {name: '承运商处理', value: '承运商处理'},]
  408. },
  409. {name: 'is_end', type: 'checkbox', tip: '是否已拦截', data: [{name: 'ture', value: '已完成'}]},
  410. ]];
  411. this.form = new query({
  412. el: '#form_div',
  413. condition: data,
  414. });
  415. this.form.init();
  416. let column = [
  417. {name: 'id', value: '工单号', neglect: true},
  418. {name: 'operation', value: '操作', neglect: true},
  419. {name: 'work_type', value: '工单类型', neglect: true},
  420. {name: 'created_at', value: '创建时间', neglect: true},
  421. {name: 'status', value: '当前处理人', neglect: true},
  422. {name: 'owner', value: '货主', neglect: true},
  423. {name: 'order_code', value: '订单号', neglect: true},
  424. {name: 'logistic_numbers', value: '快递单号'},
  425. {name: 'logistic', value: '承运商'},
  426. {name: 'creator', value: '创建人'},
  427. {name: 'remark', value: '情况说明'},
  428. {name: 'order_issue_log', value: '处理结果'},
  429. {
  430. name: 'ab_operation', type: 'multi', title: "其他操作", rows: [
  431. @can('订单管理-工单处理-删除')
  432. {
  433. value: "删除", col: "1"
  434. },
  435. {value: "查看资料", col: "6"},
  436. {value: "处理日志", col: "5"},
  437. @else
  438. {
  439. value: "查看资料", col: "6"
  440. },
  441. {value: "处理日志", col: "6"},
  442. @endcan
  443. ], neglect: true
  444. },
  445. ];
  446. new Header({
  447. el: "table",
  448. name: "workOrders",
  449. column: column,
  450. data: this.workOrders,
  451. fixedTop: ($('#form_div').height()) + 2,
  452. }).init();
  453. $("#list").removeClass("d-none");
  454. },
  455. created() {
  456. this.workOrders.forEach(item => {
  457. this.sortOrder(item);
  458. if (!item.order) return;
  459. if (!item.order.packages) return;
  460. });
  461. },
  462. filters: {
  463. dataTime: function (value) {
  464. if (value !== null) {
  465. return moment(value).format('yyyy-MM-DD');
  466. }
  467. return value
  468. },
  469. },
  470. methods: {
  471. sortOrder(workOrder) {
  472. workOrder.detail_infos = this.groupDetails(workOrder); // 工单详情
  473. workOrder.package_images = this.groupImages(workOrder, '外包装图片'); // 外包装图片
  474. workOrder.commodity_images = this.groupImages(workOrder, '内物破碎图片'); // 内物破碎图片
  475. workOrder.deal_images = this.groupImages(workOrder, '交易截图'); // 交易截图
  476. workOrder.refund_images = this.groupImages(workOrder, '退款成功截图'); //退款成功截图
  477. workOrder.issue_logs = this.groupOrderIssueLogs(workOrder); // 问题件日志
  478. workOrder.logs = this.groupLogs(workOrder); // 工单日志
  479. workOrder.commodities = this.groupCommodities(workOrder);
  480. workOrder.issue_type_name = workOrder.issue_type ? workOrder.issue_type.name : ''; // 工单类型
  481. workOrder.pending_detail = this.groupPendingDetail(workOrder);
  482. workOrder.order_issue ? (workOrder.order_issue.log_is_show = false ): '';
  483. },
  484. groupPendingDetail(workOrder) {
  485. let detail = workOrder.details.find(item => {
  486. return !['完成', '标记'].includes(item.tag);
  487. });
  488. if (!detail) return null;
  489. return {
  490. id: workOrder.id,
  491. detail_id: detail.id,
  492. commodities: detail.commodities,
  493. issue_type_name: detail.issue_type ? detail.issue_type.name : '',
  494. status: detail.status,
  495. reissue_logistic_number: detail.reissue_logistic_number,
  496. logistic_number: detail.logistic_number,
  497. price: detail.price,
  498. return_logistic_number: detail.return_logistic_number,
  499. remark: detail.remark,
  500. tag: detail.tag,
  501. };
  502. },
  503. groupCommodities(workOrder, isCurrent = true) {
  504. let commodities = [];
  505. workOrder.details.forEach(detail => {
  506. let commoditiy_itmes = detail.commodities.map(item => {
  507. item.issue_type_name = detail.issue_type ? detail.issue_type.name : '';
  508. return item;
  509. });
  510. commodities.push(...(commoditiy_itmes ?? []))
  511. });
  512. return commodities.filter(item => {
  513. if (!isCurrent) {
  514. return !['完成', '标记'].includes(item.tag);
  515. } else {
  516. return ['完成', '标记'].includes(item.tag);
  517. }
  518. })
  519. },
  520. groupOrderIssueLogs(workOrder) {
  521. workOrder.current_issue_type = workOrder.issue_type ? workOrder.issue_type.name : '';
  522. let logs = workOrder.order_issue ? (workOrder.order_issue.logs ? workOrder.order_issue.logs : []) : [];
  523. return logs.sort((perv, cur) => {
  524. let prevT = new Date(perv.created_at), curT = new Date(cur.created_at);
  525. if (prevT > curT) {
  526. return -1;
  527. } else if (prevT === curT) {
  528. return 0;
  529. } else if (prevT < curT) {
  530. return 1;
  531. }
  532. });
  533. },
  534. groupDetails(workOrder) {
  535. return workOrder.details.map(item => {
  536. return {
  537. id: item.id,
  538. issue_type: item.issue_type ? item.issue_type.name : '', // 工单类型
  539. price: item.price, // 商品价值总价
  540. reissue_logistic_number: item.reissue_logistic_number, // 补发单号
  541. return_logistic_number: item.return_logistic_number, // 退回单号
  542. logistic_number: item.logistic_number, // 快递单号
  543. status: item.status, // 工单状态
  544. created_at: item.created_at, // 创建时间
  545. tag: item.tag, // 标记
  546. };
  547. });
  548. },
  549. groupDetailCommodities(detail) {
  550. return detail.commodities.map(item => {
  551. item.commodity_name = item.commodity ? item.commodity.name : '';
  552. return item;
  553. });
  554. },
  555. groupImages(workOrder, type) {
  556. let images = [];
  557. workOrder.details.forEach(detail => {
  558. let imageList = detail.images.map(item => {
  559. item.issue_type_name = detail.issue_type ? detail.issue_type.name : '';
  560. return item;
  561. }).filter(item => {
  562. return item.type === type;
  563. })
  564. images.push(...imageList);
  565. });
  566. return images;
  567. },
  568. groupLogs(workOrder) {
  569. let logs = [];
  570. workOrder.details.forEach(detail => {
  571. let logList = detail.logs.map(item => {
  572. return {
  573. id: item.id, // id
  574. tag: detail.tag, // 标记
  575. created_at: item.created_at, // 创建时间
  576. issue_type: detail.issue_type ? detail.issue_type.name : '', // 创建时间
  577. creator: item.creator, // 创建人
  578. type: item.type, // 类型
  579. content: item.content, // 内容
  580. };
  581. });
  582. logs.push(...logList);
  583. });
  584. return logs;
  585. },
  586. createOrderIssue(item, tag) { // 生成问题件
  587. let url = '{{route('workOrder.buildOrderIssueApi')}}';
  588. let data = {};
  589. if (tag) data.ids = [item.id];
  590. else data.ids = checkData;
  591. window.tempTip.confirm('是否生成对应的问题件', () => {
  592. window.tempTip.waitingTip('生成中........');
  593. window.axios.post(url, data).then(res => {
  594. if (res.data.success) {
  595. this.replaceWorkOrder(res.data.data);
  596. this.$forceUpdate();
  597. window.tempTip.cancelWaitingTip();
  598. window.tempTip.showSuccess('已生成对应的问题件');
  599. } else {
  600. window.tempTip.cancelWaitingTip();
  601. window.tempTip.show(res.data.message ? res.data.message : '生成问题件异常');
  602. }
  603. }).catch(err => {
  604. window.tempTip.cancelWaitingTip();
  605. window.tempTip.show(err)
  606. });
  607. })
  608. },
  609. replaceWorkOrder(workOrders) {
  610. let data = [];
  611. workOrders.forEach(item => {
  612. data[item.id] = item;
  613. });
  614. this.workOrders.forEach((e, i) => {
  615. if (data[e.id]) {
  616. let item = data[e.id];
  617. this.sortOrder(item);
  618. this.$set(this.workOrders, i, item);
  619. }
  620. });
  621. this.$forceUpdate();
  622. },
  623. getMessageWorkOrder() {
  624. let selected = checkData;
  625. if (!selected) {
  626. window.tempTip.show('未选中任何信息');
  627. return null;
  628. }
  629. return this.workOrders.filter((item) => {
  630. if (!item.order || !item.order.packages) return false;
  631. return selected.includes(item.id + '');
  632. });
  633. },
  634. exportText() {
  635. let items = this.getMessageWorkOrder();
  636. if (items == null) return;
  637. let text = '';
  638. items.forEach(item => {
  639. if (item.order) text += this.getExportText(item);
  640. });
  641. this.copyText(text);
  642. },
  643. getExportText(item) {
  644. if (!item.order || !item.order.packages) return '';
  645. let message = '';
  646. let issue_type = item['issue_type'] ? item['issue_type'].name : '';
  647. switch (issue_type) {
  648. case '拦截':
  649. message = this.interceptMessage(item);
  650. break;
  651. case '信息更改':
  652. message = this.modificationMessage(item);
  653. break;
  654. default:
  655. message = this.getMessage(item);
  656. break;
  657. }
  658. return message;
  659. },
  660. interceptMessage(item) {
  661. let message = '';
  662. let order = item.order;
  663. let order_packages = item.order ? item.order.packages : [];
  664. let logistic_code = item.order ? (item.order['logistic'] ? item.order['logistic'].code : '') : ''; // 承运商编码
  665. let logistic_name = item.order ? (item.order['logistic'] ? item.order['logistic'].name : '') : ''; // 承运商名称
  666. let {consignee_name, consignee_phone, address} = order;
  667. let order_adder = `${consignee_name} ${consignee_phone} ${address}`;
  668. order_packages.forEach(item => {
  669. let logistic_number = item.logistic_number;
  670. if (logistic_code.includes('SF') || logistic_code.includes('ZTO')) {
  671. message += `${logistic_number}\n`;
  672. } else {
  673. if (item) message += `${logistic_name} ${logistic_number} ${order_adder}\n`;
  674. }
  675. });
  676. message = message.trim() + ' ——拦截\n';
  677. return message;
  678. },
  679. modificationMessage(item) {
  680. let message = '';
  681. let {remark, order} = item;
  682. let order_packages = item.order ? item.order.packages : [];
  683. let logistic_code = item.order ? (item.order['logistic'] ? item.order['logistic'].code : '') : '';
  684. const {consignee_name, consignee_phone, province, city, district, address} = order;
  685. let adder = `${consignee_name} ${consignee_phone} ${province} ${city} ${district} ${address}`;
  686. order_packages.forEach(node => {
  687. let logistic_number = node.logistic_number;
  688. if (logistic_code.includes('SF')) { // 顺丰订单
  689. message += `${logistic_number} ——改信息:${remark},运费到付或月结\n`;
  690. } else {
  691. message += `${logistic_number} ${adder} ——改地址 ${remark}\n`;
  692. }
  693. });
  694. return message;
  695. },
  696. getMessage(item) {
  697. let message = '';
  698. if (!item.order.packages) return message;
  699. let {order, remark} = item.order;
  700. let {consignee_name, consignee_phone, province, city, district, address} = order;
  701. let adder = `${consignee_name} ${consignee_phone} ${province} ${city} ${district} ${address}`;
  702. order.packages.forEach(p => {
  703. message += `${p.logistic_number} ${adder} ——描述 ${remark}\n`;
  704. });
  705. return message;
  706. },
  707. copyText(text) {
  708. let ele = document.querySelector('#copy_text');
  709. if (ele == null) {
  710. ele = document.createElement("textarea");
  711. ele.setAttribute('id', 'copy_text')
  712. ele.style.opacity = 0;
  713. document.querySelector('body').append(ele);
  714. }
  715. try {
  716. $("#copy_text").text(text).select().focus();
  717. document.execCommand("Copy");
  718. tempTip.showSuccess('复制成功')
  719. } catch (e) {
  720. tempTip.showSuccess('复制失败:' + e)
  721. }
  722. },
  723. changeIssueType(item, e) {
  724. let url = '{{route('workOrder.updateIssueTypeApi')}}';
  725. let data = {
  726. id: item.id,
  727. type_id: $(e.target).val()
  728. };
  729. window.tempTip.waitingTip('修改中.........');
  730. window.axios.post(url, data).then(res => {
  731. if (res.data.success) {
  732. window.tempTip.cancelWaitingTip();
  733. window.tempTip.showSuccess('修改成功');
  734. item.order_issue_type_id = data.type_id;
  735. } else {
  736. window.tempTip.cancelWaitingTip();
  737. window.tempTip.show(res.data.message ? res.data.message : '修改异常');
  738. }
  739. }).catch(err => {
  740. window.tempTip.cancelWaitingTip();
  741. window.tempTip.show(err);
  742. });
  743. },
  744. copyLogisticNumber() {
  745. let items = this.getMessageWorkOrder();
  746. let logistic_numbers = '';
  747. items.forEach(item => {
  748. item.order.packages.forEach(node => {
  749. logistic_numbers += `${node.logistic_number}\n`;
  750. });
  751. })
  752. this.copyText(logistic_numbers);
  753. },
  754. showEditIssueType() {
  755. this.selectIssueType = 0;
  756. $("edit-issue-type-modal").modal('show');
  757. },
  758. editOrderIssueType() {
  759. let url = '{{route('workOrder.batchUpdateIssueTypeApi')}}'
  760. let data = {ids: checkData, type: this.selectIssueType};
  761. window.tempTip.setIndex(1999);
  762. window.axios.post(url, data).then(res => {
  763. if (res.data.success) {
  764. window.tempTip.showSuccess('修改问题件类型成功');
  765. this.replaceWorkOrder(res.data.data);
  766. $("#edit-issue-type-type-modal").modal('hide');
  767. return;
  768. }
  769. window.tempTip.show(res.data.message ? res.data.message : '修改异常');
  770. }).catch(err => {
  771. window.tempTip.show(err)
  772. })
  773. },
  774. destroy(item, i) {
  775. window.tempTip.confirm('是否删除当前工单', () => {
  776. let url = '{{url('apiLocal/workOrder/')}}' + '/' + item.id;
  777. window.tempTip.waitingTip('删除.........');
  778. window.axios.delete(url).then(res => {
  779. if (res.data.success) {
  780. window.tempTip.cancelWaitingTip();
  781. window.tempTip.showSuccess('删除成功');
  782. this.$delete(this.workOrders, i);
  783. } else {
  784. window.tempTip.cancelWaitingTip();
  785. window.tempTip.show(res.data.message ? res.data.message : '');
  786. }
  787. }).catch(err => {
  788. window.tempTip.cancelWaitingTip();
  789. window.tempTip.show(err);
  790. })
  791. })
  792. },
  793. spliceImage(i, images) {
  794. window.tempTip.setIndex(1999);
  795. window.tempTip.confirm('是否取消选择该图片', () => {
  796. images.splice(i, 1);
  797. });
  798. },
  799. setFormDataImagePrefix(formData, prefix, images) {
  800. images.forEach((item, i) => {
  801. formData.append(`${prefix}[]`, item);
  802. });
  803. },
  804. getImages(images) {
  805. return images.map((item) => {
  806. return item.file;
  807. })
  808. },
  809. pasteImage(event, imageArray) {
  810. for (let i = 0; i < event.clipboardData.items.length; i++) {
  811. let item = event.clipboardData.items[i];
  812. if (item.kind === 'string') continue;
  813. if (item.type.indexOf('image') === -1) continue;
  814. if (item.kind === 'file') {
  815. let blob = item.getAsFile();
  816. let src = null;
  817. this.blobToBase64(blob).then(res => {
  818. src = res;
  819. imageArray.push({src: src, file: blob});
  820. });
  821. }
  822. }
  823. event.preventDefault();
  824. },
  825. blobToBase64(blob) {
  826. return new Promise((resolve, reject) => {
  827. const fileReader = new FileReader();
  828. fileReader.onload = (e) => {
  829. resolve(e.target.result);
  830. };
  831. fileReader.readAsDataURL(blob);
  832. fileReader.onerror = () => {
  833. reject(new Error('blobToBase64 error'));
  834. };
  835. });
  836. },
  837. getOrderCommodity(item) {
  838. return new Promise((resolve, reject) => {
  839. let url = '{{route('order.commodity.getCommoditiesApi')}}';
  840. let data = {orderNo: item ? (item.order ? item.order.code : '') : ''};
  841. window.axios.post(url, data).then(res => {
  842. if (res.data.success) {
  843. this.countCommoditiesByLogisticNumber(res.data.data);
  844. resolve(res.data.data);
  845. }
  846. }).catch(err => {
  847. });
  848. });
  849. },
  850. countCommoditiesByLogisticNumber(commodities){
  851. let index = 0;
  852. let logistic_number = commodities[0]['logistic_number'];
  853. let count = 0;
  854. for(let i = 0; i < commodities.length;i++){
  855. let cur_logistic_number = commodities[i]['logistic_number'];
  856. if (i === commodities.length - 1 && cur_logistic_number === logistic_number){
  857. count ++;
  858. commodities[index]['count'] = count;
  859. break;
  860. }
  861. if (logistic_number === cur_logistic_number){
  862. count++;
  863. } else if (logistic_number !== cur_logistic_number){
  864. commodities[index]['count'] = count;
  865. index = i;
  866. count = 1;
  867. }
  868. if (i === commodities.length - 1){
  869. commodities[index]['count'] = count;
  870. }
  871. }
  872. return commodities;
  873. },
  874. baoShiReview(item, i) { // 宝时终审
  875. this.reviewWorkOrder = JSON.parse(JSON.stringify(item.pending_detail));
  876. this.selectIndex = i;
  877. $('#bao-shi-review-modal').modal('show');
  878. },
  879. getCurrentWorkOrderDetailId(workOrder) {
  880. let items = workOrder.details.filter(item => {
  881. return !['标记', '完成'].includes(item.tag);
  882. });
  883. if (items.length === 0) return null;
  884. let item = items.shift();
  885. return item.id;
  886. },
  887. reviewWorkOrderCommodity(formData) {
  888. this.reviewWorkOrder.commodities.forEach(e => {
  889. formData.append("commodities[]", JSON.stringify(e));
  890. });
  891. },
  892. computeBaoShiCheckResult(item) {
  893. let amount = Number(item.amount);
  894. let bao_shi_check_amount = Number(item['bao_shi_check_amount']);
  895. item.check_result = amount === bao_shi_check_amount ? '核实未错漏发' : (amount < bao_shi_check_amount ? '核实多发' : '核实少发')
  896. },
  897. sumPrice(workOrder) {
  898. workOrder.price = workOrder.commodities.reduce((prev, cur) => {
  899. return Number(prev) + Number(cur.price);
  900. }, 0);
  901. },
  902. getBadgeColor(tag) { // 标记 返回徽章标记
  903. if (tag === '完成') return 'badge-success';
  904. if (tag === '创建') return 'badge-primary';
  905. return '';
  906. },
  907. // 宝时处理
  908. isBaoShiHandler(item){
  909. return '错漏发' === item.issue_type_name && item.status === '宝时处理';
  910. },
  911. isBaoShiReview(item){
  912. return item.status === '宝时终审';
  913. },
  914. baoShiShowEdit(item,index) {
  915. let {status} = item;
  916. let {issue_type_name, detail_id,commodities} = item.pending_detail;
  917. if ("快递丢件" === issue_type_name){
  918. this.selectIndex = index;
  919. this.baoShiEditWorkOrder.issue_type_name = item.issue_type_name;
  920. this.baoShiEditWorkOrder.status = status;
  921. this.baoShiEditWorkOrder.detail_id = detail_id;
  922. commodities.forEach(e=>{
  923. e.bao_shi_check_amount = e.abnormal_amount;
  924. });
  925. this.baoShiEditWorkOrder.commodities = this.countCommoditiesByLogisticNumber(commodities);
  926. $("#bao-shi-review-modal").modal('show');
  927. } else if('破损' === issue_type_name){
  928. this.selectIndex = index;
  929. this.baoShiEditWorkOrder.issue_type_name = issue_type_name;
  930. this.baoShiEditWorkOrder.detail_id = detail_id;
  931. this.baoShiEditWorkOrder.status = status;
  932. commodities.forEach(e=>{
  933. e.bao_shi_check_amount = e.check_amount;
  934. });
  935. this.baoShiEditWorkOrder.commodities = this.countCommoditiesByLogisticNumber(commodities);;
  936. $("#bao-shi-review-modal").modal('show');
  937. } else if ('快递异常' === issue_type_name){
  938. this.selectIndex = index;
  939. this.baoShiEditWorkOrder.issue_type_name = issue_type_name;
  940. this.baoShiEditWorkOrder.detail_id = detail_id;
  941. this.baoShiEditWorkOrder.status = status;
  942. commodities.forEach(e=>{
  943. e.bao_shi_check_amount = e.check_amount;
  944. });
  945. this.baoShiEditWorkOrder.commodities = this.countCommoditiesByLogisticNumber(commodities);;
  946. $("#bao-shi-review-modal").modal('show');
  947. } else if ('错漏发' === issue_type_name){
  948. this.selectIndex = index;
  949. this.baoShiEditWorkOrder.issue_type_name = issue_type_name;
  950. this.baoShiEditWorkOrder.detail_id = detail_id;
  951. this.baoShiEditWorkOrder.status = status;
  952. commodities.forEach(e=>{
  953. e.bao_shi_check_amount = e.check_amount;
  954. e.check_result = null;
  955. });
  956. this.baoShiEditWorkOrder.commodities = this.countCommoditiesByLogisticNumber(commodities);;
  957. $("#bao-shi-review-modal").modal('show');
  958. }
  959. },
  960. baoShiEdit() {
  961. let {status,commodities,issue_type_name} = this.baoShiEditWorkOrder;
  962. if ('快递丢件' === issue_type_name ){
  963. let url = '{{route('workOrder.loss.baoShi.reviewApi')}}';
  964. let formData = new FormData();
  965. formData.append('detail_id',this.baoShiEditWorkOrder.detail_id);
  966. commodities.forEach(e => {
  967. formData.append("commodities[]", JSON.stringify(e));
  968. });
  969. window.tempTip.setIndex(2000);
  970. window.tempTip.waitingTip('处理中');
  971. window.axios.post(url,formData).then(res=>{
  972. window.tempTip.cancelWaitingTip();
  973. if (res.data.success){
  974. this.sortOrder(res.data.data);
  975. this.$set(this.workOrders,this.selectIndex,res.data.data);
  976. $("#bao-shi-review-modal").modal('hide');
  977. this.successTempTip('处理完成')
  978. } else {
  979. this.errorTempTip(res.data.message ? res.data.message : '处理工单出现异常,刷新后重试');
  980. }
  981. }).catch(err=>{
  982. window.tempTip.cancelWaitingTip();
  983. this.errorTempTip(err);
  984. });
  985. } else if('破损' === issue_type_name){
  986. let res = this.checkBaoShiEditWorkOrder();
  987. if (!res.success){
  988. this.errorTempTip(res.message);
  989. return;
  990. }
  991. let url = '{{route('workOrder.damage.baoShi.reviewApi')}}';
  992. let formData = new FormData();
  993. formData.append('detail_id',this.baoShiEditWorkOrder.detail_id);
  994. commodities.forEach(e => {
  995. formData.append("commodities[]", JSON.stringify(e));
  996. });
  997. window.tempTip.setIndex(2000);
  998. window.tempTip.waitingTip('处理中');
  999. window.axios.post(url,formData).then(res=>{
  1000. window.tempTip.cancelWaitingTip();
  1001. if (res.data.success){
  1002. this.sortOrder(res.data.data);
  1003. this.$set(this.workOrders,this.selectIndex,res.data.data);
  1004. this.successTempTip('处理完成');
  1005. $("#bao-shi-review-modal").modal('hide');
  1006. } else {
  1007. this.errorTempTip(res.data.message ? res.data.message : '处理出现异常,刷新页面重试');
  1008. }
  1009. }).catch(err=>{
  1010. window.tempTip.cancelWaitingTip();
  1011. this.errorTempTip(err);
  1012. });
  1013. } else if ('快递异常' === issue_type_name){
  1014. let res = this.checkBaoShiEditWorkOrder();
  1015. if (!res.success){
  1016. this.errorTempTip(res.message);
  1017. return;
  1018. }
  1019. let url = '{{route('workOrder.damage.baoShi.reviewApi')}}';
  1020. let formData = new FormData();
  1021. formData.append('detail_id',this.baoShiEditWorkOrder.detail_id);
  1022. commodities.forEach(e => {
  1023. formData.append("commodities[]", JSON.stringify(e));
  1024. });
  1025. window.tempTip.setIndex(2000);
  1026. window.tempTip.waitingTip('处理中');
  1027. window.axios.post(url,formData).then(res=>{
  1028. window.tempTip.cancelWaitingTip();
  1029. if (res.data.success){
  1030. this.sortOrder(res.data.data);
  1031. this.$set(this.workOrders,this.selectIndex,res.data.data);
  1032. this.successTempTip('处理完成');
  1033. $("#bao-shi-review-modal").modal('hide');
  1034. } else {
  1035. this.errorTempTip(res.data.message ? res.data.message : '处理出现异常,刷新页面重试');
  1036. }
  1037. }).catch(err=>{
  1038. window.tempTip.cancelWaitingTip();
  1039. this.errorTempTip(err);
  1040. });
  1041. } else if ('错漏发' === issue_type_name){
  1042. let res = this.checkBaoShiEditWorkOrder();
  1043. if (!res.success){
  1044. this.errorTempTip(res.message);
  1045. return;
  1046. }
  1047. let url = '{{route('workOrder.mistake.baoShi.reviewApi')}}';
  1048. let formData = new FormData();
  1049. formData.append('detail_id',this.baoShiEditWorkOrder.detail_id);
  1050. commodities.forEach(e => {
  1051. formData.append("commodities[]", JSON.stringify(e));
  1052. });
  1053. window.tempTip.setIndex(2000);
  1054. window.tempTip.waitingTip('处理中');
  1055. window.axios.post(url,formData).then(res=>{
  1056. window.tempTip.cancelWaitingTip();
  1057. if (res.data.success){
  1058. this.sortOrder(res.data.data);
  1059. this.$set(this.workOrders,this.selectIndex,res.data.data);
  1060. this.successTempTip('处理完成');
  1061. $("#bao-shi-review-modal").modal('hide');
  1062. } else {
  1063. this.errorTempTip(res.data.message ? res.data.message : '处理出现异常,刷新页面重试');
  1064. }
  1065. }).catch(err=>{
  1066. window.tempTip.cancelWaitingTip();
  1067. this.errorTempTip(err);
  1068. });
  1069. }
  1070. },
  1071. // 承运商相关
  1072. isLogisticDispose(item) {
  1073. return ['拦截', '信息更改', '快递异常', '破损','快递丢件'].includes(item.issue_type_name) && item.status === '承运商处理';
  1074. },
  1075. logisticShowEdit(item, index) {
  1076. let {status} = item.issue_type_name;
  1077. let {issue_type_name,detail_id,commodities} = item.pending_detail;
  1078. if (issue_type_name === '拦截') {
  1079. window.tempTip.waitingTip('处理中');
  1080. let url = "{{route('workOrder.intercept.logistic.handlerApi')}}";
  1081. let data = {detail_id: detail_id};
  1082. window.axios.post(url, data).then(res => {
  1083. window.tempTip.cancelWaitingTip();
  1084. if (res.data.success) {
  1085. this.successTempTip("处理完成");
  1086. this.sortOrder(res.data.data);
  1087. this.$set(this.workOrders, index, res.data.data);
  1088. } else {
  1089. this.errorTempTip(res.data.message ? res.data.message : '处理出现异常!刷新页面重试');
  1090. }
  1091. }).catch(err => {
  1092. window.tempTip.cancelWaitingTip();
  1093. this.errorTempTip(err)
  1094. });
  1095. } else if (issue_type_name === '信息更改') {
  1096. window.tempTip.waitingTip('处理中');
  1097. let url = "{{route('workOrder.informationChange.logistic.handlerApi')}}";
  1098. let data = {detail_id: item.pending_detail.detail_id};
  1099. window.axios.post(url, data).then(res => {
  1100. window.tempTip.cancelWaitingTip();
  1101. if (res.data.success) {
  1102. this.successTempTip("处理完成");
  1103. this.sortOrder(res.data.data);
  1104. this.$set(this.workOrders, index, res.data.data);
  1105. } else {
  1106. this.errorTempTip(res.data.message ? res.data.message : '处理出现异常!刷新页面重试');
  1107. }
  1108. }).catch(err => {
  1109. window.tempTip.cancelWaitingTip();
  1110. this.errorTempTip(err)
  1111. });
  1112. } else if ('快递丢件' === issue_type_name ){
  1113. this.selectIndex = index;
  1114. this.logisticEditWorkOrder.detail_id = item.pending_detail.detail_id;
  1115. this.logisticEditWorkOrder.issue_type_name = issue_type_name;
  1116. this.logisticEditWorkOrder.status = status;
  1117. let commodities = item.pending_detail.commodities;
  1118. commodities.forEach(e=>{
  1119. e.check_amount = e.abnormal_amount;
  1120. });
  1121. this.logisticEditWorkOrder.commodities = this.countCommoditiesByLogisticNumber(commodities);
  1122. $("#logistic-fill-work-order-modal").modal('show');
  1123. } else if ('破损' === issue_type_name){
  1124. this.selectIndex = index;
  1125. this.logisticEditWorkOrder.detail_id = item.pending_detail.detail_id;
  1126. this.logisticEditWorkOrder.issue_type_name = issue_type_name;
  1127. this.logisticEditWorkOrder.status = status;
  1128. let commodities = item.pending_detail.commodities;
  1129. commodities.forEach(e=>{
  1130. e.check_amount = e.abnormal_amount;
  1131. });
  1132. this.logisticEditWorkOrder.commodities = this.countCommoditiesByLogisticNumber(commodities);
  1133. $("#logistic-fill-work-order-modal").modal('show');
  1134. } else if ('快递异常' === issue_type_name){
  1135. this.selectIndex = index;
  1136. this.logisticEditWorkOrder.detail_id = detail_id;
  1137. this.logisticEditWorkOrder.issue_type_name = issue_type_name;
  1138. this.logisticEditWorkOrder.status = status;
  1139. let commodities = item.pending_detail.commodities;
  1140. commodities.forEach(e=>{
  1141. e.check_amount = e.abnormal_amount;
  1142. });
  1143. this.logisticEditWorkOrder.commodities = this.countCommoditiesByLogisticNumber(commodities);
  1144. $("#logistic-fill-work-order-modal").modal('show');
  1145. }
  1146. },
  1147. logisticEdit() {
  1148. let {issue_type_name,commodities,detail_id} = this.logisticEditWorkOrder;
  1149. if (issue_type_name ==='破损'){
  1150. let res = this.checkLogisticEditWorkOrder();
  1151. if (!res.success){
  1152. this.errorTempTip(res.message);
  1153. return;
  1154. }
  1155. let url = '{{route('workOrder.damage.logistic.handlerApi')}}';
  1156. let formData= new FormData();
  1157. formData.append('detail_id',detail_id);
  1158. commodities.forEach(e=>{
  1159. formData.append('commodities[]',JSON.stringify(e));
  1160. });
  1161. window.tempTip.setIndex(2000);
  1162. window.tempTip.waitingTip('处理中');
  1163. window.axios.post(url,formData).then(res=>{
  1164. window.tempTip.cancelWaitingTip();
  1165. if (res.data.success){
  1166. this.sortOrder(res.data.data);
  1167. this.$set(this.workOrders,this.selectIndex,res.data.data);
  1168. this.successTempTip('处理完成');
  1169. $("#logistic-fill-work-order-modal").modal('hide');
  1170. } else {
  1171. this.errorTempTip(res.data.message ? res.data.message : '处理出现异常,刷新当前页面重试');
  1172. }
  1173. }).catch(err=>{
  1174. window.tempTip.cancelWaitingTip();
  1175. this.errorTempTip(err);
  1176. })
  1177. } else if ('快递异常' === issue_type_name){
  1178. let res = this.checkLogisticEditWorkOrder();
  1179. if (!res.success){
  1180. this.errorTempTip(res.message);
  1181. return;
  1182. }
  1183. let url = '{{route('workOrder.expressAbnormal.logistic.handlerApi')}}';
  1184. let formData= new FormData();
  1185. formData.append('detail_id',detail_id);
  1186. commodities.forEach(e=>{
  1187. formData.append('commodities[]',JSON.stringify(e));
  1188. });
  1189. window.tempTip.setIndex(2000);
  1190. window.tempTip.waitingTip('处理中');
  1191. window.axios.post(url,formData).then(res=>{
  1192. window.tempTip.cancelWaitingTip();
  1193. if (res.data.success){
  1194. this.sortOrder(res.data.data);
  1195. this.$set(this.workOrders,this.selectIndex,res.data.data);
  1196. this.successTempTip('处理完成');
  1197. $("#logistic-fill-work-order-modal").modal('hide');
  1198. } else {
  1199. this.errorTempTip(res.data.message ? res.data.message : '处理出现异常,刷新当前页面重试');
  1200. }
  1201. }).catch(err=>{
  1202. window.tempTip.cancelWaitingTip();
  1203. this.errorTempTip(err);
  1204. })
  1205. }
  1206. },
  1207. // 商家相关
  1208. isOwnerDispose(item) {
  1209. if (item.issue_type_name === '快递丢件' && item.status === '货主处理') return true;
  1210. else if (item.issue_type_name === '错漏发' && item.status === '待货主完结') return true;
  1211. return false;
  1212. },
  1213. ownerShowEdit(item, index) {
  1214. let issue_type_name = item.issue_type_name;
  1215. if (issue_type_name === '快递丢件' && item.status === '货主处理') {
  1216. window.tempTip.waitingTip('获取数据中');
  1217. this.getOrderCommodity(item).then(res => {
  1218. window.tempTip.cancelWaitingTip();
  1219. this.selectIndex = index;
  1220. this.ownerEditWorKOrder.pirce = null;
  1221. this.ownerEditWorKOrder.status = item.status;
  1222. this.ownerEditWorKOrder.issue_type_name = issue_type_name;
  1223. this.ownerEditWorKOrder.commodities = res.map(item => {
  1224. item.abnormal_amount = item.amount;
  1225. item.tag = 0;
  1226. item.price = 0;
  1227. return item;
  1228. }); //商品详情
  1229. this.ownerEditWorKOrder.id = item.id; // 工单id
  1230. this.ownerEditWorKOrder.detail_id = item.pending_detail.detail_id; // 工单详情id
  1231. this.ownerEditWorKOrder.reissue_logistic_number = null; //
  1232. this.ownerEditWorKOrder.logistic_number = null; //
  1233. this.ownerEditWorKOrder.refundImages = []; // 退款截图
  1234. this.ownerEditWorKOrder.dealImages = []; // 交易截图
  1235. $("#owner-fill-work-order-modal").modal('show');
  1236. }).catch(err => {
  1237. window.tempTip.cancelWaitingTip();
  1238. this.errorTempTip('获取数据异常')
  1239. });
  1240. } else if (issue_type_name === '错漏发' && item.status === '待货主完结') {
  1241. this.selectIndex = index;
  1242. this.ownerEditWorKOrder.detail_id = item.pending_detail.detail_id;
  1243. let commodities = item.pending_detail.commodities;
  1244. commodities.forEach(e=>{
  1245. e.check_amount = e.abnormal_amount;
  1246. });
  1247. this.ownerEditWorKOrder.commodities = this.countCommoditiesByLogisticNumber(commodities);
  1248. this.ownerEditWorKOrder.status = item.status;
  1249. this.ownerEditWorKOrder.issue_type_name = issue_type_name;
  1250. $("#owner-fill-work-order-modal").modal('show');
  1251. }
  1252. },
  1253. ownerEdit() {
  1254. let {issue_type_name, status} = this.ownerEditWorKOrder;
  1255. if (issue_type_name === '快递丢件' && status === '货主处理') {
  1256. let res = this.checkOwnerEditWorkOrder();
  1257. if (!res.success) {
  1258. this.errorTempTip(res.message);
  1259. return;
  1260. }
  1261. let formData = new FormData();
  1262. let {detail_id, reissue_logistic_number, logistic_number, price, dealImages, refundImages,commodities} = this.ownerEditWorKOrder;
  1263. formData.append('detail_id', detail_id);
  1264. formData.append('reissue_logistic_number', reissue_logistic_number);
  1265. formData.append('logistic_number', logistic_number);
  1266. formData.append('price', price);
  1267. dealImages = this.getImages(dealImages);
  1268. refundImages = this.getImages(refundImages);
  1269. this.setFormDataImagePrefix(formData, 'dealImages', dealImages);
  1270. this.setFormDataImagePrefix(formData, 'refundImages', refundImages);
  1271. commodities.forEach(e => {
  1272. formData.append("commodities[]", JSON.stringify(e));
  1273. });
  1274. window.tempTip.waitingTip('处理中');
  1275. let url = '{{route('workOrder.loss.owner.fillDetailApi')}}';
  1276. window.axios.post(url, formData,{'Content-Type': 'multipart/form-data'}).then(res => {
  1277. window.tempTip.cancelWaitingTip();
  1278. if (res.data.success) {
  1279. this.successTempTip('处理完成');
  1280. this.sortOrder(res.data.data);
  1281. this.$set(this.workOrders, this.selectIndex, res.data.data);
  1282. this.selectIndex = null;
  1283. $("#owner-fill-work-order-modal").modal('hide');
  1284. } else if (res.data.message) {
  1285. this.errorTempTip(res.data.message);
  1286. } else {
  1287. this.errorTempTip('处理出现异常');
  1288. }
  1289. }).catch(err => {
  1290. window.tempTip.cancelWaitingTip();
  1291. this.errorTempTip(err);
  1292. })
  1293. } else if (issue_type_name === '错漏发' && this.ownerEditWorKOrder.status === '待货主完结') {
  1294. let res = this.checkOwnerEditWorkOrder();
  1295. if (!res.success) {
  1296. this.errorTempTip(res.message);
  1297. return;
  1298. }
  1299. let url = '{{route('workOrder.mistake.owner.handlerAndEndApi')}}';
  1300. let formData = new FormData();
  1301. let {detail_id, commodities} = this.ownerEditWorKOrder;
  1302. formData.append('detail_id', detail_id);
  1303. commodities.forEach(e => {
  1304. formData.append("commodities[]", JSON.stringify(e));
  1305. });
  1306. window.tempTip.waitingTip('处理中');
  1307. window.axios.post(url, formData,{'Content-Type': 'multipart/form-data'}).then(res => {
  1308. window.tempTip.cancelWaitingTip();
  1309. if (res.data.success) {
  1310. this.successTempTip('处理完成');
  1311. this.sortOrder(res.data.data);
  1312. this.$set(this.workOrders, this.selectIndex, res.data.data);
  1313. this.selectIndex = null;
  1314. $("#owner-fill-work-order-modal").modal('hide');
  1315. } else if (res.data.message) {
  1316. this.errorTempTip(res.data.message);
  1317. } else {
  1318. this.errorTempTip('处理出现异常');
  1319. }
  1320. }).catch(err => {
  1321. window.tempTip.cancelWaitingTip();
  1322. this.errorTempTip(err);
  1323. })
  1324. }
  1325. },
  1326. checkBaoShiEditWorkOrder(){
  1327. if ( ['破损','快递异常'].includes(this.baoShiEditWorkOrder.issue_type_name)){
  1328. let filers = this.baoShiEditWorkOrder.commodities.filter(e => {
  1329. return e.process_result === null || e.process_result.length <= 0;
  1330. });
  1331. if (filers.length > 0){
  1332. return {success: false, message: '商品详情中处理结果不能为空'};
  1333. }
  1334. } else if ('错漏发' === this.baoShiEditWorkOrder.issue_type_name){
  1335. let filers = this.baoShiEditWorkOrder.commodities.filter(e => {
  1336. return e.check_result === null || e.check_result.length <= 0;
  1337. });
  1338. if (filers.length > 0){
  1339. return {success: false, message: '商品详情中处理结果不能为空'};
  1340. }
  1341. }
  1342. return {success:true};
  1343. },
  1344. checkOwnerEditWorkOrder() {
  1345. if (this.ownerEditWorKOrder.issue_type_name === '快递丢件'){
  1346. if (this.ownerEditWorKOrder.reissue_logistic_number) {
  1347. } else if (this.ownerEditWorKOrder.dealImages.length === 0) {
  1348. return {success: false, message: '交易截图和补发单号 二选一'};
  1349. }
  1350. if (this.ownerEditWorKOrder.commodities.length === 0) {
  1351. return {success: false, message: '丢件商品为必填项'};
  1352. }
  1353. let filers = this.ownerEditWorKOrder.commodities.filter(item => {
  1354. return Number(item.price) <= 0 || Number(item.abnormal_amount) <= 0;
  1355. });
  1356. if (filers.length > 0) {
  1357. return {success: false, message: '商品详情中价格为异常数量为必填项,且不为0'};
  1358. }
  1359. } else if (this.ownerEditWorKOrder.issue_type_name === '错漏发'){
  1360. let filters = this.ownerEditWorKOrder.commodities.filter(e=>{
  1361. if (e.check_result!== '核实未错漏发' &&( e.process_result === '' || e.process_result_info === ''))return true;
  1362. else return e.check_result === '核实未错漏发' && e.process_result === '';
  1363. });
  1364. if (filters.length > 0 ){
  1365. return {success: false, message: '商品详情中的处理项,和处理子项 未必选项'};
  1366. }
  1367. }
  1368. return {success: true};
  1369. },
  1370. checkLogisticEditWorkOrder(){
  1371. let filers = this.logisticEditWorkOrder.commodities.filter(item => {
  1372. return item.check_result.length === 0;
  1373. });
  1374. if (filers.length > 0){
  1375. return {success:false,message:'商品详情的核实结果不能为空'}
  1376. }
  1377. return {success:true};
  1378. },
  1379. successTempTip(message) {
  1380. window.tempTip.setDuration(1500);
  1381. window.tempTip.setIndex(2000);
  1382. window.tempTip.showSuccess(message);
  1383. },
  1384. errorTempTip(message) {
  1385. window.tempTip.setDuration(2000);
  1386. window.tempTip.setIndex(2000);
  1387. window.tempTip.show(message);
  1388. },
  1389. getProcessResult(check_result,item){
  1390. let results = null;
  1391. if (check_result === '核实少发'){
  1392. results = ['少发','少发,不补发'];
  1393. }else if (check_result === '核实多发'){
  1394. results = ['多发,客户买下','多发,客户退回'];
  1395. }else if (check_result === '核实未错漏发'){
  1396. results = ['核实未错漏发'];
  1397. item.process_result = '核实未错漏发';
  1398. }
  1399. return results;
  1400. },
  1401. getProcessResultInfo(process_result,item){
  1402. let processResultInfos = {
  1403. "少发": ['宝时补发(商家不做单)'],
  1404. "多发,客户买下": ['商家做出库单(物流选自提,宝时不发货)'],
  1405. "多发,客户退回": ['客户自行退回(提供退回单号)','宝时上门取件(提供寄件信息,地址,联系人,电话)'],
  1406. '少发,不补发': ['商家做入库单,选择明细和数量'],
  1407. '核实未错漏发': [''],
  1408. };
  1409. let infos = processResultInfos[process_result];
  1410. if (typeof(infos) === 'undefined') return [];
  1411. if (infos.length === 0){
  1412. item.process_result_info = infos[0];
  1413. }
  1414. return infos;
  1415. },
  1416. showAddBtn(e) {
  1417. let domObj = $(e.target).parents('.log-td');
  1418. if (domObj.hasClass('log-td')) {
  1419. domObj.find('.add-btn').show();
  1420. } else {
  1421. let obj = $(e.target);
  1422. if (obj.hasClass('log-td')) {
  1423. obj.find('.add-btn').show();
  1424. }
  1425. }
  1426. },
  1427. hideAddBtn(e) {
  1428. let domObj = $(e.target);
  1429. if (domObj.hasClass('log-td')) {
  1430. domObj.find('.add-btn').hide();
  1431. }
  1432. },
  1433. showAddDiv(id) {
  1434. let div = $('#' + id);
  1435. if (div.is(":hidden")) {
  1436. div.show();
  1437. div.find('input[type=text]').focus();
  1438. } else {
  1439. div.hide();
  1440. }
  1441. },
  1442. removeFocusing(e) {
  1443. $(e.target).parent('tr').removeClass('focusing')
  1444. },
  1445. showDelBtn(e) {
  1446. let domObj = $(e.target).parent();
  1447. domObj.find('.del-btn').addClass('visible').removeClass('invisible');
  1448. },
  1449. hideDelBtn(e) {
  1450. let domObj = $(e.target);
  1451. domObj.find('.del-btn').addClass('invisible').removeClass('visible');
  1452. },
  1453. toggleLogs(orderIssue, e, index) {
  1454. if (orderIssue.log_is_show === false) {
  1455. orderIssue.log_is_show = true;
  1456. $(e.target).text('点击收起');
  1457. } else {
  1458. orderIssue.log_is_show = false;
  1459. $(e.target).text("记录共" + orderIssue.logs.length + "条,点击展开");
  1460. }
  1461. },
  1462. countByCommodities(commodities){
  1463. if (commodities.length === 0) return;
  1464. let index = 0;
  1465. let logistic_number = commodities[0]['logistic_number'];
  1466. let count = 0;
  1467. for(let i = 0; i < commodities.length;i++){
  1468. let cur_logistic_number = commodities[i]['logistic_number'];
  1469. if (i === commodities.length - 1 && cur_logistic_number === logistic_number){
  1470. count ++;
  1471. commodities[index]['count'] = count;
  1472. break;
  1473. }
  1474. if (logistic_number === cur_logistic_number){
  1475. count++;
  1476. } else if (logistic_number !== cur_logistic_number){
  1477. commodities[index]['count'] = count;
  1478. index = i;
  1479. count = 1;
  1480. }
  1481. if (i === commodities.length - 1){
  1482. commodities[index]['count'] = count;
  1483. }
  1484. }
  1485. }
  1486. },
  1487. });
  1488. </script>
  1489. @endsection