商品详情:满减送的活动接入

pull/36/MERGE
YunaiV 2024-01-06 09:09:13 +08:00
parent 74e6680880
commit eb9138a668
3 changed files with 33 additions and 43 deletions

View File

@ -8,12 +8,12 @@
<detailSkeleton v-if="state.skeletonLoading" />
<!-- 下架/售罄提醒 -->
<s-empty v-else-if="state.goodsInfo === null" text="商品不存在或已下架" icon="/static/soldout-empty.png" showAction
actionText="再逛逛" actionUrl="/pages/goods/list" />
actionText="再逛逛" actionUrl="/pages/goods/list" />
<block v-else>
<view class="detail-swiper-selector">
<!-- 商品轮播图 -->
<su-swiper class="ss-m-b-14" isPreview :list="formatGoodsSwiper(state.goodsInfo.sliderPicUrls)"
dotStyle="tag" imageMode="widthFix" dotCur="bg-mask-40" :seizeHeight="750" />
otStyle="tag" imageMode="widthFix" dotCur="bg-mask-40" :seizeHeight="750" />
<!-- 价格+标题 -->
<view class="title-card detail-card ss-p-y-40 ss-p-x-20">
@ -31,12 +31,12 @@
</view>
</view>
<view class="discounts-box ss-flex ss-row-between ss-m-b-28">
<!-- 满减送/限时折扣活动的提示 TODO 芋艿promos 未写 -->
<!-- 满减送/限时折扣活动的提示 -->
<div class="tag-content">
<view class="tag-box ss-flex">
<view class="tag ss-m-r-10" v-for="promos in state.goodsInfo.promos"
:key="promos.id" @tap="onActivity">
{{ promos.title }}
<view class="tag ss-m-r-10" v-for="promos in state.activityInfo"
:key="promos.id" @tap="onActivity">
{{ promos.name }}
</view>
</view>
</div>
@ -55,12 +55,12 @@
<!-- 功能卡片 -->
<view class="detail-cell-card detail-card ss-flex-col">
<detail-cell-sku v-model="state.selectedSku.goods_sku_text" :sku="state.selectedSku"
@tap="state.showSelectSku = true" />
@tap="state.showSelectSku = true" />
</view>
<!-- 规格与数量弹框 -->
<s-select-sku :goodsInfo="state.goodsInfo" :show="state.showSelectSku" @addCart="onAddCart"
@buy="onBuy" @change="onSkuChange" @close="state.showSelectSku = false" />
@buy="onBuy" @change="onSkuChange" @close="state.showSelectSku = false" />
</view>
<!-- 评价 -->
@ -120,6 +120,7 @@
import detailContentCard from './components/detail/detail-content-card.vue';
import detailActivityTip from './components/detail/detail-activity-tip.vue';
import { isEmpty } from 'lodash';
import SpuApi from '@/sheep/api/product/spu';
onPageScroll(() => {});
@ -141,7 +142,7 @@
state.selectedSku = e;
}
// TODO
//
function onAddCart(e) {
if (!e.id) {
sheep.$helper.toast('请选择商品规格');
@ -169,13 +170,12 @@
});
}
// TODO
//
function onActivity() {
state.activityInfo = state.goodsInfo.promos;
state.showActivityModel = true;
}
// TODO
//
async function onGet(id) {
const { code } = await CouponApi.takeCoupon(id);
if (code !== 0) {
@ -225,7 +225,7 @@
}
state.goodsId = options.id;
// 1.
sheep.$api.goods.detail(state.goodsId).then((res) => {
SpuApi.getSpuDetail(state.goodsId).then((res) => {
//
if (res.code !== 0 || !res.data) {
state.goodsInfo = null;
@ -252,7 +252,15 @@
if (res.code !== 0) {
return;
}
state.activityList = res.data;
res.data.forEach(activity => {
if ([1, 2, 3].includes(activity.type)) { // //
state.activityList.push(activity);
} else if (activity.type === 5) { //
state.activityInfo.push(activity);
} else { // TODO
console.log('待实现!优先级不高');
}
})
});
});
</script>

View File

@ -49,17 +49,6 @@ export default {
showError: false,
},
}),
// 商品评价类型
getType: (id) =>
request({
url: 'goods/comment/getType/' + id,
method: 'GET',
custom: {
showLoading: false,
showError: false,
},
}),
// 活动商品查询
// 商品查询
activity: (params = {}) =>
request({

View File

@ -1,3 +1,4 @@
<!-- 商品信息满减送等营销活动的弹窗 -->
<template>
<su-popup :show="show" type="bottom" round="20" @close="emits('close')" showClose>
<view class="model-box">
@ -9,28 +10,20 @@
:enable-back-to-top="true"
>
<view v-for="item in state.activityInfo" :key="item.id">
<!-- <uni-list :border="false">
<uni-list-item showArrow clickable @tap="sheep.$router.go('/pages/goods/list')">
<template v-slot:header>
<view class="model-content-tag ss-flex ss-row-center">{{ item.type_text }}</view>
</template>
<template v-slot:body>
<view class="ss-m-l-20 model-content-title">
<view class="ss-m-b-24" v-for="text in item.texts" :key="text">
{{ text }}
</view>
</view>
</template>
</uni-list-item>
</uni-list> -->
<view class="ss-flex ss-col-top ss-m-b-40" @tap="onGoodsList(item)">
<view class="model-content-tag ss-flex ss-row-center">{{ item.type_text }}</view>
<view class="model-content-tag ss-flex ss-row-center">满减</view>
<!-- TODO 芋艿先简单做未来再搞成满 xxx yyy -->
<!-- <view class="ss-m-l-20 model-content-title ss-flex-1">-->
<!-- <view class="ss-m-b-24" v-for="text in item.texts" :key="text">-->
<!-- {{ text }}-->
<!-- </view>-->
<!-- </view>-->
<view class="ss-m-l-20 model-content-title ss-flex-1">
<view class="ss-m-b-24" v-for="text in item.texts" :key="text">
{{ text }}
<view class="ss-m-b-24">
{{ item.name }}
</view>
</view>
<text class="cicon-forward"></text>
<text class="cicon-forward" />
</view>
</view>
</scroll-view>