【首页】

1. 接入商品推荐
pull/1/MERGE
YunaiV 2023-06-23 23:37:28 +08:00
parent 7f0870a34a
commit 0a575e92d0
1 changed files with 92 additions and 113 deletions

View File

@ -5,11 +5,11 @@
<view class="header"> <view class="header">
<view class="serch-wrapper flex"> <view class="serch-wrapper flex">
<view class="logo"> <view class="logo">
<image :src="logoUrl" mode=""></image> <image :src="logoUrl" mode="" />
</view> </view>
<navigator url="/pages/goods_search/index" class="input" hover-class="none"><text <navigator url="/pages/goods_search/index" class="input" hover-class="none">
class="iconfont icon-xiazai5"></text> <text class="iconfont icon-xiazai5" /> 搜索商品
搜索商品</navigator> </navigator>
</view> </view>
</view> </view>
<!-- #endif --> <!-- #endif -->
@ -104,13 +104,13 @@
</view> </view>
</view> </view>
</view> </view>
<!-- 活动-->
<a_seckill></a_seckill> <!-- 营销活动 -->
<b_combination></b_combination> <a_seckill />
<c_bargain></c_bargain> <b_combination />
<c_bargain />
<!-- 首页推荐 --> <!-- 首页推荐 -->
<!-- :class="iSshowH?'on':''" -->
<view class="sticky-box" :style="'top:'+(marTop)+'px;'"> <view class="sticky-box" :style="'top:'+(marTop)+'px;'">
<scroll-view class="scroll-view_H" style="width: 100%;" scroll-x="true" scroll-with-animation <scroll-view class="scroll-view_H" style="width: 100%;" scroll-x="true" scroll-with-animation
:scroll-left="tabsScrollLeft" @scroll="scroll"> :scroll-left="tabsScrollLeft" @scroll="scroll">
@ -123,32 +123,30 @@
</view> </view>
</scroll-view> </scroll-view>
</view> </view>
<!-- 首发新品 --> <!-- 首发新品 -->
<view class="index-product-wrapper" :class="iSshowH?'on':''"> <view class="index-product-wrapper" :class="iSshowH?'on':''">
<view class="list-box animated" :class='tempArr.length > 0?"fadeIn on":""'> <view class="list-box animated" :class='tempArr.length > 0?"fadeIn on":""'>
<view class="item" v-for="(item,index) in tempArr" :key="index" @click="goDetail(item)"> <view class="item" v-for="(item,index) in tempArr" :key="index" @click="goDetail(item)">
<view class="pictrue"> <view class="pictrue">
<span class="pictrue_log pictrue_log_class" <span class="pictrue_log pictrue_log_class"
v-if="item.activityH5 && item.activityH5.type === '1'">秒杀</span> v-if="item.activityList && item.activityList[0] && item.activityList[0].type === 1">秒杀</span>
<span class="pictrue_log pictrue_log_class" <span class="pictrue_log pictrue_log_class"
v-if="item.activityH5 && item.activityH5.type === '2'">砍价</span> v-if="item.activityList && item.activityList[0] && item.activityList[0].type === 2">砍价</span>
<span class="pictrue_log pictrue_log_class" <span class="pictrue_log pictrue_log_class"
v-if="item.activityH5 && item.activityH5.type === '3'">拼团</span> v-if="item.activityList && item.activityList[0] && item.activityList[0].type === 3">拼团</span>
<image :src="item.image" mode=""></image> <image :src="item.picUrl" mode="" />
</view> </view>
<view class="text-info"> <view class="text-info">
<view class="title line1">{{item.storeName}}</view> <view class="title line1">{{ item.name }}</view>
<view class="old-price"><text>¥{{item.otPrice}}</text></view> <view class="old-price"><text>¥{{ fen2yuan(item.marketPrice) }}</text></view>
<view class="price"> <view class="price">
<text></text>{{item.price}} <text></text>{{ fen2yuan(item.price) }}
<view class="txt" v-if="item.checkCoupon"></view>
</view> </view>
</view> </view>
</view> </view>
</view> </view>
<view class='loadingicon acea-row row-center-wrapper' v-if="goodScroll"> <view class='loadingicon acea-row row-center-wrapper' v-if="goodScroll">
<text class='loading iconfont icon-jiazai' :hidden='loading==false'></text> <text class='loading iconfont icon-jiazai' :hidden='!loading' />
</view> </view>
<view class="mores-txt flex" v-if="!goodScroll"> <view class="mores-txt flex" v-if="!goodScroll">
<text>我是有底线的</text> <text>我是有底线的</text>
@ -158,7 +156,6 @@
</view> </view>
</view> </view>
</template> </template>
<script> <script>
import Cache from '../../utils/cache'; import Cache from '../../utils/cache';
var statusBarHeight = uni.getSystemInfoSync().statusBarHeight + 'px'; var statusBarHeight = uni.getSystemInfoSync().statusBarHeight + 'px';
@ -179,34 +176,22 @@
import c_bargain from './components/c_bargain'; import c_bargain from './components/c_bargain';
import goodList from '@/components/goodList'; import goodList from '@/components/goodList';
import promotionGood from '@/components/promotionGood'; import promotionGood from '@/components/promotionGood';
import { import { goShopDetail } from '@/libs/order.js'
goShopDetail
} from '@/libs/order.js'
import { import {
mapGetters mapGetters
} from "vuex"; } from "vuex";
import tabNav from '@/components/tabNav.vue' import tabNav from '@/components/tabNav.vue'
import countDown from '@/components/countDown'; import countDown from '@/components/countDown';
import { import { getProductHot, } from '@/api/store.js';
getProductHot,
getGroomList
} from '@/api/store.js';
import recommend from '@/components/recommend'; import recommend from '@/components/recommend';
// #ifdef MP
import authorize from '@/components/Authorize';
// #endif
import { import {
silenceBindingSpread silenceBindingSpread
} from '@/utils'; } from '@/utils';
// #ifndef MP
import {
kefuConfig
} from "@/api/public";
import {
getWechatConfig
} from "@/api/public";
// #endif
import Loading from '@/components/Loading/index.vue'; import Loading from '@/components/Loading/index.vue';
import * as ProductSpuApi from '@/api/product/spu.js';
import * as PromotionActivityApi from '@/api/promotion/activity.js';
import * as ProductUtil from '@/utils/product.js';
import * as Util from '@/utils/util.js';
const arrTemp = ["beforePay", "afterPay", "refundApply", "beforeRecharge", "createBargain", "pink"]; const arrTemp = ["beforePay", "afterPay", "refundApply", "beforeRecharge", "createBargain", "pink"];
export default { export default {
computed: mapGetters(['isLogin', 'uid']), computed: mapGetters(['isLogin', 'uid']),
@ -219,17 +204,12 @@
b_combination, b_combination,
c_bargain, c_bargain,
recommend, recommend,
// #ifdef MP
authorize,
// #endif
Loading Loading
}, },
data() { data() {
return { return {
loaded: false, loaded: false,
loading: false, loading: false,
isAuto: false, //
isShowAuth: false, //
statusBarHeight: statusBarHeight, statusBarHeight: statusBarHeight,
navIndex: 0, navIndex: 0,
navTop: [], navTop: [],
@ -260,9 +240,7 @@
}, { }, {
pic: '/static/images/hot_003.png' pic: '/static/images/hot_003.png'
}], }],
ProductNavindex: 0,
marTop: 0, marTop: 0,
childID: 0,
loadend: false, loadend: false,
loadTitle: '加载更多', loadTitle: '加载更多',
sortProduct: [], sortProduct: [],
@ -279,13 +257,6 @@
prodeuctTop: 0, prodeuctTop: 0,
searchH: 0, searchH: 0,
isFixed: false, isFixed: false,
goodType: 0, //Type
goodScroll: true, //
params: { //
page: 1,
limit: 10,
},
tempArr: [], //
roll: [], // roll: [], //
site_name: '', //title site_name: '', //title
iSshowH: false, iSshowH: false,
@ -298,8 +269,17 @@
lineColor: 'red', lineColor: 'red',
lineStyle: {}, // 线-- lineStyle: {}, // 线--
listActive: 0, // listActive: 0, //
duration: 0.2, // 线
duration: 0.2 // 线 // ========== ===========
goodScroll: true, //
ProductNavindex: 0,
goodType: 1, // Type
params: { //
page: 1,
limit: 10,
},
tempArr: [], //
} }
}, },
watch: { watch: {
@ -462,7 +442,7 @@
Cache.set('chatUrl', res.data.yzfUrl); Cache.set('chatUrl', res.data.yzfUrl);
// #endif // #endif
that.$set(that, "explosiveMoney", res.data.explosiveMoney); that.$set(that, "explosiveMoney", res.data.explosiveMoney);
that.goodType = res.data.explosiveMoney[0].type that.goodType = parseInt(res.data.explosiveMoney[0].type)
this.getGroomList(); this.getGroomList();
this.shareApi(); this.shareApi();
this.getcouponList(); this.getcouponList();
@ -513,13 +493,6 @@
// #endif // #endif
}) })
}, },
getChatUrL() {
kefuConfig().then(res => {
let data = res.data;
this.$store.commit("SET_CHATURL", data.yzfUrl);
Cache.set('chatUrl', data.yzfUrl);
})
},
// //
setOpenShare: function(data) { setOpenShare: function(data) {
let that = this; let that = this;
@ -534,18 +507,14 @@
configAppMessage); configAppMessage);
} }
}, },
//
authColse: function(e) {
this.isShowAuth = e
},
//
onLoadFun() {
}, // ========== ===========
// /**
* 首发新品切换
*/
ProductNavTab(item, index) { ProductNavTab(item, index) {
this.listActive = index this.listActive = index
this.goodType = item.type this.goodType = parseInt(item.type)
this.listActive = index this.listActive = index
this.ProductNavindex = index this.ProductNavindex = index
this.tempArr = [] this.tempArr = []
@ -554,46 +523,54 @@
let onloadH = true let onloadH = true
this.getGroomList(onloadH) this.getGroomList(onloadH)
}, },
// /**
goDetail(item) { * 商品精品推荐
if (item.activityH5 && item.activityH5.type === "2" && !this.isLogin) { */
toLogin();
} else {
goShopDetail(item, this.uid).then(res => {
uni.navigateTo({
url: `/pages/goods_details/index?id=${item.id}`
})
})
}
},
//
godDetail(item) {
goShopDetail(item, this.uid).then(res => {
uni.navigateTo({
url: `/pages/goods_details/index?id=${item.id}`
})
})
},
//
getGroomList(onloadH) { getGroomList(onloadH) {
this.loading = true if (!this.goodScroll) {
let type = this.goodType; return
if (!this.goodScroll) return }
if (onloadH) { if (onloadH) {
this.iSshowH = true this.iSshowH = true
} }
getGroomList(type, this.params).then(({ this.loading = true
data console.log(this.goodType, '====')
}) => { const type = this.goodType === 1 ? 'best' :
this.goodType === 2 ? 'hot' :
this.goodType === 3 ? 'new' :
this.goodType === 4 ? 'benefit':
this.goodType === 5 ? 'good': ''
ProductSpuApi.getSpuPage({
recommendType: type,
pageNo: this.params.page,
pageSize: this.params.limit
}).then(res => {
const good_list = res.data.list;
this.iSshowH = false this.iSshowH = false
this.loading = false this.loading = false
this.goodScroll = data.list.length >= this.params.limit this.goodScroll = good_list.length >= this.params.limit
this.params.page++ this.params.page++
this.tempArr = this.tempArr.concat(data.list)
//
const spuIds = good_list.map(item => item.id);
PromotionActivityApi.getActivityListBySpuIds(spuIds).then(res => {
ProductUtil.setActivityList(good_list, res.data);
this.tempArr = this.tempArr.concat(good_list); // Vue
});
}) })
}, },
/** /**
* 获取我的推荐 * 前往商品详情
*/
goDetail(item) {
goShopDetail(item, this.uid).then(res => {
uni.navigateTo({
url: `/pages/goods_details/index?id=${item.id}`
})
})
},
/**
* 获取我的推荐 TODO 芋艿没实现
*/ */
get_host_product: function() { get_host_product: function() {
let that = this; let that = this;
@ -609,11 +586,13 @@
that.hostProduct = that.hostProduct.concat(res.data.list) that.hostProduct = that.hostProduct.concat(res.data.list)
}); });
}, },
fen2yuan(price) {
return Util.fen2yuan(price)
}
}, },
mounted() { mounted() {
let self = this let self = this
// #ifdef H5 // #ifdef H5
//self.getChatUrL();
// H5 // H5
let appSearchH = uni.createSelectorQuery().select(".serch-wrapper"); let appSearchH = uni.createSelectorQuery().select(".serch-wrapper");
appSearchH.boundingClientRect(function(data) { appSearchH.boundingClientRect(function(data) {