seller-order-detail.vue 8.43 KB
<template>
  <layout-app>
    <div class="order-detail-wrapper">
      <div class="content">
        <!-- 状态信息 -->
        <detail-header />
        <!-- 物流信息 -->
        <router-link
          v-if="lastExpressInfo"
          :to="{ name: 'orderLogisticsInfo', params: $route.params }"
        >
          <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>
        </router-link>
        <!-- 地址信息 -->
        <address-info class="item-wrapper" />
        <!-- 商品信息 -->
        <order-item-info class="item-wrapper" />
        <!-- 价格信息 -->
        <div class="price-info item-wrapper">
          <p>
            <span class="label">平台费用:</span>
            <span>{{ platformFee.amount }}</span>
          </p>
          <p class="delivery-fee">
            <span class="label"
              >银行转账费({{
                parseInt(platformFee.payChannelPercentage)
              }}%):</span
            >
            <span>{{ orderDetail.bankTransferFee }}</span>
          </p>
          <p>
            <span class="label">实际收入:</span>
            <span class="pay-price">{{ orderDetail.income }}</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 v-if="orderDetail.paymentStr">
            <span class="label">支付方式:</span>
            <span>{{ orderDetail.paymentStr }}</span>
          </p>
          <p v-if="orderDetail.earnestMoneyStr">
            <span class="label">保证金:</span>
            <span class="earnest-price">{{ orderDetail.earnestMoneyStr }}</span>
          </p>
          <p v-if="statusDetail.paymentTips">
            <span class="payment-tip">{{ statusDetail.paymentTips }}</span>
          </p>
        </div>
      </div>
      <!-- 操作 -->
      <!-- <detail-footer>
        <template #tip="{orderDetail, statusDetail}">
          <div v-if="statusDetail.status === 0">
            <p class="earnest-price">{{ orderDetail.earnestMoneyStr }}</p>
            <p>{{ statusDetail.statuStr }}</p>
          </div>
        </template>
      </detail-footer> -->

      <div v-if="actionList.length > 0" class="footer-wrapper">
        <div v-if="statusDetail.status === 0">
          <p class="earnest-price">{{ orderDetail.earnestMoneyStr }}</p>
          <p>{{ statusDetail.statuStr }}</p>
        </div>
        <order-actions
          class="detail-actions"
          :order="orderDetail"
          @on-action="action => onAction({ action, order: orderDetail })"
        />
      </div>
    </div>
  </layout-app>
</template>

<script>
import { createNamespacedHelpers } from "vuex";
import { Button } from "cube-ui";

import AddressInfo from "./components/address-info";
import OrderItemInfo from "./components/order-detail-item";
import DetailHeader from "./components/header";
import DetailFooter from "./components//detail-footer";

import OrderActions from "../components/order-actions";
import CancelConfirmInfo from "../components/order-list/cancel-confirm-info";

import {
  orderActionsMap,
  ownType
} from "../../../../constants/order-constants";

const { mapActions, mapState, mapGetters } = createNamespacedHelpers(
  "order/orderDetail"
);

const { mapActions: orderListMapActions } = createNamespacedHelpers(
  "order/orderList"
);
export default {
  components: {
    AddressInfo,
    OrderItemInfo,
    Button,
    DetailHeader,
    DetailFooter,
    OrderActions
  },
  asyncData({ store, router }) {
    // store.dispatch("order/orderDetail/fetchOrderDetail", router.params);
  },
  mounted() {},
  activated() {
    this.fetchOrderDetail(this.$route.params);
  },
  computed: {
    ...mapState(["orderDetail"]),
    ...mapGetters([
      "lastExpressInfo",
      "priceInfo",
      "statusDetail",
      "platformFee",
      "actionList"
    ])
  },
  methods: {
    ...mapActions(["fetchOrderDetail"]),
    ...orderListMapActions([
      "cancelTradeConfirmInfo",
      "cancelTrade",
      "deleteOrder"
    ]),
    async onAction({ action, order }) {
      console.log("----------action---------", action);
      const { owner = ownType.SELL } = this.$route.params;
      const {
        orderCode,
        earnestMoney = 0,
        realPrice = "",
        priceInfo = {}
      } = order;

      const { productId, storageId, skup } = order.goodsInfo;

      switch (action.name) {
        // 删除订单
        case orderActionsMap.DEL_ORDER.name:
          this.$createDialog({
            type: "confirm",
            content: "确认删除订单?",
            onConfirm: async () => {
              const isOk = await this.deleteOrder({
                orderCode,
                owner
              });
              if (isOk) {
                this.$router.back();
              }
              // const txt = isOk ? "删除成功" : "删除失败";
              // this.$createToast({ txt, type: "txt" }).show();
            }
          }).show();
          break;
        case orderActionsMap.NOT_SOLD.name:
          const confirmInfo = await this.cancelTradeConfirmInfo({
            orderCode,
            owner
          });
          this.$createDialog(
            {
              type: "confirm",
              confirmBtn: { text: "不卖了" },
              cancelBtn: { text: "继续出售" },
              onConfirm: async () => {
                const isOk = await this.cancelTrade({
                  orderCode,
                  owner
                });
                if (isOk) {
                  this.fetchOrderDetail(this.$route.params);
                }
                // const txt = isOk ? "取消成功" : "取消失败";
                // this.$createToast({ txt, type: "txt" }).show();
              }
            },
            createElement => {
              return [
                createElement(CancelConfirmInfo, {
                  slot: "content",
                  props: { confirmInfo }
                })
              ];
            }
          ).show();
          break;
        default:
          return;
      }
    }
  }
};
</script>

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

  .footer-wrapper {
    display: flex;
    justify-content: space-between;
    align-items: center;
    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;

    .detail-actions {
      margin-top: 0;
      flex: 1;
    }
  }

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

  .earnest-price {
    font-size: 28px;
    color: #d0021b;
  }

  .logistics-info {
    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;

    & > p {
      margin: 20px 0;
    }

    & > p:first-child {
      margin-top: 0;
    }

    .earnest-price {
      color: #d0021b;
    }

    .payment-tip {
      font-size: 24px;
      color: #999;
    }
  }

  .label {
    font-size: 28px;
    margin-right: 12px;
  }
}
</style>