detail.vue 10 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237
  1. <template>
  2. <div class="app-container">
  3. <el-menu :default-active="activeIndex" class="el-menu-demo" mode="horizontal">
  4. <el-menu-item index="1" @click="backToList">订单列表</el-menu-item>
  5. <el-menu-item index="2">订单详情</el-menu-item>
  6. </el-menu>
  7. <el-card v-if="order" class="box-card">
  8. <el-row :gutter="24" class="box-row">
  9. <el-col :span="6"><b>订单编号(ID):</b> {{ order.orderNo + '(' + order.orderID + ')' }}</el-col>
  10. <el-col :span="6"><b>下单时间:</b> {{ order.orderTime | parseTime('{y}-{m}-{d} {h}:{i}') }}</el-col>
  11. <el-col :span="6"><b>订单状态:</b>
  12. <template v-if="['11','12','13','21','22','23','31','32','33'].indexOf(order.status)>=0">
  13. <el-tag type="success" size="small">{{ '交易中('+statusObj[order.status]+')' }}</el-tag>
  14. </template>
  15. <template v-else>
  16. <el-tag :type="order.status*1===6?'info':''" size="small">{{ statusObj[order.status] }}</el-tag>
  17. </template>
  18. </el-col>
  19. <el-col v-if="order.bpOrderUserinfo" :span="6"><b>买家:</b> {{ order.bpOrderUserinfo.name }}</el-col>
  20. </el-row>
  21. <el-row :gutter="24" class="box-row">
  22. <el-col :span="6"><b>收款状态:</b>
  23. <el-tag v-if="order.receiptStatus*1===1" type="danger" size="small">待收款</el-tag>
  24. <el-tag v-if="order.receiptStatus*1===2" type="warning" size="small">部分收款</el-tag>
  25. <el-tag v-if="order.receiptStatus*1===3" type="success" size="small">已收款</el-tag>
  26. </el-col>
  27. <el-col :span="6"><b>退款状态:</b>
  28. <el-tag v-if="order.refundType*1===1" type="warning" size="small">部分退</el-tag>
  29. <el-tag v-else-if="order.refundType*1===2" type="danger" size="small">全部退</el-tag>
  30. <el-tag v-else type="info" size="small">无退款</el-tag>
  31. </el-col>
  32. <el-col :span="6"><b>发货状态:</b>
  33. <el-tag v-if="order.sendOutStatus*1===1" type="danger" size="small">待发货</el-tag>
  34. <el-tag v-if="order.sendOutStatus*1===2" type="warning" size="small">部分发货</el-tag>
  35. <el-tag v-if="order.sendOutStatus*1===3" type="success" size="small">已发货</el-tag>
  36. </el-col>
  37. <el-col :span="6">
  38. <el-dropdown class="dropdown">
  39. <el-button type="primary">
  40. 功能<i class="el-icon-arrow-down el-icon--right" />
  41. </el-button>
  42. <el-dropdown-menu slot="dropdown">
  43. <el-dropdown-item><div @click="RemarksOrder(order.orderID)">备注</div></el-dropdown-item>
  44. <el-dropdown-item v-if="['0','11','21','6','4'].indexOf(order.status)<0"><router-link :to="'/order/logistics/' + order.orderID ">发货记录</router-link></el-dropdown-item>
  45. <el-dropdown-item v-if="['0','11','6'].indexOf(order.status)<0"><router-link :to="'/order/refund-record/' + order.orderID ">收退款记录</router-link></el-dropdown-item>
  46. <el-dropdown-item v-if="['0','11','6'].indexOf(order.status)<0"><router-link :to="'/order/refund-return/' + order.orderID ">退款(退货)记录</router-link></el-dropdown-item>
  47. </el-dropdown-menu>
  48. </el-dropdown>
  49. </el-col>
  50. </el-row>
  51. </el-card>
  52. <el-card v-if="order" class="box-card">
  53. <el-row v-if="order.bpOrderUserinfo" :gutter="24" class="box-row">
  54. <el-col :span="6"><b>收货人:</b> {{ order.bpOrderUserinfo.shouHuoRen }}</el-col>
  55. <el-col :span="6"><b>手机:</b> {{ order.bpOrderUserinfo.mobile }}</el-col>
  56. <el-col :span="12"><b>地址:</b> {{ order.bpOrderUserinfo.province +' '+ order.bpOrderUserinfo.city +' '+ order.bpOrderUserinfo.town +' '+ order.bpOrderUserinfo.address }}</el-col>
  57. </el-row>
  58. <el-row :gutter="24" class="box-row">
  59. <el-col :span="6"><b>订单金额:</b> ¥{{ order.payTotalFee | toThousandFilter }}</el-col>
  60. <el-col :span="6"><b>应收金额:</b> ¥{{ order.payableAmount | toThousandFilter }}<span style="color:red;"> (账户余额抵扣:¥{{ order.balancePayFee | toThousandFilter }})</span></el-col>
  61. <el-col :span="6"><b>已收金额:</b>
  62. <template v-if="order.receiptStatus*1===1">¥0</template>
  63. <template v-else>¥{{ receiptAmount | toThousandFilter }}</template>
  64. </el-col>
  65. <el-col :span="6"><b>退款金额(已完成):</b> ¥{{ returnValue | toThousandFilter }}
  66. <span style="color:red;">({{ '原:¥' + returnedPurchaseFee + ',折扣取消:¥' + (order.discountFee>returnedPurchaseFee ? returnedPurchaseFee : order.discountFee) }})</span>
  67. </el-col>
  68. </el-row>
  69. <el-row :gutter="24" class="box-row">
  70. <el-col :span="6"><b>经理折扣:</b>
  71. <template v-if="order.discountFee<0">¥0</template>
  72. <template v-else>
  73. ¥{{ order.discountFee>returnedPurchaseFee ? (order.discountFee - returnedPurchaseFee) : '0' }}
  74. <span style="color:red;">({{ '原:¥' + order.discountFee + ',折扣取消:¥' + (order.discountFee>returnedPurchaseFee ? returnedPurchaseFee : order.discountFee) }})</span>
  75. </template>
  76. </el-col>
  77. <el-col :span="6"><b>运费:</b>
  78. <template v-if="order.freight*1===0">包邮</template>
  79. <template v-else-if="order.freight*1===-1">到付</template>
  80. <template v-else-if="order.freight*1===-2">仪器到付-产品包邮</template>
  81. <template v-else>¥{{ order.freight }}</template>
  82. </el-col>
  83. </el-row>
  84. <div v-for="shopOrder in order.newShopOrders" :key="shopOrder.shopOrderID" class="order-item">
  85. <el-row :gutter="22" class="box-row">
  86. <el-col :span="9"><b>子订单号(ID):</b> {{ shopOrder.shopOrderNo + '(' + shopOrder.shopOrderID + ')' }}</el-col>
  87. <el-col :span="5"><b>下单时间:</b> {{ shopOrder.orderTime }}</el-col>
  88. <el-col :span="5"><b>子订单金额:</b> ¥{{ shopOrder.needPayAmount | toThousandFilter }}</el-col>
  89. <el-col :span="5"><b>发货状态:</b>
  90. <el-tag v-if="shopOrder.sendOutStatus*1===1" type="danger" size="small">待发货</el-tag>
  91. <el-tag v-if="shopOrder.sendOutStatus*1===2" type="warning" size="small">部分发货</el-tag>
  92. <el-tag v-if="shopOrder.sendOutStatus*1===3" type="success" size="small">已发货</el-tag>
  93. </el-col>
  94. </el-row>
  95. <el-row :gutter="22" class="box-row">
  96. <el-col :span="22"><b>留言:</b> {{ shopOrder.note ? shopOrder.note : '无' }}</el-col>
  97. </el-row>
  98. <el-row :gutter="22" class="box-row">
  99. <el-col :span="22"><b>供应商:</b> {{ shopOrder.shopName }}</el-col>
  100. </el-row>
  101. <el-row v-for="op in shopOrder.newOrderProducts" :key="op.orderProductID" :gutter="22" class="product-row">
  102. <el-col :span="2">
  103. <img :src="op.productImage" width="60" alt="">
  104. </el-col>
  105. <el-col :span="7">{{ op.name }}</el-col>
  106. <el-col :span="5">
  107. <div class="op-item"><b>数量</b>{{ op.productID*1!==999 ? ('(赠品数): x'+op.num+'('+op.presentNum+')') : (': x'+op.num) }}</div>
  108. <div v-if="op.productID*1!==999" class="op-item">规格: {{ op.unit }}</div>
  109. </el-col>
  110. <el-col v-if="op.productID*1!==999" :span="5">
  111. <div class="op-item"><b>单价:</b> ¥{{ op.price | toThousandFilter }}</div>
  112. <div class="op-item"><b>总额:</b> ¥{{ op.totalFee | toThousandFilter }}</div>
  113. </el-col>
  114. <el-col v-if="op.productID*1!==999" :span="5">
  115. <div v-if="order.sendOutStatus*1 === 2 || order.sendOutStatus*1 === 3" class="op-item"><b>已发/已收:</b> {{ ((op.num ? op.num : 0) - (op.notOutStore ? op.notOutStore : 0)) + '/' + op.receivedNum }}</div>
  116. </el-col>
  117. </el-row>
  118. </div>
  119. </el-card>
  120. <Remarks dialog-title="订单备注信息" :is-visible.sync="dialogRemarksVisible" :order-id="dialogRemarksOrderId" :remark-list="dialogRemarkList" />
  121. <template>
  122. <el-backtop style="right: 40px; bottom: 40px;">
  123. <i class="el-icon-upload2" />
  124. </el-backtop>
  125. </template>
  126. </div>
  127. </template>
  128. <script>
  129. import { getDetail, getRemarks } from '@/api/order'
  130. import Remarks from './components/remarks'
  131. export default {
  132. components: { Remarks },
  133. data() {
  134. return {
  135. activeIndex: '2',
  136. order: null,
  137. receiptAmount: 0,
  138. returnValue: 0,
  139. returnedPurchaseFee: 0,
  140. bpClauses: null,
  141. dialogRemarkList: [],
  142. dialogRemarksVisible: false,
  143. dialogRemarksOrderId: 0,
  144. statusObj: {
  145. '0': '待确认',
  146. '4': '交易完成',
  147. '5': '订单完成',
  148. '6': '已关闭',
  149. '7': '交易全退',
  150. '11': '待收待发',
  151. '12': '待收部发',
  152. '13': '待收全发',
  153. '21': '部收待发',
  154. '22': '部收部发',
  155. '23': '部收全发',
  156. '31': '已收待发',
  157. '32': '已收部发',
  158. '33': '已收全发'
  159. }
  160. }
  161. },
  162. computed: {
  163. orderID: function() {
  164. return window.location.href.split('/').reverse()[0] * 1
  165. }
  166. },
  167. created() {
  168. this.fetchData()
  169. },
  170. methods: {
  171. fetchData() {
  172. this.listLoading = true
  173. getDetail({ id: this.orderID }).then(response => {
  174. this.order = response.data.order
  175. this.bpClauses = response.data.bpClauses
  176. this.receiptAmount = response.data.receiptAmount
  177. this.returnValue = response.data.returnValue
  178. this.returnedPurchaseFee = response.data.returnedPurchaseFee
  179. this.listLoading = false
  180. }).catch(() => {
  181. this.listLoading = false
  182. })
  183. },
  184. RemarksOrder: function(id) {
  185. getRemarks({ orderID: id }).then(response => {
  186. this.dialogRemarkList = response.data
  187. })
  188. this.dialogRemarksOrderId = id
  189. this.dialogRemarksVisible = true
  190. },
  191. backToList() {
  192. this.$store.dispatch('tagsView/delView', this.$route).then(() => {
  193. this.$nextTick(() => {
  194. this.$router.replace({
  195. path: '/order/list'
  196. })
  197. })
  198. })
  199. }
  200. }
  201. }
  202. </script>
  203. <style scoped>
  204. .box-card{
  205. margin-top: 20px;
  206. font-size: 14px;
  207. }
  208. .box-row{
  209. padding: 10px 0;
  210. }
  211. .box-row .dropdown{
  212. margin-top: -10px;
  213. }
  214. .order-item{
  215. border-bottom: 1px solid #DCDFE6;
  216. background:#F2F6FC;
  217. margin-top: 20px;
  218. padding: 5px 15px 0;
  219. border-radius: 5px;
  220. }
  221. .product-row{
  222. padding: 10px 0;
  223. background: #EBEEF5;
  224. border-top: 1px dashed #DCDFE6;
  225. }
  226. .op-item{
  227. padding: 5px 0;
  228. }
  229. </style>