about summary refs log tree commit diff stats
path: root/src
diff options
context:
space:
mode:
Diffstat (limited to 'src')
-rw-r--r--src/assets/javascripts/helpers/youtube/youtube.js64
-rw-r--r--src/pages/background/background.js37
-rw-r--r--src/pages/options/youtube/youtube.html5
-rw-r--r--src/pages/options/youtube/youtube.js40
4 files changed, 92 insertions, 54 deletions
diff --git a/src/assets/javascripts/helpers/youtube/youtube.js b/src/assets/javascripts/helpers/youtube/youtube.js
index 8d4b67d5..b10ceb76 100644
--- a/src/assets/javascripts/helpers/youtube/youtube.js
+++ b/src/assets/javascripts/helpers/youtube/youtube.js
@@ -214,12 +214,12 @@ function setFrontend(val) {
   console.log("youtubeFrontend: ", val)
 }
 
-let freetubeFrontend;
-const getFreetubeFrontend = () => freetubeFrontend;
-function setFreetubeFrontend(val) {
-  freetubeFrontend = val;
-  browser.storage.local.set({ freetubeFrontend })
-  console.log("freetubeFrontend: ", freetubeFrontend)
+let youtubeEmbedFrontend;
+const getYoutubeEmbedFrontend = () => youtubeEmbedFrontend;
+function setYoutubeEmbedFrontend(val) {
+  youtubeEmbedFrontend = val;
+  browser.storage.local.set({ youtubeEmbedFrontend })
+  console.log("youtubeEmbedFrontend: ", youtubeEmbedFrontend)
 }
 
 let persistInvidiousPrefs;
@@ -303,18 +303,24 @@ function isYoutube(url, initiator) {
 function redirect(url, type) {
   if (url.pathname.match(/iframe_api/) || url.pathname.match(/www-widgetapi/)) return null; // Don't redirect YouTube Player API.
 
-  if (frontend == 'freetube' && type === "main_frame")
+  if (frontend == 'yatte' && type === "main_frame")
+    return url.href.replace(/^https?:\/\//, 'yattee://');
+
+  else if (frontend == 'freetube' && type === "main_frame")
     return `freetube://${url}`;
 
-  else if (frontend == 'freetube' && type !== "main_frame" && freetubeFrontend == "youtube")
+  else if (frontend == 'freetube' && type !== "main_frame" && youtubeEmbedFrontend == "youtube")
     return null;
 
-  else if (frontend == 'invidious' || (frontend == 'freetube' && freetubeFrontend == 'invidious' && type == "sub_frame")) {
+  else if (
+    frontend == 'invidious' ||
+    ((frontend == 'freetube' || frontend == 'yatte') && youtubeEmbedFrontend == 'invidious' && type == "sub_frame")
+  ) {
 
     if (OnlyEmbeddedVideo == 'onlyEmbedded' && type !== "sub_frame") return null;
     if (
       OnlyEmbeddedVideo == 'onlyNotEmbedded' && type !== "main_frame" &&
-      !(frontend == 'freetube' && freetubeFrontend == 'invidious' && type === "sub_frame")
+      !((frontend == 'freetube' || frontend == 'yatte') && youtubeEmbedFrontend == 'invidious' && type === "sub_frame")
     ) return null;
 
     let instancesList;
@@ -326,12 +332,15 @@ function redirect(url, type) {
 
     return `${randomInstance}${url.pathname.replace("/shorts/", "/watch?v=")}${url.search}`;
 
-  } else if (frontend == 'piped' || (frontend == 'freetube' && freetubeFrontend == 'piped' && type === "sub_frame")) {
+  } else if (
+    frontend == 'piped' ||
+    ((frontend == 'freetube' || frontend == 'yatte') && youtubeEmbedFrontend == 'piped' && type === "sub_frame")
+  ) {
 
     if (OnlyEmbeddedVideo == 'onlyEmbedded' && type !== "sub_frame") return null;
     if (
       OnlyEmbeddedVideo == 'onlyNotEmbedded' && type !== "main_frame" &&
-      !(frontend == 'freetube' && freetubeFrontend == 'piped' && type == "sub_frame")
+      !((frontend == 'freetube' || frontend == 'yatte') && youtubeEmbedFrontend == 'piped' && type == "sub_frame")
     ) return null;
 
     let instancesList;
@@ -345,6 +354,28 @@ function redirect(url, type) {
   return 'CANCEL';
 }
 
+function changeInstance(url) {
+
+  let protocolHost = `${url.protocol}//${url.host}`;
+  let instancesList;
+  if (frontend == 'invidious') {
+    if (protocol == 'normal') instancesList = [...invidiousNormalRedirectsChecks, ...invidiousNormalCustomRedirects];
+    else if (protocol == 'tor') instancesList = [...invidiousTorRedirectsChecks, ...invidiousTorCustomRedirects];
+  }
+  else if (frontend == 'piped') {
+    if (protocol == 'normal') instancesList = [...pipedNormalRedirectsChecks, ...pipedNormalCustomRedirects];
+    else if (protocol == 'tor') instancesList = [...pipedTorRedirectsChecks, ...pipedTorCustomRedirects];
+  }
+
+  console.log("instancesList", instancesList);
+  let index = instancesList.indexOf(protocolHost);
+  if (index > -1) instancesList.splice(index, 1);
+
+  if (instancesList.length === 0) return null;
+  let randomInstance = commonHelper.getRandomInstance(instancesList);
+  return `${randomInstance}${url.pathname}${url.search}`;
+}
+
 function isPipedorInvidious(url, type) {
   let protocolHost = `${url.protocol}//${url.host}`;
   return (type === "main_frame" || type === "sub_frame") && [
@@ -502,7 +533,7 @@ async function init() {
           "pipedTorRedirectsChecks",
           "pipedTorCustomRedirects",
           "alwaysusePreferred",
-          "freetubeFrontend",
+          "youtubeEmbedFrontend",
 
           "youtubeProtocol",
         ],
@@ -513,7 +544,7 @@ async function init() {
           disable = result.disableYoutube ?? false;
           protocol = result.youtubeProtocol ?? 'normal';
           frontend = result.youtubeFrontend ?? 'piped';
-          freetubeFrontend = result.freetubeFrontend ?? 'invidious';
+          youtubeEmbedFrontend = result.youtubeEmbedFrontend ?? 'invidious';
 
           theme = result.youtubeTheme ?? 'DEFAULT';
           volume = result.youtubeVolume ?? '--';
@@ -553,8 +584,8 @@ export default {
   getFrontend,
   setFrontend,
 
-  getFreetubeFrontend,
-  setFreetubeFrontend,
+  getYoutubeEmbedFrontend,
+  setYoutubeEmbedFrontend,
 
   getRedirects,
   getCustomRedirects,
@@ -563,6 +594,7 @@ export default {
 
   redirect,
   isYoutube,
+  changeInstance,
 
   isPipedorInvidious,
   isUrlPipedorInvidious,
diff --git a/src/pages/background/background.js b/src/pages/background/background.js
index 06c08c27..71ae568a 100644
--- a/src/pages/background/background.js
+++ b/src/pages/background/background.js
@@ -118,17 +118,17 @@ function changeInstance(url) {
   var protocolHost = `${tabUrl.protocol}//${tabUrl.host}`;
   var newUrl;
 
-  if (
-    youtubeHelper.getCustomRedirects().invidious.normal.includes(protocolHost) ||
-    youtubeHelper.getCustomRedirects().piped.normal.includes(protocolHost)
-  )
-    newUrl = 'https://youtube.com';
+  console.log("wewe")
+  newUrl = youtubeHelper.changeInstance(url);
 
-  if (twitterHelper.getRedirects().nitter.normal.includes(protocolHost)) newUrl = 'https://twitter.com';
+  let twitterList = [...twitterHelper.getRedirects().nitter.normal];
+  if (twitterList.includes(protocolHost) && twitterList.length > 1) newUrl = 'https://twitter.com';
 
-  if (instagramHelper.getRedirects().bibliogram.normal.includes(protocolHost)) newUrl = 'https://instagram.com';
+  let instagramList = [...instagramHelper.getRedirects().bibliogram.normal];
+  if (instagramList.includes(protocolHost) && instagramList.length > 1) newUrl = 'https://instagram.com';
 
-  if (redditHelper.getRedirects().libreddit.normal.includes(protocolHost) || redditHelper.getRedirects().teddit.normal.includes(protocolHost)) {
+  let redditList = [...redditHelper.getRedirects().libreddit.normal, ...redditHelper.getRedirects().teddit.normal]
+  if (redditList.includes(protocolHost) && redditList.length > 1) {
     if (tabUrl.pathname.startsWith('/img')) {
       newUrl = "https://i.redd.it"
       tabUrl.href = tabUrl.href.replace("/img", "")
@@ -137,21 +137,20 @@ function changeInstance(url) {
       newUrl = 'https://reddit.com';
   }
 
-  if (
-    searchHelper.getRedirects().searx.normal.includes(protocolHost) ||
-    searchHelper.getRedirects().whoogle.normal.includes(protocolHost)
-  ) newUrl = 'https://google.com';
+  let searchList = [...searchHelper.getRedirects().searx.normal, ...searchHelper.getRedirects().whoogle.normal]
+  if (searchList.includes(protocolHost) && searchList.length > 1) newUrl = 'https://google.com';
 
-  if (
-    translateHelper.getRedirects().simplyTranslate.normal.includes(protocolHost) ||
-    translateHelper.getRedirects().lingva.normal.includes(protocolHost)
-  ) newUrl = 'https://translate.google.com';
+  let translateList = [...translateHelper.getRedirects().simplyTranslate.normal, ...translateHelper.getRedirects().lingva.normal]
+  if (translateList.includes(protocolHost) && translateList.length > 1) newUrl = 'https://translate.google.com';
 
-  if (mediumHelper.getRedirects().scribe.normal.includes(protocolHost)) newUrl = 'https://medium.com';
+  let mediumList = [...mediumHelper.getRedirects().scribe.normal]
+  if (mediumList.includes(protocolHost) && mediumList.length > 1) newUrl = 'https://medium.com';
 
-  if (imgurHelper.getRedirects().rimgo.normal.includes(protocolHost)) newUrl = 'https://imgur.com';
+  let imgurList = [...imgurHelper.getRedirects().rimgo.normal];
+  if (imgurList.includes(protocolHost) && imgurList.length > 1) newUrl = 'https://imgur.com';
 
-  if (wikipediaHelper.getRedirects().wikiless.normal.includes(protocolHost)) newUrl = 'https://wikipedia.com';
+  let wikipediaList = [...wikipediaHelper.getRedirects().wikiless.normal]
+  if (wikipediaList.includes(protocolHost) && wikipediaList.length > 1) newUrl = 'https://wikipedia.com';
 
   if (newUrl) browser.tabs.update({ url: tabUrl.href.replace(protocolHost, newUrl) });
 }
diff --git a/src/pages/options/youtube/youtube.html b/src/pages/options/youtube/youtube.html
index 7482c19d..d35c5c91 100644
--- a/src/pages/options/youtube/youtube.html
+++ b/src/pages/options/youtube/youtube.html
@@ -124,15 +124,16 @@
         <option value="piped">Piped</option>
         <option value="invidious">Invidious</option>
         <option value="freetube">FreeTube</option>
+        <option value="yatte">Yatte</option>
       </select>
     </div>
 
     <hr>
 
-    <div id="freetube">
+    <div id="freetube-yatte">
       <div class="some-block option-block">
         <h4>Embedded Videos Frontend</h4>
-        <select id="freetube-embedded-frontend">
+        <select id="youtube-embed-frontend">
           <option value="invidious">Invidious</option>
           <option value="piped">Piped</option>
           <option value="youtube">Youtube</option>
diff --git a/src/pages/options/youtube/youtube.js b/src/pages/options/youtube/youtube.js
index cee38139..e535e5de 100644
--- a/src/pages/options/youtube/youtube.js
+++ b/src/pages/options/youtube/youtube.js
@@ -6,42 +6,42 @@ let youtubeFrontendElement = document.getElementById("youtube-frontend");
 let invidiousDivElement = document.getElementById("invidious");
 let pipedDivElement = document.getElementById("piped");
 let invidiousPipedDivElement = document.getElementById("invidious-piped");
-let freetubeDivElement = document.getElementById("freetube");
-let freetubeFrontendElement = document.getElementById("freetube-embedded-frontend");
+let freetubeYatteDivElement = document.getElementById("freetube-yatte");
+
 
 function changeFrontendsSettings(frontend) {
     if (frontend == 'piped') {
         invidiousPipedDivElement.style.display = 'block'
         pipedDivElement.style.display = 'block';
         invidiousDivElement.style.display = 'none';
-        freetubeDivElement.style.display = 'none';
+        freetubeYatteDivElement.style.display = 'none';
     }
     else if (frontend == 'invidious') {
         invidiousPipedDivElement.style.display = 'block'
         pipedDivElement.style.display = 'none';
         invidiousDivElement.style.display = 'block';
-        freetubeDivElement.style.display = 'none';
+        freetubeYatteDivElement.style.display = 'none';
     }
-    else if (frontend == 'freetube') {
+    else if (frontend == 'freetube' || frontend == 'yatte') {
         invidiousPipedDivElement.style.display = 'none'
         pipedDivElement.style.display = 'none';
         invidiousDivElement.style.display = 'none';
-        freetubeDivElement.style.display = 'block';
+        freetubeYatteDivElement.style.display = 'block';
     }
 }
 
-function changeFreetubeFrontendsSettings(freetubeFrontend) {
-    if (freetubeFrontend == 'invidious') {
+function changeYoutubeEmbedFrontendsSettings(youtubeEmbedFrontend) {
+    if (youtubeEmbedFrontend == 'invidious') {
         invidiousPipedDivElement.style.display = 'block'
         pipedDivElement.style.display = 'none';
         invidiousDivElement.style.display = 'block';
     }
-    if (freetubeFrontend == 'piped') {
+    if (youtubeEmbedFrontend == 'piped') {
         invidiousPipedDivElement.style.display = 'block'
         pipedDivElement.style.display = 'block';
         invidiousDivElement.style.display = 'none';
     }
-    else if (freetubeFrontend == 'youtube') {
+    else if (youtubeEmbedFrontend == 'youtube') {
         invidiousPipedDivElement.style.display = 'none'
         pipedDivElement.style.display = 'none';
         invidiousDivElement.style.display = 'none';
@@ -52,13 +52,16 @@ youtubeFrontendElement.addEventListener("change",
         let frontend = event.target.options[youtubeFrontendElement.selectedIndex].value
         youtubeHelper.setFrontend(frontend);
         changeFrontendsSettings(frontend);
+        changeYoutubeEmbedFrontendsSettings(youtubeHelper.getYoutubeEmbedFrontend());
     }
 );
-freetubeFrontendElement.addEventListener("change",
+
+let youtubeEmbedFrontendElement = document.getElementById("youtube-embed-frontend");
+youtubeEmbedFrontendElement.addEventListener("change",
     (event) => {
-        let freetubeFrontend = event.target.options[freetubeFrontendElement.selectedIndex].value
-        youtubeHelper.setFreetubeFrontend(freetubeFrontend);
-        changeFreetubeFrontendsSettings(freetubeFrontend);
+        let youtubeEmbedFrontend = event.target.options[youtubeEmbedFrontendElement.selectedIndex].value
+        youtubeHelper.setYoutubeEmbedFrontend(youtubeEmbedFrontend);
+        changeYoutubeEmbedFrontendsSettings(youtubeEmbedFrontend);
     }
 );
 
@@ -148,7 +151,10 @@ youtubeHelper.init().then(() => {
     protocolElement.value = protocol;
     changeProtocolSettings(protocol);
 
-    let freetubeFrontend = youtubeHelper.getFreetubeFrontend()
-    freetubeFrontendElement.value = freetubeFrontend
-    if (frontend == "freetube") changeFreetubeFrontendsSettings(freetubeFrontend);
+    let youtubeEmbedFrontend = youtubeHelper.getYoutubeEmbedFrontend()
+    youtubeEmbedFrontendElement.value = youtubeEmbedFrontend
+    if (frontend == "freetube" || frontend == "yatte") {
+        console.log("youtubeEmbedFrontend", youtubeEmbedFrontend);
+        changeYoutubeEmbedFrontendsSettings(youtubeEmbedFrontend)
+    };
 });