vue-detail.blade.php 45 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785
  1. @extends('layouts.base')
  2. @section('title', '中台售后详情')
  3. @section('content')
  4. <link rel="stylesheet" type="text/css" href="{{static_url('yunshop/goods/vue-goods1.css')}}"/>
  5. <style>
  6. body{font-weight:500;color:#333;}
  7. .all{background:#eff3f6}
  8. .el-form-item__label{margin-right:30px}
  9. .vue-main-form .el-form-item__content{margin-left:calc(15% + 30px) !important}
  10. .order-sum-li{width:16.66%;line-height:28px}
  11. .list-con-goods-text{min-height:70px;overflow:hidden;flex:1;display: flex;flex-direction: column;justify-content: space-between;}
  12. .list-con-goods-price{border-right:1px solid #e9e9e9;border-left:1px solid #e9e9e9;min-width:150px;min-height:90px;text-align: left;padding:20px;display: flex;flex-direction: column;}
  13. .list-con-goods-title{font-size:14px;line-height:20px;text-overflow: -o-ellipsis-lastline;overflow: hidden;text-overflow: ellipsis;display: -webkit-box;-webkit-line-clamp: 2;line-clamp: 2;-webkit-box-orient: vertical;}
  14. .list-con-goods-option{font-size:12px;color:#999}
  15. </style>
  16. <div class="all">
  17. <div id="app" v-cloak>
  18. <div class="vue-crumbs">
  19. <a>售后管理</a> > 中台售后详情
  20. </div>
  21. <el-form ref="form" :model="form" label-width="15%">
  22. <div class="vue-head">
  23. <div class="vue-main-title">
  24. <div class="vue-main-title-left"></div>
  25. <div class="vue-main-title-content">基本信息</div>
  26. </div>
  27. <div class="vue-main-form">
  28. <el-form-item label="售后编号">
  29. <div>[[orderDetail.after_sale_sn]]</div>
  30. </el-form-item>
  31. <el-form-item label="采购端编号">
  32. <div>[[orderDetail.order.third_order_sn]]</div>
  33. </el-form-item>
  34. <el-form-item label="售后金额" prop="">
  35. <div style="display:flex;width:70%">
  36. <div class="order-sum-li" >
  37. <div>子订单金额</div>
  38. <div>¥[[orderDetail.amount]]</div>
  39. </div>
  40. <div class="order-sum-li">
  41. <div>申请售后金额</div>
  42. <div style="color:red;font-weight:600">¥[[orderDetail.amount]]</div>
  43. </div>
  44. <div class="order-sum-li" v-if="orderDetail.status == 4">
  45. <div>实际退回金额</div>
  46. <div style="color:red;font-weight:600">¥[[orderDetail.practical_amount]]</div>
  47. </div>
  48. </div>
  49. </el-form-item>
  50. <el-form-item label="售后类型" prop="">
  51. <div style="display:inline-block;margin-right:20px">[[orderDetail.after_sale_type_name]]</div>
  52. </el-form-item>
  53. <el-form-item label="是否收到货" prop="">
  54. <div style="display:inline-block;margin-right:20px">[[orderDetail.is_received_name]]</div>
  55. </el-form-item>
  56. <el-form-item label="售后原因" prop="">
  57. <div style="display:inline-block;margin-right:20px" v-if="orderDetail.reason">[[orderDetail.refund_reason_name]][[orderDetail.reason]]</div>
  58. <div style="display:inline-block;margin-right:20px" v-else>[[orderDetail.refund_reason_name]]</div>
  59. </el-form-item>
  60. <el-form-item label="售后描述" prop="">
  61. <div>[[orderDetail.description]]</div>
  62. </el-form-item>
  63. <el-form-item label="售后状态" prop="">
  64. <div style="display:inline-block;margin-right:20px">[[orderDetail.after_sale_name_show]]</div>
  65. <el-button size="small" plain type="primary" @click="confirmSend(orderDetail.order.id,orderDetail)" v-if="orderDetail.self_order_id>0 && orderDetail.status==1">确认发货</el-button>
  66. <el-button size="small" plain type="primary" v-if="orderDetail.self_order_id>0 && orderDetail.status == 0 && orderDetail.after_sales_audit.status == 0" @click="cancelOrder(orderDetail.id)" >取消申请</el-button>
  67. <el-button size="small" plain type="primary" v-if="orderDetail.self_order_id>0 && orderDetail.status == 0 && orderDetail.after_sales_audit.status == 0" @click="updateOrder(orderDetail.id)">修改申请</el-button>
  68. <el-button size="small" plain type="primary" v-if="orderDetail.self_order_id>0 && ((orderDetail.status == 0 && orderDetail.after_sales_audit.status == -1) || orderDetail.status == -1)" @click="reapplyOrder()" >重新申请</el-button>
  69. </el-form-item>
  70. <el-form-item label="协商记录" prop="">
  71. <a style="color:#29BA9C;" @click="order_refund_process_log_show = true">查看</a>
  72. </el-form-item>
  73. </div>
  74. </div>
  75. <div v-if="orderDetail.return_order_express.id != 0" class="vue-head">
  76. <div class="vue-main-title">
  77. <div class="vue-main-title-left"></div>
  78. <div class="vue-main-title-content">发货信息</div>
  79. </div>
  80. <div class="vue-main-form">
  81. <el-form-item label="物流公司编码" prop="">
  82. <div>[[orderDetail.return_order_express.company_code]]</div>
  83. </el-form-item>
  84. <el-form-item label="物流公司名称" prop="">
  85. <div>[[orderDetail.return_order_express.company_name]]</div>
  86. </el-form-item>
  87. <el-form-item label="快递单号" prop="">
  88. <div>[[orderDetail.return_order_express.express_no]]</div>
  89. </el-form-item>
  90. <!-- 物流信息 -->
  91. <div v-if="orderDetail.order_express != null && orderDetail.order_express.length > 0">
  92. <el-form-item label="物流信息" prop="">
  93. <el-button size="small" type="primary" @click="showDispatchInfo()">查看</el-button>
  94. </el-form-item>
  95. </div>
  96. </div>
  97. </div>
  98. <!-- 商品信息 -->
  99. <div v-if="orderDetail.order_items" class="vue-head">
  100. <div class="vue-main-title">
  101. <div class="vue-main-title-left"></div>
  102. <div class="vue-main-title-content">商品信息</div>
  103. </div>
  104. <div class="vue-main-form">
  105. <el-table :data="orderDetail.order_items" style="width: 100%">
  106. <el-table-column prop="" label="商品" width="60" align="center">
  107. <template slot-scope="scope">
  108. <img :src="scope.row.image_url" style="width:50px;height:50px;">
  109. </template>
  110. </el-table-column>
  111. <el-table-column prop="down_time" label="" min-width="180" align="left">
  112. <template slot-scope="scope">
  113. <!-- style="color:#29BA9C;cursor: pointer;"
  114. @click=" gotoGoods(scope.row.goods_id) "> -->
  115. <div class="list-con-goods-title">
  116. [[scope.row.title]]
  117. </div>
  118. <div class="list-con-goods-option">规格: [[scope.row.sku_title]]</div>
  119. <!-- </div> -->
  120. </template>
  121. </el-table-column>
  122. <el-table-column prop="down_time" label="商品价格" min-width="230" align="center">
  123. <template slot-scope="scope">
  124. <div>
  125. <div style="display:flex;justify-content: center;">
  126. <div style="flex:1;text-align:right">价格:</div>
  127. <div style="flex:1;text-align:left">¥[[scope.row.amount]]</div>
  128. </div>
  129. </div>
  130. </template>
  131. </el-table-column>
  132. </el-table>
  133. </div>
  134. </div>
  135. {{-- <div v-if="orderDetail.logs" class="vue-head">--}}
  136. {{-- <div class="vue-main-title">--}}
  137. {{-- <div class="vue-main-title-left"></div>--}}
  138. {{-- <div class="vue-main-title-content">协商日志</div>--}}
  139. {{-- </div>--}}
  140. {{-- <div class="vue-main-form">--}}
  141. {{-- <el-form-item label="" v-for="(item,index) in orderDetail.logs">--}}
  142. {{-- <div class="list-con-goods-title" v-if="item.admin_id != 0">--}}
  143. {{-- 商家--}}
  144. {{-- </div>--}}
  145. {{-- <div class="list-con-goods-title" v-else>--}}
  146. {{-- 用户--}}
  147. {{-- </div>--}}
  148. {{-- <div class="list-con-goods-option">[[item.content]]</div>--}}
  149. {{-- </el-form-item>--}}
  150. {{-- </div>--}}
  151. {{-- </div>--}}
  152. </el-form>
  153. <!-- 查看商品 -->
  154. <el-dialog :visible.sync="get_goods_show" width="750px" title="商品列表">
  155. <div id="separate-send">
  156. <el-table ref="multipleTable1" :data="get_goods_list" tooltip-effect="dark" height="550" style="width: 100%">
  157. <el-table-column width="550">
  158. <template slot-scope="scope">
  159. <div style="display:flex;width: 88%;">
  160. <div style="width:50px;height:50px">
  161. <img :src="scope.row.image_url" alt="" style="width:50px;height:50px">
  162. </div>
  163. <div style="margin-left:20px;display: flex;flex-direction: column;justify-content: space-between;">
  164. <div style="white-space: nowrap;overflow: hidden;text-overflow: ellipsis;">[[scope.row.title]]</div>
  165. <div style="color:#999">[[scope.row.product_id]]</div>
  166. </div>
  167. </div>
  168. </template>
  169. </el-table-column>
  170. <el-table-column>
  171. <template slot-scope="scope">
  172. <div style="color:#999">[[scope.row.sku_title]]</div>
  173. </template>
  174. </el-table-column>
  175. </el-table>
  176. </div>
  177. <span slot="footer" class="dialog-footer">
  178. <el-button @click="get_goods_show = false">取 消</el-button>
  179. </span>
  180. </el-dialog>
  181. <!-- 查看订单协商记录 -->
  182. <el-dialog :visible.sync="order_refund_process_log_show" center width="700px" title="协商记录">
  183. <div style="height:380px;overflow:auto">
  184. <div v-for="(refundLog, log1) in orderDetail.logs">
  185. <div style="background-color: #f9f9f9;border-radius:5px;margin-bottom: 10px">
  186. <div style="padding:20px">
  187. <div style="float:right">[[refundLog.created_at]]</div>
  188. <div v-if="refundLog.admin_id != 0">
  189. 商家
  190. </div>
  191. <div v-else>
  192. 用户
  193. </div>
  194. </div>
  195. <div style="border-bottom:1px solid #e9e9e9;;clear: both;"></div>
  196. <div style="padding:15px 20px">
  197. <div >[[refundLog.content]]</div>
  198. </div>
  199. </div>
  200. </div>
  201. {{-- <el-form-item label="" v-for="(item,index) in orderDetail.logs">--}}
  202. {{-- <div class="list-con-goods-title" v-if="item.admin_id != 0">--}}
  203. {{-- 商家--}}
  204. {{-- </div>--}}
  205. {{-- <div class="list-con-goods-title" v-else>--}}
  206. {{-- 用户--}}
  207. {{-- </div>--}}
  208. {{-- <div class="list-con-goods-option">[[item.content]]</div>--}}
  209. {{-- </el-form-item>--}}
  210. {{--orderDetail.refund_process_log--}}
  211. </div>
  212. <span slot="footer" class="dialog-footer">
  213. <el-button @click="order_refund_process_log_show = false">取 消</el-button>
  214. </span>
  215. </el-dialog>
  216. <!-- 查看物流信息 -->
  217. <el-dialog :visible.sync="modal_dispatch_info" width="750px" center title="物流信息">
  218. <div style="height:400px;overflow:auto" id="dispatch-info">
  219. <!-- 多包裹 -->
  220. <div>
  221. <div style="display:flex;margin-bottom:15px;" v-for="(item3,index3) in dispatch">
  222. <div class="left" style="width:105px;margin-right:30px;text-align:right">
  223. 包裹[[index3 + 1]]信息
  224. </div>
  225. <div class="right" style="flex:1" v-if="item3.order_items.length>0">
  226. <div>
  227. <div class="wl-img" style="width:70px;height:70px;position:relative;">
  228. <img :src="item3.order_items[0].image_url" style="width:100%;height:100%">
  229. <div style="line-height:18px;background:RGB(17, 9, 5,0.7);color:#fff;position:absolute;bottom:0;width:100%;text-align:center">
  230. {{-- 共[[item3.count]]件--}}
  231. </div>
  232. <div @click="getGoodDetail(item3.order_items)" style="position:absolute;bottom:0;right:-80px;cursor: pointer;color:#ff9b19 ">
  233. 查看商品
  234. </div>
  235. </div>
  236. <div style="padding:5px 0" v-if="item3.company_name">公司:[[item3.company_name]]</div>
  237. <div style="padding:5px 0" v-if="item3.express_no">运单号:[[item3.express_no]]</div>
  238. <div style="padding:5px 0" v-if="item3.express_no == '' ">无物流</div>
  239. <template v-if="item3.list != null">
  240. <div style="padding:5px 0" v-for="(d1, k2) in item3.list" :key="k2">[[d1.time]] [[d1.status]]</div>
  241. </template>
  242. {{--<div style="padding:5px 0">[2020-12-12 09:12:23] 物流信息更新物流信息更新物流信息更新物流信息更新物流信息更新物流信息更新</div>--}}
  243. {{--<div style="padding:5px 0">[2020-12-12 09:12:23] 物流信息更新物流信息更新物流信息更新物流信息更新物流信息更新物流信息更新</div>--}}
  244. {{--<div style="padding:5px 0">[2020-12-12 09:12:23] 物流信息更新物流信息更新物流信息更新物流信息更新物流信息更新物流信息更新</div>--}}
  245. </div>
  246. </div>
  247. </div>
  248. </div>
  249. </div>
  250. <span slot="footer" class="dialog-footer">
  251. <el-button @click="modal_dispatch_info = false">关 闭</el-button>
  252. {{--<el-button type="primary" @click="confirmRefundReject()">确 认</el-button>--}}
  253. </span>
  254. </el-dialog>
  255. <!-- 确认发货 -->
  256. <!-- 确认发货 -->
  257. <el-dialog :visible.sync="confirm_send_show" width="750px" title="确认发货">
  258. <div style="height:400px;overflow:auto" id="confirm-send">
  259. <el-form ref="send" :model="send" :rules="send_rules" label-width="15%">
  260. <el-form-item label="收件人信息" prop="aggregation">
  261. <div>收 件 人: [[address_info.contacts]] / [[address_info.tel]]</div>
  262. <div>收货地址: [[address_info.province_name.name]][[address_info.city_name.name]][[address_info.district_name.name]][[address_info.address]]</div>
  263. </el-form-item>
  264. <div>
  265. <el-form-item label="快递公司">
  266. <el-select v-model="send.express_code" clearable filterable placeholder="快递公司" :disabled='readonly' style="width:70%;">
  267. <el-option label="请选择快递" value=""></el-option>
  268. <el-option v-for="(item,index) in expressCompanies" :key="index" :label="item.name" :value="item.code"></el-option>
  269. </el-select>
  270. </el-form-item>
  271. <el-form-item label="快递单号" prop="">
  272. <el-input v-model="send.express_sn" :disabled='readonly' style="width:70%;"></el-input>
  273. </el-form-item>
  274. </div>
  275. <el-table ref="multipleTable" :data="order_goods_send_list" tooltip-effect="dark" height="250" style="width: 100%" >
  276. {{-- <el-table-column type="selection" width="55"></el-table-column>--}}
  277. <el-table-column width="550">
  278. <template slot-scope="scope">
  279. <div style="display:flex;width: 88%;">
  280. <div style="width:50px;height:50px">
  281. <img :src="scope.row.image_url" alt="" style="width:50px;height:50px">
  282. </div>
  283. <div style="margin-left:20px;display: flex;flex-direction: column;justify-content: space-between;">
  284. <div style="white-space: nowrap;overflow: hidden;text-overflow: ellipsis;">[[scope.row.title]]</div>
  285. <div style="color:#999">[[scope.row.product_id]]</div>
  286. </div>
  287. </div>
  288. </template>
  289. </el-table-column>
  290. <el-table-column>
  291. <template slot-scope="scope">
  292. <div style="color:#999">[[scope.row.sku_title]]</div>
  293. </template>
  294. </el-table-column>
  295. </el-table>
  296. </el-form>
  297. </div>
  298. <span slot="footer" class="dialog-footer">
  299. <el-button @click="confirm_send_show = false">取 消</el-button>
  300. <el-button type="primary" @click="sureconfirmSend()">确认发货 </el-button>
  301. </span>
  302. </el-dialog>
  303. <el-dialog :visible.sync="reapply_refund_show" width="650px" title="重新申请">
  304. <el-form ref="refund_pass_form" :model="reapply_refund_form">
  305. <div v-if="reapply_refund_form.order_goods[reapply_refund_form_k]" class="vue-head">
  306. <div class="vue-main-title">
  307. <div class="vue-main-title-left"></div>
  308. <div class="vue-main-title-content">商品信息(仅为中台的商品信息)</div>
  309. </div>
  310. <div class="vue-main-form">
  311. <el-table :data="reapply_refund_form.order_goods[reapply_refund_form_k]" style="width: 100%">
  312. <el-table-column prop="product_id" label="商品ID" width="100" align="center"></el-table-column>
  313. <el-table-column prop="" label="商品" width="60" align="center">
  314. <template slot-scope="scope">
  315. <img :src="scope.row.image_url" style="width:50px;height:50px;">
  316. </template>
  317. </el-table-column>
  318. <el-table-column prop="down_time" label="" min-width="180" align="left">
  319. <template slot-scope="scope">
  320. <div class="list-con-goods-title"
  321. style="color:#29BA9C;cursor: pointer;"
  322. @click="gotoGoods(scope.row.goods_id)">
  323. [[scope.row.title]]
  324. </div>
  325. <div class="list-con-goods-option">规格: [[scope.row.goods_option_title]]</div>
  326. <div class="list-con-goods-option">数量: [[scope.row.total]]</div>
  327. </template>
  328. </el-table-column>
  329. <el-table-column prop="down_time" label="商品价格" min-width="230" align="center">
  330. <template slot-scope="scope">
  331. <div>
  332. <div style="display:flex;justify-content: center;">
  333. <div style="flex:1;text-align:right">价格:</div>
  334. <div style="flex:1;text-align:left">¥[[scope.row.amount]]</div>
  335. </div>
  336. </div>
  337. </template>
  338. </el-table-column>
  339. </el-table>
  340. </div>
  341. </div>
  342. <el-form-item label="服务类型" prop="refund_type">
  343. <el-radio v-for="(item,value) in reapply_refund_form.after_sales_type[reapply_refund_form_k]" v-model.number="reapply_refund_form.refund_type[reapply_refund_form_k]" :label="value">[[item]]</el-radio>
  344. </el-form-item>
  345. <el-form-item label="换货商品规格" prop="barter_sku_id" v-if="reapply_refund_form.refund_type[reapply_refund_form_k] == 2">
  346. <el-radio v-for="(item,value) in reapply_refund_form.after_sales_goods_options[reapply_refund_form_k]" v-model.number="reapply_refund_form.barter_sku_id[reapply_refund_form_k]" :label="item.id">[[item.title]]</el-radio>
  347. </el-form-item>
  348. <el-form-item label="" prop="refund_type" v-if="reapply_refund_form.refund_type[reapply_refund_form_k] == 2">
  349. 换货商品数量:
  350. <el-input v-model="reapply_refund_form.barter_num[reapply_refund_form_k]" placeholder="换货商品数量"></el-input>
  351. </el-form-item>
  352. <el-form-item label="货物状态" prop="is_received" v-if="reapply_refund_form.refund_type[reapply_refund_form_k] != 2">
  353. <el-radio v-model.number="reapply_refund_form.is_received[reapply_refund_form_k]" :label="1">已收到货</el-radio>
  354. <el-radio v-model.number="reapply_refund_form.is_received[reapply_refund_form_k]" :label="0">未收到货</el-radio>
  355. </el-form-item>
  356. <el-form-item label="" v-if="reapply_refund_form.refund_type[reapply_refund_form_k] != 2">
  357. 申请原因:
  358. <el-input v-model="reapply_refund_form.reason[reapply_refund_form_k]" :rows="3" type="textarea"></el-input>
  359. </el-form-item>
  360. <el-form-item label="退款方式" prop="refund_way" v-if="reapply_refund_form.refund_type[reapply_refund_form_k] != 2">
  361. <el-radio v-model.number="reapply_refund_form.refund_way[reapply_refund_form_k]" :label="0">自定义金额</el-radio>
  362. <el-radio v-model.number="reapply_refund_form.refund_way[reapply_refund_form_k]" :label="1">商品个数</el-radio>
  363. </el-form-item>
  364. <el-form-item label="" v-if="reapply_refund_form.refund_type[reapply_refund_form_k] != 2 && reapply_refund_form.refund_way[reapply_refund_form_k] == 0">
  365. 退款金额:
  366. <el-input v-model="reapply_refund_form.amount[reapply_refund_form_k]" placeholder="退款金额"></el-input>
  367. </el-form-item>
  368. <el-form-item label="" v-if="reapply_refund_form.refund_type[reapply_refund_form_k] != 2 && reapply_refund_form.refund_way[reapply_refund_form_k] == 1">
  369. 退款商品个数:
  370. <el-input v-model="reapply_refund_form.num[reapply_refund_form_k]" placeholder="退款商品个数"></el-input>
  371. </el-form-item>
  372. <el-form-item label="" v-if="reapply_refund_form.refund_type[reapply_refund_form_k] != 2 ">
  373. 退款运费金额:
  374. <el-input v-model="reapply_refund_form.freight[reapply_refund_form_k]" placeholder="退款金额"></el-input>
  375. </el-form-item>
  376. <el-form-item label="" v-if="reapply_refund_form.refund_type[reapply_refund_form_k] != 2">
  377. 退款技术服务费金额:
  378. <el-input v-model="reapply_refund_form.technical_services_fee[reapply_refund_form_k]" max="" placeholder="退款金额"></el-input>
  379. </el-form-item>
  380. <el-form-item label="">
  381. <span v-if="reapply_refund_form.refund_type[reapply_refund_form_k] != 2">
  382. 退款说明:
  383. </span>
  384. <span v-else>
  385. 换货说明:
  386. </span>
  387. <el-input v-model="reapply_refund_form.description[reapply_refund_form_k]" :rows="3" type="textarea"></el-input>
  388. </el-form-item>
  389. </el-form>
  390. <span slot="footer" class="dialog-footer">
  391. <el-button @click="reapply_refund_show = false">取 消</el-button>
  392. <el-button type="primary" @click="confirmReapplyRefund()">确 认</el-button>
  393. </span>
  394. </el-dialog>
  395. </div>
  396. </div>
  397. </div>
  398. <script>
  399. var app = new Vue({
  400. el:"#app",
  401. delimiters: ['[[', ']]'],
  402. name: 'test',
  403. data() {
  404. return{
  405. //重新申请/修改申请
  406. confirm_reapply_refund_url:'',//请求链接
  407. confirm_reapply_refund_confirm:'',//提示语
  408. reapply_refund_form_k:0,
  409. reapply_refund_form_count:[],
  410. reapply_refund_form:{
  411. order_id:[],
  412. order_item_id:[],
  413. amount:[],
  414. reason_type:[],
  415. reason:[],
  416. description:[],
  417. is_received:[],
  418. detail_images:[],
  419. refund_type:[],
  420. order_goods:[],
  421. third_order_sn:[],
  422. is_syn:[],
  423. after_sales_type:[],
  424. freight:[],
  425. technical_services_fee:[],
  426. barter_sku_id:[],
  427. barter_num:[],
  428. refund_way:[],
  429. num:[],
  430. after_sales_goods_options:[],
  431. },
  432. reapply_refund_show:false,//同步中台售后弹窗
  433. order_refund_process_log_show:false,
  434. is_pdf:false,
  435. street: '{!! \Setting::get("shop.trade")['is_street'] !!}',
  436. id:0,
  437. middleground_configuration_id:0,
  438. getDataUrl: '{!! yzWebFullUrl('plugin.yz-supply.admin.refund.detail-data') !!}',//获取售后数据链接
  439. order_id:0,
  440. orderDetail:{
  441. order:{},
  442. },
  443. amount_detail:[],//金额数组
  444. user:[],//用户信息
  445. shipping_address:[],//收货人信息
  446. readonly:false,
  447. dispatch:{}, //订单物流信息
  448. logistics:{},//物流详情
  449. modal_dispatch_info: false,
  450. form:{
  451. },
  452. loading: false,
  453. cancel_send_show:false,// 取消发货弹窗
  454. cancel_send_con:"",//取消发货原因
  455. cancel_send_id:'',
  456. confirm_send_show:false,// 确认发货弹窗
  457. confirm_send_id:"",
  458. send:{
  459. dispatch_type_id:1,
  460. express_code:"",
  461. express_sn:"",
  462. order_sn:"",
  463. },
  464. send_rules:{},
  465. address_info:{
  466. province_name:{},
  467. city_name:{},
  468. district_name:{},
  469. },
  470. expressCompanies:[],//快递公司
  471. // 多包裹发货
  472. more_send_show:false,
  473. order_goods_send_list:[],
  474. send_order_goods_ids:[],
  475. // 查看商品
  476. get_goods_show:false,
  477. get_goods_list:[],
  478. }
  479. },
  480. created() {
  481. let result = this.viewReturn();
  482. this.__initial(result);
  483. },
  484. mounted() {
  485. if(this.id) {
  486. this.getData();
  487. }
  488. },
  489. methods: {
  490. //视图返回数据
  491. viewReturn() {
  492. return {!! $data?:'{}' !!};
  493. },
  494. //初始化页面数据,请求链接
  495. __initial(data) {
  496. if (data.id) {
  497. this.id = data.id;
  498. }
  499. if (data.middleground_configuration_id) {
  500. this.middleground_configuration_id = data.middleground_configuration_id;
  501. }
  502. },
  503. getData() {
  504. let loading = this.$loading({target:document.querySelector(".content"),background: 'rgba(0, 0, 0, 0)'});
  505. this.$http.post(this.getDataUrl,{id:this.id,middleground_configuration_id:this.middleground_configuration_id }).then(function (response) {
  506. if (response.data.result){
  507. this.orderDetail = response.data.data;
  508. // this.amount_detail = response.data.data.order.amount_detail;
  509. // this.user = response.data.data.order.user;
  510. // this.shipping_address = response.data.data.order.shipping_address;
  511. //
  512. // this.order_id = response.data.data.order.id;
  513. // this.dispatch = response.data.data.order.order_express;
  514. // this.logistics = response.data.data.order.logistics;
  515. loading.close();
  516. } else {
  517. this.$message({message: response.data.msg,type: 'error'});
  518. }
  519. loading.close();
  520. },function (response) {
  521. this.$message({message: response.data.msg,type: 'error'});
  522. loading.close();
  523. }
  524. );
  525. },
  526. checkSelectable(item){
  527. // console.log(item);
  528. return item.send_status == 0;
  529. },
  530. //重新申请售后
  531. reapplyOrder(){
  532. this.confirm_reapply_refund_confirm = "确认重新申请(如果已关闭重新申请会新生成一个记录)?";
  533. this.confirm_reapply_refund_url = '{!! yzWebFullUrl('plugin.yz-supply.admin.refund.refund') !!}';
  534. this.reapplyRefundFormData();
  535. },
  536. reapplyRefundFormData(){
  537. this.reapply_refund_show = true;
  538. this.reapply_refund_form.order_item_id[0] = this.orderDetail.order_items[0].id;
  539. this.reapply_refund_form.order_id[0] = this.orderDetail.order.id;
  540. this.reapply_refund_form.amount[0] = this.orderDetail.amount;
  541. this.reapply_refund_form.reason_type[0] = this.orderDetail.reason_type;
  542. this.reapply_refund_form.reason[0] = this.orderDetail.reason;
  543. this.reapply_refund_form.description[0] = this.orderDetail.description;
  544. this.reapply_refund_form.is_received[0] = this.orderDetail.is_received;
  545. this.reapply_refund_form.detail_images[0] = this.orderDetail.detail_images;
  546. this.reapply_refund_form.refund_type[0] = this.orderDetail.type;
  547. this.reapply_refund_form.order_goods[0] = this.orderDetail.order_items;
  548. this.reapply_refund_form.third_order_sn[0] = this.orderDetail.order.third_order_sn;
  549. this.reapply_refund_form.is_syn[0] = 1;
  550. this.reapply_refund_form.middleground_configuration_id = this.middleground_configuration_id
  551. this.reapply_refund_form.freight[0] = (item.freight/100).toFixed(2);
  552. this.reapply_refund_form.technical_services_fee[0] = (item.technical_services_fee/100).toFixed(2);
  553. this.reapply_refund_form.barter_sku_id[0] = item.barter_sku_id;
  554. this.reapply_refund_form.barter_num[0] = item.barter_num;
  555. this.reapply_refund_form.refund_way[0] = item.refund_way;
  556. this.reapply_refund_form.num[0] = item.num;
  557. },
  558. /**
  559. * 修改申请
  560. */
  561. updateOrder(){
  562. item = this.orderDetail
  563. this.reapply_refund_form.after_sales_id = this.orderDetail.id;
  564. this.confirm_reapply_refund_confirm = "确认修改申请?";
  565. this.confirm_reapply_refund_url = '{!! yzWebFullUrl('plugin.yz-supply.admin.refund.refund-update') !!}';
  566. this.get_reapply_refund_type = '{!! yzWebFullUrl('plugin.yz-supply.admin.refund.get-reapply-refund-type') !!}';
  567. let loading = this.$loading({target:document.querySelector(".content"),background: 'rgba(0, 0, 0, 0)'});
  568. this.$http.post(this.get_reapply_refund_type,{'yz_goods_id':item.order_item.product_id,middleground_configuration_id:this.middleground_configuration_id,order_id :item['order_id']}).then(function (response) {
  569. if (response.data.result) {
  570. this.reapply_refund_show = false;
  571. this.reapply_refund_form.after_sales_type[0] = response.data.data.after_sales_type;
  572. this.reapply_refund_form.after_sales_goods_options[0] = response.data.data.after_sales_goods_options;
  573. this.reapplyRefundFormData();
  574. }
  575. else{
  576. this.$message({type: 'error',message: response.data.msg});
  577. }
  578. loading.close();
  579. },function (response) {
  580. this.$message({type: 'error',message: response.data.msg});
  581. loading.close();
  582. }
  583. );
  584. },
  585. //申请售后到中台
  586. confirmReapplyRefund(){
  587. var middleground_refund_form = this.reapply_refund_form
  588. this.$confirm( this.confirm_reapply_refund_confirm, '提示', {confirmButtonText: '确定',cancelButtonText: '取消',type: 'warning'}).then(() => {
  589. let loading = this.$loading({target:document.querySelector(".content"),background: 'rgba(0, 0, 0, 0)'});
  590. this.$http.post(this.confirm_reapply_refund_url,{middleground_refund_form:middleground_refund_form}).then(function (response) {
  591. if (response.data.result) {
  592. this.reapply_refund_show = false;
  593. this.$message({type: 'success',message: '成功!'});
  594. this.getData(this.current_page)
  595. }
  596. else{
  597. this.$message({type: 'error',message: response.data.msg});
  598. }
  599. loading.close();
  600. },function (response) {
  601. this.$message({type: 'error',message: response.data.msg});
  602. loading.close();
  603. }
  604. );
  605. }).catch(() => {
  606. this.$message({type: 'info',message: '已取消'});
  607. });
  608. },
  609. //取消中台售后申请
  610. cancelOrder(id){
  611. this.$confirm('确认取消申请?', '提示', {confirmButtonText: '确定',cancelButtonText: '取消',type: 'warning'}).then(() => {
  612. let loading = this.$loading({target:document.querySelector(".content"),background: 'rgba(0, 0, 0, 0)'});
  613. this.$http.post('{!! yzWebFullUrl('plugin.yz-supply.admin.refund.after-sales-close') !!}',{middleground_configuration_id:this.middleground_configuration_id,after_sales_id:id}).then(function (response) {
  614. if (response.data.result) {
  615. this.reapply_refund_show = false;
  616. this.$message({type: 'success',message: '成功!'});
  617. this.getData(this.current_page)
  618. }
  619. else{
  620. this.$message({type: 'error',message: response.data.msg});
  621. }
  622. loading.close();
  623. },function (response) {
  624. this.$message({type: 'error',message: response.data.msg});
  625. loading.close();
  626. }
  627. );
  628. }).catch(() => {
  629. this.$message({type: 'info',message: '已取消'});
  630. });
  631. },
  632. // 确认发货
  633. confirmSend(id,item) {
  634. console.log(this.middleground_configuration_id);
  635. let json = {
  636. order_id:id,
  637. middleground_configuration_id:this.middleground_configuration_id
  638. };
  639. let loading = this.$loading({target:document.querySelector(".content"),background: 'rgba(0, 0, 0, 0)'});
  640. this.$http.post('{!! yzWebFullUrl('plugin.yz-supply.admin.refund.get-send-data') !!}',json).then(function(response) {
  641. loading.close();
  642. // console.log(response.data);
  643. if (response.data.result) {
  644. this.confirm_send_show = true;
  645. this.confirm_send_con = "";
  646. this.send = {
  647. express_code:"",
  648. express_sn:"",
  649. after_sales_id:item.id,
  650. shipping_address_id:response.data.data.address.id,
  651. }
  652. this.address_info = response.data.data.address || {};
  653. this.order_goods_send_list[0] = item.order_item;
  654. this.expressCompanies = response.data.data.express;
  655. // console.log(this.expressCompanies);
  656. } else {
  657. this.$message({
  658. message: response.data.msg,
  659. type: 'error'
  660. });
  661. }
  662. }, function(response) {
  663. this.$message({
  664. message: response.data.msg,
  665. type: 'error'
  666. });
  667. loading.close();
  668. });
  669. },
  670. sureconfirmSend(){
  671. for (i in this.expressCompanies){
  672. if(this.expressCompanies[i].code == this.send.express_code){
  673. this.send.express_name = this.expressCompanies[i].name;
  674. break;
  675. }
  676. }
  677. let json = {
  678. after_sales_id :this.send.after_sales_id,
  679. express_code:this.send.express_code,
  680. express_company_name:this.send.express_name,
  681. express_sn:this.send.express_sn,
  682. shipping_address_id:this.send.shipping_address_id,
  683. middleground_configuration_id:this.middleground_configuration_id
  684. };
  685. let loading = this.$loading({target:document.querySelector(".content"),background: 'rgba(0, 0, 0, 0)'});
  686. this.$http.post('{!! yzWebFullUrl('plugin.yz-supply.admin.refund.send') !!}',json).then(function(response) {
  687. if (response.data.result) {
  688. this.$message({
  689. message: '发货成功',
  690. type: 'success'
  691. });
  692. this.confirm_send_show = false;
  693. this.getData(this.current_page);
  694. } else {
  695. this.$message({
  696. message: response.data.msg,
  697. type: 'error'
  698. });
  699. }
  700. loading.close();
  701. }, function(response) {
  702. this.$message({
  703. message: response.data.msg,
  704. type: 'error'
  705. });
  706. loading.close();
  707. });
  708. },
  709. //查看物流信息
  710. showDispatchInfo() {
  711. this.modal_dispatch_info = true;
  712. },
  713. gotoGoods(id) {
  714. window.open(`{!! yzWebFullUrl('goods.goods.edit') !!}`+`&id=`+id);
  715. {{--window.location.href = `{!! yzWebFullUrl('goods.goods.edit') !!}`+`&id=`+id;--}}
  716. },
  717. goBack() {
  718. history.go(-1)
  719. },
  720. },
  721. })
  722. </script>
  723. @endsection