Difference between revisions of "Template:Heidelberg/safetynet/JS"

 
(33 intermediate revisions by the same user not shown)
Line 1: Line 1:
function createTable(name, organism, organism_safety, functionality,
+
function safetyblast_create_table(name, organism, organism_safety,
                    functionality_safety, id, identity, e_value, onkogenes) {
+
                                  functionality, functionality_safety, id,
 +
                                  identity, e_value, onkogenes) {
  
 
   var table_head = [
 
   var table_head = [
Line 11: Line 12:
 
   var thead = document.createElement('thead');
 
   var thead = document.createElement('thead');
 
   var tbody = document.createElement('tbody');
 
   var tbody = document.createElement('tbody');
 +
 +
  $(div).empty();
  
 
   var tr_head = document.createElement('tr');
 
   var tr_head = document.createElement('tr');
Line 59: Line 62:
 
       }
 
       }
  
       if (functionality_safety[j][0] > 1 && k == 3) {
+
       if (functionality_safety[j] && k == 3) {
 
         td_body.style.backgroundColor = 'red';
 
         td_body.style.backgroundColor = 'red';
       } else if (functionality_safety[j][0] <= 1 && k == 3) {
+
       } else if (!functionality_safety[j] && k == 3) {
 
         td_body.style.backgroundColor = 'green';
 
         td_body.style.backgroundColor = 'green';
 
       } else {
 
       } else {
Line 77: Line 80:
 
}
 
}
  
function register_handlers() {
+
function safetynet_create_table(goterms) {
   $("#hyperreference1").one("click", function() {
+
  return getDatabase().then(function(db) {
     sequence = $("#push_sequence")[0].value;
+
    safetynet_create_table_impl(goterms, db);
 +
  });
 +
}
 +
 
 +
function safetynet_create_table_impl(goterms, database) {
 +
  var gored = "#9d1c20";
 +
  var gogreen = "#009e73";
 +
  var goredimg =
 +
      "https://static.igem.org/mediawiki/2017/thumb/d/dd/T--Heidelberg--2017_safety_red.jpg/600px-T--Heidelberg--2017_safety_red.jpg";
 +
  var gogreenimg =
 +
      "https://static.igem.org/mediawiki/2017/thumb/e/ee/T--Heidelberg--2017_safety_green.jpg/600px-T--Heidelberg--2017_safety_green.jpg";
 +
   $("#deeprotein_results").empty();
 +
  $("#deeprotein_results").id = "deeprotein_results";
 +
  var card_section = document.createElement("section");
 +
  card_section.className = "teaser content equal_height";
 +
  card_section.style = "padding-top: 100px";
 +
  var evilgos = Object.keys(database.functions);
 +
  for (let idx = 0; idx < goterms.length; ++idx) {
 +
    var isEvil = false;
 +
    for (let idy = 0; idy < evilgos.length; ++idy) {
 +
      if (goterms[idx].go === evilgos[idy]) {
 +
        isEvil = true;
 +
        break;
 +
      }
 +
    }
 +
    var gocolor = isEvil ? gored : gogreen;
 +
    var goevil = isEvil ? "Potentially Dangerous" : "Safe";
 +
    var goimage = document.createElement("img");
 +
    goimage.src = isEvil ? goredimg : gogreenimg;
 +
    goimage.class = "card-image";
 +
    goimage.style = "width: 100%";
 +
    var gotitle = document.createElement("h4");
 +
    gotitle.class = "card-title";
 +
    $(gotitle).text(goevil);
 +
    var gocontent = document.createElement("p");
 +
    gocontent.class = "card-content";
 +
    $(gocontent).text(goterms[idx].name);
 +
    var gobody = document.createElement("div");
 +
    gobody.class = "card-body";
 +
    gobody.appendChild(gotitle);
 +
    gobody.appendChild(gocontent);
 +
    var gocard = document.createElement("div");
 +
    gocard.className = "card";
 +
    gocard.style = "border-left: 10px solid; border-color: " + gocolor;
 +
    gocard.appendChild(goimage);
 +
    gocard.appendChild(gobody);
 +
    var gocol = document.createElement("div");
 +
    gocol.className = "col-lg-4 col-md-4 col-xs-12";
 +
    gocol.appendChild(gocard);
 +
    card_section.appendChild(gocol);
 +
  }
 +
  if (goterms.length == 0) {
 +
    var gocolor = "#222222";
 +
    var goevil = "Unknown";
 +
    var goimage = document.createElement("img");
 +
    goimage.src = gogreenimg;
 +
    goimage.class = "card-image";
 +
    goimage.style =
 +
        "width: 100%; -webkit-filter:grayscale(100%); -moz-filter:grayscale(100%); -ms-filter:grayscale(100%); -o-filter:grayscale(100%); filter:grayscale(100%);";
 +
    var gotitle = document.createElement("h4");
 +
    gotitle.class = "card-title";
 +
    $(gotitle).text(goevil);
 +
    var gocontent = document.createElement("p");
 +
    gocontent.class = "card-content";
 +
    $(gocontent).text(
 +
        "No potentially harmful GO-terms could be inferred for this sequence.");
 +
    var gobody = document.createElement("div");
 +
    gobody.class = "card-body";
 +
    gobody.appendChild(gotitle);
 +
    gobody.appendChild(gocontent);
 +
    var gocard = document.createElement("div");
 +
    gocard.className = "card";
 +
    gocard.style = "border-left: 10px solid; border-color: " + gocolor;
 +
    gocard.appendChild(goimage);
 +
    gocard.appendChild(gobody);
 +
    var gocol = document.createElement("div");
 +
    gocol.className = "col-lg-4 col-md-4 col-xs-12";
 +
    gocol.appendChild(gocard);
 +
    card_section.appendChild(gocol);
 +
  }
 +
  $("#deep_results").append(card_section);
 +
}
 +
 
 +
function safetyblast_register_handlers() {
 +
  $("#fastablast").on("change", function() {
 +
    let file = $("#fastablast")[0].files[0];
 +
    var reader = new FileReader();
 +
    reader.onload = function() {
 +
      var res = this.result.replace(/ /g, "");
 +
      res = res.replace(/\t/g, "");
 +
      if (res.indexOf(">") != -1 || res.indexOf("\n") != -1) {
 +
        var ressplit = res.split("\n");
 +
        res = "";
 +
        for (let idx = 1; idx < ressplit.length; ++idx) {
 +
          res += ressplit[idx];
 +
        }
 +
      }
 +
      console.log(res);
 +
      $("#blast_sequence").val(res);
 +
    };
 +
    reader.readAsText(file);
 +
  });
 +
  $("#blastit").on("click", function() {
 +
     sequence =
 +
        $("#blast_sequence")[0].value.replace(/ /g, "").replace(/\t/g, "");
 +
    $("#blast_status").text("Starting...");
 +
    $("#blast_status").css("cssText", "background-color: black !important");
 
     doSafetyQuery(sequence).then(function(result) {
 
     doSafetyQuery(sequence).then(function(result) {
       console.log(result);
+
       let nhits = result.hits.length;
      nhits = result.hits.length;
+
       var name = [];
       name = [];
+
       var organism = [];
       organism = [];
+
       var organism_safety = [];
       organism_safety = [];
+
       var functionality = [];
       functionality = [];
+
       var functionality_safety = [];
       functionality_safety = [];
+
       var id = [];
       id = [];
+
       var identity = [];
       identity = [];
+
       var e_value = [];
       e_value = [];
+
       var onkogenes = [];
       onkogenes = [];
+
      console.log("ORGANISMS: ", result.organisms);
+
 
       for (idx = 0; idx < nhits; ++idx) {
 
       for (idx = 0; idx < nhits; ++idx) {
         name.push(result.functions[idx]);
+
         name.push(result.hits[idx].name);
 
         organism.push(result.matches[idx]);
 
         organism.push(result.matches[idx]);
 
         organism_safety.push(result.organisms[idx][1]);
 
         organism_safety.push(result.organisms[idx][1]);
 
         functionality.push(result.functions[idx]);
 
         functionality.push(result.functions[idx]);
         functionality_safety.push(result.onkogenes[idx]);
+
         functionality_safety.push(result.functionality_safety[idx]);
 
         id.push(result.hits[idx].id);
 
         id.push(result.hits[idx].id);
 
         identity.push(result.hits[idx].identity);
 
         identity.push(result.hits[idx].identity);
Line 104: Line 211:
 
         onkogenes.push(result.onkogenes[idx]);
 
         onkogenes.push(result.onkogenes[idx]);
 
       }
 
       }
       createTable(name, organism, organism_safety, functionality,
+
       safetyblast_create_table(name, organism, organism_safety, functionality,
                  functionality_safety, id, identity, e_value, onkogenes);
+
                              functionality_safety, id, identity, e_value,
 +
                              onkogenes);
 +
      $("#blast_status").text("Done!");
 +
      $("#blast_status").css("cssText", "background-color: green !important");
 
     });
 
     });
 
   });
 
   });
Line 111: Line 221:
 
     rid = $("#get_sequence")[0].value;
 
     rid = $("#get_sequence")[0].value;
 
     doSafetyQueryWithRID(rid).then(function(result) {
 
     doSafetyQueryWithRID(rid).then(function(result) {
      console.log(result);
 
 
       let nhits = result.hits.length;
 
       let nhits = result.hits.length;
 
       var name = [];
 
       var name = [];
Line 123: Line 232:
 
       var onkogenes = [];
 
       var onkogenes = [];
 
       for (idx = 0; idx < nhits; ++idx) {
 
       for (idx = 0; idx < nhits; ++idx) {
        console.log("ORGANISMS: ", result.organisms[idx][1]);
+
         name.push(result.hits[idx].name);
         name.push(result.functions[idx]);
+
 
         organism.push(result.matches[idx]);
 
         organism.push(result.matches[idx]);
 
         organism_safety.push(result.organisms[idx][1]);
 
         organism_safety.push(result.organisms[idx][1]);
 
         functionality.push(result.functions[idx]);
 
         functionality.push(result.functions[idx]);
         functionality_safety.push(result.onkogenes[idx]);
+
         functionality_safety.push(result.functionality_safety[idx]);
 
         id.push(result.hits[idx].id);
 
         id.push(result.hits[idx].id);
 
         identity.push(result.hits[idx].identity);
 
         identity.push(result.hits[idx].identity);
Line 134: Line 242:
 
         onkogenes.push(result.onkogenes[idx]);
 
         onkogenes.push(result.onkogenes[idx]);
 
       }
 
       }
       createTable(name, organism, organism_safety, functionality,
+
       safetyblast_create_table(name, organism, organism_safety, functionality,
                  functionality_safety, id, identity, e_value, onkogenes);
+
                              functionality_safety, id, identity, e_value,
 +
                              onkogenes);
 
     });
 
     });
 
   });
 
   });
 
}
 
}
  
