detail.vue 10 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233
  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" round>
  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. </div>
  122. </template>
  123. <script>
  124. import { getDetail, getRemarks } from '@/api/order'
  125. import Remarks from './components/remarks'
  126. export default {
  127. components: { Remarks },
  128. data() {
  129. return {
  130. activeIndex: '2',
  131. order: null,
  132. receiptAmount: 0,
  133. returnValue: 0,
  134. returnedPurchaseFee: 0,
  135. bpClauses: null,
  136. dialogRemarkList: [],
  137. dialogRemarksVisible: false,
  138. dialogRemarksOrderId: 0,
  139. statusObj: {
  140. '0': '待确认',
  141. '4': '交易完成',
  142. '5': '订单完成',
  143. '6': '已关闭',
  144. '7': '交易全退',
  145. '11': '待收待发',
  146. '12': '待收部发',
  147. '13': '待收全发',
  148. '21': '部收待发',
  149. '22': '部收部发',
  150. '23': '部收全发',
  151. '31': '已收待发',
  152. '32': '已收部发',
  153. '33': '已收全发'
  154. }
  155. }
  156. },
  157. computed: {
  158. orderID: function() {
  159. return window.location.href.split('/').reverse()[0] * 1
  160. }
  161. },
  162. created() {
  163. this.fetchData()
  164. },
  165. methods: {
  166. fetchData() {
  167. this.listLoading = true
  168. getDetail({ id: this.orderID }).then(response => {
  169. this.order = response.data.order
  170. this.bpClauses = response.data.bpClauses
  171. this.receiptAmount = response.data.receiptAmount
  172. this.returnValue = response.data.returnValue
  173. this.returnedPurchaseFee = response.data.returnedPurchaseFee
  174. this.listLoading = false
  175. }).catch(() => {
  176. this.listLoading = false
  177. })
  178. },
  179. RemarksOrder: function(id) {
  180. getRemarks({ orderID: id }).then(response => {
  181. this.dialogRemarkList = response.data
  182. })
  183. this.dialogRemarksOrderId = id
  184. this.dialogRemarksVisible = true
  185. },
  186. backToList() {
  187. this.$store.dispatch('tagsView/delView', this.$route).then(() => {
  188. this.$nextTick(() => {
  189. this.$router.replace({
  190. path: '/order/list'
  191. })
  192. })
  193. })
  194. }
  195. }
  196. }
  197. </script>
  198. <style scoped>
  199. .box-card{
  200. margin-top: 20px;
  201. font-size: 14px;
  202. }
  203. .box-row{
  204. padding: 10px 0;
  205. }
  206. .box-row .dropdown{
  207. margin-top: -10px;
  208. }
  209. .order-item{
  210. border-bottom: 1px solid #DCDFE6;
  211. background:#F2F6FC;
  212. margin-top: 20px;
  213. padding: 5px 15px 0;
  214. border-radius: 5px;
  215. }
  216. .product-row{
  217. padding: 10px 0;
  218. background: #EBEEF5;
  219. border-top: 1px dashed #DCDFE6;
  220. }
  221. .op-item{
  222. padding: 5px 0;
  223. }
  224. </style>