index.vue 73 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405140614071408140914101411141214131414141514161417141814191420142114221423142414251426142714281429143014311432143314341435143614371438143914401441144214431444144514461447144814491450145114521453145414551456145714581459146014611462146314641465146614671468146914701471147214731474147514761477147814791480148114821483148414851486148714881489149014911492149314941495149614971498149915001501150215031504150515061507150815091510151115121513151415151516151715181519152015211522152315241525152615271528152915301531153215331534153515361537153815391540154115421543154415451546154715481549155015511552155315541555155615571558155915601561156215631564156515661567156815691570157115721573157415751576157715781579158015811582158315841585158615871588158915901591159215931594159515961597159815991600160116021603160416051606160716081609161016111612161316141615161616171618161916201621162216231624162516261627162816291630163116321633163416351636163716381639164016411642164316441645164616471648164916501651165216531654165516561657165816591660166116621663166416651666166716681669167016711672167316741675167616771678167916801681168216831684168516861687168816891690169116921693169416951696169716981699170017011702170317041705170617071708170917101711171217131714171517161717171817191720172117221723172417251726172717281729173017311732173317341735173617371738173917401741174217431744174517461747174817491750175117521753175417551756175717581759176017611762176317641765176617671768176917701771177217731774177517761777177817791780178117821783178417851786178717881789179017911792179317941795179617971798179918001801180218031804180518061807180818091810181118121813181418151816181718181819182018211822182318241825182618271828182918301831183218331834183518361837183818391840184118421843184418451846184718481849185018511852185318541855185618571858185918601861186218631864186518661867186818691870187118721873187418751876187718781879188018811882188318841885188618871888188918901891189218931894189518961897189818991900190119021903190419051906190719081909191019111912191319141915191619171918191919201921192219231924192519261927192819291930193119321933193419351936193719381939194019411942194319441945194619471948194919501951195219531954195519561957
  1. <template>
  2. <div class="app-container">
  3. <el-page-header @back="goBack" content="订单详情"></el-page-header>
  4. <div class="order-main">
  5. <el-row style="padding: 15px 15px 10px">
  6. <el-col :span="24">
  7. <div class="order-main-title">
  8. <span>订单编号:{{ orderDetail.orderId }}</span>
  9. <span>下单时间:{{ orderDetail.createTime }}</span>
  10. <span>商户:{{ orderDetail.companyWechatName || '无' }}</span>
  11. <!-- <span>网点:{{ orderDetail.websitName || '无' }}</span> -->
  12. <el-tag v-if="orderDetail.isOld == 'YES'">以旧换新</el-tag>
  13. <div class="fr">
  14. <el-link type="primary" :underline="false" @click="showDialog('remark')">订单备注</el-link>
  15. </div>
  16. </div>
  17. </el-col>
  18. </el-row>
  19. <div style="width: 100%; padding: 10px 15px 15px 15px">
  20. <el-row>
  21. <el-col :span="10">
  22. <div style="display: flex">
  23. <div>
  24. <div class="order-main-status">
  25. <span>{{ orderDetail.orderStatus | ORDER_CURRENT_STATUS_FILTER }}</span>
  26. </div>
  27. <div class="order-main-opt-btn">
  28. <template v-if="orderDetail.orderStatus === 'NOPAY'">
  29. <el-popconfirm
  30. v-if="!['WECHAT'].includes(orderDetail.payTypeId)"
  31. title="确定收款吗?"
  32. @confirm="confirmOrder"
  33. >
  34. <el-button slot="reference" size="small">确认收款</el-button>
  35. </el-popconfirm>
  36. <el-button size="small" @click="showDialog('price')" style="margin-left: 10px">修改价格</el-button>
  37. <el-popconfirm title="确定取消订单吗?" @confirm="cancelOrder" style="margin-left: 10px">
  38. <el-button slot="reference" size="small" type="danger">取消订单</el-button>
  39. </el-popconfirm>
  40. </template>
  41. <template v-if="['SPTG', 'DFH'].includes(orderDetail.orderStatus)">
  42. <el-popconfirm
  43. v-if="['PART_PAID', 'NO_PAID'].includes(orderDetail.payStatus)"
  44. title="是否确定操作发货?"
  45. @confirm="
  46. () => {
  47. showDialog('send')
  48. }
  49. "
  50. style="margin-left: 10px"
  51. >
  52. <el-button slot="reference" size="small" type="primary">发货</el-button>
  53. </el-popconfirm>
  54. <el-button v-else size="small" type="primary" @click="showDialog('send')">发货</el-button>
  55. </template>
  56. <template v-if="['DFH'].includes(orderDetail.orderStatus)">
  57. <el-popconfirm title="确定取消订单吗?" @confirm="cancelOrder" style="margin-left: 10px">
  58. <el-button slot="reference" size="small" type="danger">取消订单</el-button>
  59. </el-popconfirm>
  60. </template>
  61. <template v-if="orderDetail.orderStatus === 'YFH' || orderDetail.orderStatus === 'OVER'">
  62. <el-button size="small" @click="showDialog('query')">查看物流</el-button>
  63. </template>
  64. </div>
  65. </div>
  66. <el-table
  67. class="specTable"
  68. style="margin-left: 30px"
  69. height="120px"
  70. :data="printList"
  71. element-loading-text="Loading"
  72. border
  73. highlight-current-row
  74. stripe
  75. >
  76. <el-table-column
  77. align="center"
  78. label="打印人"
  79. prop="createBy"
  80. min-width="120"
  81. show-overflow-tooltip
  82. ></el-table-column>
  83. <el-table-column align="center" label="打印时间" prop="createTime" width="160"></el-table-column>
  84. </el-table>
  85. </div>
  86. </el-col>
  87. <el-col :span="14" style="padding-top: 10px">
  88. <el-steps :active="orderDetail.orderStatus != 'CLOSE' ? curOrderStatus : -1" align-center>
  89. <el-step title="买家下单" :description="orderDetail.createTime"></el-step>
  90. <el-step title="审核通过" :description="orderDetail.payTime ? orderDetail.payTime : ''"></el-step>
  91. <el-step title="商家发货" :description="orderDetail.deliverTime ? orderDetail.deliverTime : ''"></el-step>
  92. <el-step title="交易成功" :description="orderDetail.overTime ? orderDetail.overTime : ''"></el-step>
  93. </el-steps>
  94. </el-col>
  95. </el-row>
  96. </div>
  97. </div>
  98. <div class="order-receive-info">
  99. <el-row :gutter="30">
  100. <el-col :xs="24" :sm="12" :lg="12">
  101. <div class="main-detail">
  102. <h3>订单信息</h3>
  103. <div class="item">
  104. <div class="label">收货人信息:</div>
  105. <div class="value">{{ orderDetail.receUserName }} ({{ orderDetail.recePhone }})</div>
  106. </div>
  107. <div class="item">
  108. <div class="label">收货人地址:</div>
  109. <div class="value">
  110. {{
  111. orderDetail.province +
  112. orderDetail.city +
  113. orderDetail.area +
  114. orderDetail.street +
  115. orderDetail.receAddress +
  116. (orderDetail.houseNo || '')
  117. }}
  118. </div>
  119. </div>
  120. <div class="item">
  121. <div class="label">销售员信息:</div>
  122. <div class="value">{{ orderDetail.workerName }} ({{ orderDetail.workerPhone }})</div>
  123. </div>
  124. <div class="item">
  125. <div class="label">业务员信息:</div>
  126. <div class="value">{{ orderDetail.saleName }} ({{ orderDetail.saleMobile }})</div>
  127. </div>
  128. <div class="item">
  129. <div class="label">下单渠道:</div>
  130. <div class="value">{{ orderDetail.source }}</div>
  131. </div>
  132. <div class="item">
  133. <div class="label">支付方式:</div>
  134. <div class="value">
  135. {{ orderDetail.payType }}--{{
  136. { NO_PAID: '待收款', PART_PAID: '部分收款', PAID: '完成收款' }[orderDetail.payStatus]
  137. }}
  138. </div>
  139. </div>
  140. <div class="item">
  141. <div class="label">是否开票:</div>
  142. <div class="value">{{ orderDetail.tax ? '是' : '否' }}</div>
  143. </div>
  144. <div class="item" v-if="orderDetail.dispatchType">
  145. <div class="label">工单派单方式:</div>
  146. <div class="value">{{ orderDetail.dispatchType }}</div>
  147. </div>
  148. <div class="item" v-if="orderDetail.remark">
  149. <div class="label">订单备注:</div>
  150. <div class="value">{{ orderDetail.remark }}</div>
  151. </div>
  152. </div>
  153. </el-col>
  154. <el-col
  155. :xs="24"
  156. :sm="12"
  157. :lg="12"
  158. v-if="orderDetail.orderStatus === 'YFH' || orderDetail.orderStatus === 'OVER'"
  159. >
  160. <div class="main-detail">
  161. <h3>物流信息</h3>
  162. <div class="item">
  163. <div class="label">快递单号:</div>
  164. <div class="value">{{ orderDetail.logisticsNo }}</div>
  165. </div>
  166. <div class="item">
  167. <div class="label">快递公司:</div>
  168. <div class="value">{{ orderDetail.companyName }}</div>
  169. </div>
  170. <div class="item">
  171. <div class="label">货件仓储:</div>
  172. <div class="value">{{ orderDetail.storageName }}</div>
  173. </div>
  174. </div>
  175. </el-col>
  176. </el-row>
  177. </div>
  178. <div
  179. v-if="orderDetail.orderOldProductDTOList && orderDetail.orderOldProductDTOList.length > 0"
  180. style="margin-bottom: 30px"
  181. >
  182. <h3>旧机信息</h3>
  183. <div class="order-detail">
  184. <!-- 回收 -->
  185. <el-table :data="orderDetail.orderOldProductDTOList" style="width: 100%" size="small" border>
  186. <el-table-column prop="mainName" label="大类" align="center"></el-table-column>
  187. <el-table-column prop="smallName" label="小类" align="center"></el-table-column>
  188. <el-table-column prop="specName" label="型号" align="center"></el-table-column>
  189. <el-table-column prop="itemList" label="属性" align="center">
  190. <template slot-scope="scope">
  191. {{ scope.row.itemList.map(o => o.dictName).join('、') }}
  192. </template>
  193. </el-table-column>
  194. <el-table-column prop="unit" label="单位" align="center">
  195. <template>台</template>
  196. </el-table-column>
  197. <el-table-column prop="num" label="数量" align="center"></el-table-column>
  198. <el-table-column prop="payAmount" label="旧机金额" align="center"></el-table-column>
  199. <el-table-column prop="yjhxDkFlag" label="支付方式" align="center">
  200. <template slot-scope="scope">
  201. {{ { 1: '线上支付抵扣订单货款', 2: '仅线上展示旧机价值' }[scope.row.yjhxDkFlag] }}
  202. </template>
  203. </el-table-column>
  204. </el-table>
  205. </div>
  206. </div>
  207. <div v-if="compensateList.length > 0" style="margin-bottom: 30px">
  208. <h3>理赔信息</h3>
  209. <div class="order-detail">
  210. <!-- 理赔表格 -->
  211. <el-table :data="compensateList" style="width: 100%" size="small" border>
  212. <el-table-column prop="goodsName" label="理赔商品" align="center"></el-table-column>
  213. <el-table-column prop="num" label="理赔数量" align="center"></el-table-column>
  214. <el-table-column prop="createTime" label="理赔时间" align="center"></el-table-column>
  215. <el-table-column prop="refundAmount" label="理赔金额" align="center"></el-table-column>
  216. <el-table-column prop="operatorUser" label="操作人" align="center"></el-table-column>
  217. <el-table-column prop="remark" label="备注" align="center"></el-table-column>
  218. </el-table>
  219. </div>
  220. </div>
  221. <h3>商品信息</h3>
  222. <div class="order-detail" style="margin-bottom: 30px">
  223. <!-- 订单表格 -->
  224. <el-table :data="orderDetail.orderDetails" style="width: 100%" border>
  225. <el-table-column label="商品信息" min-width="200">
  226. <template slot-scope="scope">
  227. <el-row>
  228. <el-col :span="6">
  229. <el-image style="width: 40px; height: 40px" :src="$showImgUrl(scope.row.imgUrl)">
  230. <div slot="error" class="image-slot">
  231. <i class="el-icon-picture-outline"></i>
  232. </div>
  233. </el-image>
  234. </el-col>
  235. <el-col :span="18">
  236. <div>
  237. <el-tag
  238. type="danger"
  239. effect="plain"
  240. size="mini"
  241. style="margin-right: 4px"
  242. v-if="scope.row.promotionFullPieceId"
  243. >满件打折</el-tag
  244. >{{ scope.row.goodsName }}
  245. </div>
  246. </el-col>
  247. </el-row>
  248. </template>
  249. </el-table-column>
  250. <el-table-column prop="goodsSpecValue" label="规格" align="center">
  251. <template slot-scope="scope"> {{ scope.row.goodsSpecName }}{{ scope.row.goodsSpecValue }} </template>
  252. </el-table-column>
  253. <el-table-column prop="price" label="单价" align="center"></el-table-column>
  254. <el-table-column prop="num" label="数量" align="center"></el-table-column>
  255. <el-table-column prop="sendStockNum" label="已发货数量" min-width="100" align="center"></el-table-column>
  256. <el-table-column prop="shareAmount" label="分销金额" align="center">
  257. <template slot-scope="scope">
  258. {{ orderDetail.workerId || orderDetail.promotionGroupUserId ? scope.row.shareAmount : '0' }}
  259. </template>
  260. </el-table-column>
  261. <el-table-column prop="discountAmount" label="优惠金额" align="center"></el-table-column>
  262. <!-- <el-table-column prop="zkAmount" label="折扣优惠" align="center"></el-table-column> -->
  263. <el-table-column prop="applyAmount" label="优惠价格申请" align="center" min-width="110"></el-table-column>
  264. <el-table-column prop="profitAmount" label="实际销售金额" align="center" min-width="110">
  265. <template slot-scope="scope">
  266. {{
  267. orderDetail.workerId || orderDetail.promotionGroupUserId ? scope.row.profitAmount : scope.row.payAmount
  268. }}
  269. </template>
  270. </el-table-column>
  271. <el-table-column prop="payAmount" label="商品总金额" align="center" min-width="100"></el-table-column>
  272. <el-table-column prop="freight" label="运费" align="center"></el-table-column>
  273. <el-table-column prop="userRefundNum" label="用户维权数量" align="center" min-width="110"></el-table-column>
  274. <el-table-column prop="userRefundAmount" label="用户维权金额" align="center" min-width="110"></el-table-column>
  275. <el-table-column prop="refundNum" label="退款数量" align="center"></el-table-column>
  276. <el-table-column prop="refundAmount" label="退款金额" align="center"></el-table-column>
  277. <el-table-column prop="refundBy" label="退款人" align="center"></el-table-column>
  278. <el-table-column prop="refundTime" label="退款时间" align="center" min-width="160"></el-table-column>
  279. <el-table-column
  280. label="操作"
  281. align="center"
  282. width="160"
  283. v-if="orderDetail.orderStatus != 'CLOSE' && orderDetail.payTypeId == 'WECHAT'"
  284. >
  285. <template slot-scope="scope">
  286. <!-- <el-button v-if="!~['TIMEOUT', 'CLOSE'].indexOf(orderDetail.orderStatus)" size="mini" type="primary"
  287. @click="handleRefund(scope.row)"
  288. :disabled="!orderDetail.refundAble || scope.row.refundNum >= scope.row.num">退款</el-button> -->
  289. <!-- <el-button v-if="!~['TIMEOUT'].indexOf(orderDetail.orderStatus)" size="mini"
  290. @click="handleCompensate(scope.row)">理赔</el-button> -->
  291. </template>
  292. </el-table-column>
  293. </el-table>
  294. </div>
  295. <div v-if="deliverList.length > 0" style="margin-bottom: 30px">
  296. <h3>发货记录</h3>
  297. <div class="order-detail">
  298. <!-- 发货记录 -->
  299. <el-table :data="deliverList" style="width: 100%" size="small" border>
  300. <el-table-column prop="deliveryId" align="center" label="发货单号" width="160"></el-table-column>
  301. <el-table-column prop="status" align="center" label="状态">
  302. <template slot-scope="scope">
  303. {{
  304. { SEND: '已发货', REFUND: '已退货', PART_REFUND: '部分退货', REFUND_PRICE: '仅退款' }[scope.row.status]
  305. }}
  306. </template>
  307. </el-table-column>
  308. <el-table-column prop="sendNum" align="center" label="发货数量"></el-table-column>
  309. <el-table-column prop="refundNum" align="center" label="退货数量"></el-table-column>
  310. <el-table-column prop="num" align="center" label="订单数量"></el-table-column>
  311. <el-table-column prop="sendInsideCodeQty" align="center" label="内机数量"></el-table-column>
  312. <el-table-column prop="sendOutCodeQty" align="center" label="外机数量"></el-table-column>
  313. <el-table-column prop="sendPartsCodeQty" align="center" label="配件数量"></el-table-column>
  314. <el-table-column prop="storageStockName" align="center" label="发货仓库" width="100"></el-table-column>
  315. <el-table-column prop="pickType" align="center" label="发货方式">
  316. <template slot-scope="scope">
  317. {{ scope.row.pickType == 'YES' ? '自提' : '快递物流' }}
  318. </template>
  319. </el-table-column>
  320. <el-table-column prop="logisticsNo" align="center" label="快递单号" width="100"></el-table-column>
  321. <el-table-column prop="companyName" align="center" label="物流公司" width="100"></el-table-column>
  322. <el-table-column prop="pickName" align="center" label="提货人"></el-table-column>
  323. <el-table-column prop="pickPhone" align="center" label="提货人电话" width="110"></el-table-column>
  324. <el-table-column align="center" prop="deliverTime" label="发货时间" min-width="160"></el-table-column>
  325. <el-table-column prop="createBy" align="center" label="操作人" width="140"></el-table-column>
  326. <el-table-column prop="createTime" align="center" label="操作时间" width="160"></el-table-column>
  327. <el-table-column align="center" label="操作" fixed="right">
  328. <template slot-scope="scope">
  329. <!-- <el-button v-if="!~['TIMEOUT', 'CLOSE'].indexOf(orderDetail.orderStatus)" size="mini" type="text"
  330. @click="handleRefund(scope.row)" :disabled="!orderDetail.refundAble || scope.row.refundNum >= scope.row.num">退款
  331. </el-button> -->
  332. <el-button type="text" size="small" @click="toDeliverDetail(scope.row.deliveryId)">详情</el-button>
  333. <el-button
  334. type="text"
  335. size="small"
  336. @click="returnOrder(scope.row.deliveryId)"
  337. v-if="!~['TIMEOUT', 'CLOSE'].indexOf(orderDetail.orderStatus) && scope.row.status == 'SEND'"
  338. >发起退货</el-button
  339. >
  340. </template>
  341. </el-table-column>
  342. </el-table>
  343. </div>
  344. </div>
  345. <div class="order-detail">
  346. <div class="order-amount-info">
  347. <el-row>
  348. <el-col :span="19">
  349. <div style="width: 1px; height: 1px"></div>
  350. </el-col>
  351. <el-col :span="5">
  352. <div style="padding-bottom: 10px">商品总价:¥ {{ orderDetail.totalAmount }}</div>
  353. <div style="padding-bottom: 10px">运费:¥ {{ orderDetail.freight }}</div>
  354. <div style="padding-bottom: 10px" v-if="orderDetail.discountAmount">
  355. 优惠:¥ {{ orderDetail.discountAmount }}
  356. <span v-if="orderDetail.exchangeCode">(优惠码:{{ orderDetail.exchangeCode }})</span>
  357. <span v-if="orderDetail.promotionDiscountRate">({{ orderDetail.promotionDiscountRate * 10 }}折)</span>
  358. <span v-if="orderDetail.promotionFullPieceId">({{ orderDetail.promotionFullPieceRemark }})</span>
  359. </div>
  360. <div style="font-size: 14px">
  361. <span style="padding-right: 15px">实际收款</span
  362. ><span style="color: red; font-size: 18px">¥ {{ orderDetail.payAmount }}</span>
  363. </div>
  364. </el-col>
  365. </el-row>
  366. </div>
  367. </div>
  368. <div class="order-evaluate-info" v-if="evaluateDetail">
  369. <div class="title">
  370. <div class="left">
  371. 评价信息<span>{{ evaluateDetail.createTime }}</span>
  372. </div>
  373. <div class="right">
  374. <span>是否客户端展示</span>
  375. <el-switch v-model="evaluateDetail.isShow" @change="changeShow"></el-switch>
  376. </div>
  377. </div>
  378. <div class="main">
  379. <div class="rate-list">
  380. <div style="display: flex; align-items: center; margin-bottom: 5px">
  381. 商品质量:<el-rate :value="evaluateDetail.commentGoods" disabled disabled-void-color="#DDDDDD"></el-rate>
  382. </div>
  383. <div style="display: flex; align-items: center; margin-bottom: 5px">
  384. 服务质量:<el-rate :value="evaluateDetail.commentService" disabled disabled-void-color="#DDDDDD"></el-rate>
  385. </div>
  386. <div style="display: flex; align-items: center">
  387. 配送质量:<el-rate :value="evaluateDetail.commentExpress" disabled disabled-void-color="#DDDDDD"></el-rate>
  388. </div>
  389. </div>
  390. <div class="tag-list" v-if="orderDetail.orderCommentTags && orderDetail.orderCommentTags.length > 0">
  391. <el-tag v-for="(item, index) in orderDetail.orderCommentTags" :key="index">{{ item }}</el-tag>
  392. </div>
  393. </div>
  394. <div class="content">{{ evaluateDetail.content }}</div>
  395. <div class="img-list" v-if="orderDetail.orderCommentImgs && orderDetail.orderCommentImgs.length > 0">
  396. <el-image
  397. v-for="(item, index) in orderDetail.orderCommentImgs"
  398. :key="index"
  399. :src="$showImgUrl(item)"
  400. :preview-src-list="orderDetail.orderCommentImgs.map(u => $showImgUrl(u))"
  401. fit="cover"
  402. ></el-image>
  403. </div>
  404. </div>
  405. <!-- 收款记录 -->
  406. <div style="margin-top: 20px" v-if="!(orderDetail.payTypeId == 'WECHAT')">
  407. <h3>收款记录</h3>
  408. <!-- 列表 -->
  409. <div style="margin-bottom: 20px">
  410. <div>
  411. <span style="margin-right: 30px; font-size: 18px">订单总金额:{{ orderDetail.payAmount }}</span>
  412. <span style="margin-right: 30px; font-size: 18px"
  413. >待收款金额:{{
  414. (Math.ceil(((orderDetail.payAmount || 0) - (orderDetail.paidAmount || 0)) * 100) / 100).toFixed(2)
  415. }}</span
  416. >
  417. <span style="margin-right: 30px; font-size: 18px">已收款金额:{{ orderDetail.paidAmount }}</span>
  418. </div>
  419. <el-table
  420. v-if="orderPaymentRecordListData.length"
  421. :data="orderPaymentRecordListData"
  422. style="width: 100%"
  423. border
  424. >
  425. <el-table-column prop="payStatus" label="收款标志" align="center">
  426. <template slot-scope="scope">
  427. <div>
  428. {{ { NO_PAID: '待收款', PART_PAID: '部分收款', PAID: '完成收款' }[scope.row.payStatus] }}
  429. </div>
  430. </template>
  431. </el-table-column>
  432. <el-table-column prop="paidBy" label="收款人" align="center"></el-table-column>
  433. <el-table-column prop="paidTime" label="收款时间" align="center"></el-table-column>
  434. <el-table-column prop="paidAmount" label="收款金额" align="center"></el-table-column>
  435. <el-table-column prop="fileUrl" label="收款凭证" align="center">
  436. <template slot-scope="scope">
  437. <div>
  438. <el-image
  439. v-for="(url, index) in (scope.row.fileUrl || '').split(',').filter(url => !!url)"
  440. :key="index"
  441. style="width: 100px; height: 100px"
  442. :src="url"
  443. :preview-src-list="[url]"
  444. ></el-image>
  445. </div>
  446. </template>
  447. </el-table-column>
  448. </el-table>
  449. </div>
  450. <!-- 表单 -->
  451. <el-card
  452. class="box-card"
  453. v-if="
  454. pageType === 'shoukuan' &&
  455. orderDetail.payStatus !== 'PAID' &&
  456. !['DQR', 'CLOSE'].includes(orderDetail.orderStatus)
  457. "
  458. >
  459. <div>
  460. <el-form size="mini" :model="ruleForm" :inline="true" :rules="rules" ref="ruleForm" label-width="120px">
  461. <el-row :gutter="20">
  462. <el-col :span="8">
  463. <el-form-item label="*收款人" prop="paidBy">
  464. <el-input style="width: 100%" v-model="ruleForm.paidBy"></el-input>
  465. </el-form-item>
  466. </el-col>
  467. <el-col :span="8">
  468. <el-form-item label="*收款金额" prop="paidAmount">
  469. <el-input style="width: 100%" type="number" v-model="ruleForm.paidAmount"></el-input>
  470. </el-form-item>
  471. </el-col>
  472. <el-col :span="8">
  473. <el-form-item label="*收款时间" prop="paidTime">
  474. <el-date-picker
  475. style="width: 100%"
  476. v-model="ruleForm.paidTime"
  477. type="datetime"
  478. placeholder="选择日期时间"
  479. value-format="yyyy-MM-dd HH:mm:ss"
  480. >
  481. </el-date-picker>
  482. </el-form-item>
  483. </el-col>
  484. <el-col :span="24">
  485. <el-form-item label="凭证">
  486. <ImageUpload :fileList="ruleForm.fileUrls" :limit="100" :isEdit="true" />
  487. </el-form-item>
  488. </el-col>
  489. </el-row>
  490. </el-form>
  491. </div>
  492. <!-- 操作按钮 -->
  493. <div style="text-align: right">
  494. <el-button size="mini" type="primary" @click="shoukuanhs('PART_PAID')">部分收款</el-button>
  495. <el-button size="mini" type="primary" @click="shoukuanhs('PAID')">完成收款</el-button>
  496. </div>
  497. </el-card>
  498. </div>
  499. <!-- -------------------------------------------------------------------------------------------- -->
  500. <el-dialog
  501. :title="dialogTitle"
  502. :visible.sync="remarkVisible"
  503. :show-close="false"
  504. :width="dialogWidth"
  505. :close-on-click-modal="false"
  506. >
  507. <el-form
  508. :model="orderForm"
  509. :rules="orderFormRules"
  510. ref="orderForm"
  511. v-if="curOpenDialogType !== 'query'"
  512. label-width="100px"
  513. label-position="left"
  514. >
  515. <el-form-item prop="remark" v-if="curOpenDialogType === 'remark'">
  516. <el-input
  517. type="textarea"
  518. :autosize="{ minRows: 8, maxRows: 16 }"
  519. placeholder="请输入备注内容"
  520. v-model="remark"
  521. maxlength="100"
  522. show-word-limit
  523. >
  524. </el-input>
  525. </el-form-item>
  526. <el-form-item prop="payAmount" v-if="curOpenDialogType === 'price'">
  527. <el-input v-model="orderForm.payAmount" autocomplete="off" placeholder="请输入价格"></el-input>
  528. </el-form-item>
  529. <el-form-item label="收货人" prop="receUserName" v-if="curOpenDialogType === 'info'">
  530. <el-input v-model="orderForm.receUserName" autocomplete="off" placeholder="请输入收货人"></el-input>
  531. </el-form-item>
  532. <el-form-item label="收货电话" prop="recePhone" v-if="curOpenDialogType === 'info'">
  533. <el-input v-model="orderForm.recePhone" autocomplete="off" placeholder="请输入收货电话"></el-input>
  534. </el-form-item>
  535. <el-form-item label="收货地址" prop="receAddress" v-if="curOpenDialogType === 'info'">
  536. <el-input v-model="orderForm.receAddress" autocomplete="off" placeholder="请输入收货地址"></el-input>
  537. </el-form-item>
  538. <template v-if="curOpenDialogType === 'send'">
  539. <el-row :gutter="20">
  540. <el-col :span="6">
  541. <el-form-item label="发货方式" prop="pickType">
  542. <el-radio-group v-model="orderForm.pickType">
  543. <el-radio label="YES">自提/自送</el-radio>
  544. <el-radio label="NO">快递物流</el-radio>
  545. </el-radio-group>
  546. </el-form-item>
  547. </el-col>
  548. <el-col :span="6">
  549. <el-form-item
  550. v-if="orderForm.pickType == 'YES'"
  551. label="提货人"
  552. prop="pickName"
  553. :rules="[{ required: true, message: '提货人不能为空', trigger: 'blur' }]"
  554. >
  555. <el-input v-model="orderForm.pickName" placeholder="请输入提货人"></el-input>
  556. </el-form-item>
  557. </el-col>
  558. <el-col :span="6">
  559. <el-form-item
  560. v-if="orderForm.pickType == 'YES'"
  561. label="提货人电话"
  562. prop="pickPhone"
  563. :rules="[
  564. { required: true, message: '提货人电话不能为空', trigger: 'blur' },
  565. { pattern: /^((1[3456789]\d{9}))$/, message: '电话号码格式不正确', trigger: 'blur' }
  566. ]"
  567. >
  568. <el-input v-model="orderForm.pickPhone" placeholder="请输入提货人电话"></el-input>
  569. </el-form-item>
  570. </el-col>
  571. <el-col :span="6">
  572. <el-form-item v-if="orderForm.pickType == 'NO'" label="快递单号" prop="logisticsNo">
  573. <el-input v-model="orderForm.logisticsNo" autocomplete="off" placeholder="请输入快递单号"></el-input>
  574. </el-form-item>
  575. </el-col>
  576. <el-col :span="6">
  577. <el-form-item v-if="orderForm.pickType == 'NO'" label="物流公司" prop="companyCode">
  578. <el-select v-model="orderForm.companyCode" placeholder="请选择物流公司" style="width: 100%">
  579. <el-option
  580. :label="item.name"
  581. :value="item.code"
  582. v-for="(item, index) in companyList"
  583. :key="index"
  584. ></el-option>
  585. </el-select>
  586. </el-form-item>
  587. </el-col>
  588. <el-col :span="6">
  589. <el-form-item label="仓储" prop="storageId">
  590. <el-select
  591. v-model="orderForm.storageId"
  592. placeholder="请选择仓储"
  593. @change="
  594. e => {
  595. storageName = storageList.find(item => item.storageId == e).storageName
  596. getDetail()
  597. }
  598. "
  599. style="width: 100%"
  600. >
  601. <el-option
  602. :label="item.storageName"
  603. :value="item.storageId"
  604. v-for="(item, index) in storageList"
  605. :key="index"
  606. ></el-option>
  607. </el-select>
  608. </el-form-item>
  609. </el-col>
  610. <el-col :span="6">
  611. <el-form-item label="是否派单" prop="workOrder">
  612. <el-radio-group v-model="orderForm.workOrder">
  613. <el-radio :label="true">是</el-radio>
  614. <el-radio :label="false">否</el-radio>
  615. </el-radio-group>
  616. </el-form-item>
  617. </el-col>
  618. <el-col :span="24">
  619. <el-card class="box-card">
  620. <el-tabs v-model="typeIndex">
  621. <el-tab-pane
  622. v-if="orderDetail.orderStatus != 'YFH' && orderDetail.orderStatus != 'OVER'"
  623. label="发货数量"
  624. name="1"
  625. ></el-tab-pane>
  626. <el-tab-pane v-if="joinCode == 'CODE'" label="发货条码" name="2"></el-tab-pane>
  627. </el-tabs>
  628. <br />
  629. <el-button size="small" v-show="typeIndex == 2 && joinCode == 'CODE'" type="primary" @click="addCode()"
  630. >新增</el-button
  631. >
  632. <el-button
  633. size="small"
  634. v-show="typeIndex == 1 && joinCode == 'CODE'"
  635. type="primary"
  636. @click="handleDownload('导入条码模板')"
  637. >导入条码模板下载</el-button
  638. >
  639. <div class="table">
  640. <!-- 发货数量 -->
  641. <el-form
  642. v-show="typeIndex == 1"
  643. ref="formData1"
  644. :model="formData1"
  645. label-width="0"
  646. size="small"
  647. label-position="left"
  648. >
  649. <el-table
  650. :data="formData1.list"
  651. element-loading-text="Loading"
  652. border
  653. fit
  654. highlight-current-row
  655. stripe
  656. @selection-change="deliverSelectionChange"
  657. >
  658. <el-table-column type="selection" width="40"></el-table-column>
  659. <el-table-column prop="brandName" align="center" label="品牌"></el-table-column>
  660. <el-table-column prop="mainName" align="center" label="大类"></el-table-column>
  661. <el-table-column prop="smallName" align="center" label="小类"></el-table-column>
  662. <el-table-column prop="goodsName" align="center" label="商品名称"></el-table-column>
  663. <el-table-column prop="goodsMaterialName" align="center" label="物料名称"></el-table-column>
  664. <el-table-column prop="goodsMaterialSpecsName" align="center" label="规格型号"></el-table-column>
  665. <el-table-column prop="goodsMaterialUnit" align="center" label="单位">
  666. <template slot-scope="scope">
  667. {{
  668. scope.row.goodsMaterialUnit == 'C'
  669. ? '整套'
  670. : scope.row.goodsMaterialUnit == 'I'
  671. ? '单个'
  672. : ''
  673. }}
  674. </template>
  675. </el-table-column>
  676. <el-table-column prop="num" align="center" label="订单数量">
  677. <template slot-scope="scope">
  678. <el-input v-model="scope.row.num" placeholder="请输入" type="number"></el-input>
  679. </template>
  680. </el-table-column>
  681. <el-table-column prop="sendStockNum" align="center" label="发货数量"></el-table-column>
  682. <el-table-column v-if="joinCode != 'NO'" prop="" align="center" label="发货仓库">
  683. <template slot-scope="scope">
  684. {{ storageName }}
  685. </template>
  686. </el-table-column>
  687. <el-table-column
  688. v-if="joinCode != 'NO'"
  689. prop="stockOnQty"
  690. align="center"
  691. label="发货仓库库存"
  692. width="100"
  693. ></el-table-column>
  694. <el-table-column
  695. v-if="joinCode != 'NO'"
  696. prop="allStockQty"
  697. align="center"
  698. label="库存总数量"
  699. width="100"
  700. ></el-table-column>
  701. <el-table-column prop="insideNum" align="center" label="内机数量"></el-table-column>
  702. <el-table-column prop="outNum" align="center" label="外机数量"></el-table-column>
  703. <el-table-column prop="partNum" align="center" label="配件数量"></el-table-column>
  704. <el-table-column
  705. prop="insideCodeQty"
  706. align="center"
  707. label="导入内机条码数量"
  708. width="140"
  709. ></el-table-column>
  710. <el-table-column
  711. prop="outCodeQty"
  712. align="center"
  713. label="导入外机条码数量"
  714. width="140"
  715. ></el-table-column>
  716. <el-table-column
  717. prop="partsCodeQty"
  718. align="center"
  719. label="导入配件条码数量"
  720. width="140"
  721. ></el-table-column>
  722. <el-table-column label="操作" align="center" width="140" fixed="right">
  723. <template slot-scope="scope" v-if="joinCode == 'CODE'">
  724. <el-upload action="_" :show-file-list="false" :http-request="importCode">
  725. <el-button @click="orderDetailId = scope.row.orderDetailId" size="mini" type="text"
  726. >导入条码</el-button
  727. >
  728. </el-upload>
  729. </template>
  730. </el-table-column>
  731. </el-table>
  732. </el-form>
  733. <!-- 发货条码 -->
  734. <el-form ref="formData2" :model="formData2">
  735. <el-table
  736. v-show="typeIndex == 2"
  737. :data="formData2.list"
  738. element-loading-text="Loading"
  739. border
  740. fit
  741. highlight-current-row
  742. stripe
  743. >
  744. <el-table-column label="品牌" align="center">
  745. <template slot-scope="scope">
  746. <el-form-item>
  747. <el-input
  748. type="text"
  749. v-model="scope.row.brandName"
  750. :disabled="true"
  751. placeholder="请输入"
  752. ></el-input>
  753. </el-form-item>
  754. </template>
  755. </el-table-column>
  756. <el-table-column label="商品大类" align="center">
  757. <template slot-scope="scope">
  758. <el-form-item>
  759. <el-input
  760. type="text"
  761. v-model="scope.row.mainName"
  762. :disabled="true"
  763. placeholder="请输入"
  764. ></el-input>
  765. </el-form-item>
  766. </template>
  767. </el-table-column>
  768. <el-table-column label="商品小类" align="center">
  769. <template slot-scope="scope">
  770. <el-form-item>
  771. <el-input
  772. type="text"
  773. v-model="scope.row.smallName"
  774. :disabled="true"
  775. placeholder="请输入"
  776. ></el-input>
  777. </el-form-item>
  778. </template>
  779. </el-table-column>
  780. <el-table-column prop="" align="center" label="商品名称">
  781. <template slot-scope="scope">
  782. <el-form-item>
  783. <el-input
  784. type="text"
  785. v-model="scope.row.goodsMaterialName"
  786. :disabled="true"
  787. placeholder="请输入"
  788. ></el-input>
  789. </el-form-item>
  790. </template>
  791. </el-table-column>
  792. <el-table-column label="规格型号" align="center">
  793. <template slot-scope="scope">
  794. <el-form-item
  795. :prop="'list.' + scope.$index + '.specs'"
  796. :rules="[{ required: true, message: `请选择规格型号`, trigger: 'blur' }]"
  797. >
  798. <el-select
  799. v-model="scope.row.specs"
  800. @change="
  801. e => {
  802. changeSpecs(e, scope.row)
  803. }
  804. "
  805. value-key="orderDetailId"
  806. :disabled="isEdit2 != scope.$index"
  807. placeholder="请选择"
  808. style="width: 100%"
  809. >
  810. <el-option
  811. v-for="(item, ind) in formData1.list"
  812. :key="ind"
  813. :label="item.goodsMaterialSpecsName"
  814. :value="item"
  815. >
  816. </el-option>
  817. </el-select>
  818. </el-form-item>
  819. </template>
  820. </el-table-column>
  821. <el-table-column label="物料类型" align="center">
  822. <template slot-scope="scope">
  823. <el-form-item
  824. :prop="'list.' + scope.$index + '.goodsMaterialItemType'"
  825. :rules="[{ required: true, message: `请选择物料类型`, trigger: 'blur' }]"
  826. >
  827. <el-select
  828. v-model="scope.row.goodsMaterialItemType"
  829. @change="
  830. e => {
  831. changeMaterial(e, scope.row)
  832. }
  833. "
  834. :disabled="isEdit2 != scope.$index"
  835. placeholder="请选择"
  836. style="width: 100%"
  837. >
  838. <el-option
  839. v-for="(item, ind) in [
  840. { name: '内机', id: 'INSIDE' },
  841. { name: '外机', id: 'OUT' },
  842. { name: '配件', id: 'PARTS' }
  843. ]"
  844. :key="ind"
  845. :label="item.name"
  846. :value="item.id"
  847. >
  848. </el-option>
  849. </el-select>
  850. </el-form-item>
  851. </template>
  852. </el-table-column>
  853. <el-table-column label="物料名称" align="center">
  854. <template slot-scope="scope">
  855. <el-form-item
  856. :prop="'list.' + scope.$index + '.material'"
  857. :rules="[{ required: true, message: `请选择物料名称`, trigger: 'blur' }]"
  858. >
  859. <el-select
  860. v-model="scope.row.material"
  861. @focus="
  862. e => {
  863. if (!scope.row.goodsMaterialItemType) {
  864. return $message.warning('请先选择物料类型!')
  865. }
  866. }
  867. "
  868. @change="
  869. e => {
  870. scope.row.materialName = e.name
  871. scope.row.stockQty = e.uniqueCode == 'YES' ? 1 : null
  872. scope.row.uniqueCode = e.uniqueCode
  873. scope.row.goodsMaterialItemId = e.itemId
  874. }
  875. "
  876. value-key="name"
  877. :disabled="isEdit2 != scope.$index"
  878. placeholder="请选择"
  879. style="width: 100%"
  880. >
  881. <el-option
  882. v-for="(item, ind) in scope.row.materialList"
  883. :key="ind"
  884. :label="item.name"
  885. :value="item"
  886. >
  887. </el-option>
  888. </el-select>
  889. </el-form-item>
  890. </template>
  891. </el-table-column>
  892. <el-table-column prop="" align="center" label="是否一物一码">
  893. <template slot-scope="scope">
  894. <el-form-item>
  895. {{ scope.row.uniqueCode == 'YES' ? '是' : scope.row.uniqueCode == 'NO' ? '否' : '' }}
  896. </el-form-item>
  897. </template>
  898. </el-table-column>
  899. <el-table-column prop="" align="center" label="条码">
  900. <template slot-scope="scope">
  901. <el-form-item
  902. :prop="'list.' + scope.$index + '.materialCode'"
  903. :rules="[{ required: true, message: `请输入条码`, trigger: 'blur' }]"
  904. >
  905. <el-input
  906. type="text"
  907. v-model="scope.row.materialCode"
  908. :disabled="isEdit2 != scope.$index"
  909. placeholder="请输入"
  910. ></el-input>
  911. </el-form-item>
  912. </template>
  913. </el-table-column>
  914. <el-table-column prop="" align="center" label="数量">
  915. <template slot-scope="scope">
  916. <el-form-item
  917. :prop="'list.' + scope.$index + '.stockQty'"
  918. :rules="[{ required: true, message: `请输入数量`, trigger: 'blur' }]"
  919. >
  920. <el-input
  921. type="number"
  922. v-model="scope.row.stockQty"
  923. :disabled="isEdit2 != scope.$index || scope.row.uniqueCode == 'YES'"
  924. placeholder="请输入"
  925. ></el-input>
  926. </el-form-item>
  927. </template>
  928. </el-table-column>
  929. <el-table-column label="操作" align="right" width="140" fixed="right">
  930. <template slot-scope="scope">
  931. <el-button
  932. size="mini"
  933. type="primary"
  934. v-if="scope.$index == isEdit2"
  935. @click="saveCode(scope.row)"
  936. >保存</el-button
  937. >
  938. <el-button
  939. size="mini"
  940. type="primary"
  941. v-if="scope.$index != isEdit2"
  942. @click="isEdit2 = scope.$index"
  943. >编辑</el-button
  944. >
  945. <el-popconfirm
  946. title="确定删除吗?"
  947. @confirm="delCode(scope.row.orderDetailCodeId, scope.$index)"
  948. >
  949. <el-button slot="reference" size="mini" type="danger">删除</el-button>
  950. </el-popconfirm>
  951. </template>
  952. </el-table-column>
  953. </el-table>
  954. </el-form>
  955. </div>
  956. </el-card>
  957. </el-col>
  958. </el-row>
  959. </template>
  960. </el-form>
  961. <el-table
  962. v-loading="logisticsLoading"
  963. :data="logistics"
  964. style="width: 100%"
  965. size="mini"
  966. v-if="curOpenDialogType === 'query'"
  967. >
  968. <el-table-column prop="comName" label="物流公司" align="center"></el-table-column>
  969. <el-table-column prop="areaName" label="地区名称" align="center"></el-table-column>
  970. <el-table-column prop="time" label="物流时间" align="center"></el-table-column>
  971. <el-table-column prop="state" label="物流状态" align="center">
  972. <template slot-scope="scope">
  973. {{ scope.row.state | EXPRESS_CURRENT_STATE_FILTER }}
  974. </template>
  975. </el-table-column>
  976. <el-table-column prop="context" label="物流详情" align="center"></el-table-column>
  977. </el-table>
  978. <div slot="footer" class="dialog-footer">
  979. <el-button type="primary" @click="saveForm" v-if="curOpenDialogType !== 'query' && curOpenDialogType !== 'send'"
  980. >保 存</el-button
  981. >
  982. <el-button type="primary" @click="deliverGoods" v-if="curOpenDialogType == 'send'">发 货</el-button>
  983. <el-button @click="cancelForm">{{ curOpenDialogType === 'query' ? '关 闭' : '取 消' }}</el-button>
  984. </div>
  985. </el-dialog>
  986. <el-dialog title="理赔" :visible.sync="compensateFormVisible" width="30%" :close-on-click-modal="false">
  987. <el-form ref="compensateForm" :model="compensateForm" :rules="compensateFormRules" label-position="left">
  988. <el-form-item label="理赔数量" prop="num">
  989. <el-input v-model="compensateForm.num" autocomplete="off"></el-input>
  990. </el-form-item>
  991. <el-form-item label="理赔金额" prop="amount">
  992. <el-input v-model="compensateForm.amount" autocomplete="off"></el-input>
  993. </el-form-item>
  994. <el-form-item label="备注" prop="remark">
  995. <el-input v-model="compensateForm.remark" autocomplete="off" type="textarea" :rows="3"></el-input>
  996. </el-form-item>
  997. </el-form>
  998. <div slot="footer" class="dialog-footer">
  999. <el-button @click="cancelCompensateForm">取 消</el-button>
  1000. <el-button type="primary" @click="submitCompensateForm">确 定</el-button>
  1001. </div>
  1002. </el-dialog>
  1003. </div>
  1004. </template>
  1005. <script>
  1006. import ImageUpload from '@/components/file-upload'
  1007. import {
  1008. cancelOrder,
  1009. changePrice,
  1010. changeReceiveInfo,
  1011. confirmOrder,
  1012. getOrderDetail,
  1013. orderDeliver,
  1014. saveRemark,
  1015. orderRefund,
  1016. orderCompensate,
  1017. getCompensateList,
  1018. changeShow,
  1019. getCodeDetail,
  1020. getMaterialList,
  1021. listImport,
  1022. saveCode,
  1023. delCode,
  1024. getPrintList,
  1025. getDeliverList,
  1026. orderPaymentRecordList,
  1027. orderPaymentRecordAdd
  1028. } from '@/api/order'
  1029. import { getExpress, getCompanyList } from '@/api/common'
  1030. import { commonTemplateDownload } from '@/api/common.js'
  1031. import * as Storage from '@/api/storage'
  1032. import { mapGetters } from 'vuex'
  1033. export default {
  1034. components: { ImageUpload },
  1035. name: 'detail',
  1036. data() {
  1037. return {
  1038. orderId: '',
  1039. orderDetail: {},
  1040. evaluateDetail: null,
  1041. dialogTitle: '',
  1042. remarkVisible: false,
  1043. remark: '',
  1044. price: 0,
  1045. orderForm: {
  1046. orderId: '',
  1047. payAmount: '',
  1048. receAddress: '',
  1049. receUserName: '',
  1050. recePhone: '',
  1051. logisticsNo: '',
  1052. companyCode: '',
  1053. workOrder: true,
  1054. pickType: 'YES',
  1055. pickName: '',
  1056. pickPhone: ''
  1057. },
  1058. orderFormRules: {
  1059. payAmount: [
  1060. {
  1061. validator: (rule, value, callback) => {
  1062. if (this.curOpenDialogType !== 'price') {
  1063. callback()
  1064. } else {
  1065. if (!value) {
  1066. callback(new Error('请输入价格'))
  1067. } else {
  1068. if (!this.isNumber(value)) {
  1069. callback(new Error('请输入数字值'))
  1070. } else {
  1071. callback()
  1072. }
  1073. }
  1074. }
  1075. },
  1076. trigger: 'blur'
  1077. }
  1078. ],
  1079. receUserName: [{ require: true, message: '请输入收货人', trigger: 'blur' }],
  1080. recePhone: [{ require: true, message: '请输入收货电话', trigger: 'blur' }],
  1081. receAddress: [{ require: true, message: '请输入收货地址', trigger: 'blur' }],
  1082. logisticsNo: [
  1083. {
  1084. validator: (rule, value, callback) => {
  1085. if (this.curOpenDialogType !== 'send') {
  1086. callback()
  1087. } else {
  1088. if (!value) {
  1089. callback(new Error('请输入快递单号'))
  1090. } else {
  1091. callback()
  1092. }
  1093. }
  1094. },
  1095. trigger: 'blur'
  1096. }
  1097. ],
  1098. storageId: [
  1099. {
  1100. validator: (rule, value, callback) => {
  1101. let joinCode = JSON.parse(localStorage.getItem('greemall_user')).joinCode
  1102. if (this.curOpenDialogType !== 'send' || joinCode == 'NO') {
  1103. callback()
  1104. } else {
  1105. if (!value) {
  1106. callback(new Error('请选择仓储'))
  1107. } else {
  1108. callback()
  1109. }
  1110. }
  1111. },
  1112. trigger: 'change'
  1113. }
  1114. ],
  1115. companyCode: [
  1116. {
  1117. validator: (rule, value, callback) => {
  1118. if (this.curOpenDialogType !== 'send') {
  1119. callback()
  1120. } else {
  1121. if (!value) {
  1122. callback(new Error('请选择快递公司'))
  1123. } else {
  1124. callback()
  1125. }
  1126. }
  1127. },
  1128. trigger: 'change'
  1129. }
  1130. ]
  1131. },
  1132. curOpenDialogType: 'order',
  1133. logistics: [],
  1134. storageList: [],
  1135. dialogWidth: '50%',
  1136. logisticsLoading: false,
  1137. companyList: [],
  1138. compensateFormVisible: false,
  1139. compensateForm: {
  1140. id: null,
  1141. num: '',
  1142. amount: '',
  1143. remark: ''
  1144. },
  1145. compensateFormRules: {
  1146. num: [
  1147. { required: true, message: '请输入理赔数量', trigger: 'blur' },
  1148. {
  1149. validator: (rule, value, callback) => {
  1150. if (value > this.compensateItem.num - this.compensateItem.refundNum) {
  1151. callback(
  1152. new Error('最多还可以理赔' + (this.compensateItem.num - this.compensateItem.refundNum) + '件商品')
  1153. )
  1154. } else {
  1155. callback()
  1156. }
  1157. },
  1158. trigger: 'blur'
  1159. }
  1160. ],
  1161. amount: [{ required: true, message: '请输入理赔金额', trigger: 'blur' }]
  1162. },
  1163. compensateItem: {
  1164. num: '',
  1165. refundNum: ''
  1166. },
  1167. compensateList: [],
  1168. typeIndex: '1',
  1169. formData1: {
  1170. list: []
  1171. },
  1172. formData2: {
  1173. list: []
  1174. },
  1175. isEdit1: 0,
  1176. isEdit2: 0,
  1177. joinCode: JSON.parse(localStorage.getItem('greemall_user')).joinCode,
  1178. orderDetailId: '',
  1179. printList: [],
  1180. deliverList: [],
  1181. deliverSelection: [],
  1182. storageName: '',
  1183. pageType: '',
  1184. orderPaymentRecordListData: [],
  1185. ruleForm: {
  1186. paidAmount: '',
  1187. paidBy: '',
  1188. paidTime: '',
  1189. fileUrls: []
  1190. },
  1191. rules: {
  1192. paidAmount: [
  1193. {
  1194. validator: (rule, value, callback) => {
  1195. if (!value) {
  1196. callback(new Error('请输入'))
  1197. } else {
  1198. callback()
  1199. }
  1200. },
  1201. trigger: 'blur'
  1202. }
  1203. ],
  1204. paidBy: [
  1205. {
  1206. validator: (rule, value, callback) => {
  1207. if (!value) {
  1208. callback(new Error('请输入'))
  1209. } else {
  1210. callback()
  1211. }
  1212. },
  1213. trigger: 'blur'
  1214. }
  1215. ],
  1216. paidTime: [
  1217. {
  1218. validator: (rule, value, callback) => {
  1219. if (!value) {
  1220. callback(new Error('请输入'))
  1221. } else {
  1222. callback()
  1223. }
  1224. },
  1225. trigger: 'blur'
  1226. }
  1227. ],
  1228. fileUrls: []
  1229. }
  1230. }
  1231. },
  1232. created() {
  1233. this.orderId = this.$route.query.orderId
  1234. this.pageType = this.$route.query.type
  1235. this.getDetail()
  1236. this.getStorageList()
  1237. this.getCompanyList()
  1238. this.getCompensateList()
  1239. this.getPrintList()
  1240. this.getDeliverList()
  1241. setTimeout(() => {
  1242. if (this.pageType === 'shoukuan') {
  1243. var elements = document.getElementsByClassName('app-main-view-div')
  1244. for (var el of elements) {
  1245. el.scrollTo(1000, 10000000000000000000)
  1246. }
  1247. }
  1248. }, 500)
  1249. },
  1250. methods: {
  1251. shoukuanhs(type) {
  1252. this.$refs.ruleForm.validate(valid => {
  1253. if (valid) {
  1254. orderPaymentRecordAdd({
  1255. payStatus: type,
  1256. orderId: this.orderId,
  1257. ...this.ruleForm,
  1258. fileUrls: undefined,
  1259. fileUrl: this.ruleForm.fileUrls.map(item => item.url).join(',')
  1260. }).then(res => {
  1261. this.ruleForm = {
  1262. paidAmount: '',
  1263. paidBy: '',
  1264. paidTime: '',
  1265. fileUrls: []
  1266. }
  1267. this.$successMsg('记录成功')
  1268. this.getDetail()
  1269. })
  1270. }
  1271. })
  1272. },
  1273. getDetail() {
  1274. orderPaymentRecordList({ orderId: this.orderId }).then(res => {
  1275. this.orderPaymentRecordListData = res.data
  1276. })
  1277. getOrderDetail({ orderId: this.orderId, storageId: this.orderForm.storageId }).then(res => {
  1278. this.orderDetail = res.data
  1279. this.orderDetail.workerName = this.orderDetail.workerName ? this.orderDetail.workerName : '暂无'
  1280. this.orderDetail.workerPhone = this.orderDetail.workerPhone ? this.orderDetail.workerPhone : ''
  1281. this.evaluateDetail = res.data.orderComment
  1282. let arr = []
  1283. res.data.orderDetails.forEach(item => {
  1284. arr.push(item)
  1285. })
  1286. this.formData1.list = arr
  1287. })
  1288. },
  1289. getDeliverList() {
  1290. getDeliverList({
  1291. pageNum: 1,
  1292. pageSize: -1,
  1293. params: [{ param: 'a.order_id', compare: '=', value: this.orderId }]
  1294. }).then(res => {
  1295. this.deliverList = res.data.records
  1296. })
  1297. },
  1298. getPrintList() {
  1299. getPrintList({ orderId: this.orderId }).then(res => {
  1300. this.printList = res.data || []
  1301. })
  1302. },
  1303. showDialog(type) {
  1304. this.dialogWidth = type === 'query' ? '80%' : type === 'send' ? '80%' : '50%'
  1305. this.remarkVisible = true
  1306. this.curOpenDialogType = type
  1307. if (type === 'remark') {
  1308. this.dialogTitle = '订单备注'
  1309. this.remark = this.orderDetail.remark
  1310. } else if (type === 'price') {
  1311. this.dialogTitle = '修改价格'
  1312. this.orderForm.payAmount = this.orderDetail.payAmount
  1313. } else if (type === 'info') {
  1314. this.dialogTitle = '收货人信息'
  1315. this.orderForm.receUserName = this.orderDetail.receUserName
  1316. this.orderForm.recePhone = this.orderDetail.recePhone
  1317. this.orderForm.receAddress = this.orderDetail.receAddress
  1318. } else if (type === 'send') {
  1319. this.dialogTitle = '发货信息'
  1320. } else if (type === 'query') {
  1321. this.logisticsLoading = true
  1322. this.dialogTitle = '物流信息'
  1323. getExpress({
  1324. logisticsNo: this.orderDetail.logisticsNo,
  1325. companyCode: this.orderDetail.companyCode
  1326. }).then(res => {
  1327. this.logistics = res.data
  1328. this.logisticsLoading = false
  1329. })
  1330. }
  1331. },
  1332. cancelForm() {
  1333. this.remarkVisible = false
  1334. if (this.curOpenDialogType === 'query') {
  1335. return
  1336. }
  1337. this.$refs.orderForm.resetFields()
  1338. if (this.curOpenDialogType === 'remark') {
  1339. this.remark = ''
  1340. } else if (this.curOpenDialogType === 'price') {
  1341. this.price = ''
  1342. }
  1343. },
  1344. saveForm() {
  1345. const params = {
  1346. orderId: this.orderId
  1347. }
  1348. if (this.curOpenDialogType === 'remark') {
  1349. params.remark = this.remark
  1350. saveRemark(params).then(() => {
  1351. this.cancelForm()
  1352. this.getDetail()
  1353. this.$successMsg('保存成功')
  1354. })
  1355. } else if (this.curOpenDialogType === 'price') {
  1356. params.price = this.orderForm.payAmount
  1357. this.$refs.orderForm.validate(valid => {
  1358. if (valid) {
  1359. changePrice(params).then(() => {
  1360. this.cancelForm()
  1361. this.getDetail()
  1362. this.$successMsg('保存成功')
  1363. })
  1364. }
  1365. })
  1366. } else if (this.curOpenDialogType === 'info') {
  1367. params.receUserName = this.orderForm.receUserName
  1368. params.recePhone = this.orderForm.recePhone
  1369. params.receAddress = this.orderForm.receAddress
  1370. params.orderStatus = this.orderDetail.orderStatus
  1371. this.$refs.orderForm.validate(valid => {
  1372. if (valid) {
  1373. changeReceiveInfo(params).then(() => {
  1374. this.cancelForm()
  1375. this.getDetail()
  1376. this.$successMsg('保存成功')
  1377. })
  1378. }
  1379. })
  1380. } else if (this.curOpenDialogType === 'send') {
  1381. params.logisticsNo = this.orderForm.logisticsNo
  1382. params.storageId = this.orderForm.storageId
  1383. params.companyCode = this.orderForm.companyCode
  1384. params.workOrder = this.orderForm.workOrder
  1385. this.$refs.orderForm.validate(valid => {
  1386. if (valid) {
  1387. orderDeliver(params).then(() => {
  1388. this.cancelForm()
  1389. this.getDetail()
  1390. this.$successMsg('保存成功')
  1391. })
  1392. }
  1393. })
  1394. }
  1395. },
  1396. cancelOrder() {
  1397. cancelOrder({ orderId: this.orderId }).then(() => {
  1398. this.getDetail()
  1399. this.$successMsg('取消成功')
  1400. })
  1401. },
  1402. confirmOrder() {
  1403. confirmOrder({ orderId: this.orderId }).then(() => {
  1404. this.getDetail()
  1405. this.$successMsg('确认收款成功')
  1406. })
  1407. },
  1408. toDeliverDetail(deliveryId) {
  1409. this.$router.push({
  1410. name: 'sales_deliver_order_list',
  1411. query: {
  1412. deliverId: deliveryId
  1413. }
  1414. })
  1415. },
  1416. // 发起退货
  1417. returnOrder(deliveryId) {
  1418. this.$router.push({
  1419. name: 'sales_return_order_list',
  1420. query: {
  1421. deliverId: deliveryId
  1422. }
  1423. })
  1424. },
  1425. goBack() {
  1426. // this.$router.go(-1);
  1427. this.$router.push({
  1428. name: 'order_list'
  1429. })
  1430. },
  1431. isNumber(val) {
  1432. const regPos = /^\d+(\.\d+)?$/
  1433. const regNeg = /^(-(([0-9]+\.[0-9]*[1-9][0-9]*)|([0-9]*[1-9][0-9]*\.[0-9]+)|([0-9]*[1-9][0-9]*)))$/
  1434. if (regPos.test(val) || regNeg.test(val)) {
  1435. return true
  1436. } else {
  1437. return false
  1438. }
  1439. },
  1440. getStorageList() {
  1441. Storage.getList({ pageNum: 1, pageSize: -1, type: '商品' }).then(res => {
  1442. this.storageList = res.data.records
  1443. })
  1444. },
  1445. // 获取物流公司列表
  1446. getCompanyList() {
  1447. getCompanyList().then(res => {
  1448. this.companyList = res.data
  1449. })
  1450. },
  1451. // 退款
  1452. handleRefund(row) {
  1453. console.log(row)
  1454. if (row.num == 1) {
  1455. this.$confirm('此操作将退款此商品, 是否继续?', '退款', {
  1456. confirmButtonText: '确定',
  1457. cancelButtonText: '取消',
  1458. type: 'warning'
  1459. })
  1460. .then(() => {
  1461. this.orderRefund(1, row.orderDetailId)
  1462. })
  1463. .catch(() => {})
  1464. } else {
  1465. this.$prompt('请输入退款数量', '退款', {
  1466. confirmButtonText: '确定',
  1467. cancelButtonText: '取消',
  1468. inputValidator: function (value) {
  1469. if (!value) return '请输入退款数量'
  1470. if (value == 0) return '退款数量不能小于1'
  1471. if (value > row.num - row.refundNum) {
  1472. return '最多还可以退款' + (row.num - row.refundNum) + '件商品'
  1473. }
  1474. }
  1475. })
  1476. .then(({ value }) => {
  1477. this.orderRefund(value, row.orderDetailId)
  1478. })
  1479. .catch(() => {})
  1480. }
  1481. },
  1482. // 退款
  1483. orderRefund(num, id) {
  1484. orderRefund({
  1485. num: num,
  1486. orderDetailId: id
  1487. }).then(res => {
  1488. this.getDetail()
  1489. this.$successMsg('退款成功')
  1490. })
  1491. },
  1492. // 理赔
  1493. handleCompensate(row) {
  1494. this.compensateFormVisible = true
  1495. this.compensateForm.id = row.orderDetailId
  1496. this.compensateItem.num = row.num
  1497. this.compensateItem.refundNum = row.refundNum
  1498. },
  1499. // 取消 理赔
  1500. cancelCompensateForm() {
  1501. this.compensateFormVisible = false
  1502. this.compensateForm = {
  1503. id: null,
  1504. num: '',
  1505. amount: '',
  1506. remark: ''
  1507. }
  1508. },
  1509. // 提交 理赔
  1510. submitCompensateForm() {
  1511. this.$refs.compensateForm.validate(valid => {
  1512. if (valid) {
  1513. let params = {
  1514. adminUserId: this.userid,
  1515. orderDetailId: this.compensateForm.id,
  1516. num: this.compensateForm.num,
  1517. refundAmount: this.compensateForm.amount,
  1518. remark: this.compensateForm.remark
  1519. }
  1520. orderCompensate(params).then(res => {
  1521. this.cancelCompensateForm()
  1522. this.getDetail()
  1523. this.getCompensateList()
  1524. this.$successMsg('理赔成功')
  1525. })
  1526. }
  1527. })
  1528. },
  1529. // 获取理赔列表
  1530. getCompensateList() {
  1531. getCompensateList({ orderId: this.orderId }).then(res => {
  1532. this.compensateList = res.data
  1533. })
  1534. },
  1535. // 切换评价信息是否显示
  1536. changeShow() {
  1537. changeShow({
  1538. isShow: this.evaluateDetail.isShow,
  1539. orderId: this.orderId
  1540. }).then(res => {
  1541. this.getDetail()
  1542. this.$successMsg()
  1543. })
  1544. },
  1545. async getCodeDetail() {
  1546. getCodeDetail({ orderId: this.orderId }).then(async res => {
  1547. for (var item of res.data) {
  1548. item.specs = { goodsMaterialSpecsName: item.specsName, orderDetailId: item.orderDetailId }
  1549. item.material = { name: item.materialName }
  1550. item.materialList = await this.getMaterialList(item.specsName, item.goodsMaterialItemType)
  1551. }
  1552. this.formData2.list = res.data
  1553. })
  1554. },
  1555. async getMaterialList(specsName, type) {
  1556. return new Promise((resolve, reject) => {
  1557. getMaterialList({
  1558. pageNum: 1,
  1559. pageSize: -1,
  1560. specsName,
  1561. type
  1562. }).then(async res => {
  1563. resolve(res.data.records)
  1564. })
  1565. })
  1566. },
  1567. async changeSpecs(e, row) {
  1568. row.brandName = e.brandName
  1569. row.brandId = e.brandId
  1570. row.mainName = e.mainName
  1571. row.mainId = e.mainNumber
  1572. row.smallName = e.smallName
  1573. row.smallId = e.smallNumber
  1574. row.specsName = e.goodsMaterialSpecsName
  1575. row.goodsMaterialName = e.goodsName
  1576. row.goodsMaterialId = e.goodsMaterialId
  1577. row.material = null
  1578. row.materialName = ''
  1579. row.stockQty = ''
  1580. row.uniqueCode = ''
  1581. row.materialList = await this.getMaterialList(row.specsName, row.goodsMaterialItemType)
  1582. row.orderDetailId = e.orderDetailId
  1583. },
  1584. async changeMaterial(e, row) {
  1585. if (!row.specs) {
  1586. return this.$message.warning('请先选择规格型号!')
  1587. }
  1588. row.material = null
  1589. row.materialName = ''
  1590. row.stockQty = ''
  1591. row.uniqueCode = ''
  1592. row.materialList = await this.getMaterialList(row.specsName, row.goodsMaterialItemType)
  1593. },
  1594. //发货新增条码
  1595. addCode() {
  1596. this.$refs.formData2.validate(valid => {
  1597. if (valid) {
  1598. this.isEdit2 = 0
  1599. this.formData2.list.unshift({
  1600. brandId: '',
  1601. brandName: '',
  1602. mainId: '',
  1603. mainName: '',
  1604. stockQty: '',
  1605. smallId: '',
  1606. smallName: '',
  1607. goodsMaterialItemType: '',
  1608. goodsMaterialName: '',
  1609. goodsMaterialId: '',
  1610. materialCode: '',
  1611. uniqueCode: '',
  1612. specs: null,
  1613. specsName: '',
  1614. materialName: '',
  1615. material: null,
  1616. materialList: [],
  1617. orderDetailId: '',
  1618. goodsMaterialItemId: ''
  1619. })
  1620. }
  1621. })
  1622. },
  1623. delCode(orderDetailCodeId, index) {
  1624. if (orderDetailCodeId) {
  1625. delCode({
  1626. orderDetailCodeId
  1627. }).then(res => {
  1628. if (res.code == 200) {
  1629. this.$message({ type: 'success', message: '删除成功!' })
  1630. this.getOrderDetail()
  1631. this.getCodeDetail()
  1632. } else {
  1633. this.$message.error(res.msg)
  1634. }
  1635. })
  1636. } else {
  1637. this.formData2.list.splice(index, 1)
  1638. }
  1639. },
  1640. saveCode(orderDetailCodes) {
  1641. const that = this
  1642. let params = [
  1643. {
  1644. ...orderDetailCodes,
  1645. orderId: this.orderId
  1646. }
  1647. ]
  1648. delete params[0].material
  1649. delete params[0].specs
  1650. this.$refs.formData2.validate((valid, invalidFields, errLabels) => {
  1651. if (valid) {
  1652. saveCode(params).then(res => {
  1653. if (res.code == 200) {
  1654. that.$message.success('保存成功!')
  1655. this.getOrderDetail()
  1656. this.getCodeDetail()
  1657. }
  1658. })
  1659. }
  1660. })
  1661. },
  1662. deliverSelectionChange(val) {
  1663. this.deliverSelection = val
  1664. },
  1665. deliverGoods() {
  1666. this.$refs.orderForm.validate(valid => {
  1667. if (valid) {
  1668. if (this.deliverSelection.length < 1) return this.$errorMsg('请选择一个发货信息')
  1669. for (let i = 0; i < this.deliverSelection.length; i++) {
  1670. const item = this.deliverSelection[i]
  1671. if (!item.num || item.num == 0) return this.$errorMsg('请填写发货数量-订单数量')
  1672. }
  1673. orderDeliver({
  1674. orderId: this.orderId,
  1675. logisticsNo: this.orderForm.pickType == 'NO' ? this.orderForm.logisticsNo : '',
  1676. storageId: this.orderForm.storageId,
  1677. companyCode: this.orderForm.pickType == 'NO' ? this.orderForm.companyCode : '',
  1678. workOrder: this.orderForm.workOrder,
  1679. pickName: this.orderForm.pickType == 'YES' ? this.orderForm.pickName : '',
  1680. pickPhone: this.orderForm.pickType == 'YES' ? this.orderForm.pickPhone : '',
  1681. pickType: this.orderForm.pickType,
  1682. orderDeliveryDetailList: this.deliverSelection.map(item => {
  1683. return {
  1684. orderDetailId: item.orderDetailId,
  1685. sendNum: item.num,
  1686. sendInsideCodeQty: item.insideCodeQty,
  1687. sendOutCodeQty: item.outCodeQty,
  1688. sendPartsCodeQty: item.partsCodeQty
  1689. }
  1690. })
  1691. }).then(() => {
  1692. this.cancelForm()
  1693. this.getDetail()
  1694. this.getDeliverList()
  1695. this.$successMsg('发货成功')
  1696. })
  1697. }
  1698. })
  1699. },
  1700. importCode(data) {
  1701. const loading = this.$loading({
  1702. lock: true,
  1703. text: '正在导入',
  1704. spinner: 'el-icon-loading',
  1705. background: 'rgba(0, 0, 0, 0.7)'
  1706. })
  1707. var formdata = new FormData()
  1708. formdata.append('file', data.file)
  1709. let params = {
  1710. orderDetailId: this.orderDetailId
  1711. }
  1712. if (!!params) {
  1713. for (const key in params) {
  1714. if (Object.hasOwnProperty.call(params, key)) {
  1715. formdata.append(key, params[key])
  1716. }
  1717. }
  1718. }
  1719. listImport({ formdata })
  1720. .then(res => {
  1721. this.getOrderDetail()
  1722. loading.close()
  1723. this.$message({
  1724. type: 'success',
  1725. message: '导入成功!'
  1726. })
  1727. })
  1728. .catch(err => {
  1729. loading.close()
  1730. this.$message({
  1731. type: 'error',
  1732. message: err.message || '导入失败'
  1733. })
  1734. })
  1735. },
  1736. // 下载导入模版
  1737. handleDownload(title) {
  1738. commonTemplateDownload({ name: '导入条码.xlsx' }, title)
  1739. .then(res => {
  1740. this.$message({
  1741. message: '下载成功',
  1742. type: 'success'
  1743. })
  1744. })
  1745. .catch(err => {
  1746. this.$message.error('下载失败')
  1747. })
  1748. }
  1749. },
  1750. computed: {
  1751. ...mapGetters(['userid', 'name']),
  1752. curOrderStatus() {
  1753. switch (this.orderDetail.orderStatus) {
  1754. case 'NOPAY':
  1755. return 1
  1756. break
  1757. case 'DFH':
  1758. return 2
  1759. break
  1760. case 'YFH':
  1761. return 3
  1762. break
  1763. case 'OVER':
  1764. return 4
  1765. break
  1766. default:
  1767. return 1
  1768. }
  1769. },
  1770. totalAmountCompute() {
  1771. if (!this.orderDetail.totalAmount) {
  1772. return 0
  1773. }
  1774. const totalAmount = parseFloat(this.orderDetail.totalAmount)
  1775. const freight = parseFloat(this.orderDetail.freight)
  1776. return (totalAmount - freight).toFixed(2)
  1777. }
  1778. }
  1779. }
  1780. </script>
  1781. <style scoped lang="scss">
  1782. .order-main {
  1783. margin-top: 15px;
  1784. border: 1px solid #e5e5e5;
  1785. .order-main-title {
  1786. font-size: 14px;
  1787. }
  1788. .order-main-title span {
  1789. margin-right: 15px;
  1790. }
  1791. .order-main-status {
  1792. padding: 15px 0;
  1793. font-size: 24px;
  1794. color: #409eff;
  1795. }
  1796. .order-main-opt-btn {
  1797. padding: 15px 0;
  1798. }
  1799. }
  1800. .order-receive-info {
  1801. margin: 15px 0 30px;
  1802. padding: 15px;
  1803. background: #f5f7fa;
  1804. :first-child div span {
  1805. padding-right: 15px;
  1806. }
  1807. }
  1808. .order-detail {
  1809. background: #f5f7fa;
  1810. .order-amount-info {
  1811. padding: 15px 0;
  1812. font-size: 12px;
  1813. font-weight: bold;
  1814. }
  1815. ::v-deep .el-table tr,
  1816. ::v-deep .el-table th {
  1817. background-color: #f5f7fa;
  1818. }
  1819. }
  1820. .main-detail {
  1821. .title {
  1822. font-size: 16px;
  1823. font-weight: 700;
  1824. margin-bottom: 20px;
  1825. }
  1826. .item {
  1827. display: flex;
  1828. font-size: 14px;
  1829. color: #666;
  1830. padding-bottom: 12px;
  1831. .label {
  1832. white-space: nowrap;
  1833. }
  1834. }
  1835. }
  1836. .order-evaluate-info {
  1837. margin: 15px 0;
  1838. padding: 30px 15px;
  1839. background: #f5f7fa;
  1840. .title {
  1841. display: flex;
  1842. justify-content: space-between;
  1843. align-items: center;
  1844. .left {
  1845. font-size: 16px;
  1846. font-weight: 700;
  1847. span {
  1848. font-weight: normal;
  1849. margin-left: 20px;
  1850. font-size: 14px;
  1851. color: #666;
  1852. }
  1853. }
  1854. .right {
  1855. display: flex;
  1856. align-items: center;
  1857. font-size: 14px;
  1858. span {
  1859. margin-right: 10px;
  1860. }
  1861. }
  1862. }
  1863. .main {
  1864. margin-top: 20px;
  1865. display: flex;
  1866. .rate-list {
  1867. font-size: 14px;
  1868. flex-shrink: 0;
  1869. }
  1870. .tag-list {
  1871. margin-left: 30px;
  1872. ::v-deep .el-tag {
  1873. margin-right: 10px;
  1874. margin-bottom: 10px;
  1875. }
  1876. }
  1877. }
  1878. .content {
  1879. width: 400px;
  1880. line-height: 20px;
  1881. font-size: 14px;
  1882. color: #333;
  1883. margin-top: 10px;
  1884. }
  1885. .img-list {
  1886. display: flex;
  1887. flex-wrap: wrap;
  1888. margin-top: 10px;
  1889. width: 400px;
  1890. ::v-deep .el-image {
  1891. width: 100px;
  1892. height: 100px;
  1893. margin-right: 10px;
  1894. margin-bottom: 10px;
  1895. border: 1px solid #eaeaea;
  1896. }
  1897. }
  1898. }
  1899. </style>