12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352135313541355135613571358135913601361136213631364136513661367136813691370137113721373137413751376137713781379138013811382138313841385138613871388138913901391139213931394139513961397139813991400140114021403140414051406140714081409141014111412141314141415141614171418141914201421142214231424142514261427142814291430143114321433143414351436143714381439144014411442144314441445144614471448144914501451145214531454145514561457145814591460146114621463146414651466146714681469147014711472147314741475147614771478147914801481148214831484148514861487148814891490149114921493149414951496149714981499150015011502150315041505150615071508150915101511151215131514151515161517151815191520152115221523152415251526152715281529153015311532153315341535153615371538153915401541154215431544154515461547154815491550155115521553 |
- <template>
- <view class="home-container">
-
- <block v-show="isLoaded">
- <custom :bgColor="'bg-them'" :backColor="'#FFFFFF'" :isBack="false" v-show="scrollTop > 100">
- <text slot="content" style="color: #FFFFFF; font-size: 36rpx;">{{configInfo.minAppName}}</text>
- </custom>
-
- <view class="top-container">
- <image src="@/static/home/top_bg.png" mode="widthFix" class="bg"></image>
-
- <view class="content">
- <view class="title" :style="cuStyle">{{configInfo.minAppName}}</view>
-
- <view class="search">
- <image src="/static/icon/search.png" class=""></image>
- <input type="text" confirm-type="search" placeholder="搜索商品名称或型号" v-model="keyword" @confirm="searchSubmit">
- </view>
- </view>
- </view>
-
- <view class="classify-container">
- <view class="content">
- <block v-for="(item, index) in classifyList" :key='index'>
- <view class="item" @tap="toClassifyLst(item.categoryId)">
- <image :src="item.imgUrl" mode="aspectFill"></image>
- <text class="ellipsis">{{item.name}}</text>
- </view>
- </block>
- <view class="item" @tap="toClassifyLst(0)">
- <image src="@/static/home/class_more.png" mode="aspectFill"></image>
- <text>更多分类</text>
- </view>
- </view>
- </view>
-
- <view class="swiper-container" v-if="isShow_banner && bannerList.length > 0">
- <swiper @change="changeBanner" :autoplay="true">
- <block v-for="(item, index) in bannerList" :key='index'>
- <swiper-item>
- <image :src="item.imgSrc" mode="aspectFill" @tap="toMiniProgram(item.appId, item.linkUrl)" v-if="item.type === 2"></image>
- <image :src="item.imgSrc" mode="aspectFill" @tap="toActivityList(item.goodsId)" v-if="item.type === 3"></image>
- <image :src="item.imgSrc" mode="aspectFill" @tap="toGoodsDetail(item.goodsId)" v-else></image>
- </swiper-item>
- </block>
- </swiper>
- <view class="dots-conatiner">
- <view class="con" :style="'width:'+(bannerList.length * 20)+'rpx;'" >
- <view class="dot" :style=" 'transform:translateX('+ (bannerCurrent * 100) +'%)' " ></view>
- </view>
- </view>
- </view>
-
- <view class="notice-container" v-if="isShow_notice && noticeList.length > 0 && userInfo.type === 'SERVICE'">
- <view class="content">
- <view class="left">
- <image src="@/static/home/notice.png" ></image>
- </view>
- <swiper class="swiper" :autoplay="true" :vertical="true" :circular="true" :disable-touch="true">
- <block v-for="(item,index) in noticeList" :key='index' >
- <swiper-item @touchmove.stop='stopTouchMove'>
- <view class="ellipsis">{{item.workUserName}}成功分享商城,获得收益{{item.amount}}元</view>
- </swiper-item>
- </block>
- </swiper>
- </view>
- </view>
-
- <view class="coupon-container" v-if="isShow_coupon && couponList.length > 0">
- <image src="@/static/home/cp_bg1.png" mode="widthFix" class="bg" v-if="couponList.length == 1"></image>
- <image src="@/static/home/cp_bg2.png" mode="widthFix" class="bg" v-if="couponList.length > 1"></image>
-
- <view class="list list1" v-if="couponList.length == 1">
- <block v-for="(item, index) in couponList" :key='index'>
- <view class="item" @tap="handleCoupon(item)">
- <image class="cp" src="@/static/home/coupon_bg1.png"></image>
- <view class="content">
- <view class="left">
- <view class="price">¥{{item.couponValue}}</view>
- <view class="text" v-if="item.couponType == 'SATISFY'">满{{item.orderAmount}}可用</view>
- </view>
- <view class="right">
- <view class="main">
- <view class="row1 ellipsis-2">{{item.couponName}}</view>
- <view class="row2">
- <view class="date" v-if="item.obtainType == 0 || item.obtainType == 1">
- <view>领取时间:</view>
- <view>{{item.obtainStartTime | dateToYYmmdd2}}-{{item.obtainEndTime | dateToYYmmdd2}}</view>
- </view>
- <view class="date" v-if="item.obtainType == 2">
- <view>使用时间:</view>
- <view>{{item.activeStartTime | dateToYYmmdd2}}-{{item.activeEndTime | dateToYYmmdd2}}</view>
- </view>
- <view class="button gary" v-if="item.obtainType == 0">待开始</view>
- <view class="button red" v-if="item.obtainType == 1">立即领取</view>
- <view class="button white" v-if="item.obtainType == 2">去使用</view>
- </view>
- </view>
- </view>
- </view>
- </view>
- </block>
- </view>
-
- <view class="list list2" v-if="couponList.length == 2">
- <block v-for="(item, index) in couponList" :key='index'>
- <view class="item" @tap="handleCoupon(item)">
- <image class="cp" src="@/static/home/coupon_bg2.png"></image>
- <view class="content">
- <view class="top">
- <view class="price">¥{{item.couponValue}}</view>
- <view class="text">满{{item.orderAmount}}可用</view>
- </view>
- <view class="bottom">
- <view class="name ellipsis">{{item.couponName}}</view>
- <view class="date ellipsis" v-if="item.obtainType == 0 || item.obtainType == 1">领取时间:{{item.obtainStartTime | dateToYYmmdd2}}-{{item.obtainEndTime | dateToYYmmdd2}}</view>
- <view class="date ellipsis" v-if="item.obtainType == 2">使用时间:{{item.activeStartTime | dateToYYmmdd2}}-{{item.activeEndTime | dateToYYmmdd2}}</view>
- <view class="button gary" v-if="item.obtainType == 0">待开始</view>
- <view class="button red" v-if="item.obtainType == 1">立即领取</view>
- <view class="button white" v-if="item.obtainType == 2">去使用</view>
- </view>
- </view>
- </view>
- </block>
- </view>
-
- <view class="list list3" v-if="couponList.length > 2">
- <view class="left">
- <block v-for="(item, index) in couponList" :key='index'>
- <view class="item" @tap="handleCoupon(item)">
- <image class="cp" src="@/static/home/coupon_bg3.png"></image>
- <view class="content">
- <view class="top">
- <view class="price">¥{{item.couponValue}}</view>
- <view class="text">满{{item.orderAmount}}可用</view>
- </view>
- <view class="bottom">
- <view class="name ellipsis">{{item.couponName}}</view>
- <view class="date ellipsis" v-if="item.obtainType == 0 || item.obtainType == 1">领取时间:{{item.obtainStartTime | dateToYYmmdd2}}-{{item.obtainEndTime | dateToYYmmdd2}}</view>
- <view class="date ellipsis" v-if="item.obtainType == 2">使用时间:{{item.activeStartTime | dateToYYmmdd2}}-{{item.activeEndTime | dateToYYmmdd2}}</view>
- <view class="button gary" v-if="item.obtainType == 0">待开始</view>
- <view class="button red" v-if="item.obtainType == 1">立即领取</view>
- <view class="button white" v-if="item.obtainType == 2">去使用</view>
- </view>
- </view>
- </view>
- </block>
- </view>
- <view class="right">
- <view class="text" @tap="toReceiveCoupon">
- <text>查</text>
- <text>看</text>
- <text>更</text>
- <text>多</text>
- <image src="@/static/home/cp_more.png"></image>
- </view>
- </view>
- </view>
- </view>
-
- <view class="myManager-container" v-if="isShow_manager && myManagerDetail && !userInfo.promotionGroupLeader && !userInfo.type === 'SERVICE'">
- <view class="content">
- <view class="left">
- <image :src="myManagerDetail.avatar" mode="aspectFill" v-if="myManagerDetail.avatar.indexOf('http') >= 0"></image>
- <image :src="imageUrl + myManagerDetail.avatar" mode="aspectFill" v-else></image>
- <view class="main">
- <view>客户经理:{{myManagerDetail.workName}}</view>
- <view>{{myManagerDetail.workPhone}}</view>
- </view>
- </view>
- <view class="right" @tap="callPhone(myManagerDetail.workPhone)">拨打电话</view>
- </view>
- </view>
-
- <view class="seckill-container" v-if="isShow_seckill && seckillTimeList.length > 0">
- <image src="@/static/home/seckill_bg.png" mode="widthFix" class="bg"></image>
-
- <view class="content">
- <view class="time-list">
- <block v-for="(item, index) in seckillTimeList" :key='index'>
- <view class="item" :class="seckillTimeCurrent == index ? 'current':''" @tap="changeSeckillTime(index)">
- <view class="time">{{item.startHour}}:00</view>
- <view class="tag" v-if="item.type == 'yjs'">已结束</view>
- <view class="tag" v-if="item.type == 'jxz'">{{countdownTime}}</view>
- <view class="tag" v-if="item.type == 'wks'">即将开始</view>
- </view>
- </block>
- </view>
- <view class="product-list">
- <block v-for="(item, index) in seckillGoodsList" :key='index'>
- <div class="item" @tap="toSeckillGoodsDetail(item.goodsId)">
- <image :src="item.imgUrl" mode="aspectFill"></image>
- <view class="right">
- <view class="title ellipsis-2">{{item.goodsName}}</view>
- <view class="des ellipsis-2">{{item.describeText ? item.describeText : ''}}</view>
- <view class="stock-sales">
- <view class="stock">
- <text>剩余{{item.secStockNum}}件</text>
- <view class="progress-box">
- <!-- 库存 / 总数 * 100 = 剩余百分比 -->
- <progress :percent="item.secStockNum / item.limitBuy * 100" activeColor="#FF3F42" active stroke-width="6" />
- </view>
- </view>
- <view class="sales">销量:{{item.salesVolume}}</view>
- </view>
- <view class="bottom">
- <view class="price">
- <view class="price-1">¥{{item.price | numToFixed}}</view>
- <view class="price-2">¥{{item.goodsPrice | numToFixed}}</view>
- </view>
- <view class="btn" v-if="seckillTimeList[seckillTimeCurrent].type == 'jxz'">马上抢</view>
- <view class="btn2" v-else>马上抢</view>
- </view>
- </view>
- </div>
- </block>
- </view>
- <view class="loadmore" v-if="!seckillGoodsNoMore" @tap="loadMoreSeckillGoods">点击加载更多商品</view>
- </view>
- </view>
-
- <view class="recom-container" v-if="isShow_recom">
- <view class="top">
- <view class="title"><image src="@/static/home/recom.png"></image></view>
- <scroll-view
- :scroll-x="true"
- :scroll-left="scrollLeft"
- scroll-with-animation
- :show-scrollbar="false"
- class="tabs-view"
- ref="tabs-view">
- <view class="tab">
- <block v-for="(item, index) in tabList" :key='index'>
- <view class="item" :ref="`tabs-item-${index}`" :class="[`tabs-item-${index}`, item.categoryId == tabCurrent ? 'current':'']" @tap="changeTab(item.categoryId)">{{item.name}}</view>
- </block>
- </view>
- </scroll-view>
- </view>
- <view class="list">
- <block v-for="(item, index) in recomList" :key='index'>
- <view class="item" @tap="toGoodsDetail(item.goodsId)">
- <view class="image">
- <image :src="item.imgUrl" mode="aspectFill" class="img"></image>
- <image :src="item.logo" mode="aspectFill" class="water" v-if="item.isShowWater"></image>
- </view>
- <view class="content">
- <view class="title ellipsis-2">{{item.goodsName}}</view>
- <view class="bottom">
- <view class="price">
- <view class="price-1">¥{{item.goodsPrice | numToFixed}}</view>
- <view class="price-2">¥{{item.orgGoodsPrice | numToFixed}}</view>
- </view>
- <view class="btn"><image src="@/static/icon/cart.png" mode="aspectFill"></image></view>
- </view>
- </view>
- </view>
- </block>
- </view>
- <no-data v-if="!recomList.length" :showText="'暂无商品'"></no-data>
- </view>
-
- </block>
- </view>
- </template>
- <script>
- import {mapState} from 'vuex';
-
- export default {
- props:{
- homePage: {
- type: Number,
- default: 0
- },
- templateInfo: {
- type: Object,
- default: {}
- }
- },
- data() {
- return {
- thisHomePage: 1, // 当前首页页面模版
-
- imageUrl: this.$imageUrl,
- configInfo: uni.getStorageSync('configInfo'),
- isShow_banner: false,
- isShow_notice: false,
- isShow_classify: false,
- isShow_seckill: false,
- isShow_coupon: false,
- isShow_manager: false,
- isShow_recom: false,
-
- scrollTop: 0, // 滚动高度(用于控制自定义导航)
- keyword: '', // 搜索关键词
- classifyList: [], // 分类列表
- bannerList: [], // 轮播图列表
- bannerCurrent: 0, // 轮播图当前值
- noticeList: [],
- couponList: [], // 可领取优惠券列表
- myManagerDetail: null, // 我的客户经理信息
- seckillTimeList: [], // 秒杀时间段列表
- seckillTimeCurrent: 0, // 秒杀时间段选择
- seckillGoodsList: [], // 秒杀商品列表
- seckillGoodsPage: 1, // 秒杀商品分页
- seckillGoodsNoMore: false, //
- countdownTime: '', // 倒计时
- endDatetime: '', // 倒计时结束时间
- nowDate: null, // 当前时间
- dateInterval: null, // 时间定时器
- tabList: [], // 好物推荐分类列表
- tabCurrent: 1, // 好物推荐分类当前值
- recomList: [], // 好物推荐列表
-
- isLoaded_banner: false,
- isLoaded_coupon: false,
- isLoaded_seckill: false,
- isLoaded_tab: false,
- isLoaded_myManager: false,
-
- scrollLeft: 50,
- scrollViewWidth: 0,
- tabsRect: {
- left: 0
- },
- }
- },
- computed:{
- cuStyle(){
- return `height:${this.CustomBar-this.StatusBar}px; padding-top:${this.StatusBar}px;`
- },
- ...mapState(['userInfo', 'isLogin', 'userId']),
- isLoaded() {
- uni.hideLoading();
- return (!this.isShow_banner || (this.isShow_banner && this.isLoaded_banner))
- && (!this.isShow_coupon || (this.isShow_coupon && this.isLoaded_coupon))
- && (!this.isShow_seckill || (this.isShow_seckill && this.isLoaded_seckill))
- && (!this.isShow_classify || (this.isShow_classify && this.isLoaded_tab))
- && (!this.isShow_manager || (this.isShow_manager && this.isLoaded_myManager))
- }
- },
- watch: {
- nowDate() {
- let hh = this.nowDate.getHours(),
- mm = this.nowDate.getMinutes(),
- ss = this.nowDate.getSeconds();
- let hs = [10, 12, 15, 18, 20];
- if(mm == 0 && ss == 0 && hs.indexOf(hh) >= 0) {
- setTimeout(() => {
- this.getSeckillTimeList();
- }, 1000)
- }
- },
- tabList() {
- this.$nextTick(() => {
- this.resize()
- })
- },
- templateInfo: {
- handler(newValue, oldValue) {
- const templateInfo = this.templateInfo;
- this.isShow_banner = templateInfo.carouseStatus;
- this.isShow_classify = templateInfo.categoryStatus;
- this.isShow_seckill = templateInfo.killStatus;
- this.isShow_coupon = templateInfo.couponStatus;
- this.isShow_manager = templateInfo.customerStatus;
- this.isShow_notice = templateInfo.notiveStatus;
- this.isShow_recom = templateInfo.okStatus;
- },
- immediate: true,
- deep: true
- }
- },
- mounted() {
- uni.$on('onPageScroll', (data) => {
- if(this.homePage !== this.thisHomePage) return false;
-
- this.scrollTop = data;
- });
-
- uni.$on('onPullDownRefresh', (data) => {
- if(this.homePage !== this.thisHomePage) return false;
-
- this.keyword = '';
- this.getTabList();
- this.getBannerList();
- this.getNoticeList();
- this.getCouponList();
- this.getMyManager();
- this.getSeckillTimeList();
- });
-
- uni.$on('onShow', (data) => {
- if(this.homePage !== this.thisHomePage) return false;
-
- console.log('onShow page ' + this.thisHomePage);
- this.keyword = '';
- this.getTabList();
- this.getBannerList();
- this.getNoticeList();
- this.getCouponList();
- this.getMyManager();
- this.getSeckillTimeList();
-
- this.dateInterval = setInterval(() => {
- this.nowDate = new Date();
- }, 1000)
- });
-
- uni.$on('onHide', (data) => {
- if(this.homePage !== this.thisHomePage) return false;
-
- clearInterval(this.dateInterval);
- })
- },
- methods: {
- // 搜索商品
- searchSubmit() {
- uni.navigateTo({
- url: '/packageGoods/pages/search?keyword=' + this.keyword
- })
- },
-
- // 获取一级菜单
- getTabList() {
- this.$axios({
- url: '/goods/category/list',
- method: 'get',
- params: {}
- }).then(res => {
- this.tabList = res.data;
- this.classifyList = res.data.slice(0, 9);
- this.tabCurrent = res.data.length > 0 ? res.data[0].categoryId : 0;
- this.getRecomList();
-
- uni.stopPullDownRefresh();
- }).finally(res => {
- this.isLoaded_tab = true;
- })
- },
-
- // 去分类列表
- toClassifyLst(categoryId) {
- uni.setStorageSync('categoryId', categoryId);
- uni.switchTab({
- url:'/pages/goods/classify'
- })
- },
-
- // 获取轮播图列表
- getBannerList() {
- this.$axios({
- url: '/common/list/page',
- method: 'get',
- params: {
- pageNum: 1,
- pageSize: 10,
- state: true
- }
- }).then(res => {
- this.bannerList = res.data.records;
- }).finally(res => {
- this.isLoaded_banner = true;
- uni.stopPullDownRefresh();
- })
- },
-
- // 切换广告图
- changeBanner(e) {
- this.bannerCurrent = e.detail.current;
- },
-
- // 获取公告列表
- getNoticeList() {
- this.$axios({
- url: '/renovation/settle/list',
- method: 'get',
- params: {
-
- }
- }).then(res => {
- if(res.data) {
- res.data.forEach(item => {
- item.workUserName = item.workUserName.slice(0, 1) + '师傅';
- })
- this.noticeList = res.data;
- }
- })
- },
-
- // 获取可领优惠券列表
- getCouponList() {
- this.$axios({
- url: '/coupon/list/all',
- method: 'get',
- params: {
- userId: this.userId
- }
- }).then(res => {
- this.couponList = res.data;
- }).finally(res => {
- this.isLoaded_coupon = true;
- })
- },
-
- // 处理优惠券
- handleCoupon(item) {
- if(item.obtainType == 0) {
- return this.$toast('该优惠券不可领取');
- }else if(item.obtainType == 1) {
- this.$axios({
- url: '/coupon/obtain',
- method: 'get',
- params: {
- userId: this.userId,
- couponId: item.couponId
- }
- }).then(res => {
- this.$successToast('领取成功');
- this.getCouponList();
- })
- }else if(item.obtainType == 2) {
- uni.switchTab({
- url: '/pages/goods/classify'
- });
- }
- },
-
- // 去可领取优惠券
- toReceiveCoupon() {
- uni.navigateTo({
- url:'/pages/index/coupon'
- })
- },
-
- // 获取我的客户经理
- getMyManager() {
- this.$axios({
- url: '/user/parent',
- method: 'get',
- params: {
- userId: this.userId
- }
- }).then(res => {
- if(res.data) {
- this.myManagerDetail = res.data;
- }
- }).finally(res => {
- this.isLoaded_myManager = true;
- })
- },
-
- // 拨打电话
- callPhone(val) {
- uni.makePhoneCall({
- phoneNumber: val
- });
- },
-
- findElem(array, attr, val) {
- for (var i = 0; i < array.length; i++) {
- if (array[i][attr] == val) {
- return i; //返回当前索引值
- }
- }
- return -1;
- },
-
- // 计算倒计时
- countTime() {
- let endDatetime = this.endDatetime.replace(/\-/g, '/');
- // console.log(endDatetime)
- var nowtime = new Date(), //获取当前时间
- endtime = new Date(endDatetime); //定义结束时间
- var lefttime = endtime.getTime() - nowtime.getTime(), //距离结束时间的毫秒数
- hh = Math.floor(lefttime/(1000*60*60)), //计算小时数
- mm = Math.floor(lefttime/(1000*60)%60), //计算分钟数
- ss = Math.floor(lefttime/1000%60); //计算秒数
- // console.log(new Date(endDatetime))
- function checkTime(i){
- if (i<10) {
- i = "0"+i;
- }
- return i;
- }
- setTimeout(() => {
- this.countTime();
- }, 1000);
- this.countdownTime = checkTime(hh) + ":" + checkTime(mm) + ":" + checkTime(ss);
- // console.log(this.countdownTime)
- },
-
- // 获取秒杀时间列表
- getSeckillTimeList() {
- this.$axios({
- url: '/goods/sec/time',
- method: 'get',
- params: {}
- }).then(res => {
- if(res.data.length < 1) {return false;}
- this.seckillTimeList = res.data;
- this.seckillTimeCurrent = this.findElem(this.seckillTimeList, 'type', 'jxz');
- if(this.seckillTimeCurrent == -1) {
- this.seckillTimeCurrent = 0;
- this.getSeckillGoodsList();
- }else {
- this.endDatetime = this.seckillTimeList[this.seckillTimeCurrent].endDatetime;
- this.countTime();
- this.getSeckillGoodsList();
- }
- }).finally(res => {
- this.isLoaded_seckill = true;
- })
- },
-
- // 切换秒杀时间
- changeSeckillTime(index) {
- this.seckillTimeCurrent = index;
- this.getSeckillGoodsList();
- },
-
- // 获取秒杀商品列表
- getSeckillGoodsList(loadMore) {
- if(this.seckillGoodsNoMore && loadMore)return;
- if(!loadMore) {
- this.seckillGoodsNoMore = false;
- this.seckillGoodsPage = 1;
- }
- let secKillId = this.seckillTimeList[this.seckillTimeCurrent].secKillId;
- this.$axios({
- url: '/goods/sec/goods/list',
- method: 'get',
- params: {
- pageNum: this.seckillGoodsPage,
- pageSize: 5,
- secKillId: secKillId,
- }
- }).then(res => {
- let _list = res.data.records;
- let pageTotal = res.data.pages;
- if(this.seckillGoodsPage >= pageTotal){
- this.seckillGoodsNoMore = true;
- }
- if (_list.length) {
- this.seckillGoodsPage += 1;
- }
- if (loadMore) {
- this.seckillGoodsList = this.seckillGoodsList.concat(_list);
- } else {
- this.seckillGoodsList = _list;
- }
- })
- },
-
- // 加载更多秒杀商品
- loadMoreSeckillGoods() {
- this.getSeckillGoodsList(true);
- },
-
- // 进入秒杀商品详情
- toSeckillGoodsDetail(id) {
- if(!id) {
- return false;
- }
- if(this.seckillTimeList[this.seckillTimeCurrent].type == 'wks') {
- return this.$toast('活动未开始');
- }
- if(this.seckillTimeList[this.seckillTimeCurrent].type == 'yjs') {
- return this.$toast('活动已结束');
- }
- uni.navigateTo({
- url: '/packageGoods/pages/detail?id=' + id
- })
- },
-
- // 切换一级菜单
- changeTab(current) {
- this.tabCurrent = current;
- this.getRecomList();
- this.resize();
- },
-
- // 获取好物推荐商品列表
- getRecomList() {
- this.$axios({
- url: '/goods/list/level1',
- method: 'get',
- params: {
- pageNum: 1,
- pageSize: 6,
- categoryId: this.tabCurrent,
- },
- }).then(res => {
- res.data.records.forEach(item => {
- if(item.logo && item.logoStartTime) {
- item.isShowWater = this.$compareTime(item.logoStartTime, item.logoEndTime);
- }else {
- item.isShowWater = false;
- }
- })
- this.recomList = res.data.records;
- })
- },
-
- // 进入商品详情
- toGoodsDetail(id) {
- if(!id) {
- return false;
- }
- uni.navigateTo({
- url: '/packageGoods/pages/detail?id=' + id
- })
- },
-
- // 跳转小程序
- toMiniProgram(appId, path) {
- wx.navigateToMiniProgram({
- appId,
- path,
- extraData: {},
- envVersion: 'release',
- success(res) {}
- });
- },
-
- // 进入活动列表
- toActivityList(type) {
- uni.navigateTo({
- url: '/packageGoods/pages/activity?type=' + type
- })
- },
-
- setScrollLeft() {
- // 当前活动tab的布局信息,有tab菜单的width和left(为元素左边界到父元素左边界的距离)等信息
- const index = this.findElem(this.tabList, 'categoryId', this.tabCurrent);
- const tabRect = this.tabList[index]
- // 累加得到当前item到左边的距离
- const offsetLeft = this.tabList
- .slice(0, index)
- .reduce((total, curr) => {
- return total + curr.rect.width
- }, 0)
- // 此处为屏幕宽度
- const res = uni.getSystemInfoSync();
- const windowWidth = res.windowWidth;
- // 将活动的tabs-item移动到屏幕正中间,实际上是对scroll-view的移动
- let scrollLeft = offsetLeft - (this.tabsRect.width - tabRect.rect.width) / 2 - (windowWidth - this.tabsRect.right) / 2 + this.tabsRect.left / 2
-
- // 这里做一个限制,限制scrollLeft的最大值为整个scroll-view宽度减去tabs组件的宽度
- scrollLeft = Math.min(scrollLeft, this.scrollViewWidth - this.tabsRect.width)
- this.scrollLeft = Math.max(0, scrollLeft)
- },
- // 获取所有标签的尺寸
- resize() {
- // 如果不存在list,则不处理
- if(this.tabList.length === 0) {
- return
- }
- Promise.all([this.getTabsRect(), this.getAllItemRect()]).then(([tabsRect, itemRect = []]) => {
- this.tabsRect = tabsRect
- this.scrollViewWidth = 0
- itemRect.map((item, index) => {
- // 计算scroll-view的宽度,这里
- this.scrollViewWidth += item.width
- // 另外计算每一个item的中心点X轴坐标
- this.tabList[index].rect = item
- })
- // 获取了tabs的尺寸之后,设置滑块的位置
- this.setScrollLeft()
- })
- },
- // 获取导航菜单的尺寸
- getTabsRect() {
- return new Promise(resolve => {
- this.queryRect('tabs-view').then(size => resolve(size))
- })
- },
- // 获取所有标签的尺寸
- getAllItemRect() {
- return new Promise(resolve => {
- const promiseAllArr = this.tabList.map((item, index) => this.queryRect(
- `tabs-item-${index}`, true))
- Promise.all(promiseAllArr).then(sizes => resolve(sizes))
- })
- },
- // 获取各个标签的尺寸
- queryRect(el, item) {
- const query = uni.createSelectorQuery().in(this);
- return new Promise(resolve => {
- query.select(`.${el}`).boundingClientRect(data => {
- resolve(data)
- }).exec();
- })
- },
- }
- }
- </script>
- <style lang="scss" scoped>
- .top-container {
- position: relative;
- .bg {
- display: block;
- width: 750rpx;
- position: absolute;
- top: 0;
- z-index: 0;
- }
- .content {
- width: 710rpx;
- padding: 0 20rpx;
- position: relative;
- z-index: 1;
- }
- .title {
- display: flex;
- align-items: center;
- justify-content: center;
- color: #FFFFFF;
- font-size: 36rpx;
- }
- .search {
- background: #FFFFFF;
- height: 64rpx;
- display: flex;
- align-items: center;
- border-radius: 64rpx;
- padding: 0 20rpx;
- margin-top: 20rpx;
- image {
- width: 28rpx;
- height: 28rpx;
- }
- input {
- width: 100%;
- padding-left: 15rpx;
- }
- }
- }
- .classify-container {
- margin-top: 40rpx;
- position: relative;
- z-index: 1;
- padding: 0 20rpx;
- .content {
- border-radius: 20rpx;
- padding-top: 30rpx;
- display: flex;
- flex-wrap: wrap;
- background: #FFFFFF;
- .item {
- display: flex;
- flex-direction: column;
- align-items: center;
- width: 142rpx;
- margin-bottom: 30rpx;
- image {
- width: 78rpx;
- height: 78rpx;
- display: block;
- border-radius: 50%;
- overflow: hidden;
- }
- text {
- font-size: 24rpx;
- color: #666666;
- margin-top: 10rpx;
- width: 150rpx;
- text-align: center;
- }
- }
- }
- }
- .swiper-container {
- position: relative;
- margin-top: 20rpx;
- swiper {
- height: 350rpx;
- }
- image {
- height: 350rpx;
- width: 710rpx;
- display: block;
- margin: 0 auto 0;
- border-radius: 15rpx;
- overflow: hidden;
- }
- .dots-conatiner {
- position: absolute;
- width: 100%;
- bottom: 40rpx;
- display: flex;
- align-items: center;
- justify-content: center;
- .con {
- border-radius: 4rpx;
- overflow: hidden;
- height: 4rpx;
- background-color: rgba($color: #FFFFFF, $alpha: 0.3);
- }
- .dot {
- width: 20rpx;
- height: 4rpx;
- background-color: #FFFFFF;
- transition: all .3s;
- }
- }
- }
- .notice-container {
- padding: 0 20rpx;
- margin-top: 20rpx;
- .content {
- display: flex;
- align-items: center;
- height: 100rpx;
- background: #FFFFFF;
- border-radius: 20rpx;
- }
- .left{
- display: flex;
- align-items: center;
- justify-content: center;
- width: 96rpx;
- height: 48rpx;
- margin-right: 20rpx;
- border-right: 2rpx solid #E5E5E5;
- image {
- width: 60rpx;
- height: 30rpx;
- display: block;
- }
- }
- .swiper{
- height: 100rpx;
- flex: 1;
- padding-right: 20rpx;
- ::v-deep swiper-item {
- display: block;
- height: 100rpx;
- width: 100%;
- line-height: 100rpx;
- }
- }
- }
- .coupon-container {
- position: relative;
- margin-top: 20rpx;
- padding: 0 20rpx;
- .bg {
- display: block;
- width: 100%;
- }
- .list {
- position: absolute;
- top: 80rpx;
- z-index: 1;
- }
- .list1 {
- .item {
- position: relative;
- margin-bottom: 20rpx;
- margin-left: 16rpx;
- .cp {
- width: 688rpx;
- height: 178rpx;
- display: block;
- }
- .content {
- position: absolute;
- left: 0;
- top: 0;
- width: 710rpx;
- height: 160rpx;
- display: flex;
- align-items: center;
- .left {
- width: 210rpx;
- display: flex;
- align-items: center;
- justify-content: center;
- flex-direction: column;
- .price {
- font-size: 48rpx;
- color: #FFFFFF;
- }
- .text {
- color: #FFFFFF;
- font-size: 28rpx;
- }
- }
- .right {
- display: flex;
- align-items: center;
- justify-content: space-between;
- padding: 0 20rpx;
- width: 470rpx;
- height: 150rpx;
- box-sizing: border-box;
- .main {
- width: 430rpx;
- height: 150rpx;
- padding: 16rpx 0 8rpx;
- box-sizing: border-box;
- display: flex;
- flex-direction: column;
- justify-content: space-between;
- .row1 {
- font-size: 28rpx;
- line-height: 32rpx;
- height: 64rpx;
- }
- .row2 {
- font-size: 24rpx;
- line-height: 28rpx;
- color: #999999;
- display: flex;
- justify-content: space-between;
- align-items: center;
- }
- }
- }
- }
- }
- }
- .list2 {
- display: flex;
- .item {
- position: relative;
- margin-bottom: 20rpx;
- &:first-child {
- margin-left: 16rpx;
- }
- .cp {
- width: 342rpx;
- height: 308rpx;
- display: block;
- }
- .content {
- position: absolute;
- left: 0;
- top: 0;
- width: 342rpx;
- height: 328rpx;
- display: flex;
- flex-direction: column;
- align-items: center;
- .top {
- width: 324rpx;
- height: 130rpx;
- display: flex;
- align-items: center;
- justify-content: center;
- flex-direction: column;
- .price {
- font-size: 48rpx;
- color: #FFFFFF;
- line-height: 48rpx;
- margin-top: 16rpx;
- }
- .text {
- color: #FFFFFF;
- font-size: 28rpx;
- line-height: 28rpx;
- margin-top: 10rpx;
- }
- }
- .bottom {
- width: 324rpx;
- height: 160rpx;
- padding: 16rpx;
- box-sizing: border-box;
- display: flex;
- flex-direction: column;
- justify-content: space-between;
- align-items: center;
- .name {
- font-size: 28rpx;
- text-align: left;
- line-height: 32rpx;
- width: 100%;
- }
- .date {
- font-size: 24rpx;
- color: #999999;
- text-align: left;
- width: 100%;
- line-height: 28rpx;
- }
- }
- }
- }
- }
- .list3 {
- display: flex;
- align-items: center;
- .left {
- display: flex;
- width: 630rpx;
- overflow-x: scroll;
- }
- .right {
- width: 80rpx;
- display: flex;
- justify-content: center;
- .text {
- width: 48rpx;
- height: 200rpx;
- border-radius: 48rpx;
- background: #FFFFFF;
- display: flex;
- flex-direction: column;
- align-items: center;
- justify-content: center;
- text {
- font-size: 28rpx;
- color: #FF3F42;
- line-height: 32rpx;
- }
- image {
- width: 32rpx;
- height: 32rpx;
- display: block;
- flex-shrink: 0;
- margin-top: 10rpx;
- }
- }
- }
- .item {
- position: relative;
- margin-bottom: 20rpx;
- &:first-child {
- margin-left: 16rpx;
- }
- .cp {
- width: 278rpx;
- height: 308rpx;
- display: block;
- }
- .content {
- position: absolute;
- left: 0;
- top: 0;
- width: 278rpx;
- height: 328rpx;
- display: flex;
- flex-direction: column;
- align-items: center;
- .top {
- width: 260rpx;
- height: 130rpx;
- display: flex;
- align-items: center;
- justify-content: center;
- flex-direction: column;
- .price {
- font-size: 48rpx;
- color: #FFFFFF;
- line-height: 48rpx;
- margin-top: 16rpx;
- }
- .text {
- color: #FFFFFF;
- font-size: 28rpx;
- line-height: 28rpx;
- margin-top: 10rpx;
- }
- }
- .bottom {
- width: 260rpx;
- height: 160rpx;
- padding: 16rpx;
- box-sizing: border-box;
- display: flex;
- flex-direction: column;
- justify-content: space-between;
- align-items: center;
- .name {
- font-size: 28rpx;
- text-align: left;
- line-height: 32rpx;
- width: 100%;
- }
- .date {
- font-size: 24rpx;
- color: #999999;
- text-align: left;
- width: 100%;
- line-height: 28rpx;
- }
- }
- }
- }
- }
- .button {
- width: 120rpx;
- height: 40rpx;
- border-radius: 40rpx;
- font-size: 24rpx;
- flex-shrink: 0;
- box-sizing: border-box;
- display: flex;
- justify-content: center;
- align-items: center;
- &.gary {
- background: #AAAAAA;
- color: #FFFFFF;
- border: 1px solid #AAAAAA;
- }
- &.red {
- background: #C434FF;
- color: #FFFFFF;
- border: 1px solid #C434FF;
- }
- &.white {
- color: #FF3F42;
- border: 1px solid #FF3F42;
- }
- }
- }
- .myManager-container {
- padding: 0 20rpx;
- .content {
- display: flex;
- justify-content: space-between;
- align-items: center;
- background: #FFFFFF;
- border-radius: 20rpx;
- padding: 20rpx;
- .left {
- display: flex;
- align-items: center;
- image {
- width: 100rpx;
- height: 100rpx;
- border-radius: 50%;
- }
- .main {
- font-size: 28rpx;
- line-height: 48rpx;
- margin-left: 20rpx;
- }
- }
- .right {
- width: 160rpx;
- height: 60rpx;
- line-height: 60rpx;
- border-radius: 60rpx;
- text-align: center;
- font-size: 28rpx;
- color: #E43B38;
- border: 1px solid #E43B38;
- }
- }
- }
- .seckill-container {
- position: relative;
- margin-top: 20rpx;
- min-height: 340rpx;
- .bg {
- display: block;
- width: 750rpx;
- position: absolute;
- top: 0;
- z-index: 0;
- }
- .content {
- width: 710rpx;
- padding: 0 20rpx;
- position: relative;
- z-index: 1;
- }
- .time-list {
- display: flex;
- overflow-x: scroll;
- padding-top: 90rpx;
- padding-bottom: 40rpx;
- .item {
- display: flex;
- flex-direction: column;
- align-items: center;
- flex-shrink: 0;
- width: 140rpx;
- margin-right: 48rpx;
- .time {
- font-size: 32rpx;
- color: #FFFFFF;
- }
- .tag {
- width: 140rpx;
- height: 44rpx;
- border-radius: 44rpx;
- border: 1px solid #FFFFFF;
- font-size: 24rpx;
- color: #FFFFFF;
- box-sizing: border-box;
- margin-top: 12rpx;
- display: flex;
- align-items: center;
- justify-content: center;
- }
- &.current {
- .tag {
- background: #FFFFFF;
- color: #FF3F42;
- }
- }
- }
- }
- .product-list {
- .item {
- background: #FFFFFF;
- border-radius: 10rpx;
- display: flex;
- padding: 20rpx;
- margin-bottom: 20rpx;
- image {
- display: block;
- width: 180rpx;
- height: 180rpx;
- flex-shrink: 0;
- }
- .right {
- width: 490rpx;
- box-sizing: border-box;
- padding-left: 20rpx;
- .title {
- font-size: 30rpx;
- color: #333333;
- line-height: 36rpx;
- font-weight: 600;
- }
- .des {
- font-size: 24rpx;
- line-height: 30rpx;
- color: #999999;
- margin-top: 6rpx;
- }
- .stock-sales {
- display: flex;
- justify-content: space-between;
- align-items: center;
- margin-top: 10rpx;
- font-size: 24rpx;
- color: #666666;
- .stock {
- display: flex;
- align-items: center;
- text {
- font-size: 24rpx;
- color: #666666;
- }
- .progress-box {
- width: 140rpx;
- border-radius: 6px;
- overflow: hidden;
- margin-left: 10rpx;
- }
- }
- }
- .bottom {
- display: flex;
- justify-content: space-between;
- align-items: center;
- margin-top: 10rpx;
- .price {
- display: flex;
- flex-direction: column;
- }
- .price-1 {
- font-size: 32rpx;
- color: #FF3F42;
- line-height: 36rpx;
- }
- .price-2 {
- font-size: 26rpx;
- color: #666666;
- line-height: 30rpx;
- text-decoration: line-through;
- }
- .btn {
- width: 110rpx;
- height: 44rpx;
- background: #FF3F42;
- border-radius: 5rpx;
- font-size: 28rpx;
- color: #FFFFFF;
- text-align: center;
- line-height: 44rpx;
- }
- .btn2 {
- width: 110rpx;
- height: 44rpx;
- background: #AAAAAA;
- border-radius: 5rpx;
- font-size: 28rpx;
- color: #FFFFFF;
- text-align: center;
- line-height: 44rpx;
- }
- }
- }
- }
- }
- .loadmore {
- background: #FFFFFF;
- border-radius: 10rpx;
- display: flex;
- justify-content: center;
- align-items: center;
- height: 88rpx;
- }
- }
- .recom-container {
- margin-top: 30rpx;
- .top {
- background: #FFFFFF;
- padding: 30rpx 0 0;
- .title {
- display: flex;
- align-items: center;
- justify-content: center;
- margin-bottom: 10rpx;
- image {
- width: 300rpx;
- height: 40rpx;
- display: block;
- }
- }
- .tab {
- display: flex;
- margin-left: -10rpx;
- .item {
- display: flex;
- flex-direction: column;
- align-items: center;
- flex-shrink: 0;
- font-size: 28rpx;
- color: #666666;
- height: 80rpx;
- line-height: 80rpx;
- position: relative;
- padding: 0 30rpx;
- &.current {
- color: #FF3F42;
- font-weight: 600;
- &::after {
- content: '';
- display: block;
- width: 50rpx;
- height: 6rpx;
- background: #FF3F42;
- position: absolute;
- bottom: 0;
- left: 50%;
- margin-left: -25rpx;
- }
- }
- }
- }
- }
- .list {
- display: flex;
- flex-wrap: wrap;
- padding: 20rpx;
- .item {
- width: 348rpx;
- background: #FFFFFF;
- margin-right: 14rpx;
- margin-bottom: 20rpx;
- border-radius: 20rpx;
- overflow: hidden;
- &:nth-child(2n) {
- margin-right: 0;
- }
- .image {
- width: 348rpx;
- height: 348rpx;
- flex-shrink: 0;
- position: relative;
- .img {
- width: 348rpx;
- height: 348rpx;
- display: block;
- }
- .water {
- width: 348rpx;
- height: 348rpx;
- display: block;
- position: absolute;
- left: 0;
- top: 0;
- z-index: 1;
- }
- }
- .content {
- padding: 15rpx 20rpx;
- .title {
- font-size: 30rpx;
- color: #333333;
- line-height: 36rpx;
- font-weight: 600;
- height: 72rpx;
- }
- .bottom {
- display: flex;
- justify-content: space-between;
- align-items: center;
- margin-top: 10rpx;
- .price {
- display: flex;
- flex-direction: column;
- }
- .price-1 {
- font-size: 32rpx;
- color: #FF3F42;
- line-height: 36rpx;
- }
- .price-2 {
- font-size: 26rpx;
- color: #666666;
- line-height: 30rpx;
- text-decoration: line-through;
- }
- .btn {
- width: 60rpx;
- height: 60rpx;
- background: #FE781F;
- border-radius: 50%;
- display: flex;
- align-items: center;
- justify-content: center;
- image {
- width: 41rpx;
- height: 36rpx;
- display: block;
- }
- }
- }
- }
- }
- }
- }
- </style>
- <style>
- ::-webkit-scrollbar {
- display: none;
- width: 0 !important;
- height: 0 !important;
- -webkit-appearance: none;
- background: transparent;
- color: transparent;
- }
- </style>
|