Commit b02c4e5a by zhanghaozhe

播放样式 选择视频

parent d0b782ad
...@@ -41,8 +41,6 @@ class App extends Component { ...@@ -41,8 +41,6 @@ class App extends Component {
//平台信息 //平台信息
cookie.set('plat', '5', {domain: '.julyedu.com'}) cookie.set('plat', '5', {domain: '.julyedu.com'})
console.log(this.props.location);
this.props.startFetchUser() this.props.startFetchUser()
http.get(`${API.home}/m/user_info`).then(res => { http.get(`${API.home}/m/user_info`).then(res => {
this.props.setCurrentUser(this.transformUser(res)) this.props.setCurrentUser(this.transformUser(res))
......
...@@ -283,7 +283,6 @@ class Detail extends Component { ...@@ -283,7 +283,6 @@ class Detail extends Component {
} }
// 点击子组件单集购买按钮 // 点击子组件单集购买按钮
toSingleset = (item) => { toSingleset = (item) => {
console.log(this.props);
const {user} = this.props const {user} = this.props
const uid = user && user.data && user.data.uid const uid = user && user.data && user.data.uid
if (!uid) { if (!uid) {
...@@ -415,7 +414,6 @@ class Detail extends Component { ...@@ -415,7 +414,6 @@ class Detail extends Component {
render() { render() {
const { course: { course_info={} }, barInfo, singleBox, singleType } = this.state; const { course: { course_info={} }, barInfo, singleBox, singleType } = this.state;
console.log(course_info);
let courseInfo = '', let courseInfo = '',
service = '', service = '',
number = 0, number = 0,
......
...@@ -104,6 +104,7 @@ class Single extends Component { ...@@ -104,6 +104,7 @@ class Single extends Component {
http.get(`${API['base-api']}/pay/wxpay/pub_charge/oid/${getParam('oid')}/code/${weixin_code}`).then((res) => { http.get(`${API['base-api']}/pay/wxpay/pub_charge/oid/${getParam('oid')}/code/${weixin_code}`).then((res) => {
if (res.data.errno === 0) { if (res.data.errno === 0) {
const data = res.data.data; const data = res.data.data;
function onBridgeReady() { function onBridgeReady() {
WeixinJSBridge.invoke( WeixinJSBridge.invoke(
'getBrandWCPayRequest', { 'getBrandWCPayRequest', {
...@@ -163,6 +164,7 @@ class Single extends Component { ...@@ -163,6 +164,7 @@ class Single extends Component {
} }
) )
} }
if (typeof WeixinJSBridge == "undefined") { if (typeof WeixinJSBridge == "undefined") {
if (document.addEventListener) { if (document.addEventListener) {
document.addEventListener('WeixinJSBridgeReady', onBridgeReady, false) document.addEventListener('WeixinJSBridgeReady', onBridgeReady, false)
...@@ -184,9 +186,9 @@ class Single extends Component { ...@@ -184,9 +186,9 @@ class Single extends Component {
// 支付完成之后获取状态 // 支付完成之后获取状态
payCallback = () => { payCallback = () => {
const _this = this; const _this = this;
if(!getParam('oid')) { if (!getParam('oid')) {
return; return;
}else{ } else {
_this.intervalPayStatus = setInterval(function () { _this.intervalPayStatus = setInterval(function () {
http.get(`${API['base-api']}/m/orderState/oid/${getParam('oid')}`).then(res => { http.get(`${API['base-api']}/m/orderState/oid/${getParam('oid')}`).then(res => {
if (res.data.errno === 401) { if (res.data.errno === 401) {
...@@ -301,7 +303,7 @@ class Single extends Component { ...@@ -301,7 +303,7 @@ class Single extends Component {
} }
render() { render() {
const { showSingleBox } = this.state; const {showSingleBox} = this.state;
if (this.state.endTime) { if (this.state.endTime) {
let date = this.state.endTime * 1000 let date = this.state.endTime * 1000
let now = Date.now() let now = Date.now()
...@@ -317,53 +319,46 @@ class Single extends Component { ...@@ -317,53 +319,46 @@ class Single extends Component {
}) })
}, 1000) }, 1000)
} }
const { singleType } = this.props; const {singleType} = this.props;
console.log(this.state.singleBox);
return ( return (
singleType === 1 &&
<div> <div>
<div className='popup-box'>
<div className='content singleset-payment'>
<div className='popup-box'> <div className='price-box'>
{ <span>实付款:</span>
singleType === 1 && <p>{this.props.data.class_price}</p>
<div className='content singleset-payment'> </div>
<div className='price-box'> <div className='course-info'>
<span>实付款:</span> <p className='text-overflow-1'><span>课程:</span>
<p>{this.props.data.class_price}</p> {this.props.title}
</div> </p>
<div className='course-info'> <p className='text-overflow-1'><span>课时:</span>
<p className='text-overflow-1'><span>课程:</span> {this.props.data.name}
{this.props.title} </p>
</p> </div>
<p className='text-overflow-1'><span>课时:</span> <div className='payment-type'>
{this.props.data.name} <label>支付方式:</label>
</p> {
</div> !browser.isWeixin &&
<div className='payment-type'> <p onClick={this.check.bind(this, '1')}>
<label>支付方式:</label> <i className='iconfont iconalipay'></i>
{ <span>支付宝</span>
!browser.isWeixin && <i className={`iconfont icondanseshixintubiao-5 redio ${this.state.payType === '1' ? 'redioed' : ''}`}></i>
<p onClick={this.check.bind(this, '1')}> </p>
<i className='iconfont iconalipay'></i> }
<span>支付宝</span>
<i className={`iconfont icondanseshixintubiao-5 redio ${this.state.payType === '1' ? 'redioed' : ''}`}></i>
</p>
}
<p onClick={this.check.bind(this, '0')}> <p onClick={this.check.bind(this, '0')}>
<i className='iconfont iconweixinzhifu buy'></i> <i className='iconfont iconweixinzhifu buy'></i>
<span>微信支付</span> <span>微信支付</span>
<i className={`iconfont icondanseshixintubiao-5 redio ${this.state.payType === '0' ? 'redioed' : ''}`}></i> <i className={`iconfont icondanseshixintubiao-5 redio ${this.state.payType === '0' ? 'redioed' : ''}`}></i>
</p> </p>
</div> </div>
<div className='btn btn-18B4ED' onClick={this.toBuy}>确认购买</div> <div className='btn btn-18B4ED' onClick={this.toBuy}>确认购买</div>
</div>
}
<i onClick={this.colse} className={'iconfont iconiconfront-2 close'}></i>
</div> </div>
<i onClick={this.colse} className={'iconfont iconiconfront-2 close'}></i>
</div>
</div> </div>
); );
......
import videojs from 'video.js'
const Component = videojs.getComponent('Component')
const Button = videojs.getComponent('Button')
class CustomPlayButtonCover extends Component {
createEl() {
return super.createEl('div', {
className: 'vjs-custom-play-button-cover'
})
}
dispose() {
this.el_ && (this.el_ = null)
}
}
class CustomPlayButton extends Button {
constructor(player, options) {
super(player, options)
this.on('tap', this.tap)
}
createEl() {
return super.createEl('button', {
className: 'vjs-custom-play-button'
}, {
type: 'button'
})
}
tap() {
this.player_.play()
}
dispose() {
if (this.el_) {
this.off('tap', this.tap)
this.el_ = null
}
}
}
Component.registerComponent('CustomPlayButton', CustomPlayButton)
CustomPlayButtonCover.prototype.options_ = {
children: [
'CustomPlayButton'
]
}
Component.registerComponent('CustomPlayButtonCover', CustomPlayButtonCover)
\ No newline at end of file
import React, {Component} from 'react' import React, { Component } from 'react'
import HeaderBar from '@/common/HeaderBar' import HeaderBar from '@/common/HeaderBar'
import './video.scss' import './video.scss'
import {NavLink, Route, Redirect, Switch, Link} from 'react-router-dom' import { NavLink, Route, Redirect, Switch, Link } from 'react-router-dom'
import {http, getParam} from '@/utils' import { http, getParam } from '@/utils'
import Recommendation from './recommendation' import Recommendation from './recommendation'
import VideoCatalog from './video-catalog' import VideoCatalog from './video-catalog'
import DatumCatalog from './datum-catalog' import DatumCatalog from './datum-catalog'
import {Toast} from 'antd-mobile' import { Toast } from 'antd-mobile'
import videojs from 'video.js' import videojs from 'video.js'
import 'video.js/dist/video-js.min.css' import 'video.js/dist/video-js.min.css'
import {Modal} from "antd-mobile" import { Modal } from "antd-mobile"
import {Loading} from '@/common' import { Loading } from '@/common'
import {connect} from "react-redux" import { connect } from "react-redux"
import jsCookie from 'js-cookie' import jsCookie from 'js-cookie'
import io from 'socket.io-client' import io from 'socket.io-client'
import Single from "@/components/detail/single"; import Single from "@/components/detail/single";
import './CustomPlayButton'
let alert = Modal.alert let alert = Modal.alert
...@@ -58,7 +59,6 @@ function ProgressShareModal(props) { ...@@ -58,7 +59,6 @@ function ProgressShareModal(props) {
) )
} }
class Video extends Component { class Video extends Component {
video //video element video //video element
...@@ -262,7 +262,7 @@ class Video extends Component { ...@@ -262,7 +262,7 @@ class Video extends Component {
this.player = videojs(this.video, { this.player = videojs(this.video, {
controls: true, controls: true,
preload: 'auto', preload: 'auto',
bigPlayButton: true, bigPlayButton: false,
textTrackDisplay: false, textTrackDisplay: false,
posterImage: false, posterImage: false,
errorDisplay: false, errorDisplay: false,
...@@ -271,6 +271,7 @@ class Video extends Component { ...@@ -271,6 +271,7 @@ class Video extends Component {
pictureInPictureToggle: false pictureInPictureToggle: false
} }
}) })
this.player.addChild('CustomPlayButtonCover')
this.player.on('ready', () => { this.player.on('ready', () => {
this.recordSocket.emit('load', this.recordUserInfo()) this.recordSocket.emit('load', this.recordUserInfo())
}) })
...@@ -310,7 +311,6 @@ class Video extends Component { ...@@ -310,7 +311,6 @@ class Video extends Component {
} }
selectVideo = index => { selectVideo = index => {
if (index === this.state.activeIndex) { if (index === this.state.activeIndex) {
return return
} }
...@@ -321,7 +321,7 @@ class Video extends Component { ...@@ -321,7 +321,7 @@ class Video extends Component {
activeIndex: index activeIndex: index
}, },
() => { () => {
if (this.hasAuth()) { if (this.hasAuth(this.state.activeIndex)) {
this.setPlayerSrc(this.state.videoList[index]['play_url']) this.setPlayerSrc(this.state.videoList[index]['play_url'])
this.sendLastRecord() this.sendLastRecord()
this.playVideo() this.playVideo()
...@@ -332,6 +332,9 @@ class Video extends Component { ...@@ -332,6 +332,9 @@ class Video extends Component {
) )
} }
getLastVideoIndex = lastIndex => {
return this.state.videoList.findIndex(item => item.id == lastIndex)
}
getVideoList = () => { getVideoList = () => {
let url = '' let url = ''
...@@ -356,29 +359,7 @@ class Video extends Component { ...@@ -356,29 +359,7 @@ class Video extends Component {
title: data.data.course['course_title'], title: data.data.course['course_title'],
isLoading: false isLoading: false
}), }),
() => { this.playSetup
if (this.state.course.is_aist) {
this.setupWS()
this.setupTimer()
}
if (this.lessonAvailable()) {
if (this.hasAuth()) {
Promise.resolve().then(() => {
this.initializePlayer()
this.playWithAuth()
})
} else {
this.getCoursePrice();
}
} else {
alert('暂无视频', '', [{
text: 'OK',
onPress: () => {
this.props.history.push('/')
}
}])
}
}
) )
} else { } else {
Toast.info(data.msg) Toast.info(data.msg)
...@@ -386,6 +367,37 @@ class Video extends Component { ...@@ -386,6 +367,37 @@ class Video extends Component {
}) })
} }
playSetup = () => {
if (this.state.course.is_aist) {
this.setupWS()
this.setupTimer()
}
let index = this.getLastVideoIndex(this.state.course.last_video_id)
index = index >= 0 ? index : 0
this.setState({
activeIndex: index
}, () => {
if (this.lessonAvailable(index)) {
if (this.hasAuth(index)) {
Promise.resolve().then(() => {
this.initializePlayer()
this.playWithAuth()
})
} else {
this.getCoursePrice();
}
} else {
alert('暂无视频', '', [{
text: 'OK',
onPress: () => {
this.props.history.push('/')
}
}])
}
})
}
setPlayerSrc = src => { setPlayerSrc = src => {
if (!this.player) { if (!this.player) {
this.initializePlayer() this.initializePlayer()
...@@ -417,13 +429,8 @@ class Video extends Component { ...@@ -417,13 +429,8 @@ class Video extends Component {
}) })
} }
lessonAvailable = () => { lessonAvailable = index => {
let {videoList, course} = this.state return this.state.videoList[index]['video_size'] !== 0
let videoIndex = videoList.findIndex(item => item.id == course.last_video_id)
this.setState({
activeIndex: videoIndex
})
return videoList[videoIndex]['video_size'] !== 0
} }
getCoursePrice = () => { getCoursePrice = () => {
...@@ -441,19 +448,15 @@ class Video extends Component { ...@@ -441,19 +448,15 @@ class Video extends Component {
playWithAuth = () => { playWithAuth = () => {
const {videoList, activeIndex} = this.state const {videoList, activeIndex} = this.state
if (this.hasAuth()) { if (this.hasAuth(activeIndex)) {
this.setPlayerSrc(videoList[activeIndex]['play_url']) this.setPlayerSrc(videoList[activeIndex]['play_url'])
} }
} }
hasAuth = () => { hasAuth = index => {
const {course, videoList} = this.state const {videoList} = this.state
let videoIndex = videoList.findIndex(item => item.id == course.last_video_id) let lesson = videoList[index]
this.setState({
activeIndex: videoIndex
})
let lesson = videoList[videoIndex]
if (lesson['video_auth']) { if (lesson['video_auth']) {
this.setState({ this.setState({
......
...@@ -9,12 +9,9 @@ ...@@ -9,12 +9,9 @@
&.active { &.active {
.title, .duration {
color: $active;
}
.video-title { .video-title {
background-color: #F5FBFF; background-color: #F5FBFF;
color: $active;
} }
.exercise{ .exercise{
border-top: 1px solid #E7EAF1; border-top: 1px solid #E7EAF1;
...@@ -73,4 +70,8 @@ ...@@ -73,4 +70,8 @@
float: right; float: right;
} }
.iconplay_hovericon{
color: $active;
}
} }
\ No newline at end of file
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment