orderDetail.vue 14 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388
  1. <template>
  2. <view class="content">
  3. <view class="row b-b b-t" v-if="status._deliveryType == '快递配送'" @click="towuliu(item)">
  4. <text class="order-status" v-if="status._title == '待评价'">已完成</text>
  5. <text class="order-status" v-else-if="status._title == '申请退款中'">{{status._msg}}</text>
  6. <text class="order-status" v-else>{{ status ? status._msg : '' }}(查看物流)</text>
  7. </view>
  8. <view class="row b-b b-t" v-else>
  9. <text class="order-status" v-if="status._title == '待评价'">已完成</text>
  10. <text class="order-status" v-else-if="status._title == '申请退款中'">{{status._msg}}</text>
  11. <text class="order-status" v-else>{{ status ? status._msg : '' }}</text>
  12. </view>
  13. <view class="address-box position-relative">
  14. <view class="address-top flex">
  15. <view class="title">{{ item.real_name }}</view>
  16. <view class="phone">{{ item.user_phone }}</view>
  17. </view>
  18. <view class="addrdss-detail">{{ item.user_address }}</view>
  19. <image class="a-bg" :src="addressImg"></image>
  20. </view>
  21. <view class="order-item">
  22. <view class="goods-box-single" v-for="(goodsItem, goodsIndex) in item.cartInfo" :key="goodsIndex">
  23. <image class="goods-img" :src="goodsItem.productInfo.image" mode="aspectFill"></image>
  24. <view class="right position-relative">
  25. <view class="flex">
  26. <text class="title">{{ goodsItem.productInfo.store_name }}</text>
  27. <view class="title-right">
  28. <view class="price">{{ goodsItem.productInfo.price }}</view>
  29. <view class="attr-box">{{ goodsItem.attrInfo ? goodsItem.attrInfo.suk : '' }} x {{ goodsItem.cart_num + '' + goodsItem.productInfo.unit_name }}</view>
  30. </view>
  31. </view>
  32. </view>
  33. </view>
  34. </view>
  35. <view class="row b-b flex">
  36. <text class="tit">订单总价</text>
  37. <view class="input">¥{{ item.total_price }}</view>
  38. </view>
  39. <view class="row b-b flex">
  40. <text class="tit">邮费</text>
  41. <view class="input">{{ item.pay_postage > 0 ? '¥' + item.pay_postage : '免邮费' }}</view>
  42. </view>
  43. <view class="row b-b flex" v-if="item.coupon_id > 0">
  44. <text class="tit">优惠券</text>
  45. <view class="input">-¥{{ item.coupon_price }}</view>
  46. </view>
  47. <view class="row b-b flex" v-if="item.use_integral > 0">
  48. <text class="tit">积分抵扣</text>
  49. <view class="input">-¥{{ item.use_integral }}</view>
  50. </view>
  51. <view class="row b-b flex">
  52. <text class="tit ">实付</text>
  53. <view class="input payColor">¥{{ item.pay_price }}</view>
  54. </view>
  55. <view class="orderDetialBox">
  56. <view class="f-header m-t">
  57. <view class="f-left-icon"></view>
  58. <view class="tit-box"><text class="tit">订单信息</text></view>
  59. </view>
  60. <view class="item flex">
  61. <view class="title-left flex">
  62. <text class="title">订单编号:</text>
  63. <view class="text">{{ item.order_id }}</view>
  64. </view>
  65. <view class="buttom-right" @click="copyOrderId(item.order_id)">复制单号</view>
  66. </view>
  67. <view class="item flex">
  68. <view class="title-left flex">
  69. <text class="title">下单时间:</text>
  70. <view class="text">{{ item._add_time }}</view>
  71. </view>
  72. </view>
  73. <view class="item flex">
  74. <view class="title-left flex">
  75. <text class="title">订单类型:</text>
  76. <view class="text">{{ item | orderType }}</view>
  77. </view>
  78. </view>
  79. <view class="item flex">
  80. <view class="title-left flex">
  81. <text class="title">订单状态:</text>
  82. <view class="text" v-if="status._title == '待评价'">已完成</view>
  83. <!-- <view class="text" v-else-if="status._title == '申请退款中'">{{status._title}}</view> -->
  84. <view class="text" v-else>{{ status._title }}</view>
  85. </view>
  86. </view>
  87. <view class="item flex">
  88. <view class="title-left flex">
  89. <text class="title">支付方式:</text>
  90. <view class="text">{{ status._payType }}</view>
  91. </view>
  92. </view>
  93. </view>
  94. <view class="orderDetialBox" v-if="item.delivery_id">
  95. <view class="item flex">
  96. <view class="title-left flex">
  97. <text class="title">配送方式:</text>
  98. <view class="text">{{ item.delivery_type=='express'?'发货':item.delivery_type=='send'?'送货':'' }}</view>
  99. </view>
  100. </view>
  101. <view class="item flex">
  102. <view class="title-left flex">
  103. <text class="title">快递公司:</text>
  104. <view class="text">{{ item.delivery_name }}</view>
  105. </view>
  106. <view v-if="status._deliveryType == '快递配送'" class="buttom-right" @click="towuliu(item)">查看物流</view>
  107. </view>
  108. <view class="item flex">
  109. <view class="title-left flex">
  110. <text class="title">快递单号:</text>
  111. <view class="text">{{ item.delivery_id }}</view>
  112. </view>
  113. </view>
  114. </view>
  115. </view>
  116. </template>
  117. <script>
  118. import { orderDetail } from '@/api/order.js';
  119. export default {
  120. filters: {
  121. orderType: function(item) {
  122. if (item.combination_id > 0) {
  123. return '拼团订单';
  124. } else if (item.seckill_id > 0) {
  125. return '秒杀订单';
  126. } else if (item.bargain_id > 0) {
  127. return '砍价订单';
  128. } else {
  129. return '普通订单';
  130. }
  131. }
  132. },
  133. data() {
  134. return {
  135. refund: '', //退款理由
  136. status:'',
  137. reason: '', //备注
  138. value: ['1', '2', '3', '4', '5', '6', '7', '8', 9, 10, 11, 12, 13],
  139. orderId: '',
  140. item: {},
  141. addressImg:
  142. ''
  143. };
  144. },
  145. onLoad(option) {
  146. this.orderId = option.id;
  147. this.loadOrder();
  148. },
  149. methods: {
  150. // 载入订单详细
  151. loadOrder() {
  152. orderDetail({}, this.orderId).then(e => {
  153. console.log(e,555)
  154. this.item = e.data;
  155. this.status = e.data._status;
  156. console.log(this.status);
  157. });
  158. },
  159. towuliu(item){
  160. let delivery_id = item.delivery_id;
  161. console.log(delivery_id,55)
  162. window.location.href = "https://m.kuaidi100.com/result.jsp?nu="+ delivery_id
  163. },
  164. // 复制订单编号
  165. copyOrderId(text) {
  166. // #ifndef H5
  167. uni.setClipboardData({
  168. data: text,
  169. success: e => {
  170. uni.showToast({
  171. title: '复制成功',
  172. duration: 1500,
  173. icon:'none'
  174. });
  175. }
  176. });
  177. // #endif
  178. // #ifdef H5
  179. let inputH = document.querySelector('#copyOrder input');
  180. // 获取需要复制的文字
  181. const copyStr = text;
  182. // 创建input标签存放需要复制的文字
  183. const oInput = document.createElement('input');
  184. // 把文字放进input中,供复制
  185. oInput.value = copyStr;
  186. // 添加文
  187. document.body.appendChild(oInput);
  188. // 选中创建的input
  189. oInput.select();
  190. // 执行复制方法, 该方法返回bool类型的结果,告诉我们是否复制成功
  191. const copyResult = document.execCommand('copy');
  192. // 操作中完成后 从Dom中删除创建的input
  193. document.body.removeChild(oInput);
  194. // 根据返回的复制结果 给用户不同的提示
  195. if (copyResult) {
  196. uni.showToast({
  197. title: '已复制到粘贴板',
  198. duration: 2000,
  199. icon: 'none',
  200. });
  201. } else {
  202. this.$api.msg('复制失败');
  203. }
  204. // #endif
  205. }
  206. }
  207. };
  208. </script>
  209. <style lang="scss">
  210. page {
  211. background: $page-color-base;
  212. }
  213. // 订单详细
  214. .orderDetialBox {
  215. margin-top: 20rpx;
  216. padding: 0 30rpx;
  217. background-color: #ffffff;
  218. font-size: $font-base;
  219. color: $font-color-base;
  220. .item {
  221. height: 80rpx;
  222. .text {
  223. padding-left: 10rpx;
  224. }
  225. .buttom-right {
  226. width: 180rpx;
  227. border-radius: 99rpx;
  228. padding: 10rpx;
  229. text-align: center;
  230. border: 1px solid $border-color-light;
  231. }
  232. }
  233. }
  234. // 地址信息
  235. .address-box {
  236. margin-top: 20rpx;
  237. padding: 30rpx;
  238. padding-bottom: 35rpx;
  239. background-color: #ffffff;
  240. line-height: 1;
  241. .address-top {
  242. margin-bottom: 30rpx;
  243. .title {
  244. font-size: $font-lg;
  245. color: $font-color-dark;
  246. }
  247. .phone {
  248. font-size: $font-base;
  249. color: $font-color-light;
  250. }
  251. }
  252. .addrdss-detail {
  253. font-size: $font-base;
  254. color: $font-color-base;
  255. }
  256. .a-bg {
  257. position: absolute;
  258. bottom: 0;
  259. left: 0;
  260. width: 100%;
  261. height: 5rpx;
  262. }
  263. }
  264. .row {
  265. display: flex;
  266. align-items: center;
  267. position: relative;
  268. padding: 0 30rpx;
  269. height: 80rpx;
  270. background: #fff;
  271. .order-status {
  272. font-size: $font-lg;
  273. color: $color-red;
  274. font-weight: 500;
  275. }
  276. .refund {
  277. font-size: 30rpx;
  278. color: $font-color-dark;
  279. }
  280. .noRefund {
  281. font-size: 30rpx;
  282. color: $font-color-light;
  283. }
  284. .tit {
  285. flex-shrink: 0;
  286. width: 120rpx;
  287. font-size: 30rpx;
  288. color: $font-color-dark;
  289. }
  290. .input {
  291. text-align: right;
  292. flex: 1;
  293. font-size: 30rpx;
  294. color: $font-color-dark;
  295. &.payColor {
  296. color: $color-red;
  297. }
  298. }
  299. .iconlocation {
  300. font-size: 36rpx;
  301. color: $font-color-light;
  302. }
  303. }
  304. .add-btn {
  305. display: flex;
  306. align-items: center;
  307. justify-content: center;
  308. width: 690rpx;
  309. height: 80rpx;
  310. margin: 60rpx auto;
  311. font-size: $font-lg;
  312. color: #fff;
  313. background-color: $base-color;
  314. border-radius: 10rpx;
  315. // box-shadow: 1px 2px 5px rgba(219, 63, 96, 0.4);
  316. }
  317. /* 多条商品 */
  318. .order-item {
  319. display: flex;
  320. flex-direction: column;
  321. padding-left: 30rpx;
  322. background: #fff;
  323. margin-top: 20rpx;
  324. /* 单条商品 */
  325. .goods-box-single {
  326. display: flex;
  327. padding: 20rpx 0;
  328. .goods-img {
  329. display: block;
  330. width: 120rpx;
  331. height: 120rpx;
  332. }
  333. .right {
  334. flex: 1;
  335. display: flex;
  336. flex-direction: column;
  337. padding: 0 30rpx 0 24rpx;
  338. overflow: hidden;
  339. height: 100%;
  340. .title {
  341. align-self: flex-start;
  342. font-size: $font-base + 2rpx;
  343. color: $font-color-dark;
  344. }
  345. .title-right {
  346. flex-shrink: 0;
  347. text-align: right;
  348. align-self: flex-start;
  349. }
  350. .attr-box {
  351. font-size: $font-sm + 2rpx;
  352. color: $font-color-light;
  353. }
  354. .price {
  355. font-size: $font-base + 2rpx;
  356. color: $font-color-dark;
  357. &:before {
  358. content: '¥';
  359. font-size: $font-sm;
  360. margin: 0 2rpx 0 8rpx;
  361. }
  362. }
  363. }
  364. }
  365. }
  366. // 标题头
  367. .f-header {
  368. display: flex;
  369. align-items: center;
  370. height: 80rpx;
  371. .tit-box {
  372. @extend %font-title-box;
  373. }
  374. .tit {
  375. @extend %font-title;
  376. }
  377. .f-left-icon {
  378. @extend %f-left-icon;
  379. }
  380. }
  381. </style>