| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159 | <template>	<view class="kecheng-study-page">		<view class="icon-title-navBar-box">			<view @click="goUpPage" class="nav-bar-icon"></view>			<text class="nav-bar-title">{{name}}</text>		</view>		<!-- 播放器 -->		<videoPlayVue ref="videoRef" class="phone-video-box" v-if="showVideo"></videoPlayVue>		<view v-else class="phone-video-box master-image"></view>		<!-- 中间区域 -->		<view class="kc-info-box">			<view>时长:{{period}}</view>			<view>{{userCount}}人学习</view>		</view>		<!-- 大纲 -->		<view class="phone-tab-box">			<uni-segmented-control :current="current" :values="items" style-type="text" :active-color="activeColor"				@clickItem="onClickItem" />		</view>		<view class="kecheng-content-box">			<!-- 目录 -->			<kechengMuluVue v-if="current === 0" :chapterArr="list" @play="handlePlay" :isHasProgress="false" 			:activeKjId="curPlayData&&curPlayData.kjId"></kechengMuluVue>			<!-- 介绍 -->			<rich-text :nodes="intro || '暂无内容'" v-if="current === 1 && intro" class="kecheng-jieshao-box"></rich-text>		</view>	</view></template><script>	import * as kechengApi from "@/api/kecheng.js";	import videoPlayVue from "@/components/videoPlay/videoPlay.vue";	import kechengMuluVue from "@/components/kecheng-mulu/kecheng-mulu.vue";	import {		useUserCache	} from "@/utils/userCache.js"	import {		formatSecondsToCnhms	} from "@/utils/common.js"	export default {		components: {			videoPlayVue,			kechengMuluVue		},		data() {			return {				showVideo: false,				items: ['目录', '介绍'],				colors: ['#007aff', '#4cd964', '#dd524d'],				activeColor: '#3fd2a1',				current: 0, // 激活的选项卡				kcId: '', // 课程				title: '',				period: 0, // 时长				userCount: 0, // 学习人数				list: [],				intro: '',				curPlayData: null,				kechengFlag: null,				zyName: '',				zyLevelName: '',				operId: '', // 课程			}		},		onLoad(options) {			this.kcId = options.kcId;			this.init();		},		methods: {			goUpPage() {				uni.redirectTo({					url: '/pages/admin/Kecheng/list'				})			},			onClickItem(e) {				if (this.current !== e.currentIndex) {					this.current = e.currentIndex				}			},			formatData(data) {				data.forEach(zhang => {					zhang.open = false;					zhang.jieList.forEach(jie => {						jie.open = false;					})				})				return data;			},			handlePlay(data) {				if (!this.kechengFlag) {					uni.showToast({						icon: 'none',						title: '当前课件不可查看'					})					return;				}				this.showVideo = true;				if (this.curPlayData && this.curPlayData.videoId == data.videoId) {					return;				}				this.curPlayData = data;				kechengApi.getVideoAuth({					videoId: data.url				}).then(res => {					this.$refs.videoRef.init({						videoId: data.url,						playAuth: res.data,						seekTime: '',						isPlay: false					})				})			},			initFirstVideo() {				if (this.list && this.list[0].jieList && this.list[0].jieList[0].kejianList) {					// 设置默认展开项					this.list[0].open = true;					this.list[0].jieList[0].open = true;					const kejian = this.list[0].jieList[0].kejianList[0];				}			},			init() {				kechengApi.getKechengGlStart({					kcId: this.kcId				}).then(res => {					const {						userCount,						period,						name,						kejianUserVo,						intro,						kechengFlag,						operId,						zyName,						zyLevelName,					} = res.data;					this.userCount = userCount;					this.period = formatSecondsToCnhms(period,true);					this.name = name;					this.zyName = zyName;					this.zyLevelName = zyLevelName;					this.kechengFlag = kechengFlag;					this.formatData(kejianUserVo.zhangList)					this.list = kejianUserVo.zhangList;					this.intro = intro;					this.operId = operId;										this.initFirstVideo();				})			}		}	}</script><style></style>
 |