Difference between revisions of "Template:Virginia/scripts/seqsJS"

 
(3 intermediate revisions by the same user not shown)
Line 1: Line 1:
 +
var currentSeq;
 +
 
function disableScroll() {  
 
function disableScroll() {  
 
   html=document.getElementsByTagName('html')[0];
 
   html=document.getElementsByTagName('html')[0];
Line 28: Line 30:
 
}
 
}
  
loadSeqViz = function(){
+
//Takes a sequence object and exports it as a .gb file
 +
downloadSeq = function(seq){
 +
  var blob = new Blob([seq.data],{ type: "text/plain;charset=utf-8" });
 +
  saveAs(blob, seq.name+".gb");
 +
}
 +
 
 +
//seqType takes values "linear", "circular", "both", or "both_flip"
 +
seqChange = function(seq){
 +
  currentSeq = seq;
 +
  document.getElementById("seqTitle").innerHTML = seq.name;
 
   seqViewer = document.getElementById('seqVizViewer');
 
   seqViewer = document.getElementById('seqVizViewer');
   var viewer = seqviz
+
   options = {
    .Viewer(seqViewer, {
+
    file: seq.data,
      file: roligoFlipper,
+
    style: {width: "100%", height: "100%"},
      style: {width: "100%", height: "100%"},
+
    copyEvent: (event => event.key === "c" && (event.metaKey || event.ctrlKey)),
      copyEvent: (event => event.key === "c" && (event.metaKey || event.ctrlKey))
+
     viewer: seq.seqType,
     });
+
    showComplement: seq.comp
 +
  }
 +
  var viewer = seqviz.Viewer(seqViewer, options);
 
   viewer.render();
 
   viewer.render();
 
}
 
}
  
fixSeqScrollLauncher = function(){
+
loadSeqViz = function(){
   holder = document.getElementById("seqVizViewer");
+
   pageSeq = window.location.search.split("?").pop();
  holder.addEventListener("mouseover",fixSeqScroll);
+
  if (pageSeq in sequences){
 +
    //Load sequence from queryString
 +
    seqChange(sequences[pageSeq])
 +
    //Prevent scrolling while mouse is over plasmid
 +
    if(!mobileCheck()){
 +
      holder = document.getElementById("seqVizViewer");
 +
      holder.addEventListener("mouseover",fixSeqScroll);
 +
    }
 +
  }else{
 +
    //Show error text
 +
    errorText = document.getElementsByClassName('invalid')[0];
 +
    console.log(errorText)
 +
    errorText.style.visibility = "visible";
 +
  }
 +
}
 +
 
 +
mainCall = function(){
 +
  //Add click event listener to download button
 +
  document.getElementsByClassName('download')[0].addEventListener("click",function(){
 +
    downloadSeq(currentSeq);
 +
  })
 +
  //Populate Sequence Table from sequeneces in sequences object
 +
  table = document.getElementById("seqTable");
 +
  Object.keys(sequences).forEach(function(key){
 +
    seq = sequences[key];
 +
    row = table.insertRow(-1);
 +
    cell1 = row.insertCell(0);
 +
    cell2 = row.insertCell(1);
 +
    cell3 = row.insertCell(2);
 +
    cell1.innerHTML = seq.name;
 +
    cell2.seqData = seq; //Pass seq info to cell element so link can see it
 +
    cell2.innerHTML = "<a onClick='window.location.search=this.parentElement.seqData.varName'>View</a>"
 +
    cell3.seqData = seq; //Pass seq info to cell element so link can see it
 +
    cell3.innerHTML = "<a onClick='downloadSeq(this.parentElement.seqData)'>Download</a>"
 +
  })
 
}
 
}
startupFunctions.push(fixSeqScrollLauncher)
+
startupFunctions.push(mainCall)
  
 
//Make first function to run on page load
 
//Make first function to run on page load
 
startupFunctions.unshift(loadSeqViz)
 
startupFunctions.unshift(loadSeqViz)

Latest revision as of 20:46, 25 October 2020

var currentSeq;

function disableScroll() {

 html=document.getElementsByTagName('html')[0];
 body=document.getElementsByTagName('body')[0];
 html.style.height = "200%";
 body.style.overflow = "hidden";
 body.style.height = "200%";  
 html.style.padding = "0px 10px 0px 0px"

}

function enableScroll() {

 html=document.getElementsByTagName('html')[0];
 body=document.getElementsByTagName('body')[0];
 html.style.height = "auto";
 body.style.overflow = "auto";
 body.style.height = "auto";
 html.style.padding = "0px"

}

fixSeqScroll = function(){

 //Remove Event Listener
 holder.removeEventListener("mouseover",fixSeqScroll);
 //Grab the plasmid viewer
 plasmidViewer = document.getElementsByClassName('la-vz-viewer-event-router')[0];
 //Disable page scroll on mouse over
 plasmidViewer.addEventListener("mouseover",disableScroll)
 //Re-Enable scroll when mouse leaves 
 plasmidViewer.addEventListener("mouseout",enableScroll)

}

//Takes a sequence object and exports it as a .gb file downloadSeq = function(seq){

 var blob = new Blob([seq.data],{ type: "text/plain;charset=utf-8" });
 saveAs(blob, seq.name+".gb");

}

//seqType takes values "linear", "circular", "both", or "both_flip" seqChange = function(seq){

 currentSeq = seq;
 document.getElementById("seqTitle").innerHTML = seq.name;
 seqViewer = document.getElementById('seqVizViewer');
 options =  {
   file: seq.data,
   style: {width: "100%", height: "100%"},
   copyEvent: (event => event.key === "c" && (event.metaKey || event.ctrlKey)),
   viewer: seq.seqType,
   showComplement: seq.comp
 }
 var viewer = seqviz.Viewer(seqViewer, options);
 viewer.render();

}

loadSeqViz = function(){

 pageSeq = window.location.search.split("?").pop();
 if (pageSeq in sequences){
   //Load sequence from queryString
   seqChange(sequences[pageSeq])
   //Prevent scrolling while mouse is over plasmid
   if(!mobileCheck()){
     holder = document.getElementById("seqVizViewer");
     holder.addEventListener("mouseover",fixSeqScroll);
   }
 }else{
   //Show error text
   errorText = document.getElementsByClassName('invalid')[0];
   console.log(errorText)
   errorText.style.visibility = "visible";
 }

}

mainCall = function(){

 //Add click event listener to download button
 document.getElementsByClassName('download')[0].addEventListener("click",function(){
   downloadSeq(currentSeq);
 })
 //Populate Sequence Table from sequeneces in sequences object
 table = document.getElementById("seqTable");
 Object.keys(sequences).forEach(function(key){
   seq = sequences[key];
   row = table.insertRow(-1);
   cell1 = row.insertCell(0);
   cell2 = row.insertCell(1);
   cell3 = row.insertCell(2);
   cell1.innerHTML = seq.name;
   cell2.seqData = seq; //Pass seq info to cell element so link can see it
   cell2.innerHTML = "<a onClick='window.location.search=this.parentElement.seqData.varName'>View</a>"
   cell3.seqData = seq; //Pass seq info to cell element so link can see it
   cell3.innerHTML = "<a onClick='downloadSeq(this.parentElement.seqData)'>Download</a>"
 })

} startupFunctions.push(mainCall)

//Make first function to run on page load startupFunctions.unshift(loadSeqViz)