| 
									
										
										
										
											2019-03-01 11:58:27 +08:00
										 |  |  | import React from 'react'; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | import videojs from 'video.js'; | 
					
						
							| 
									
										
										
										
											2025-05-07 14:40:22 +08:00
										 |  |  | import 'videojs-hotkeys'; | 
					
						
							| 
									
										
										
										
											2019-03-01 11:58:27 +08:00
										 |  |  | import 'video.js/dist/video-js.css'; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | class VideoPlayer extends React.Component { | 
					
						
							|  |  |  |   componentDidMount() { | 
					
						
							|  |  |  |     // instantiate Video.js
 | 
					
						
							| 
									
										
										
										
											2025-05-07 14:40:22 +08:00
										 |  |  |     this.player = videojs(this.videoNode, { | 
					
						
							|  |  |  |       ...this.props, | 
					
						
							|  |  |  |       plugins: { | 
					
						
							|  |  |  |         hotkeys: { | 
					
						
							|  |  |  |           alwaysCaptureHotkeys: true, | 
					
						
							|  |  |  |           volumeStep: 0.1, | 
					
						
							|  |  |  |           seekStep: 5, | 
					
						
							|  |  |  |           enableMute: true, | 
					
						
							|  |  |  |           enableFullscreen: true, | 
					
						
							|  |  |  |           enableNumbers: true | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     }, function onPlayerReady() {}); | 
					
						
							|  |  |  |     this.player.el().focus(); | 
					
						
							| 
									
										
										
										
											2019-03-01 11:58:27 +08:00
										 |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-08-08 16:06:33 +08:00
										 |  |  |   componentDidUpdate(prevProps) { | 
					
						
							|  |  |  |     // Update sources if changed
 | 
					
						
							|  |  |  |     if (JSON.stringify(this.props.sources) !== JSON.stringify(prevProps.sources)) { | 
					
						
							|  |  |  |       this.player.src(this.props.sources[0]); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-03-01 11:58:27 +08:00
										 |  |  |   // destroy player on unmount
 | 
					
						
							|  |  |  |   componentWillUnmount() { | 
					
						
							| 
									
										
										
										
											2025-09-25 13:37:31 +08:00
										 |  |  |     setTimeout(() => { | 
					
						
							|  |  |  |       try { | 
					
						
							|  |  |  |         if (this.player) { | 
					
						
							|  |  |  |           this.player.dispose(); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       } catch (e) { | 
					
						
							|  |  |  |         //
 | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     }, 0); | 
					
						
							| 
									
										
										
										
											2019-03-01 11:58:27 +08:00
										 |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   // wrap the player in a div with a `data-vjs-player` attribute
 | 
					
						
							|  |  |  |   // so videojs won't create additional wrapper in the DOM
 | 
					
						
							|  |  |  |   // see https://github.com/videojs/video.js/pull/3856
 | 
					
						
							|  |  |  |   render() { | 
					
						
							|  |  |  |     return ( | 
					
						
							|  |  |  |       <div data-vjs-player> | 
					
						
							| 
									
										
										
										
											2025-05-07 14:40:22 +08:00
										 |  |  |         <video ref={ node => this.videoNode = node } className="video-js" style={{ display: 'block' }}></video> | 
					
						
							| 
									
										
										
										
											2019-03-01 11:58:27 +08:00
										 |  |  |       </div> | 
					
						
							|  |  |  |     ); | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | export default VideoPlayer; |