Copy Video Source Link

Copies the source URL of the currently playing video in various streaming sites to clipboard, opens it in a new tab, or provides a safe-to-share link.

// ==UserScript==
// @name         Copy Video Source Link
// @namespace    https://naeembolchhi.github.io/
// @version      2.38
// @description  Copies the source URL of the currently playing video in various streaming sites to clipboard, opens it in a new tab, or provides a safe-to-share link.
// @author       NaeemBolchhi
// @license      GPL-3.0-or-later
// @match        https://www2.movies7.to/*
// @match        https://4anime.biz/*
// @match        https://sflix.to/*
// @match        https://solarmovies.win/*
// @match        https://solarmovie.ma/*
// @match        https://animepahe.com/*
// @match        https://aniwave.to/*
// @match        https://azm.to/*
// @match        https://cineb.net/*
// @match        https://flixtor.video/*
// @match        https://flixtor.id/*
// @match        https://fmovies.to/*
// @match        https://fmovies2.cx/*
// @match        https://fmovies.kim/*
// @match        https://fmovies.ps/*
// @match        https://1fmovies.co/*
// @match        https://streamm4u.com/*
// @match        https://hdonline.co/*
// @match        https://9goaltv.cc/*
// @match        https://9goaltv.in/*
// @match        https://kissasian.li/*
// @match        https://*.fboxtv.com/*
// @match        https://filmoflix.app/*
// @match        https://filmoflix.zip/*
// @icon         
// @run-at       document-idle
// @grant        none
// ==/UserScript==

