index.blade.php 83 KB

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