about summary refs log tree commit diff stats
path: root/src/pages/popup
diff options
context:
space:
mode:
Diffstat (limited to 'src/pages/popup')
-rw-r--r--src/pages/popup/popup.html16
-rw-r--r--src/pages/popup/popup.js31
-rw-r--r--src/pages/popup/style.css4
3 files changed, 45 insertions, 6 deletions
diff --git a/src/pages/popup/popup.html b/src/pages/popup/popup.html
index 2f83116c..2c4f76d5 100644
--- a/src/pages/popup/popup.html
+++ b/src/pages/popup/popup.html
@@ -169,26 +169,32 @@
 
   <div class="buttons-popup">
     <a class="button" id="change-instance">
-      <svg xmlns="http://www.w3.org/2000/svg" height="24px" viewBox="0 0 24 24" width="24px" fill="currentColor">
+      <svg xmlns="http://www.w3.org/2000/svg" height="26px" viewBox="0 0 24 24" width="26px" fill="currentColor">
         <path
           d="M12 4V1L8 5l4 4V6c3.31 0 6 2.69 6 6 0 1.01-.25 1.97-.7 2.8l1.46 1.46C19.54 15.03 20 13.57 20 12c0-4.42-3.58-8-8-8zm0 14c-3.31 0-6-2.69-6-6 0-1.01.25-1.97.7-2.8L5.24 7.74C4.46 8.97 4 10.43 4 12c0 4.42 3.58 8 8 8v3l4-4-4-4v3z" />
       </svg>
       <x data-localise="__MSG_instance__">Instance</x>
     </a>
     <a class="button" id="more-options">
-      <svg xmlns="http://www.w3.org/2000/svg" enable-background="new 0 0 24 24" height="24px" viewBox="0 0 24 24"
-        width="24px" fill="currentColor">
+      <svg xmlns="http://www.w3.org/2000/svg" enable-background="new 0 0 24 24" height="26px" viewBox="0 0 24 24"
+        width="26px" fill="currentColor">
         <path
           d="M19.14,12.94c0.04-0.3,0.06-0.61,0.06-0.94c0-0.32-0.02-0.64-0.07-0.94l2.03-1.58c0.18-0.14,0.23-0.41,0.12-0.61 l-1.92-3.32c-0.12-0.22-0.37-0.29-0.59-0.22l-2.39,0.96c-0.5-0.38-1.03-0.7-1.62-0.94L14.4,2.81c-0.04-0.24-0.24-0.41-0.48-0.41 h-3.84c-0.24,0-0.43,0.17-0.47,0.41L9.25,5.35C8.66,5.59,8.12,5.92,7.63,6.29L5.24,5.33c-0.22-0.08-0.47,0-0.59,0.22L2.74,8.87 C2.62,9.08,2.66,9.34,2.86,9.48l2.03,1.58C4.84,11.36,4.8,11.69,4.8,12s0.02,0.64,0.07,0.94l-2.03,1.58 c-0.18,0.14-0.23,0.41-0.12,0.61l1.92,3.32c0.12,0.22,0.37,0.29,0.59,0.22l2.39-0.96c0.5,0.38,1.03,0.7,1.62,0.94l0.36,2.54 c0.05,0.24,0.24,0.41,0.48,0.41h3.84c0.24,0,0.44-0.17,0.47-0.41l0.36-2.54c0.59-0.24,1.13-0.56,1.62-0.94l2.39,0.96 c0.22,0.08,0.47,0,0.59-0.22l1.92-3.32c0.12-0.22,0.07-0.47-0.12-0.61L19.14,12.94z M12,15.6c-1.98,0-3.6-1.62-3.6-3.6 s1.62-3.6,3.6-3.6s3.6,1.62,3.6,3.6S13.98,15.6,12,15.6z" />
       </svg>
       <x data-localise="__MSG_settings__">Settings</x>
     </a>
+    <a class="button" id="copy_raw">
+      <svg xmlns="http://www.w3.org/2000/svg" height="24px" viewBox="0 0 24 24" width="24px" fill="currentColor">
+        <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>
+      <x data-localise="__MSG_copyRaw__">Copy Raw</x>
+    </a>
   </div>
 
-
   <script type="module" src="../options/init.js"></script>
   <script type="module" src="./popup.js"></script>
   <script src="../../assets/javascripts/localise.js"></script>
 </body>
 
-</html>
+</html>
\ No newline at end of file
diff --git a/src/pages/popup/popup.js b/src/pages/popup/popup.js
index 14f59dfc..53e8c103 100644
--- a/src/pages/popup/popup.js
+++ b/src/pages/popup/popup.js
@@ -59,6 +59,7 @@ async function wholeInit() {
   await mediumHelper.init();
 };
 
+let copyRawElement = document.getElementById('copy_raw');
 wholeInit().then(() => {
   disableTwitterElement.checked = !twitterHelper.getDisable();
   disableYoutubeElement.checked = !youtubeHelper.getDisable();
@@ -79,6 +80,7 @@ wholeInit().then(() => {
 
   let changeInstanceElement = document.getElementById("change-instance")
   changeInstanceElement.addEventListener("click", switchInstance);
+  copyRawElement.addEventListener("click", copyRaw);
 })
 
 disableTwitterElement.addEventListener("change",
@@ -153,7 +155,6 @@ document.getElementById("more-options").addEventListener("click",
   () => browser.runtime.openOptionsPage()
 );
 
-
 function switchInstance() {
   browser.tabs.query({ active: true, currentWindow: true }, function (tabs) {
     let currTab = tabs[0];
@@ -197,6 +198,34 @@ function switchInstance() {
   return false;
 }
 
+function copyRaw() {
+  browser.tabs.query({ active: true, currentWindow: true }, function (tabs) {
+    let currTab = tabs[0];
+    if (currTab) {
+      let url = currTab.url;
+      let tabUrl
+      try { tabUrl = new URL(url); }
+      catch (_) { return false; }
+      let newUrl;
+      newUrl = youtubeHelper.reverse(tabUrl);
+      if (!newUrl) newUrl = twitterHelper.reverse(tabUrl);
+      if (!newUrl) newUrl = instagramHelper.reverse(tabUrl);
+      if (!newUrl) newUrl = tiktokHelper.reverse(tabUrl);
+      if (!newUrl) newUrl = imgurHelper.reverse(tabUrl);
+      if (newUrl) {
+        navigator.clipboard.writeText(newUrl);
+        const oldHtml = copyRawElement.innerHTML;
+        copyRawElement.innerHTML = `
+        <svg xmlns="http://www.w3.org/2000/svg" height="24px" viewBox="0 0 24 24" width="24px" fill="currentColor">
+          <path d="M9 16.2L4.8 12l-1.4 1.4L9 19 21 7l-1.4-1.4L9 16.2z"/>
+        </svg>
+        Copied`;
+        setTimeout(() => copyRawElement.innerHTML = oldHtml, 1000);
+      }
+    }
+  })
+}
+
 let popupFrontends;
 generalHelper.init().then(() => {
   popupFrontends = generalHelper.getPopupFrontends();
diff --git a/src/pages/popup/style.css b/src/pages/popup/style.css
index a2fc1256..4cc56145 100644
--- a/src/pages/popup/style.css
+++ b/src/pages/popup/style.css
@@ -3,6 +3,10 @@ body {
     min-height: auto;
 }
 
+html, body {
+    margin: 0;
+}
+
 .hide {
     display: none !important;
 }
\ No newline at end of file