remember position of column titles
[newtab.git] / admin.js
index 0c9e0d44660a6ecc8191f41aadf1e1182b52a13b..ddc08c5e2aff6cd442b4ffbbb12e082c62e5e5f0 100644 (file)
--- a/admin.js
+++ b/admin.js
 var mainlist;
-
-//chrome.tabs.create({ url: chrome.extension.getURL("newtab.html") });
-//window.close();
-
+var rmspan = ["<span class='remove' id='delete-", "'>–</span>"]
 document.addEventListener("DOMContentLoaded", function() {
-       chrome.storage.sync.get(
-{"lists": [
-    [
+  chrome.storage.sync.get(
+    {"lists": [
+      ["General",
         ["Github", "https://github.com"],
         ["Wikipedia", "https://en.wikipedia.org"],
         ["Gmail", "https://mail.google.com"]
-    ],
-    [
+      ],
+      ["Productivity",
         ["Desmos", "https://www.desmos.com/calculator"],
         ["Wolfram", "https://wolframalpha.com"],
         ["Hacker News", "https://news.ycombinator.com"]
-    ],
-    [
+      ],
+      ["Social",
         ["Reddit", "https://www.reddit.com"],
         ["YouTube", "https://youtube.com"],
         ["Instagram", "https://instagram.com"]
+      ]
     ]
-],
-"l1name": "General",
-"l2name": "Productivity",
-"l3name": "Social"},
-       userListsCallback);
+},
+    userListsCallback);
 });
 
+function columnToArray(list) {
+  var l = [];
+  var elem = list.getElementsByClassName("item");
+  for (var i = 0; i < elem.length; ++i) {
+    l[i] = [elem[i].innerText, elem[i].getAttribute("href")];
+  }
+  return l;
+}
+
 function listToArray(list) {
-       var l = [];
-       var elem = list.getElementsByTagName("li");
-       for (var i = 0; i < elem.length; ++i) {
-         l[i] = [elem[i].getElementsByTagName("a")[0].innerText, elem[i].getElementsByTagName("a")[0].getAttribute("href")];
-       }
-       return l;
+  var l = [];
+  console.log(list);
+  console.log(list.getElementsByClassName('title')[0].getElementsByTagName("p")[0].textContent);
+  l[0] = list.getElementsByClassName('title')[0].getElementsByTagName("p")[0].textContent;
+  var elem = list.getElementsByTagName("li");
+  for (var i = 0; i < elem.length; ++i) {
+    l[i+1] = [elem[i].getElementsByTagName("a")[0].innerText, elem[i].getElementsByTagName("a")[0].getAttribute("href")];
+  }
+  return l;
 }
 
 var userListsCallback = function(lists) {
-       mainlist = [lists["l1name"],lists["l2name"],lists["l3name"]]
-       for(var i=0;i<lists["lists"].length;i++) {
-               var div = document.createElement("div");
-               div.setAttribute("class", "favorites-list users-list");
-               document.getElementById("links").appendChild(div);
-
-               var ul = document.createElement("ul");
-               ul.setAttribute("id", mainlist[i]);
-               div.appendChild(ul);
-
-               var title = document.createElement("div");
-               title.setAttribute("class", "title");
-               ul.appendChild(title);
-
-               var p = document.createElement("p");
-               p.innerText = mainlist[i];
-               title.appendChild(p);
-
-               title.insertAdjacentHTML("beforeend", "<span id='add-"+mainlist[i]+"'>+</span>");
-
-               var list = lists["lists"][i];
-               for(var j=0;j<lists["lists"][i].length;j++) {
-                       var li = document.createElement("li");
-                       li.setAttribute("id", mainlist[i]+"-"+j);
-                       var siteurl = list[j][1];
-                       var name = list[j][0];
-                       // ronmurphy change start
-                       var img = document.createElement("img");
-                                               img.className = "icon";
-                                               img.src = "http://www.google.com/s2/favicons?domain="+siteurl+"";
-                       li.insertAdjacentHTML("beforeend", "<a href="+siteurl+"> <img src="+img.src+" alt="+extractDomain(siteurl,1)+"/> "+name+"</a>");
-                       // ronmurphy end
-                       //li.insertAdjacentHTML("beforeend", "<a href="+siteurl+">"+name+"</a>");
-                       li.insertAdjacentHTML("beforeend", "<span id='delete-"+j+"-"+mainlist[i]+"'>&#10799;</span>");
-                       ul.appendChild(li);
-               }
-
-               var sortable = Sortable.create(ul, {
-                       group: "userlists",
-                       onUpdate: function (evt) {
-                               save();
-                       }
-               });
-       }
-
-       menu();
+  console.log(lists);
+  console.log(lists['lists'][0][0]);
+  mainlist = [lists['lists'][0][0],lists['lists'][1][0],lists['lists'][2][0]]
+  for(var i=0;i<lists["lists"].length;i++) {
+    var ul = document.createElement("ul");
+    ul.setAttribute("id", mainlist[i]);
+    ul.setAttribute('draggable', 'true');
+    ul.addEventListener('dragstart', dragStart, false);
+    ul.addEventListener('dragenter', dragEnter, false);
+    ul.addEventListener('dragover', dragOver, false);
+    ul.addEventListener('dragleave', dragLeave, false);
+    ul.addEventListener('drop', drop, false);
+    document.getElementById("links").appendChild(ul);
+
+    var grip = document.createElement("span");
+    grip.setAttribute("class", "grip");
+
+    var title = document.createElement("div");
+    title.setAttribute("class", "title");
+    title.appendChild(grip)
+    ul.appendChild(title);
+
+    var p = document.createElement("p");
+    p.innerText = mainlist[i];
+    title.appendChild(p);
+
+    title.insertAdjacentHTML("beforeend", "<span class='add' id='add-"+mainlist[i]+"'>+</span>");
+
+    var list = lists["lists"][i];
+    for(var j=1;j<lists["lists"][i].length;j++) {
+      var li = document.createElement("li");
+      li.setAttribute("id", mainlist[i]+"-"+j);
+      var siteurl = list[j][1];
+      var nme = list[j][0];
+      var img = document.createElement("img");
+      img.className = "icon";
+      img.src = "https://www.google.com/s2/favicons?domain="+siteurl+"";
+      li.insertAdjacentHTML("beforeend", "<a class='item' href="+siteurl+"><img src="+img.src+" alt="+extractDomain(siteurl,1)+"/> "+nme+"</a>");
+      li.insertAdjacentHTML("beforeend", rmspan[0] + j + "-" + mainlist[i] + rmspan[1]);
+      ul.appendChild(li);
+    }
+
+    new Sortable(ul, {
+      group: "userlists",
+      animation: 150,
+      onUpdate: function (evt) {
+        save();
+      }
+    });
+  }
+
+  menu();
 
 };
 
+function dragStart(e) {
+  console.log(this);
+  dragSrcEl = this;
+  e.dataTransfer.effectAllowed = 'move';
+  e.dataTransfer.setData('text/html', this.innerHTML);
+}
+
+function dragOver(e) {
+  if (e.preventDefault) {
+    e.preventDefault();
+  }
+  e.dataTransfer.dropEffect = 'move';
+  return false;
+}
+
+function dragEnter(e) {
+  this.classList.add('over');
+}
+
+function dragLeave(e) {
+  this.classList.remove('over');
+}
+
+function drop(e) {
+  if (e.stopPropagation); {
+    e.stopPropagation();
+  }
+  if (dragSrcEl != this) {
+    console.log(mainlist);
+    dragSrcEl.innerHTML = this.innerHTML;
+    this.innerHTML = e.dataTransfer.getData('text/html');
+    save();
+  }
+  return false;
+}
+
+var dragSrcEl = null;
+
+document.onkeyup=function(e){
+  var e = e || window.event; // for IE to cover IEs window event-object
+  fields = document.getElementsByClassName("new");
+  if(e.which == 27 && fields != null) {
+    fields[fields.length-1].remove();
+    return false;
+  }
+  if(e.which == 13 && fields.length > 0) {
+    fields[fields.length-1].getElementsByClassName("save")[0].click();
+    return false;
+  }
+}
+
 function listen(li) {
-       li.addEventListener('click', function(event){
-               var r = event.target.id.split("-");
-               if (r[0] == "delete") {
-                       var el = document.getElementById(r[2]+"-"+r[1]);
-                       el.outerHTML = "";
-                       delete el;
-                       save();
-               } else {
-                       var ul = document.getElementById(r[1]);
-                       ul.insertAdjacentHTML("beforeend", "<div class='inp' id='div-"+listToArray(ul).length.toString()+"'><input style='width:35%' type='text' class='name' value='' placeholder='name'><input style='width:47%' type='text' class='url' value='' placeholder='url' id='form-"+listToArray(ul).length.toString()+"'><a id='input-"+listToArray(ul).length.toString()+"'>&#x2714;</a></div>");
-                       var inp = document.getElementById("div-"+listToArray(ul).length.toString());
-                       var span = document.getElementById("input-"+listToArray(ul).length.toString());
-                       var form = document.getElementById("form-"+listToArray(ul).length.toString());
-
-                       form.addEventListener('keyup', function(event){
-                               if (event.keyCode == 13) {
-                                       span.click();
-                               }
-                       });
-
-                       span.addEventListener('click', function(event){
-                               inp.outerHTML = "";
-                               delete inp;
-
-                               if (inp.getElementsByClassName("name")[0].value != "" || inp.getElementsByClassName("url")[0].value != "") {
-                                       var li = document.createElement("li");
-                                       li.setAttribute("id",r[1]+"-"+listToArray(ul).length.toString());
-                                       //var splitted = splitHostname(inp.getElementsByClassName("url")[0].value); fix later
-                                       var siteurl = addhttp(inp.getElementsByClassName("url")[0].value);
-                                       var name = inp.getElementsByClassName("name")[0].value;
-
-                                       li.insertAdjacentHTML("beforeend", "<a href="+siteurl+">"+name+"</a>");
-                                       li.insertAdjacentHTML("beforeend", "<span id='delete-"+listToArray(ul).length.toString()+"-"+r[1]+"'>-</span>");
-                                       document.getElementById(r[1]).appendChild(li);
-                                       save();
-                                       listen(li);
-                               }
-                       });
-               }
-       }, false);
+  li.addEventListener('click', function(event){
+    var r = event.target.id.split("-");
+    if (r[0] == "delete") {
+      var el = document.getElementById(r[2]+"-"+r[1]);
+      el.outerHTML = "";
+      delete el;
+      save();
+    } else {
+      var ul = document.getElementById(r[1]);
+      if (document.querySelectorAll("#"+r[1]+" .new").length > 0) {
+        fields = document.querySelector("#"+r[1]+" .new .name");
+        fields.focus(); 
+        return false;
+      }
+      var li = document.createElement("li");
+      li.setAttribute("class", "new");
+      li.insertAdjacentHTML("beforeend", "<span class='save' tabindex='3' id='input-"+columnToArray(li).length.toString()+"'>&#x2714;</span><input type='text' class='name' value='' placeholder='name' tabindex='1'><br /><input type='url' spellcheck=false class='url' value='' placeholder='url' tabindex='2' id='form-"+columnToArray(li).length.toString()+"'>");
+      ul.appendChild(li);
+      var span = document.getElementById("input-"+columnToArray(li).length.toString());
+      var form = document.getElementById("form-"+columnToArray(li).length.toString());
+      span.addEventListener('click', function(event){
+        var li = document.getElementsByClassName("new")[0]
+        var ul = li.parentNode;
+        if (li.getElementsByClassName("name")[0].value != "" && li.getElementsByClassName("url")[0].value != "" && li.getElementsByClassName("url")[0].validity.typeMismatch== false) {
+          var newli = document.createElement("li");
+          newli.setAttribute("id",r[1]+"-"+columnToArray(ul).length.toString());
+          var siteurl = addhttp(li.getElementsByClassName("url")[0].value);
+          var nme = li.getElementsByClassName("name")[0].value;
+          li.remove()
+          delete li;
+
+          newli.insertAdjacentHTML("beforeend", "<a href="+siteurl+">"+nme+"</a>");
+          newli.insertAdjacentHTML("beforeend", rmspan[0]+columnToArray(ul).length.toString()+"-"+r[1]+rmspan[1]);
+          document.getElementById(r[1]).appendChild(newli);
+          save();
+          listen(newli);
+        }
+        else {
+          if (li.getElementsByClassName("name")[0].value == "" && li.getElementsByClassName("url")[0].value == "") {
+            console.log("No data supplied, deleting form");
+            this.parentNode.remove();
+          }
+          else {
+            console.log("Missing data, press Esc to delete form");
+          }
+        }
+      });
+      span.onmouseover = function() {
+        nme = document.getElementsByClassName("name")[0];
+        url = document.getElementsByClassName("url")[0];
+        if (nme.value === ''  || url.value === '' || url.validity.typeMismatch == true) {
+          this.style.background = "#bf616a";
+        }
+        else {
+          this.style.background = "#a3be8c";
+        }
+      };
+      span.onmouseout = function() {
+        this.style.background = "#848ead";
+      };
+      fields = document.querySelector("#"+r[1]+" .new .name");
+      fields.focus(); 
+    }
+  }, false);
 }
 
 function menu() {
-       var allUserLi = document.querySelectorAll('.users-list > ul > li > span, .users-list > ul > .title > span');
+  var allUserLi = document.querySelectorAll('.remove, .add');
 
-       allUserLi.forEach(function(li, p_index){
-       listen(li);
-    });
+  allUserLi.forEach(function(li, p_index){
+    listen(li);
+  });
 }
 
 function save(l) {
-       var set = l || JSON.parse(JSON.stringify(mainlist));
-       d = []
-       d = set;
-       for (var i = 0; i < set.length; ++i) {
-               e = document.getElementById(set[i]);
-               d[i] = listToArray(e);
-       }
-       chrome.storage.sync.set( {"lists": d} );
+  var set = l || JSON.parse(JSON.stringify(mainlist));
+  console.log(set);
+  d = []
+  d = set;
+  console.log("Saving settings");
+  for (var i = 0; i < set.length; ++i) {
+    d[i] = listToArray(document.getElementById(set[i]));
+  }
+  chrome.storage.sync.set( {"lists": d} );
 }