dev_admin
hjm 6 years ago
parent 25a627df2f
commit 533b01a8a5

@ -10,33 +10,50 @@ class Clappr extends Component{
this.state={ this.state={
} }
} }
componentWillUnmount() {
this['player'+this.props.id] && this['player'+this.props.id].destroy()
}
componentDidMount() { componentDidMount() {
const source = this.props.source || "http://your.video/here.mp4" const source = this.props.source || "http://your.video/here.mp4"
const { id } = this.props const { id, type } = this.props
const _id = `#_player${id}` const _id = `#_player${id}`
if (window['Clappr']) { if (!window['Clappr'] && window['ClapprLoading'] == true) {
const player = new window.Clappr.Player({ setTimeout(() => {
source: source, parentId: _id, this.componentDidMount()
plugins: { }, 300)
'core': [window.Clappr.MediaControl, window.Clappr.Playback] return;
} }
// && window['clappr-playback-rate-plugin']
if (window['Clappr'] ) {
// http://clappr.github.io/classes/Player.html#method_mute
this['player'+id] = new window.Clappr.Player({
source: source, parentId: _id,
height: type == 'mp3' ? 60 : 360,
hideMediaControl: type == 'mp3' ? false : true,
// plugins: {
// 'core': [window.Clappr.MediaControl, window['clappr-playback-rate-plugin'].default]
// }
}); });
} else { } else {
window['ClapprLoading'] = true;
$.getScript( $.getScript(
`${_url_origin}/javascripts/media/clappr.min.js`, `${_url_origin}/javascripts/media/clappr.min.js`,
(data, textStatus, jqxhr) => { (data, textStatus, jqxhr) => {
window.clappr = window.Clappr window.clappr = window.Clappr
$.getScript( // $.getScript(
`${_url_origin}/javascripts/media/clappr-playback-rate-plugin.min.js`, // `${_url_origin}/javascripts/media/clappr-playback-rate-plugin.min.js`,
(data, textStatus, jqxhr) => { // (data, textStatus, jqxhr) => {
const player = new window.Clappr.Player({ this['player'+id] = new window.Clappr.Player({
source: source, parentId: _id, source: source, parentId: _id,
plugins: { height: type == 'mp3' ? 60 : 360,
'core': [window.Clappr.MediaControl, window['clappr-playback-rate-plugin'].default] hideMediaControl: type == 'mp3' ? false : true,
} // plugins: {
// 'core': [window.Clappr.MediaControl, window['clappr-playback-rate-plugin'].default]
// }
}); });
}) // })
}); });
@ -62,7 +79,7 @@ class Clappr extends Component{
render(){ render(){
let { source, id, className } = this.props; let { source, id, className, type } = this.props;
const _id = `_player${id}` const _id = `_player${id}`
return( return(
<React.Fragment> <React.Fragment>
@ -71,7 +88,7 @@ class Clappr extends Component{
margin-right: 16px; margin-right: 16px;
} }
`}</style> `}</style>
<div id={_id} className={className}></div> <div id={_id} className={className + ' ' + type}></div>
</React.Fragment> </React.Fragment>
) )
} }

@ -1,4 +1,6 @@
import React, { Component } from 'react'; import React, { Component } from 'react';
import ReactDOM from 'react-dom';
import { Redirect } from 'react-router'; import { Redirect } from 'react-router';
import PropTypes from 'prop-types'; import PropTypes from 'prop-types';
@ -29,7 +31,11 @@ class EvaluateSuccessEffectDisplay extends Component {
} }
} }
hidepicture = () => { hidepicture = () => {
window.$('#picture_display').hide(); const dom = document.getElementById('picture_display');
ReactDOM.unmountComponentAtNode(dom)
// window.$('#picture_display').hide();
window.$('.data-tip-right').hide()
} }
renderContent = () => { renderContent = () => {
// qrcode // qrcode
@ -107,11 +113,11 @@ class EvaluateSuccessEffectDisplay extends Component {
<EffectDisplayContent <EffectDisplayContent
typeName="音频" typeName="音频"
content1={ orignal_file[0] && orignal_file[0].file_url content1={ orignal_file[0] && orignal_file[0].file_url
? <Clappr source={orignal_file[0].file_url} id="1" className="clappr"></Clappr> : null } ? <Clappr source={orignal_file[0].file_url} id="1" className="clappr" type="mp3"></Clappr> : null }
content2={ user_file[0] && user_file[0].file_url content2={ user_file[0] && user_file[0].file_url
? <Clappr source={user_file[0].file_url} id="2" className="clappr"></Clappr> : null } ? <Clappr source={user_file[0].file_url} id="2" className="clappr" type="mp3"></Clappr> : null }
content3={ answer_file[0] && answer_file[0].file_url content3={ answer_file[0] && answer_file[0].file_url
? <Clappr source={answer_file[0].file_url} id="3" className="clappr"></Clappr> : null } ? <Clappr source={answer_file[0].file_url} id="3" className="clappr" type="mp3"></Clappr> : null }
></EffectDisplayContent> ></EffectDisplayContent>
) )
} else if (type == 'mp4') { } else if (type == 'mp4') {
@ -119,11 +125,11 @@ class EvaluateSuccessEffectDisplay extends Component {
<EffectDisplayContent <EffectDisplayContent
typeName="视频" typeName="视频"
content1={ orignal_file[0] && orignal_file[0].file_url content1={ orignal_file[0] && orignal_file[0].file_url
? <Clappr source={orignal_file[0].file_url} id="1" className="clappr"></Clappr> : null } ? <Clappr source={orignal_file[0].file_url} id="1" className="clappr" type="mp4"></Clappr> : null }
content2={ user_file[0] && user_file[0].file_url content2={ user_file[0] && user_file[0].file_url
? <Clappr source={user_file[0].file_url} id="2" className="clappr"></Clappr> : null } ? <Clappr source={user_file[0].file_url} id="2" className="clappr" type="mp4"></Clappr> : null }
content3={ answer_file[0] && answer_file[0].file_url content3={ answer_file[0] && answer_file[0].file_url
? <Clappr source={answer_file[0].file_url} id="3" className="clappr"></Clappr> : null } ? <Clappr source={answer_file[0].file_url} id="3" className="clappr" type="mp4"></Clappr> : null }
></EffectDisplayContent> ></EffectDisplayContent>
) )
} }

Loading…
Cancel
Save