lilishop-uniapp/pages/promotion/point/detail.vue

217 lines
4.5 KiB
Vue
Raw Normal View History

<template>
<div class="page">
<u-navbar :border-bottom="false" title="积分商品"></u-navbar>
<div class="wrapper">
2021-07-30 08:02:13 +08:00
<!-- 积分商品列表 -->
<div class="box box1">
<div class="bargain">
<div class="row-title">商品信息</div>
<div class="flex row-item">
<div class="goods-img">
<u-image width="200" height="200" :src="goodsData.thumbnail"></u-image>
</div>
<div class="goods-config">
<div class="goods-title wes-2">
{{goodsData.goodsName}}
</div>
<div class="flex price-box">
<div class="purchase-price">积分:<span>{{ pointDetail.points | unitPrice }}</span>
</div>
<div class="max-price">原价:<span>{{ goodsData.price | unitPrice}}</span>
</div>
</div>
<div class="tips">{{goodsData.sellingPoint}}</div>
</div>
</div>
<div class="buy" @click="getGoodsDetail">
立即购买
</div>
</div>
</div>
<!-- 产品详情 -->
<div class="box box3">
<div class="bargain">
<div class="row-title">商品详情</div>
<view class="u-content">
<u-parse :html="goodsData.mobileIntro"></u-parse>
</view>
</div>
</div>
<!-- 购买 -->
<popupGoods ref="popupGoods" :goodsSpec="goodsSpec" :buyMask="maskFlag" @closeBuy="closePopupBuy" :goodsDetail="goodsData" v-if="goodsData.id " @handleClickSku="getGoodsDetail" />
<div class="box4"></div>
</div>
</div>
</template>
<script>
import popupGoods from "@/components/m-buy/goods"; //购物车商品的模块
import { getPointsGoodsDetail } from "@/api/promotions";
export default {
components: {
popupGoods,
},
data() {
return {
maskFlag: false, //商品弹框
lightColor: this.$lightColor,
goodsData: {}, //积分商品中商品详情
pointDetail: {}, //积分商品详情
goodsDetail: {}, //商品详情
goodsSpec: {}, //商品规格
selectedGoods: {},
};
},
onLoad(options) {
this.routerVal = options;
},
onShow() {
this.init();
},
watch: {},
methods: {
// 购买积分商品
getGoodsDetail() {
uni.showLoading({
title: "加载中",
mask: true,
});
this.$refs.popupGoods.buy({
skuId: this.goodsData.id,
num: 1,
cartType: "POINTS",
});
},
// 初始化商品
async init() {
// 获取商品
let res = await getPointsGoodsDetail(this.routerVal.id);
if (res.data.success) {
this.goodsData = res.data.result.goodsSku;
this.pointDetail = res.data.result;
}
},
},
};
</script>
<style lang="scss">
</style>
<style lang="scss" scoped>
.page {
min-height: 100vh;
}
.slot-content {
display: flex;
align-items: flex-end;
justify-content: center;
margin: 20rpx 0 80rpx 0;
}
.price {
margin-left: 10rpx;
color: #44a88d;
}
.price-box {
align-items: center;
padding: 10rpx 0;
}
.box {
background: #fff;
border-radius: 20rpx;
position: relative;
margin: 40rpx auto;
> .bargain {
padding: 32rpx;
}
}
.row-item {
align-items: center;
}
.goods-config {
margin-left: 20rpx;
> .goods-title {
font-weight: bold;
}
}
.max-price,
.purchase-price {
font-size: 24rpx;
color: #999;
}
.max-price {
margin-left: 10rpx;
text-decoration: line-through;
}
.purchase-price {
color: #44a88d;
> span {
font-size: 32rpx;
font-weight: bold;
}
}
.buy {
font-size: 24rpx;
color: #fff;
width: 80%;
margin: 50rpx auto 0 auto;
text-align: center;
font-size: 30rpx;
background-image: linear-gradient(25deg, #00627d, #2d8485, #44a88d, #57ce93);
padding: 18rpx;
border-radius: 100px;
}
.line {
margin: 20rpx 0;
}
.tips {
font-size: 24rpx;
color: #999;
justify-content: space-between;
}
.row-progress {
margin: 20rpx 0;
}
.row-title {
font-size: 32rpx;
font-weight: bold;
color: #44a88d;
text-align: center;
margin-bottom: 40rpx;
}
.user-item {
margin: 40rpx 0;
align-items: center;
}
.user-config {
margin-left: 20rpx;
flex: 8;
align-items: center;
justify-content: space-between;
> .user-name {
> div:nth-of-type(1) {
font-size: 28rpx;
}
> div:nth-last-of-type(1) {
font-size: 24rpx;
color: #999;
}
}
}
.mobile-intro {
overflow: hidden;
max-width: 100%;
}
</style>