803 lines
32 KiB
Vue
803 lines
32 KiB
Vue
<template>
|
||
<view>
|
||
<!-- 状态栏 -->
|
||
<status-nav v-if="invite_code==''" :titleVal="'分类'" :statusTitle="true"></status-nav>
|
||
<view v-if="invite_code!=''" class="status-box statusHNH" style="background-color: #FFFFFF;">
|
||
<view :style="{height:statusBarHeight+'px'}"></view>
|
||
<view class="status-nav">
|
||
<!-- 标题 -->
|
||
<view class="tab-title tcenter" style="color: #000000;">分类</view>
|
||
</view>
|
||
</view>
|
||
<!-- 列表 -->
|
||
<view :style="{top: statusHNH+'px'}" class="posiszy" style="height: 50px;">
|
||
<view class="bacf pad-zy32 pad-sx20">
|
||
<cate-pu @choosecateEv="choosecateEv" :activeb="invite_code!=''?'#3875F6':publicColor" :newCurrent="cateCurrent*1" :newbmo="'#F2F2F2'" :isCenter="false" :newcateList="cateList"></cate-pu>
|
||
</view>
|
||
</view>
|
||
<view class="pad-x180" :style="{paddingTop: (statusHNH+50)+'px'}">
|
||
<view v-if="isLoading" class="pad-s30">
|
||
<view v-show="cateCurrent==isNum">
|
||
<view class="pad-zy32">
|
||
<!-- 自定义轮播 -->
|
||
<swiper-pu :browseP="true" :isplay="isAutoPlay" :bannerList="bannerList" :newHeight="'450'" :newRadius="'10'" :newBottom="'5'"></swiper-pu>
|
||
<!-- 标题 -->
|
||
<view class="fon36 col3 bold mar-sx20 clips2" style="line-height: 50rpx;">{{detailObj.title}}</view>
|
||
<view class="disjbac">
|
||
<view class="disac">
|
||
<!-- 发布者头像 -->
|
||
<image class="flexs" src="/static/public/logo.png" style="width: 60rpx;height: 60rpx;border-radius: 100%;" mode="aspectFill"></image>
|
||
<view class="mar-z10">
|
||
<!-- 发布者昵称 -->
|
||
<view class="fon28 col3 clips1">恒美植发</view>
|
||
<!-- 发布时间 -->
|
||
<view class="fon20 col9" style="margin-top: 6rpx;">{{detailObj.published_at}}发布</view>
|
||
</view>
|
||
</view>
|
||
<view class="disac flexs">
|
||
<view class="disac fc" @tap="tapLike" style="width: 60rpx;">
|
||
<image v-if="isDetailLike" src="/static/public/detail-like.png" style="width: 42rpx;height: 42rpx;" mode=""></image>
|
||
<image v-else src="/static/public/detail-nlike.png" style="width: 42rpx;height: 42rpx;" mode=""></image>
|
||
<view class="fon24 col9 tc">{{likeCon}}</view>
|
||
</view>
|
||
<view @tap="shareEv" class="disac fc mar-zy36 posir">
|
||
<image src="/static/public/weix.png" style="width: 42rpx;height: 42rpx;" mode=""></image>
|
||
<view class="fon24 col9">分享</view>
|
||
<button class="posia-op" open-type="share">分享</button>
|
||
<!-- <button v-if="haveImg" class="posia" open-type="share" style="top: 0;right: 0;left: 0;bottom: 0;opacity: 0;">分享</button> -->
|
||
</view>
|
||
<view class="disac fc" @tap="tapConllection">
|
||
<image v-if="isDetailConllection" src="/static/public/yconllection.png" style="width: 44rpx;height: 44rpx;" mode=""></image>
|
||
<image v-else src="/static/public/conllection.png" style="width: 44rpx;height: 44rpx;" mode=""></image>
|
||
<view class="fon24 col9">收藏</view>
|
||
</view>
|
||
</view>
|
||
</view>
|
||
<!-- 内容详情 -->
|
||
<view class="fon28 mar-s20" style="color: #1A1A1A; line-height: 40rpx;">
|
||
<rich-text :nodes="detailInfo"></rich-text>
|
||
</view>
|
||
</view>
|
||
<view class="pad-zy20" v-show="cateCurrent==1">
|
||
<view class="fon30 bold tc mar-sx40" :style="{color:publicColor}">相关推荐</view>
|
||
<!-- 相关推荐列表 -->
|
||
<list-pu @chooseLike="chooseLikex" @comfirmev="comfirmevx" :list="xgList"></list-pu>
|
||
</view>
|
||
<view class="pad-zy20">
|
||
<view class="fon30 bold tc mar-sx40" :style="{color:publicColor}">推荐医生</view>
|
||
<!-- 推荐医生列表 -->
|
||
<list-doctor v-if="dataList.length!=0" :list="dataList"></list-doctor>
|
||
<view v-if="dataList.length==0" class="disjcac fc" style="margin-top: 10%;">
|
||
<image class="zanw-img" src="/static/public/nothing.png" mode="aspectFill"></image>
|
||
<view class="fon24 col3">暂无推荐医生</view>
|
||
</view>
|
||
</view>
|
||
</view>
|
||
<!-- 案例日记 -->
|
||
<view v-show="cateCurrent==0 && isNum!=0" class="pad-zy20">
|
||
<view v-if="listArrone.length!=0">
|
||
<list-pu @chooseLike="chooseLike" @comfirmev="comfirmev" :list="listArrone"></list-pu>
|
||
</view>
|
||
<view v-else class="disjcac fc" style="margin-top: 40%;">
|
||
<image class="zanw-img" src="/static/public/nothing.png" mode="aspectFill"></image>
|
||
<view class="fon24 col3">暂无内容</view>
|
||
</view>
|
||
</view>
|
||
<!-- 案例日记 -->
|
||
<view v-show="cateCurrent==1 && isNum!=1" class="pad-zy20">
|
||
<view v-if="listArrtwo.length!=0">
|
||
<list-pu @chooseLike="chooseLike" @comfirmev="comfirmev" :list="listArrtwo"></list-pu>
|
||
</view>
|
||
<view v-else class="disjcac fc" style="margin-top: 40%;">
|
||
<image class="zanw-img" src="/static/public/nothing.png" mode="aspectFill"></image>
|
||
<view class="fon24 col3">暂无内容</view>
|
||
</view>
|
||
</view>
|
||
<!-- 效果模拟 -->
|
||
<view v-show="cateCurrent==2 && isNum!=2" class="pad-zy20">
|
||
<view v-if="listArrthree.length!=0">
|
||
<list-pu @chooseLike="chooseLike" @comfirmev="comfirmev" :list="listArrthree"></list-pu>
|
||
</view>
|
||
<view v-else class="disjcac fc" style="margin-top: 40%;">
|
||
<image class="zanw-img" src="/static/public/nothing.png" mode="aspectFill"></image>
|
||
<view class="fon24 col3">暂无内容</view>
|
||
</view>
|
||
</view>
|
||
<!-- 科普视频 -->
|
||
<view v-show="cateCurrent==3 && isNum!=3" class="pad-zy20">
|
||
<view v-if="listArrfour.length!=0">
|
||
<list-pu @chooseLike="chooseLike" @comfirmev="comfirmev" :list="listArrfour"></list-pu>
|
||
</view>
|
||
<view v-else class="disjcac fc" style="margin-top: 40%;">
|
||
<image class="zanw-img" src="/static/public/nothing.png" mode="aspectFill"></image>
|
||
<view class="fon24 col3">暂无内容</view>
|
||
</view>
|
||
</view>
|
||
<block v-if="isHot">
|
||
<view v-if="dataShopList.length!=0" style="margin-top: -20rpx;">
|
||
<view class="pad20">
|
||
<view style="width: 48.6%;float: left;">
|
||
<view v-if="index1%2==0" v-for="(item1,index1) in dataShopList" :key="index1" class="bacf radius15 mar-x20 animated fadeIn posir" @tap="goPage(item1.id,index1)">
|
||
<image :src="item1.imgSrc" mode="aspectFill" style="width: 100%;border-top-left-radius: 15rpx;border-top-right-radius: 15rpx;height: 325rpx;"></image>
|
||
<view class="pad-zy20 pad-s10 pad-x30">
|
||
<view class="fon28 bold col3 clips2">{{item1.title}}</view>
|
||
<view class="disac fon20 mar-sx20" v-if="!item1.isIntegral">
|
||
<view class="radius10 colf mar-y10" style="padding: 6rpx 10rpx;" :style="{background:publicColor}">{{item1.disease_name}}</view>
|
||
<view class="radius10 colf" v-if="item1.isTuan" style="padding: 6rpx 10rpx;background: #F85050;">团购</view>
|
||
<view class="radius10 colf" v-if="item1.isPing" style="padding: 6rpx 10rpx;background: #F85050;">拼团活动</view>
|
||
<view class="radius10 colf" v-if="item1.isXian" style="padding: 6rpx 10rpx;background: #F85050;">限时促销</view>
|
||
</view>
|
||
<view class="disac">
|
||
<view class="fon28 bold" style="color: #F85050;margin-right: 8rpx;">
|
||
<view v-if="item1.isIntegral" class="mar-s20">
|
||
<view>积分:{{item1.integral}}</view>
|
||
<view class="disac mar-s20" v-if="item1.grade!=0">
|
||
<image src="/static/public/huiy.png" style="width: 40rpx;height: 33rpx;" mode=""></image>
|
||
<view class="fon24 col3 mar-z10">{{item1.level_text}}</view>
|
||
</view>
|
||
</view>
|
||
<view v-else>
|
||
<span v-if="item1.isPing">拼团价</span>
|
||
<span v-if="item1.isXian">促销价</span>
|
||
¥{{item1.zhePrice}}
|
||
</view>
|
||
</view>
|
||
<view v-if="item1.isXian || item1.isPing || item1.isTuan" class="fon24" style="text-decoration: line-through;color: #C7C7C7;">¥{{item1.yuanPrice}}</view>
|
||
</view>
|
||
<view v-if="item1.isPing" class="disjbac mar-s20">
|
||
<view class="fon24 col80">已拼团{{item1.activity_group_num}}组</view>
|
||
<view class="disac">
|
||
<image v-for="(itemm,indexm) in item1.activity_group_cover" :key="indexm" :src="itemm" mode="" style="width: 40rpx;height: 40rpx;border-radius: 100%;margin-left: -20rpx;"></image>
|
||
</view>
|
||
</view>
|
||
<view v-if="item1.isXian || item1.isPing || item1.isTuan" class="fon24 col80 mar-s20">结束时间:{{item1.activity_end_at}}</view>
|
||
</view>
|
||
</view>
|
||
</view>
|
||
<view style="width: 48.6%;float: right;">
|
||
<view v-if="index1%2!=0" v-for="(item1,index1) in dataShopList" :key="index1" class="bacf radius15 mar-x20 animated fadeIn posir" @tap="goPage(item1.id,index1)">
|
||
<image :src="item1.imgSrc" mode="aspectFill" style="width: 100%;border-top-left-radius: 15rpx;border-top-right-radius: 15rpx;height: 325rpx;"></image>
|
||
<view class="pad-zy20 pad-s10 pad-x30">
|
||
<view class="fon28 bold col3 clips2">{{item1.title}}</view>
|
||
<view class="disac fon20 mar-sx20" v-if="!item1.isIntegral">
|
||
<view class="radius10 colf mar-y10" style="padding: 6rpx 10rpx;" :style="{background:publicColor}">{{item1.disease_name}}</view>
|
||
<view class="radius10 colf" v-if="item1.isTuan" style="padding: 6rpx 10rpx;background: #F85050;">团购</view>
|
||
<view class="radius10 colf" v-if="item1.isPing" style="padding: 6rpx 10rpx;background: #F85050;">拼团活动</view>
|
||
<view class="radius10 colf" v-if="item1.isXian" style="padding: 6rpx 10rpx;background: #F85050;">限时促销</view>
|
||
</view>
|
||
<view class="disac">
|
||
<view class="fon28 bold" style="color: #F85050;margin-right: 8rpx;">
|
||
<view v-if="item1.isIntegral" class="mar-s20">
|
||
<view>积分:{{item1.integral}}</view>
|
||
<view class="disac mar-s20" v-if="item1.grade!=0">
|
||
<image src="/static/public/huiy.png" style="width: 40rpx;height: 33rpx;" mode=""></image>
|
||
<view class="fon24 col3 mar-z10">{{item1.level_text}}</view>
|
||
</view>
|
||
</view>
|
||
<view v-else>
|
||
<span v-if="item1.isPing">拼团价</span>
|
||
<span v-if="item1.isXian">促销价</span>
|
||
¥{{item1.zhePrice}}
|
||
</view>
|
||
</view>
|
||
<view v-if="item1.isTuan || item1.isPing || item1.isXian" class="fon24" style="text-decoration: line-through;color: #C7C7C7;">¥{{item1.yuanPrice}}</view>
|
||
</view>
|
||
<view v-if="item1.isPing" class="disjbac mar-s20">
|
||
<view class="fon24 col80">已拼团{{item1.activity_group_num}}组</view>
|
||
<view class="disac">
|
||
<image v-for="(itemm,indexm) in item1.activity_group_cover" :key="indexm" :src="itemm" mode="" style="width: 40rpx;height: 40rpx;border-radius: 100%;margin-left: -20rpx;"></image>
|
||
</view>
|
||
</view>
|
||
<view v-if="item1.isXian || item1.isPing || item1.isTuan" class="fon24 col80 mar-s20">结束时间:{{item1.activity_end_at}}</view>
|
||
</view>
|
||
</view>
|
||
</view>
|
||
</view>
|
||
</view>
|
||
<!-- <nothing-page v-if="dataShopList.length==0" :content="`暂无更多商品列表`"></nothing-page> -->
|
||
</block>
|
||
</view>
|
||
<view class="posixzy disjbac bacf pad-zy32 btnBKS">
|
||
<view class="posir">
|
||
<image @tap="backHome" class="posia backH" src="/static/public/back-home.png" mode="aspectFill"></image>
|
||
</view>
|
||
<view class="disac fon26 colf">
|
||
<view @tap="lianK" class="disac posir lianShare" style="background-color: #3875F6; border-top-left-radius: 51rpx;border-bottom-left-radius: 51rpx;">
|
||
<image src="/static/public/bottom-customer.png" class="mar-zy20" style="width: 47rpx;height: 47rpx;" mode="aspectFill"></image>
|
||
<view>联系客服</view>
|
||
<button v-if="haveImg" class="fon24 posia" style="opacity: 0;top: 0;left: 0;right: 0;bottom: 0;" open-type="contact">客服</button>
|
||
</view>
|
||
<view @tap="shareEv" class="disac posir lianShare" style="background-color: #38CE51;border-top-right-radius: 51rpx;border-bottom-right-radius: 51rpx;">
|
||
<image src="/static/public/bottom-shear.png" style="width: 47rpx;height: 47rpx;margin-left: 15rpx;margin-right: 8rpx;" mode="aspectFill"></image>
|
||
<view>分享给好友</view>
|
||
<button v-if="haveImg" class="posia-op" open-type="share">分享</button>
|
||
</view>
|
||
</view>
|
||
</view>
|
||
<!-- 返回顶部 -->
|
||
<!-- <back-top :showTop="showTop" @backTop="backTop"></back-top> -->
|
||
<!-- 弹框授权 -->
|
||
<empower @buttonH="buttonH" :vision="vision" :isWhere="2" @cancleEv="cancleEv"></empower>
|
||
<!-- 弹框 -->
|
||
<view v-if="isShowP" @touchmove.stop.prevent="moveHandle" class="disjcac posAll">
|
||
<view class="bacf radius20 width100 tank-box">
|
||
<view class="tc tank-box-itemone">请授权绑定手机号</view>
|
||
<view class="fon28 colf pad-x30 pad-zy30 tc disjb">
|
||
<view @tap="isShowP=false" class="pad-sx10 radius10 tank-btn" style="background-color: rgba(230, 230, 230,1);color: #000000;">暂不绑定</view>
|
||
<view class="pad-sx10 radius10 tank-btn posir pbackc">
|
||
立即绑定
|
||
<button open-type="getPhoneNumber" @getphonenumber="getphonenumber" class="posia syxzo">立即绑定</button>
|
||
</view>
|
||
</view>
|
||
</view>
|
||
</view>
|
||
</view>
|
||
</view>
|
||
</template>
|
||
|
||
<script>
|
||
import listDoctor from '@/components/list-doctor.vue';
|
||
import swiperPu from '@/components/swiper-pu.vue';
|
||
import {collectionEV,cancleCollectionEV} from '@/jsFile/publicAPI.js';
|
||
import empower from '@/components/empower.vue';
|
||
export default {
|
||
components:{
|
||
listDoctor,
|
||
swiperPu,
|
||
empower
|
||
},
|
||
data() {
|
||
return {
|
||
statusBarHeight:uni.getSystemInfoSync().statusBarHeight,
|
||
isLoading:false,
|
||
vision:false,
|
||
statusHNH:uni.getStorageSync('statusHNH'),
|
||
publicColor:uni.getStorageSync('publicColor') || '#3875F6',//主题颜色
|
||
cateCurrent:0,
|
||
haveImg:true,
|
||
cateList:[],
|
||
bannerList:[],//轮播
|
||
xgList:[//相关推荐
|
||
],
|
||
dataList:[//推荐医生
|
||
],
|
||
showTop:false,
|
||
isDetailLike:false,//是否喜欢
|
||
likeCon:'点赞',
|
||
isDetailConllection:false,//是否已收藏
|
||
isNum:0,
|
||
listArrone:[],//问题
|
||
listArrtwo:[//案例日记
|
||
],
|
||
listArrthree:[//效果模拟
|
||
],
|
||
listArrfour:[//科普视频
|
||
],
|
||
detailObj:{},//详情
|
||
detailInfo:'',//富文本
|
||
category_id:'',//栏目ID
|
||
active:'',//是否是详情页
|
||
// jieDuan:false,
|
||
share_id:0,
|
||
invite_code:'',
|
||
isShowP:false,
|
||
zanArr:[],
|
||
dataShopList:[],
|
||
timeList:[],
|
||
isHot:false,
|
||
isAutoPlay:false
|
||
}
|
||
},
|
||
onPageScroll(e) {
|
||
e.scrollTop > 360 ? this.showTop = true : this.showTop = false
|
||
},
|
||
onReachBottom() {//触底事件
|
||
// for (let i = 0; i < 4; i++) {
|
||
// if(this.cateCurrent==0) {
|
||
// let obj = {status:false,main_img:'',title:'恒美小课堂',content:'饺子会吃肉?',head_img:'/static/public/like.png',name:'吃肉的饺子',isCate:0}
|
||
// this.listArrone.push(obj)
|
||
// }
|
||
// if(this.cateCurrent==1) {
|
||
// let obj = {status:false,main_img:'',title:'恒美小课堂',content:'饺子会吃肉?',head_img:'/static/public/like.png',name:'吃肉的饺子',isCate:1}
|
||
// this.listArrtwo.push(obj)
|
||
// }
|
||
// if(this.cateCurrent==2) {
|
||
// let obj = {status:false,main_img:'',title:'恒美小课堂',content:'饺子会吃肉?',head_img:'/static/public/like.png',name:'吃肉的饺子',isCate:2}
|
||
// this.listArrthree.push(obj)
|
||
// }
|
||
// if(this.cateCurrent==3) {
|
||
// let obj = {status:false,main_img:'',title:'恒美小课堂',content:'饺子会吃肉?',head_img:'/static/public/like.png',name:'吃肉的饺子',isCate:3}
|
||
// this.listArrfour.push(obj)
|
||
// }
|
||
// }
|
||
},
|
||
onShareTimeline() {},
|
||
onShareAppMessage(res) {
|
||
var ya = this;
|
||
this.$requst.post('user/record',{type:'content',action:'share',id:this.detailObj.id}).then(res=>{console.log('分享成功:',res);},error=>{})
|
||
let maiOjb = {
|
||
e:4,//内容分享
|
||
c:this.detailObj.id*1,
|
||
t:new Date().getTime()//当前时间戳
|
||
}
|
||
this.$toolAll.tools.maiDian(maiOjb)
|
||
var shareObj = {
|
||
title: `${ya.detailObj.title}`, // 默认是小程序的名称(可以写slogan等)
|
||
path: `/pagesB/problemDetail/problemDetail?id=${this.detailObj.id}&category_id=${this.category_id}&share_id=${uni.getStorageSync('userId')}&invite_code=${uni.getStorageSync('invite_code')}`, // 默认是当前页面,必须是以‘/’开头的完整路径
|
||
imageUrl: ya.$http + ya.detailObj.share_img//自定义图片路径,可以是本地文件路径、代码包文件路径或者网络图片路径,支持PNG及JPG,不传入 imageUrl 则使用默认截图。显示图片长宽比是 5:4
|
||
};
|
||
return shareObj;
|
||
},
|
||
onShow() {
|
||
this.isAutoPlay = true;
|
||
},
|
||
onUnload() {
|
||
this.isAutoPlay = false;
|
||
},
|
||
onHide() {
|
||
this.isAutoPlay = false;
|
||
},
|
||
onLoad(options) {
|
||
if(options.category_id!=undefined) {
|
||
this.category_id = options.category_id
|
||
this.conid = options.id
|
||
this.invite_code = options.invite_code
|
||
uni.setStorageSync('ninvite_code',this.invite_code)
|
||
if(this.invite_code!='' && this.invite_code!=undefined){
|
||
uni.login({
|
||
provider: 'weixin',
|
||
success: (res)=> {
|
||
if (res.code) {
|
||
var params = {
|
||
code:res.code,
|
||
invite_code:this.invite_code,//用户邀请码
|
||
}
|
||
this.$requst.post('user/login',params).then(res => {
|
||
if(res.data.token!=''){
|
||
if(res.data.is_active==0) {
|
||
this.haveImg = false
|
||
this.vision = true
|
||
}
|
||
}
|
||
},error => {})
|
||
}
|
||
},
|
||
});
|
||
} else {
|
||
this.$toolAll.tools.overdue()
|
||
this.$toolAll.tools.isLogin()
|
||
}
|
||
}
|
||
this.checkDetail(this.conid)
|
||
if(options.share_id!=undefined) this.share_id = options.share_id
|
||
let maiOjb = {
|
||
e:4,//内容分享
|
||
c:this.conid*1,
|
||
t:new Date().getTime()//当前时间戳
|
||
}
|
||
this.$toolAll.tools.maiDian(maiOjb)
|
||
},
|
||
methods: {
|
||
moveHandle(){//禁止底层滑动
|
||
return false
|
||
},
|
||
getphonenumber(e){//授权绑定手机号
|
||
if(e.detail.errMsg=="getPhoneNumber:ok"){
|
||
this.$requst.post('user/bind-phone',{iv:e.detail.iv,encryptedData:e.detail.encryptedData}).then(res=>{
|
||
// console.log('手机号信息:',res);
|
||
if(res.code==0){
|
||
this.isShowP = false
|
||
this.$toolAll.tools.showToast('手机号绑定成功','success')
|
||
}
|
||
},error=>{})
|
||
} else {
|
||
this.isShowP = false
|
||
}
|
||
},
|
||
chooseLike(e){//收藏事件
|
||
// console.log(this.dataList[e].is_collected);
|
||
let cateId = ''
|
||
let newArr = []
|
||
if(this.cateCurrent==0) {
|
||
newArr = this.listArrone
|
||
cateId = newArr[e].id
|
||
}
|
||
if(this.cateCurrent==1) {
|
||
newArr = this.listArrtwo
|
||
cateId = newArr[e].id
|
||
}
|
||
if(this.cateCurrent==2) {
|
||
newArr = this.listArrthree
|
||
cateId = newArr[e].id
|
||
}
|
||
if(this.cateCurrent==3) {
|
||
newArr = this.listArrfour
|
||
cateId = newArr[e].id
|
||
}
|
||
if(newArr[e].is_collected==0){
|
||
newArr[e].is_collected = 1
|
||
// 调用收藏事件
|
||
collectionEV({action:'collect',archive_id:cateId})
|
||
}
|
||
},
|
||
comfirmev(e){//确认取消收藏事件
|
||
let cateId = ''
|
||
if(this.cateCurrent==0) {
|
||
this.listArrone[e].is_collected = 0
|
||
cateId = this.listArrone[e].id
|
||
}
|
||
if(this.cateCurrent==1) {
|
||
this.listArrtwo[e].is_collected = 0
|
||
cateId = this.listArrtwo[e].id
|
||
}
|
||
if(this.cateCurrent==2) {
|
||
this.listArrthree[e].is_collected = 0
|
||
cateId = this.listArrthree[e].id
|
||
}
|
||
if(this.cateCurrent==3) {
|
||
this.listArrfour[e].is_collected = 0
|
||
cateId = this.listArrfour[e].id
|
||
}
|
||
this.$toolAll.tools.showToast('正在取消...','loading')
|
||
// 调用取消收藏事件
|
||
cancleCollectionEV({action:'collect',archive_id:cateId})
|
||
},
|
||
chooseLikex(e){//收藏事件
|
||
if(this.xgList[e].is_collected==0){
|
||
this.xgList[e].is_collected = 1
|
||
// 调用收藏事件
|
||
collectionEV({action:'collect',archive_id:this.xgList[e].id})
|
||
}
|
||
},
|
||
comfirmevx(e){//确认取消收藏事件
|
||
this.xgList[e].is_collected = 0
|
||
this.$toolAll.tools.showToast('正在取消...','loading')
|
||
// 调用取消收藏事件
|
||
cancleCollectionEV({action:'collect',archive_id:this.xgList[e].id})
|
||
},
|
||
buttonH(e){//授权成功
|
||
this.haveImg = e
|
||
if(e) {
|
||
this.vision = false
|
||
this.isShowP = true
|
||
}
|
||
},
|
||
cancleEv(e){//取消授权
|
||
if(e==0) this.vision = false
|
||
},
|
||
backHome(){
|
||
uni.navigateTo({
|
||
url:'/pages/tabbar/pagehome/pagehome'
|
||
})
|
||
},
|
||
lianK(){//客服
|
||
// if(!this.jieDuan){
|
||
// let isAuth = this.$toolAll.tools.returnAuth()
|
||
// if(!isAuth){
|
||
if(this.haveImg == false) {
|
||
this.vision = true
|
||
} else {
|
||
this.$requst.post('user/rand-bind-service').then(res=>{})
|
||
this.$toolAll.tools.closeTimer()//清空埋点倒计时
|
||
this.$requst.post('user/record',{type:'other',action:'ask',id:0}).then(res=>{},error=>{})
|
||
let maiOjb = {
|
||
e:5,//内容咨询
|
||
t:new Date().getTime()//当前时间戳
|
||
}
|
||
this.$toolAll.tools.maiDian(maiOjb)
|
||
}
|
||
// } else this.jieDuan = true
|
||
// }
|
||
},
|
||
shareEv(){
|
||
if(this.haveImg == false) {
|
||
this.vision = true
|
||
}
|
||
},
|
||
checkDetail(newId){
|
||
this.$requst.post('archives/detail',{id:newId,share_id:this.share_id}).then(res=>{
|
||
// console.log('详情数据:',res);
|
||
if(res.code==0){
|
||
this.isLoading=true
|
||
// 栏目类别
|
||
if(res.data.category.length!=0){
|
||
res.data.category.forEach((item,index)=>{
|
||
let cateObj = {
|
||
id:item.id,//栏目ID
|
||
title:item.title,//栏目名称
|
||
active:item.active,//是否选中
|
||
model_id:item.model_id,//模型ID
|
||
model_name:item.model_name,//模型标识
|
||
sort:item.sort
|
||
}
|
||
this.cateList.push(cateObj)
|
||
// 默认选中的栏目
|
||
if(item.active==1) this.active = this.cateCurrent = index
|
||
// 默认展示栏目详情
|
||
if(this.category_id==item.id) this.isNum = index
|
||
})
|
||
this.cateList.push({title:'热门商品'})
|
||
}
|
||
if(this.invite_code!='' && this.invite_code!=undefined){
|
||
const query = wx.createSelectorQuery()
|
||
query.select('.statusHNH').boundingClientRect((rect) => {
|
||
// console.log('状态栏+标题栏:',rect);
|
||
this.statusHNH = rect.height
|
||
// console.log(this.statusHNH );
|
||
}).exec()
|
||
}
|
||
// 详情
|
||
this.detailObj = res.data.detail
|
||
let maiOjb = {
|
||
e:1,//内容访问
|
||
c:this.detailObj.id*1,
|
||
t:new Date().getTime()//当前时间戳
|
||
}
|
||
this.$toolAll.tools.maiDian(maiOjb)
|
||
if(this.detailObj.is_liked==1) {
|
||
if(this.detailObj.likes >= 1000) this.likeCon = '999+'
|
||
else this.likeCon = this.detailObj.likes
|
||
}
|
||
// 轮播
|
||
// 图片字符串转数组
|
||
let arrImg = this.detailObj.images.split(',')
|
||
arrImg.forEach(item=>{
|
||
let newImgObj = {
|
||
imgSrc:this.$http + item,
|
||
url:'',
|
||
isVideo:false,
|
||
poster:'',
|
||
}
|
||
// 存图片
|
||
this.bannerList.push(newImgObj)
|
||
})
|
||
// 存视频
|
||
if(this.detailObj.video!=''){
|
||
this.bannerList[0] = {
|
||
imgSrc:this.$http + arrImg[0],
|
||
url:this.$http + this.detailObj.video,
|
||
isVideo:true,
|
||
poster:'',
|
||
}
|
||
}
|
||
// 默认显示是否收藏
|
||
if(this.detailObj.is_collected==0) this.isDetailConllection = false
|
||
if(this.detailObj.is_collected==1) this.isDetailConllection = true
|
||
if(this.detailObj.is_liked==0) this.isDetailLike = false
|
||
if(this.detailObj.is_liked==1) this.isDetailLike = true
|
||
// 富文本
|
||
this.detailInfo = this.$toolAll.tools.escape2Html(this.detailObj.content)
|
||
// 相关推荐xgList
|
||
if(res.data.diary.length!=0){
|
||
res.data.diary.forEach(item=>{
|
||
let tObj = {
|
||
category_id:item.category_id,//栏目ID
|
||
id:item.id,
|
||
is_collected:item.is_collected,//是否已收藏
|
||
collects:item.collects,//收藏量
|
||
views:item.views,//查看量
|
||
main_img:this.$http + item.cover,//封面图
|
||
video:this.$http + item.video,//视频地址
|
||
title:item.title,//标题
|
||
content:item.subtitle,//副标题
|
||
head_img:'/static/public/logo.png',//发布者头像
|
||
name:'恒美植发',//发布者昵称
|
||
isVideo:item.video.includes(".mp4")//是否是视频
|
||
}
|
||
if(item.cover!='' && item.video==''){
|
||
this.xgList.push(tObj)
|
||
}
|
||
})
|
||
}
|
||
// 推荐医生
|
||
if(res.data.doctor.length!=0){
|
||
res.data.doctor.forEach(item=>{
|
||
let doObj = {
|
||
id:item.id,
|
||
imgSrc: item.headimg!=null ? item.headimg : '',
|
||
name:item.name,
|
||
cyear:parseFloat(item.work_time),
|
||
bmen:item.dept_name,
|
||
zcheng:'主任医师',
|
||
goodAt:item.diseases,
|
||
show_detail:item.show_detail
|
||
}
|
||
this.dataList.push(doObj)
|
||
})
|
||
}
|
||
this.choosecateEv(this.cateCurrent)
|
||
}
|
||
},error=>{})
|
||
},
|
||
choosecateEv(e){
|
||
this.cateCurrent = e
|
||
this.isHot = false;
|
||
if(this.cateList[e].title=='热门商品'){
|
||
this.checkSotList();
|
||
} else {
|
||
this.$requst.post('archives/category',{category_id:this.cateList[e].id,keyword:''}).then(res=>{
|
||
// console.log('该分类下的列表:',res);
|
||
if(res.code==0){
|
||
if(e==0 && this.active!=e) this.listArrone = []
|
||
if(e==1 && this.active!=e) this.listArrtwo = []
|
||
if(e==2 && this.active!=e) this.listArrthree = []
|
||
if(e==3 && this.active!=e) this.listArrfour = []
|
||
if(res.data.list.list.length!=0){
|
||
res.data.list.list.forEach(item=>{
|
||
let num = item.video.search(".mp4")
|
||
let isVideo = false
|
||
if(num!='-1') isVideo = true
|
||
let arrObj = {
|
||
category_id:item.category_id,//栏目ID
|
||
id:item.id,
|
||
is_collected:item.is_collected,//是否已收藏
|
||
collects:item.collects,//收藏量
|
||
views:item.views,//查看量
|
||
main_img:this.$http + item.cover,//封面图
|
||
video:this.$http + item.video,//视频地址
|
||
title:item.title,//标题
|
||
content:item.subtitle,//副标题
|
||
head_img:'/static/public/logo.png',//发布者头像
|
||
name:'恒美植发',//发布者昵称
|
||
isVideo:isVideo//是否是视频
|
||
}
|
||
if(item.cover!=''){
|
||
if(e==0 && this.active!=e) this.listArrone.push(arrObj)
|
||
if(e==1 && this.active!=e) this.listArrtwo.push(arrObj)
|
||
if(e==2 && this.active!=e) this.listArrthree.push(arrObj)
|
||
if(e==3 && this.active!=e) this.listArrfour.push(arrObj)
|
||
}
|
||
})
|
||
}
|
||
}
|
||
},error=>{})
|
||
}
|
||
},
|
||
tapLike(){//喜欢、不喜欢事件
|
||
// if(!this.jieDuan){
|
||
// let isAuth = this.$toolAll.tools.returnAuth()
|
||
// if(!isAuth){
|
||
this.isDetailLike = !this.isDetailLike
|
||
if(this.isDetailLike){
|
||
this.detailObj.likes++
|
||
this.likeCon = this.detailObj.likes
|
||
if(this.likeCon >= 1000) this.likeCon = '999+'
|
||
}else{
|
||
this.detailObj.likes--
|
||
this.likeCon = '喜欢'
|
||
}
|
||
let isLikeCon = 'like'
|
||
//调用点赞事件
|
||
if(this.isDetailLike) collectionEV({action:isLikeCon,archive_id:this.detailObj.id})
|
||
//调用取消点赞事件
|
||
else cancleCollectionEV({action:isLikeCon,archive_id:this.detailObj.id})
|
||
// } else this.jieDuan = true
|
||
// }
|
||
},
|
||
tapConllection(){//收藏、取消收藏事件
|
||
let isLikeCon = 'collect'
|
||
// if(!this.jieDuan){
|
||
// let isAuth = this.$toolAll.tools.returnAuth()
|
||
// if(!isAuth){
|
||
// 调用收藏事件
|
||
if(!this.isDetailConllection) collectionEV({action:isLikeCon,archive_id:this.detailObj.id})
|
||
// 调用取消收藏事件
|
||
else cancleCollectionEV({action:isLikeCon,archive_id:this.detailObj.id})
|
||
this.isDetailConllection = !this.isDetailConllection
|
||
// } else this.jieDuan = true
|
||
// }
|
||
},
|
||
checkSotList(){//查询热门商品
|
||
this.isHot = true;
|
||
let params = {
|
||
page:1,
|
||
size:2000,
|
||
is_hot:1
|
||
}
|
||
uni.request({
|
||
url:'https://hengmei.scdxtc.cn/api/spu/list',
|
||
data:params,
|
||
method:'post',
|
||
header:{
|
||
'Content-Type': 'application/json; charset=UTF-8',
|
||
'Authorization': 'Bearer '+uni.getStorageSync('token') || ''
|
||
},
|
||
success: (res) => {
|
||
if(res.data.code==0){
|
||
clearInterval(this.timer);
|
||
// if(this.page==1) {
|
||
this.zanArr = [];
|
||
this.dataShopList = [];
|
||
this.timeList = [];
|
||
// }
|
||
this.total = res.data.total;
|
||
if(res.data.data.list.length!=0){
|
||
res.data.data.list.forEach(item=>{
|
||
let tuan = false,ping = false,xian = false,integral = false;
|
||
if(item.activity_type=='group_make') ping = true;
|
||
if(item.activity_type=='group_buy') tuan = true;
|
||
if(item.activity_type=='limit_time') xian = true;
|
||
let group_cover = [];
|
||
if(item.activity_group_cover.length!=0) {
|
||
item.activity_group_cover.forEach(item=>{
|
||
group_cover.push(this.$http + item)
|
||
})
|
||
}
|
||
let obj = {
|
||
id:item.id,
|
||
imgSrc: this.$http + item.cover,
|
||
title: item.name,
|
||
zhePrice:item.price/100,
|
||
yuanPrice:item.original_price/100,
|
||
integral:'',
|
||
isTuan:tuan,//是否是团购
|
||
isPing:ping,//是否是拼团活动
|
||
isXian:xian,//是否是限时活动
|
||
isIntegral:integral,//是否是积分
|
||
grade:'',
|
||
disease_name:item.disease_name,//病种名称
|
||
reponseTime:res.header.Date,//接口响应时间
|
||
activity_end_at:item.activity_end_at,//限时结束时间
|
||
activity_group_cover:group_cover,//参团人的头像
|
||
activity_group_num:item.activity_group_num,//已经参团人数
|
||
}
|
||
this.zanArr.push(obj)
|
||
})
|
||
this.zanArr.forEach((item,index)=>{
|
||
if(item.activity_end_at!='') {
|
||
let obj = {
|
||
id:item.id,
|
||
reponseTime:item.reponseTime,
|
||
time:item.activity_end_at,
|
||
nIndex:index
|
||
}
|
||
this.timeList.push(obj);
|
||
}
|
||
})
|
||
if(this.timeList!=0){
|
||
this.$toolAll.tools.showToast('加载中...')
|
||
this.timer = setInterval(()=>{//定时器
|
||
if(this.timeList.length!=0){
|
||
this.timeList.forEach((item,index)=>{
|
||
if(item.id==this.zanArr[item.nIndex].id){
|
||
let endTime = new Date(this.timeList[index].time).getTime();//把结束时间转时间戳
|
||
this.timeList[index].reponseTime = new Date(this.timeList[index].reponseTime).getTime() + 1000;//请求接口的时间递增,即:开始时间
|
||
if(this.timeList[index].reponseTime - endTime >=0) {//如果开始时间的时间戳 - 结束时间的时间戳 >= 0 活动结束
|
||
this.zanArr[item.nIndex].activity_end_at = "活动已结束";
|
||
} else {
|
||
// 继续进行倒计时
|
||
this.zanArr[item.nIndex].activity_end_at = this.$toolAll.tools.dayTime(this.timeList[index].time,this.timeList[index].reponseTime);
|
||
}
|
||
}
|
||
})
|
||
}
|
||
},1000)
|
||
setTimeout(()=>{
|
||
this.dataShopList = this.zanArr;
|
||
},1000)
|
||
} else {
|
||
this.dataShopList = this.zanArr;
|
||
}
|
||
}
|
||
}
|
||
}
|
||
})
|
||
},
|
||
goPage(id,index){//进入商品详情事件
|
||
uni.navigateTo({
|
||
url:`/pagesB/shopDetail/shopDetail?id=${id}&isIntegral=${this.dataShopList[index].isIntegral}`
|
||
})
|
||
},
|
||
backTop(){//回到顶部事件
|
||
uni.pageScrollTo({
|
||
scrollTop: 0,
|
||
duration: 300
|
||
});
|
||
},
|
||
}
|
||
}
|
||
</script>
|
||
|
||
<style>
|
||
</style>
|