(function() {
'use strict';

// Various ICONs used in the script.
const toggleSVG = '<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="M0 0h24v24H0z" fill="none"/><path d="M7 11H1v2h6v-2zm2.17-3.24L7.05 5.64 5.64 7.05l2.12 2.12 1.41-1.41zM13 1h-2v6h2V1zm5.36 6.05l-1.41-1.41-2.12 2.12 1.41 1.41 2.12-2.12zM17 11v2h6v-2h-6zm-5-2c-1.66 0-3 1.34-3 3s1.34 3 3 3 3-1.34 3-3-1.34-3-3-3zm2.83 7.24l2.12 2.12 1.41-1.41-2.12-2.12-1.41 1.41zm-9.19.71l1.41 1.41 2.12-2.12-1.41-1.41-2.12 2.12zM11 23h2v-6h-2v6z"/></svg>';
const copySVG = '<svg id="orb-copy-svg" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="M0 0h24v24H0z" fill="none"/><path d="M16 1H4c-1.1 0-2 .9-2 2v14h2V3h12V1zm3 4H8c-1.1 0-2 .9-2 2v14c0 1.1.9 2 2 2h11c1.1 0 2-.9 2-2V7c0-1.1-.9-2-2-2zm0 16H8V7h11v14z"/></svg>';
const copyGREEN = '<svg id="orb-green-svg" style="display: none;" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="M0 0h24v24H0z" fill="none"/><path d="M22,5.18L10.59,16.6l-4.24-4.24l1.41-1.41l2.83,2.83l10-10L22,5.18z M19.79,10.22C19.92,10.79,20,11.39,20,12 c0,4.42-3.58,8-8,8s-8-3.58-8-8c0-4.42,3.58-8,8-8c1.58,0,3.04,0.46,4.28,1.25l1.44-1.44C16.1,2.67,14.13,2,12,2C6.48,2,2,6.48,2,12 c0,5.52,4.48,10,10,10s10-4.48,10-10c0-1.19-0.22-2.33-0.6-3.39L19.79,10.22z"/></svg>';
const copyRED = '<svg id="orb-red-svg" style="display: none;" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="M0 0h24v24H0z" fill="none"/><path d="M12 2C6.48 2 2 6.48 2 12s4.48 10 10 10 10-4.48 10-10S17.52 2 12 2zm0 18c-4.42 0-8-3.58-8-8 0-1.85.63-3.55 1.69-4.9L16.9 18.31C15.55 19.37 13.85 20 12 20zm6.31-3.1L7.1 5.69C8.45 4.63 10.15 4 12 4c4.42 0 8 3.58 8 8 0 1.85-.63 3.55-1.69 4.9z"/></svg>';
const linkSVG = '<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="M0 0h24v24H0z" fill="none"/><path d="M19 19H5V5h7V3H5c-1.11 0-2 .9-2 2v14c0 1.1.89 2 2 2h14c1.1 0 2-.9 2-2v-7h-2v7zM14 3v2h3.59l-9.83 9.83 1.41 1.41L19 6.41V10h2V3h-7z"/></svg>';
const shareSVG = '<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="M0 0h24v24H0z" fill="none"/><path d="M18 16.08c-.76 0-1.44.3-1.96.77L8.91 12.7c.05-.23.09-.46.09-.7s-.04-.47-.09-.7l7.05-4.11c.54.5 1.25.81 2.04.81 1.66 0 3-1.34 3-3s-1.34-3-3-3-3 1.34-3 3c0 .24.04.47.09.7L8.04 9.81C7.5 9.31 6.79 9 6 9c-1.66 0-3 1.34-3 3s1.34 3 3 3c.79 0 1.5-.31 2.04-.81l7.12 4.16c-.05.21-.08.43-.08.65 0 1.61 1.31 2.92 2.92 2.92 1.61 0 2.92-1.31 2.92-2.92s-1.31-2.92-2.92-2.92z"/></svg>';

// Some variables for recognizing links and websites.
let sourceLINK = "document.querySelector('iframe').src";
let sitename = window.location.hostname;

// JSON for site matching.
const siteLIST = [
    {"match": "sflix", "video": "#iframe-embed"},
    {"match": "kissasian", "video": "#my_video_1"}
];

// Loop with siteLIST to set proper sourceLINK value.
(function() {
    for (let x = 0; x < siteLIST.length; x++) {
        if (sitename.match(siteLIST[x].match)) {
            sourceLINK = "document.querySelector('" + siteLIST[x].video + "').src";
        }
    }
})();

// Define dark and light colors.
const orbWhite = `:root {
  --orb-background-100: #f8f8ff;
  --orb-background-95: #eaeaf2;
  --orb-background-reverse: #0f0f0f;
  --orb-foreground: #000000;
  --orb-foreground-reverse: #f8f8ff;
  --orb-warning-red: #ff0000;
  --orb-success-green: #28cc28;
}`;
const orbBlack = `:root {
  --orb-background-100: #0f0f0f;
  --orb-background-95: #1c1c1c;
  --orb-background-reverse: #f8f8ff;
  --orb-foreground: #f8f8ff;
  --orb-foreground-reverse: #0f0f0f;
  --orb-warning-red: #7f0000;
  --orb-success-green: #146614;
}`;

// Function for setting theme choice.
function orbColor() {
    if (sitename.match(/streamm4u/)) {
        return orbBlack;
    } else {
        return orbWhite;
    }
}

// Functions for injecting CSS, JS, and HTML.
function addStyle(css) {
    var head, style;
    head = document.getElementsByTagName('head')[0];
    if (!head) {window.location.reload();}
    style = document.createElement('style');
    style.type = 'text/css';
    style.innerHTML = css;
    head.appendChild(style);
}
function addScript(js) {
    var body, script;
    body = document.getElementsByTagName('body')[0];
    if (!body) {window.location.reload();}
    script = document.createElement('script');
    script.type = "text/javascript";
    script.innerHTML = js;
    body.appendChild(script);
}
function addElement(html) {
    var body, element;
    body = document.getElementsByTagName('body')[0];
    if (!body) {window.location.reload();}
    element = document.createElement('controlcenter');
    element.innerHTML = html;
    body.appendChild(element);
}

// Defining CSS of the script.
const toggleStyle = `
@import url("https://fonts.googleapis.com/css2?family=PT+Sans&display=swap");
${orbColor()}
orbinfo {
  background: var(--orb-background-100);
  border-radius: 50px;
  bottom: 0;
  box-shadow: 0 0 4px 1px rgba(0, 0, 0, 0.45);
  color: var(--orb-foreground);
  font-family: "PT Sans", sans-serif !important;
  font-size: 14px;
  left: 80px;
  line-height: 1;
  opacity: 0;
  padding: 4px 10px;
  position: fixed;
  transition: opacity 240ms ease-in-out;
  white-space: nowrap;
  z-index: -2147483647;
}
orbinfo.orb-toggle {
  transform: translate(0,-39px);
}
orbinfo.orb-copy {
  transform: translate(0,-99px);
}
orbinfo.orb-link {
  transform: translate(0,-159px);
}
orbinfo.orb-share {
  transform: translate(0,-219px);
}
orbinfo.orb-active {
  opacity: 1;
  z-index: 2147483647;
}
orb {
  display: flex;
  align-items: center;
  justify-content: center;
  position: fixed;
  bottom: 30px;
  left: 25px;
  height: 40px;
  width: 40px;
  border-radius: 50%;
  box-shadow: 0 0 4px 1px rgba(0, 0, 0, 0.35);
}
orb:hover {
  box-shadow: 0 0 4.5px 1.5px rgba(0, 0, 0, 0.45);
  cursor: pointer;
}
orb > svg {
  box-sizing: content-box;
  fill: var(--orb-foreground) !important;
  height: 20px;
  width: 20px;
}
orb.orb-control-toggle {
  background: var(--orb-background-100);
  opacity: 0.3;
  transform: translate(0,0);
  z-index: 2147483647;
  transition: transform 150ms ease-in-out, opacity 240ms;
}
orb.orb-control-toggle:hover {
  opacity: 1;
  transition: transform 150ms ease-in-out, opacity 240ms;
}
orb.orb-control-toggle > svg {
  transform: rotate(0deg);
  transition: transform 200ms ease-in-out;
}
orb.orb-control-copy {
  background: var(--orb-background-95);
  transform: translate(0,-60px);
  z-index: 2147483646;
  transition: transform 150ms ease-in-out, opacity 240ms;
}
orb.orb-control-link {
  background: var(--orb-background-95);
  transform: translate(0,-120px);
  z-index: 2147483645;
  transition: transform 150ms ease-in-out, opacity 240ms;
}
orb.orb-control-share {
  background: var(--orb-background-95);
  transform: translate(0,-180px);
  z-index: 2147483644;
  transition: transform 150ms ease-in-out, opacity 240ms;
}
orb.orb-hidden {
  transform: translate(0,0);
  opacity: 0;
  transition: transform 150ms ease-in-out, opacity 240ms;
}
orb.orb-active {
  opacity: 1 !important;
}
orb.orb-active > svg {
  transform: rotate(180deg);
  transition: transform 200ms ease-in-out;
}
orb.orb-color-red {
  background: var(--orb-warning-red) !important;
}
orb.orb-color-green {
  background: var(--orb-success-green) !important;
}
orb.orb-color-red > #orb-red-svg, orb.orb-color-green > #orb-green-svg {
  display: inline !important;
}
orb.orb-color-red > #orb-copy-svg, orb.orb-color-green > #orb-copy-svg {
  display: none !important;
}
orb.orb-color-flip {
  background: var(--orb-background-reverse) !important;
}
orb.orb-color-flip > svg {
  fill: var(--orb-foreground-reverse) !important;
}
div.orb-curtain {
  position: fixed;
  left: 0;
  top: 0;
  height: 100%;
  width: 100%;
  z-index: 2147483640;
}
div.orb-nothing {
  display: none;
}
`;

// Defining HTML of the script.
const toggleElement = `
<orbinfo class="orb-toggle">Toggle Quick Commands</orbinfo>
<orbinfo class="orb-copy">Copy Video Source Link</orbinfo>
<orbinfo class="orb-link">Open Video Source Link in New Tab</orbinfo>
<orbinfo class="orb-share">Get Safely Sharable Video Link</orbinfo>
<orb class="orb-control-toggle" onclick="setOrbLink();">${toggleSVG}</orb>
<orb class="orb-control-copy orb-hidden">${copySVG + copyGREEN + copyRED}</orb>
<a target="_blank"><orb class="orb-control-link orb-hidden">${linkSVG}</orb></a>
<a target="_blank"><orb class="orb-control-share orb-hidden">${shareSVG}</orb></a>
<div class="orb-curtain orb-nothing"></div>
`;

// Defining JS of the script.
const toggleScript = `
function setOrbLink() {
    if (!document.querySelector('iframe')) {
        alert('No video found. Play a video first.');
        return;
    } else {
        document.querySelector('orb.orb-control-link').parentNode.href = ${sourceLINK};
        var encodedLINK = encodeURIComponent(document.querySelector('orb.orb-control-link').parentNode.href);
        document.querySelector('orb.orb-control-share').parentNode.href = "https://disshit.github.io/take.html?x=lnk&y=" + encodedLINK + "&z=1";
    }
}
document.querySelector('orb.orb-control-copy').addEventListener("click", (function() {
    navigator.clipboard.writeText(${sourceLINK}).then(function() {
        document.querySelector('orb.orb-control-copy').classList.add('orb-color-green');
    }, function() {
        document.querySelector('orb.orb-control-copy').classList.add('orb-color-red');
    });
    setTimeout((function(){
        document.querySelector('orb.orb-control-copy').classList.remove('orb-color-green');
        document.querySelector('orb.orb-control-copy').classList.remove('orb-color-red');
    }),1000);
}));

function orbToggleMain() {
    if (document.querySelector('orb.orb-control-copy').className.match(/hidden/i)) {
        if (document.querySelector('iframe')) {
            document.querySelector('orb.orb-control-copy').classList.remove('orb-hidden');
            document.querySelector('orb.orb-control-link').classList.remove('orb-hidden');
            document.querySelector('orb.orb-control-share').classList.remove('orb-hidden');
            document.querySelector('orb.orb-control-toggle').classList.add('orb-active');
            document.querySelector('div.orb-curtain').classList.remove('orb-nothing');
        }
	} else {
        document.querySelector('orb.orb-control-copy').classList.add('orb-hidden');
        document.querySelector('orb.orb-control-link').classList.add('orb-hidden');
        document.querySelector('orb.orb-control-share').classList.add('orb-hidden');
        document.querySelector('orb.orb-control-toggle').classList.remove('orb-active');
        document.querySelector('orbinfo.orb-toggle').classList.remove('orb-active');
        document.querySelector('orbinfo.orb-copy').classList.remove('orb-active');
        document.querySelector('orbinfo.orb-link').classList.remove('orb-active');
        document.querySelector('orbinfo.orb-share').classList.remove('orb-active');
        document.querySelector('div.orb-curtain').classList.add('orb-nothing');
	}
}
document.querySelector('orb.orb-control-toggle').addEventListener("click", orbToggleMain);
document.querySelector('div.orb-curtain').addEventListener("click", orbToggleMain);

document.querySelector('orb.orb-control-link').parentNode.addEventListener("click", (function() {
    document.querySelector('orb.orb-control-link').classList.add('orb-color-flip');
    setTimeout((function(){
        document.querySelector('orb.orb-control-link').classList.remove('orb-color-flip');
    }),1000);
}));
document.querySelector('orb.orb-control-share').parentNode.addEventListener("click", (function() {
    document.querySelector('orb.orb-control-share').classList.add('orb-color-flip');
    setTimeout((function(){
        document.querySelector('orb.orb-control-share').classList.remove('orb-color-flip');
    }),1000);
}));
document.querySelector('orb.orb-control-toggle').addEventListener("mouseover", (function() {
	document.querySelector('orbinfo.orb-toggle').classList.add('orb-active');
}));

document.querySelector('orb.orb-control-toggle').addEventListener("mouseout", (function() {
	document.querySelector('orbinfo.orb-toggle').classList.remove('orb-active');
}));
document.querySelector('orb.orb-control-copy').addEventListener("mouseover", (function() {
	document.querySelector('orbinfo.orb-copy').classList.add('orb-active');
}));
document.querySelector('orb.orb-control-copy').addEventListener("mouseout", (function() {
	document.querySelector('orbinfo.orb-copy').classList.remove('orb-active');
}));
document.querySelector('orb.orb-control-link').addEventListener("mouseover", (function() {
	document.querySelector('orbinfo.orb-link').classList.add('orb-active');
}));
document.querySelector('orb.orb-control-link').addEventListener("mouseout", (function() {
	document.querySelector('orbinfo.orb-link').classList.remove('orb-active');
}));
document.querySelector('orb.orb-control-share').addEventListener("mouseover", (function() {
	document.querySelector('orbinfo.orb-share').classList.add('orb-active');
}));
document.querySelector('orb.orb-control-share').addEventListener("mouseout", (function() {
	document.querySelector('orbinfo.orb-share').classList.remove('orb-active');
}));
`;

// Invoking injection functions with appropriate constants.
addStyle(toggleStyle); addElement(toggleElement); addScript(toggleScript);

})();