$( document ).ready(function() {
+
function safetynet_register_handlers() {
     console.log("READY!");
+
  window.ctx = newDeeProteinContext();
     register_handlers();
+
  ctx.ready();
 +
  $("#download").on("click", function() {
 +
     top.location.href =
 +
        "https://static.igem.org/mediawiki/2017/f/fd/T--Heidelberg--2017_DeeProteinWeights.zip";
 +
  });
 +
  $("#deepweights").on("change", function() {
 +
    var status = $("#deep_status");
 +
    status.text("Loading Weights ...");
 +
    var file = $("#deepweights")[0].files[0];
 +
    ctx.loadWeightsFromFile(file);
 +
  });
 +
  $("#fastadeep").on("change", function() {
 +
    let file = $("#fastadeep")[0].files[0];
 +
    var reader = new FileReader();
 +
    reader.onload = function() {
 +
      var res = this.result.replace(/ /g, "");
 +
      res = res.replace(/\t/g, "");
 +
      if (res.indexOf(">") != -1 || res.indexOf("\n") != -1) {
 +
        var ressplit = res.split("\n");
 +
        res = "";
 +
        for (let idx = 1; idx < ressplit.length; ++idx) {
 +
          res += ressplit[idx];
 +
        }
 +
      }
 +
      console.log(res);
 +
      $("#deep_sequence").val(res);
 +
    };
 +
    reader.readAsText(file);
 +
  });
 +
  $("#deepit").on("click", function() {
 +
    var status = $("#deeprotein_status");
 +
    status.text("Inferring ...");
 +
    let string = $("#deep_sequence")[0].value;
 +
    ctx.infer(string);
 +
  });
 +
  ctx.onready = function() {
 +
    var status = $("#deeprotein_status");
 +
    status.css("cssText", "background-color: black !important");
 +
     status.text("Initialized ...");
 +
  };
 +
  ctx.onloadfile = function() {
 +
    var status = $("#deep_status");
 +
    status.css("cssText", "background-color: blue !important");
 +
    status.text("Weights loaded ...")
 +
  };
 +
  ctx.oninfer = function(result) {
 +
    var status = $("#deep_status");
 +
    safetynet_create_table(result);
 +
    console.log(result);
 +
    status.css("cssText", "background-color: green !important");
 +
    status.text("Inferred!");
 +
  };
 +
}
 +
 
 +
$(document).ready(function() {
 +
  safetyblast_register_handlers();
 +
  safetynet_register_handlers();
 
});
 
});

