-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathvideo url.js
124 lines (109 loc) · 9.34 KB
/
video url.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
// ==UserScript==
// @name Video URL grabber
// @namespace https://github.com/Rainman69/video-link-grabber
// @homepage https://github.com/Rainman69/video-link-grabber
// @icon 
// @version 1.0
// @description Display video URLs and allow copying on the webpage while playing videos.
// @author https://t.me/TheErfon
// @match *://*/*
// @grant GM_addStyle
// @license CC BY-NC-ND 4.0
// @licenseURL https://github.com/Rainman69/video-link-grabber/blob/main/LICENSE
// ==/UserScript==
(function() {
'use strict';
// Create a container for the video URLs
var videoURLContainer = document.createElement('div');
videoURLContainer.style.position = 'fixed';
videoURLContainer.style.top = '10px';
videoURLContainer.style.left = '10px';
videoURLContainer.style.padding = '5px';
videoURLContainer.style.background = 'none';
videoURLContainer.style.color = '#000';
videoURLContainer.style.fontFamily = 'Times New Roman, serif';
videoURLContainer.style.fontSize = '10px';
videoURLContainer.style.zIndex = '9999';
videoURLContainer.style.cursor = 'pointer';
videoURLContainer.style.userSelect = 'none';
videoURLContainer.style.opacity = '0';
videoURLContainer.style.transition = 'opacity 0.3s ease-in-out';
// Function to extract video URLs from <video> elements
function extractVideoURLs() {
var videoElements = document.getElementsByTagName('video');
var videoURLs = [];
for (var i = 0; i < videoElements.length; i++) {
var videoElement = videoElements[i];
var videoURL = videoElement.currentSrc || videoElement.src;
if (videoURL) {
videoURLs.push(videoURL);
}
}
return videoURLs;
}
// Update the video URLs in the container
function updateVideoURLs() {
var videoURLs = extractVideoURLs();
if (videoURLs.length > 0) {
videoURLContainer.textContent = videoURLs.join('\n');
} else {
videoURLContainer.textContent = 'No video URLs found.';
}
}
// Copy the video URL to the clipboard
function copyURL() {
var textarea = document.createElement('textarea');
textarea.value = videoURLContainer.textContent;
document.body.appendChild(textarea);
textarea.select();
document.execCommand('copy');
document.body.removeChild(textarea);
// Display a confirmation message
videoURLContainer.style.opacity = '1';
videoURLContainer.textContent = 'URL copied!';
setTimeout(function() {
videoURLContainer.style.opacity = '0';
updateVideoURLs();
}, 3000);
}
// Call the updateVideoURLs function initially
updateVideoURLs();
// Add the video URL container to the document body
document.documentElement.appendChild(videoURLContainer);
// Update the video URLs whenever the video elements on the page change
var observer = new MutationObserver(updateVideoURLs);
observer.observe(document.documentElement, { subtree: true, childList: true });
// Show the video URL container when clicked
videoURLContainer.addEventListener('click', copyURL);
// Hide the video URL container on scroll
var isScrolling;
window.addEventListener('scroll', function() {
videoURLContainer.style.opacity = '0';
clearTimeout(isScrolling);
isScrolling = setTimeout(function() {
videoURLContainer.style.opacity = '1';
}, 300);
});
// Get the most used color on the target site and change the text color accordingly
var colors = {};
var elements = document.querySelectorAll('*');
Array.prototype.forEach.call(elements, function(element) {
var computedStyle = getComputedStyle(element);
var color = computedStyle.color;
if (color in colors) {
colors[color]++;
} else {
colors[color] = 1;
}
});
var mostUsedColor = Object.keys(colors).reduce(function(a, b) {
return colors[a] > colors[b] ? a : b;
}, '');
videoURLContainer.style.color = mostUsedColor;
// Add the custom styles to the page using GM_addStyle
GM_addStyle(`
* {
color: ${mostUsedColor} !important;
}
`);
})();