aboutsummaryrefslogtreecommitdiffstats
path: root/youtube/static/js/common.js
diff options
context:
space:
mode:
authorJames Taylor <28744867+user234683@users.noreply.github.com>2020-10-13 20:06:52 -0700
committerGitHub <noreply@github.com>2020-10-13 20:06:52 -0700
commite3c311e10a54ae1b7d9114cc58de315157538e0f (patch)
tree36b3325a43db223ba9a999cf8716ea0b1c148322 /youtube/static/js/common.js
parent641af53e2ea0cb7ea398631d13c804d7ac1e0a8a (diff)
parentd2ee49ec453999904381ec592f38a9a34e02044c (diff)
downloadyt-local-e3c311e10a54ae1b7d9114cc58de315157538e0f.tar.lz
yt-local-e3c311e10a54ae1b7d9114cc58de315157538e0f.tar.xz
yt-local-e3c311e10a54ae1b7d9114cc58de315157538e0f.zip
Merge pull request #29 from zrose584/copy_ts
add 't' hotkey to copy video link at current time
Diffstat (limited to 'youtube/static/js/common.js')
-rw-r--r--youtube/static/js/common.js59
1 files changed, 59 insertions, 0 deletions
diff --git a/youtube/static/js/common.js b/youtube/static/js/common.js
index 2997f61..2db4390 100644
--- a/youtube/static/js/common.js
+++ b/youtube/static/js/common.js
@@ -49,6 +49,65 @@ function doXhr(url, callback=null) {
return xhr;
}
+// https://stackoverflow.com/a/30810322
+function copyTextToClipboard(text) {
+ var textArea = document.createElement("textarea");
+
+ //
+ // *** This styling is an extra step which is likely not required. ***
+ //
+ // Why is it here? To ensure:
+ // 1. the element is able to have focus and selection.
+ // 2. if element was to flash render it has minimal visual impact.
+ // 3. less flakyness with selection and copying which **might** occur if
+ // the textarea element is not visible.
+ //
+ // The likelihood is the element won't even render, not even a
+ // flash, so some of these are just precautions. However in
+ // Internet Explorer the element is visible whilst the popup
+ // box asking the user for permission for the web page to
+ // copy to the clipboard.
+ //
+
+ // Place in top-left corner of screen regardless of scroll position.
+ textArea.style.position = 'fixed';
+ textArea.style.top = 0;
+ textArea.style.left = 0;
+
+ // Ensure it has a small width and height. Setting to 1px / 1em
+ // doesn't work as this gives a negative w/h on some browsers.
+ textArea.style.width = '2em';
+ textArea.style.height = '2em';
+
+ // We don't need padding, reducing the size if it does flash render.
+ textArea.style.padding = 0;
+
+ // Clean up any borders.
+ textArea.style.border = 'none';
+ textArea.style.outline = 'none';
+ textArea.style.boxShadow = 'none';
+
+ // Avoid flash of white box if rendered for any reason.
+ textArea.style.background = 'transparent';
+
+
+ textArea.value = text;
+
+ document.body.appendChild(textArea);
+ textArea.focus();
+ textArea.select();
+
+ try {
+ var successful = document.execCommand('copy');
+ var msg = successful ? 'successful' : 'unsuccessful';
+ console.log('Copying text command was ' + msg);
+ } catch (err) {
+ console.log('Oops, unable to copy');
+ }
+
+ document.body.removeChild(textArea);
+}
+
window.addEventListener('DOMContentLoaded', function() {
cur_track_idx = getDefaultTranscriptTrackIdx();