Latest revision as of 21:09, 1 November 2017

function safetyblast_create_table(name, organism, organism_safety,

                                 functionality, functionality_safety, id,
                                 identity, e_value, onkogenes) {
 var table_head = [
   'Name', 'Organism', 'Group', 'Functionality', 'ID', 'Identity', 'E-Value',
   'Onkogenicity'
 ];
 var div = document.getElementById('safety_table');
 var table = document.createElement('table');
 var thead = document.createElement('thead');
 var tbody = document.createElement('tbody');
 $(div).empty();
 var tr_head = document.createElement('tr');
 for (var i = 0; i < 8; i++) {
   var td_head = document.createElement('th');
   td_head.append(document.createTextNode(table_head[i]));
   tr_head.appendChild(td_head);
 }
 thead.appendChild(tr_head);
 for (var j = 0; j < organism.length; j++) {
   var table_body = [];
   table_body[0] = name[j];
   table_body[1] = organism[j];
   table_body[2] = "S" + organism_safety[j].toString();
   table_body[3] = functionality[j];
   table_body[4] = id[j];
   table_body[5] = identity[j];
   table_body[6] = e_value[j];
   table_body[7] = onkogenes[j];
   var tr_body = document.createElement('tr');
   for (var k = 0; k < 8; k++) {
     var td_body = document.createElement('td');
     if (k == 3) {
       var inner_func = table_body[k].split(',');
       for (var w = 0; w < functionality[j].split(',').length; w++) {
         var tr_inner = document.createElement('tr');
         var td_inner = document.createElement('td');
         td_inner.append(document.createTextNode(inner_func[w]));
         tr_inner.appendChild(td_inner);
         td_body.appendChild(tr_inner);
       }
     } else {
       td_body.append(document.createTextNode(table_body[k]));
       if (organism_safety[j] > 1 && k == 2) {
         td_body.style.backgroundColor = 'red';
       } else if (organism_safety[j] <= 1 && k == 2) {
         td_body.style.backgroundColor = 'green';
       } else {
         // Nothing
       }
     }
     if (functionality_safety[j] && k == 3) {
       td_body.style.backgroundColor = 'red';
     } else if (!functionality_safety[j] && k == 3) {
       td_body.style.backgroundColor = 'green';
     } else {
       // Nothing
     }
     tr_body.appendChild(td_body);
   }
   tbody.appendChild(tr_body);
 }
 table.appendChild(thead);
 table.appendChild(tbody);
 table.className = "table table-bordered mdl-shadow--4dp";
 div.appendChild(table);

}

