【功能完善】商品列表,增加满减送提示(优化)

pull/102/MERGE
YunaiV 2024-09-16 19:30:56 +08:00
parent 9df0194aeb
commit ff6769001d
7 changed files with 157 additions and 323 deletions

View File

@ -60,12 +60,14 @@
</s-layout> </s-layout>
</template> </template>
<script setup> <script setup>
import { reactive, toRaw, ref } from 'vue'; import { reactive } from 'vue';
import { onLoad, onReachBottom } from '@dcloudio/uni-app'; import { onLoad, onReachBottom } from '@dcloudio/uni-app';
import sheep from '@/sheep'; import sheep from '@/sheep';
import _ from 'lodash-es'; import _ from 'lodash-es';
import RewardActivityApi from '@/sheep/api/promotion/rewardActivity'; import RewardActivityApi from '@/sheep/api/promotion/rewardActivity';
import SpuApi from '@/sheep/api/product/spu'; import SpuApi from '@/sheep/api/product/spu';
import { appendSettlementProduct } from '@/sheep/hooks/useGoods';
import OrderApi from '@/sheep/api/trade/order';
const state = reactive({ const state = reactive({
activityId: 0, // activityId: 0, //
@ -105,128 +107,36 @@
// //
async function getList() { async function getList() {
// state.loadStatus = 'loading';
// //
const params = {}; const params = {};
if (state.activityInfo.productScope === 2) { if (state.activityInfo.productScope === 2) {
// const params = toRaw(state.activityInfo.productScopeValues) params.ids = state.activityInfo.productSpuIds.join(',');
//
const { code, data } = await SpuApi.getSpuListByIds(
state.activityInfo.productScopeValues.join(','),
);
if (code !== 0) {
return;
}
// 使 map id
const ids = data.map((item) => item.id);
// 使 join id
const idsString = ids.join(',');
//
settleData.value = await getSettlementByIds(idsString);
//
const ms = enrichDataWithSkus(data, settleData.value);
state.pagination.list = ms;
// state.pagination.total = data.total;
// state.loadStatus = state.pagination.list.length < state.pagination.total ? 'more' : 'noMore';
} else if (state.activityInfo.productScope === 3) { } else if (state.activityInfo.productScope === 3) {
params.categoryIds = state.activityInfo.productScopeValues.join(','); params.categoryIds = state.activityInfo.productSpuIds.join(',');
state.loadStatus = 'loading';
const { code, data } = await SpuApi.getSpuPage({
pageNo: state.pagination.pageNo,
pageSize: state.pagination.pageSize,
...params,
});
if (code !== 0) {
return;
}
// 使 map id
const ids = data.list.map((item) => item.id);
// 使 join id
const idsString = ids.join(',');
//
settleData.value = await getSettlementByIds(idsString);
//
const ms = enrichDataWithSkus(data.list, settleData.value);
state.pagination.list = _.concat(state.pagination.list, ms);
state.pagination.total = data.total;
state.loadStatus = state.pagination.list.length < state.pagination.total ? 'more' : 'noMore';
} else {
state.loadStatus = 'loading';
const { code, data } = await SpuApi.getSpuPage({
pageNo: state.pagination.pageNo,
pageSize: state.pagination.pageSize,
});
if (code !== 0) {
return;
}
// 使 map id
const ids = data.list.map((item) => item.id);
// 使 join id
const idsString = ids.join(',');
//
settleData.value = await getSettlementByIds(idsString);
//
const ms = enrichDataWithSkus(data.list, settleData.value);
state.pagination.list = _.concat(state.pagination.list, ms);
state.pagination.total = data.total;
state.loadStatus = state.pagination.list.length < state.pagination.total ? 'more' : 'noMore';
} }
//
state.loadStatus = 'loading';
const { code, data } = await SpuApi.getSpuPage({
pageNo: state.pagination.pageNo,
pageSize: state.pagination.pageSize,
...params,
});
if (code !== 0) {
return;
}
//
await OrderApi.getSettlementProduct(data.list.map((item) => item.id).join(',')).then((res) => {
if (res.code !== 0) {
return;
}
appendSettlementProduct(data.list, res.data);
});
state.pagination.list = _.concat(state.pagination.list, data.list);
state.pagination.total = data.total;
state.loadStatus = state.pagination.list.length < state.pagination.total ? 'more' : 'noMore';
mountMasonry(); mountMasonry();
} }
//
const settleData = ref();
async function getSettlementByIds(ids) {
const { data } = await SpuApi.getSettlementProduct(ids);
return data;
}
//
function enrichDataWithSkus(data, array) {
// id data
const dataMap = new Map(
data.map((item) => [
item.id,
{
...item,
},
]),
);
// array
array.forEach((item) => {
// discountPrice vipPrice null
let discountPrice = null;
let vipPrice = null;
let foundType4 = false;
let foundType6 = false;
// skus type 4 6
item.skus.forEach((sku) => {
if (!foundType4 && sku.type === 4) {
discountPrice = sku.price;
foundType4 = true;
}
if (!foundType6 && sku.type === 6) {
vipPrice = sku.price;
foundType6 = true;
}
// type 4 6
if (foundType4 && foundType6) {
return;
}
});
// dataMap
if (dataMap.has(item.id)) {
dataMap.get(item.id).discountPrice = discountPrice;
dataMap.get(item.id).vipPrice = vipPrice;
dataMap.get(item.id).reward = item.reward;
}
});
//
return Array.from(dataMap.values());
}
// //
async function getActivity(id) { async function getActivity(id) {
const { code, data } = await RewardActivityApi.getRewardActivity(id); const { code, data } = await RewardActivityApi.getRewardActivity(id);
@ -252,32 +162,28 @@
onLoad(async (options) => { onLoad(async (options) => {
state.activityId = options.activityId; state.activityId = options.activityId;
await getActivity(state.activityId); await getActivity(state.activityId);
await getList(); await getList(state.activityId);
}); });
</script> </script>
<style lang="scss" scoped> <style lang="scss" scoped>
.goods-list-box { .goods-list-box {
width: 50%; width: 50%;
box-sizing: border-box; box-sizing: border-box;
.left-list { .left-list {
margin-right: 10rpx; margin-right: 10rpx;
margin-bottom: 20rpx; margin-bottom: 20rpx;
} }
.right-list { .right-list {
margin-left: 10rpx; margin-left: 10rpx;
margin-bottom: 20rpx; margin-bottom: 20rpx;
} }
} }
.tip-box { .tip-box {
background: #fff0e7; background: #fff0e7;
padding: 20rpx; padding: 20rpx;
width: 100%; width: 100%;
position: relative; position: relative;
box-sizing: border-box; box-sizing: border-box;
.activity-left-image { .activity-left-image {
position: absolute; position: absolute;
bottom: 0; bottom: 0;
@ -285,7 +191,6 @@
width: 58rpx; width: 58rpx;
height: 36rpx; height: 36rpx;
} }
.activity-right-image { .activity-right-image {
position: absolute; position: absolute;
top: 0; top: 0;
@ -293,14 +198,12 @@
width: 72rpx; width: 72rpx;
height: 50rpx; height: 50rpx;
} }
.type-text { .type-text {
font-size: 26rpx; font-size: 26rpx;
font-weight: 500; font-weight: 500;
color: #ff6000; color: #ff6000;
line-height: 42rpx; line-height: 42rpx;
} }
.tip-content { .tip-content {
font-size: 26rpx; font-size: 26rpx;
font-weight: 500; font-weight: 500;

View File

@ -217,6 +217,7 @@
onPageScroll(() => {}); onPageScroll(() => {});
import countDown from '@/sheep/components/countDown/index.vue'; import countDown from '@/sheep/components/countDown/index.vue';
import OrderApi from '@/sheep/api/trade/order';
const bgColor = { const bgColor = {
bgColor: '#E93323', bgColor: '#E93323',
@ -323,7 +324,7 @@
} }
async function getSettlementByIds(ids) { async function getSettlementByIds(ids) {
let { data, code } = await SpuApi.getSettlementProduct(ids); let { data, code } = await OrderApi.getSettlementProduct(ids);
if (code !== 0 || data.length !== 1) { if (code !== 0 || data.length !== 1) {
return; return;
} }

View File

@ -124,6 +124,8 @@
import _ from 'lodash-es'; import _ from 'lodash-es';
import { resetPagination } from '@/sheep/util'; import { resetPagination } from '@/sheep/util';
import SpuApi from '@/sheep/api/product/spu'; import SpuApi from '@/sheep/api/product/spu';
import OrderApi from '@/sheep/api/trade/order';
import { appendSettlementProduct } from '@/sheep/hooks/useGoods';
const sys_navBar = sheep.$platform.navbar; const sys_navBar = sheep.$platform.navbar;
const emits = defineEmits(['close', 'change']); const emits = defineEmits(['close', 'change']);
@ -277,15 +279,14 @@
if (code !== 0) { if (code !== 0) {
return; return;
} }
// 使 map id //
const ids = data.list.map((item) => item.id); await OrderApi.getSettlementProduct(data.list.map((item) => item.id).join(',')).then((res) => {
// 使 join id if (res.code !== 0) {
const idsString = ids.join(','); return;
// }
settleData.value = await getSettlementByIds(idsString); appendSettlementProduct(data.list, res.data);
// });
const ms = enrichDataWithSkus(data.list, settleData.value); state.pagination.list = _.concat(state.pagination.list, data.list);
state.pagination.list = _.concat(state.pagination.list, ms);
state.pagination.total = data.total; state.pagination.total = data.total;
state.loadStatus = state.pagination.list.length < state.pagination.total ? 'more' : 'noMore'; state.loadStatus = state.pagination.list.length < state.pagination.total ? 'more' : 'noMore';
mountMasonry(); mountMasonry();
@ -300,57 +301,6 @@
getList(state.currentSort, state.currentOrder); getList(state.currentSort, state.currentOrder);
} }
//
const settleData = ref();
async function getSettlementByIds(ids) {
const { data } = await SpuApi.getSettlementProduct(ids);
return data;
}
//
function enrichDataWithSkus(data, array) {
// id data
const dataMap = new Map(data.map((item) => [item.id, { ...item }]));
// array
array.forEach((item) => {
// discountPrice vipPrice null
let discountPrice = null;
let vipPrice = null;
let foundType4 = false;
let foundType6 = false;
// skus type 4 6
item.skus.forEach((sku) => {
debugger;
if (!foundType4 && sku.promotionType === 4) {
discountPrice = sku.payPrice;
foundType4 = true;
}
if (!foundType6 && sku.promotionType === 6) {
vipPrice = sku.payPrice;
foundType6 = true;
}
// type 4 6
if (foundType4 && foundType6) {
return;
}
});
// dataMap
if (dataMap.has(item.spuId)) {
debugger;
dataMap.get(item.spuId).discountPrice = discountPrice;
dataMap.get(item.spuId).vipPrice = vipPrice;
dataMap.get(item.spuId).reward = item.rewardActivity;
}
});
//
return Array.from(dataMap.values());
}
onLoad((options) => { onLoad((options) => {
state.categoryId = options.categoryId; state.categoryId = options.categoryId;
state.keyword = options.keyword; state.keyword = options.keyword;

View File

@ -53,6 +53,18 @@ const OrderApi = {
}, },
}); });
}, },
// 获得商品结算信息
getSettlementProduct: (spuIds) => {
return request({
url: '/trade/order/settlement-product',
method: 'GET',
params: { spuIds },
custom: {
showLoading: false,
showError: false,
},
});
},
// 创建订单 // 创建订单
createOrder: (data) => { createOrder: (data) => {
return request({ return request({

View File

@ -141,9 +141,11 @@
/** /**
* 商品卡片 * 商品卡片
*/ */
import { computed, reactive, onMounted, ref } from 'vue'; import { computed, reactive, onMounted } from 'vue';
import sheep from '@/sheep'; import sheep from '@/sheep';
import SpuApi from '@/sheep/api/product/spu'; import SpuApi from '@/sheep/api/product/spu';
import OrderApi from '@/sheep/api/trade/order';
import { appendSettlementProduct } from '@/sheep/hooks/useGoods';
// //
const LayoutTypeEnum = { const LayoutTypeEnum = {
@ -234,61 +236,19 @@
return data; return data;
} }
//
const settleData = ref()
async function getSettlementByIds(ids) {
const { data } = await SpuApi.getSettlementProduct(ids);
return data;
}
//
async function enrichDataWithSkus(data, array) {
// id data
const dataMap = new Map(data.map(item => [item.id, { ...item }]));
// array
array.forEach(item => {
// discountPrice vipPrice null
let discountPrice = null;
let vipPrice = null;
let foundType4 = false;
let foundType6 = false;
// skus type 4 6
item.skus.forEach(sku => {
if (!foundType4 && sku.type === 4) {
discountPrice = sku.price;
foundType4 = true;
}
if (!foundType6 && sku.type === 6) {
vipPrice = sku.price;
foundType6 = true;
}
// type 4 6
if (foundType4 && foundType6) {
return;
}
});
// dataMap
if (dataMap.has(item.id)) {
dataMap.get(item.id).discountPrice = discountPrice;
dataMap.get(item.id).vipPrice = vipPrice;
dataMap.get(item.id).reward = item.reward;
}
});
//
return Array.from(dataMap.values());
}
// //
onMounted(async () => { onMounted(async () => {
// //
const ms = await getGoodsListByIds(spuIds.join(',')); state.goodsList = await getGoodsListByIds(spuIds.join(','));
settleData.value = await getSettlementByIds(spuIds.join(',')) //
state.goodsList = await enrichDataWithSkus(ms,settleData.value) await OrderApi.getSettlementProduct(state.goodsList.map((item) => item.id).join(',')).then(
(res) => {
if (res.code !== 0) {
return;
}
appendSettlementProduct(state.goodsList, res.data);
},
);
// //
if (layoutType === LayoutTypeEnum.TWO_COL) { if (layoutType === LayoutTypeEnum.TWO_COL) {
// //

View File

@ -11,11 +11,7 @@
<view v-if="tagStyle.show" class="tag-icon-box"> <view v-if="tagStyle.show" class="tag-icon-box">
<image class="tag-icon" :src="sheep.$url.cdn(tagStyle.src || tagStyle.imgUrl)"></image> <image class="tag-icon" :src="sheep.$url.cdn(tagStyle.src || tagStyle.imgUrl)"></image>
</view> </view>
<image <image class="xs-img-box" :src="sheep.$url.cdn(data.image || data.picUrl)" mode="aspectFit" />
class="xs-img-box"
:src="sheep.$url.cdn(data.image || data.picUrl)"
mode="aspectFit"
></image>
<view <view
v-if="goodsFields.title?.show || goodsFields.name?.show || goodsFields.price?.show" v-if="goodsFields.title?.show || goodsFields.name?.show || goodsFields.price?.show"
class="xs-goods-content ss-flex-col ss-row-around" class="xs-goods-content ss-flex-col ss-row-around"
@ -27,23 +23,24 @@
> >
{{ data.title || data.name }} {{ data.title || data.name }}
</view> </view>
<!-- 这里是新加的会员价和限时优惠 --> <!-- 活动信息 -->
<view class="iconBox" v-if="data.discountPrice || data.vipPrice || data.reward"> <view class="iconBox" v-if="data.promotionType > 0 || data.rewardActivity">
<view class="card" v-if="iconShow">{{ iconShow }}</view> <view class="card" v-if="discountText">{{ discountText }}</view>
<view class="card2" v-if="data.reward">{{ data.reward.ruleDescriptions[0] }}</view> <view class="card2" v-if="data.rewardActivity">
{{ data.rewardActivity.ruleDescriptions[0] }}
</view>
</view> </view>
<!-- 这里是新加的会员价和限时优惠结束 -->
<view <view
v-if="goodsFields.price?.show" v-if="goodsFields.price?.show"
class="xs-goods-price font-OPPOSANS" class="xs-goods-price font-OPPOSANS"
:style="[{ color: goodsFields.price.color }]" :style="[{ color: goodsFields.price.color }]"
> >
<text class="price-unit ss-font-24">{{ priceUnit }}</text> <text class="price-unit ss-font-24">{{ priceUnit }}</text>
<text v-if="iconShow == '限时优惠'">{{ fen2yuan(data.discountPrice) }}</text> <!-- 活动价格 -->
<text v-else-if="iconShow == ''">{{ fen2yuan(data.vipPrice) }}</text> <text v-if="data.promotionPrice > 0">{{ fen2yuan(data.promotionPrice) }}</text>
<text v-else>{{ <text v-else>
isArray(data.price) ? fen2yuan(data.price[0]) : fen2yuan(data.price) {{ isArray(data.price) ? fen2yuan(data.price[0]) : fen2yuan(data.price) }}
}}</text> </text>
</view> </view>
</view> </view>
</view> </view>
@ -70,23 +67,24 @@
> >
{{ data.title || data.name }} {{ data.title || data.name }}
</view> </view>
<!-- 这里是新加的会员价和限时优惠 --> <!-- 活动信息 -->
<view class="iconBox" v-if="data.discountPrice || data.vipPrice || data.reward"> <view class="iconBox" v-if="data.promotionType > 0 || data.rewardActivity">
<view class="card" v-if="iconShow">{{ iconShow }}</view> <view class="card" v-if="discountText">{{ discountText }}</view>
<view class="card2" v-if="data.reward">{{ data.reward.ruleDescriptions[0] }}</view> <view class="card2" v-if="data.rewardActivity">
{{ data.rewardActivity.ruleDescriptions[0] }}
</view>
</view> </view>
<!-- 这里是新加的会员价和限时优惠结束 -->
<view <view
v-if="goodsFields.price?.show" v-if="goodsFields.price?.show"
class="sm-goods-price font-OPPOSANS" class="sm-goods-price font-OPPOSANS"
:style="[{ color: goodsFields.price.color }]" :style="[{ color: goodsFields.price.color }]"
> >
<text class="price-unit ss-font-24">{{ priceUnit }}</text> <text class="price-unit ss-font-24">{{ priceUnit }}</text>
<text v-if="iconShow == '限时优惠'">{{ fen2yuan(data.discountPrice) }}</text> <!-- 活动价格 -->
<text v-else-if="iconShow == ''">{{ fen2yuan(data.vipPrice) }}</text> <text v-if="data.promotionPrice > 0">{{ fen2yuan(data.promotionPrice) }}</text>
<text v-else>{{ <text v-else>
isArray(data.price) ? fen2yuan(data.price[0]) : fen2yuan(data.price) {{ isArray(data.price) ? fen2yuan(data.price[0]) : fen2yuan(data.price) }}
}}</text> </text>
</view> </view>
</view> </view>
</view> </view>
@ -94,13 +92,9 @@
<!-- md卡片竖向一行放两个图上内容下 --> <!-- md卡片竖向一行放两个图上内容下 -->
<view v-if="size === 'md'" class="md-goods-card ss-flex-col" :style="[elStyles]" @tap="onClick"> <view v-if="size === 'md'" class="md-goods-card ss-flex-col" :style="[elStyles]" @tap="onClick">
<view v-if="tagStyle.show" class="tag-icon-box"> <view v-if="tagStyle.show" class="tag-icon-box">
<image class="tag-icon" :src="sheep.$url.cdn(tagStyle.src || tagStyle.imgUrl)"></image> <image class="tag-icon" :src="sheep.$url.cdn(tagStyle.src || tagStyle.imgUrl)" />
</view> </view>
<image <image class="md-img-box" :src="sheep.$url.cdn(data.image || data.picUrl)" mode="widthFix" />
class="md-img-box"
:src="sheep.$url.cdn(data.image || data.picUrl)"
mode="widthFix"
></image>
<view <view
class="md-goods-content ss-flex-col ss-row-around ss-p-b-20 ss-p-t-20 ss-p-x-16" class="md-goods-content ss-flex-col ss-row-around ss-p-b-20 ss-p-t-20 ss-p-x-16"
:id="elId" :id="elId"
@ -130,12 +124,13 @@
</view> </view>
</view> </view>
</slot> </slot>
<!-- 这里是新加的会员价和限时优惠 --> <!-- 活动信息 -->
<view class="iconBox" v-if="data.discountPrice || data.vipPrice || data.reward"> <view class="iconBox" v-if="data.promotionType > 0 || data.rewardActivity">
<view class="card" v-if="iconShow">{{ iconShow }}</view> <view class="card" v-if="discountText">{{ discountText }}</view>
<view class="card2" v-if="data.reward">{{ data.reward.ruleDescriptions[0] }}</view> <view class="card2" v-if="data.rewardActivity">
{{ data.rewardActivity.ruleDescriptions[0] }}
</view>
</view> </view>
<!-- 这里是新加的会员价和限时优惠结束 -->
<view class="ss-flex ss-col-bottom"> <view class="ss-flex ss-col-bottom">
<view <view
v-if="goodsFields.price?.show" v-if="goodsFields.price?.show"
@ -143,13 +138,12 @@
:style="[{ color: goodsFields.price.color }]" :style="[{ color: goodsFields.price.color }]"
> >
<text class="price-unit ss-font-24">{{ priceUnit }}</text> <text class="price-unit ss-font-24">{{ priceUnit }}</text>
<text v-if="iconShow == '限时优惠'">{{ fen2yuan(data.discountPrice) }}</text> <!-- 活动价格 -->
<text v-else-if="iconShow == ''">{{ fen2yuan(data.vipPrice) }}</text> <text v-if="data.promotionPrice > 0">{{ fen2yuan(data.promotionPrice) }}</text>
<text v-else>{{ <text v-else>
isArray(data.price) ? fen2yuan(data.price[0]) : fen2yuan(data.price) {{ isArray(data.price) ? fen2yuan(data.price[0]) : fen2yuan(data.price) }}
}}</text> </text>
</view> </view>
<view <view
v-if=" v-if="
(goodsFields.original_price?.show || goodsFields.marketPrice?.show) && (goodsFields.original_price?.show || goodsFields.marketPrice?.show) &&
@ -193,7 +187,7 @@
class="lg-img-box" class="lg-img-box"
:src="sheep.$url.cdn(data.image || data.picUrl)" :src="sheep.$url.cdn(data.image || data.picUrl)"
mode="aspectFill" mode="aspectFill"
></image> />
<view class="lg-goods-content ss-flex-1 ss-flex-col ss-row-between ss-p-b-10 ss-p-t-20"> <view class="lg-goods-content ss-flex-1 ss-flex-col ss-row-between ss-p-b-10 ss-p-t-20">
<view> <view>
<view <view
@ -219,12 +213,13 @@
</view> </view>
</view> </view>
</slot> </slot>
<!-- 这里是新加的会员价和限时优惠 --> <!-- 活动信息 -->
<view class="iconBox" v-if="data.discountPrice || data.vipPrice || data.reward"> <view class="iconBox" v-if="data.promotionType > 0 || data.rewardActivity">
<view class="card" v-if="iconShow">{{ iconShow }}</view> <view class="card" v-if="discountText">{{ discountText }}</view>
<view class="card2" v-if="data.reward">{{ data.reward.ruleDescriptions[0] }}</view> <view class="card2" v-if="data.rewardActivity">
{{ data.rewardActivity.ruleDescriptions[0] }}
</view>
</view> </view>
<!-- 这里是新加的会员价和限时优惠结束 -->
<view class="ss-flex ss-col-bottom ss-m-t-10"> <view class="ss-flex ss-col-bottom ss-m-t-10">
<view <view
v-if="goodsFields.price?.show" v-if="goodsFields.price?.show"
@ -243,11 +238,11 @@
:style="[{ color: originPriceColor }]" :style="[{ color: originPriceColor }]"
> >
<text class="price-unit ss-font-20">{{ priceUnit }}</text> <text class="price-unit ss-font-20">{{ priceUnit }}</text>
<text v-if="iconShow == '限时优惠'">{{ fen2yuan(data.discountPrice) }}</text> <!-- 活动价格 -->
<text v-else-if="iconShow == ''">{{ fen2yuan(data.vipPrice) }}</text> <text v-if="data.promotionPrice > 0">{{ fen2yuan(data.promotionPrice) }}</text>
<text v-else>{{ <text v-else>
isArray(data.price) ? fen2yuan(data.price[0]) : fen2yuan(data.price) {{ isArray(data.price) ? fen2yuan(data.price[0]) : fen2yuan(data.price) }}
}}</text> </text>
</view> </view>
</view> </view>
<view class="ss-m-t-8 ss-flex ss-col-center ss-flex-wrap"> <view class="ss-m-t-8 ss-flex ss-col-center ss-flex-wrap">
@ -264,15 +259,13 @@
<!-- sl卡片竖向型一行放一个图片上内容下边 --> <!-- sl卡片竖向型一行放一个图片上内容下边 -->
<view v-if="size === 'sl'" class="sl-goods-card ss-flex-col" :style="[elStyles]" @tap="onClick"> <view v-if="size === 'sl'" class="sl-goods-card ss-flex-col" :style="[elStyles]" @tap="onClick">
<view v-if="tagStyle.show" class="tag-icon-box"> <view v-if="tagStyle.show" class="tag-icon-box">
<image class="tag-icon" :src="sheep.$url.cdn(tagStyle.src || tagStyle.imgUrl)"></image> <image class="tag-icon" :src="sheep.$url.cdn(tagStyle.src || tagStyle.imgUrl)" />
</view> </view>
<image <image
class="sl-img-box" class="sl-img-box"
:src="sheep.$url.cdn(data.image || data.picUrl)" :src="sheep.$url.cdn(data.image || data.picUrl)"
mode="aspectFill" mode="aspectFill"
></image> />
<view class="sl-goods-content"> <view class="sl-goods-content">
<view> <view>
<view <view
@ -302,20 +295,21 @@
</view> </view>
</view> </view>
</slot> </slot>
<!-- 这里是新加的会员价和限时优惠 --> <!-- 活动信息 -->
<view class="iconBox" v-if="data.discountPrice || data.vipPrice || data.reward"> <view class="iconBox" v-if="data.promotionType > 0 || data.rewardActivity">
<view class="card" v-if="iconShow">{{ iconShow }}</view> <view class="card" v-if="discountText">{{ discountText }}</view>
<view class="card2" v-if="data.reward">{{ data.reward.ruleDescriptions[0] }}</view> <view class="card2" v-if="data.rewardActivity">
{{ data.rewardActivity.ruleDescriptions[0] }}
</view>
</view> </view>
<!-- 这里是新加的会员价和限时优惠结束 -->
<view v-if="goodsFields.price?.show" class="ss-flex ss-col-bottom font-OPPOSANS"> <view v-if="goodsFields.price?.show" class="ss-flex ss-col-bottom font-OPPOSANS">
<view class="sl-goods-price ss-m-r-12" :style="[{ color: goodsFields.price.color }]"> <view class="sl-goods-price ss-m-r-12" :style="[{ color: goodsFields.price.color }]">
<text class="price-unit ss-font-24">{{ priceUnit }}</text> <text class="price-unit ss-font-24">{{ priceUnit }}</text>
<text v-if="iconShow == '限时优惠'">{{ fen2yuan(data.discountPrice) }}</text> <!-- 活动价格 -->
<text v-else-if="iconShow == ''">{{ fen2yuan(data.vipPrice) }}</text> <text v-if="data.promotionPrice > 0">{{ fen2yuan(data.promotionPrice) }}</text>
<text v-else>{{ <text v-else>
isArray(data.price) ? fen2yuan(data.price[0]) : fen2yuan(data.price) {{ isArray(data.price) ? fen2yuan(data.price[0]) : fen2yuan(data.price) }}
}}</text> </text>
</view> </view>
<view <view
v-if=" v-if="
@ -371,14 +365,11 @@
* @event {Function()} click - 点击卡片 * @event {Function()} click - 点击卡片
* *
*/ */
import { computed, reactive, getCurrentInstance, onMounted, nextTick, ref } from 'vue'; import { computed, getCurrentInstance, onMounted, nextTick } from 'vue';
import sheep from '@/sheep'; import sheep from '@/sheep';
import { fen2yuan, formatSales } from '@/sheep/hooks/useGoods'; import { fen2yuan, formatSales } from '@/sheep/hooks/useGoods';
import { formatStock } from '@/sheep/hooks/useGoods'; import { formatStock } from '@/sheep/hooks/useGoods';
import goodsCollectVue from '@/pages/user/goods-collect.vue';
import { isArray } from 'lodash-es'; import { isArray } from 'lodash-es';
//
const state = reactive({});
// //
const props = defineProps({ const props = defineProps({
@ -478,25 +469,18 @@
default: false, default: false,
}, },
}); });
//
const iconShow = handle();
function handle() { //
if (props.data.discountPrice === null && props.data.vipPrice === null) { const discountText = computed(() => {
// null const promotionType = props.data.promotionType;
return ''; if (promotionType === 4) {
} else if (props.data.discountPrice === null) {
// discountPrice null vipPrice
return '会员价';
} else if (props.data.vipPrice === null) {
// vipPrice null discountPrice
return '限时优惠'; return '限时优惠';
} else if (props.data.discountPrice < props.data.vipPrice) { } else if (promotionType === 6) {
return '限时优惠';
} else if (props.data.discountPrice > props.data.vipPrice) {
return '会员价'; return '会员价';
} }
} return undefined;
});
// //
const elStyles = computed(() => { const elStyles = computed(() => {
return { return {

View File

@ -382,3 +382,27 @@ export function convertProductPropertyList(skus) {
} }
return result; return result;
} }
export function appendSettlementProduct(spus, settlementInfos) {
if (!settlementInfos || settlementInfos.length === 0) {
return;
}
for (const spu of spus) {
const settlementInfo = settlementInfos.find((info) => info.spuId === spu.id);
if (!settlementInfo) {
return;
}
// 选择价格最小的 SKU 设置到 SPU 上
const settlementSku = settlementInfo.skus
.filter((sku) => sku.promotionPrice > 0)
.reduce((prev, curr) => (prev.promotionPrice < curr.promotionPrice ? prev : curr));
if (settlementSku) {
spu.promotionType = settlementSku.promotionType;
spu.promotionPrice = settlementSku.promotionPrice;
}
// 设置【满减送】活动
if (settlementInfo.rewardActivity) {
spu.rewardActivity = settlementInfo.rewardActivity;
}
}
}