1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405140614071408140914101411141214131414141514161417141814191420142114221423142414251426142714281429143014311432143314341435143614371438143914401441144214431444144514461447144814491450145114521453145414551456145714581459146014611462146314641465146614671468146914701471147214731474147514761477147814791480148114821483148414851486148714881489149014911492149314941495149614971498149915001501150215031504150515061507150815091510151115121513151415151516151715181519152015211522152315241525152615271528152915301531153215331534153515361537153815391540154115421543154415451546154715481549155015511552155315541555155615571558155915601561156215631564156515661567156815691570157115721573157415751576157715781579158015811582158315841585158615871588158915901591159215931594159515961597159815991600160116021603160416051606160716081609161016111612161316141615161616171618161916201621162216231624162516261627162816291630163116321633163416351636163716381639164016411642164316441645164616471648164916501651165216531654165516561657165816591660166116621663166416651666 |
- <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_2.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="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="bigActivity-container" v-if="isShow_activity1 && bigActivityImgUrl">
- <image :src="bigActivityImgUrl" mode="widthFix" @tap="toActivityList(3)"></image>
- </view>
-
- <view class="classify-container" v-if="isShow_classify"
- :class="(!isShow_banner || (isShow_banner && bannerList.length < 1))
- && (!isShow_activity1 || (isShow_activity1 && !bigActivityImgUrl)) ? 'whiteBg':''">
- <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_more2.png" mode="aspectFill"></image>
- <text>更多分类</text>
- </view>
- </view>
- </view>
-
- <view class="other-container" v-if="isShow_activity2 && leftActivityImgUrl && rightActivityImgUrl">
- <image :src="leftActivityImgUrl" mode="aspectFill" @tap="toActivityList(4)"></image>
- <image :src="rightActivityImgUrl" mode="aspectFill" @tap="toActivityList(5)"></image>
- </view>
-
- <view class="smallActivity-container" v-if="isShow_special">
- <view class="content">
- <view class="title">专场专区</view>
- <view class="list">
- <view class="item">
- <image :src="smallActivity1ImgUrl" mode="aspectFill" @tap="toActivityList(6)"></image>
- </view>
- <view class="item">
- <image :src="smallActivity2ImgUrl" mode="aspectFill" @tap="toActivityList(7)"></image>
- </view>
- <view class="item">
- <image :src="smallActivity3ImgUrl" mode="aspectFill" @tap="toActivityList(8)"></image>
- </view>
- <view class="item">
- <image :src="smallActivity4ImgUrl" mode="aspectFill" @tap="toActivityList(9)"></image>
- </view>
- </view>
- </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="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="seckill2-container" v-if="isShow_seckill && seckillTimeList.length > 0">
- <view class="content">
- <view class="top">
- <view class="left">
- <view class="title">秒杀专区</view>
- <view class="timeout">
- <view class="text">{{countdownText}}</view>
- <view class="time">{{countdownTime}}</view>
- </view>
- </view>
- <view class="right" @tap="toSeckillGoodsList()">更多<image src="@/static/icon/right.png"></image></view>
- </view>
- <view class="list">
- <block v-for="(item, index) in seckillGoodsList" :key='index'>
- <view class="item" @tap="toSeckillGoodsDetail(item.goodsId)">
- <image :src="item.imgUrl" mode="aspectFill"></image>
- <view class="title ellipsis-2">{{item.goodsName}}</view>
- <view class="price">¥{{item.price | numToFixed}}</view>
- </view>
- </block>
- </view>
- </view>
- </view>
-
- <view class="recom-container" v-if="isShow_newclassify">
- <view class="top">
- <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.goodsNewsCategoryId == tabCurrent ? 'current':'']" @tap="changeTab(item.goodsNewsCategoryId)">
- <view class="name">{{item.mainTitle}}</view>
- <view class="text">{{item.subTitle}}</view>
- </view>
- </block>
- </view>
- </scroll-view>
- </view>
- <view class="goods-row-list" v-if="recomList.length > 0">
- <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="heightFix" class="water" v-if="item.isShowWater"></image>
- </view>
-
- <view class="right">
- <view>
- <view class="title ellipsis-2">{{item.goodsName}}</view>
- <view class="tags" v-if="item.tags1 && item.tags1.length > 0">
- <view class="it" v-for="(it, idx) in item.tags1" :key="idx">{{it}}</view>
- </view>
- </view>
- <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="text">销量:{{item.soldNum}}</view>
- </view>
- </view>
- </view>
- </view>
- </block>
- </view>
- <no-data v-if="!recomList.length" :showText="'暂无商品'"></no-data>
- <loading-text v-if="recomList.length" :loading="loading" :noMore="noMore" ></loading-text>
- </view>
-
- <view class="dialog-container" v-if="isShow_dialog && dialogImgUrl && isShowDialog">
- <uni-transition ref="dialog" mode-class="zoom-in" :duration="500" :show="isShow_dialog && dialogImgUrl && isShowDialog">
- <image class="image" :src="dialogImgUrl" mode="widthFix" @tap="toActivityList(2)"></image>
- </uni-transition>
- <uni-transition ref="dialogBtn" mode-class="fade" :duration="500" :show="isShow_dialog && dialogImgUrl && isShowDialog">
- <image class="close" src="@/static/icon/close4.png" @tap="closeDialog()"></image>
- </uni-transition>
- </view>
-
- <view class="dialog-container" v-if="couponDialogImgUrl && isShowCouponDialog">
- <uni-transition ref="dialog2" mode-class="zoom-in" :duration="500" :show="couponDialogImgUrl && isShowCouponDialog">
- <image class="image" :src="couponDialogImgUrl" mode="widthFix"></image>
- </uni-transition>
- <uni-transition ref="dialogBtn2" mode-class="fade" :duration="500" :show="couponDialogImgUrl && isShowCouponDialog">
- <image class="close" src="@/static/icon/close4.png" @tap="closeDialog2()"></image>
- </uni-transition>
- </view>
-
- <modal-dialog showTitle="提示" showText="优惠券领取成功,请及时使用!" :isShowDialog="isShowCouponSuccessDialog" @cancel="isShowCouponSuccessDialog = false" :isShowConfirm="false"></modal-dialog>
- </block>
- </view>
- </template>
- <script>
- import {mapState} from 'vuex';
-
- export default {
- props:{
- homePage: {
- type: Number,
- default: 0
- },
- templateInfo: {
- type: Object,
- default: {}
- }
- },
- data() {
- return {
- thisHomePage: 2, // 当前首页页面模版
-
- imageUrl: this.$imageUrl,
- configInfo: uni.getStorageSync('configInfo'),
- isShow_dialog: false,
- isShow_banner: false,
- isShow_activity1: false,
- isShow_classify: false,
- isShow_activity2: false,
- isShow_special: false,
- isShow_seckill: false,
- isShow_coupon: false,
- isShow_manager: false,
- isShow_notice: false,
- isShow_newclassify: false,
-
- scrollTop: 0, // 滚动高度(用于控制自定义导航)
- keyword: '', // 搜索关键词
- classifyList: [], // 分类列表
- bannerList: [], // 轮播图列表
- bannerCurrent: 0, // 轮播图当前值
- dialogImgUrl: '',
- bigActivityImgUrl: '',
- leftActivityImgUrl: '',
- rightActivityImgUrl: '',
- smallActivity1ImgUrl: '',
- smallActivity2ImgUrl: '',
- smallActivity3ImgUrl: '',
- smallActivity4ImgUrl: '',
- noticeList: [],
- couponList: [], // 可领取优惠券列表
- myManagerDetail: null, // 我的客户经理信息
- seckillTimeList: [], // 秒杀时间段列表
- seckillGoodsList: [], // 秒杀商品列表
- seckillGoodsPage: 1, // 秒杀商品分页
- seckillGoodsNoMore: false, //
- countdownText: '', // 倒计时文字
- countdownTime: '', // 倒计时时间
- endDatetime: '', // 倒计时结束时间
- nowDate: null, // 当前时间
- dateInterval: null, // 时间定时器
- tabList: [], // 好物推荐分类列表
- tabCurrent: 1, // 好物推荐分类当前值
- pageNum: 1,
- pageSize: 8,
- recomList: [], // 好物推荐列表
- noMore: false,
- loading: false,
-
- isLoaded_banner: false,
- isLoaded_coupon: false,
- isLoaded_seckill: false,
- isLoaded_classify: false,
- isLoaded_manager: false,
- isLoaded_classfly: false,
- isLoaded_newclassify: false,
-
- scrollLeft: 50,
- scrollViewWidth: 0,
- tabsRect: {
- left: 0
- },
-
- isShowDialog: true,
-
- couponDialogImgUrl: '',
- isShowCouponDialog: true,
- isShowCouponSuccessDialog: false,
- }
- },
- 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_classify))
- && (!this.isShow_manager || (this.isShow_manager && this.isLoaded_manager))
- && (!this.isShow_newclassify || (this.isShow_newclassify && this.isLoaded_newclassify))
- }
- },
- 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_dialog = templateInfo.popupStatus;
- this.isShow_banner = templateInfo.carouseStatus;
- this.isShow_activity1 = templateInfo.active1Status;
- this.isShow_classify = templateInfo.categoryStatus;
- this.isShow_activity2 = templateInfo.active2Status;
- this.isShow_special = templateInfo.onlyStatus;
- this.isShow_seckill = templateInfo.killStatus;
- this.isShow_coupon = templateInfo.couponStatus;
- this.isShow_manager = templateInfo.customerStatus;
- this.isShow_notice = templateInfo.notiveStatus;
- this.isShow_newclassify = templateInfo.newsStatus;
-
- this.dialogImgUrl = templateInfo.popupImage;
- this.bigActivityImgUrl = templateInfo.active1Image;
- this.leftActivityImgUrl = templateInfo.active2LeftImage;
- this.rightActivityImgUrl = templateInfo.active2RightImage;
- this.smallActivity1ImgUrl = templateInfo.only1Image;
- this.smallActivity2ImgUrl = templateInfo.only2Image;
- this.smallActivity3ImgUrl = templateInfo.only3Image;
- this.smallActivity4ImgUrl = templateInfo.only4Image;
- },
- immediate: true,
- deep: true
- }
- },
- mounted() {
- uni.$on('onPageScroll', (data) => {
- this.scrollTop = data;
- });
-
- uni.$on('onPullDownRefresh', (data) => {
- this.keyword = '';
- this.getTabList();
- this.getBannerList();
- this.getCouponList();
- this.getMyManager();
- this.getNoticeList();
- this.getSeckillTimeList();
- this.getClassflyList();
- });
-
- uni.$on('onReachBottom', (data) => {
- this.getRecomList(1);
- });
-
- uni.$on('onShow', (data) => {
- console.log('onShow page ' + this.thisHomePage);
- this.keyword = '';
- this.getTabList();
- this.getBannerList();
- this.getCouponList();
- this.getMyManager();
- this.getNoticeList();
- this.getSeckillTimeList();
- if(this.tabList.length < 1) {
- this.getClassflyList();
- }
-
- 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.classifyList = res.data.slice(0, 9);
-
- uni.stopPullDownRefresh();
- }).finally(res => {
- this.isLoaded_classify = 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;
- },
-
- stopTouchMove() {
- return true;
- },
-
- // 获取可领优惠券列表
- getCouponList() {
- this.$axios({
- url: '/coupon/list/all',
- method: 'get',
- params: {
- userId: this.userId
- }
- }).then(res => {
- this.couponList = res.data;
- let couponList = res.data.filter(item => {
- return item.obtainType === 1;
- });
- if(couponList && couponList.length > 0) {
- this.couponDialogImgUrl = couponList[0].imgSrc;
- this.isShow_coupon = true;
- }
- }).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_manager = true;
- })
- },
-
- // 获取公告列表
- 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;
- }
- })
- },
-
- // 拨打电话
- 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(), //距离结束时间的毫秒数
- dd = Math.floor(lefttime/(1000*60*60)/24), //计算天数
- 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 = (dd > 0 ? dd + '天 ' : '') + 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.endDatetime = this.seckillTimeList[0].endDatetime;
- this.countdownText = this.seckillTimeList[0].type == 'jxz' ? '距离结束':'即将开始';
- this.countTime();
- this.getSeckillGoodsList();
- }).finally(res => {
- this.isLoaded_seckill = true;
- })
- },
-
- // 获取秒杀商品列表
- getSeckillGoodsList(loadMore) {
- if(this.seckillGoodsNoMore && loadMore)return;
- if(!loadMore) {
- this.seckillGoodsNoMore = false;
- this.seckillGoodsPage = 1;
- }
- let secKillId = this.seckillTimeList[0].secKillId;
- this.$axios({
- url: '/goods/sec/goods/list',
- method: 'get',
- params: {
- pageNum: this.seckillGoodsPage,
- pageSize: 3,
- 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[0].type == 'wks') {
- return this.$toast('活动未开始');
- }
- uni.navigateTo({
- url: '/packageGoods/pages/detail?id=' + id
- })
- },
-
- // 进入秒杀商品列表
- toSeckillGoodsList() {
- uni.navigateTo({
- url: '/packageGoods/pages/seckill'
- })
- },
-
- // 获取推荐分类
- getClassflyList() {
- this.$axios({
- url: '/renovation/category/list',
- method: 'get',
- params: {
- pageNo: 1,
- pageSize: 10
- }
- }).then(res => {
- this.tabList = res.data.records;
- this.tabCurrent = res.data.records.length > 0 ? res.data.records[0].goodsNewsCategoryId : 0;
- this.getRecomList();
-
- uni.stopPullDownRefresh();
- }).finally(res => {
- this.isLoaded_newclassify = true;
- })
- },
-
- // 切换一级菜单
- changeTab(current) {
- this.tabCurrent = current;
- this.getRecomList();
- this.resize();
- },
-
- // 获取好物推荐商品列表
- getRecomList(loadMore) {
- if(this.noMore && loadMore)return;
- this.noMore = false
- if(!loadMore){
- this.pageNum = 1;
- }else{
- this.loading = true;
- }
- this.$axios({
- url: '/renovation/goods/list',
- method: 'get',
- params: {
- pageNo: this.pageNum,
- pageSize: this.pageSize,
- type: 1,
- objId: this.tabCurrent,
- sort: 1
- },
- }).then(res => {
- res.data.records.forEach(item => {
- if(item.logo && item.logoStartTime) {
- item.isShowWater = this.$compareTime(item.logoStartTime, item.logoEndTime);
- }else {
- item.isShowWater = false;
- }
- })
-
- let _list = res.data.records;
- let pageTotal = res.data.pages;
- if(this.pageNum >= pageTotal){
- this.noMore = true;
- }
- if (_list.length) {
- this.pageNum += 1
- }
- if (loadMore) {
- this.recomList = this.recomList.concat(_list);
- this.loading = false;
- } else {
- this.recomList = _list;
- }
-
- uni.stopPullDownRefresh();
- })
- },
-
- // 进入商品详情
- 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) {}
- });
- },
-
- setScrollLeft() {
- // 当前活动tab的布局信息,有tab菜单的width和left(为元素左边界到父元素左边界的距离)等信息
- const index = this.findElem(this.tabList, 'goodsNewsCategoryId', 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();
- })
- },
-
- // 关闭弹窗
- closeDialog() {
- this.$refs.dialog.step({
- scale: 0
- }, {
- duration: 400
- })
- this.$refs.dialog.run(()=>{
- this.isShowDialog = false;
- })
- this.$refs.dialogBtn.step({
- scale: 0
- }, {
- duration: 400
- })
- this.$refs.dialogBtn.run(()=>{
- this.isShowDialog = false;
- })
- },
-
- // 进入活动列表
- toActivityList(type) {
- if(type == 2) {
- this.closeDialog();
- }
- uni.navigateTo({
- url: '/packageGoods/pages/activity?type=' + type
- })
- },
-
- // 关闭弹窗
- closeDialog2() {
- this.$refs.dialog2.step({
- scale: 0
- }, {
- duration: 400
- })
- this.$refs.dialog2.run(()=>{
- this.isShowCouponDialog = false;
- })
- this.$refs.dialogBtn2.step({
- scale: 0
- }, {
- duration: 400
- })
- this.$refs.dialogBtn2.run(()=>{
- this.isShowCouponDialog = false;
- })
- },
- }
- }
- </script>
- <style lang="scss" scoped>
- .top-container {
- position: relative;
- margin-bottom: 40rpx;
- .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: 20rpx;
- position: relative;
- z-index: 1;
- padding: 0 20rpx;
- &.whiteBg {
- .content {
- background: #ffffff;
- text {
- color: #666666;
- }
- }
- }
- .content {
- border-radius: 20rpx;
- padding-top: 30rpx;
- display: flex;
- flex-wrap: wrap;
- .item {
- display: flex;
- flex-direction: column;
- align-items: center;
- width: 142rpx;
- margin-bottom: 30rpx;
- image {
- width: 78rpx;
- height: 78rpx;
- display: block;
- border-radius: 30rpx;
- overflow: hidden;
- }
- text {
- font-size: 24rpx;
- color: #333333;
- 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;
- }
- }
- }
- .bigActivity-container {
- position: relative;
- z-index: 9;
- margin-top: 40rpx;
- padding: 0 20rpx;
- image {
- width: 710rpx;
- display: block;
- }
- }
- .other-container {
- display: flex;
- padding: 0 20rpx;
- margin-top: 20rpx;
- justify-content: space-between;
- image {
- display: block;
- width: 350rpx;
- height: 240rpx;
- border-radius: 20rpx;
- }
- }
- .smallActivity-container {
- margin-top: 20rpx;
- padding: 0 20rpx;
- .content {
- background: #FFFFFF;
- border-radius: 20rpx;
- .title {
- font-size: 32rpx;
- color: #333333;
- line-height: 74rpx;
- padding-left: 20rpx;
- font-weight: 600;
- }
- .list {
- display: flex;
- flex-wrap: wrap;
- padding: 0 20rpx;
- .item {
- width: 320rpx;
- margin-right: 30rpx;
- margin-bottom: 20rpx;
- &:nth-child(2n) {
- margin-right: 0;
- }
- image {
- width: 320rpx;
- height: 200rpx;
- display: block;
- border-radius: 20rpx;
- }
- }
- }
- }
- }
- .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;
- }
- }
- }
- .seckill2-container {
- padding: 0 20rpx;
- margin-top: 20rpx;
- .content {
- background: #FFFFFF;
- border-radius: 20rpx;
- padding: 0 20rpx;
- .top {
- display: flex;
- justify-content: space-between;
- align-items: center;
- height: 86rpx;
- .left {
- display: flex;
- align-items: center;
- .title {
- font-size: 32rpx;
- color: #333333;
- line-height: 74rpx;
- font-weight: 600;
- }
- .timeout {
- display: flex;
- align-items: center;
- margin-left: 20rpx;
- border-radius: 40rpx;
- height: 40rpx;
- overflow: hidden;
- .text {
- font-size: 24rpx;
- color: #FFFFFF;
- width: 120rpx;
- text-align: center;
- background: #FF3F42;
- border-radius: 40rpx;
- position: relative;
- z-index: 1;
- }
- .time {
- padding: 0 20rpx 0 32rpx;
- background: #FFD3B5;
- font-size: 24rpx;
- color: #FF3F42;
- margin-left: -20rpx;
- position: relative;
- z-index: 0;
- }
- }
- }
- .right {
- display: flex;
- align-items: center;
- font-size: 28rpx;
- color: #999999;
- image {
- width: 12rpx;
- height: 26rpx;
- display: block;
- margin-left: 8rpx;
- }
- }
- }
- .list {
- display: flex;
- .item {
- width: 210rpx;
- margin-right: 20rpx;
- padding-bottom: 20rpx;
- &:last-child {
- margin-right: 0;
- }
- image {
- width: 210rpx;
- height: 210rpx;
- display: block;
- }
- .title {
- font-size: 28rpx;
- color: #333333;
- line-height: 36rpx;
- font-weight: 600;
- margin-top: 6rpx;
- }
- .price {
- font-size: 32rpx;
- color: #FF3F42;
- line-height: 36rpx;
- margin-top: 6rpx;
- }
- }
- }
- }
- }
- .recom-container {
- margin-top: 20rpx;
- .top {
- .tab {
- display: flex;
- .item {
- display: flex;
- flex-direction: column;
- align-items: center;
- justify-content: center;
- flex-shrink: 0;
- width: 187.5rpx;
- font-size: 28rpx;
- color: #666666;
- position: relative;
- height: 130rpx;
- .name {
- font-size: 36rpx;
- color: #333333;
- }
- .text {
- font-size: 24rpx;
- color: #666666;
- margin-top: 8rpx;
- }
- &.current {
- .name {
- color: #FF3F42;
- font-weight: 600;
- }
- .text {
- color: #FF3F42;
- }
- &::after {
- content: '';
- display: block;
- width: 48rpx;
- height: 6rpx;
- background: #FF3F42;
- position: absolute;
- bottom: 0;
- left: 50%;
- margin-left: -24rpx;
- }
- }
- }
- }
- }
- }
- .dialog-container {
- position: fixed;
- z-index: 1000000;
- top: 0;
- left: 0;
- width: 100%;
- height: 100vh;
- display: flex;
- align-items: center;
- justify-content: center;
- flex-direction: column;
- background: rgba($color: #000000, $alpha: .6);
- .image {
- width: 600rpx;
- display: block;
- border-radius: 20rpx;
- margin-top: 40rpx;
- }
- .close {
- width: 68rpx;
- height: 68rpx;
- display: block;
- margin-top: 40rpx;
- }
- }
-
- </style>
- <style>
- ::-webkit-scrollbar {
- display: none;
- width: 0 !important;
- height: 0 !important;
- -webkit-appearance: none;
- background: transparent;
- color: transparent;
- }
- </style>
|