function safetynet_create_table(goterms) {

 return getDatabase().then(function(db) {
   safetynet_create_table_impl(goterms, db);
 });

}

function safetynet_create_table_impl(goterms, database) {

 var gored = "#9d1c20";
 var gogreen = "#009e73";
 var goredimg =
     "600px-T--Heidelberg--2017_safety_red.jpg";
 var gogreenimg =
     "600px-T--Heidelberg--2017_safety_green.jpg";
 $("#deeprotein_results").empty();
 $("#deeprotein_results").id = "deeprotein_results";
 var card_section = document.createElement("section");
 card_section.className = "teaser content equal_height";
 card_section.style = "padding-top: 100px";
 var evilgos = Object.keys(database.functions);
 for (let idx = 0; idx < goterms.length; ++idx) {
   var isEvil = false;
   for (let idy = 0; idy < evilgos.length; ++idy) {
     if (goterms[idx].go === evilgos[idy]) {
       isEvil = true;
       break;
     }
   }
   var gocolor = isEvil ? gored : gogreen;
   var goevil = isEvil ? "Potentially Dangerous" : "Safe";
   var goimage = document.createElement("img");
   goimage.src = isEvil ? goredimg : gogreenimg;
   goimage.class = "card-image";
   goimage.style = "width: 100%";
   var gotitle = document.createElement("h4");
   gotitle.class = "card-title";
   $(gotitle).text(goevil);
   var gocontent = document.createElement("p");
   gocontent.class = "card-content";
   $(gocontent).text(goterms[idx].name);
   var gobody = document.createElement("div");
   gobody.class = "card-body";
   gobody.appendChild(gotitle);
   gobody.appendChild(gocontent);
   var gocard = document.createElement("div");
   gocard.className = "card";
   gocard.style = "border-left: 10px solid; border-color: " + gocolor;
   gocard.appendChild(goimage);
   gocard.appendChild(gobody);
   var gocol = document.createElement("div");
   gocol.className = "col-lg-4 col-md-4 col-xs-12";
   gocol.appendChild(gocard);
   card_section.appendChild(gocol);
 }
 if (goterms.length == 0) {
   var gocolor = "#222222";
   var goevil = "Unknown";
   var goimage = document.createElement("img");
   goimage.src = gogreenimg;
   goimage.class = "card-image";
   goimage.style =
       "width: 100%; -webkit-filter:grayscale(100%); -moz-filter:grayscale(100%); -ms-filter:grayscale(100%); -o-filter:grayscale(100%); filter:grayscale(100%);";
   var gotitle = document.createElement("h4");
   gotitle.class = "card-title";
   $(gotitle).text(goevil);
   var gocontent = document.createElement("p");
   gocontent.class = "card-content";
   $(gocontent).text(
       "No potentially harmful GO-terms could be inferred for this sequence.");
   var gobody = document.createElement("div");
   gobody.class = "card-body";
   gobody.appendChild(gotitle);
   gobody.appendChild(gocontent);
   var gocard = document.createElement("div");
   gocard.className = "card";
   gocard.style = "border-left: 10px solid; border-color: " + gocolor;
   gocard.appendChild(goimage);
   gocard.appendChild(gobody);
   var gocol = document.createElement("div");
   gocol.className = "col-lg-4 col-md-4 col-xs-12";
   gocol.appendChild(gocard);
   card_section.appendChild(gocol);
 }
 $("#deep_results").append(card_section);

}

