【商品详情】

1. 接入营销活动列表
pull/1/MERGE
YunaiV 2023-06-10 14:47:22 +08:00
parent d89f64f80f
commit b6fd22c8fb
3 changed files with 75 additions and 31 deletions

15
api/promotion/activity.js Normal file
View File

@ -0,0 +1,15 @@
import request from "@/utils/request.js";
// 获得单个商品,近期参与的每个活动
export function getActivityListBySpuId(spuId) {
return request.get("app-api/promotion/activity/list-by-spu-id", {
spuId
});
}
// 获得多个商品,近期参与的每个活动
export function getActivityListBySpuIds(spuIds) {
return request.get("app-api/promotion/activity/list-by-spu-id", {
spuIds
});
}

View File

@ -56,26 +56,21 @@
</view> </view>
<view class='iconfont icon-jiantou'></view> <view class='iconfont icon-jiantou'></view>
</view> </view>
<!-- 营销活动 TODO 芋艿待接入 --> <!-- 营销活动 -->
<view class="coupon acea-row row-between-wrapper" v-if="activityH5.length"> <view class="coupon acea-row row-between-wrapper" v-if="activityH5.length">
<view class="line1 acea-row"> <view class="line1 acea-row">
<text class="activityName">&nbsp;&nbsp;&nbsp;</text> <text class="activityName">&nbsp;&nbsp;&nbsp;</text>
<view v-for='(item,index) in activityH5' :key='index' @click="goActivity(item)" <view v-for='(item, index) in activityH5' :key='index' @click="goActivity(item)"
class="activityBox"> class="activityBox">
<view v-if="item.type === '1'" <view v-if="item.type === 1" class="activity_miao">
:class="index==0?'activity_pin':'' || index==1?'activity_miao':'' || index==2?'activity_kan':''">
<text class="iconfonts iconfont icon-pintuan"></text> <text class="iconfonts iconfont icon-pintuan"></text>
<text class="activity_title"> 参与秒杀</text> <text class="activity_title"> 参与秒杀</text>
</view> </view>
<view <view v-if="item.type === 2" class="activity_kan">
:class="index==0?'activity_pin':'' || index==1?'activity_miao':'' || index==2?'activity_kan':''"
v-if="item.type === '2'">
<text class="iconfonts iconfont icon-shenhezhong"></text> <text class="iconfonts iconfont icon-shenhezhong"></text>
<text class="activity_title"> 参与砍价</text> <text class="activity_title"> 参与砍价</text>
</view> </view>
<view <view v-if="item.type === 3" class="activity_pin">
:class="index==0?'activity_pin':'' || index==1?'activity_miao':'' || index==2?'activity_kan':''"
v-if="item.type === '3'">
<text class="iconfonts iconfont icon-kanjia"></text> <text class="iconfonts iconfont icon-kanjia"></text>
<text class="activity_title"> 参与拼团</text> <text class="activity_title"> 参与拼团</text>
</view> </view>
@ -301,6 +296,7 @@
import * as ProductFavoriteApi from '@/api/product/favorite.js'; import * as ProductFavoriteApi from '@/api/product/favorite.js';
import * as ProductCommentApi from '@/api/product/comment.js'; import * as ProductCommentApi from '@/api/product/comment.js';
import * as CouponTemplateApi from '@/api/promotion/couponTemplate.js'; import * as CouponTemplateApi from '@/api/promotion/couponTemplate.js';
import * as PromotionActivityApi from '@/api/promotion/activity.js';
import * as TradeCartApi from '@/api/trade/cart.js'; import * as TradeCartApi from '@/api/trade/cart.js';
import * as Util from '@/utils/util.js'; import * as Util from '@/utils/util.js';
import * as ProductUtil from '@/utils/product.js'; import * as ProductUtil from '@/utils/product.js';
@ -356,8 +352,8 @@
list: [], // list: [], //
}, },
// ========== TODO ========== // ========== ==========
activityH5: [], // TODO activityH5: [], //
// ========== TODO ========== // ========== TODO ==========
circular: false, // TODO circular: false, // TODO
@ -512,17 +508,22 @@
*/ */
getGoodsDetails: function() { getGoodsDetails: function() {
ProductSpuApi.getSpuDetail(this.id).then(res => { ProductSpuApi.getSpuDetail(this.id).then(res => {
let productInfo = res.data;
let spu = res.data; let spu = res.data;
let skus = res.data.skus; let skus = res.data.skus;
this.$set(this, 'spu', spu); this.$set(this, 'spu', spu);
this.$set(this.attr, 'properties', ProductUtil.convertProductPropertyList(skus)); this.$set(this.attr, 'properties', ProductUtil.convertProductPropertyList(skus));
this.$set(this, 'skuMap', ProductUtil.convertProductSkuMap(skus)); this.$set(this, 'skuMap', ProductUtil.convertProductSkuMap(skus));
// // TODO // // TODO
this.$set(this.sharePacket, 'priceName', res.data.priceName); this.$set(this.sharePacket, 'priceName', res.data.priceName);
this.$set(this.sharePacket, 'isState', Math.floor(res.data.priceName) === 0); this.$set(this.sharePacket, 'isState', Math.floor(res.data.priceName) === 0);
// //
this.$set(this, 'activityH5', res.data.activityAllH5 ? res.data.activityAllH5 : []); PromotionActivityApi.getActivityListBySpuId(this.id).then(res => {
let activityList = res.data;
activityList = ProductUtil.sortActivityList(activityList);
this.$set(this, 'activityH5', activityList);
});
// //
uni.setNavigationBarTitle({ uni.setNavigationBarTitle({
@ -853,27 +854,33 @@
this.getCouponList(this.coupon.type); this.getCouponList(this.coupon.type);
}, },
// ========== ==========
/**
* 前往活动页面
*
* @param activity 活动
*/
goActivity: function(activity) {
if (activity.type === 1) {
uni.navigateTo({
url: `/pages/activity/goods_seckill_details/index?id=${activity.id}`
});
} else if (activity.type === 2) {
uni.navigateTo({
url: `/pages/activity/goods_bargain_details/index?id=${activity.id}&startBargainUid=${this.uid}`
});
} else {
uni.navigateTo({
url: `/pages/activity/goods_combination_details/index?id=${activity.id}`
});
}
},
// === TODO ==== // === TODO ====
kefuClick() { kefuClick() {
location.href = this.chatUrl; location.href = this.chatUrl;
}, },
goActivity: function(e) {
let item = e;
if (item.type === "1") {
uni.navigateTo({
url: `/pages/activity/goods_seckill_details/index?id=${item.id}`
});
} else if (item.type === "2") {
uni.navigateTo({
url: `/pages/activity/goods_bargain_details/index?id=${item.id}&startBargainUid=${this.uid}`
});
} else {
uni.navigateTo({
url: `/pages/activity/goods_combination_details/index?id=${item.id}`
});
}
},
/** /**
* 去商品详情页 * 去商品详情页
*/ */

View File

@ -68,3 +68,25 @@ export function convertProductSkuMap(skus) {
} }
return result return result
} }
/**
* 根据 SPU 的活动展示顺序排序活动列表
*
* @param activityList 原始的活动列表
* @param spu
* @return 新的活动列表
*/
export function sortActivityList(activityList, spu) {
if (!spu || !spu.activityOrders) {
return activityList;
}
const result = [];
for (const activityOrder of spu.activityOrders) {
for (const activity of activityList) {
if (activity.type === activityOrder) {
result.push(activity)
}
}
}
return result;
}