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_php/application/wap/view/first/special/single_details.html

1406 lines
62 KiB

11 months ago
<!-- +---------------------------------------------------------------------- -->
<!-- | 天诚科技 [ 刘海东 17600099397赋能开发者,助力企业发展 ] -->
<!-- +---------------------------------------------------------------------- -->
<!-- | Copyright (c) 2016~2022 https://www.crmeb.com All rights reserved. -->
<!-- +---------------------------------------------------------------------- -->
<!-- | Licensed 该系统并不是自由软件,未经许可不能去掉相关版权 -->
<!-- +---------------------------------------------------------------------- -->
<!-- | Author:甘肃天诚志信电子商务有限公司 刘海东 联系电话维系17600099397 -->
<!-- +---------------------------------------------------------------------- -->
{extend name="public/container"}
{block name="title"}{$title}{/block}
{block name="head_top"}
<link rel="stylesheet" href="{__PLUG_PATH}vue-photo-preview/skin.css">
<script src="{__PLUG_PATH}vue-photo-preview/vue-photo-preview.js"></script>
<style>
body {
padding-bottom: 1rem;
padding-bottom: calc(1rem + constant(safe-area-inset-bottom));
padding-bottom: calc(1rem + env(safe-area-inset-bottom));
background-color: #f5f5f5;
}
.validity {
padding-left: 0.3rem;
background: url("{__WAP_PATH}zsff/images/validity.png") center/cover no-repeat;
font-size: .26rem;
line-height: .8rem;
color: #FF6B00;
}
a[href^="tel"] {
color: #2C8EFF;
}
</style>
{/block}
{block name="content"}
<div v-cloak id="app">
<div class="single-special">
<!-- 播放器 -->
<div class="header" :style="{ height: playerHeight + 'px' }">
<img :src="special.image" alt="封面">
</div>
<div v-if="special_validity == -1" class="validity">
<template v-if="special.validity">课程有效期为{{ special.validity }}天,过期后需重新购买哦!</template>
<template v-else>课程永久有效哦!</template>
</div>
<div v-else-if="special_validity == 0" class="validity">课程永久有效哦!</div>
<div v-else-if="special_validity > 0" class="validity">课程有效期剩余{{ special_validity | formatValidity }},过期后需重新购买哦!</div>
<div class="special-attr">
<div class="title">{{ special.title }}</div>
<div class="label">
<div v-for="(item, index) in special.label" :key="index">{{ item }}</div>
</div>
<div class="money-button">
<div class="money">
<template v-if="special.pay_type">
<div><span></span>{{ special.money }}</div>
<div>¥{{ special.member_money }}</div>
</template>
<div v-else>免费</div>
</div>
<button type="button" @click="createSharePoster">
<i class="iconfont iconfenxiang"></i>
<div>分享</div>
</button>
<button type="button" @click="collect">
<i :class="['iconfont', special.collect ? 'iconshoucang2' : 'iconshoucang11']"></i>
<div>{{ special.collect ? '已收藏' : '收藏' }}</div>
</button>
</div>
</div>
<!-- 群聊 -->
<template v-if="special.service_code">
<div class="group-chat">
<div>和小伙伴一起学习,有老师答疑哦~</div>
<button type="button" @click="groupChartShow = true">加入群聊</button>
</div>
</template>
<!-- 学习人数、讲师 -->
<div class="learner-teacher">
<div v-if="record.length" class="learner">
<div>
<img v-for="(item, index) in record" :key="index" :src="item.avatar" alt="">
</div>
已有{{ recordCoujnt }}人学习
</div>
<a v-if="lecturer" class="teacher" :href="'{:url('merchant/teacher_detail')}?id=' + special.lecturer_id">
<div>
<img :src="lecturer.lecturer_head" :alt="lecturer.lecturer_name">
</div>
<div>
<div>{{ lecturer.lecturer_name }}</div>
<div v-if="lecturer.label.length" class="label">
<div v-for="(item, index) in lecturer.label" :key="index">{{ item }}</div>
</div>
</div>
<i class="iconfont iconxiangyou"></i>
</a>
</div>
<!-- 关联资料 -->
<div v-if="specialDownload.length" class="material">
<a v-for="item in specialDownload" :key="item.id" :href="'{:url('special/data_details')}?id=' + item.id">
<div>
<img :src="item.image" alt="">
</div>
<div>
<div>{{ item.title }}</div>
<div v-if="item.pay_type" class="money"><span>{{ item.money }}</span></div>
<div v-else>免费</div>
<div>
<div>{{ item.ficti + item.sales }}人已下载</div>
<button type="button">去下载</button>
</div>
</div>
</a>
</div>
<!-- 拼团人数 -->
<div v-if="special.is_pink" class="group-buy">
<div v-if="specialGroupLists.length" class="marquee">
<i class="iconfont iconshengyinyinliang"></i>
<div>已拼{{ specialGroupLists.length }}件</div>
<div class="swiper-container">
<div class="swiper-wrapper">
<div v-for="(item, index) in specialGroupLists" :key="index" class="swiper-slide">{{ item.nickname }}拼团成功</div>
</div>
</div>
</div>
<ul v-if="specialPinkLists.length">
<li v-for="(item, index) in specialPinkLists" :key="index">
<div>
<img :src="item.avatar" alt="">
</div>
<div>{{ item.nickname }}</div>
<div>
<div>还差<span>{{ item.num }}人</span>成团</div>
<div>剩余 {{ item.duration | format }}</div>
</div>
<button type="button" @click="goPink(item.id, item.uid)">去拼单</button>
</li>
</ul>
</div>
<!-- 拼团玩法 -->
<div v-if="special.is_pink" class="group-way">
<div>拼团玩法</div>
<ul>
<li>开团/参团</li>
<li>邀请好友</li>
<li>满员发货</li>
</ul>
</div>
<!-- 导航 -->
<ul class="tabbar">
<li :class="{ on: tabActive === 1}" @click="tabActive = 1">详情</li>
<li v-if="specialTest1.length" :class="{ on: tabActive === 2}" @click="tabActive = 2">练习</li>
<li v-if="specialTest2.length" :class="{ on: tabActive === 3}" @click="tabActive = 3">考试</li>
<li v-if="comment_switch" :class="{ on: tabActive === 4}" @click="tabActive = 4">评价({{ whole }})</li>
</ul>
<!-- 详情 -->
<div v-show="tabActive === 1" class="detail" v-html="special.abstract"></div>
<!-- 练习 -->
<ul v-if="specialTest1.length" v-show="tabActive === 2" class="exercise">
<li v-for="item in specialTest1" :key="item.id">
<div class="title"><i v-if="!isPay" class="iconfont iconsuozi"></i>{{ item.title }}</div>
<div class="group">
<div class="progress">
<div :style="{ width: item.rate + '%' }"></div>
</div>
<div>{{ item.rate }}%</div>
<div>{{ item.answer }}人已答题</div>
<button type="button" @click="goQuestion(item)"><i class="iconfont icon-19-lianxi"></i>练习</button>
</div>
</li>
</ul>
<!-- 考试 -->
<ul v-if="specialTest2.length" v-show="tabActive === 3" class="question">
<li v-for="item in specialTest2" :key="item.id">
<div class="head">
<div>
<img :src="item.image" alt="">
</div>
<div>
<div class="title">{{ item.title }}</div>
<div class="group">
<div>共{{ item.item_number }}题</div>
<button v-if="isPay" type="button" @click="goQuestion(item)"><i class="iconfont icon-19-lianxi"></i>答题
</button>
<div v-else>
<i class="iconfont iconsuozi"></i>
</div>
</div>
</div>
</div>
</li>
</ul>
<!-- 评价 -->
<div v-show="tabActive === 4" class="evaluate">
<div>
<div class="score">
<div><span>{{ score }}</span></div>
<div>课程评分</div>
</div>
<button type="button" @click="userEvaluate">我要评价</button>
</div>
<evaluate-list :evaluate-list="replyList"></evaluate-list>
<div v-if="evaluateLoading" class="loading">
<i class="fa fa-spinner fa-spin"></i>
</div>
<div v-if="evaluateFinished && replyList.length" class="finished">已全部加载完</div>
<div v-if="evaluateFinished && !replyList.length" class="empty">
<img src="{__WAP_PATH}zsff/images/empty.png" alt="暂无评价">
<div>暂无评价</div>
</div>
</div>
<!-- 底部按钮 -->
<div class="footer">
<button type="button" @click="goHome">
<img src="{__WAP_PATH}zsff/images/special01.png" alt="首页">
<div>首页</div>
</button>
<button type="button" @click="customerService">
<img src="{__WAP_PATH}zsff/images/special02.png" alt="客服">
<div>客服</div>
</button>
<button type="button" @click="buy(1)">
<img src="{__WAP_PATH}zsff/images/special03.png" alt="送朋友">
<div>送朋友</div>
</button>
<div>
<button v-if="gift" type="button" @click="buy(4)">领取课程</button>
<template v-else>
<button v-if="isPay || (!special.member_pay_type && is_member)" type="button" @click="buy(5)">{{
special.pay_type || special.member_pay_type ? '去学习' : '免费学习' }}
</button>
<template v-else>
<button v-if="special.profile.is_try" @click="handleTry">试{{ special.light_type === 2 ? '听' : '看' }}</button>
<template v-if="special.is_pink">
<button v-if="isPink" type="button">查看拼团</button>
<template>
<button type="button" @click="buy(3)">
¥{{ special.pink_money }}
<div>{{ special.pink_number }}人团</div>
</button>
<button type="button" @click="buy(2)">
¥{{ is_member ? special.member_money : special.money }}
<div>单独购</div>
</button>
</template>
</template>
<button v-else type="button" @click="buy(2)">立即购买</button>
</template>
</template>
</div>
</div>
<!-- 遮罩层 -->
<div :class="{ mask: payDialogOpen || shareShow || groupChartShow || dialogShow || certificateImage }" @touchmove.prevent @click="maskClick">
</div>
<!-- 支付弹窗 -->
<pay-dialog :open.sync="payDialogOpen" :money="money" :now_money="now_money" :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" :template-id="templateIds" :wxpay-h5="wxpayH5" :is-member="is_member"
:member-money="special.member_money" :member-link="memberLink" @change="changeVal">
</pay-dialog>
<!-- 分享海报 -->
<img v-show="shareImage && shareShow" class="share-dialog" :src="shareImage" alt="">
<!-- 加入群聊 -->
<div v-show="groupChartShow" class="group-chart-dialog">
<img :src="special.service_code" alt="">
<div>
<div>长按扫码</div>
<div>加客服好友进群</div>
</div>
</div>
<!-- 登录弹窗 -->
<base-login :login-show="loginShow" :site-name="site_name" @login-close="loginClose"></base-login>
<!-- 评价弹窗 -->
<evaluate-dialog :dialog-show="dialogShow" :rate-value="rateValue" :image-list="imageList" @rate-change="rateChange" @image-upload="imageUpload" @image-delete="imageDelete"
@evaluate-submit="evaluateSubmit"></evaluate-dialog>
<!-- 兑换码 -->
<exchange-guide v-if="isBatch && !isPay" :href="'{:url('special/exchange')}?special_id=' + special.id"></exchange-guide>
<!-- 完课证书 -->
<img :src="certificateImage" class="certificate-image" alt="">
<!-- 弹幕 -->
<div v-if="barrageList.length" class="barrage">
<div>
<img :src="barrageList[barrage_index].avatar" alt="">
</div>
<div>{{ barrageList[barrage_index].nickname }} {{ barrageList[barrage_index].status_name }}</div>
</div>
</div>
<!-- 分享返佣 -->
<rebate-guide v-if="rebateMoney" :rebate-money="rebateMoney" @rebate-action="rebateAction"></rebate-guide>
</div>
{/block}
{block name="foot"}
<script>
window.overallShare = false;
require([
'vue',
'axios',
'helper',
'store',
'swiper',
'components/pay-dialog/index',
'moment',
'components/evaluate-list/index',
'components/evaluate-dialog/index',
'components/exchange-guide/index',
'components/base-login/index',
'components/rebate-guide/index',
'aliplayer',
'qrcode',
'layer'
], function (Vue, axios, $h, store, Swiper, PayDialog, moment, EvaluateList, EvaluateDialog, ExchangeGuide, BaseLogin, RebateGuide) {
var special = {$special};
var site_url = "{$site_url}";
var site_name = "{$Auth_site_name}";
var now_money = {$now_money};
var link_pay_uid = {$link_pay_uid};
var pinkId = {$pinkId};
var isWechat = {$isWechat? 'true': 'false'};
var is_alipay = {$is_alipay? 'true': 'false'};
var is_yue = {$is_yue? 'true': 'false'};
var wxpayH5 = {$is_h5_wechat_payment_switch? 'true': 'false'};
var isPay = {$isPay? 'true': 'false'};
var is_member = {$is_member};
var orderId = '{$orderId ? $orderId : ""}';
var gift = {$gift};
var isBatch = {$isBatch? 'true': 'false'};
var uid = {$userInfo['uid']? $userInfo['uid'] : 0};
var isPink = {$isPink? 'true': 'false'};
var BarrageShowTime = {$BarrageShowTime? $BarrageShowTime: 5};
var barrage_index = {$barrage_index? $barrage_index: 0};
var callback_url = '{$callback_url}';
var options = {
captionEl: false,
fullscreenEl: false,
zoomEl: false,
arrowEl: false
};
var comment_switch = {$comment_switch};
var memberLink = "{:url('special/member_recharge')}";
Vue.use(vuePhotoPreview, options);
new Vue({
el: '#app',
components: {
'pay-dialog': PayDialog,
'evaluate-list': EvaluateList,
'evaluate-dialog': EvaluateDialog,
'exchange-guide': ExchangeGuide,
'base-login': BaseLogin,
'rebate-guide': RebateGuide
},
filters: {
format: function (time, sibling) {
var duration = moment.duration(time * 1000);
var hours = duration.hours();
var siblingHours = sibling ? moment.duration(sibling * 1000).hours() : 0;
return moment({
h: hours,
m: duration.minutes(),
s: duration.seconds()
}).format((hours || siblingHours ? 'HH:' : '') + 'mm:ss');
},
formatValidity: function (time) {
var duration = moment.duration(Number(time), 'seconds');
var days = Math.floor(duration.asDays());
var hours = duration.hours();
var minutes = duration.minutes();
return (days ? days + '天' : '') + (hours ? hours + '小时' : '') + minutes + '分钟';
}
},
data: {
special: special,
site_url: site_url,
site_name: site_name,
isPay: isPay,
is_member: is_member,
gift: gift,
isBatch: isBatch,
uid: uid,
isPink: isPink,
barrageShowTime: BarrageShowTime,
barrage_index: barrage_index,
barrageList: [],
record: [], // 学习人员
recordCoujnt: '', // 学习人数
lecturer: null,
specialGroupLists: [], // 拼团信息
specialPinkLists: [], // 拼团人员
tabActive: 1,
specialTest1: [], // 关联练习
specialTest2: [], // 关联考试
evaluatePage: 1,
evaluateLimit: 16,
replyList: [], // 评价列表
payDialogOpen: false, // 是否显示支付弹窗
money: 0,
now_money: now_money,
link_pay_uid: 0,
pay_type_num: -1,
pinkId: pinkId,
isWechat: isWechat,
is_alipay: is_alipay,
is_yue: is_yue,
templateIds: '', // 订阅模板id
wxpayH5: wxpayH5,
shareImage: '',
shareShow: false,
groupChartShow: false,
loginShow: false,
url: isWechat ? $h.U({c: 'index', a: 'login'}) : $h.U({c: 'login', a: 'phone_check'}),
score: 0,
whole: 0,
dialogShow: false,
rateValue: 5,
imageList: [],
orderId: orderId,
evaluateLoading: false,
evaluateFinished: false,
playerHeight: 0,
currentTime: 0,
duration: 0,
paused: true,
certificateImage: '',
specialDownload: [], // 关联资料
isLogin: false, // 是否登录
comment_switch: comment_switch,
special_validity: -1,
tryShow: true,
seeked: false,
rebateMoney: 0,
memberLink: memberLink
},
computed: {
range: function () {
return Math.ceil(this.currentTime / this.duration * 100);
}
},
watch: {
paused: function (paused) {
paused ? this.player.pause() : this.player.play();
}
},
created: function () {
var vm = this;
this.playerHeight = Math.floor(window.innerWidth * 9 / 16);
this.learningRecords();
this.lecturerDetails();
this.addLearningRecords();
this.specialDataDownload();
this.specialTestPaper(1);
this.specialTestPaper(2);
this.inspect();
this.rebateAmount();
if (this.special.is_pink) {
this.groupLists();
this.pinkIngLists();
this.getBarrageList();
}
if (comment_switch) {
this.specialReplyData();
this.specialReplyList();
}
if (this.isWechat) {
this.getTemplateIds();
mapleWx($jssdk(), function () {
this.onMenuShareAll({
title: vm.special.title,
desc: vm.special.title,
imgUrl: vm.special.image,
link: location.href + (location.search ? '&' : '?') + 'spread_uid=' + uid,
});
});
}
store.baseGet($h.U({
c: 'special',
a: 'special_validity',
q: {
id: this.special.id
}
}), function (res) {
vm.special_validity = res.data.data.validity;
}, false, true);
},
mounted: function () {
var vm = this;
this.$nextTick(function () {
$h.EventUtil.listenTouchDirection(document, function () {
if (vm.tabActive === 4) {
vm.specialReplyList();
}
});
});
},
methods: {
goTry: function () {
window.location.assign("{:url('special/single_text_detail')}?try=1&id=" + this.special.id);
},
// 学习人数
learningRecords: function () {
var vm = this;
$h.loadFFF();
store.baseGet($h.U({
c: 'special',
a: 'learningRecords',
q: {
id: this.special.id
}
}), function (res) {
var data = res.data.data;
$h.loadClear();
vm.record = data.record;
vm.recordCoujnt = data.recordCoujnt;
}, function () {
$h.loadClear();
});
},
// 讲师信息
lecturerDetails: function () {
var vm = this;
$h.loadFFF();
store.baseGet($h.U({
c: 'auth_api',
a: 'getLecturer',
q: {
mer_id: this.special.mer_id
}
}), function (res) {
$h.loadClear();
vm.lecturer = res.data.data;
}, function () {
$h.loadClear();
});
},
// 拼团消息
groupLists: function () {
var vm = this;
$h.loadFFF();
store.baseGet($h.U({
c: 'special',
a: 'groupLists',
q: {
special_id: this.special.id
}
}), function (res) {
$h.loadClear();
vm.specialGroupLists = res.data.data;
vm.$nextTick(function () {
new Swiper('.swiper-container', {
direction: 'vertical',
autoplay: true,
loop: true
});
});
}, function () {
$h.loadClear();
});
},
// 拼团列表
pinkIngLists: function () {
var vm = this;
$h.loadFFF();
store.baseGet($h.U({
c: 'special',
a: 'pinkIngLists',
q: {
id: this.special.id,
pinkId: 0
}
}), function (res) {
var data = res.data.data;
$h.loadClear();
data.forEach(function (item) {
item.duration = 0;
item.stop_time = item.stop_time * 1000;
});
vm.specialPinkLists = data;
}, function () {
$h.loadClear();
});
},
// 练习、考试
specialTestPaper: function (type) {
var vm = this;
$h.loadFFF();
store.basePost($h.U({
c: 'topic',
a: 'specialTestPaper'
}), {
special_id: this.special.id,
type: type
}, function (res) {
var data = res.data.data;
$h.loadClear();
if (type === 1) {
data.forEach(function (item) {
item.rate = Math.floor(item.done / item.item_number * 100);
});
}
vm['specialTest' + type] = data;
}, function () {
$h.loadClear();
});
},
// 评价状态
specialReplyData: function () {
var vm = this;
$h.loadFFF();
store.baseGet($h.U({
c: 'special',
a: 'special_reply_data',
q: {
special_id: this.special.id
}
}), function (res) {
var data = res.data.data;
$h.loadClear();
vm.score = data.score;
vm.whole = data.whole;
}, function () {
$h.loadClear();
});
},
// 评价列表
specialReplyList: function () {
var vm = this;
if (this.evaluateLoading || this.evaluateFinished) {
return;
}
this.evaluateLoading = true;
$h.loadFFF();
store.baseGet($h.U({
c: 'special',
a: 'special_reply_list',
q: {
special_id: this.special.id,
page: this.evaluatePage++,
limit: this.evaluateLimit
}
}), function (res) {
var data = res.data.data;
vm.evaluateLoading = false;
$h.loadClear();
vm.replyList = vm.replyList.concat(data);
vm.evaluateFinished = vm.evaluateLimit > data.length;
}, function () {
vm.evaluateLoading = false;
$h.loadClear();
});
},
// 生成分享海报
createSharePoster: function () {
var vm = this;
if (this.shareImage) {
return this.shareShow = true;
}
Promise.all([
new Promise(function (resolve, reject) {
var image = new Image();
image.crossOrigin = 'anonymous';
image.src = vm.special.poster_image + '?' + new Date().getTime();
image.onload = function () {
resolve(image);
};
image.onerror = function () {
reject('error-image');
};
}),
new Promise(function (resolve, reject) {
resolve(new QRCode(document.createElement('canvas'), vm.site_url));
})
]).then(function (sources) {
var canvas = document.createElement('canvas');
var context = canvas.getContext('2d');
canvas.width = 600;
canvas.height = 960;
context.fillStyle = '#FFFFFF';
context.fillRect(0, 0, canvas.width, canvas.height);
context.drawImage(sources[0], 0, 0, 600, 740);
context.drawImage(sources[1]._el.firstElementChild, 108, 775, 150, 150);
context.font = '22px sans-serif';
context.fillStyle = '#999999';
context.textBaseline = 'top';
var text = '邀您加入' + site_name;
var list = [];
var start = 0;
for (var i = 0; i <= text.length; i++) {
if (context.measureText(text.slice(start, i)).width > 198) {
list.push(text.slice(start, i - 1));
start = i - 1;
}
}
if (start !== text.length) {
list.push(text.slice(start));
}
if (list.length > 3) {
list.length = 3;
for (var j = 0; j <= list[2].length; j++) {
if (context.measureText(list[2].slice(0, j) + '……').width > 198) {
list[2] = list[2].slice(0, j - 1) + '……';
break;
}
}
}
list.push('长按识别或扫码进入');
for (var k = 0; k < list.length; k++) {
context.fillText(list[k], 294, 775 + (150 / list.length) * k);
}
vm.shareImage = canvas.toDataURL('image/jpeg');
vm.shareShow = true;
canvas = null;
}).catch(function (error) {
$h.pushMsg(error);
});
},
// 收藏、取消收藏
collect: function () {
var vm = this;
$h.loadFFF();
store.baseGet("{:url('index/login_user')}", function (res) {
$h.loadClear();
store.baseGet("{:url('special/collect')}?id=" + vm.special.id, function () {
vm.special.collect = !vm.special.collect;
$h.pushMsg(vm.special.collect ? '收藏成功' : '取消收藏成功');
});
}, function () {
$h.loadClear();
if (isWechat) {
window.localStorage.setItem('login_back_url', window.location.href);
window.location.assign("{:url('login/index')}");
} else {
vm.loginShow = true;
}
}, true);
},
changeVal: function (opt) {
if (typeof opt !== 'object') {
opt = {};
}
var action = opt.action || '';
var value = opt.value || '';
this[action] && this[action](value);
},
// 点击遮罩层
maskClick: function () {
this.shareShow = false;
this.groupChartShow = false;
this.dialogShow = false;
this.certificateImage = '';
},
// 关闭登录
loginClose: function (value) {
this.loginShow = false;
value && this.logComplete();
},
// 登录完成回调事件
logComplete: function () {
var vm = this;
this.isLogin = true;
store.baseGet($h.U({
c: 'special',
a: 'isMember'
}), function (res) {
var data = res.data.data;
vm.is_member = data.is_member;
vm.now_money = data.now_money;
});
store.baseGet($h.U({
c: 'special',
a: 'special_validity',
q: {
id: special.id
}
}), function (res) {
vm.special_validity = res.data.data.validity;
}, false, true);
},
// 立即购买
buy: function (type) {
var vm = this;
this.pay_type_num = type;
store.baseGet("{:url('index/login_user')}", function () {
if (isWechat) {
store.baseGet("{:url('index/user_login')}", function () {
switch (type) {
case 1:
if (!this.special.pay_type) {
return $h.pushMsg('免费的不可以赠送哦');
}
if (this.is_member && !this.special.member_pay_type) {
return $h.pushMsg('会员价免费的不可以赠送哦');
}
this.money = this.special.money;
this.payDialogOpen = true;
break;
case 2:
vm.money = vm.is_member ? vm.special.member_money : vm.special.money;
vm.payDialogOpen = true;
break;
case 3:
this.money = this.special.pink_money;
this.payDialogOpen = true;
break;
case 4:
$h.loadFFF();
store.baseGet($h.U({
c: 'special',
a: 'receive_gift',
q: {
orderId: this.orderId
}
}), function (res) {
$h.loadClear();
$h.pushMsg(res.data.msg, function () {
window.location.assign("{:url('special/grade_special')}");
});
}, function () {
$h.loadClear();
});
break;
case 5:
if (vm.special.light_type === 1) {
window.location.assign("{:url('special/single_text_detail')}?try=0&id=" + vm.special.id);
} else {
window.location.assign("{:url('special/single_con_detail')}?try=0&id=" + vm.special.id);
}
break;
default:
break;
}
}, function () {
vm.loginShow = true;
}, true);
} else {
switch (type) {
case 1:
if (!this.special.pay_type) {
return $h.pushMsg('免费的不可以赠送哦');
}
if (this.is_member && !this.special.member_pay_type) {
return $h.pushMsg('会员价免费的不可以赠送哦');
}
this.money = this.special.money;
this.payDialogOpen = true;
break;
case 2:
vm.money = vm.is_member ? vm.special.member_money : vm.special.money;
vm.payDialogOpen = true;
break;
case 3:
this.money = this.special.pink_money;
this.payDialogOpen = true;
break;
case 4:
$h.loadFFF();
store.baseGet($h.U({
c: 'special',
a: 'receive_gift',
q: {
orderId: this.orderId
}
}), function (res) {
$h.loadClear();
$h.pushMsg(res.data.msg, function () {
window.location.assign("{:url('special/grade_special')}");
});
}, function () {
$h.loadClear();
});
break;
case 5:
if (vm.special.light_type === 1) {
window.location.assign("{:url('special/single_text_detail')}?try=0&id=" + vm.special.id);
} else {
window.location.assign("{:url('special/single_con_detail')}?try=0&id=" + vm.special.id);
}
break;
default:
break;
}
}
}.bind(this), function () {
if (isWechat) {
window.localStorage.setItem('login_back_url', window.location.href);
window.location.assign("{:url('login/index')}");
} else {
vm.loginShow = true;
}
}, true);
},
// 支付方式回调
pay_order: function (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;
var callbackUrl = callback_url + '?type=7&id=' + this.special.id;
var mwebUrl = data.data.result.jsConfig.mweb_url + '&redirect_url=' + encodeURIComponent(callbackUrl);
window.location.assign(mwebUrl);
break;
case 'SUCCESS':
this.successOrder(data.msg);
break;
case 'ZHIFUBAO_PAY':
window.location.assign($h.U({
c: 'alipay',
a: 'index',
q: {
info: data.data.result,
params: 'special'
}
}));
break;
}
},
// 微信支付
wechatPay: function (config) {
var vm = this;
mapleWx($jssdk(), function () {
this.chooseWXPay(config, function () {
vm.successOrder();
}, {
fail: vm.extendOrder,
cancel: vm.extendOrder
});
});
},
// 支付成功
successOrder: function (msg) {
var that = this;
$h.showMsg({
title: msg || '支付成功',
icon: 'success',
success: function () {
switch (that.pay_type_num) {
case 1:
window.location.assign($h.U({
c: 'special',
a: 'gift_special',
q: {
orderId: that.orderId
}
}));
break;
case 2:
that.isPay = true;
that.payDialogOpen = false;
break;
case 3:
window.location.assign($h.U({
c: 'special',
a: 'pink',
q: {
orderId: that.orderId
}
}));
break;
}
}
});
store.baseGet($h.U({
c: 'special',
a: 'special_validity',
q: {
id: special.id
}
}), function (res) {
that.special_validity = res.data.data.validity;
}, function () {
}, true);
},
updateMaterialStatus: function () {
var that = this;
that.otherLoading = false;
that.otherLoaded = false;
that.where.page = 1;
that.$set(that, 'otherTaskList', []);
that.getCourseList();
},
// 支付未完成
extendOrder: function (msg) {
var that = this;
if (typeof msg === 'object') {
if (msg.errMsg === 'chooseWXPay:cancel') {
msg = '微信支付取消';
} else {
msg = '支付失败';
}
} else {
msg = msg || '支付失败';
}
$h.pushMsg(msg, function () {
that.payDialogOpen = false;
if (that.orderId) {
store.baseGet($h.U({
c: 'special',
a: 'del_order',
q: {
orderId: that.orderId
}
}));
}
});
},
// 评分
rateChange: function (value) {
this.rateValue = value;
},
// 上传图片
imageUpload: function (file) {
var formData = new FormData();
formData.append('file', file);
axios.post("{:url('auth_api/upload')}", formData).then(function (res) {
var resData = res.data;
if (resData.code === 200) {
this.imageList.push(resData.data.url);
} else {
layer.msg(resData.msg);
}
}.bind(this)).catch(function (err) {
});
},
// 删除图片
imageDelete: function (index) {
this.imageList.splice(index, 1);
},
// 提交评价
evaluateSubmit: function (text) {
var vm = this;
$h.loadFFF();
store.basePost($h.U({
c: 'special',
a: 'user_comment_special',
q: {
special_id: this.special.id
}
}), {
satisfied_score: this.rateValue,
comment: text.trim(),
pics: this.imageList
}, function (res) {
$h.loadClear();
$h.pushMsg(res.data.msg, function () {
vm.dialogShow = false;
vm.specialReplyData();
vm.evaluateFinished = false;
vm.evaluatePage = 1;
vm.replyList = [];
vm.specialReplyList();
});
}, function () {
$h.loadClear();
vm.dialogShow = false;
});
},
// 我要评价
userEvaluate: function () {
var vm = this;
store.baseGet("{:url('index/login_user')}", function () {
if (this.isPay) {
this.dialogShow = true;
} else {
layer.msg('购买学习后可进行评价');
}
}.bind(this), function () {
if (isWechat) {
window.localStorage.setItem('login_back_url', window.location.href);
window.location.assign("{:url('login/index')}");
} else {
vm.loginShow = true;
}
}, true);
},
// 去练习、答题
goQuestion: function (question) {
var vm = this;
store.baseGet("{:url('index/login_user')}", function () {
if (question.is_pay || vm.isPay) {
window.location.assign((question.type === 1 ? "{:url('topic/problem_index')}" : "{:url('special/question_index')}") + '?id=' + question.id);
} else {
vm.payDialogOpen = true;
}
}, function () {
if (isWechat) {
window.localStorage.setItem('login_back_url', window.location.href);
window.location.assign("{:url('login/index')}");
} else {
vm.loginShow = true;
}
}, true);
},
// 客服
customerService: function () {
store.baseGet($h.U({
c: 'public_api',
a: 'public_data'
}), function (res) {
var data = res.data.data;
if (data.customer_service === '3') {
if (data.site_service_phone) {
layer.confirm('是否拨打 <a href="tel:' + data.site_service_phone + '">' + data.site_service_phone + '</a> 进行咨询?', {
title: false,
closeBtn: false,
btn: ['拨打', '取消']
}, function (index) {
window.location.assign('tel:' + data.site_service_phone);
layer.close(index);
});
} else {
layer.msg('抱歉,无法联系客服');
}
} else {
window.location.assign($h.U({
c: 'service',
a: 'service_list'
}));
}
});
},
// 首页
goHome: function () {
window.location.assign("{:url('index/index')}");
},
// 订阅通知模板id
getTemplateIds: function () {
var vm = this;
$h.loadFFF();
store.baseGet($h.U({
c: 'special',
a: 'getTemplateIds',
q: {
pay_type_num: this.pay_type_num,
special_id: this.special.id
}
}), function (res) {
$h.loadClear();
vm.templateIds = res.data.msg;
}, function () {
$h.loadClear();
});
},
// 记录浏览人数
addLearningRecords: function () {
store.baseGet($h.U({
c: 'special',
a: 'addLearningRecords',
q: {
id: this.special.id
}
}));
},
// 去拼团
goPink: function (id, uid) {
if (uid === this.uid && this.isPink) {
window.location.href = "{:url('special/pink')}?is_help=0&special_id=" + this.special.id + '&pink_id=' + this.pinkId;
} else {
window.location.href = "{:url('special/pink')}?is_help=1&special_id=" + this.special.id + '&pink_id=' + (id ? id : this.pinkId);
}
},
// 播放记忆
viewing: function (currentTime) {
store.basePost($h.U({
c: 'special',
a: 'viewing'
}), {
special_id: this.special.id,
task_id: 0,
total: this.duration * 1e3,
viewing_time: currentTime * 1e3,
percentage: Math.floor(currentTime / this.duration * 100)
}, false, false, true);
},
// 发放证书
inspect: function () {
var vm = this;
$h.loadFFF();
store.baseGet($h.U({
c: 'special',
a: 'inspect',
q: {
special_id: this.special.id,
is_light: 1
}
}), function (res) {
$h.loadClear();
layer.confirm('恭喜您达到发放证书要求,是否领取?', {
title: false,
closeBtn: 0,
btn: ['领取', '取消']
}, function (index) {
vm.getTheCertificate();
layer.close(index);
});
}, function () {
$h.loadClear();
}, true);
},
// 领取证书
getTheCertificate: function () {
var vm = this;
$h.loadFFF();
store.baseGet($h.U({
c: 'special',
a: 'getTheCertificate',
q: {
special_id: this.special.id
}
}), function (res) {
$h.loadClear();
$h.pushMsg('领取成功<br>证书制作中……', function () {
vm.viewCertificate(res.data.msg);
});
}, function () {
$h.loadClear();
});
},
// 证书信息
viewCertificate: function (id) {
var vm = this;
$h.loadFFF();
store.baseGet($h.U({
c: 'topic',
a: 'viewCertificate',
q: {
id: id,
obtain: 1
}
}), function (res) {
$h.loadClear();
vm.createCertificate(res.data.data);
}, function () {
$h.loadClear();
});
},
// 加载图片
loadImage: function (path) {
return new Promise(function (resolve, reject) {
var image = new Image();
image.crossOrigin = 'anonymous';
image.src = path + '?' + new Date().getTime();
image.onload = function () {
resolve(image);
};
image.onerror = function () {
reject('error-image');
};
});
},
// 制作证书
createCertificate: function (certificate) {
var vm = this;
$h.loadFFF();
Promise.all([
this.loadImage(certificate.certificate.background),
this.loadImage(certificate.certificate.qr_code)
]).then(function (images) {
var canvas = document.createElement('canvas');
var context = canvas.getContext('2d');
canvas.width = images[0].width;
canvas.height = images[0].height;
context.drawImage(images[0], 0, 0);
context.drawImage(images[1], 220, 557, 160, 160);
context.fillStyle = 'rgba(255, 255, 255, 1)';
context.fillRect(220, 724, 160, 36);
context.font = '20px sans-serif';
context.textAlign = 'center';
context.fillStyle = '#666666';
context.fillText('长按二维码查看', 300, 748);
context.font = 'bold 34px sans-serif';
context.fillStyle = '#29466D';
context.fillText(certificate.nickname, 300, 296);
context.font = '24px sans-serif';
context.fillText('颁发时间:' + moment(certificate.add_time * 1000).format('YYYY.MM.DD'), 300, 481);
context.font = '28px sans-serif';
context.textAlign = 'start';
context.fillStyle = '#333333';
for (var i = Math.ceil(certificate.certificate.explain.length % 16); i--;) {
context.fillText(certificate.certificate.explain.substr(i * 16, 16), 83, i * 40 + 370);
}
vm.certificateImage = canvas.toDataURL('image/jpeg');
canvas = null;
}).catch(function (err) {
});
},
// 弹幕
getBarrageList: function () {
var vm = this;
$h.loadFFF();
store.baseGet($h.U({
c: 'special',
a: 'get_barrage_list',
q: {
special_id: this.special.id
}
}), function (res) {
var barrageLen = 0;
$h.loadClear();
vm.barrageList = res.data.data;
barrageLen = vm.barrageList.length;
if (!barrageLen) {
return;
}
setInterval(function () {
vm.barrage_index++;
if (vm.barrage_index >= barrageLen) {
vm.barrage_index = 0
}
store.baseGet($h.U({
c: 'special',
a: 'set_barrage_index',
q: {
index: vm.barrage_index
}
}));
}, vm.barrageShowTime * 1000);
}, function () {
$h.loadClear();
});
},
// 关联资料
specialDataDownload: function () {
var vm = this;
$h.loadFFF();
store.baseGet($h.U({
c: 'special',
a: 'SpecialDataDownload',
q: {
special_id: this.special.id
}
}), function (res) {
$h.loadClear();
vm.specialDownload = res.data.data;
}, function () {
$h.loadClear();
});
},
// 获取返佣金额
rebateAmount: function () {
var vm = this;
store.baseGet($h.U({
c: 'auth_api',
a: 'rebateAmount',
p: {
id: this.special.id
}
}), function (res) {
vm.rebateMoney = parseFloat(res.data.data.brokeragePrice);
});
},
rebateAction: function (value) {
switch (value) {
case 'close':
this.rebateMoney = 0;
break;
case 'share':
this.createSharePoster();
break;
}
},
handleTry: function () {
var vm = this;
store.baseGet("{:url('index/login_user')}", function () {
if (vm.special.light_type === 1) {
window.location.assign("{:url('special/single_text_detail')}?try=1&id=" + vm.special.id);
} else {
window.location.assign("{:url('special/single_con_detail')}?try=1&id=" + vm.special.id);
}
}, function () {
if (isWechat) {
window.localStorage.setItem('login_back_url', window.location.href);
window.location.assign("{:url('login/index')}");
} else {
vm.loginShow = true;
}
}, true);
}
}
});
});
</script>
{/block}