]> git.ktnx.net Git - icedeb.git/blobdiff - icedeb.js
fixup for d28e9ea: add support for clipboard.readText()
[icedeb.git] / icedeb.js
index c36044c7c6d3a4d75c29cb3cc37f218aaa25f21e..41117778fa9a08fc08acb30ff44b05acb69b465b 100644 (file)
--- a/icedeb.js
+++ b/icedeb.js
@@ -30,6 +30,7 @@ function trim(word) {
     word = word.replace(/^[^a-zA-Z0-9]+/, '');
     word = word.replace(/[^a-zA-Z0-9]+$/, '');
     word = word.replace(/^Bug#/i, '');
+    word = word.replace(/^#/, '');
   } while ( oldword != word );
 
   return word;
@@ -116,15 +117,10 @@ function link_clicked(e) {
     return false;
   }
 
-  if ( !e.target.classList.contains('icedeb-button') )
-    return;
-
-  let autoclose = true;
-
   let clip_input = document.getElementById("clipboard");
   let clip = trim(clip_input.value);
 
-  console.log(clip);
+  if(clip_input.value == '') return;
 
   let url;
 
@@ -142,17 +138,24 @@ function link_clicked(e) {
       url = 'https://lists.debian.org/msgid-search/' + clip;
       break;
     case 'ddpo':
-      url = 'https://qa.debian.org/developer.php';
-      if (clip != '')
-        url += '?login=' + clip;
+      url = 'https://qa.debian.org/developer.php?login=' + clip;
+      break;
+    case 'dmd':
+      url = 'https://udd.debian.org/dmd.cgi?email1=' + clip;
       break;
     case 'buildd':
       url = 'https://buildd.debian.org/' + clip;
       break;
     case 'security':
-      url = 'https://security-tracker.debian.org/';
-      if (clip != '')
-        url += 'tracker/' + clip;
+      clip = clip.replace(' ', '-');
+      clip = clip.toUpperCase();
+      url = 'https://security-tracker.debian.org/tracker/' + clip;
+      break;
+    case 'piuparts':
+      url = `https://piuparts.debian.org/sid/source/${clip.substring(0,1)}/${clip}.html`;
+      break;
+    case 'r-b':
+      url = 'https://tests.reproducible-builds.org/debian/rb-pkg/' + clip + '.html';
       break;
   }
 
@@ -164,8 +167,79 @@ function link_clicked(e) {
       }
     });
 
-window.addEventListener('load', (e) => {
-  document.getElementById('button-list-container').addEventListener('click', link_clicked);
+  e.preventDefault();
+  return false;
+}
+
+function check_likely_inputs(q) {
+  let cnt = document.getElementById('button-list-container').classList;
+
+  cnt.remove('like-b', 'like-p', 'like-m', 'like-i', 'like-s');
+  document.querySelectorAll('.likely')
+    .forEach((el) => {
+        el.classList.remove('likely');
+    });
+
+  q = q.replace(/^\s+/, '');
+  q = q.replace(/\s+$/, '');
+
+  if ( /^#?\d+$/.test(q) || /^CVE-/.test(q) )
+    cnt.add('like-b');
+
+  if ( /^[a-z0-9][a-z0-9\-+.]+$/.test(q) )
+    cnt.add('like-p');
+
+  if ( /.@[a-z0-9-]/i.test(q) )
+    cnt.add('like-m');
+
+  if ( /^<.+@.+>$/.test(q) )
+    cnt.add('like-i');
+
+  if ( /^d[sl]a[- ]\d+(-\d+)?$/i.test(q) )
+    cnt.add('like-s');
+
+  document.querySelectorAll('.like-b .hint.b, .like-p .hint.p, .like-m .hint.m, .like-i .hint.i, .like-s .hint.s')
+    .forEach((el) => {
+      el.parentElement.parentElement.classList.add('likely');
+    } );
+}
+
+function react_to_clipboard_text(text) {
+  let clip_input = document.getElementById("clipboard");
+  clip_input.value = text;
+  clip_input.focus();
+  clip_input.setSelectionRange(0, clip_input.value.length);
+
+  check_likely_inputs(text);
+}
+
+function get_clipboard_contents() {
+  if (navigator.clipboard && navigator.clipboard.readText) {
+    navigator.clipboard.readText().then(function(q){
+      react_to_clipboard_text(q);
+    });
+  }
+  else {
+    let clip_pot = document.getElementById('clip-pot');
+    let clip_input = document.getElementById("clipboard");
+    clip_pot.focus();
+    if (document.execCommand("Paste")) {
+      let q = clip_pot.textContent.trim();
+      react_to_clipboard_text(q);
+    }
+  }
+}
+
+window.addEventListener('DOMContentLoaded', (e) => {
+  document.querySelectorAll('.icedeb-button, #button-list-container a')
+    .forEach(function(el){
+      el.addEventListener('mouseup', link_clicked);
+    });
+
+  document.querySelector('#clipboard')
+    .addEventListener('input', function(ev) {
+      check_likely_inputs(ev.target.value);
+    });
 
   document.addEventListener('change', (e) => {
     if ( !e.target.classList.contains('icedeb-option') )
@@ -174,11 +248,9 @@ window.addEventListener('load', (e) => {
     save_settings();
   });
 
-  let clip_input = document.getElementById("clipboard");
-  clip_input.focus();
-  if (!document.execCommand("paste")) {
-    let err = document.getElementById('error');
-    err.textContent = 'Error retrieving clipboard contents';
-    err.classList.remove('hidden');
-  }
+  window.requestAnimationFrame(()=>{
+    window.requestAnimationFrame(get_clipboard_contents);
+  });
 });
+
+// vim: sw=2