function safetyblast_register_handlers() {

 $("#fastablast").on("change", function() {
   let file = $("#fastablast")[0].files[0];
   var reader = new FileReader();
   reader.onload = function() {
     var res = this.result.replace(/ /g, "");
     res = res.replace(/\t/g, "");
     if (res.indexOf(">") != -1 || res.indexOf("\n") != -1) {
       var ressplit = res.split("\n");
       res = "";
       for (let idx = 1; idx < ressplit.length; ++idx) {
         res += ressplit[idx];
       }
     }
     console.log(res);
     $("#blast_sequence").val(res);
   };
   reader.readAsText(file);
 });
 $("#blastit").on("click", function() {
   sequence =
       $("#blast_sequence")[0].value.replace(/ /g, "").replace(/\t/g, "");
   $("#blast_status").text("Starting...");
   $("#blast_status").css("cssText", "background-color: black !important");
   doSafetyQuery(sequence).then(function(result) {
     let nhits = result.hits.length;
     var name = [];
     var organism = [];
     var organism_safety = [];
     var functionality = [];
     var functionality_safety = [];
     var id = [];
     var identity = [];
     var e_value = [];
     var onkogenes = [];
     for (idx = 0; idx < nhits; ++idx) {
       name.push(result.hits[idx].name);
       organism.push(result.matches[idx]);
       organism_safety.push(result.organisms[idx][1]);
       functionality.push(result.functions[idx]);
       functionality_safety.push(result.functionality_safety[idx]);
       id.push(result.hits[idx].id);
       identity.push(result.hits[idx].identity);
       e_value.push(result.hits[idx].evalue);
       onkogenes.push(result.onkogenes[idx]);
     }
     safetyblast_create_table(name, organism, organism_safety, functionality,
                              functionality_safety, id, identity, e_value,
                              onkogenes);
     $("#blast_status").text("Done!");
     $("#blast_status").css("cssText", "background-color: green !important");
   });
 });
 $("#hyperreference2").one("click", function() {
   rid = $("#get_sequence")[0].value;
   doSafetyQueryWithRID(rid).then(function(result) {
     let nhits = result.hits.length;
     var name = [];
     var organism = [];
     var organism_safety = [];
     var functionality = [];
     var functionality_safety = [];
     var id = [];
     var identity = [];
     var e_value = [];
     var onkogenes = [];
     for (idx = 0; idx < nhits; ++idx) {
       name.push(result.hits[idx].name);
       organism.push(result.matches[idx]);
       organism_safety.push(result.organisms[idx][1]);
       functionality.push(result.functions[idx]);
       functionality_safety.push(result.functionality_safety[idx]);
       id.push(result.hits[idx].id);
       identity.push(result.hits[idx].identity);
       e_value.push(result.hits[idx].evalue);
       onkogenes.push(result.onkogenes[idx]);
     }
     safetyblast_create_table(name, organism, organism_safety, functionality,
                              functionality_safety, id, identity, e_value,
                              onkogenes);
   });
 });

}

