order-detail.vue 4.94 KB
<template>
  <div class="order-detail-wrapper">
    <div class="content">
      <!-- 状态信息 -->
      <div class="status-info">
        <p class="status">{{ statusDetail.statuStr }}</p>
        <p class="status-desc">{{ statusDetail.detailDesc }}</p>
      </div>
      <!-- 物流信息 -->
      <div class="logistics-info item-wrapper">
        <div class="content">
          <i class="logistics-icon"></i>
          <div class="info">
            <p>{{ lastExpressInfo.acceptRemark }}</p>
            <p>{{ lastExpressInfo.createTimeStr }}</p>
          </div>
        </div>
        <i class="right-icon"></i>
      </div>
      <!-- 地址信息 -->
      <address-info class="item-wrapper" />
      <!-- 商品信息 -->
      <order-item-info class="item-wrapper" />
      <!-- 价格信息 -->
      <div class="price-info item-wrapper">
        <p>
          <span class="label">商品金额:</span>
          <span>¥{{ priceInfo.goodPrice }}</span>
        </p>
        <p class="delivery-fee">
          <span class="label">运费:</span>
          <span>¥{{ priceInfo.feePrice }}</span>
        </p>
        <p>
          <span class="label">实际金额:</span>
          <span class="pay-price">¥{{ priceInfo.realPayPrice }}</span>
        </p>
      </div>
      <!-- 交易信息 -->
      <div class="trade-info item-wrapper">
        <p>
          <span class="label">创建时间:</span>
          <span>{{ orderDetail.createTime }}</span>
        </p>
        <p>
          <span class="label">订单编号:</span>
          <span>{{ orderDetail.orderCode }}</span>
        </p>
        <p>
          <span class="label">支付方式:</span>
          <span>{{ orderDetail.paymentStr }}</span>
        </p>
      </div>
    </div>
    <!-- 操作 -->
    <div class="actions">
      <Button v-for="actionInfo in actionList" :key="actionInfo.code">{{
        actionInfo.text
      }}</Button>
    </div>
  </div>
</template>

<script>
import { createNamespacedHelpers } from "vuex";
import AddressInfo from "./components/address-info";
import OrderItemInfo from "./components/order-detail-item";
import { Button } from "cube-ui";

const { mapActions, mapState, mapGetters } = createNamespacedHelpers(
  "order/orderDetail"
);
export default {
  components: {
    AddressInfo,
    OrderItemInfo,
    Button
  },
  asyncData({ store, router }) {
    // store.dispatch("order/orderDetail/fetchOrderDetail", router.params);
  },
  mounted() {
    this.fetchOrderDetail(this.$route.params);
  },
  computed: {
    ...mapState(["orderDetail"]),
    ...mapGetters([
      "statusDetail",
      "lastExpressInfo",
      "priceInfo",
      "actionList"
    ])
  },
  methods: {
    ...mapActions(["fetchOrderDetail"])
  }
};
</script>

<style lang="scss" scoped>
.order-detail-wrapper {
  // footer高度120px
  padding: 24px 40px 144px 40px;
  -webkit-box-orient: vertical;
  height: 100vh;
  overflow-x: hidden;
  overflow-y: auto;
  font-size: 24px;

  .item-wrapper {
    border-top: 1px solid #eee;
    padding: 40px 0;
  }

  .status-info {
    .status {
      font-size: 68px;
      color: #000;
      letter-spacing: 0.82px;
      line-height: 82px;
      font-weight: bold;
    }

    .status-desc {
      color: #999;
      letter-spacing: 0;
      margin-top: 30px;
    }
  }

  .logistics-info {
    margin-top: 40px;
    display: flex;
    align-items: center;
    justify-content: space-between;

    .content {
      display: flex;
      align-items: center;

      .info :last-child {
        color: #999;
        margin-top: 12px;
      }
    }

    .logistics-icon,
    .right-icon {
      width: 48px;
      height: 48px;
      display: block;
      background-size: contain;
    }

    .logistics-icon {
      margin-right: 40px;
      background-image: url("~statics/image/order/logistics-icon@3x.png");
    }

    .right-icon {
      background-image: url("~statics/image/order/right-arrow-icon@3x.png");
    }
  }

  .price-info {
    font-size: 28px;

    & > p {
      display: flex;
      justify-content: space-between;
    }

    & > p:first-child {
      color: #999;
    }

    .delivery-fee {
      margin: 12px 0;
      color: #999;
    }

    .pay-price {
      color: #d0021b;
    }
  }

  .trade-info {
    font-size: 28px;

    & > :first-child + p {
      margin: 20px 0;
    }
  }

  .label {
    font-size: 28px;
    margin-right: 12px;
  }

  .actions {
    display: flex;
    justify-content: flex-end;
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    height: 120px;
    background: #fff;
    box-shadow: inset 0 1px 0 0 #eee;
    padding: 20px;
    z-index: 10;

    button {
      font-size: 24px;
      padding: 24px 64px 22px 64px;
      color: #999;
      letter-spacing: 0;
      border-radius: 0;
      background: #fff;
      border: 1px solid #ccc;
      line-height: 1.3;
      width: 224px;
      margin-right: 20px;
    }

    & :last-child {
      background: #002b47;
      color: #fff;
      border: 1px solid #002b47;
      margin-right: 0;
    }
  }
}
</style>