mirror of
				https://github.com/iv-org/invidious.git
				synced 2025-10-29 12:18:29 -05:00 
			
		
		
		
	
		
			
				
	
	
		
			146 lines
		
	
	
		
			5.9 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			146 lines
		
	
	
		
			5.9 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
| 'use strict';
 | |
| 
 | |
| (function () {
 | |
|     var n2a = function (n) { return Array.prototype.slice.call(n); };
 | |
| 
 | |
|     var video_player = document.getElementById('player_html5_api');
 | |
|     if (video_player) {
 | |
|         video_player.onmouseenter = function () { video_player['data-title'] = video_player['title']; video_player['title'] = ''; };
 | |
|         video_player.onmouseleave = function () { video_player['title'] = video_player['data-title']; video_player['data-title'] = ''; };
 | |
|         video_player.oncontextmenu = function () { video_player['title'] = video_player['data-title']; };
 | |
|     }
 | |
| 
 | |
|     // For dynamically inserted elements
 | |
|     document.addEventListener('click', function (e) {
 | |
|         if (!e || !e.target) { return; }
 | |
|         e = e.target;
 | |
|         var handler_name = e.getAttribute('data-onclick');
 | |
|         switch (handler_name) {
 | |
|             case 'jump_to_time':
 | |
|                 var time = e.getAttribute('data-jump-time');
 | |
|                 player.currentTime(time);
 | |
|                 break;
 | |
|             case 'get_youtube_replies':
 | |
|                 var load_more = e.getAttribute('data-load-more') !== null;
 | |
|                 var load_replies = e.getAttribute('data-load-replies') !== null;
 | |
|                 get_youtube_replies(e, load_more, load_replies);
 | |
|                 break;
 | |
|             case 'toggle_parent':
 | |
|                 toggle_parent(e);
 | |
|                 break;
 | |
|             default:
 | |
|                 break;
 | |
|         }
 | |
|     });
 | |
| 
 | |
|     n2a(document.querySelectorAll('[data-mouse="switch_classes"]')).forEach(function (e) {
 | |
|         var classes = e.getAttribute('data-switch-classes').split(',');
 | |
|         var ec = classes[0];
 | |
|         var lc = classes[1];
 | |
|         var onoff = function (on, off) {
 | |
|             var cs = e.getAttribute('class');
 | |
|             cs = cs.split(off).join(on);
 | |
|             e.setAttribute('class', cs);
 | |
|         };
 | |
|         e.onmouseenter = function () { onoff(ec, lc); };
 | |
|         e.onmouseleave = function () { onoff(lc, ec); };
 | |
|     });
 | |
| 
 | |
|     n2a(document.querySelectorAll('[data-onsubmit="return_false"]')).forEach(function (e) {
 | |
|         e.onsubmit = function () { return false; };
 | |
|     });
 | |
| 
 | |
|     n2a(document.querySelectorAll('[data-onclick="mark_watched"]')).forEach(function (e) {
 | |
|         e.onclick = function () { mark_watched(e); };
 | |
|     });
 | |
|     n2a(document.querySelectorAll('[data-onclick="mark_unwatched"]')).forEach(function (e) {
 | |
|         e.onclick = function () { mark_unwatched(e); };
 | |
|     });
 | |
|     n2a(document.querySelectorAll('[data-onclick="add_playlist_video"]')).forEach(function (e) {
 | |
|         e.onclick = function () { add_playlist_video(e); };
 | |
|     });
 | |
|     n2a(document.querySelectorAll('[data-onclick="add_playlist_item"]')).forEach(function (e) {
 | |
|         e.onclick = function () { add_playlist_item(e); };
 | |
|     });
 | |
|     n2a(document.querySelectorAll('[data-onclick="remove_playlist_item"]')).forEach(function (e) {
 | |
|         e.onclick = function () { remove_playlist_item(e); };
 | |
|     });
 | |
|     n2a(document.querySelectorAll('[data-onclick="revoke_token"]')).forEach(function (e) {
 | |
|         e.onclick = function () { revoke_token(e); };
 | |
|     });
 | |
|     n2a(document.querySelectorAll('[data-onclick="remove_subscription"]')).forEach(function (e) {
 | |
|         e.onclick = function () { remove_subscription(e); };
 | |
|     });
 | |
|     n2a(document.querySelectorAll('[data-onclick="notification_requestPermission"]')).forEach(function (e) {
 | |
|         e.onclick = function () { Notification.requestPermission(); };
 | |
|     });
 | |
| 
 | |
|     n2a(document.querySelectorAll('[data-onrange="update_volume_value"]')).forEach(function (e) {
 | |
|         var cb = function () { update_volume_value(e); }
 | |
|         e.oninput = cb;
 | |
|         e.onchange = cb;
 | |
|     });
 | |
| 
 | |
|     function update_volume_value(element) {
 | |
|         document.getElementById('volume-value').innerText = element.value;
 | |
|     }
 | |
| 
 | |
|     function revoke_token(target) {
 | |
|         var row = target.parentNode.parentNode.parentNode.parentNode.parentNode;
 | |
|         row.style.display = 'none';
 | |
|         var count = document.getElementById('count');
 | |
|         count.innerText = count.innerText - 1;
 | |
| 
 | |
|         var referer = window.encodeURIComponent(document.location.href);
 | |
|         var url = '/token_ajax?action_revoke_token=1&redirect=false' +
 | |
|             '&referer=' + referer +
 | |
|             '&session=' + target.getAttribute('data-session');
 | |
|         var xhr = new XMLHttpRequest();
 | |
|         xhr.responseType = 'json';
 | |
|         xhr.timeout = 10000;
 | |
|         xhr.open('POST', url, true);
 | |
|         xhr.setRequestHeader('Content-Type', 'application/x-www-form-urlencoded');
 | |
| 
 | |
|         xhr.onreadystatechange = function () {
 | |
|             if (xhr.readyState == 4) {
 | |
|                 if (xhr.status != 200) {
 | |
|                     count.innerText = parseInt(count.innerText) + 1;
 | |
|                     row.style.display = '';
 | |
|                 }
 | |
|             }
 | |
|         }
 | |
| 
 | |
|         var csrf_token = target.parentNode.querySelector('input[name="csrf_token"]').value;
 | |
|         xhr.send('csrf_token=' + csrf_token);
 | |
|     }
 | |
| 
 | |
|     function remove_subscription(target) {
 | |
|         var row = target.parentNode.parentNode.parentNode.parentNode.parentNode;
 | |
|         row.style.display = 'none';
 | |
|         var count = document.getElementById('count');
 | |
|         count.innerText = count.innerText - 1;
 | |
| 
 | |
|         var referer = window.encodeURIComponent(document.location.href);
 | |
|         var url = '/subscription_ajax?action_remove_subscriptions=1&redirect=false' +
 | |
|             '&referer=' + referer +
 | |
|             '&c=' + target.getAttribute('data-ucid');
 | |
|         var xhr = new XMLHttpRequest();
 | |
|         xhr.responseType = 'json';
 | |
|         xhr.timeout = 10000;
 | |
|         xhr.open('POST', url, true);
 | |
|         xhr.setRequestHeader('Content-Type', 'application/x-www-form-urlencoded');
 | |
| 
 | |
|         xhr.onreadystatechange = function () {
 | |
|             if (xhr.readyState == 4) {
 | |
|                 if (xhr.status != 200) {
 | |
|                     count.innerText = parseInt(count.innerText) + 1;
 | |
|                     row.style.display = '';
 | |
|                 }
 | |
|             }
 | |
|         }
 | |
| 
 | |
|         var csrf_token = target.parentNode.querySelector('input[name="csrf_token"]').value;
 | |
|         xhr.send('csrf_token=' + csrf_token);
 | |
|     }
 | |
| })();
 |