You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
zhishifufei_uniapp/pages/special/details.vue

3529 lines
106 KiB

<template>
<BaseContainer class="thematic-details">
<NavBar :title="navTitle" />
<template v-if="infoLoading">
<view class="base-wrap">
<view class="swiper-details">
<view class="special-coverimg">
<image :src="swiperlist[0]" mode="aspectFill"></image>
</view>
<!-- <swiper class="banner slider-banner">
<swiper-item>
<view class="swiper-slide" v-for="(src, key) in swiperlist" :key="key">
<image :src="src" mode="aspectFill" />
</view>
</swiper-item>
</swiper> -->
<view class="successTip" v-if="barrageStatus">
<template v-for="(item, index) of Barragelist">
<view class="picTxt acea-row row-middle" v-if="num == index" :key="index">
<view class="pictrue">
<image mode="aspectFill" :src="item.avatar" />
</view>
<view class="acea-row row-middle" style="flex: 1; overflow: hidden; white-space: nowrap;">
<view class="name line1">{{ item.nickname }}</view>
<view style="flex: 1; overflow: hidden; text-overflow: ellipsis">{{ item.status_name }}</view>
</view>
</view>
</template>
</view>
<view class="swiper" style="padding-bottom: 40rpx;">
<!-- <view v-if="special_validity == -1" class="validity">
<template v-if="special.validity">课程有效期为{{
special.validity
}}天,过期后需重新购买哦!</template>
<template v-else>课程永久有效哦!</template>
</view>
<view v-else-if="special_validity == 0" class="validity">课程永久有效哦!</view>
<view v-else-if="special_validity > 0" class="validity">
课程有效期剩余{{
special_validity | validityFormat
}},过期后需重新购买哦!
</view> -->
<view class="name txp1">
{{ special.title || "加载中" }}
</view>
<view class="swiper-int">
<view class="swiper-int-top">
<!-- <view class="swiper-int-top-left">
<view v-if="special.label.length" class="attr">
<view v-for="(item, idx) of special.label" :key="idx">{{
item
}}</view>
</view>
</view> -->
<view class="acea-row" style="flex-direction: column;line-height: 22rpx;">
<view class="pin-money" v-if="is_pay">
<text class="price">
<text>
{{ special.is_pink ? special.pink_money : special.money }}
</text>
</text>
<text class="vip-price" style="margin-left: 13rpx;">¥{{ special.member_money }}</text>
<img class="vip-price-icon" :src="getImgPath('/wap/first/zsff/images/vip.png')" />
</view>
<view class="pin-money" v-if="special.is_pink">
拼课价<text class="money">¥{{ special.pink_money }}</text>
</view>
<view class="study-count" style="color: #999999;font-size: 20rpx;margin-top: 16rpx;">{{ record.recordCoujnt }}人已学习</view>
</view>
</view>
<view class="collect" @click="handleCreateSharePoster">
<view class="iconfont">
<image :src="getImgPath('/wap/first/zsff/images/fenxiang.png')"></image>
</view>
<view>分享</view>
</view>
<view class="collect" @click="collect">
<view :class="[
'iconfont',
special.collect ? 'iconshoucang2' : 'iconshoucang11',
]"></view>
<view>{{ special.collect ? "已收藏" : "收藏" }}</view>
</view>
</view>
<join-vip></join-vip>
</view>
<!-- <view class="share">
<view v-if="special.service_code" class="share_wechat">
<view class="pinTip2 acea-row row-between-wrapper"
v-if="is_pay || (isMember && special.member_pay_type == 0)">
<view class="reminder line1">和小伙伴一起学习,有老师答疑哦~</view>
<view class="chatBnt acea-row row-center-wrapper" @click="open = false">
加入群聊
</view>
</view>
</view>
<view class="teacher-section">
<view class="teacher-table">
<view class="item">
<view class="num">{{ count }}</view>
<view>总节数</view>
</view>
<view class="item">
<view>
<template v-for="(item, index) in record.record">
<image mode="aspectFill" v-if="index < 5" :key="index" :src="item.avatar" />
</template>
</view>
<view class="learn">
<text class="child">已有</text>
<text class="child">{{ record.recordCoujnt }}</text>
<text class="child">人学习</text>
</view>
</view>
</view>
<view v-if="lecturer" class="teacher-detail-wrap">
<navigator class="a" :url="`/pages/merchant/teacher_detail?id=${special.lecturer_id}`">
<view class="detail-hd">
<view class="head">
<image class="image" mode="aspectFill" :src="lecturer.lecturer_head" />
</view>
<view class="text">
<view>{{ lecturer.lecturer_name }}</view>
<view v-if="lecturer.label.length">
<template v-for="(item, index) in lecturer.label">
<text class="text" v-if="index < 3" :key="index">{{ item }}</text>
</template>
</view>
</view>
<view class="iconfont iconxiangyou"></view>
</view>
</navigator>
</view>
</view>
</view> -->
<navigator v-if="lecturer" class="lecturer-info flex" :url="`/pages/merchant/teacher_detail?id=${special.lecturer_id}`">
<view class="info-avatar">
<image :src="lecturer && lecturer.lecturer_head" mode="aspectFill"></image>
</view>
<view class="info-box">
<view class="info-name">
{{ lecturer.lecturer_name }} <text>{{ lecturer.explain }}</text>
</view>
<view class="info-desc">{{ lecturer.explain }}</view>
</view>
<text class="more"></text>
</navigator>
<view v-if="materialList.length" class="material">
<navigator v-for="item in materialList" :key="item.id" :url="`/pages/special/data_details?id=${item.id}`">
<view>
<image mode="aspectFill" :src="item.image" alt="" />
</view>
<view>
<view>{{ item.title }}</view>
<view v-if="item.pay_type" class="money">
¥<text>{{ item.money }}</text>
</view>
<view v-else>免费</view>
<view>
<view>{{ item.ficti + item.sales }}人已下载</view>
<button type="button">去下载</button>
</view>
</view>
</navigator>
</view>
<view v-if="pinkIngList.length && is_pay == false" class="scroll-section">
<view class="label">已拼{{ scrollData.length }}件</view>
<swiper class="swiper-container" :autoplay="true" interval="2000" circular vertical>
<swiper-item class="swiper-wrapper">
<view v-for="(item, index) in scrollData" :key="index" class="swiper-slide">
{{ item.nickname }}拼团成功
</view>
</swiper-item>
</swiper>
</view>
<view class="list" v-if="pinkIngList.length && is_pay == false">
<view class="item acea-row row-middle" v-for="(item, k) of pinkIngList" :key="k">
<view class="pictrue">
<image mode="aspectFill" :src="item.avatar" />
</view>
<view class="name line1">{{ item.nickname }}</view>
<view class="left">
<view>
还差<text>{{ item.num }}人</text>成团
</view>
<view class="time">
剩余{{ item.difftime.hour }}:{{ item.difftime.minute }}:{{
item.difftime.second
}}
</view>
</view>
<view class="acea-row row-center-wrapper link" @click="goPink(item.id, item.uid, item.order_id)">
去拼单
<text class="iconfont iconxiangyou"></text>
</view>
</view>
</view>
<view v-if="special.is_pink" class="process-section">
<view class="title">拼团玩法</view>
<view class="list">
<view class="item">
<text>1</text>
<text>开团/参团</text>
</view>
<view class="item">
<text>2</text>
<text>邀请好友</text>
</view>
<view class="item">
<text>3</text>
<text>满员成团</text>
</view>
</view>
</view>
<!-- 导航栏 -->
<view ref="list" class="swiper-nav">
<view class="navCon acea-row row-middle">
<template v-if="special.type === 4">
<view v-for="nav in liveNavlist" :key="nav.value" :class="{ on: active === nav.value }" class="item"
@click="active = nav.value">
{{ nav.title }}
</view>
</template>
<!-- <template v-else-if="special.type === 5">
<view v-for="nav in cloumnNavlist" :key="nav.value" :class="{ on: active === nav.value }" class="item"
@click="active = nav.value">
{{ nav.title
}}<text v-if="nav.value === 5">({{ evaluateWhole }})</text>
</view>
</template> -->
<template v-else>
<view v-for="nav in otherNavlist" :key="nav.value" :class="{ on: active === nav.value }" class="item"
@click="active = nav.value">
{{ nav.title
}}<text v-if="nav.value === 5">({{ evaluateWhole }})</text>
</view>
</template>
</view>
</view>
<!-- 详情 -->
<mp-html v-if="active === 2" class="swiper-conter" container-style="padding: 0 30rpx;background: #ffffff;width: 690rpx; margin: 0 auto;"
:content="special.content"></mp-html>
<template v-if="special.type === 4">
<!-- 回放目录 -->
<view v-if="active === 1" class="replay-directory">
<view v-if="liveTaskList.length">
<view v-for="(item, index) in liveTaskList" :key="index" :class="{ active: RecordId === item.RecordId }"
class="item" @click="playBackRecord(item.RecordId)">
<view class="label">回放</view>
<view class="name">
{{ index | serial }} |
{{ item.playback_name || special.title }}
</view>
<view></view>
</view>
</view>
<view class="foot">
<text v-if="liveLoading" class="fa fa-spinner loadingpic"></text>
</view>
</view>
</template>
<view v-else class="mulu">
<view v-if="active === 1">
<view ref="list">
<!-- 专栏目录 -->
<view v-if="special.type === 5" class="parent-catalogue">
<view v-for="specialItem of otherTaskList" :key="specialItem.id"
:class="{ active: specialItem.active }" @click="show(specialItem)">
<view class="parent-title">
<view class="name">{{ specialItem.title }}</view>
<view :class="[
specialItem.active ? 'iconxiangshang' : 'iconxiangxia',
'iconfont',
]"></view>
</view>
<view v-if="specialItem.special_task.length" class="catalogue">
<view v-for="(item, index) of specialItem.special_task" :key="item.id" @click.stop="play(item)">
<view>
<image src="@/static/images/special/video.png" />
</view>
<view class="text">
<view class="title">
{{ index >= 9 ? index + 1 : "0" + (index + 1) }}.
{{ item.title }}
</view>
<view class="try-progress">
<view v-if="
!is_pay &&
(special.member_pay_type || !isMember) &&
item.is_free &&
item.is_try
" class="try">
试看
</view>
<template v-if="
isLogin &&
(is_pay || (!special.member_pay_type && isMember))
">
<view v-if="item.watch && item.watch.percentage" class="progress">
已学习
</view>
<view v-else class="progress no">未学习</view>
</template>
</view>
</view>
<view class="status">
<i v-if="item.is_free" :class="[
item.pay_status ? 'iconsuozi' : 'iconziyuan2',
'iconfont',
]"></i>
<text v-else class="free">免费</text>
</view>
</view>
</view>
</view>
</view>
<!-- 专题目录 -->
<view v-else class="catalogue">
<view v-for="(item, index) in otherTaskList" :key="item.id" @click="play(item)">
<view>
<image src="@/static/images/special/video.png" />
</view>
<view class="text">
<view class="title">
{{ index >= 9 ? index + 1 : "0" + (index + 1) }}.
{{ item.title }}
</view>
<view class="try-progress">
<view v-if="
!is_pay &&
(special.member_pay_type || !isMember) &&
item.is_free &&
item.is_try
" class="try">
试看
</view>
<template v-if="
isLogin &&
(is_pay || (!special.member_pay_type && isMember))
">
<view v-if="item.watch && item.watch.percentage" class="progress">
已学习
</view>
<view v-else class="progress no">未学习</view>
</template>
</view>
</view>
<view class="status">
<i v-if="item.is_free" :class="[
item.pay_status ? 'iconsuozi' : 'iconziyuan2',
'iconfont',
]"></i>
<text v-else class="free">免费</text>
</view>
</view>
</view>
</view>
<view class="loading-line" style="background-color: #ffffff">
<text v-if="otherLoading == true" class="fa fa-spinner loadingpic" style="font-size: 40rpx"></text>
<text>{{ otherLoadTitle || "加载更多" }}</text>
</view>
</view>
</view>
<!-- 专栏套餐 -->
<template v-if="special.type === 5">
<view v-if="active === 6" class="video-list" style="-webkit-overflow-scrolling: touch">
<view v-if="columnTaskList.length" ref="list">
<view class="video-listn" style="padding: 30rpx 0">
<view class="item acea-row row-between-wrapper" :key="idx" v-for="(vo, idx) in columnTaskList"
@click="setMeal(vo)">
<view class="pictrue" @click="play(vo)" style="position: relative">
<image :src="vo.image" mode="aspectFill" />
<view class="label">{{ specialType[vo.type] }}</view>
</view>
<view class="underline">
<view class="text acea-row row-between row-column">
<view class="name line1" v-text="vo.title" @click="setMeal(vo)"></view>
<view v-if="vo.label.length" class="attr">
<view v-for="(item, idx) in vo.label" :key="idx">{{
item
}}</view>
</view>
<template v-if="special.pay_type">
<template v-if="vo.pay_status">
<template v-if="isMember">
<view v-if="vo.member_pay_type" class="price">
¥{{
vo.member_money === "0.00"
? vo.money
: vo.member_money
}}
</view>
<view v-else class="free">去学习</view>
</template>
<view v-else class="price">
¥<text>{{ vo.money }}</text>
</view>
</template>
<view v-else class="free">去学习</view>
</template>
<view v-else class="free">去学习</view>
</view>
</view>
</view>
</view>
</view>
<view class="loading-line" style="background-color: #ffffff">
<text v-if="columnLoading == true" class="fa fa-spinner loadingpic" style="font-size: 40rpx"></text>
<text>{{ columnLoadTitle || "加载更多" }}</text>
</view>
</view>
</template>
<template v-if="special.type !== 4">
<!-- 练习 -->
<view v-if="active === 3" class="problem-section">
<view v-if="problemList.length" class="problem-list">
<view v-for="item of problemList" :key="item.id" class="item">
<view :class="{ lock: !is_pay }" class="title">{{
item.title
}}</view>
<view class="group">
<view class="progress">
<view :style="{ width: item.rate + '%' }"></view>
</view>
<view class="people">
<text>{{ item.rate + "%" }}</text>{{ item.answer }}人已答题
</view>
<view class="exercise-btn" @click="goQuestion(item)">
<image mode="widthFix" :src="getImgPath('/wap/first/zsff/images/question07.png')" />练习
</view>
</view>
</view>
</view>
</view>
<!-- 考试 -->
<view v-if="active === 4" class="question-section">
<view v-if="questionList.length" class="list">
<view v-for="item in questionList" :key="item.id" @click="goQuestion(item)" class="item">
<view>
<image :src="item.image" mode="aspectFill" />
</view>
<view>
<view>{{ item.title }}</view>
<view>
<view>共{{ item.item_number }}题</view>
<view v-if="is_pay" class="btn">
<image :src="
getImgPath(`/wap/first/zsff/images/question07.png`)
" />答题
</view>
<view v-else>
<image class="lock" :src="
getImgPath(`/wap/first/zsff/images/question06.png`)
" />
</view>
</view>
</view>
</view>
</view>
</view>
<!-- 评价 -->
<view v-if="active === 5" class="evaluate-section">
<view class="head">
<view class="score">
<view>
<text>{{ evaluateScore }}</text>分
</view>
<view>课程评分</view>
</view>
<button type="button" class="flex-center flex" @click="userEvaluate">
我要评价
</button>
</view>
<EvaluateList :evaluate-list="evaluateList" />
<view v-if="evaluateLoading" class="loading">
<i class="fa fa-spinner fa-spin"></i>
</view>
<view v-if="evaluateFinished && evaluateList.length" class="finished">
已全部加载完
</view>
<view v-if="evaluateFinished && !evaluateList.length" class="empty">
<image :src="getImgPath('/wap/first/zsff/images/empty.png')" alt="暂无评价" />
<view>暂无评价</view>
</view>
</view>
</template>
</view>
</view>
<view class="acea-row row-middle footer" ref="storeMenu"
v-if="is_pay == false && is_gift == false && isPink == false">
<navigator class="link" url="/pages/index/index" open-type="switchTab">
<view class="cont">
<image :src="getImgPath('/wap/first/zsff/images/home.png')" />
<view>首页</view>
</view>
</navigator>
<!-- 抖音客服 -->
<view class="link" v-if="TOUTIAO_STATUS">
<view class="cont">
<view>
<button class="im" open-type="im" :data-im-id="imId" bindim="imCallback" binderror="onimError">
<image :src="getImgPath('/wap/first/zsff/images/chat.png')" />
客服</button>
</view>
</view>
</view>
<!-- 系统客服 -->
<view class="link" v-else @click="customerService">
<view class="cont">
<image :src="getImgPath('/wap/first/zsff/images/chat.png')" />
<view>客服</view>
</view>
</view>
<view v-if="(special.pay_type == 1 && special.type == 4) || special.money > 0" class="link" @click="OpenPay(1)">
<view class="cont">
<image :src="getImgPath('/wap/first/zsff/images/link.png')" />
<view>送朋友</view>
</view>
</view>
<view class="wrap">
<view class="video_footer_btn acea-row" :class="special.pay_type == 1 ? '' : 'item2'">
<view class="video_footer_btn_left acea-row row-column row-center-wrapper" v-if="
special.is_pink &&
((special.member_pay_type == 1 && isMember == 1) || isMember == 0)
" @click="OpenPay(3)">
<text class="video_footer_btn_left_pic">¥{{ special.pink_money }}</text>
<text class="video_footer_btn_left_num">{{ special.pink_number }}人团</text>
</view>
<view class="video_footer_btn_right acea-row" :class="
special.is_pink == 0 ||
(special.is_pink && isMember == 1 && special.member_pay_type == 0)
? 'on'
: ''
" v-if="special.type == 4">
<text :class="xtt_class" @click="OpenPay(6)" v-if="
special.pay_type == 0 ||
(special.member_pay_type == 0 && isMember) ||
is_pay
">进入直播间</text>
<text :class="xtt_class" @click="OpenPay(2)" v-if="isMember == 1 && special.member_pay_type == 1">¥{{
special.member_money }}</text>
<text :class="xtt_class" @click="OpenPay(2)" v-if="isMember == 0 && special.pay_type == 1">¥{{
special.money
}}</text>
</view>
<view class="video_footer_btn_right acea-row" :class="
special.is_pink == 0 ||
(special.is_pink && isMember == 1 && special.member_pay_type == 0)
? 'on'
: ''
" v-if="special.type != 4">
<text v-if="
special.pay_type == 0 ||
(special.member_pay_type == 0 && isMember) ||
is_pay
" @click="OpenPay(5)" :class="xtt_class">免费学习</text>
<text v-if="isMember == 1 && special.member_pay_type == 1" @click="OpenPay(2)" :class="xtt_class">¥{{
special.member_money }}</text>
<text v-if="isMember == 0 && special.pay_type == 1" @click="OpenPay(2)" :class="xtt_class">{{
special.money
}}</text>
</view>
</view>
</view>
</view>
<view class="acea-row row-wrap-all footer" ref="storeMenu"
v-if="is_pay == true && is_gift == false && paid && isPink == false">
<navigator class="link" open-type="switchTab" url="/pages/index/index">
<view class="cont">
<image :src="getImgPath('/wap/first/zsff/images/home.png')" />
<view>首页</view>
</view>
</navigator>
<!-- 抖音客服 -->
<view class="link" v-if="TOUTIAO_STATUS">
<view class="cont">
<view>
<button class="im" open-type="im" :data-im-id="imId" bindim="imCallback" binderror="onimError">
<image :src="getImgPath('/wap/first/zsff/images/chat.png')" />
客服</button>
</view>
</view>
</view>
<!-- 系统客服 -->
<view class="link" @click="customerService" v-else>
<view class="cont">
<image :src="getImgPath('/wap/first/zsff/images/chat.png')" />
<view>客服</view>
</view>
</view>
<view v-if="(special.pay_type == 1 && special.type == 4) || special.money > 0" class="link" @click="OpenPay(1)">
<view class="cont">
<image :src="getImgPath('/wap/first/zsff/images/link.png')" />
<view>送朋友</view>
</view>
</view>
<view class="wrap">
<view class="video_footer_btn acea-row">
<view :class="xtt_class2" v-if="special.type != 4" @click="OpenPay(5)">
<text class="video_footer_btn_left_pic">去学习</text>
</view>
<view :class="xtt_class2" v-if="special.type == 4" @click="OpenPay(6)">
<text class="video_footer_btn_left_pic">进入直播间</text>
</view>
</view>
</view>
</view>
<view class="acea-row row-wrap-all footer" v-if="isPink" ref="storeMenu">
<navigator class="link" open-type="switchTab" url="/pages/index/index">
<view class="cont">
<image :src="getImgPath('/wap/first/zsff/images/home.png')" />
<view>首页</view>
</view>
</navigator>
<!-- 抖音客服 -->
<view class="link" v-if="TOUTIAO_STATUS">
<view class="cont">
<view>
<button class="im" open-type="im" :data-im-id="imId" bindim="imCallback" binderror="onimError">
<image :src="getImgPath('/wap/first/zsff/images/chat.png')" />
客服</button>
</view>
</view>
</view>
<!-- 系统客服 -->
<view class="link" @click="customerService" v-else>
<view class="cont">
<image :src="getImgPath('/wap/first/zsff/images/chat.png')" />
<view>客服</view>
</view>
</view>
<view class="link" @click="OpenPay(1)">
<view class="cont">
<image :src="getImgPath('/wap/first/zsff/images/link.png')" />
<view>送朋友</view>
</view>
</view>
<view class="wrap">
<view class="video_footer_btn acea-row">
<view :class="xtt_class2" @click="goPink(0, uid, pinkOrderId, oid)">
<text class="video_footer_btn_left_pic">查看拼课详情</text>
</view>
</view>
</view>
</view>
<view class="acea-row row-middle footer" v-if="is_gift" ref="storeMenu">
<navigator class="link" open-type="switchTab" url="/pages/index/index">
<view class="cont">
<image :src="getImgPath('/wap/first/zsff/images/special01.png')" />
<view>首页</view>
</view>
</navigator>
<!-- 抖音客服 -->
<view class="link" v-if="TOUTIAO_STATUS">
<view class="cont">
<view>
<button class="im" open-type="im" :data-im-id="imId" bindim="imCallback" binderror="onimError">
<image :src="getImgPath('/wap/first/zsff/images/chat.png')" />
客服</button>
</view>
</view>
</view>
<!-- 系统客服 -->
<view class="link" @click="customerService" v-else>
<view class="cont">
<image :src="getImgPath('/wap/first/zsff/images/special02.png')" />
<view>客服</view>
</view>
</view>
<view class="wrap">
<view class="video_footer_btn acea-row">
<view :class="xtt_class2" @click="OpenPay(4)">
<text class="video_footer_btn_left_pic">领取课程</text>
</view>
</view>
</view>
</view>
</template>
<!-- 遮罩层 -->
<view :class="{ mask: dialogShow || password || is_poster || imgSrc || !open }" @touchmove.prevent
@click.self="maskClick"></view>
<!-- 加入群聊弹窗 -->
<view :class="{ show: !open }" class="dialog" v-if="!open">
<image :src="special.service_code" />
<view>长按扫一扫</view>
<view>加客服好友进群哦</view>
</view>
<!-- 关注公众号弹窗 -->
<view class="mask flex flex-center-x" @touchmove.prevent v-if="is_code" @click="is_code = false">
<image :src="wechat_qrcode" alt="" style="width: 500rpx; height: 500rpx; margin: 0 auto" />
</view>
<!-- 兑换码 -->
<view class="exchange-guide" v-if="isBatch && !is_pay" @click="getexchange">
<i class="iconfont iconicon-life-gift"></i> 兑换码 <i class="iconfont iconxiangyou"></i>
</view>
<!-- 直播间密码弹窗 -->
<view :class="{ on: password }" class="password">
<view class="title">请输入密码</view>
<input type="password" v-model="qr_password" autocomplete="off" />
<input type="hidden" v-model="studio_pwd" autocomplete="off" />
<view class="psdBnt" @click="goLive">确定</view>
</view>
<!-- 分享海报 -->
<view v-if="is_poster" class="poster">
<image mode="widthFix" :src="filename" />
<view v-if="filename">长按保存,分享朋友</view>
</view>
<!-- 完课证书 -->
<view v-if="imgSrc" class="certificate-image">
<image mode="widthFix" :src="imgSrc" />
</view>
<PayDialog v-if="init" :open.sync="payDialogOpen" :money="money" :now_money="now_money"
:memberMoney="Number(special.member_money)" :memberLink="memberLink" :isMember="!!isMember"
:special_id="special_id" :link_pay_uid="link_pay_uid" :pay_type_num="pay_type_num" :pink-id="pinkId"
:is-wechat="isWechat" :is-alipay="is_alipay" :is-balance="is_yue" :isMembership="true"
@fatherMethod="fatherMethod" :template-id="templateId" :wxpay-h5="wxpayH5" @change="changeVal" />
<!-- 评价弹窗 -->
<EvaluateDialog :dialog-show="dialogShow" :rate-value="rateValue" :image-list="imageList" @rate-change="rateChange"
@image-upload="imageUpload" @image-delete="imageDelete" @evaluate-submit="evaluateSubmit" />
<!-- 分享返佣 -->
<RebateGuide v-if="rebateMoney && isShareDisplaySwitch" :rebate-money="rebateMoney" @rebate-action="rebateAction" />
<TkiQrcode loadMake v-if="infoLoading && isQrcodeCanvasVisable" ref="qrcode" :showLoading="false" :val="qrcodeText"
@result="handleQrcodeCreateSuccess" />
<canvas canvas-id="poster" v-if="isPosterCanvasVisable" class="poster-canvas" />
<canvas canvas-id="poster2" v-if="isPosterCanvasVisable2" class="poster-canvas2" />
</BaseContainer>
</template>
<script>
import {
validitySpecial,
getSpecialNumberCourse,
addLearningRecords,
getLearningRecords,
getSpecialInfo,
getSpecialList,
getTopicSpecialTestPaper,
getSpecialTemplateIds,
getSpecialMaterial,
getSpecialReplyData,
getSpecialReplyList,
getGroupList,
getInspectData,
getSpecialCertificate,
getSpecialCertificateInfo,
getCourseList,
getColumnTask,
getLiveRecordList,
submitSpecialComment,
getBarrageList,
// setBarrageIndex,
getTaskLink,
getSpecialPlayNum,
collectSpecial,
receiveGift,
getSpecialPinkList,
aliPayApp,
aliPayWap,
delSpecialOrder,
getGiftToken,
getMemberRechargeApi
} from "@/api/special";
import { getLecturer, getRebateAmount } from "@/api/auth";
import specialType from "@/constants/special-type";
import mpHtml from "mp-html/dist/uni-app/components/mp-html/mp-html.vue";
import EvaluateList from "@/components/EvaluateList/index.vue";
import RebateGuide from "@/components/RebateGuide/index.vue";
import EvaluateDialog from "@/components/EvaluateDialog/index.vue";
import userInfoMixins from "@/mixins/userInfo";
import PayDialog from "@/components/PayDialog/index.vue";
import posterMixin from "@/mixins/poster";
import JoinVip from '@/components/JoinVip/index.vue';
import config from "@/config/index";
import { precheckLive } from "@/api/live";
import dayjs from "dayjs";
import { CUSTOMER_DETAIL_TYPE, CUSTOMER_SUPPORT_TYPE } from '@/constants/customer-type';
const { BASE_LIVE_URL } = config;
export default {
mixins: [userInfoMixins, posterMixin],
components: {
mpHtml,
EvaluateList,
RebateGuide,
EvaluateDialog,
PayDialog,
JoinVip,
},
filters: {
serial(value) {
return value < 9 ? "0" + (value + 1) : value + 1;
},
validityFormat(value) {
let result = "";
let days = Math.floor(value / 60 / 60 / 24);
let hours = Math.floor((value / 60 / 60) % 24);
let minutes = Math.floor((value / 60) % 60);
if (days) {
result += days + "天";
}
if (hours) {
result += hours + "小时";
}
return result + minutes + "分钟";
},
},
data() {
return {
imId:"",
memberLink: '',
memberMoney: '',
xtt_class:
"acea-row row-center-wrapper video_footer_btn_left_pic flex-auto",
xtt_class2:
"video_footer_btn_right acea-row row-column row-center-wrapper on",
init: false,
poster_image: "",
navTitle: "",
BarrageShowTime: 5,
infoLoading: false,
comment_switch: false,
special_id: 0,
parentActive: 0,
site_name: "",
RecordId: "",
count: 0,
special: {},
swiperlist: [],
pinkIngList: [],
otherTaskList: [],
columnTaskList: [],
liveTaskList: [],
cloumnNavlist: [
{
title: "目录",
value: 1,
},
{
title: "套餐",
value: 6,
},
{
title: "详情",
value: 2,
},
{
title: "评价",
value: 5,
},
],
otherNavlist: [
{
title: "目录",
value: 1,
},
{
title: "详情",
value: 2,
},
{
title: "评价",
value: 5,
},
],
liveNavlist: [
{
title: "回放目录",
value: 1,
},
{
title: "直播介绍",
value: 2,
},
],
active: 1,
open: true,
payDialogOpen: false, // 是否显示支付弹窗
loginShow: false,
is_pay: false,
isMember: 0,
otherLoading: false,
columnLoading: false,
liveLoading: false,
otherLoadend: false,
columnLoadend: false,
liveLoadend: false,
otherLoaded: false,
columnLoaded: false,
liveLoaded: false,
pay_type_num: -1,
pinkId: 0,
pinkInfo: {
pinkT: {
difftime: { hour: "00", minute: "00", second: "00" },
},
},
Barragelist: [],
otherLoadTitle: "上拉加载更多",
columnLoadTitle: "上拉加载更多",
liveLoadTitle: "上拉加载更多",
money: 0,
where: {
page: 1,
limit: 16,
special_id: 0,
source_id: 0,
},
where2: {
page: 1,
limit: 16,
special_id: 0,
source_id: 0,
},
orderId: null,
is_gift: false,
paid: false,
link_pay: false,
link_pay_uid: 0,
uid: 0,
wechat_qrcode: "",
is_code: false,
isWechat: false,
is_live: false,
url: "/pages/index/login",
isPink: false,
pinkOrderId: '',
oid: 0,
barrageStatus: true,
num: null,
stream_name: "",
password: false,
liveInfo: {},
qr_password: "",
studio_pwd: null,
is_alipay: false, //支付宝是否开启
is_yue: false, //余额是否开启
now_money: 0, //余额
lecturer: null,
specialType,
topFocus: true,
record: {
recordCoujnt: 0,
},
scrollData: [],
templateId: "",
problemList: [],
questionList: [],
is_poster: false,
filename: "",
imgSrc: "",
wxpayH5: false,
dialogShow: false,
rateValue: 5, // 评价打分
imageList: [], // 评价上传图片
evaluateList: [],
evaluateLoading: false,
evaluateFinished: false,
evaluatePage: 1,
evaluateLimit: 10,
evaluateWhole: 0,
evaluateScore: 0,
isBatch: false,
materialList: [],
special_validity: -1, // -1 未购买显示课程有效期 0 已购买并永久 >0 已购买并有有效期
rebateMoney: 0,
isShareDisplaySwitch: false,
isOpenWeixing: false,
gift_uid: 0,
gift_order_id: 0,
gift: 0,
spread_uid: 0,
isPosterCanvasVisable2: false,
site_url: '',
TOUTIAO_STATUS:false
};
},
watch: {
pay_type_num() {
this.getSubscribeId();
},
},
onShow() {
if (this.isOpenWeixing && this.orderId) {
this.$util.wxh5PayIsSuccess(this.orderId, 1, this);
this.isOpenWeixing = false;
}
this.getSpecialInfo();
},
onUnload() {
clearInterval(this.timerFlag);
},
onLoad(options) {
let id = 0;
const parmData = this.$util.mergeLaunchParams(options)
if (parmData.id) id = parmData.id;
if (parmData.goid) {
this.gift = 1
this.spread_uid = parmData.guid
this.gift_order_id = parmData.goid
this.gift_uid = parmData.guid
}
this.special_id = Number(id);
if (this.special_id) {
this.where.special_id = this.special_id;
this.where2.special_id = this.special_id;
}
this.getSpecialInfo().then(() => {
this.getLecturer();
this.getPinkIngLists();
this.getProblem();
this.getPinkInfo();
if (this.special.type != 4) {
this.getInspect();
if (this.comment_switch) {
this.getEvaluateStatus();
this.getEvaluateList();
} else {
if (this.special == 5) {
for (let i = 0; i < this.cloumnNavlist.length; i++) {
if (this.cloumnNavlist[i].value == 5) {
this.cloumnNavlist.splice(i, 1);
break;
}
}
} else {
for (let j = 0; j < this.otherNavlist.length; j++) {
if (this.otherNavlist[j].value == 5) {
this.otherNavlist.splice(j, 1);
break;
}
}
}
}
}
this.getCourseLiveData();
});
this.validitySpecial();
this.getNumberCourses();
this.addLearningRecords();
this.getSubscribeId();
this.specialMaterial();
this.rebateAmount();
this.getGroupList();
this.getMemberRecharge();
/* #ifdef MP-TOUTIAO */
this.TOUTIAO_STATUS = true;
/* #endif */
},
created() {
//#ifdef MP-WEIXIN
wx.showShareMenu({
withShareTicket: true,
menus: ['shareAppMessage', 'shareTimeline']
});
//#endif
},
// 分享朋友
onShareAppMessage() {
console.log();
return { title: this.special.title, path: '/pages/special/details?id=' + this.special_id+'&spread_uid='+(this.userInfo.uid??0) }
},
onShareTimeline() {
return {
title: this.special.title,
imageUrl: this.swiperlist[0]
};
},
onReachBottom() {
if (this.active === 1) {
if (this.special.type === 4) {
this.getLiveTask();
} else {
this.getCourseList();
}
}
if (this.active === 6) {
this.getCloumnTask();
}
if (this.active === 5) {
this.getEvaluateList();
}
},
computed: {
shareQrcodeData() {
return {
spread_uid: this.userInfo?.uid,
id: this.special_id,
};
},
},
methods: {
imCallback(e) {
console.log("跳转IM客服成功", e.detail);
},
onimError(e) {
console.log("拉起IM客服失败", e.detail);
},
fatherMethod() {
this.init = false;
},
getMemberRecharge() {
getMemberRechargeApi().then(res => {
this.memberLink = res.data.url;
}).catch(err => {
// console.log(err)
})
},
getGroupList() {
getGroupList(this.special_id).then((res) => {
this.scrollData = res.data;
});
},
async getPinkInfo() {
if (!this.pinkId) return;
try {
const { data } = await this.getPinkInfo(this.pinkId);
this.pinkInfo = data;
this.CountDown({ name: "pinkInfo.pinkT", time_name: "stop_time" });
} catch (err) { }
},
getCourseLiveData() {
switch (this.special.type) {
case 5:
this.getCourseList();
this.getCloumnTask();
break;
case 4:
this.getLiveTask();
break;
case 1:
case 2:
case 3:
case 6:
this.getCourseList();
break;
}
},
validitySpecial() {
validitySpecial(this.special_id).then(({ data }) => {
this.special_validity = data.validity;
});
},
// 点击我要评价
userEvaluate() {
this.$util.checkLogin(() => {
if (
!(this.is_pay || (!this.special.member_pay_type && this.isMember))
) {
uni.showModal({
title: "提示",
content: "购买后即可进行评价,是否购买?",
confirmText: "购买",
success: ({ confirm }) => {
if (!confirm) return;
this.payDialogOpen = true;
this.init = true;
},
});
} else {
this.dialogShow = true;
}
}, true);
},
getexchange() {
this.$util.checkLogin(() => {
uni.navigateTo({
url: `/pages/special/exchange?special_id=${this.special_id}`
});
}, true);
},
// 获取评价状态
getEvaluateStatus() {
getSpecialReplyData(this.special_id).then((resData) => {
if (resData.code === 200) {
let data = resData.data;
this.evaluateWhole = data.whole;
this.evaluateScore = data.score;
} else {
this.$util.showMsg(resData.msg);
}
});
},
// 获取评价列表
async getEvaluateList() {
if (this.evaluateLoading || this.evaluateFinished) {
return;
}
this.evaluateLoading = true;
try {
const resData = await getSpecialReplyList(
this.special_id,
this.evaluatePage++,
this.evaluateLimit
);
if (resData.code === 200) {
let data = resData.data;
this.evaluateList = this.evaluateList.concat(data);
this.evaluateFinished = this.evaluateLimit > data.length;
} else {
this.$util.showMsg(resData.msg);
}
} catch (err) { }
this.evaluateLoading = false;
},
// 点击遮罩层
maskClick() {
this.dialogShow = false;
this.password = false;
this.is_poster = false;
this.open = true;
this.imgSrc = "";
},
// 提交评价
async evaluateSubmit(text) {
uni.showLoading({ mask: true });
try {
const { msg } = await submitSpecialComment(this.special_id, {
satisfied_score: this.rateValue,
comment: text.trim(),
pics: this.imageList,
});
uni.hideLoading();
this.$util.showMsg(msg);
this.dialogShow = false;
this.getEvaluateStatus();
this.evaluateFinished = false;
this.evaluatePage = 1;
this.evaluateList = [];
this.getEvaluateList();
} catch (err) {
uni.hideLoading();
this.$util.showMsg(err.msg);
}
},
// 删除图片
imageDelete(index) {
this.imageList.splice(index, 1);
},
// 上传图片
imageUpload(path) {
this.imageList.push(path);
},
// 评分
rateChange(value) {
this.rateValue = value;
},
handleQrcodeCreateSuccess(path) {
this.x_cb(path);
},
handleCreateSharePoster() {
this.$util.checkLogin(() => {
this.poster_image = this.special.poster_image;
this.createSharePoster("poster", {
id: this.special_id,
spread_uid: this.userInfo?.uid,
url: 'pages/special/details'
});
}, true);
},
// 是否可以发放证书
getInspect() {
getInspectData(this.special_id)
.then((res) => {
if (200 == res.code) {
uni.showModal({
title: "提示",
content: "恭喜您已达到证书发放标准,是否领取?",
confirmText: "领取",
cancelText: "取消",
success: ({ confirm }) => {
if (!confirm) return;
this.getCertificate();
},
});
}
})
.catch((err) => {
// console.log(err);
});
},
async renderProductPoster2(data) {
this.isPosterCanvasVisable2 = true
let id = "poster2"
let task1 = this.$util.getImagePath(data.certificate.background);
let task2 = this.$util.getImagePath(data.certificate.qr_code);
const [bgPath, codePath] = await Promise.all([task1, task2]);
let WIDTH = 600;
let HEIGHT = 850;
let site_name = "知识付费"
let context = uni.createCanvasContext(id);
context.drawImage(bgPath, 0, 0);
context.drawImage(codePath, 220, 557, 160, 160);
context.fillStyle = "rgba(255, 255, 255, 0.8)";
context.fillRect(220, 724, 160, 36);
context.font = "bold 34px sans-serif";
context.textAlign = "center";
context.fillStyle = "#29466D";
context.fillText(data.nickname, 300, 296);
context.font = "24px sans-serif";
context.fillText(
"颁发时间:" +
dayjs(data.add_time * 1000).format("YYYY.MM.DD"),
300,
490
);
context.font = "20px sans-serif";
context.fillStyle = "#666666";
context.fillText("长按二维码查看", 300, 748);
context.font = "28px sans-serif";
context.textAlign = "start";
context.fillStyle = "#333333";
let lineWidth = 0;
let substringFrom = 0;
let offsetTop = 364;
for (let i = 0; i < data.certificate.explain.length; i++) {
lineWidth += context.measureText(
data.certificate.explain[i]
).width;
if (lineWidth > 434) {
context.fillText(
data.certificate.explain.substring(substringFrom, i),
83,
offsetTop
);
lineWidth = 0;
substringFrom = i;
offsetTop += 50;
}
if (i == data.certificate.explain.length - 1) {
context.fillText(
data.certificate.explain.substring(substringFrom, i),
83,
offsetTop
);
}
}
context.draw(true, () => {
uni.canvasToTempFilePath(
{
canvasId: id,
fileType: "png",
destWidth: WIDTH,
destHeight: HEIGHT,
success: (res) => {
this.isPosterCanvasVisable2 = false
uni.previewImage({
current: 0,
urls: [res.tempFilePath],
})
context = null;
},
fail: (err) => {
this.isPosterCanvasVisable2 = false
context = null;
},
}
);
});
},
// 领取证书
getCertificate() {
getSpecialCertificate(this.special_id).then((res) => {
this.$util.showMsg("领取成功,证书制作中…");
this.getCertificateInfo(res.msg);
});
},
// 获取证书信息
getCertificateInfo(id) {
getSpecialCertificateInfo(id).then((res) => {
this.renderProductPoster2(res.data);
});
},
// 去练习、答题
goQuestion(question) {
this.$util.checkLogin(() => {
if (question.is_pay || this.is_pay) {
if (question.type == 1) {
uni.navigateTo({
url: `/pages/topic/problem_index?id=${question.id}`,
});
} else {
uni.navigateTo({
url: `/pages/special/question_index?id=${question.id}`,
});
}
} else {
this.init = true;
this.pay_type_num = 2;
this.payDialogOpen = true;
}
}, true);
},
// 获取练习
async getProblem() {
try {
const { data: questions } = await getTopicSpecialTestPaper(
this.special_id
);
if (questions.length) {
if (this.special.type === 5) {
this.cloumnNavlist.splice(this.cloumnNavlist.length - 1, 0, {
title: "练习",
value: 3,
});
} else {
this.otherNavlist.splice(this.otherNavlist.length - 1, 0, {
title: "练习",
value: 3,
});
}
for (var i = questions.length; i--;) {
questions[i].rate = Math.floor(
(questions[i].done / questions[i].item_number) * 100
);
}
this.problemList = questions;
}
} catch (err) { }
this.getQuestion();
},
// 获取考试
getQuestion() {
getTopicSpecialTestPaper(this.special_id, 2).then(
({ data: questions }) => {
if (questions.length) {
console.log(this.special.type, 1472);
if (this.special.type === 5) {
this.cloumnNavlist.splice(this.cloumnNavlist.length - 1, 0, {
title: "考试",
value: 4,
});
} else {
this.otherNavlist.splice(this.otherNavlist.length - 1, 0, {
title: "考试",
value: 4,
});
console.log(this.otherNavlist);
}
}
this.questionList = questions;
}
);
},
// 获取订阅通知模板id
getSubscribeId() {
if (!this.isWechat) {
return;
}
getSpecialTemplateIds(this.pay_type_num, this.special_id).then((res) => {
this.templateId = res.msg;
});
},
show(special) {
// if (special.is_light) {
// window.location.href = "{:url('special/single_details')}?id=" + special.id;
// } else {
// special.active = !special.active;
// }
special.active = !special.active;
},
// 讲师详情
getLecturer() {
getLecturer(this.special.mer_id).then(({ data }) => {
this.lecturer = data;
});
},
getSpecialInfo() {
return getSpecialInfo(this.special_id, this.gift_uid, this.gift_order_id, this.gift, this.spread_uid)
.then(({ data }) => {
const {
special,
orderId,
isPay,
gift,
is_member,
link_pay,
pinkId,
wechat_qrcode,
link_pay_uid,
isWechat,
BarrageShowTime,
isPink,
pinkOrderId,
oid,
barrage_index,
liveInfo,
is_alipay,
site_url,
is_yue,
now_money,
wxpayH5,
share_display,
uid,
isBatch,
comment_switch,
d_im
} = data;
Object.assign(this, {
navTitle: special.title,
infoLoading: true,
orderId,
is_gift: !!gift,
link_pay: !!link_pay,
link_pay_uid: link_pay ? link_pay_uid : 0,
comment_switch,
isBatch,
uid,
BarrageShowTime,
special: special.special,
swiperlist: special.swiperlist,
is_pay: isPay,
paid: isPay,
isMember: is_member,
pinkId,
money: Number(special.special.money),
wechat_qrcode,
isWechat,
is_live: special.special.is_live,
url: isWechat ? "/pages/index/login" : "/pages/login/phone_check",
isPink,
pinkOrderId,
oid,
num: barrage_index,
stream_name: liveInfo.stream_name || "",
liveInfo,
studio_pwd: liveInfo.studio_pwd,
is_alipay: !!is_alipay,
site_url: site_url,
is_yue: !!is_yue,
now_money: Number(now_money),
wxpayH5,
isShareDisplaySwitch: share_display,
imId:d_im
});
this.barrage();
})
.catch((err) => {
this.$util.showMsg(err.msg);
setTimeout(() => {
// #ifndef MP
uni.reLaunch({
url: '/pages/index/index'
})
// #endif
// #ifdef MP
uni.navigateBack({
fail: (err) => {
uni.switchTab({
url: '/pages/index/index'
});
}
})
// #endif
}, 2000);
});
},
// 获取浏览人数
getLearningRecords() {
getLearningRecords(this.special_id).then(({ data }) => {
this.record = data;
});
},
// 记录浏览人数
addLearningRecords() {
addLearningRecords(this.special_id).then(() => {
this.getLearningRecords();
});
},
// 拼团列表
getPinkIngLists() {
if (!this.special.is_pink) return;
getSpecialPinkList(this.special_id, 0).then(({ data }) => {
this.pinkIngList = data;
this.CountDown({ name: "pinkIngList", time_name: "stop_time" });
});
},
// 专题下章节数量
getNumberCourses() {
getSpecialNumberCourse(this.special_id).then(({ data }) => {
this.count = data;
});
},
goLive() {
if (!this.qr_password) return this.$util.showMsg("请输入密码");
if (this.qr_password != this.studio_pwd)
return this.$util.showMsg("密码不正确");
uni.navigateTo({
url: `/pages/live/index?${this.$util.objToParam({
stream_name: this.stream_name,
record_id: this.RecordId,
})}`,
});
// document.cookie =
// this.stream_name +
// "studio_pwd" +
// "=" +
// this.studio_pwd +
// ";expires=7200" +
// ";path=/";
// window.location.href = $h.U({
// c: "live",
// a: "index",
// q: { stream_name: this.stream_name, record_id: this.RecordId },
// });
},
barrage() {
if (typeof this.BarrageShowTime == "string")
this.BarrageShowTime = parseInt(this.BarrageShowTime);
this.BarrageShowTime = this.BarrageShowTime * 1000;
getBarrageList(this.special_id).then(({ data }) => {
this.$set(this, "Barragelist", data);
this.Barragelist = this.Barragelist || [];
let len = this.Barragelist.length;
if (!len) return;
// this.timerFlag = setInterval(() => {
// this.num = this.num + 1;
// this.num = this.num >= len ? 0 : this.num;
// this.num = this.num < 0 ? 0 : this.num;
// this.barrageStatus = !this.barrageStatus;
// setBarrageIndex(this.num);
// }, this.BarrageShowTime);
});
},
goPink(pink_id, uid, orderId, oid = 0) {
if (uid == this.uid && this.isPink) {
uni.navigateTo({
url:
"/pages/special/pink?" +
this.$util.objToParam({
orderId: orderId,
pink_id: this.pinkId,
special_id: this.special.id,
is_help: 0,
oid: oid
}),
});
} else {
uni.navigateTo({
url:
"/pages/special/pink?" +
this.$util.objToParam({
orderId: orderId,
pink_id: pink_id > 0 ? pink_id : this.pinkId,
special_id: this.special.id,
is_help: 1,
}),
});
}
},
follow() {
uni.previewImage({
current: 0,
urls: [this.wechat_qrcode],
});
},
getPartakePinkUrl() {
return `/pages/special/details?id=${this.special_id}`;
},
pay_order(data) {
this.orderId = data.data.result.orderId || "";
switch (data.data.status) {
case "PAY_ERROR":
case "ORDER_EXIST":
case "ORDER_ERROR":
this.extendOrder(data.msg);
break;
case "WECHAT_PAY":
this.wechatPay(data.data.result.jsConfig);
break;
case "WECHAT_H5_PAY":
this.payDialogOpen = false;
this.$util.wechatH5Pay(data.data.result.jsConfig, this);
break;
case "WECHAT_ROUTINE_PAY":
this.$util.wechatRoutinePay(data.data.result.jsConfig, this);
break;
case "SUCCESS":
this.successOrder(data.msg);
break;
case "ZHIFUBAO_PAY":
this.aliPay(data.data.result, "special");
break;
case 'TOUTIAO_PAY':
this.$util.toutiaoPay(data.data.result.jsConfig, this);
break;
case 'KUAISHOU_PAY':
this.$util.kuaishouPay(data.data.result.jsConfig, this);
break
}
},
aliPay(msn, type) {
this.$util.aliPay(msn, type, this);
},
wechatPay: function (config) {
this.$util.weixinpay(config, this);
},
successOrder(msg) {
this.$util.showMsg(msg ? msg : "支付成功");
switch (parseInt(this.pay_type_num)) {
case 1:
uni.navigateTo({
url: `/pages/special/gift_special?orderId=${this.orderId}`,
});
break;
case 2:
this.paid = true;
this.is_pay = true;
this.payDialogOpen = false;
this.updateMaterialStatus();
break;
case 3:
uni.navigateTo({
url: `/pages/special/pink?orderId=${this.orderId}`,
});
break;
}
validitySpecial(this.special_id).then((res) => {
this.special_validity = res.data.validity;
});
},
updateMaterialStatus() {
this.otherLoading = false;
this.otherLoaded = false;
this.where.page = 1;
this.$set(this, "otherTaskList", []);
this.getCourseList();
},
extendOrder(msg) {
let that = this;
if (typeof msg === "object") {
if (msg.errMsg === "chooseWXPay:cancel") {
msg = "微信支付取消";
} else {
msg = "支付失败";
}
} else {
msg = "支付失败";
}
this.$util.showMsg(msg);
this.payDialogOpen = false;
if (this.orderId) {
delSpecialOrder(this.orderId).then((res) => {
console.log(res);
});
}
},
setMeal(item) {
if (this.special.type == 5) {
uni.navigateTo({
url: item.is_light
? "/pages/special/single_details"
: "/pages/special/details" + `?id=${item.id}`,
});
}
},
// 点击专题目录
play(item) {
if (this.active == 6) {
uni.navigateTo({
url: `/pages/special/details?id=${item.id}`,
});
} else {
this.$util.checkLogin(() => {
if (
!item.is_free ||
item.is_try ||
this.is_pay ||
(!this.special.member_pay_type && this.isMember)
) {
this.goPlayTask(item);
} else {
uni.showModal({
title: "提示",
content: "购买后可操作,是否购买?",
confirmText: "购买",
success: ({ confirm }) => {
if (!confirm) return;
this.payDialogOpen = true;
this.init = true
this.pay_type_num = 2;
},
});
}
}, true)
}
},
// 专题列表
async getCourseList() {
if (this.otherLoading) return;
if (this.otherLoaded) return;
this.otherLoadTitle = "";
this.otherLoading = true;
try {
const { data } = await getCourseList(this.where);
let list = data.list || [],
taskList = [];
list.forEach((item) => {
item.active = false;
});
taskList = this.$util.SplitArray(list, this.otherTaskList);
taskList.forEach((item, index) => {
item.active = !index;
});
this.where.page = data.page;
this.otherLoaded = list.length < this.where.limit;
this.otherLoadTitle = this.otherLoaded
? "我也是有底线的"
: "上拉加载更多";
this.otherLoading = false;
console.log(taskList);
this.$set(this, "otherTaskList", taskList);
} catch (error) {
this.otherLoading = false;
this.otherLoadTitle = "加载更多";
}
},
// 套餐列表
async getCloumnTask() {
if (this.columnLoading) return;
if (this.columnLoaded) return;
this.columnLoadTitle = "";
this.columnLoading = true;
try {
const { data } = await getColumnTask(this.where2);
let list = data.list || [];
let taskList = this.$util.SplitArray(list, this.columnTaskList);
this.where2.page = data.page;
this.columnLoaded = list.length < this.where2.limit;
this.columnLoadTitle = this.columnLoaded
? "我也是有底线的"
: "上拉加载更多";
this.columnLoading = false;
this.$set(this, "columnTaskList", taskList);
} catch (error) {
this.columnLoading = false;
this.columnLoadTitle = "加载更多";
}
},
// 直播回放列表
async getLiveTask() {
let that = this;
if (this.liveLoading) return;
if (this.liveLoaded) return;
this.liveLoadTitle = "";
this.liveLoading = true;
try {
const res = await getLiveRecordList(
this.special_id,
this.where.page,
this.where.limit
);
let data = res.data.data;
let list = data || [];
let taskList = this.$util.SplitArray(list, this.liveTaskList);
this.where.page = this.where.page + 1;
this.liveLoaded = list.length < this.where.limit;
this.liveLoadTitle = this.liveLoaded
? "我也是有底线的"
: "上拉加载更多";
this.liveLoading = false;
this.$set(this, "liveTaskList", taskList);
} catch (error) {
this.liveLoading = false;
this.liveLoadTitle = "加载更多";
}
},
//播放素材
async goPlayTask(item) {
if (item.is_light) {
return uni.navigateTo({
url: `/pages/special/single_details?id=${item.id}`,
});
}
uni.showLoading({ mask: true });
try {
await getTaskLink(item.id, item.special_id);
await getSpecialPlayNum(item.id, item.special_id);
uni.hideLoading();
const url =
"/pages/special/" +
(this.special.type == 1 || this.type == 1
? "task_text_info"
: "task_info") +
"?" +
this.$util.objToParam({
id: item.id,
specialId: item.special_id,
viewing_time: (item.watch && item.watch.viewing_time) ? item.watch.viewing_time : 0,
isWechat: this.isWechat,
is_alipay: this.is_alipay,
is_yue: this.is_yue,
wxpayH5: this.wxpayH5,
memberLink: this.memberLink,
now_money: this.now_money,
templateIds: this.templateIds
});
uni.hideLoading();
uni.navigateTo({
url,
});
} catch (err) {
uni.hideLoading();
}
},
//滑动底部加载
bScrollInit: function () {
let that = this;
$h.EventUtil.listenTouchDirection(
document,
function () {
if (that.special.type == 5) {
that.columnLoading == false && that.getCloumnTask();
} else {
that.otherLoading == false && that.getCourseList();
}
},
false
);
},
// 点击收藏
collect() {
this.$util.checkLogin(() => {
collectSpecial(this.special_id)
.then(() => {
this.special.collect = !this.special.collect;
this.$util.showMsg(
this.special.collect ? "收藏成功" : "取消收藏成功"
);
})
.catch((err) => {
console.log(err);
});
}, true);
},
// 点击客服
customerService() {
this.$util.goSupport(CUSTOMER_DETAIL_TYPE.GOOD, CUSTOMER_SUPPORT_TYPE.SPECIAL, this.special_id, this.special.mer_id);
},
//打开支付插件,并检测登录状态,没有登录,打开登录插件
OpenPay(is_pink) {
this.init = true;
this.pay_type_num = is_pink;
this.$util.checkLogin(() => {
switch (is_pink) {
case 1:
if (!this.special.pay_type) {
return this.$util.showMsg("免费的不可以赠送哦");
}
if (this.isMember && !this.special.member_pay_type) {
return this.$util.showMsg("会员价免费的不可以赠送哦");
}
this.money = Number(this.special.money);
this.payDialogOpen = true;
break;
case 2:
if (this.isMember) {
this.money = Number(
this.special.member_pay_type ? this.special.member_money : 0
);
} else {
this.money = Number(this.special.money);
}
this.payDialogOpen = true;
break;
case 3:
this.money = Number(this.special.pink_money);
this.payDialogOpen = true;
break;
case 4:
this.payDialogOpen = false;
receiveGift(this.orderId).then(({ msg }) => {
this.$util.showMsg(msg);
uni.navigateTo({
url: "/pages/special/grade_special",
});
}).catch(({ msg }) => {
this.$util.showMsg(msg);
});
break;
case 5:
// location.hash = '#tash';
// $('body,html').animate({scrollTop: $(this.$refs.list).offset().top}, 800);
// this.is_pay = true;
// this.paid = false;
// this.active = 1;
let url = "/pages/special/";
const params = {
id: 0,
};
let task = this.otherTaskList[0];
if (task.special_task) {
task = task.special_task[0];
}
if (task.is_light) {
if (task.light_type === 1) {
url += "single_text_detail";
}
} else {
url += task.type === 1 ? "task_text_info" : "task_info";
params.specialId = task.special_id;
params.viewing_time =
(task.watch && task.watch.viewing_time) || 0;
}
params.id = task.id;
url += "?" + this.$util.objToParam(params);
uni.navigateTo({
url,
});
break;
case 6:
this.handleToLivePage();
break;
}
}, true);
},
async handleToLivePage() {
if (this.liveInfo.studio_pwd && this.special.pay_type == 2) {
this.password = true;
return;
}
const params = {
stream_name: this.stream_name,
record_id: this.RecordId,
};
const xparams = this.$util.objToParam(params);
uni.showLoading({ mask: true });
try {
await precheckLive(params);
uni.hideLoading();
} catch (err) {
uni.hideLoading();
return this.$util.showMsg(err.msg);
}
uni.navigateTo({
url: "/pages/live/index?" + xparams,
});
},
ReceiveGift() {
if (!this.orderId) return;
receiveGift(this.orderId).then(({ msg }) => {
this.$util.showMsg(msg);
uni.navigateTo({
url: "/pages/index/index",
});
});
},
//关闭登录
loginClose: function (val) {
this.loginShow = false;
val && this.logComplete();
},
//登录完成回调事件
logComplete: function () {
let that = this;
that.isLogin = true;
that.otherLoaded = false;
that.where.page = false;
that.otherTaskList = [];
that.getCourseList();
app.baseGet($h.U({ c: "special", a: "isMember" }), function (res) {
let isMember = res.data.data.is_member;
that.isMember = isMember;
that.now_money = res.data.data.now_money;
switch (that.pay_type_num) {
case 1:
that.money =
isMember && that.special.member_pay_type == 1
? that.special.member_money
: that.special.money;
break;
case 2:
if (isMember) {
that.money = that.special.member_pay_type
? that.special.member_money
: 0;
} else {
that.money = that.special.money;
}
break;
case 3:
that.money = that.special.pink_money;
break;
}
});
app.baseGet(
$h.U({
c: "special",
a: "special_validity",
q: {
id: special.id,
},
}),
function (res) {
that.special_validity = res.data.data.validity;
},
function () { },
true
);
},
//所有插件回调处理事件
changeVal(opt) {
if (typeof opt != "object") opt = {};
let action = opt.action || "";
let value = opt.value || "";
this[action] && this[action](value);
},
CountDown(opt, that) {
if (typeof opt != "object") opt = {};
let name = opt.name || "",
value = null;
that = that ? that : this;
if (name.indexOf(".") === -1) value = that[name];
else {
let nameArray = name.split(".");
value = that[nameArray[0]][nameArray[1]];
}
let tiem = opt.time || 1000,
timeName = opt.time_name || "datatime",
strName = { hour: "00", minute: "00", second: "00" },
outputName = opt.output || "difftime";
if (!name) return false;
if (value === undefined) return false;
opt.nowTime = function () {
if (Array.isArray(value)) {
for (var i = 0; i < value.length; i++) {
let intDiff = value[i][timeName] - Date.parse(new Date()) / 1000; //获取数据中的时间戳的时间差;
let days = 0,
hour = 0,
minute = 0,
second = 0;
if (intDiff > 0) {
hour = Math.floor(intDiff / (60 * 60)) - days * 24;
minute = Math.floor(intDiff / 60) - hour * 60;
second = Math.floor(intDiff) - hour * 60 * 60 - minute * 60;
if (hour <= 9) hour = "0" + hour;
if (minute <= 9) minute = "0" + minute;
if (second <= 9) second = "0" + second;
strName = {
hour: hour,
minute: minute,
second: second,
};
} else {
strName = {
hour: "00",
minute: "00",
second: "00",
};
}
value[i][outputName] = strName;
}
that.$set(that, name, value);
} else {
let intDiff = value[timeName] - Date.parse(new Date()) / 1000;
let days = 0,
hour = 0,
minute = 0,
second = 0;
if (intDiff > 0) {
hour = Math.floor(intDiff / (60 * 60)) - days * 24;
minute = Math.floor(intDiff / 60) - hour * 60;
second = Math.floor(intDiff) - hour * 60 * 60 - minute * 60;
if (hour <= 9) hour = "0" + hour;
if (minute <= 9) minute = "0" + minute;
if (second <= 9) second = "0" + second;
strName = {
hour: hour,
minute: minute,
second: second,
};
} else {
strName = {
hour: "00",
minute: "00",
second: "00",
};
}
if (name.indexOf(".") === -1)
that.$set(that[name], outputName, strName);
else {
let nameArray = name.split(".");
that.$set(that[nameArray[0]][nameArray[1]], outputName, strName);
}
}
};
opt.nowTime();
setInterval(opt.nowTime, tiem);
},
//播放回放
playBackRecord: function (item) {
this.RecordId = item;
this.OpenPay(6);
},
// 关联资料
specialMaterial() {
getSpecialMaterial(this.special_id).then((res) => {
this.materialList = res.data;
});
},
// 获取返佣金额
rebateAmount() {
getRebateAmount(this.special_id).then((res) => {
this.rebateMoney = parseFloat(res.data.brokeragePrice);
});
},
rebateAction(value) {
switch (value) {
case "close":
this.rebateMoney = 0;
break;
case "share":
this.handleCreateSharePoster();
break;
}
},
},
};
</script>
<style>
page {
background: #f5f5f5;
}
/* #ifdef MP-WEIXIN */
.swiper-conter {
padding: 0!important;
}
/* #endif */
</style>
<style scoped lang="scss">
.teacher-section {
// border-top: 14rpx solid #f5f5f5;
background: #F6F6F6;
}
.thematic-details .swiper-details .share {
background-color: #ffffff;
.share_wechat {
padding: 20rpx 0 0 0;
}
}
.swiper-details .special-coverimg {
width: 100%;
height: 390rpx;
> image {
width: 100%;
height: 100%;
}
}
.teacher-table {
display: flex;
align-items: center;
height: 150rpx;
}
.teacher-table .item {
-webkit-box-flex: 1;
-webkit-flex: 1;
flex: 1;
position: relative;
min-width: 0;
font-size: 24rpx;
text-align: center;
color: #999999;
}
.teacher-table .item:last-child::before {
content: "";
position: absolute;
top: 50%;
left: 0;
width: 2rpx;
height: 40rpx;
background-color: #e8e8e8;
-webkit-transform: translateY(-50%);
transform: translateY(-50%);
}
.teacher-table .item .learn {
font-size: 0;
}
.teacher-table .item .learn .child {
font-size: 24rpx;
}
.teacher-table .item .learn .child:nth-child(2) {
font-weight: bold;
font-size: 28rpx;
}
.teacher-table>view:last-child>view:first-child {
margin-bottom: 6rpx;
}
.teacher-table .num {
font-size: 38rpx;
color: #333333;
}
.teacher-table image {
width: 50rpx;
height: 50rpx;
border: 2px solid #ffffff;
border-radius: 50%;
margin-left: -15rpx;
-webkit-box-sizing: border-box;
box-sizing: border-box;
background-color: #2c8eff;
vertical-align: middle;
object-fit: cover;
pointer-events: none;
-webkit-touch-callout: none;
}
.teacher-detail-wrap {
padding: 0 30rpx 30rpx;
}
.teacher-detail-wrap .a {
display: block;
padding: 30rpx;
border-radius: 4rpx;
background-color: #f9fafc;
}
.teacher-detail-wrap .iconfont {
color: #666666;
}
.teacher-detail-wrap .detail-hd {
display: -webkit-box;
display: -webkit-flex;
display: flex;
-webkit-box-align: center;
-webkit-align-items: center;
align-items: center;
}
.teacher-detail-wrap .detail-hd .head {
width: 100rpx;
height: 100rpx;
border-radius: 50%;
overflow: hidden;
}
.teacher-detail-wrap .detail-hd .head .image {
display: block;
width: 100rpx;
height: 100rpx;
object-fit: cover;
}
.teacher-detail-wrap .detail-hd .text {
-webkit-box-flex: 1;
-webkit-flex: 1;
flex: 1;
min-width: 0;
margin: 0 18rpx;
font-weight: bold;
font-size: 30rpx;
color: #282828;
}
.teacher-detail-wrap .detail-hd .text .text {
display: inline-block;
height: 34rpx;
padding: 0 12rpx;
border-radius: 10rpx;
background-color: #fff0e5;
font-weight: normal;
font-size: 20rpx;
line-height: 34rpx;
color: #ff6b00;
}
.teacher-detail-wrap .detail-hd .text {
margin-left: 10rpx;
}
.teacher-detail-wrap .detail-bd {
margin-top: 20rpx;
font-size: 26rpx;
line-height: 38rpx;
color: #666666;
}
.scroll-section {
display: -webkit-box;
display: -webkit-flex;
display: flex;
-webkit-box-align: center;
-webkit-align-items: center;
align-items: center;
margin-top: 14rpx;
background-color: #fffcf6;
font-size: 24rpx;
}
.scroll-section .label {
width: 200rpx;
padding-left: 75rpx;
background: url("") 30rpx center/26rpx 22rpx no-repeat;
color: #feb720;
}
.scroll-section .swiper-container {
position: relative;
-webkit-box-flex: 1;
-webkit-flex: 1;
flex: 1;
min-width: 0;
height: 62rpx;
padding-left: 16rpx;
line-height: 62rpx;
}
.scroll-section .swiper-container::before {
content: "";
position: absolute;
top: 50%;
left: 0;
width: 1px;
height: 24rpx;
border-left: 1px solid #999999;
-webkit-transform: translateY(-50%);
transform: translateY(-50%);
}
.process-section {
margin-top: 14rpx;
background-color: #ffffff;
}
.process-section .title {
display: -webkit-box;
display: -webkit-flex;
display: flex;
-webkit-box-align: center;
-webkit-align-items: center;
align-items: center;
height: 86rpx;
padding-right: 30rpx;
padding-left: 30rpx;
font-size: 28rpx;
color: #282828;
}
.process-section .list {
display: -webkit-box;
display: flex;
-webkit-box-pack: justify;
justify-content: space-between;
-webkit-box-align: center;
align-items: center;
height: 110rpx;
padding-right: 30rpx;
padding-left: 30rpx;
border-top: 1px solid #eeeeee;
}
.process-section .list .item {
padding-right: 0 !important;
}
.process-section .list .item~.item {
padding-left: 67rpx;
border: none !important;
background: url("") left center/28rpx 20rpx no-repeat;
}
.process-section .list .item span {
display: inline-block;
box-sizing: border-box;
vertical-align: middle;
font-size: 26rpx;
line-height: 37rpx;
color: #282828;
}
.process-section .list .item span:first-child {
width: 28rpx;
height: 28rpx;
border: 1px solid #282828;
border-radius: 50%;
margin-right: 6rpx;
font-size: 22rpx;
line-height: 24rpx;
text-align: center;
color: #282828;
}
.navCon {
position: relative;
padding: 0 30rpx;
}
.navCon {
.item {
margin: 0 72rpx 0 0!important;
&.on {
font-weight: normal!important;
&:after {
background: linear-gradient(90deg, #24A9E1, #0F74BB);
border-radius: 3rpx;
}
}
&:last-child {
margin-right: 0;
color: #999;
font-size: 28rpx;
}
}
}
.evaluate-section .head {
display: -webkit-box;
display: flex;
-webkit-box-pack: justify;
justify-content: space-between;
-webkit-box-align: center;
align-items: center;
padding: 33rpx 30rpx 13rpx;
}
.evaluate-section .score {
display: -webkit-box;
display: flex;
-webkit-box-align: center;
align-items: center;
}
.evaluate-section .score view:first-child {
font-size: 28rpx;
color: #ff6b00;
}
.evaluate-section .score text {
margin-right: 5rpx;
font-weight: bold;
font-size: 44rpx;
}
.evaluate-section .score view:last-child {
width: 170rpx;
height: 42rpx;
border-radius: 21rpx;
margin-left: 15rpx;
background-color: #f5f5f5;
font-size: 24rpx;
line-height: 42rpx;
text-align: center;
color: #999999;
}
.evaluate-section .head button {
width: 160rpx;
height: 56rpx;
border-radius: 28rpx;
background-image: linear-gradient(90deg, #409dff 0%, #1e85fb 100%);
font-size: 26rpx;
color: #ffffff;
}
.video_footer_btn {
-webkit-flex: 1;
flex: 1;
height: 76rpx;
border-radius: 37px;
}
.video_footer_btn_left {
width: 50%;
height: 100%;
border-radius: 37px 0px 0px 37px;
background: #ff6b00;
}
.video_footer_btn_right {
width: 50%;
height: 100%;
border-radius: 0px 37px 37px 0px;
background: #1D8DFF;
}
.video_footer_btn_left_pic {
font-size: 28rpx;
line-height: 22rpx;
font-weight: 600;
color: #ffffff;
text-align: center;
}
.video_footer_btn_left_num {
font-size: 20rpx;
line-height: 20rpx;
color: #ffffff;
text-align: center;
}
.video_footer_btn_left_pic+.video_footer_btn_left_num {
margin-top: 9rpx;
}
.thematic-details .material button,
.single-special .material button {
padding: 3rpx 20rpx;
border-radius: 30rpx;
background-color: #2c8eff;
font-family: inherit;
font-weight: normal;
font-size: 22rpx;
color: #ffffff;
height: 50rpx;
line-height: 50rpx;
}
.footer .video_footer_btn .on {
width: 100% !important;
border-radius: 37px !important;
}
.thematic-details .poster {
position: fixed;
top: 15%;
left: 15%;
width: 70%;
z-index: 60;
}
.base-wrap {
/* #ifndef MP-WEIXIN */
padding-bottom: calc(100rpx + var(--safe-bottom));
/* #endif */
}
.thematic-details .poster image {
width: 100%;
}
.thematic-details .poster view {
color: #eee;
font-size: 14px;
margin-left: 25%;
}
.thematic-details .footer {
position: fixed;
bottom: 0;
left: 0;
z-index: 9;
width: 100%;
border-top: 1px solid #eee;
padding-bottom: var(--safe-bottom);
background-color: #ffffff;
}
.thematic-details .footer .link {
width: 90rpx;
height: 100rpx;
line-height: 100rpx;
text-align: center;
}
.thematic-details .footer .link .cont {
display: inline-block;
vertical-align: middle;
font-size: 20rpx;
line-height: 36rpx;
color: #666;
}
.thematic-details .footer .link image {
display: block;
width: 44rpx;
height: 44rpx;
margin-right: auto;
margin-left: auto;
}
.thematic-details .footer .wrap {
flex: 1;
min-width: 0;
padding-right: 30rpx;
padding-left: 30rpx;
}
.thematic-details .footer .item {
border: 1rpx solid #d9d9d9;
width: 133rpx;
height: 100rpx;
border-radius: 10rpx;
font-size: 24rpx;
color: #333;
}
.thematic-details .footer .item image {
width: 42rpx;
height: 46rpx;
}
.thematic-details .footer .item.item1 {
width: 187rpx;
}
.thematic-details .footer .item.item2 {
width: 187rpx;
background-color: #f9e067;
border-color: #f9e067;
}
.thematic-details .footer .item .money {
font-size: 36rpx;
color: #333;
font-weight: bold;
margin-bottom: -6rpx;
}
.thematic-details .footer .item.on {
width: 390rpx;
}
.thematic-details .footer .item.on .money {
margin-bottom: 0;
}
.dialog {
position: fixed;
top: 50%;
right: 85rpx;
left: 85rpx;
z-index: 56;
display: none;
max-height: 90%;
padding: 50rpx 0;
border-radius: 12rpx;
background-color: #ffffff;
transform: translateY(-50%);
text-align: center;
font-size: 30rpx;
color: #333333;
opacity: 0;
}
.dialog.show {
display: block;
opacity: 1;
}
.dialog image {
width: 354rpx;
height: 354rpx;
margin-bottom: 20rpx;
vertical-align: middle;
object-fit: contain;
}
.thematic-details .swiper-details .swiper-nav {
background: #ffffff;
width: 690rpx;
margin: 20rpx auto 0;
}
.thematic-details .lecturer-info {
align-items: center;
width: 690rpx;
height: 180rpx;
margin: 20rpx auto 0;
padding: 0 32rpx;
background: #fff;
.info-avatar {
width: 100rpx;
height: 100rpx;
>image {
width: 100%;
height: 100%;
border-radius: 50%;
}
}
.info-box {
margin: 0 24rpx 0 9rpx;
flex: 1;
display: flex;
flex-direction: column;
justify-content: center;
.info-name {
display: flex;
font-size: 28rpx;
color: #333;
margin-bottom: 14rpx;
line-height: 39rpx;
>text {
padding: 0 14rpx;
height: 39rpx;
background: #FFEDE9;
border-radius: 6rpx;
color: #FF4B33;
font-size: 22rpx;
margin-left: 12rpx;
text-align: center;
}
}
.info-desc {
color: #999999;
font-size: 24rpx;
max-height: 60rpx;
line-height: 30rpx;
-webkit-line-clamp: 2;
text-overflow: ellipsis;
display: -webkit-box;
-webkit-box-orient: vertical;
}
}
}
.mulu {
background: #ffffff;
width: 690rpx;
margin: 0 auto;
}
.thematic-details .catalogue {
background: #ffffff !important;
}
.thematic-details .swiper-details .swiper {
background-color: #ffffff;
// border-radius: 40rpx 40rpx 0 0;
// position: relative;
margin: 22rpx auto 0;
width: 690rpx;
}
.thematic-details .swiper-details .swiper .validity {
padding-left: 30rpx;
background: url(getAssetsPath("/wap/first/zsff/images/validity.png")) center/cover no-repeat;
font-size: 26rpx;
border-radius: 40rpx 40rpx 0 0;
line-height: 80rpx;
color: #ff6b00;
}
.thematic-details .swiper-details .swiper .name {
-webkit-line-clamp: 2;
overflow: hidden;
}
.thematic-details .follow {
position: fixed;
top: 0;
left: 0;
z-index: 11;
width: 100%;
height: 80rpx;
padding-right: 30rpx;
padding-left: 30rpx;
background-color: rgba(0, 0, 0, 0.32);
font-size: 26rpx;
color: #ffffff;
}
.thematic-details .follow .picTxt .pictrue {
width: 85rpx;
height: 85rpx;
}
.thematic-details .follow .picTxt .pictrue image {
width: 100%;
height: 100%;
border-radius: 15rpx;
}
.thematic-details .follow .picTxt .text {
width: 365rpx;
font-size: 28rpx;
color: #509efb;
}
.thematic-details .follow .picTxt .text .name {
font-weight: bold;
}
.thematic-details .follow .followBnt {
display: inline-block;
width: 160rpx;
height: 50rpx;
border-radius: 25rpx;
background-color: #2c8eff;
vertical-align: middle;
font-size: 24rpx;
line-height: 50rpx;
text-align: center;
color: #ffffff;
}
.thematic-details .follow .iconguanbi2 {
margin-left: 24rpx;
vertical-align: middle;
font-size: 30rpx;
}
.thematic-details .swiper-details .swiper .swiper-int .pin-money {
flex: 1;
}
.thematic-details .swiper-details .swiper .swiper-int .pin-money .price {
display: inline-block;
font-weight: bold;
font-size: 22rpx;
color: #ff6b00;
}
.thematic-details .swiper-details .swiper .swiper-int .pin-money .price text {
font-weight: bold;
font-size: 32rpx;
line-height: 25rpx;
}
.thematic-details .swiper-details .swiper .swiper-int .pin-money .vip-price {
font-size: 24rpx;
color: #282828;
}
.thematic-details .swiper-details .swiper .swiper-int .pin-money .vip-price+.vip-price-icon {
vertical-align: inherit;
}
.swiper-details .swiper .swiper-int .collect {
align-items: center;
}
.swiper-details .swiper .swiper-int .collect .iconfont.iconshoucang2 {
color: #ff6b00 !important;
}
.swiper-details .swiper .swiper-int .collect .iconfont {
font-weight: 600;
color: #23272E !important;
font-size: 36rpx;
image {
width: 36rpx;
height: 36rpx;
}
}
.thematic-details .swiper-details .swiper .swiper-int .pin-money .total {
margin-left: 10rpx;
font-size: 26rpx;
color: #999999;
}
.thematic-details .swiper-details .pinTip {
height: 70rpx;
padding-left: 33rpx;
font-size: 26rpx;
line-height: 70rpx;
}
.thematic-details .pinTip2 {
height: 70rpx;
padding-right: 30rpx;
padding-left: 30rpx;
border-radius: 12rpx;
margin: 14rpx 20rpx;
background-color: #e2efff;
}
.thematic-details .pinTip2 .chatBnt {
width: 136rpx;
height: 46rpx;
border: 1px solid #3895ff;
border-radius: 23rpx;
background-color: #2c8eff;
font-size: 24rpx;
line-height: 42rpx;
text-align: center;
color: #f5f5f5;
cursor: pointer;
}
.thematic-details .pinTip2 .reminder {
font-size: 26rpx;
color: #2c8dff;
}
.thematic-details .swiper-details .list {
padding-left: 30rpx;
background-color: #ffffff;
}
.thematic-details .swiper-details .list .item {
padding-top: 25rpx;
padding-right: 30rpx;
padding-bottom: 25rpx;
}
.thematic-details .swiper-details .list .item .item {
border-top: 1px solid #f0f0f0;
}
.thematic-details .swiper-details .list .item .pictrue {
width: 80rpx;
height: 80rpx;
border-radius: 50%;
margin-right: 20rpx;
overflow: hidden;
}
.thematic-details .swiper-details .list .item .pictrue image {
display: block;
width: 100%;
height: 100%;
object-fit: cover;
}
.thematic-details .swiper-details .list .item .name {
flex: 1;
min-width: 0;
}
.thematic-details .swiper-details .list .item .left {
width: 210rpx;
font-size: 24rpx;
line-height: 34rpx;
text-align: center;
}
.thematic-details .swiper-details .list .item .link {
width: 140rpx;
height: 50rpx;
border-radius: 25rpx;
background: linear-gradient(90deg, #409dff 0%, #1e85fb 100%);
font-size: 24rpx;
line-height: 50rpx;
text-align: center;
color: #ffffff;
}
.thematic-details .swiper-details .list .item .link .iconfont {
margin-left: 11rpx;
font-size: 18rpx;
}
.thematic-details .swiper-details .list .item .left text {
color: #feb720;
}
.thematic-details .swiper-details .list .item .left .time {
line-height: 30rpx;
color: #82848f;
}
.thematic-details .groupCode {
width: 640rpx;
height: 574rpx;
background-color: #ffffff;
border-radius: 24rpx;
position: fixed;
left: 50%;
top: 50%;
z-index: 99;
transform: translate(-50%, -50%);
}
.thematic-details .groupCode .code {
width: 310rpx;
height: 310rpx;
margin: 70rpx auto 0 auto;
}
.thematic-details .groupCode .code image {
width: 100%;
height: 100%;
}
.thematic-details .groupCode .codeTip {
text-align: center;
margin-top: 40rpx;
font-size: 37rpx;
color: #333;
}
/* 专题目录 */
.thematic-details .special-tip {
display: inline-block;
height: 50rpx;
padding: 0 22rpx;
border: 1px solid #2c8eff;
border-radius: 25rpx 25rpx 25rpx 0;
margin-top: 30rpx;
margin-left: 30rpx;
font-size: 24rpx;
line-height: 50rpx;
color: #2c8eff;
}
.thematic-details .catalogue {
background-color: #f9fafc;
}
.thematic-details .catalogue>view {
position: relative;
display: flex;
align-items: center;
height: 152rpx;
}
.thematic-details .catalogue>view::before {
content: "";
position: absolute;
top: 0;
right: 0;
left: 91rpx;
border-top: 1px solid #f5f5f5;
}
.thematic-details .catalogue>view:first-child::before {
display: none;
}
.thematic-details .catalogue image {
display: block;
width: 38rpx;
height: 27rpx;
margin: 0 33rpx 0 20rpx;
}
.thematic-details .catalogue .text {
flex: 1;
min-width: 0;
}
.thematic-details .catalogue .title {
overflow: hidden;
white-space: nowrap;
text-overflow: ellipsis;
font-size: 28rpx;
line-height: 40rpx;
color: #333333;
}
.thematic-details .catalogue .try-progress {
font-size: 0;
}
.thematic-details .catalogue .try,
.thematic-details .catalogue .progress {
display: inline-block;
padding: 0 7rpx;
border: 1px solid transparent;
border-radius: 3rpx;
margin-top: 15rpx;
font-size: 18rpx;
line-height: 33rpx;
height: 33rpx;
}
.thematic-details .catalogue .try {
border-color: #2c8eff;
color: #2c8eff;
}
.thematic-details .catalogue .progress {
padding-left: 9rpx;
border-color: #fff0e5;
background-color: #FF9500;
color: #fff;
}
.thematic-details .catalogue .progress.no {
border-color: #FFC067;
background-color: #fff;
color: #FFBF66;
}
.thematic-details .catalogue .try+.progress {
margin-left: 15rpx;
}
.thematic-details .catalogue .status {
width: 130rpx;
font-size: 0;
text-align: center;
}
.thematic-details .catalogue .free {
display: inline-block;
width: 90rpx;
height: 40rpx;
border-radius: 20rpx;
background-color: #fff0e5;
font-size: 22rpx;
line-height: 40rpx;
text-align: center;
color: #ff6b00;
}
.thematic-details .catalogue .iconfont {
font-size: 34rpx;
color: #cccccc;
}
.problem-section,
.question-section,
.evaluate-section {
width: 690rpx;
margin: 0 auto;
}
/* 专题练习题 */
.thematic-details .problem-section .problem-list {
padding: 30rpx;
background-color: #ffffff;
}
.thematic-details .problem-section .item {
padding: 30rpx 30rpx 32rpx;
border-radius: 12rpx;
box-shadow: 0 3rpx 20rpx rgba(0, 0, 0, 0.07);
}
.thematic-details .problem-section .item+.item {
margin-top: 30rpx;
}
.thematic-details .problem-section .title {
overflow: hidden;
white-space: nowrap;
text-overflow: ellipsis;
font-size: 30rpx;
color: #282828;
}
.thematic-details .problem-section .title.lock {
padding-left: 43rpx;
background: url(getAssetsPath("/wap/first/zsff/images/question06.png")) left center/23rpx 30rpx no-repeat;
}
.thematic-details .problem-section .group {
display: flex;
align-items: center;
margin-top: 30rpx;
}
.thematic-details .problem-section .progress {
width: 160rpx;
height: 12rpx;
border-radius: 6rpx;
background-color: #eee;
}
.thematic-details .problem-section .progress view {
width: 50%;
height: 100%;
border-radius: 6rpx;
background-color: #2c8eff;
}
.thematic-details .problem-section .people {
flex: 1;
margin-left: 10rpx;
font-size: 22rpx;
color: #999999;
}
.thematic-details .problem-section .people text {
display: inline-block;
width: 98rpx;
}
.thematic-details .problem-section .exercise-btn {
width: 120rpx;
height: 42rpx;
border-radius: 21rpx;
background-color: #2c8eff;
font-size: 22rpx;
line-height: 42rpx;
text-align: center;
color: #ffffff;
image {
width: 18rpx;
margin-right: 10rpx;
pointer-events: none;
-webkit-touch-callout: none;
}
}
.thematic-details .question-section .list {
padding: 30rpx;
background-color: #ffffff;
}
.thematic-details .question-section .item {
display: flex;
padding: 30rpx 30rpx 36rpx;
border-radius: 12rpx;
box-shadow: 0 3rpx 20rpx rgba(0, 0, 0, 0.07);
cursor: pointer;
}
.thematic-details .question-section .item+.item {
margin-top: 30rpx;
}
.thematic-details .question-section .item>view>image {
display: block;
width: 240rpx;
height: 135rpx;
border-radius: 10rpx;
object-fit: cover;
-webkit-touch-callout: none;
pointer-events: none;
}
.thematic-details .question-section .text {
flex: 1;
display: flex;
flex-direction: column;
justify-content: space-between;
margin-left: 20rpx;
}
.thematic-details .question-section .item>view:last-child {
flex: 1;
display: flex;
flex-direction: column;
justify-content: space-between;
margin-left: 20rpx;
}
.thematic-details .question-section .item>view>view:first-child {
-webkit-line-clamp: 2;
overflow: hidden;
font-size: 30rpx;
color: #333;
}
.thematic-details .question-section .item>view>view:last-child {
display: flex;
justify-content: space-between;
align-items: center;
font-size: 22rpx;
color: #ff6b00;
}
.thematic-details .question-section .lock {
display: block;
width: 24rpx;
height: 30rpx;
-webkit-touch-callout: none;
pointer-events: none;
}
.thematic-details .question-section .btn {
width: 120rpx;
height: 42rpx;
border-radius: 21rpx;
background-color: #2c8eff;
font-size: 22rpx;
line-height: 42rpx;
text-align: center;
color: #ffffff;
}
.thematic-details .question-section .btn image {
width: 17rpx;
height: 19rpx;
margin-right: 10rpx;
-webkit-touch-callout: none;
pointer-events: none;
}
.thematic-details .finished,
.thematic-details .loading {
font-size: 28rpx;
line-height: 100rpx;
text-align: center;
color: #bbb;
}
.thematic-details .fa-spin {
animation: fa-spin 1s infinite linear;
}
.thematic-details .empty {
padding-top: 50rpx;
padding-bottom: 50rpx;
background-color: #ffffff;
font-size: 28rpx;
text-align: center;
color: #bbb;
}
.thematic-details .empty image {
display: block;
width: 414rpx;
height: 305rpx;
margin: 0 auto;
}
.txp1 {
padding: 25rpx 30rpx 0;
font-size: 32rpx;
line-height: 50rpx;
color: #333333;
display: -webkit-box;
-webkit-box-orient: vertical;
-webkit-line-clamp: 2;
overflow: hidden;
}
.exchange-guide {
position: fixed;
top: 50%;
right: 0;
display: -webkit-box;
display: -webkit-flex;
display: -ms-flexbox;
display: flex;
-webkit-box-align: center;
-webkit-align-items: center;
-ms-flex-align: center;
align-items: center;
height: 62rpx;
padding-right: 21rpx;
padding-left: 28rpx;
border-top-left-radius: 31rpx;
border-bottom-left-radius: 31rpx;
background-color: #2c8eff;
-webkit-box-shadow: 0 2rpx 10rpx rgba(76, 146, 226, 0.25);
box-shadow: 0 2rpx 1rpx rgba(76, 146, 226, 0.25);
font-size: 30rpx;
line-height: normal;
color: #ffffff;
}
.poster-canvas2 {
width: 1200rpx;
height: 1700rpx;
}
.im{
color: #666;
border:none;
}
.im::after{
border:none;
}
</style>