index.blade.php 145 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344134513461347134813491350135113521353135413551356135713581359136013611362136313641365136613671368136913701371137213731374137513761377137813791380138113821383138413851386138713881389139013911392139313941395139613971398139914001401140214031404140514061407140814091410141114121413141414151416141714181419142014211422142314241425142614271428142914301431143214331434143514361437143814391440144114421443144414451446144714481449145014511452145314541455145614571458145914601461146214631464146514661467146814691470147114721473147414751476147714781479148014811482148314841485148614871488148914901491149214931494149514961497149814991500150115021503150415051506150715081509151015111512151315141515151615171518151915201521152215231524152515261527152815291530153115321533153415351536153715381539154015411542154315441545154615471548154915501551155215531554155515561557155815591560156115621563156415651566156715681569157015711572157315741575157615771578157915801581158215831584158515861587158815891590159115921593159415951596159715981599160016011602160316041605160616071608160916101611161216131614161516161617161816191620162116221623162416251626162716281629163016311632163316341635163616371638163916401641164216431644164516461647164816491650165116521653165416551656165716581659166016611662166316641665166616671668166916701671167216731674167516761677167816791680168116821683168416851686168716881689169016911692169316941695169616971698169917001701170217031704170517061707170817091710171117121713171417151716171717181719172017211722172317241725172617271728172917301731173217331734173517361737173817391740174117421743174417451746174717481749175017511752175317541755175617571758175917601761176217631764176517661767176817691770177117721773177417751776177717781779178017811782178317841785178617871788178917901791179217931794179517961797179817991800180118021803180418051806180718081809181018111812181318141815181618171818181918201821182218231824182518261827182818291830183118321833183418351836183718381839184018411842184318441845184618471848184918501851185218531854185518561857185818591860186118621863186418651866186718681869187018711872187318741875187618771878187918801881188218831884188518861887188818891890189118921893189418951896189718981899190019011902190319041905190619071908190919101911191219131914191519161917191819191920192119221923192419251926192719281929193019311932193319341935193619371938193919401941194219431944194519461947194819491950195119521953195419551956195719581959196019611962196319641965196619671968196919701971197219731974197519761977197819791980198119821983198419851986198719881989199019911992199319941995199619971998199920002001200220032004200520062007200820092010201120122013201420152016201720182019202020212022202320242025202620272028202920302031203220332034203520362037203820392040204120422043204420452046204720482049205020512052205320542055205620572058205920602061206220632064206520662067206820692070207120722073207420752076207720782079208020812082208320842085208620872088208920902091209220932094209520962097209820992100210121022103210421052106210721082109211021112112211321142115211621172118211921202121212221232124212521262127212821292130213121322133213421352136213721382139214021412142214321442145214621472148214921502151215221532154215521562157215821592160216121622163216421652166216721682169217021712172217321742175217621772178217921802181218221832184218521862187218821892190219121922193219421952196219721982199220022012202220322042205220622072208220922102211221222132214221522162217221822192220222122222223222422252226222722282229223022312232223322342235223622372238223922402241224222432244224522462247224822492250225122522253225422552256225722582259226022612262226322642265226622672268226922702271227222732274227522762277227822792280228122822283228422852286228722882289229022912292229322942295229622972298229923002301230223032304230523062307230823092310231123122313231423152316231723182319232023212322232323242325232623272328232923302331233223332334233523362337233823392340234123422343234423452346234723482349235023512352235323542355235623572358235923602361236223632364236523662367236823692370237123722373237423752376237723782379238023812382238323842385238623872388238923902391239223932394239523962397239823992400240124022403240424052406240724082409241024112412241324142415241624172418241924202421242224232424242524262427242824292430243124322433243424352436243724382439244024412442244324442445244624472448244924502451245224532454245524562457245824592460246124622463246424652466246724682469247024712472247324742475247624772478247924802481248224832484248524862487248824892490249124922493249424952496249724982499250025012502250325042505250625072508250925102511251225132514251525162517251825192520252125222523252425252526252725282529
  1. @extends("layouts.app")
  2. @section('title','处理工单')
  3. @section('head')
  4. <link href="{{ mix('css/element-ui.css') }}" rel="stylesheet">
  5. @endsection
  6. @section("content")
  7. <div class="container-fluid d-none" id="list">
  8. <div>
  9. <div class="">
  10. <div id="form_div" style="min-width: 1220px;"></div>
  11. <div class="form-inline mt-1" id="btn">
  12. @can('订单管理-订单问题件生成')
  13. <button type="button"
  14. class="ml-1 btn btn-outline-dark btn-sm form-control-sm tooltipTarget"
  15. @click="createOrderIssue(null,false)" style="background: #dad7e8;">生成问题件
  16. </button>
  17. @endcan
  18. @can('订单管理-订单问题件生成')
  19. <button type="button"
  20. class="ml-1 btn btn-outline-primary btn-sm form-control-sm tooltipTarget"
  21. @click="exportText()">导出文本
  22. </button>
  23. @endcan
  24. @can('订单管理-工单处理-审核')
  25. @endcan
  26. <button type="button"
  27. class="ml-1 btn btn-outline-dark btn-sm form-control-sm tooltipTarget"
  28. @click="copyLogisticNumber()" style="background: #dad7e8;">批量复制单号
  29. </button>
  30. @can('订单管理-工单处理-审核')
  31. @endcan
  32. </div>
  33. <div>
  34. <table class="table table-sm table-striped table-hover table-bordered td-min-width-80 " id="table">
  35. <tbody>
  36. <template v-for="(item,i) in workOrders">
  37. <tr @click="selectTr===i+1?selectTr=0:selectTr=i+1" :class="selectTr===i+1?'focusing' : ''">
  38. <td>
  39. <label><input type="checkbox" :value="item.id"></label>
  40. </td>
  41. <td>
  42. <span v-text="item.id"></span>
  43. <a :href="'{{url("order/issue/index")}}'+'?orderCode='+item.orderno"
  44. target="order/issue/index?addtime=15">
  45. <span v-show="item.is_issue_order" class="badge badge-primary">问题件</span>
  46. </a>
  47. <span v-if="item.work_order_status === '1'" class="badge text-white bg-info">
  48. </span>
  49. <button class="btn btn-sm btn-outline-secondary"
  50. @click="showWorkOrderItem(item)">详情
  51. </button>
  52. </td>
  53. <td>
  54. @can('订单管理-订单问题件生成')
  55. <button class="btn btn-sm btn-outline-primary"
  56. v-show="!item.is_issue_order "
  57. @click="createOrderIssue(item,true)">生成问题件
  58. </button>
  59. @endcan
  60. @can('订单管理-工单处理-货主编辑')
  61. <button class="btn btn-sm"
  62. style="background-color: #5d9983;color: #FFFFFF;border-color: #378d72"
  63. v-show="isOwnerDispose(item)"
  64. @click="ownerShowDispose(item,i)">
  65. 商家处理
  66. </button>
  67. <button class="btn btn-sm"
  68. style="background-color: #13b6af;color: #FFFFFF;border-color: #079e74"
  69. v-show="canOwnerEdit(item)"
  70. @click="ownerShowEdit(item,i)"
  71. >
  72. 重新编辑
  73. </button>
  74. @endcan
  75. @can('订单管理-工单处理-承运商编辑')
  76. <button class="btn btn-sm"
  77. style="background-color:#ea8863;color: #FFFFFF;border-color: #9a3d23"
  78. v-show="isLogisticDispose(item)"
  79. @click="logisticShowDispose(item,i)">
  80. 快递处理
  81. </button>
  82. <button class="btn btn-sm"
  83. style="background-color:#bf674e;color: #FFFFFF;border-color: #9a3d23"
  84. v-show="canLogisticEdit(item)"
  85. @click="logisticShowEdit(item,i)">
  86. 重新编辑
  87. </button>
  88. @endcan
  89. @can('订单管理-工单处理-宝时编辑')
  90. <button class="btn btn-sm"
  91. style="background-color: #52b7d7;color: #FFFFFF;border-color:#90acb6;"
  92. v-show="isBaoShiDispose(item)"
  93. @click="baoShiShowDispose(item,i)">
  94. 宝时处理
  95. </button>
  96. <button class="btn btn-sm "
  97. style="background-color: #62a151;color: #FFFFFF;border-color:#90acb6;"
  98. v-show="isBaoShiReview(item)"
  99. @click="baoShiShowDispose(item,i)">
  100. <span>宝时客服</span>
  101. </button>
  102. <button class="btn btn-sm"
  103. style="background-color: #4390a7;color: #FFFFFF;border-color:#90acb6;"
  104. v-show="isBaoShiEdit(item)"
  105. @click="baoShiShowEdit(item,i)">
  106. 重新编辑
  107. </button>
  108. @endcan
  109. </td>
  110. <td>
  111. @can('订单管理-工单处理-审核')
  112. <select class="form-control form-control-sm"
  113. :value="item.order_issue_type_id"
  114. @change="changeIssueType(item,$event)">
  115. <option value="0"></option>
  116. <option v-for="type in orderIssueTypes"
  117. :value="type.name"
  118. v-text="type.value">
  119. </option>
  120. </select>
  121. @else
  122. <span v-text="item.issue_type_name"></span>
  123. @endcan
  124. </td>
  125. <td>
  126. <span v-text="item['last_handler_name'] + ':' + item.process_progress"></span>
  127. <span class="badge badge-pill badge-warning" v-if="'快递异常' === item.issue_type_name"
  128. v-text="item.type"></span>
  129. </td>
  130. <td v-text="item.created_at"></td>
  131. <td v-text="item.status"></td>
  132. <td v-text="item.owner? item.owner.name : ''"></td>
  133. <td v-text="item.order? item.order.client_code : ''"></td>
  134. <td>
  135. <div v-for="logistic_number in item.logistic_numbers">
  136. <span v-text="logistic_number"></span>
  137. </div>
  138. </td>
  139. <td v-text="item.logistic ? item.logistic.name : ''"></td>
  140. <td v-text="item.creator ? item.creator.name : ''"></td>
  141. <td v-text="item.result_explain ? item.result_explain: item.remark"></td>
  142. @can('订单管理-工单处理-宝时编辑')
  143. <td class="log-td" colspan=""
  144. v-on:mouseover="showAddBtn($event)"
  145. v-on:mouseleave="hideAddBtn($event)">
  146. @include('order.workOrder._issue_logs')
  147. </td>
  148. @endcan
  149. <td class="container">
  150. <div class="row">
  151. @can('订单管理-工单处理-删除')
  152. <div class="col-1 ">
  153. <div class="header-alert">
  154. <button type="button"
  155. class="btn btn-sm btn-outline-danger"
  156. @click="destroy(item,i)">
  157. 删除
  158. </button>
  159. </div>
  160. </div>
  161. @endcan
  162. <div class="col-6 m-0 ">
  163. @include('order.workOrder._work_order_details')
  164. </div>
  165. <div @can('订单管理-工单处理-删除') class="col-5 m-0"
  166. @else class="col-6 p-0" @endcan>
  167. @include('order.workOrder._work_order_log')
  168. </div>
  169. </div>
  170. </td>
  171. </template>
  172. </tbody>
  173. </table>
  174. {{ $workOrders->withQueryString()->links() }}
  175. </div>
  176. </div>
  177. @can('订单管理-工单处理-审核')
  178. {{-- @include('order.workOrder._edit_issue_type')--}}
  179. @endcan
  180. </div>
  181. <div class="row">
  182. @include('order.workOrder._work_order_show')
  183. </div>
  184. @include('order.workOrder._bao_shi_review_modal')
  185. @include('order.workOrder._bao_shi_fill_work_order_modal')
  186. @include('order.workOrder._logistic_fill_work_order_modal')
  187. @include('order.workOrder._owner_fill_work_order_modal')
  188. </div>
  189. @endsection()
  190. @section("lastScript")
  191. <script type="text/javascript" src="{{asset('js/queryForm/queryForm.js')}}"></script>
  192. <script type="text/javascript" src="{{mix('js/queryForm/header.js')}}"></script>
  193. <script src="{{ mix('js/element-ui.js') }}"></script>
  194. <style>
  195. .fade-enter-active {
  196. transition: opacity .3s;
  197. }
  198. .fade-leave-active {
  199. transition: opacity .1s;
  200. }
  201. .fade-enter, .fade-leave-to {
  202. opacity: 0;
  203. }
  204. .image-div {
  205. }
  206. .image-w {
  207. width: 100%;
  208. }
  209. </style>
  210. <script>
  211. const orderIssueVue = new Vue({
  212. methods: {
  213. tagIssueLog(log) { // 标记问题件log不可见
  214. let url = '{{route('order.issue.log.tagApi')}}';
  215. let data = {id: log.id};
  216. if (!confirm('是否标记当前记录客户不可见')) return;
  217. window.axios.post(url, data).then(res => {
  218. if (res.data.success) {
  219. window.tempTip.showSuccess('标记成功');
  220. log.tag = 1;
  221. } else {
  222. window.tempTip.show(res.data.message ? res.data.message : '标记出现异常');
  223. }
  224. }).catch(err => {
  225. window.tempTip.show(err);
  226. });
  227. },
  228. addOrderIssueLog(id, order_issue_id, logs) {
  229. let idInput = $('#' + id + ' :input[name="id"]');
  230. let contentInput = $('#' + id + ' :input[name="content"]');
  231. if (!contentInput.val()) {
  232. contentInput.addClass('is-invalid').focus();
  233. return;
  234. }
  235. contentInput.removeClass('is-invalid');
  236. let tag = document.getElementById(order_issue_id + '_log_check').checked;
  237. let url = '{{route('order.issue.log.storeApi')}}';
  238. let data = {id: idInput.val(), content: contentInput.val(), tag: tag ? 1 : 0};
  239. window.tempTip.waitingTip("处理中");
  240. window.axios.post(url, data).then(function (res) {
  241. window.tempTip.cancelWaitingTip();
  242. if (res.data.success) {
  243. logs.unshift(res.data.data);
  244. contentInput.val('');
  245. $('#' + id).hide();
  246. vue.successTempTip('添加成功');
  247. return;
  248. }
  249. vue.errorTempTip(res.data.fail_info);
  250. }).catch(function (err) {
  251. window.tempTip.cancelWaitingTip();
  252. vue.errorTempTip('网络异常:' + err);
  253. });
  254. },
  255. destroyLog(log, issue_logs, logIndex) { // 删除处理日志
  256. if (!confirm('是否删除当前记录')) return;
  257. if (log.type === '创建') {
  258. tempTip.show('创建记录不能删除');
  259. return;
  260. }
  261. let url = "{{route("order.issue.log.destroyApi")}}";
  262. let data = {id: log.id};
  263. window.tempTip.setIndex('1999');
  264. window.axios.post(url, data).then(res => {
  265. if (res.data.success) {
  266. issue_logs.splice(logIndex, 1);
  267. tempTip.setDuration(1500);
  268. tempTip.showSuccess('删除成功');
  269. } else {
  270. tempTip.setDuration(2000);
  271. tempTip.show('删除失败:' + res.data.fail_info);
  272. }
  273. }).catch(err => {
  274. tempTip.setDuration(2500);
  275. tempTip.show('网络异常:' + err);
  276. });
  277. },
  278. }
  279. });
  280. let vue = new Vue({
  281. el: "#list",
  282. data: {
  283. orderIssueVue: orderIssueVue,
  284. workOrders: {!! $workOrders->toJson() !!}['data'],
  285. form: null,
  286. logistics: [
  287. @foreach($logistics as $logistic)
  288. {
  289. name: {{$logistic->id}}, value: '{{$logistic->name}}'
  290. },
  291. @endforeach
  292. ],
  293. orderIssueTypes: [
  294. @foreach($orderIssueTypes as $type)
  295. {
  296. name: '{{$type->id}}', value: "{{$type->name}}"
  297. },
  298. @endforeach
  299. ],
  300. owners: [
  301. @foreach($owners as $owner)
  302. {
  303. name: '{{$owner->id}}', value: '{{$owner->name}}'
  304. },
  305. @endforeach
  306. ],
  307. logisticEditWorkOrder: {
  308. id: null,
  309. issue_type_name: null,
  310. detail_id: null,
  311. reissue_logistic_number: null, // 补发单号
  312. logistic_number: null, // 丢件快递单号
  313. commodities: [],
  314. process_progress: null,
  315. is_edit: false,
  316. },
  317. baoShiEditWorkOrder: {
  318. id: null,
  319. issue_type_name: null,
  320. detail_id: null,
  321. reissue_logistic_number: null, // 补发单号
  322. logistic_number: null, // 丢件快递单号
  323. commodities: [],
  324. process_progress: null,
  325. is_edit: false,
  326. },
  327. ownerEditWorkOrder: {
  328. id: null,
  329. issue_type_name: null,
  330. detail_id: null,
  331. price: null,
  332. type: null,
  333. status: '',
  334. reissue_logistic_number: null, // 补发单号
  335. logistic_number: null, // 丢件快递单号
  336. packageImages: [],
  337. commodityImages: [],
  338. refundImages: [], // 退款图
  339. dealImages: [], // 交易图
  340. commodities: [],
  341. return_logistic_number: null,
  342. return_name: null,
  343. return_address: null,
  344. return_phone: null,
  345. process_progress: null,
  346. is_edit: false,
  347. delete_image_ids: [],
  348. delete_commodity_ids: [],
  349. remark: null,
  350. },
  351. showWorkOrder: {
  352. issue_type_name: null,
  353. package_images: [],
  354. commodity_images: [],
  355. deal_images: [],
  356. refund_images: [],
  357. commodities: [],
  358. reissue_logistic_number: null,
  359. logistic_number: null,
  360. return_logistic_number: null,
  361. return_name: null,
  362. return_address: null,
  363. return_phone: null,
  364. process_progress: null,
  365. type:null,
  366. },
  367. selectTr: null, // table 行
  368. selectDetailId: null, // 详情
  369. selectCreateOrderIssueLog: null,// 创建问题件处理信息
  370. selectOrderIssueLog: null, // 问题件处理信息
  371. selectOrderIssue: null, // 问题件
  372. selectIssueType: '',
  373. selectLog: null, // 工单日志
  374. selectIndex: null, // 选中工单
  375. filePrefix: "{{asset("/storage")}}",
  376. dialogShowBaoShiVisible:false,
  377. dialogEditBaoShiVisible:false,
  378. dialogShowOwnerVisible:false,
  379. dialogEditOwnerVisible:false,
  380. dialogShowLogisticVisible:false,
  381. dialogEditLogisticVisible:false,
  382. dialogShowOrderWorkVisible:false,
  383. },
  384. computed: {},
  385. mounted() {
  386. let data = [[
  387. {name: 'created_at_start', type: 'time', tip: ['工单创建开始日期', '时间']},
  388. {name: 'created_at_end', type: 'time', tip: ['工单创建结束日期', '时间']},
  389. {
  390. name: 'logistic',
  391. type: 'select_multiple_select',
  392. data: this.logistics,
  393. tip: ['输入关键词快速定位下拉列表,回车确定', '选择要显示的承运商'],
  394. placeholder: ['承运商', '定位或多选承运商']
  395. },
  396. @can('订单管理-订单问题件生成')
  397. {
  398. name: 'owner',
  399. type: 'select_multiple_select',
  400. data: this.owners,
  401. tip: ['输入关键词快速定位下拉列表,回车确定', '选择要显示的货主'],
  402. placeholder: ['货主', '定位或多选货主']
  403. },
  404. @endcan
  405. {
  406. name: 'logistic_number', type: 'input', placeholder: '快递单号'
  407. },
  408. {
  409. name: 'is_issue_order',
  410. type: 'select',
  411. placeholder: '问题件',
  412. data: [{name: 'true', value: '有'}, {name: 'false', value: '无'}]
  413. },
  414. {name: 'creator', type: 'input', placeholder: '创建人'},
  415. ], [
  416. {name: 'review_at_start', type: 'time', tip: ['终审开始日期', '时间']},
  417. {name: 'review_at_end', type: 'time', tip: ['终审结束日期', '时间']},
  418. {name: 'order_issue_type', type: 'select', placeholder: '问题件类型', data: this.orderIssueTypes},
  419. {name: 'client_code', type: 'input', placeholder: '客户订单号'},
  420. {
  421. name: 'status', type: 'select', placeholder: '工单当前处理人',
  422. data: [{name: '宝时处理', value: '宝时处理'},
  423. {name: '货主处理', value: '货主处理'},
  424. {name: '承运商处理', value: '承运商处理'},]
  425. },
  426. {
  427. name: 'process_progress', type: 'select', placeholder: '当前进度',
  428. data: [
  429. {name: '已处理', value: '已处理'},
  430. {name: '已签收', value: '已签收'},
  431. {name: '拦截成功', value: '拦截失败'},
  432. {name: '拦截失败', value: '拦截失败'},
  433. {name: '已处理', value: '已处理'},
  434. {name: '无法更改', value: '无法更改'},
  435. {name: '更改成功', value: '更改成功'},
  436. {name: '更改失败', value: '更改失败'},
  437. {name: '已处理', value: '已处理'},
  438. {name: '已拦截', value: '已拦截'},
  439. {name: '丢件赔偿', value: '丢件赔偿'},
  440. {name: '签收成功', value: '签收成功'},
  441. {name: '已核实', value: '已核实'},
  442. {name: '补发', value: '补发'},
  443. {name: '不补发', value: '不补发'},
  444. {name: '已补发', value: '已补发'},
  445. {name: '已入库', value: '已入库'},
  446. {name: '核实全部破损', value: '核实全部破损'},
  447. {name: '核实部分破损', value: '核实部分破损'},
  448. {name: '核实未破损', value: '核实未破损'},
  449. {name: '待商家处理', value: '待商家处理'},
  450. {name: '待终审', value: '待终审'},
  451. {name: '完结', value: '完结'},
  452. ]
  453. },
  454. {name: 'is_end', type: 'checkbox', tip: '是否已拦截', data: [{name: 'ture', value: '已完成'}]},
  455. ]];
  456. this.form = new query({
  457. el: '#form_div',
  458. condition: data,
  459. });
  460. this.form.init();
  461. let column = [
  462. {name: 'id', value: '工单号', neglect: true},
  463. {name: 'operation', value: '操作', neglect: true},
  464. {name: 'work_type', value: '工单类型', neglect: true},
  465. {name: 'process_progress', value: '当前进度', neglect: true},
  466. {name: 'created_at', value: '创建时间', neglect: true},
  467. {name: 'status', value: '当前处理人', neglect: true},
  468. {name: 'owner', value: '货主', neglect: true},
  469. {name: 'order_code', value: '订单号', neglect: true},
  470. {name: 'logistic_numbers', value: '快递单号'},
  471. {name: 'logistic', value: '承运商'},
  472. {name: 'creator', value: '创建人'},
  473. {name: 'remark', value: '情况说明'},
  474. @can('订单管理-工单处理-宝时编辑')
  475. {
  476. name: 'order_issue_log', value: '处理结果'
  477. },
  478. @endcan
  479. {
  480. name: 'ab_operation', type: 'multi', title: "其他操作", rows: [
  481. @can('订单管理-工单处理-删除')
  482. {
  483. value: "删除", col: "1"
  484. },
  485. {value: "查看资料", col: "6"},
  486. {value: "处理日志", col: "5"},
  487. @else
  488. {
  489. value: "查看资料", col: "6"
  490. },
  491. {value: "处理日志", col: "6"},
  492. @endcan
  493. ], neglect: true
  494. },
  495. ];
  496. new Header({
  497. el: "table",
  498. name: "workOrders",
  499. column: column,
  500. data: this.workOrders,
  501. fixedTop: ($('#form_div').height()) + 2,
  502. }).init();
  503. $("#list").removeClass("d-none");
  504. },
  505. created() {
  506. this.workOrders.forEach(item => {
  507. this.sortOrder(item);
  508. });
  509. },
  510. filters: {
  511. dataTime: function (value) {
  512. if (value !== null) {
  513. return moment(value).format('yyyy-MM-DD');
  514. }
  515. return value
  516. },
  517. },
  518. methods: {
  519. waitingTempTip(message) {
  520. window.tempTip.setIndex(2005);
  521. window.tempTip.waitingTip(message);
  522. },
  523. successTempTip(message) {
  524. window.tempTip.setDuration(1500);
  525. window.tempTip.setIndex(2005);
  526. window.tempTip.showSuccess(message);
  527. },
  528. errorTempTip(message) {
  529. window.tempTip.setDuration(2000);
  530. window.tempTip.setIndex(2005);
  531. window.tempTip.show(message);
  532. },
  533. showAddBtn(e) {
  534. let domObj = $(e.target).parents('.log-td');
  535. if (domObj.hasClass('log-td')) {
  536. domObj.find('.add-btn').show();
  537. } else {
  538. let obj = $(e.target);
  539. if (obj.hasClass('log-td')) {
  540. obj.find('.add-btn').show();
  541. }
  542. }
  543. },
  544. hideAddBtn(e) {
  545. let domObj = $(e.target);
  546. if (domObj.hasClass('log-td')) {
  547. domObj.find('.add-btn').hide();
  548. }
  549. },
  550. showAddDiv(id) {
  551. let div = $('#' + id);
  552. if (div.is(":hidden")) {
  553. div.show();
  554. div.find('input[type=text]').focus();
  555. } else {
  556. div.hide();
  557. }
  558. },
  559. removeFocusing(e) {
  560. $(e.target).parent('tr').removeClass('focusing')
  561. },
  562. showDelBtn(e) {
  563. let domObj = $(e.target).parent();
  564. domObj.find('.del-btn').addClass('visible').removeClass('invisible');
  565. },
  566. hideDelBtn(e) {
  567. let domObj = $(e.target);
  568. domObj.find('.del-btn').addClass('invisible').removeClass('visible');
  569. },
  570. toggleLogs(orderIssue, e, index) {
  571. if (orderIssue.log_is_show === false) {
  572. orderIssue.log_is_show = true;
  573. $(e.target).text('点击收起');
  574. } else {
  575. orderIssue.log_is_show = false;
  576. $(e.target).text("记录共" + orderIssue.logs.length + "条,点击展开");
  577. }
  578. },
  579. sortOrder(workOrder) {
  580. workOrder.last_handler_name = workOrder.last_handler ? workOrder.last_handler.name : '';
  581. workOrder.detail_infos = this.groupDetails(workOrder); // 工单详情
  582. workOrder.package_images = this.groupImages(workOrder, '外包装图片'); // 外包装图片
  583. workOrder.commodity_images = this.groupImages(workOrder, '内物破碎图片'); // 内物破碎图片
  584. workOrder.deal_images = this.groupImages(workOrder, '交易截图'); // 交易截图
  585. workOrder.refund_images = this.groupImages(workOrder, '退款成功截图'); //退款成功截图
  586. workOrder.issue_logs = this.groupOrderIssueLogs(workOrder); // 问题件日志
  587. workOrder.logs = this.groupLogs(workOrder); // 工单日志
  588. workOrder.commodities = this.groupCommodities(workOrder);
  589. workOrder.issue_type_name = workOrder.issue_type ? workOrder.issue_type.name : ''; // 工单类型
  590. workOrder.pending_detail = this.groupPendingDetail(workOrder);
  591. workOrder.order_issue ? (workOrder.order_issue.log_is_show = false) : '';
  592. workOrder.logistic_numbers = this.groupLogisticNumber(workOrder);
  593. },
  594. groupPendingDetail(workOrder) {
  595. let detail = workOrder.details.find(item => {
  596. return !['完成', '标记'].includes(item.tag);
  597. });
  598. if (!detail) return null;
  599. return {
  600. id: workOrder.id,
  601. detail_id: detail.id,
  602. commodities: detail.commodities,
  603. issue_type_name: detail.issue_type ? detail.issue_type.name : '',
  604. status: detail.status,
  605. reissue_logistic_number: detail.reissue_logistic_number,
  606. logistic_number: detail.logistic_number,
  607. price: detail.price,
  608. return_logistic_number: detail.return_logistic_number,
  609. remark: detail.remark,
  610. tag: detail.tag,
  611. return_address: detail.return_address,
  612. return_phone: detail.return_phone,
  613. return_name: detail.return_name,
  614. images: detail.images,
  615. };
  616. },
  617. groupCommodities(workOrder, isCurrent = true) {
  618. let commodities = [];
  619. workOrder.details.forEach(detail => {
  620. let commoditiy_itmes = detail.commodities.map(item => {
  621. item.issue_type_name = detail.issue_type ? detail.issue_type.name : '';
  622. return item;
  623. });
  624. commodities.push(...(commoditiy_itmes ?? []))
  625. });
  626. return commodities.filter(item => {
  627. if (!isCurrent) {
  628. return !['完成', '标记'].includes(item.tag);
  629. } else {
  630. return ['完成', '标记'].includes(item.tag);
  631. }
  632. })
  633. },
  634. groupOrderIssueLogs(workOrder) {
  635. workOrder.current_issue_type = workOrder.issue_type ? workOrder.issue_type.name : '';
  636. let logs = workOrder.order_issue ? (workOrder.order_issue.logs ? workOrder.order_issue.logs : []) : [];
  637. return logs.sort((perv, cur) => {
  638. let prevT = new Date(perv.created_at), curT = new Date(cur.created_at);
  639. if (prevT > curT) {
  640. return -1;
  641. } else if (prevT === curT) {
  642. return 0;
  643. } else if (prevT < curT) {
  644. return 1;
  645. }
  646. });
  647. },
  648. groupDetails(workOrder) {
  649. return workOrder.details.map(item => {
  650. return {
  651. id: item.id,
  652. issue_type: item.issue_type ? item.issue_type.name : '', // 工单类型
  653. price: item.price, // 商品价值总价
  654. reissue_logistic_number: item.reissue_logistic_number, // 补发单号
  655. return_logistic_number: item.return_logistic_number, // 退回单号
  656. logistic_number: item.logistic_number, // 快递单号
  657. status: item.status, // 工单状态
  658. created_at: item.created_at, // 创建时间
  659. tag: item.tag, // 标记
  660. };
  661. });
  662. },
  663. groupDetailCommodities(detail) {
  664. return detail.commodities.map(item => {
  665. item.commodity_name = item.commodity ? item.commodity.name : '';
  666. return item;
  667. });
  668. },
  669. groupImages(workOrder, type) {
  670. let images = [];
  671. workOrder.details.forEach(detail => {
  672. let imageList = detail.images.map(item => {
  673. item.issue_type_name = detail.issue_type ? detail.issue_type.name : '';
  674. return item;
  675. }).filter(item => {
  676. return item.type === type;
  677. }).map(e => {
  678. let {url, type} = e['upload_file'];
  679. e.urlExist = e.hasOwnProperty('upload_file');
  680. e.fileUrl = this.filePrefix + `${url}.${type}`;
  681. return e;
  682. })
  683. images.push(...imageList);
  684. });
  685. return images;
  686. },
  687. groupLogs(workOrder) {
  688. let logs = [];
  689. workOrder.details.forEach(detail => {
  690. let logList = detail.logs.map(item => {
  691. return {
  692. id: item.id, // id
  693. tag: detail.tag, // 标记
  694. created_at: item.created_at, // 创建时间
  695. issue_type: detail.issue_type ? detail.issue_type.name : '', // 创建时间
  696. creator: item.creator, // 创建人
  697. type: item.type, // 类型
  698. content: item.content, // 内容
  699. };
  700. });
  701. logs.push(...logList);
  702. });
  703. return logs;
  704. },
  705. groupLogisticNumber(workOrder) {
  706. let detail = null;
  707. workOrder.details.forEach(e => {
  708. if (!detail) detail = e;
  709. if (new Date(e.created_at) > new Date(detail.created_at)) detail = e;
  710. });
  711. let {commodities} = detail;
  712. let logistic_numbers = new Set();
  713. commodities.forEach(e => logistic_numbers.add(e.logistic_number));
  714. if (logistic_numbers.size === 0){
  715. if (workOrder.order && workOrder.order.packages){
  716. workOrder.order.packages.forEach(e=>logistic_numbers.add(e.logistic_number));
  717. }
  718. }
  719. return new Array(...logistic_numbers);
  720. },
  721. createOrderIssue(item, tag) { // 生成问题件
  722. let url = '{{route('workOrder.buildOrderIssueApi')}}';
  723. let data = {};
  724. if (tag) data.ids = [item.id];
  725. else data.ids = checkData;
  726. window.tempTip.confirm('是否生成对应的问题件', () => {
  727. window.tempTip.waitingTip('生成中........');
  728. window.axios.post(url, data).then(res => {
  729. if (res.data.success) {
  730. this.replaceWorkOrder(res.data.data);
  731. this.$forceUpdate();
  732. window.tempTip.cancelWaitingTip();
  733. window.tempTip.showSuccess('已生成对应的问题件');
  734. } else {
  735. window.tempTip.cancelWaitingTip();
  736. window.tempTip.show(res.data.message ? res.data.message : '生成问题件异常');
  737. }
  738. }).catch(err => {
  739. window.tempTip.cancelWaitingTip();
  740. window.tempTip.show(err)
  741. });
  742. })
  743. },
  744. replaceWorkOrder(workOrders) {
  745. let data = [];
  746. workOrders.forEach(item => {
  747. data[item.id] = item;
  748. });
  749. this.workOrders.forEach((e, i) => {
  750. if (data[e.id]) {
  751. let item = data[e.id];
  752. this.sortOrder(item);
  753. this.$set(this.workOrders, i, item);
  754. }
  755. });
  756. this.$forceUpdate();
  757. },
  758. getMessageWorkOrder() {
  759. let selected = checkData;
  760. if (!selected) {
  761. window.tempTip.show('未选中任何信息');
  762. return null;
  763. }
  764. return this.workOrders.filter((item) => {
  765. if (!item.order || !item.order.packages) return false;
  766. return selected.includes(item.id + '');
  767. });
  768. },
  769. exportText() {
  770. let items = this.getMessageWorkOrder();
  771. if (items == null) return;
  772. let text = '';
  773. items.forEach(item => {
  774. if (item.order) text += this.getExportText(item);
  775. });
  776. this.copyText(text);
  777. },
  778. getExportText(item) {
  779. if (!item.order || !item.order.packages) return '';
  780. let message = '';
  781. let issue_type = item['issue_type'] ? item['issue_type'].name : '';
  782. switch (issue_type) {
  783. case '拦截':
  784. message = this.interceptMessage(item);
  785. break;
  786. case '信息更改':
  787. message = this.modificationMessage(item);
  788. break;
  789. default:
  790. message = this.getMessage(item);
  791. break;
  792. }
  793. return message;
  794. },
  795. interceptMessage(item) {
  796. let message = '';
  797. let order = item.order;
  798. let order_packages = item.order ? item.order.packages : [];
  799. let logistic_code = item.order ? (item.order['logistic'] ? item.order['logistic'].code : '') : ''; // 承运商编码
  800. let logistic_name = item.order ? (item.order['logistic'] ? item.order['logistic'].name : '') : ''; // 承运商名称
  801. let {consignee_name, consignee_phone, address} = order;
  802. let order_adder = `${consignee_name} ${consignee_phone} ${address}`;
  803. order_packages.forEach(item => {
  804. let logistic_number = item.logistic_number;
  805. if (logistic_code.includes('SF') || logistic_code.includes('ZTO')) {
  806. message += `${logistic_number}\n`;
  807. } else {
  808. if (item) message += `${logistic_name} ${logistic_number} ${order_adder}\n`;
  809. }
  810. });
  811. message = message.trim() + ' ——拦截\n';
  812. return message;
  813. },
  814. modificationMessage(item) {
  815. let message = '';
  816. let {remark, order} = item;
  817. let order_packages = item.order ? item.order.packages : [];
  818. let logistic_code = item.order ? (item.order['logistic'] ? item.order['logistic'].code : '') : '';
  819. const {consignee_name, consignee_phone, province, city, district, address} = order;
  820. let adder = `${consignee_name} ${consignee_phone} ${province} ${city} ${district} ${address}`;
  821. order_packages.forEach(node => {
  822. let logistic_number = node.logistic_number;
  823. if (logistic_code.includes('SF')) { // 顺丰订单
  824. message += `${logistic_number} ——改信息:${remark},运费到付或月结\n`;
  825. } else {
  826. message += `${logistic_number} ${adder} ——改地址 ${remark}\n`;
  827. }
  828. });
  829. return message;
  830. },
  831. getMessage(item) {
  832. let message = '';
  833. if (!item.order.packages) return message;
  834. let {order, remark} = item.order;
  835. let {consignee_name, consignee_phone, province, city, district, address} = order;
  836. let adder = `${consignee_name} ${consignee_phone} ${province} ${city} ${district} ${address}`;
  837. order.packages.forEach(p => {
  838. message += `${p.logistic_number} ${adder} ——描述 ${remark}\n`;
  839. });
  840. return message;
  841. },
  842. copyText(text) {
  843. let ele = document.querySelector('#copy_text');
  844. if (ele == null) {
  845. ele = document.createElement("textarea");
  846. ele.setAttribute('id', 'copy_text')
  847. ele.style.opacity = 0;
  848. document.querySelector('body').append(ele);
  849. }
  850. try {
  851. $("#copy_text").text(text).select().focus();
  852. document.execCommand("Copy");
  853. tempTip.showSuccess('复制成功')
  854. } catch (e) {
  855. tempTip.showSuccess('复制失败:' + e)
  856. }
  857. },
  858. changeIssueType(item, e) {
  859. let url = '{{route('workOrder.updateIssueTypeApi')}}';
  860. let data = {
  861. id: item.id,
  862. type_id: $(e.target).val()
  863. };
  864. window.tempTip.waitingTip('修改中.........');
  865. window.axios.post(url, data).then(res => {
  866. if (res.data.success) {
  867. window.tempTip.cancelWaitingTip();
  868. window.tempTip.showSuccess('修改成功');
  869. item.order_issue_type_id = data.type_id;
  870. } else {
  871. window.tempTip.cancelWaitingTip();
  872. window.tempTip.show(res.data.message ? res.data.message : '修改异常');
  873. }
  874. }).catch(err => {
  875. window.tempTip.cancelWaitingTip();
  876. window.tempTip.show(err);
  877. });
  878. },
  879. copyLogisticNumber() {
  880. let items = this.getMessageWorkOrder();
  881. let logistic_numbers = '';
  882. items.forEach(item => {
  883. item.order.packages.forEach(node => {
  884. logistic_numbers += `${node.logistic_number}\n`;
  885. });
  886. })
  887. this.copyText(logistic_numbers);
  888. },
  889. showEditIssueType() {
  890. this.selectIssueType = 0;
  891. $("edit-issue-type-modal").modal('show');
  892. },
  893. editOrderIssueType() {
  894. let url = '{{route('workOrder.batchUpdateIssueTypeApi')}}'
  895. let data = {ids: checkData, type: this.selectIssueType};
  896. window.tempTip.setIndex(1999);
  897. window.axios.post(url, data).then(res => {
  898. if (res.data.success) {
  899. window.tempTip.showSuccess('修改问题件类型成功');
  900. this.replaceWorkOrder(res.data.data);
  901. $("#edit-issue-type-type-modal").modal('hide');
  902. return;
  903. }
  904. window.tempTip.show(res.data.message ? res.data.message : '修改异常');
  905. }).catch(err => {
  906. window.tempTip.show(err)
  907. })
  908. },
  909. destroy(item, i) {
  910. window.tempTip.confirm('是否删除当前工单', () => {
  911. let url = '{{url('apiLocal/workOrder/')}}' + '/' + item.id;
  912. window.tempTip.waitingTip('删除.........');
  913. window.axios.delete(url).then(res => {
  914. if (res.data.success) {
  915. window.tempTip.cancelWaitingTip();
  916. window.tempTip.showSuccess('删除成功');
  917. this.$delete(this.workOrders, i);
  918. } else {
  919. window.tempTip.cancelWaitingTip();
  920. window.tempTip.show(res.data.message ? res.data.message : '');
  921. }
  922. }).catch(err => {
  923. window.tempTip.cancelWaitingTip();
  924. window.tempTip.show(err);
  925. })
  926. })
  927. },
  928. spliceImage(i, images) {
  929. window.tempTip.setIndex(1999);
  930. window.tempTip.confirm('是否取消选择该图片', () => {
  931. images.splice(i, 1);
  932. });
  933. },
  934. setFormDataImagePrefix(formData, prefix, images) {
  935. images.forEach((item, i) => {
  936. formData.append(`${prefix}[]`, item);
  937. });
  938. },
  939. getImages(images) {
  940. return images.map((item) => {
  941. return item.file;
  942. })
  943. },
  944. pasteImage(event, imageArray) {
  945. for (let i = 0; i < event.clipboardData.items.length; i++) {
  946. let item = event.clipboardData.items[i];
  947. if (item.kind === 'string') continue;
  948. if (item.type.indexOf('image') === -1) continue;
  949. if (item.kind === 'file') {
  950. let blob = item.getAsFile();
  951. let src = null;
  952. this.blobToBase64(blob).then(res => {
  953. src = res;
  954. imageArray.push({src: src, file: blob});
  955. });
  956. }
  957. }
  958. event.preventDefault();
  959. },
  960. pasteRefundImagesOrReissueLogisticNumber(event, refundImages) {
  961. for (let i = 0; i < event.clipboardData.items.length; i++) {
  962. let item = event.clipboardData.items[i];
  963. if (item.kind === 'string') continue
  964. if (item.type.indexOf('image') === -1) continue;
  965. if (item.kind === 'file') {
  966. this.ownerEditWorkOrder.reissue_logistic_number = null;
  967. let blob = item.getAsFile();
  968. let src = null;
  969. this.blobToBase64(blob).then(res => {
  970. src = res;
  971. refundImages.push({src: src, file: blob});
  972. if (refundImages.length > 0) {
  973. let div = $("#refund-image");
  974. div.html(div.children());
  975. }
  976. });
  977. }
  978. }
  979. event.preventDefault();
  980. },
  981. editOwnerReissueLogisticNumber(){
  982. let reissue_logistic_number = this.$refs['refund-image-edit-reissue_logistic_number'].innerHTML;
  983. if (this.ownerEditWorkOrder.refundImages.length === 0) this.ownerEditWorkOrder.reissue_logistic_number = reissue_logistic_number;
  984. else {
  985. let div = $("#refund-image");
  986. div.html(div.children());
  987. }
  988. },
  989. editReissueLogisticNumber() {
  990. let reissue_logistic_number = this.$refs['refund-image-reissue_logistic_number'].innerHTML;
  991. if (this.ownerEditWorkOrder.refundImages.length === 0) this.ownerEditWorkOrder.reissue_logistic_number = reissue_logistic_number;
  992. else {
  993. let div = $("#refund-image");
  994. div.html(div.children());
  995. }
  996. },
  997. blobToBase64(blob) {
  998. return new Promise((resolve, reject) => {
  999. const fileReader = new FileReader();
  1000. fileReader.onload = (e) => {
  1001. resolve(e.target.result);
  1002. };
  1003. fileReader.readAsDataURL(blob);
  1004. fileReader.onerror = () => {
  1005. reject(new Error('blobToBase64 error'));
  1006. };
  1007. });
  1008. },
  1009. getOrderCommodity(item) {
  1010. return new Promise((resolve, reject) => {
  1011. let url = '{{route('order.commodity.getCommoditiesApi')}}';
  1012. let data = {orderNo: item ? (item.order ? item.order.code : '') : ''};
  1013. window.axios.post(url, data).then(res => {
  1014. if (res.data.success) {
  1015. resolve(res.data.data);
  1016. }
  1017. }).catch(err => {
  1018. reject(err);
  1019. });
  1020. });
  1021. },
  1022. countCommoditiesByLogisticNumber(items) {
  1023. if (items.length === 0) return [];
  1024. let commodities = JSON.parse(JSON.stringify(items));
  1025. this.ownerGroupCommodities(commodities);
  1026. return commodities;
  1027. },
  1028. ownerGroupCommodities(items) {
  1029. items.forEach(e => e.count = 0);
  1030. let index = 0;
  1031. let logistic_number = items[0]['logistic_number'];
  1032. let count = 0;
  1033. items.forEach((e, i) => {
  1034. let cur_logistic_number = e.logistic_number,
  1035. process_result_info = e.process_result_info,
  1036. isAdd = false, isAddRow = false;
  1037. if (process_result_info && (process_result_info.indexOf('商家做入库单') >= 0 || process_result_info.indexOf('商家做出库单') >= 0)) {
  1038. isAddRow = true;
  1039. }
  1040. if (cur_logistic_number === logistic_number) {
  1041. count++;
  1042. if (isAddRow) count++;
  1043. if (isAdd) count++;
  1044. } else if (cur_logistic_number !== logistic_number) {
  1045. logistic_number = cur_logistic_number;
  1046. items[index]['count'] = count;
  1047. index = i;
  1048. count = 1;
  1049. if (isAdd) count++;
  1050. if (isAddRow) count++;
  1051. }
  1052. items[index]['count'] = count;
  1053. });
  1054. },
  1055. reviseMistakeWorkOrder(item) {
  1056. if (item.process_result === '多发,客户买下') {
  1057. } else if (item.process_result === '多发,客户退回') {
  1058. item.store_in_amount = null;
  1059. item.store_in_number = null;
  1060. item.reissue_logistic_number = null;
  1061. item.out_order_number = null;
  1062. }
  1063. },
  1064. getCurrentWorkOrderDetailId(workOrder) {
  1065. let items = workOrder.details.filter(item => {
  1066. return !['标记', '完成'].includes(item.tag);
  1067. });
  1068. if (items.length === 0) return null;
  1069. let item = items.shift();
  1070. return item.id;
  1071. },
  1072. sumPrice(workOrder) {
  1073. workOrder.price = workOrder.commodities.reduce((prev, cur) => {
  1074. return Number(prev) + Number(cur.price) * Number(cur.abnormal_amount);
  1075. }, 0);
  1076. },
  1077. getBadgeColor(tag) { // 标记 返回徽章标记
  1078. if (tag === '完成') return 'badge-success';
  1079. if (tag === '创建') return 'badge-primary';
  1080. return '';
  1081. },
  1082. // 宝时客服
  1083. isBaoShiDispose(item) {
  1084. let {status} = item;
  1085. return status === '宝时处理';
  1086. },
  1087. isBaoShiEdit(item) {
  1088. return item.last_status === '宝时处理';
  1089. },
  1090. isBaoShiReview(item) {
  1091. return item.status === '宝时终审';
  1092. },
  1093. baoShiShowEdit(item, index) {
  1094. this.selectIndex = index;
  1095. let {status, issue_type_name} = item;
  1096. this.baoShiEditWorkOrder.is_edit = true;
  1097. if ('错漏发' === issue_type_name) {
  1098. let {detail_id, commodities, process_progress} = item.pending_detail;
  1099. this.baoShiEditWorkOrder.issue_type_name = issue_type_name;
  1100. this.baoShiEditWorkOrder.detail_id = detail_id;
  1101. this.baoShiEditWorkOrder.status = status;
  1102. this.baoShiEditWorkOrder.process_progress = process_progress;
  1103. this.baoShiEditWorkOrder.commodities = this.countCommoditiesByLogisticNumber(commodities);
  1104. this.dialogEditBaoShiVisible = true;
  1105. }
  1106. },
  1107. baoShiShowDispose(item, index) {
  1108. let {status} = item;
  1109. let {issue_type_name, detail_id, commodities} = item.pending_detail;
  1110. this.baoShiEditWorkOrder.is_edit = false;
  1111. this.selectIndex = index;
  1112. this.baoShiEditWorkOrder.issue_type_name = issue_type_name;
  1113. this.baoShiEditWorkOrder.detail_id = detail_id;
  1114. this.baoShiEditWorkOrder.status = status;
  1115. if ("拦截" === issue_type_name) {
  1116. this.dialogShowBaoShiVisible = true
  1117. } else if ("信息更改" === issue_type_name) {
  1118. this.dialogShowBaoShiVisible = true
  1119. } else if ("快递丢件" === issue_type_name) {
  1120. commodities.forEach(e => {
  1121. e.bao_shi_check_amount = e.abnormal_amount;
  1122. });
  1123. this.baoShiEditWorkOrder.commodities = this.countCommoditiesByLogisticNumber(commodities);
  1124. this.dialogShowBaoShiVisible = true
  1125. } else if ('破损' === issue_type_name) {
  1126. commodities.forEach(e => {
  1127. e.bao_shi_check_amount = e.abnormal_amount;
  1128. e.process_result = '核实全部破损';
  1129. });
  1130. this.baoShiEditWorkOrder.process_progress = '全部赔偿';
  1131. this.baoShiEditWorkOrder.commodities = this.countCommoditiesByLogisticNumber(commodities);
  1132. this.dialogShowBaoShiVisible = true
  1133. } else if ('快递异常' === issue_type_name) {
  1134. this.selectIndex = index;
  1135. this.baoShiEditWorkOrder.status = status;
  1136. commodities.forEach(e => {
  1137. e.bao_shi_check_amount = e.check_amount;
  1138. });
  1139. this.baoShiEditWorkOrder.commodities = this.countCommoditiesByLogisticNumber(commodities);
  1140. this.dialogShowBaoShiVisible = true
  1141. } else if ('错漏发' === issue_type_name) {
  1142. commodities.forEach(e => {
  1143. e.bao_shi_check_amount = e.amount;
  1144. if ('宝时处理' === status) {
  1145. e.check_result = null;
  1146. e.check_result = '核实未错漏发';
  1147. }
  1148. });
  1149. if ('宝时处理' === status) this.baoShiEditWorkOrder.process_progress = '核实未错漏发';
  1150. this.baoShiEditWorkOrder.commodities = this.countCommoditiesByLogisticNumber(commodities);
  1151. this.dialogShowBaoShiVisible = true
  1152. }
  1153. },
  1154. baoShiEdit() {
  1155. let {status, commodities, issue_type_name, process_progress, detail_id} = this.baoShiEditWorkOrder;
  1156. if ('拦截' === issue_type_name) {
  1157. let res = this.checkBaoShiEditWorkOrder();
  1158. if (!res.success) {
  1159. this.errorTempTip(res.message);
  1160. return;
  1161. }
  1162. let url = "{{route('workOrder.intercept.baoShi.reviewApi')}}";
  1163. let formData = {detail_id: detail_id, process_progress: process_progress}
  1164. this.baoShiEditProcess(url, formData);
  1165. } else if ('信息更改' === issue_type_name) {
  1166. let res = this.checkBaoShiEditWorkOrder();
  1167. if (!res.success) {
  1168. this.errorTempTip(res.message);
  1169. return;
  1170. }
  1171. let url = "{{route('workOrder.informationChange.baoShi.reviewApi')}}";
  1172. let formData = {detail_id: detail_id, process_progress: process_progress}
  1173. this.baoShiEditProcess(url, formData);
  1174. } else if ('快递丢件' === issue_type_name) {
  1175. let url = '{{route('workOrder.loss.baoShi.reviewApi')}}';
  1176. let formData = new FormData();
  1177. formData.append('detail_id', detail_id);
  1178. commodities.forEach(e => {
  1179. formData.append("commodities[]", JSON.stringify(e));
  1180. });
  1181. this.baoShiEditProcess(url, formData);
  1182. } else if ('破损' === issue_type_name) {
  1183. let res = this.checkBaoShiEditWorkOrder();
  1184. if (!res.success) {
  1185. this.errorTempTip(res.message);
  1186. return;
  1187. }
  1188. let url = '{{route('workOrder.damage.baoShi.reviewApi')}}';
  1189. let formData = new FormData();
  1190. formData.append('detail_id', this.baoShiEditWorkOrder.detail_id);
  1191. formData.append('process_progress', process_progress);
  1192. commodities.forEach(e => {
  1193. formData.append("commodities[]", JSON.stringify(e));
  1194. });
  1195. this.baoShiEditProcess(url, formData);
  1196. } else if ('快递异常' === issue_type_name) {
  1197. let res = this.checkBaoShiEditWorkOrder();
  1198. if (!res.success) {
  1199. this.errorTempTip(res.message);
  1200. return;
  1201. }
  1202. let url = '{{route('workOrder.expressAbnormal.baoShi.reviewApi')}}';
  1203. let formData = new FormData();
  1204. formData.append('detail_id', detail_id);
  1205. formData.append('process_progress', process_progress);
  1206. commodities.forEach(e => {
  1207. formData.append("commodities[]", JSON.stringify(e));
  1208. });
  1209. this.baoShiEditProcess(url, formData);
  1210. } else if ('错漏发' === issue_type_name) {
  1211. if (this.baoShiEditWorkOrder.is_edit) {
  1212. // 默认为编辑
  1213. let res = this.checkBaoShiEditWorkOrder();
  1214. if (!res.success) {
  1215. this.errorTempTip(res.message);
  1216. return;
  1217. }
  1218. let url = '{{route('workOrder.mistake.baoShi.handleApi')}}';
  1219. let formData = new FormData();
  1220. formData.append('detail_id', detail_id);
  1221. formData.append('process_progress', '已核实');
  1222. commodities.forEach(e => {
  1223. formData.append("commodities[]", JSON.stringify(e));
  1224. });
  1225. this.baoShiEditProcess(url, formData);
  1226. } else {
  1227. if ('宝时处理' === status) {
  1228. let res = this.checkBaoShiEditWorkOrder();
  1229. if (!res.success) {
  1230. this.errorTempTip(res.message);
  1231. return;
  1232. }
  1233. let url = '{{route('workOrder.mistake.baoShi.handleApi')}}';
  1234. let formData = new FormData();
  1235. formData.append('detail_id', detail_id);
  1236. formData.append('process_progress', '已核实');
  1237. commodities.forEach(e => {
  1238. formData.append("commodities[]", JSON.stringify(e));
  1239. });
  1240. this.baoShiEditProcess(url, formData);
  1241. } else if ('宝时终审' === status) {
  1242. this.baoShiAutoComputeMistakeProcessProcess();
  1243. let res = this.checkBaoShiEditWorkOrder();
  1244. if (!res.success) {
  1245. this.errorTempTip(res.message);
  1246. return;
  1247. }
  1248. let url = '{{route('workOrder.mistake.baoShi.reviewApi')}}';
  1249. let formData = new FormData();
  1250. formData.append('detail_id', detail_id);
  1251. formData.append('process_progress', this.baoShiEditWorkOrder.process_progress);
  1252. commodities.forEach(e => {
  1253. formData.append("commodities[]", JSON.stringify(e));
  1254. });
  1255. this.baoShiEditProcess(url, formData);
  1256. }
  1257. }
  1258. }
  1259. },
  1260. checkBaoShiEditWorkOrder() {
  1261. let {status} = this.baoShiEditWorkOrder;
  1262. if (['拦截', '信息更改'].includes(this.baoShiEditWorkOrder.issue_type_name)) {
  1263. if (this.baoShiEditWorkOrder.process_progress === null) {
  1264. return {success: false, message: '处理条件不能为空'};
  1265. }
  1266. } else if (['破损', '快递异常'].includes(this.baoShiEditWorkOrder.issue_type_name)) {
  1267. if (this.baoShiEditWorkOrder.process_progress === null) {
  1268. return {success: false, message: '处理条件不能为空'};
  1269. }
  1270. let filers = this.baoShiEditWorkOrder.commodities.filter(e => {
  1271. return e.process_result === null || e.process_result.length <= 0;
  1272. });
  1273. if (filers.length > 0) {
  1274. return {success: false, message: '商品详情中处理结果不能为空'};
  1275. }
  1276. } else if ('错漏发' === this.baoShiEditWorkOrder.issue_type_name) {
  1277. if ('宝时终审' === status) {
  1278. if (this.baoShiEditWorkOrder.process_progress === null || this.baoShiEditWorkOrder.process_progress === '') {
  1279. return {success: false, message: '处理条件不能为空'};
  1280. }
  1281. let message = null
  1282. this.baoShiEditWorkOrder.commodities.forEach(e => {
  1283. let {reissue_logistic_number, check_result, end_handle_result, store_in_number} = e;
  1284. if (!message) {
  1285. if (!end_handle_result) message = '选择处理结果';
  1286. else if (end_handle_result.indexOf('补发') >= 0 && !reissue_logistic_number) message = '补发单不能为空';
  1287. else if (end_handle_result.indexOf('入库') >= 0 && !store_in_number) message = '入库单号不能为空';
  1288. }
  1289. });
  1290. if (message) {
  1291. return {success: false, message: message};
  1292. }
  1293. } else if ('宝时补发' === status) {
  1294. if (this.baoShiEditWorkOrder.process_progress === null || this.baoShiEditWorkOrder.process_progress === '') {
  1295. return {success: false, message: '处理条件不能为空'};
  1296. }
  1297. let filers = this.baoShiEditWorkOrder.commodities.filter(e => {
  1298. return e.check_result === null || e.check_result.length <= 0;
  1299. });
  1300. if (filers.length > 0) {
  1301. return {success: false, message: '商品详情中处理结果不能为空'};
  1302. }
  1303. let message = null
  1304. this.baoShiEditWorkOrder.commodities.forEach(e => {
  1305. if (message) {
  1306. } else if ('宝时补发' === e.end_handle_result && (!e.reissue_logistic_number || e.reissue_logistic_number.trim().length === 0)) {
  1307. message = '补发单号为必填';
  1308. }
  1309. });
  1310. if (message) {
  1311. return {success: false, message: message};
  1312. }
  1313. }
  1314. }
  1315. return {success: true};
  1316. },
  1317. baoShiEditProcess(url, formData) {
  1318. this.waitingTempTip('处理中');
  1319. window.axios.post(url, formData).then(res => {
  1320. window.tempTip.cancelWaitingTip();
  1321. if (res.data.success) {
  1322. this.sortOrder(res.data.data);
  1323. this.$set(this.workOrders, this.selectIndex, res.data.data);
  1324. this.successTempTip('处理完成');
  1325. if (this.baoShiEditWorkOrder.is_edit) this.dialogEditBaoShiVisible = false
  1326. else this.dialogShowBaoShiVisible = false
  1327. } else {
  1328. this.errorTempTip(res.data.message ? res.data.message : '处理出现异常,刷新页面重试');
  1329. }
  1330. }).catch(err => {
  1331. window.tempTip.cancelWaitingTip();
  1332. this.errorTempTip(err);
  1333. });
  1334. },
  1335. getBaoShiProcessProgress() {
  1336. let {issue_type_name} = this.baoShiEditWorkOrder;
  1337. let items = [
  1338. {issue_type_name: '拦截', option: ['拦截成功', '拦截失败']},
  1339. {issue_type_name: '信息更改', option: ['更改成功', '更改失败'],},
  1340. {issue_type_name: '快递异常', option: ['丢件赔偿', '签收成功']},
  1341. {issue_type_name: '错漏发', option: ['已补发', '已入库'],},
  1342. {issue_type_name: '破损', option: ['全部赔偿', '部分赔偿', '不赔偿'],},
  1343. ];
  1344. let item = items.find(e => e.issue_type_name === issue_type_name);
  1345. return item ? item.option : [];
  1346. },
  1347. getBaoShiProcessResults() {
  1348. let {issue_type_name} = this.baoShiEditWorkOrder;
  1349. let items = [
  1350. {issue_type_name: '拦截', option: ['拦截成功', '拦截失败']},
  1351. {issue_type_name: '信息更改', option: ['更改成功', '更改失败'],},
  1352. {issue_type_name: '快递异常', option: ['赔偿', '不赔偿'],},
  1353. {issue_type_name: '错漏发', option: ['核实少发', '核实多发', '核实未错漏发']},
  1354. {issue_type_name: '破损', option: ['核实全部破损', '核实部分破损', '核实未破损'],},
  1355. {issue_type_name: '快递丢件', option: ['赔偿', '不赔偿'],},
  1356. ];
  1357. let item = items.find(e => e.issue_type_name === issue_type_name);
  1358. return item ? item.option : [];
  1359. },
  1360. getBaoShiProcessResultByItem(item){
  1361. },
  1362. getBaoShiEndHandleResult(commodity) {
  1363. let {process_result} = commodity;
  1364. let items = [
  1365. {process_result: '多发,客户买下', option: ['已完成出库']},
  1366. {process_result: '多发,客户退回', option: ['已退回仓库', '完成']},
  1367. {process_result: '少发,宝时补发', option: ['宝时补发']},
  1368. {process_result: '少发,不补发', option: ['已完成入库']},
  1369. {process_result: '核实未错漏发', option: ['确认未错漏发']},
  1370. ];
  1371. return items.filter(e => process_result === e.process_result).map(e => e.option).shift() ?? [];
  1372. },
  1373. getOwnerMistakeProcessResultInfo(process_result, item) {
  1374. let items = [
  1375. {process_result: "少发,宝时补发", option: ['商家不做单'],},
  1376. {process_result: "多发,客户买下", option: ['商家做出库单(物流选自提,宝时不发货)'],},
  1377. {process_result: "多发,客户退回", option: ['客户自行退回(提供退回单号)', '宝时上门取件(提供寄件信息,地址,联系人,电话)'],},
  1378. {process_result: "少发,不补发", option: ['商家做入库单,选择明细和数量'],},
  1379. {process_result: "核实未错漏发", option: ['确认未错漏发'],},
  1380. ];
  1381. let options = items.filter(e => e.process_result === process_result).map(e => e.option).shift() ?? [];
  1382. if (options.length === 0) {
  1383. item.process_result_info = options[0];
  1384. }
  1385. return options
  1386. },
  1387. baoShiDamageWorkOrderAuto(item) {
  1388. let abnormal_amount = Number(item.abnormal_amount),
  1389. check_amount = Number(item.bao_shi_check_amount);
  1390. if (check_amount === 0) item.process_result = '核实未破损';
  1391. else if (abnormal_amount > check_amount) item.process_result = '核实部分破损';
  1392. else if (abnormal_amount === check_amount) item.process_result = '核实全部破损';
  1393. this.countBaoShiDamageWorkOrderAuto();
  1394. },
  1395. countBaoShiDamageWorkOrderAuto() {
  1396. let data = {allCompensate: 0, partiallyCompensate: 0, notCompensate: 0};
  1397. this.baoShiEditWorkOrder.commodities.forEach(e => {
  1398. let abnormal_amount = Number(e.abnormal_amount),
  1399. bao_shi_check_amount = Number(e.bao_shi_check_amount);
  1400. if (bao_shi_check_amount === 0) {
  1401. data.notCompensate += 1;
  1402. } else if (abnormal_amount > bao_shi_check_amount) {
  1403. data.partiallyCompensate += 1;
  1404. } else if (abnormal_amount === bao_shi_check_amount) {
  1405. data.allCompensate += 1;
  1406. }
  1407. });
  1408. if (data.partiallyCompensate === 0 && data.allCompensate === 0 && data.notCompensate > 0) this.baoShiEditWorkOrder.process_progress = '不赔偿';
  1409. else if (data.partiallyCompensate > 0 || (data.partiallyCompensate > 0 || data.notCompensate > 0)) this.baoShiEditWorkOrder.process_progress = '部分赔偿';
  1410. else if (data.allCompensate > 0 && data.partiallyCompensate === 0 && data.notCompensate === 0) this.baoShiEditWorkOrder.process_progress = '全部赔偿';
  1411. },
  1412. baoShiChangeExpressAbnormal(item) {
  1413. if (item.process_result === '赔偿') this.baoShiEditWorkOrder.process_progress = '丢件赔偿';
  1414. else if (item.process_result === '不赔偿') this.baoShiEditWorkOrder.process_progress = '签收成功';
  1415. },
  1416. computeBaoShiMistakeCheckResult(item) {
  1417. let amount = Number(item.amount);
  1418. let bao_shi_check_amount = Number(item['bao_shi_check_amount']);
  1419. item.check_result = amount === bao_shi_check_amount ? '核实未错漏发' : (amount < bao_shi_check_amount ? '核实多发' : '核实少发')
  1420. },
  1421. computeBaoShiMistakeProcess() {
  1422. let less = 0, mary = 0, not = 0;
  1423. this.baoShiEditWorkOrder.commodities.forEach(e => {
  1424. if (e.process_result_info.indexOf("少发") !== -1) less++;
  1425. else if (e.process_result_info.indexOf("多发") !== -1) mary++;
  1426. else if (e.process_result_info) not++;
  1427. });
  1428. this.baoShiEditWorkOrder.process_progress = '';
  1429. },
  1430. autoComputeBaoShiMistake() {
  1431. let store_in = 0, out_in = 0, noMistake = 0; // store_in 不补发 out_in 补发
  1432. this.baoShiEditWorkOrder.commodities.forEach(e => {
  1433. let {end_handle_result} = e;
  1434. if (end_handle_result.indexOf('补发') >= 0) out_in++;
  1435. else if (end_handle_result.indexOf('入库') >= 0) store_in++;
  1436. else if (end_handle_result.indexOf('退回') >= 0) store_in++;
  1437. else if (end_handle_result.indexOf('完成') >= 0) store_in++;
  1438. else if (end_handle_result.indexOf('未错漏发')) noMistake++;
  1439. });
  1440. // 补发 不补发
  1441. if (out_in > store_in) this.baoShiEditWorkOrder.process_progress = '已补发';
  1442. else if (out_in < store_in) this.baoShiEditWorkOrder.process_progress = '已入库';
  1443. else if (noMistake > 0) this.baoShiEditWorkOrder.process_progress = '确认未错漏发';
  1444. },
  1445. baoShiAutoComputeMistakeProcessProcess() { //
  1446. let all = 0, reissue = 0, store = 0, process_progress = ''; // 未错漏发 补发 入库
  1447. this.baoShiEditWorkOrder.commodities.forEach(e => {
  1448. let {end_handle_result} = e;
  1449. if (end_handle_result.indexOf('补发') >= 0 || end_handle_result.indexOf('出库') >= 0) reissue++;
  1450. else if (end_handle_result.indexOf('退回') >= 0 || end_handle_result.indexOf('完成') >= 0) store++;
  1451. else if (end_handle_result.indexOf('已完成入库') >= 0 ) store++;
  1452. else if (end_handle_result.indexOf('完成出库') >= 0 ) reissue++;
  1453. else if (end_handle_result.indexOf('确认未错漏发') >= 0) all++;
  1454. });
  1455. if (reissue > 0) process_progress = '已补发';
  1456. else if (store > 0) process_progress = '已入库';
  1457. else if (all > 0) process_progress = '确认未错漏发';
  1458. else process_progress = '确认未错漏发';
  1459. this.baoShiEditWorkOrder.process_progress = process_progress;
  1460. },
  1461. baoShiGroupCommodities(items) {
  1462. items.forEach(e => e.count = 0);
  1463. let index = 0;
  1464. let logistic_number = items[0]['logistic_number'];
  1465. let count = 0;
  1466. items.forEach(e=>e.count=0);
  1467. items.forEach((e, i) => {
  1468. let cur_logistic_number = e.logistic_number,
  1469. {process_result_info,end_handle_result} = e,
  1470. isAdd = false, isAddRow = false;
  1471. if (process_result_info) {
  1472. if (process_result_info.indexOf('补发') >= 0 ||
  1473. process_result_info.indexOf('完成') >= 0 ||
  1474. process_result_info.indexOf('入库') >= 0 ||
  1475. process_result_info.indexOf('商家做出库单') >= 0 ||
  1476. process_result_info.indexOf('商家做入库单') >= 0 ||
  1477. process_result_info.indexOf('商家不做单') >= 0) {
  1478. isAddRow = true;
  1479. }
  1480. }
  1481. if (cur_logistic_number === logistic_number) {
  1482. count++;
  1483. if (isAddRow) count++;
  1484. if (isAdd) count++;
  1485. } else if (cur_logistic_number !== logistic_number) {
  1486. logistic_number = cur_logistic_number;
  1487. items[index]['count'] = count;
  1488. index = i;
  1489. count = 1;
  1490. if (isAdd) count++;
  1491. if (isAddRow) count++;
  1492. }
  1493. items[index]['count'] = count;
  1494. });
  1495. },
  1496. // 承运商
  1497. isLogisticDispose(item) {
  1498. let {issue_type_name, status} = item;
  1499. return ['拦截', '信息更改', '快递异常', '破损', '快递丢件'].includes(issue_type_name) && status === '承运商处理';
  1500. },
  1501. canLogisticEdit(item) {
  1502. let {issue_type_name, last_status, status} = item;
  1503. if (status === '完成') return false;
  1504. else return ['拦截', '信息更改', '快递异常', '破损', '快递丢件'].includes(issue_type_name) && last_status === '承运商处理';
  1505. },
  1506. logisticShowEdit(item, index) {
  1507. let {issue_type_name, detail_id, commodities} = item.pending_detail;
  1508. this.logisticEditWorkOrder.is_edit = true;
  1509. this.selectIndex = index;
  1510. this.logisticEditWorkOrder.issue_type_name = issue_type_name;
  1511. this.logisticEditWorkOrder.detail_id = detail_id;
  1512. this.logisticEditWorkOrder.process_progress = item.process_progress;
  1513. if ('拦截' === issue_type_name) {
  1514. this.dialogEditLogisticVisible = true;
  1515. } else if ('信息更改' === issue_type_name) {
  1516. this.dialogEditLogisticVisible = true;
  1517. } else if ('快递异常' === issue_type_name) {
  1518. this.logisticEditWorkOrder.commodities = item.pending_detail.commodities.map(e => e);
  1519. this.dialogEditLogisticVisible = true;
  1520. } else if ('破损' === issue_type_name) {
  1521. this.countByCommodities(commodities);
  1522. this.logisticEditWorkOrder.commodities = commodities;
  1523. this.dialogEditLogisticVisible = true;
  1524. }
  1525. },
  1526. logisticShowDispose(item, index) {
  1527. let {status} = item.issue_type_name;
  1528. let {issue_type_name, detail_id, commodities} = item.pending_detail;
  1529. this.logisticEditWorkOrder.is_edit = false;
  1530. if (issue_type_name === '拦截') {
  1531. this.selectIndex = index;
  1532. this.logisticEditWorkOrder.issue_type_name = issue_type_name;
  1533. this.logisticEditWorkOrder.detail_id = detail_id;
  1534. this.logisticEditWorkOrder.process_progress = null;
  1535. this.dialogShowLogisticVisible = true;
  1536. } else if (issue_type_name === '信息更改') {
  1537. this.selectIndex = index;
  1538. this.logisticEditWorkOrder.issue_type_name = issue_type_name;
  1539. this.logisticEditWorkOrder.detail_id = detail_id;
  1540. this.logisticEditWorkOrder.process_progress = null;
  1541. this.dialogShowLogisticVisible = true;
  1542. } else if ('快递丢件' === issue_type_name) {
  1543. this.selectIndex = index;
  1544. this.logisticEditWorkOrder.detail_id = item.pending_detail.detail_id;
  1545. this.logisticEditWorkOrder.issue_type_name = issue_type_name;
  1546. this.logisticEditWorkOrder.status = status;
  1547. let commodities = item.pending_detail.commodities;
  1548. commodities.forEach(e => {
  1549. e.check_amount = e.abnormal_amount;
  1550. });
  1551. this.logisticEditWorkOrder.commodities = this.countCommoditiesByLogisticNumber(commodities);
  1552. this.dialogShowLogisticVisible = true;
  1553. } else if ('破损' === issue_type_name) {
  1554. this.selectIndex = index;
  1555. this.logisticEditWorkOrder.detail_id = item.pending_detail.detail_id;
  1556. this.logisticEditWorkOrder.issue_type_name = issue_type_name;
  1557. this.logisticEditWorkOrder.status = status;
  1558. let commodities = item.pending_detail.commodities;
  1559. commodities.forEach(e => {
  1560. e.check_amount = e.amount;
  1561. e.check_result = '核实全部破损';
  1562. });
  1563. this.logisticEditWorkOrder.process_progress = '核实全部破损'
  1564. this.logisticEditWorkOrder.commodities = this.countCommoditiesByLogisticNumber(commodities);
  1565. this.dialogShowLogisticVisible = true;
  1566. } else if ('快递异常' === issue_type_name) {
  1567. this.selectIndex = index;
  1568. this.logisticEditWorkOrder.detail_id = detail_id;
  1569. this.logisticEditWorkOrder.issue_type_name = issue_type_name;
  1570. this.logisticEditWorkOrder.status = status;
  1571. this.logisticEditWorkOrder.process_progress = null;
  1572. let commodities = item.pending_detail.commodities;
  1573. commodities.forEach(e => {
  1574. e.check_amount = e.abnormal_amount;
  1575. });
  1576. this.logisticEditWorkOrder.commodities = this.countCommoditiesByLogisticNumber(commodities);
  1577. this.dialogShowLogisticVisible = true;
  1578. }
  1579. },
  1580. logisticEdit() {
  1581. let {issue_type_name, commodities, detail_id, process_progress} = this.logisticEditWorkOrder;
  1582. if (issue_type_name === '拦截') {
  1583. let res = this.checkLogisticEditWorkOrder();
  1584. if (!res.success) {
  1585. this.errorTempTip(res.message);
  1586. return;
  1587. }
  1588. let url = "{{route('workOrder.intercept.logistic.handlerApi')}}";
  1589. let data = {detail_id: detail_id, process_progress: process_progress};
  1590. this.logisticEditProcess(data, url);
  1591. } else if (issue_type_name === '信息更改') {
  1592. let res = this.checkLogisticEditWorkOrder();
  1593. if (!res.success) {
  1594. this.errorTempTip(res.message);
  1595. return;
  1596. }
  1597. let url = "{{route('workOrder.informationChange.logistic.handlerApi')}}";
  1598. let data = {detail_id: detail_id, process_progress: process_progress};
  1599. this.logisticEditProcess(data, url);
  1600. } else if (issue_type_name === '破损') {
  1601. let res = this.checkLogisticEditWorkOrder();
  1602. if (!res.success) {
  1603. this.errorTempTip(res.message);
  1604. return;
  1605. }
  1606. let url = '{{route('workOrder.damage.logistic.handlerApi')}}';
  1607. let formData = new FormData();
  1608. formData.append('detail_id', detail_id);
  1609. formData.append('process_progress', process_progress);
  1610. commodities.forEach(e => {
  1611. formData.append('commodities[]', JSON.stringify(e));
  1612. });
  1613. this.logisticEditProcess(formData, url);
  1614. } else if ('快递异常' === issue_type_name) {
  1615. let res = this.checkLogisticEditWorkOrder();
  1616. if (!res.success) {
  1617. this.errorTempTip(res.message);
  1618. return;
  1619. }
  1620. let url = '{{route('workOrder.expressAbnormal.logistic.handlerApi')}}';
  1621. let formData = new FormData();
  1622. formData.append('detail_id', detail_id);
  1623. formData.append('process_progress', process_progress);
  1624. commodities.forEach(e => {
  1625. formData.append('commodities[]', JSON.stringify(e));
  1626. });
  1627. this.logisticEditProcess(formData, url);
  1628. }
  1629. },
  1630. logisticEditProcess(data, url) {
  1631. this.waitingTempTip('处理中')
  1632. window.axios.post(url, data).then(res => {
  1633. window.tempTip.cancelWaitingTip();
  1634. if (res.data.success) {
  1635. this.sortOrder(res.data.data);
  1636. this.$set(this.workOrders, this.selectIndex, res.data.data);
  1637. this.successTempTip('处理完成');
  1638. if (this.logisticEditWorkOrder.is_edit) this.dialogEditLogisticVisible = false;
  1639. else this.dialogShowLogisticVisible = false;
  1640. } else {
  1641. this.errorTempTip(res.data.message ? res.data.message : '处理出现异常,刷新当前页面重试');
  1642. }
  1643. }).catch(err => {
  1644. window.tempTip.cancelWaitingTip();
  1645. this.errorTempTip(err);
  1646. });
  1647. },
  1648. checkLogisticEditWorkOrder() {
  1649. if (this.logisticEditWorkOrder.process_progress === null) {
  1650. return {success: false, message: '处理结果为必选项'};
  1651. }
  1652. let filers = this.logisticEditWorkOrder.commodities.filter(item => {
  1653. return item.check_result.length === 0;
  1654. });
  1655. if (filers.length > 0) {
  1656. return {success: false, message: '商品详情的核实结果不能为空'};
  1657. }
  1658. return {success: true};
  1659. },
  1660. getLogisticCheckResult() {
  1661. let {issue_type_name} = this.logisticEditWorkOrder;
  1662. let items = [
  1663. {issue_type_name: '快递异常', option: ['已处理', '已拦截']},
  1664. {issue_type_name: '破损', option: ['核实全部破损', '核实部分破损', '核实未破损']},
  1665. ];
  1666. let item = items.find(e => e.issue_type_name === issue_type_name);
  1667. return item ? item.option : [];
  1668. },
  1669. getLogisticProcessProgress() {
  1670. let {issue_type_name} = this.logisticEditWorkOrder;
  1671. let items = [
  1672. {issue_type_name: '拦截', option: ['已处理', '已签收']},
  1673. {issue_type_name: '信息更改', option: ['已处理', '无法更改']},
  1674. {issue_type_name: '快递异常', option: ['已处理', '已拦截']},
  1675. {issue_type_name: '破损', option: ['核实全部破损', '核实部分破损', '核实未破损']},
  1676. ];
  1677. let item = items.find(e => e.issue_type_name === issue_type_name);
  1678. return item ? item.option : [];
  1679. },
  1680. logisticDamageWorkOrderAuto(item) {
  1681. let abnormal_amount = Number(item.abnormal_amount),
  1682. check_amount = Number(item.check_amount);
  1683. if (check_amount === 0) item.check_result = '核实未破损';
  1684. else if (abnormal_amount > check_amount) item.check_result = '核实部分破损';
  1685. else if (abnormal_amount === check_amount) item.check_result = '核实全部破损';
  1686. this.countLogisticDamageWorkOrderAuto();
  1687. },
  1688. logisticChangeExpressAbnormal(item) {
  1689. this.logisticEditWorkOrder.process_progress = item.check_result;
  1690. },
  1691. countLogisticDamageWorkOrderAuto() {
  1692. let data = {allDamage: 0, partiallyDamage: 0, notDamage: 0};
  1693. this.logisticEditWorkOrder.commodities.forEach(e => {
  1694. let abnormal_amount = Number(e.abnormal_amount),
  1695. check_amount = Number(e.check_amount);
  1696. if (check_amount === 0) {
  1697. data.notDamage += 1;
  1698. } else if (abnormal_amount > check_amount) {
  1699. data.partiallyDamage += 1;
  1700. } else if (abnormal_amount === check_amount) {
  1701. data.allDamage += 1;
  1702. }
  1703. });
  1704. if (data.partiallyDamage === 0 && data.allDamage === 0 && data.notDamage > 0) this.logisticEditWorkOrder.process_progress = '核实未破损';
  1705. else if (data.partiallyDamage > 0 || (data.partiallyDamage > 0 || data.notDamage > 0)) this.logisticEditWorkOrder.process_progress = '核实部分破损';
  1706. else if (data.allDamage > 0 && data.partiallyDamage === 0 && data.notDamage === 0) this.logisticEditWorkOrder.process_progress = '核实全部破损'
  1707. },
  1708. // 商家
  1709. isOwnerDispose(item) {
  1710. let {issue_type_name, status} = item;
  1711. if (issue_type_name === '快递丢件' && status === '货主处理') return true;
  1712. else if (issue_type_name === '错漏发' && status === '货主处理') return true;
  1713. return false;
  1714. },
  1715. canOwnerEdit(item) {
  1716. let {issue_type_name, status} = item;
  1717. if (issue_type_name === '信息更改' && status === '承运商处理') return true;
  1718. if (issue_type_name === '快递丢件' && status === '宝时终审') return true;
  1719. if (issue_type_name === '快递异常' && status === '承运商处理') return true;
  1720. if (issue_type_name === '破损' && status === '承运商处理') return true;
  1721. if (issue_type_name === '错漏发' && status === '宝时终审') return true;
  1722. else if (issue_type_name === '错漏发' && status === '宝时处理') return true;
  1723. return false;
  1724. },
  1725. ownerShowDispose(item, index) {
  1726. let issue_type_name = item.issue_type_name;
  1727. this.selectIndex = index;
  1728. this.ownerEditWorkOrder.is_edit = false;
  1729. this.ownerEditWorkOrder.detail_id = item.pending_detail.detail_id; // 工单详情id
  1730. if (issue_type_name === '快递丢件' && item.status === '货主处理') {
  1731. this.waitingTempTip('获取数据中');
  1732. this.getOrderCommodity(item).then(res => {
  1733. res = this.countCommoditiesByLogisticNumber(res);
  1734. window.tempTip.cancelWaitingTip();
  1735. this.ownerEditWorkOrder.id = item.id; // 工单id
  1736. this.selectIndex = index;
  1737. this.ownerEditWorkOrder.pirce = null;
  1738. this.ownerEditWorkOrder.status = item.status;
  1739. this.ownerEditWorkOrder.issue_type_name = issue_type_name;
  1740. let commodities = res.map(item => {
  1741. item.abnormal_amount = item.amount;
  1742. item.tag = 0;
  1743. item.price = 0;
  1744. item.reissue_logistic_number = null;
  1745. item.out_order_number = null;
  1746. item.store_in_amount = null;
  1747. return item;
  1748. }); //商品详情
  1749. this.ownerEditWorkOrder.commodities = this.groupShowWorkOrderCommodity(commodities);
  1750. this.ownerEditWorkOrder.reissue_logistic_number = null; //
  1751. this.ownerEditWorkOrder.logistic_number = null; //
  1752. this.ownerEditWorkOrder.refundImages = []; // 退款截图
  1753. this.ownerEditWorkOrder.dealImages = []; // 交易截图
  1754. this.dialogShowOwnerVisible = true;
  1755. }).catch(err => {
  1756. window.tempTip.cancelWaitingTip();
  1757. this.errorTempTip('获取数据异常')
  1758. });
  1759. } else if (issue_type_name === '错漏发' && item.status === '货主处理') {
  1760. let commodities = item.pending_detail.commodities;
  1761. commodities.forEach(e => {
  1762. e.check_amount = e.abnormal_amount;
  1763. e.reissue_logistic_number = null;
  1764. e.out_order_number = null;
  1765. e.store_in_amount = null;
  1766. });
  1767. this.ownerEditWorkOrder.commodities = this.countCommoditiesByLogisticNumber(commodities);
  1768. this.ownerEditWorkOrder.status = item.status;
  1769. this.ownerEditWorkOrder.issue_type_name = issue_type_name;
  1770. this.autoComputeOwnerMistake();
  1771. this.dialogShowOwnerVisible = true;
  1772. }
  1773. },
  1774. ownerShowEdit(item, index) {
  1775. this.selectIndex = index;
  1776. let {issue_type_name, logistic_number, pending_detail, type, remark, status} = item;
  1777. let {price, remake, images,reissue_logistic_number} = pending_detail;
  1778. this.ownerEditWorkOrder.is_edit = true;
  1779. this.ownerEditWorkOrder.status = status;
  1780. this.ownerEditWorkOrder.price = price;
  1781. this.ownerEditWorkOrder.issue_type_name = issue_type_name;
  1782. this.ownerEditWorkOrder.logistic_number = logistic_number;
  1783. this.ownerEditWorkOrder.remake = remake;
  1784. this.ownerEditWorkOrder.type = type;
  1785. this.ownerEditWorkOrder.reissue_logistic_number = reissue_logistic_number;
  1786. this.ownerEditWorkOrder.detail_id = pending_detail.detail_id;
  1787. this.ownerEditWorkOrder.packageImages = images.filter(e => e.type === '外包装图片');
  1788. this.ownerEditWorkOrder.commodityImages = images.filter(e => e.type === '内物破碎图片');
  1789. this.ownerEditWorkOrder.dealImages = images.filter(e => e.type === '交易截图');
  1790. this.ownerEditWorkOrder.refundImages = images.filter(e => e.type === '退款成功截图');
  1791. this.ownerEditWorkOrder.process_progress = item.process_progress;
  1792. this.ownerEditWorkOrder.remark = remark;
  1793. let work_order_commodities = pending_detail.commodities ? pending_detail.commodities : [];
  1794. work_order_commodities = JSON.parse(JSON.stringify(work_order_commodities));
  1795. if ('快递异常' === issue_type_name) {
  1796. let {order} = item;
  1797. let {packages} = order;
  1798. let items = packages.map(e => {
  1799. return {logistic_number: e.logistic_number, selected: false, is_created: true}
  1800. });
  1801. let logistic_numbers = pending_detail.commodities.map(e => {
  1802. return {logistic_number: e.logistic_number, selected: true, is_created: false, id: e.id}
  1803. });
  1804. items.forEach(item => {
  1805. let data = logistic_numbers.find(e => e.logistic_number === item.logistic_number);
  1806. if (!data) {
  1807. logistic_numbers.push(item);
  1808. }
  1809. });
  1810. this.ownerEditWorkOrder.commodities = logistic_numbers;
  1811. this.dialogEditOwnerVisible = true;
  1812. } else if ('错漏发' === issue_type_name) {
  1813. work_order_commodities.forEach(e => {
  1814. e.created = false;
  1815. e.tag = false;
  1816. }); // 标记编辑
  1817. if ('宝时处理' === status) {
  1818. this.waitingTempTip('查询中...')
  1819. this.getOrderCommodity(item).then(res => {
  1820. window.tempTip.cancelWaitingTip();
  1821. res.forEach(item => {
  1822. item.created = true; // 标记创建
  1823. item.tag = false; // 标记是否过滤
  1824. item.commodity = {name: item.name};
  1825. let data = work_order_commodities.find(e => e.logistic_number === item.logistic_number && e.sku === item.sku);
  1826. if (!data) {
  1827. if ('错漏发' === issue_type_name) {
  1828. if (status === '宝时终审') {
  1829. } else if (status === '宝时处理') {
  1830. item.abnormal_amount = item.amount;
  1831. item.abnormal_type = '未错漏发'
  1832. }
  1833. } else if ('破损' === issue_type_name) {
  1834. item.price = 0;
  1835. item.abnormal_type = '破损';
  1836. item.abnormal_amount = item.amount;
  1837. }
  1838. work_order_commodities.push(item);
  1839. }
  1840. });
  1841. this.ownerEditWorkOrder.commodities = this.countCommoditiesByLogisticNumber(work_order_commodities);
  1842. this.dialogEditOwnerVisible = true;
  1843. });
  1844. } else if ('宝时终审' === status) {
  1845. let {return_address, return_phone, return_name, return_logistic_number} = pending_detail;
  1846. this.ownerEditWorkOrder.return_logistic_number = return_logistic_number;
  1847. this.ownerEditWorkOrder.return_address = return_address;
  1848. this.ownerEditWorkOrder.return_phone = return_phone;
  1849. this.ownerEditWorkOrder.return_name = return_name;
  1850. this.ownerEditWorkOrder.commodities = this.countCommoditiesByLogisticNumber(work_order_commodities);
  1851. this.dialogEditOwnerVisible = true;
  1852. }
  1853. }else if ('破损' === issue_type_name){
  1854. work_order_commodities.forEach(e => {
  1855. e.created = false;
  1856. e.tag = false;
  1857. }); // 标记编辑
  1858. this.waitingTempTip('查询中...')
  1859. this.getOrderCommodity(item).then(res => {
  1860. window.tempTip.cancelWaitingTip();
  1861. res.forEach(item => {
  1862. item.created = true; // 标记创建
  1863. item.tag = false; // 标记是否过滤
  1864. item.commodity = {name: item.name};
  1865. let data = work_order_commodities.find(e => e.logistic_number === item.logistic_number && e.sku === item.sku);
  1866. if (!data) {
  1867. item.price = 0;
  1868. item.abnormal_type = '破损';
  1869. item.abnormal_amount = item.amount;
  1870. work_order_commodities.push(item);
  1871. }
  1872. });
  1873. this.ownerEditWorkOrder.commodities = this.countCommoditiesByLogisticNumber(work_order_commodities);
  1874. this.dialogEditOwnerVisible = true;
  1875. if (this.ownerEditWorkOrder.reissue_logistic_number) {
  1876. this.$refs['refund-image-edit-reissue_logistic_number'].innerHTML = reissue_logistic_number;
  1877. }
  1878. }).catch(err => {
  1879. window.tempTip.cancelWaitingTip();
  1880. this.errorTempTip(err)
  1881. });
  1882. } else if(['拦截','信息更改'].includes(issue_type_name)){
  1883. this.dialogEditOwnerVisible = true;
  1884. } else if ('快递丢件'.includes(issue_type_name)){
  1885. work_order_commodities.forEach(e => {
  1886. e.created = false;
  1887. e.tag = false;
  1888. }); // 标记编辑
  1889. this.waitingTempTip('查询中...')
  1890. this.getOrderCommodity(item).then(res => {
  1891. window.tempTip.cancelWaitingTip();
  1892. res.forEach(item => {
  1893. item.created = true; // 标记创建
  1894. item.tag = false; // 标记是否过滤
  1895. item.commodity = {name: item.name};
  1896. let data = work_order_commodities.find(e => e.logistic_number === item.logistic_number && e.sku === item.sku);
  1897. if (!data) {
  1898. item.abnormal_amount = item.amount;
  1899. work_order_commodities.push(item);
  1900. }
  1901. });
  1902. this.ownerEditWorkOrder.commodities = this.countCommoditiesByLogisticNumber(work_order_commodities);
  1903. this.dialogEditOwnerVisible = true;
  1904. }).catch(err => {
  1905. window.tempTip.cancelWaitingTip();
  1906. this.errorTempTip(err)
  1907. });
  1908. }
  1909. },
  1910. ownerEdit() {
  1911. let {issue_type_name, process_progress, is_edit} = this.ownerEditWorkOrder;
  1912. let {
  1913. detail_id, price, dealImages, refundImages,
  1914. commodities, reissue_logistic_number,
  1915. return_logistic_number, return_address,
  1916. return_phone, return_name, remark, status
  1917. } = this.ownerEditWorkOrder;
  1918. let {delete_image_ids, delete_commodity_ids} = this.ownerEditWorkOrder;
  1919. if (issue_type_name === '快递丢件') {
  1920. if (is_edit) {
  1921. let res = this.checkOwnerEditWorkOrder();
  1922. if (!res.success) {
  1923. this.errorTempTip(res.message);
  1924. return;
  1925. }
  1926. let formData = new FormData();
  1927. formData.append('detail_id', detail_id);
  1928. formData.append('price', price);
  1929. delete_image_ids.forEach(e => formData.append("delete_image_ids[]", e));
  1930. delete_commodity_ids.forEach(e => formData.append("delete_commodity_ids[]", e));
  1931. commodities.filter(e => !e.tag).filter(e => e.created).forEach(e => {
  1932. if (!e.id) formData.append("commodities[]", JSON.stringify(e));
  1933. });
  1934. formData.append('is_edit', true);
  1935. formData.append('reissue_logistic_number', reissue_logistic_number);
  1936. let {dealImages, refundImages} = this.ownerEditWorkOrder;
  1937. dealImages = dealImages.filter(e => e.src);
  1938. refundImages = refundImages.filter(e => e.src);
  1939. this.setFormDataImagePrefix(formData, 'dealImages', this.getImages(dealImages));
  1940. this.setFormDataImagePrefix(formData, 'refundImages', this.getImages(refundImages));
  1941. let url = '{{route('workOrder.loss.owner.fillDetailApi')}}';
  1942. this.ownerEditProcess(formData, url);
  1943. } else {
  1944. let res = this.checkOwnerEditWorkOrder();
  1945. if (!res.success) {
  1946. this.errorTempTip(res.message);
  1947. return;
  1948. }
  1949. let formData = new FormData();
  1950. reissue_logistic_number ? formData.append('reissue_logistic_number', reissue_logistic_number) : null;
  1951. formData.append('detail_id', detail_id);
  1952. formData.append('price', price);
  1953. dealImages = this.getImages(dealImages);
  1954. refundImages = this.getImages(refundImages);
  1955. this.setFormDataImagePrefix(formData, 'dealImages', dealImages);
  1956. this.setFormDataImagePrefix(formData, 'refundImages', refundImages);
  1957. commodities.forEach(e => {
  1958. formData.append("commodities[]", JSON.stringify(e));
  1959. });
  1960. window.tempTip.setIndex(2000);
  1961. window.tempTip.waitingTip('处理中');
  1962. let url = '{{route('workOrder.loss.owner.fillDetailApi')}}';
  1963. this.ownerEditProcess(formData, url);
  1964. }
  1965. } else if (issue_type_name === '错漏发') {
  1966. if (is_edit) {
  1967. let formData = new FormData();
  1968. formData.append('detail_id', detail_id);
  1969. formData.append('is_edit', true);
  1970. formData.append('remark', remark);
  1971. if (status === '宝时处理') {
  1972. this.ownerAutoComputeMistake();
  1973. let res = this.checkOwnerEditWorkOrder();
  1974. if (!res.success) {
  1975. this.errorTempTip(res.message);
  1976. return;
  1977. }
  1978. let url = '{{route('workOrder.mistake.owner.editApi')}}';
  1979. commodities.filter(e => !e.tag).filter(e => !e.created).forEach(e => {
  1980. if (e.id) formData.append("update_commodities[]", JSON.stringify(e));
  1981. });
  1982. commodities.filter(e => !e.tag).filter(e => e.created).filter(e => e.abnormal_type !== '未错漏发').forEach(e => {
  1983. if (!e.id) formData.append("commodities[]", JSON.stringify(e));
  1984. });
  1985. commodities.filter(e => e.tag).forEach(e => {
  1986. if (e.id) formData.append("delete_commodity_ids[]", e.id);
  1987. });
  1988. this.ownerEditProcess(formData, url);
  1989. } else if (status === '宝时终审') {
  1990. let res = this.checkOwnerEditWorkOrder();
  1991. if (!res.success) {
  1992. this.errorTempTip(res.message);
  1993. return;
  1994. }
  1995. let url = '{{route('workOrder.mistake.logistic.end.handlerApi')}}';
  1996. formData.append('process_progress', process_progress);
  1997. return_logistic_number ? formData.append('return_logistic_number', return_logistic_number) : null;
  1998. return_address ? formData.append('return_address', return_address) : null;
  1999. return_phone ? formData.append('return_phone', return_phone) : null;
  2000. return_name ? formData.append('return_name', return_name) : null;
  2001. commodities.filter(e => !e.tag).filter(e => !e.created).forEach(e => {
  2002. if (e.id) formData.append("update_commodities[]", JSON.stringify(e));
  2003. });
  2004. commodities.filter(e => !e.tag).filter(e => e.created).filter(e => e.abnormal_type !== '未错漏发').forEach(e => {
  2005. if (!e.id) formData.append("commodities[]", JSON.stringify(e));
  2006. });
  2007. commodities.filter(e => e.tag).forEach(e => {
  2008. if (e.id) formData.append("delete_commodity_ids[]", e.id);
  2009. });
  2010. this.ownerEditProcess(formData, url);
  2011. }
  2012. } else {
  2013. let res = this.checkOwnerEditWorkOrder();
  2014. if (!res.success) {
  2015. this.errorTempTip(res.message);
  2016. return;
  2017. }
  2018. let url = '{{route('workOrder.mistake.owner.handlerApi')}}';
  2019. let formData = new FormData();
  2020. formData.append('detail_id', detail_id);
  2021. formData.append('process_progress', process_progress);
  2022. return_logistic_number ? formData.append('return_logistic_number', return_logistic_number) : null;
  2023. return_address ? formData.append('return_address', return_address) : null;
  2024. return_phone ? formData.append('return_phone', return_phone) : null;
  2025. return_name ? formData.append('return_name', return_name) : null;
  2026. return_name ? formData.append('return_name', return_name) : null;
  2027. commodities.forEach(e => {
  2028. formData.append("commodities[]", JSON.stringify(e));
  2029. });
  2030. this.ownerEditProcess(formData, url);
  2031. }
  2032. } else if ('快递异常' === issue_type_name) {
  2033. if (is_edit) {
  2034. let res = this.checkOwnerEditWorkOrder();
  2035. if (!res.success) {
  2036. this.errorTempTip(res.message);
  2037. return;
  2038. }
  2039. let {dealImages} = this.ownerEditWorkOrder;
  2040. let formData = new FormData();
  2041. let url = '{{route('workOrder.expressAbnormal.owner.editApi')}}';
  2042. formData.append('detail_id', detail_id);
  2043. formData.append('is_edit', true);
  2044. commodities.filter(e => e.selected && e.is_created).forEach(e => formData.append("commodities[]", JSON.stringify(e)));
  2045. commodities.filter(e => e.is_created === false && !e.selected).forEach(e => formData.append("delete_commodity_ids[]", e.id));
  2046. dealImages = this.getImages(dealImages.filter(e => e.file));
  2047. this.setFormDataImagePrefix(formData, 'dealImages', dealImages);
  2048. this.ownerEditProcess(formData, url);
  2049. }
  2050. } else if ('破损' === issue_type_name) {
  2051. if (is_edit) {
  2052. let res = this.checkOwnerEditWorkOrder();
  2053. if (!res.success) {
  2054. this.errorTempTip(res.message);
  2055. return;
  2056. }
  2057. let url = '{{route('workOrder.damage.owner.editApi')}}';
  2058. let formData = new FormData;
  2059. formData.append('detail_id', detail_id);
  2060. formData.append('is_edit', true);
  2061. formData.append('price', price);
  2062. commodities.filter(e => e.created).filter(e => !e.tag).forEach(e => formData.append("commodities[]", JSON.stringify(e)));
  2063. commodities.filter(e => !e.created).filter(e => !e.tag).forEach(e => formData.append("update_commodities[]", JSON.stringify(e)));
  2064. commodities.filter(e => !e.created).filter(e => e.tag).forEach(e => formData.append("delete_commodity_ids[]", e.id));
  2065. this.ownerEditWorkOrder.delete_image_ids.forEach(e => formData.append("delete_image_ids[]", e));
  2066. let {packageImages, commodityImages, dealImages} = this.ownerEditWorkOrder;
  2067. this.setFormDataImagePrefix(formData, 'packageImages', this.getImages(packageImages.filter(e => e.file)));
  2068. this.setFormDataImagePrefix(formData, 'commodityImages', this.getImages(commodityImages.filter(e => e.file)));
  2069. this.setFormDataImagePrefix(formData, 'dealImages', this.getImages(dealImages.filter(e => e.file)));
  2070. this.ownerEditProcess(formData, url);
  2071. }
  2072. } else if ('信息更改' === issue_type_name){
  2073. let formData = new FormData();
  2074. let {detail_id,remark} = this.ownerEditWorkOrder;
  2075. formData.append('detail_id',detail_id);
  2076. formData.append('remark',remark);
  2077. let url = "{{route('workOrder.informationChange.owner.editApi')}}";
  2078. this.ownerEditProcess(formData,url);
  2079. }
  2080. },
  2081. ownerEditProcess(data, url) {
  2082. this.waitingTempTip('处理中');
  2083. window.axios.post(url, data, {'Content-Type': 'multipart/form-data'}).then(res => {
  2084. window.tempTip.cancelWaitingTip();
  2085. if (res.data.success) {
  2086. this.successTempTip('处理完成');
  2087. this.sortOrder(res.data.data);
  2088. this.$set(this.workOrders, this.selectIndex, res.data.data);
  2089. this.selectIndex = null;
  2090. if (this.ownerEditWorkOrder.is_edit) this.dialogEditOwnerVisible = false;
  2091. else this.dialogShowOwnerVisible = false;
  2092. } else if (res.data.message) {
  2093. this.errorTempTip(res.data.message);
  2094. } else {
  2095. this.errorTempTip('处理出现异常');
  2096. }
  2097. }).catch(err => {
  2098. window.tempTip.cancelWaitingTip();
  2099. this.errorTempTip(err);
  2100. });
  2101. },
  2102. checkOwnerEditWorkOrder() {
  2103. let {issue_type_name, is_edit} = this.ownerEditWorkOrder;
  2104. if (issue_type_name === '快递丢件') {
  2105. if (!this.ownerEditWorkOrder.price) {
  2106. return {success: false, message: '商品总价值为必填项'};
  2107. }
  2108. if (this.ownerEditWorkOrder.reissue_logistic_number) {
  2109. } else if (this.ownerEditWorkOrder.refundImages.length === 0) {
  2110. return {success: false, message: '退款成功截图和补发快递单号 二选一'};
  2111. }
  2112. if (this.ownerEditWorkOrder.commodities.length === 0) {
  2113. return {success: false, message: '丢件商品为必填项'};
  2114. }
  2115. if (this.ownerEditWorkOrder.dealImages.length === 0) {
  2116. return {success: false, message: '交易截图为必填项'};
  2117. }
  2118. } else if (issue_type_name === '错漏发') {
  2119. if (is_edit) {
  2120. let change_commodities = this.ownerEditWorkOrder.commodities.filter(e => !e.tag).filter(e => !e.created).filter(e => e.abnormal_type !== '未错漏发');
  2121. let create_commodities = this.ownerEditWorkOrder.commodities.filter(e => !e.tag).filter(e => e.created).filter(e => e.abnormal_type !== '未错漏发');
  2122. if (change_commodities.length === 0 && create_commodities.length === 0) {
  2123. return {success: false, message: '商品详情为必选项,且商品不能全为未错漏发'};
  2124. }
  2125. if (this.hasReturnAddressInfo(this.ownerEditWorkOrder.commodities)) {
  2126. if (!this.ownerEditWorkOrder.return_name || !this.ownerEditWorkOrder.return_address || !this.ownerEditWorkOrder.return_phone) {
  2127. return {success: false, message: '完整填写寄件人信息'};
  2128. }
  2129. }
  2130. if (this.hasReturnLogisticNumber(this.ownerEditWorkOrder.commodities)) {
  2131. if (!this.ownerEditWorkOrder.return_logistic_number) {
  2132. return {success: false, message: '填写退回快递单号'};
  2133. }
  2134. }
  2135. let message = null
  2136. this.ownerEditWorkOrder.commodities.forEach(e=>{
  2137. if (!message){
  2138. if(this.hasStoreNumber(e) && !e.store_in_number){
  2139. message = '入库单号不能未空';
  2140. }
  2141. }
  2142. });
  2143. return {success: true};
  2144. }
  2145. if (!this.ownerEditWorkOrder.process_progress) {
  2146. return {success: false, message: '处理项不能为空'};
  2147. }
  2148. let filters = this.ownerEditWorkOrder.commodities.filter(e => {
  2149. if (e.check_result !== '核实未错漏发' && (e.process_result === '' || e.process_result_info === '')) return true;
  2150. else return e.check_result === '核实未错漏发' && e.process_result === '';
  2151. });
  2152. if (filters.length > 0) {
  2153. return {success: false, message: '商品详情中的处理项,和处理子项 未必选项'};
  2154. }
  2155. if (this.hasReturnAddressInfo(this.ownerEditWorkOrder.commodities)) {
  2156. if (!this.ownerEditWorkOrder.return_name || !this.ownerEditWorkOrder.return_address || !this.ownerEditWorkOrder.return_phone) {
  2157. return {success: false, message: '完整填写寄件人信息'};
  2158. }
  2159. }
  2160. if (this.hasReturnLogisticNumber(this.ownerEditWorkOrder.commodities)) {
  2161. if (!this.ownerEditWorkOrder.return_logistic_number) {
  2162. return {success: false, message: '填写退回快递单号'};
  2163. }
  2164. }
  2165. let message = null
  2166. this.ownerEditWorkOrder.commodities.forEach(e=>{
  2167. if (!message){
  2168. if(this.hasStoreNumber(e) && !e.store_in_number){
  2169. message = '入库单号不能未空';
  2170. }
  2171. }
  2172. });
  2173. if (!this.ownerEditWorkOrder.process_progress) {
  2174. return {success: false, message: '处理项未必填项'};
  2175. }
  2176. message = null;
  2177. this.ownerEditWorkOrder.commodities.forEach(e => {
  2178. if (message) {
  2179. } else if ('商家做出库单(物流选自提,宝时不发货)' === e.process_result_info && !e.out_order_number) {
  2180. message = '出库订单号不能为空';
  2181. } else if ('商家做入库单,选择明细和数量' === e.process_result_info && !e.store_in_amount) {
  2182. message = '入库单不能为空';
  2183. }
  2184. });
  2185. if (message) return {success: false, message: message};
  2186. } else if ('快递异常' === issue_type_name) {
  2187. if (is_edit) {
  2188. let {type, commodities, dealImages} = this.ownerEditWorkOrder;
  2189. if (commodities.length === 0) {
  2190. return {success: false, message: '快递单号不能为空'};
  2191. }
  2192. if (type === null) {
  2193. return {success: false, message: '快递异常类型不能为空'};
  2194. }
  2195. if (dealImages.length === 0) {
  2196. return {success: false, message: '交易截图不能为空'};
  2197. }
  2198. commodities = commodities.filter(e => e.selected);
  2199. if (commodities.length === 0) {
  2200. return {success: false, message: '请勾选快递单号'};
  2201. }
  2202. }
  2203. } else if ('破损' === issue_type_name) {
  2204. let {type, commodities, dealImages, packageImages, commodityImages} = this.ownerEditWorkOrder;
  2205. if (commodities.length === 0) {
  2206. return {success: false, message: '快递单号不能为空'};
  2207. }
  2208. if (type === null) {
  2209. return {success: false, message: '快递异常类型不能为空'};
  2210. }
  2211. if (packageImages.length === 0) {
  2212. return {success: false, message: '交易截图不能为空'};
  2213. }
  2214. if (commodityImages.length === 0) {
  2215. return {success: false, message: '内物破损图不能为空'};
  2216. }
  2217. if (dealImages.length === 0) {
  2218. return {success: false, message: '交易截图不能为空'};
  2219. }
  2220. commodities = commodities.filter(e => !e.tag);
  2221. if (commodities.length === 0) {
  2222. return {success: false, message: '商品详情不能为空'};
  2223. }
  2224. }
  2225. return {success: true};
  2226. },
  2227. ownerAutoComputeMistake() {
  2228. let store_in = 0, out_in = 0,noMistake = 0; // store_in 不补发 out_in 补发
  2229. this.ownerEditWorkOrder.commodities.forEach(e => {
  2230. let {process_result} = e;
  2231. if (process_result.indexOf('少发,宝时补发')>=0) out_in++;
  2232. else if (e.process_result.indexOf('多发,客户买下') >=0 ) out_in++;
  2233. else if (e.process_result.indexOf('多发,客户退回')>=0 ) store_in++;
  2234. else if (e.process_result.indexOf('少发,不补发') >=0) store_in++;
  2235. else if (e.process_result.indexOf('核实未错漏发') >= 0 ) noMistake++;
  2236. });
  2237. // 补发 不补发
  2238. let process_progress = null;
  2239. if (out_in > store_in) process_progress = '补发';
  2240. else if (out_in < store_in) process_progress = '不补发';
  2241. else if (out_in > store_in > 0 && store_in > 0 && store_in === out_in) process_progress = '补发';
  2242. else if (noMistake > 0)process_progress = '核实未错漏发';
  2243. this.ownerEditWorkOrder.process_progress = process_progress;
  2244. },
  2245. autoComputeOwnerMistake() {
  2246. let store_in = 0, out_in = 0; // store_in 不补发 out_in 补发
  2247. this.ownerEditWorkOrder.commodities.forEach(e => {
  2248. let {process_result} = e;
  2249. if (process_result.indexOf('少发,宝时补发')>=0) out_in++;
  2250. else if (e.process_result.indexOf() ) out_in++;
  2251. else if (e.process_result === '多发,客户退回') store_in++;
  2252. else if (e.process_result === '少发,不补发') out_in++;
  2253. else if (e.process_result === '核实未错漏发') store_in++;
  2254. });
  2255. // 补发 不补发
  2256. if (out_in > store_in) this.ownerEditWorkOrder.process_progress = '补发';
  2257. else if (out_in < store_in) this.ownerEditWorkOrder.process_progress = '不补发';
  2258. else this.ownerEditWorkOrder.process_progress = '不补发';
  2259. },
  2260. ownerEditWorkOrderSpliceImage(index, images = []) {
  2261. if (!confirm('是否删除当前图片')) return;
  2262. let imageitem = images.find((e, i) => Number(index) === Number(i));
  2263. if (!imageitem) return;
  2264. if (imageitem.upload_file) {
  2265. this.ownerEditWorkOrder.delete_image_ids.push(imageitem.id);
  2266. }
  2267. images.splice(index, 1);
  2268. },
  2269. ownerEditWorkOrderSpliceCommodity(i, item) {
  2270. this.ownerEditWorkOrder.delete_commodity_ids.push(item.id);
  2271. this.ownerEditWorkOrder.commodities.splice(i, 1);
  2272. },
  2273. countByCommodities(commodities) {
  2274. if (commodities.length === 0) return;
  2275. let index = 0;
  2276. let logistic_number = commodities[0]['logistic_number'];
  2277. let count = 0;
  2278. commodities.forEach((e, i, array) => {
  2279. let {cur_logistic_number} = e;
  2280. if (logistic_number === cur_logistic_number) {
  2281. count++;
  2282. } else {
  2283. array[index]['count'] = count;
  2284. index = i;
  2285. count = 1;
  2286. }
  2287. array[index]['count'] = count;
  2288. });
  2289. },
  2290. ownerComputeAbnormalType(item) {
  2291. if (this.ownerEditWorkOrder.issue_type_name !== '错漏发') return;
  2292. let abnormal_amount = Number(item.abnormal_amount); // 客户实收数量
  2293. let amount = Number(item.amount);
  2294. item.abnormal_type = abnormal_amount === amount ? '未错漏发' : (amount < abnormal_amount ? '多发' : '少发')
  2295. },
  2296. groupMistakeWorkOrder() {
  2297. let count = 0,
  2298. index = this.ownerEditWorkOrder.commodities.findIndex(e => !e.tag),
  2299. first_commodity = this.ownerEditWorkOrder.commodities.find(e => true)
  2300. let logistic_number = first_commodity ? first_commodity.logistic_number : '';
  2301. this.ownerEditWorkOrder.commodities.forEach(e => e.count = null);
  2302. this.ownerEditWorkOrder.commodities.forEach((e, i, self) => {
  2303. if (e.tag === false) {
  2304. let current_logistic_number = e.logistic_number;
  2305. if (current_logistic_number === logistic_number) {
  2306. count++;
  2307. } else {
  2308. self[index].count = count;
  2309. index = i;
  2310. count = 1;
  2311. }
  2312. self[index].count = count;
  2313. }
  2314. });
  2315. },
  2316. groupDamageWorkOrder() {
  2317. let count = 0,
  2318. index = this.ownerEditWorkOrder.commodities.findIndex(e => !e.tag),
  2319. first_commodity = this.ownerEditWorkOrder.commodities.find(e => true)
  2320. let logistic_number = first_commodity ? first_commodity.logistic_number : '';
  2321. this.ownerEditWorkOrder.commodities.forEach(e => e.count = null);
  2322. this.ownerEditWorkOrder.commodities.forEach((e, i, self) => {
  2323. if (e.tag === false) {
  2324. let current_logistic_number = e.logistic_number;
  2325. if (current_logistic_number === logistic_number) {
  2326. count++;
  2327. } else {
  2328. self[index].count = count;
  2329. index = i;
  2330. count = 1;
  2331. }
  2332. self[index].count = count;
  2333. }
  2334. });
  2335. },
  2336. ownerMistakeWorkOrderTag(item) {
  2337. item.tag = true;
  2338. },
  2339. ownerDamageWorkOrderTag(item) {
  2340. item.tag = true;
  2341. },
  2342. getProcessResult(check_result, item) {
  2343. let results = null;
  2344. if (check_result === '核实少发') {
  2345. results = ['少发,宝时补发', '少发,不补发'];
  2346. } else if (check_result === '核实多发') {
  2347. results = ['多发,客户买下', '多发,客户退回'];
  2348. } else if (check_result === '核实未错漏发') {
  2349. results = ['核实未错漏发'];
  2350. item.process_result = '核实未错漏发';
  2351. }
  2352. return results;
  2353. },
  2354. checkWorkOrderCommodityMistake(item){
  2355. if (this.hasStoreNumber(item)){
  2356. item.reissue_logistic_number = null;
  2357. item.out_order_numbere = null;
  2358. } else if (this.hasOutInNumber(item)){
  2359. item.reissue_logistic_number = null;
  2360. item.store_in_number = null;
  2361. item.store_in_amount = null;
  2362. } else if (this.hasReissueLogisticNumber(item)){
  2363. item.store_in_number = null;
  2364. item.store_in_amount = null;
  2365. item.out_order_numbere = null;
  2366. }
  2367. },
  2368. hasReturnAddressInfo(commodities) {
  2369. let filter = commodities.filter(e => (e.process_result_info ? e.process_result_info : '').indexOf('宝时上门取件') >= 0);
  2370. return filter.length > 0;
  2371. },
  2372. hasReturnLogisticNumber(commodities) {
  2373. let filter = commodities.filter(e => {
  2374. return (e.process_result_info ? e.process_result_info : '').indexOf('客户自行退回') >= 0;
  2375. });
  2376. return filter.length > 0;
  2377. },
  2378. hasOutInNumber(item) {
  2379. return (item.process_result_info ? item.process_result_info : '').indexOf('商家做出库单') >= 0;
  2380. },
  2381. hasStoreNumber(item) {
  2382. return (item.process_result_info ? item.process_result_info : '').indexOf('商家做入库单') >= 0;
  2383. },
  2384. hasReissueLogisticNumber(item) {
  2385. return (item.process_result ? item.process_result : '').indexOf('宝时补发') >= 0;
  2386. },
  2387. showWorkOrderItem(item, index) {
  2388. this.selectIndex = index;
  2389. let {details} = item;
  2390. let copy_details = JSON.parse(JSON.stringify(details));
  2391. let detail = copy_details.sort((prev, curr) => {
  2392. return new Date(prev.created_at) > new Date(curr.created_at) ? -1 : 0;
  2393. }).find(e => e);
  2394. if (!detail) {
  2395. return;
  2396. }
  2397. let {images, commodities, issue_type, price, status,reissue_logistic_number
  2398. ,return_logistic_number,return_address,return_phone,return_name,type,process_progress,remark} = detail;
  2399. this.showWorkOrder.issue_type_name = issue_type.name ? issue_type.name : '';
  2400. this.showWorkOrder.process_progress = process_progress;
  2401. this.showWorkOrder.price = price;
  2402. this.showWorkOrder.type = type;
  2403. this.showWorkOrder.remark = remark;
  2404. this.showWorkOrder.status = status;
  2405. this.showWorkOrder.reissue_logistic_number = reissue_logistic_number;
  2406. if (reissue_logistic_number){
  2407. }
  2408. this.showWorkOrder.return_address = return_address;
  2409. this.showWorkOrder.return_phone = return_phone;
  2410. this.showWorkOrder.return_name = return_name;
  2411. this.showWorkOrder.package_images = this.filterShowWorkOrder(images, '外包装图片');
  2412. this.showWorkOrder.commodity_images = this.filterShowWorkOrder(images, '内物破碎图片');
  2413. this.showWorkOrder.deal_images = this.filterShowWorkOrder(images, '交易截图');
  2414. this.showWorkOrder.refund_images = this.filterShowWorkOrder(images, '退款成功截图');
  2415. this.showWorkOrder.commodities = this.groupShowWorkOrderCommodities(commodities);
  2416. this.dialogShowOrderWorkVisible = true;
  2417. // $("#work_order_show_modal").modal('show');
  2418. },
  2419. filterShowWorkOrder(images, type) {
  2420. if (!images) return [];
  2421. return images.filter(e => e.type === type).map(e => {
  2422. e.urlExist = e.hasOwnProperty('upload_file');
  2423. let {upload_file} = e;
  2424. let {type, url} = upload_file;
  2425. e.fileUrl = this.filePrefix + `${url}.${type}`;
  2426. return e;
  2427. });
  2428. },
  2429. groupShowWorkOrderCommodity(items) {
  2430. if (items.length === 0) return [];
  2431. let commodities = JSON.parse(JSON.stringify(items));
  2432. commodities.sort((prev, curr) => prev.logistic_number > curr.logistic_number ? 1 : -1);
  2433. let index = 0, count = 0, logistic_number = commodities[0] ? commodities[0]['logistic_number'] : '';
  2434. commodities.forEach(e=>e.count = 0);
  2435. commodities.forEach((e, i, array) => {
  2436. e.commodity_name = e.commodity ? e.commodity.name : '';
  2437. let current_logistic_number = e.logistic_number;
  2438. if (current_logistic_number === logistic_number) {
  2439. count++;
  2440. } else {
  2441. logistic_number = current_logistic_number;
  2442. array[i]['count'] = count++;
  2443. index = i;
  2444. count = 1;
  2445. }
  2446. if (this.hasCommodityInfo(e)) count++;
  2447. array[index]['count'] = count;
  2448. });
  2449. return commodities;
  2450. },
  2451. hasCommodityInfo(item) {
  2452. let {reissue_logistic_number, out_order_number, store_in_number} = item;
  2453. return this.hasNumber(reissue_logistic_number) || this.hasNumber(out_order_number) || this.hasNumber(store_in_number);
  2454. },
  2455. hasNumber(number) {
  2456. return number !== null && number !== 0 && number !== '' && number !== '0';
  2457. },
  2458. groupShowWorkOrderCommodities(items) {
  2459. let copy_items = JSON.parse(JSON.stringify(items));
  2460. let item = copy_items.find(e => e);
  2461. if (!item) return [];
  2462. let {logistic_number} = item, index = 0, count = 0;
  2463. copy_items.forEach(e=>e.count = 0);
  2464. copy_items.forEach((e, i) => {
  2465. let current_logistic_number = e.logistic_number;
  2466. let add_flag = false;
  2467. if (e.reissue_logistic_number || e.out_order_number || e.store_in_number) {
  2468. add_flag = true;
  2469. }
  2470. if (current_logistic_number === logistic_number) {
  2471. count++;
  2472. if (add_flag) count++;
  2473. } else {
  2474. copy_items[index].count = count;
  2475. index = i;
  2476. count = 1;
  2477. if (add_flag) count++;
  2478. }
  2479. copy_items[index].count = count;
  2480. });
  2481. return copy_items;
  2482. },
  2483. autoComputeStoreInAmount(item) {
  2484. item.store_in_amount = Number(item.amount) - Number(item.bao_shi_check_amount);
  2485. },
  2486. },
  2487. });
  2488. </script>
  2489. @endsection