mirror of
				https://github.com/iv-org/invidious.git
				synced 2025-10-25 18:28:30 -05:00 
			
		
		
		
	fix playing related bugs
This commit is contained in:
		
							parent
							
								
									54c90bae48
								
							
						
					
					
						commit
						fc49ab285e
					
				| @ -26,6 +26,8 @@ class invidious_embed{ | |||||||
|     Player(element,options){ |     Player(element,options){ | ||||||
|         this.player_status = -1; |         this.player_status = -1; | ||||||
|         this.error_code = 0; |         this.error_code = 0; | ||||||
|  |         this.volume = 100; | ||||||
|  |         this.eventobject = {ready:[],ended:[],error:[],ratechange:[],volumechange:[],waiting:[],timeupdate:[],loadedmetadata:[],play:[],seeking:[],seeked:[],playerresize:[],pause:[],statechange:[]}; | ||||||
|         var replace_elemnt; |         var replace_elemnt; | ||||||
|         if(element===undefined||element===null){ |         if(element===undefined||element===null){ | ||||||
|             throw 'please set element id or HTMLElement'; |             throw 'please set element id or HTMLElement'; | ||||||
| @ -79,6 +81,7 @@ class invidious_embed{ | |||||||
|         this.player_iframe = document.createElement("iframe"); |         this.player_iframe = document.createElement("iframe"); | ||||||
|         this.loaded = false; |         this.loaded = false; | ||||||
|         this.addEventListener('loadedmetadata',()=>{this.event_executor('ready');this.loaded=true}); |         this.addEventListener('loadedmetadata',()=>{this.event_executor('ready');this.loaded=true}); | ||||||
|  |         this.addEventListener('loadedmetadata',()=>{this.setVolume(this.volume)}); | ||||||
|         this.player_iframe.src = iframe_src; |         this.player_iframe.src = iframe_src; | ||||||
|         if(options.width!==undefined&&typeof options.width==='number'){ |         if(options.width!==undefined&&typeof options.width==='number'){ | ||||||
|             this.player_iframe.width = options.width; |             this.player_iframe.width = options.width; | ||||||
| @ -98,7 +101,6 @@ class invidious_embed{ | |||||||
|             this.player_iframe.height = this.player_iframe.width * (9/16); |             this.player_iframe.height = this.player_iframe.width * (9/16); | ||||||
|         } |         } | ||||||
|         this.player_iframe.style.border = "none"; |         this.player_iframe.style.border = "none"; | ||||||
|         this.eventobject = {ready:[],ended:[],error:[],ratechange:[],volumechange:[],waiting:[],timeupdate:[],loadedmetadata:[],play:[],seeking:[],seeked:[],playerresize:[],pause:[],statechange:[]}; |  | ||||||
|         replace_elemnt.replaceWith(this.player_iframe); |         replace_elemnt.replaceWith(this.player_iframe); | ||||||
|         this.eventdata = {}; |         this.eventdata = {}; | ||||||
|         return this; |         return this; | ||||||
| @ -198,6 +200,7 @@ class invidious_embed{ | |||||||
|     } |     } | ||||||
|     setVolume(volume){ |     setVolume(volume){ | ||||||
|         volume = Number(volume); |         volume = Number(volume); | ||||||
|  |         this.volume = volume; | ||||||
|         if(volume!==NaN&&volume!=undefined&&volume>=0&&volume<=100){ |         if(volume!==NaN&&volume!=undefined&&volume>=0&&volume<=100){ | ||||||
|             this.postMessage({eventname:'setvolume',value:volume/100}); |             this.postMessage({eventname:'setvolume',value:volume/100}); | ||||||
|         } |         } | ||||||
| @ -276,7 +279,7 @@ class invidious_embed{ | |||||||
|                 startSeconds = option.startSeconds; |                 startSeconds = option.startSeconds; | ||||||
|             } |             } | ||||||
|             if(option.endSeconds!==undefined&&typeof option.endSeconds==='number'&&option.endSeconds>=0){ |             if(option.endSeconds!==undefined&&typeof option.endSeconds==='number'&&option.endSeconds>=0){ | ||||||
|                 startSeconds = option.endSeconds; |                 endSeconds = option.endSeconds; | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
|         if(mediaContetUrl.length>0){ |         if(mediaContetUrl.length>0){ | ||||||
| @ -355,9 +358,6 @@ class invidious_embed{ | |||||||
|     getVideoUrl(){ |     getVideoUrl(){ | ||||||
|         return this.target_origin + "/watch?v=" + this.videoId; |         return this.target_origin + "/watch?v=" + this.videoId; | ||||||
|     } |     } | ||||||
|     getVideoTitle(){//original function
 |  | ||||||
|         return this.promise_send_event('gettitle'); |  | ||||||
|     } |  | ||||||
|     async getVideoEmbedCode(){ |     async getVideoEmbedCode(){ | ||||||
|         var title = await this.getVideoTitle(); |         var title = await this.getVideoTitle(); | ||||||
|         return '<iframe width="560" height="315" src="' + this.target_origin + "/embed/" + this.videoId + '" title="' + title.replace('"','') + '" frameborder="0" allow="autoplay;encrypted-media;picture-in-picture; web-share" allowfullscreen></iframe>'; |         return '<iframe width="560" height="315" src="' + this.target_origin + "/embed/" + this.videoId + '" title="' + title.replace('"','') + '" frameborder="0" allow="autoplay;encrypted-media;picture-in-picture; web-share" allowfullscreen></iframe>'; | ||||||
| @ -370,6 +370,9 @@ class invidious_embed{ | |||||||
|         window.addEventListener('message',(ms)=>{this.receiveMessage(ms)}); |         window.addEventListener('message',(ms)=>{this.receiveMessage(ms)}); | ||||||
|         this.message_wait = {getvolume:[],getmutestatus:[],getduration:[],getcurrenttime:[],getplaybackrate:[],getavailableplaybackrates:[],gettitle:[]}; |         this.message_wait = {getvolume:[],getmutestatus:[],getduration:[],getcurrenttime:[],getplaybackrate:[],getavailableplaybackrates:[],gettitle:[]}; | ||||||
|     } |     } | ||||||
|  |     async getVideoData(){ | ||||||
|  |         return {video_id:this.videoId,title:this.promise_send_event('gettitle')}; | ||||||
|  |     } | ||||||
| } | } | ||||||
| function invidious_ready(func){ | function invidious_ready(func){ | ||||||
|     if(typeof func==='function'){ |     if(typeof func==='function'){ | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user