function safetynet_register_handlers() {

 window.ctx = newDeeProteinContext();
 ctx.ready();
 $("#download").on("click", function() {
   top.location.href =
       "https://static.igem.org/mediawiki/2017/f/fd/T--Heidelberg--2017_DeeProteinWeights.zip";
 });
 $("#deepweights").on("change", function() {
   var status = $("#deep_status");
   status.text("Loading Weights ...");
   var file = $("#deepweights")[0].files[0];
   ctx.loadWeightsFromFile(file);
 });
 $("#fastadeep").on("change", function() {
   let file = $("#fastadeep")[0].files[0];
   var reader = new FileReader();
   reader.onload = function() {
     var res = this.result.replace(/ /g, "");
     res = res.replace(/\t/g, "");
     if (res.indexOf(">") != -1 || res.indexOf("\n") != -1) {
       var ressplit = res.split("\n");
       res = "";
       for (let idx = 1; idx < ressplit.length; ++idx) {
         res += ressplit[idx];
       }
     }
     console.log(res);
     $("#deep_sequence").val(res);
   };
   reader.readAsText(file);
 });
 $("#deepit").on("click", function() {
   var status = $("#deeprotein_status");
   status.text("Inferring ...");
   let string = $("#deep_sequence")[0].value;
   ctx.infer(string);
 });
 ctx.onready = function() {
   var status = $("#deeprotein_status");
   status.css("cssText", "background-color: black !important");
   status.text("Initialized ...");
 };
 ctx.onloadfile = function() {
   var status = $("#deep_status");
   status.css("cssText", "background-color: blue !important");
   status.text("Weights loaded ...")
 };
 ctx.oninfer = function(result) {
   var status = $("#deep_status");
   safetynet_create_table(result);
   console.log(result);
   status.css("cssText", "background-color: green !important");
   status.text("Inferred!");
 };

}

$(document).ready(function() {

 safetyblast_register_handlers();
 safetynet_register_handlers();

});