diff --git a/public/build/asset-manifest.json b/public/build/asset-manifest.json
index 7344716..6dd8c9c 100644
--- a/public/build/asset-manifest.json
+++ b/public/build/asset-manifest.json
@@ -1,8 +1,8 @@
{
"files": {
"main.css": "/static/css/main.86a4484a.chunk.css",
- "main.js": "/static/js/main.0b9b0faa.chunk.js",
- "main.js.map": "/static/js/main.0b9b0faa.chunk.js.map",
+ "main.js": "/static/js/main.d723f0fa.chunk.js",
+ "main.js.map": "/static/js/main.d723f0fa.chunk.js.map",
"runtime-main.js": "/static/js/runtime-main.82eb8401.js",
"runtime-main.js.map": "/static/js/runtime-main.82eb8401.js.map",
"static/js/2.a90056d8.chunk.js": "/static/js/2.a90056d8.chunk.js",
@@ -15,6 +15,6 @@
"static/js/runtime-main.82eb8401.js",
"static/js/2.a90056d8.chunk.js",
"static/css/main.86a4484a.chunk.css",
- "static/js/main.0b9b0faa.chunk.js"
+ "static/js/main.d723f0fa.chunk.js"
]
}
\ No newline at end of file
diff --git a/public/build/index.html b/public/build/index.html
index 069adff..c842bd9 100644
--- a/public/build/index.html
+++ b/public/build/index.html
@@ -1 +1 @@
-
CrisprBuildr
\ No newline at end of file
+CrisprBuildr
\ No newline at end of file
diff --git a/public/build/static/js/main.0b9b0faa.chunk.js b/public/build/static/js/main.0b9b0faa.chunk.js
deleted file mode 100644
index 310bac9..0000000
--- a/public/build/static/js/main.0b9b0faa.chunk.js
+++ /dev/null
@@ -1,2 +0,0 @@
-(this.webpackJsonpcrispr_buildr=this.webpackJsonpcrispr_buildr||[]).push([[0],[,function(e,t,s){"use strict";t.a=""},,,,,,,function(e,t,s){"use strict";(function(e){s.d(t,"a",(function(){return N}));var i=s(9),n=s(10),a=s(11),c=s(2),l=s(22),A=s(21),r=s(3),o=s.n(r),h=(s(33),s(12)),d=s(13),j=s(14),m=s(15),g=s(16),u=s(17),b=s(18),v=s(19),x=s(20),O=s(1),p=s(4),C=s(0),f="http://localhost:8080",N=function(t){Object(l.a)(r,t);var s=Object(A.a)(r);function r(e){var t;return Object(n.a)(this,r),(t=s.call(this,e)).state={menu:null,screen:0,hamburger:!1,themeColor:!1,highlights:[],currentHighlight:null,fontSize:23,fontMenu:!1,geneInfo:null,popup:{show:!1,message:null,image:null},currentPam:null},t.changeMenus=t.changeMenus.bind(Object(c.a)(t)),t.highlight=t.highlight.bind(Object(c.a)(t)),t.saveCurrentHighlight=t.saveCurrentHighlight.bind(Object(c.a)(t)),t}return Object(a.a)(r,[{key:"changeMenus",value:function(e){var t=parseInt(e.target.dataset.menu);t===this.state.menu&&(t=null),this.setState({menu:t},(function(){}))}},{key:"changeScreens",value:function(e){var t=this,s=e.target.dataset.screen;console.log(s);var i=null;1==s&&(i=1),this.setState({screen:parseInt(s),hamburger:!1,menu:i},(function(){console.log(t.state),3==s&&t.setState({mutatePam:!0})}))}},{key:"openMenu",value:function(e){e.target.dataset.screen;this.setState({hamburger:!this.state.hamburger})}},{key:"changeThemeColor",value:function(e){this.setState({themeColor:!this.state.themeColor})}},{key:"closeAllMenus",value:function(e){}},{key:"closePopup",value:function(e){this.setState({popup:{show:!1}})}},{key:"highlight",value:function(e,t){}},{key:"fontMenu",value:function(e){this.setState({fontMenu:!this.state.fontMenu})}},{key:"changeFontSize",value:function(e){var t=parseInt(e.target.value);this.setState({fontSize:t},(function(){}))}},{key:"saveDesign",value:function(){var e=JSON.stringify(this.state),t=this.state.geneName+".txt",s=new Blob([e],{type:"text/plain;charset=utf-8"});Object(p.saveAs)(s,t),this.setState({hamburger:!1})}},{key:"openDesign",value:function(e){var t=this,s=new FileReader;this.setState({popup:{show:!0,message:Object(C.jsx)("h2",{children:"Uploading File"}),image:O.a,stayOpen:!0}},(function(){s.onloadend=function(e){var s=JSON.parse(e.target.result);s.popup=null,s.hamburger=!1,t.setState(s,(function(){console.log(t.state)}))},e.target.value.length&&s.readAsText(e.target.files[0])}))}},{key:"viewFinishedDesign",value:function(){var e=this,t=Object.keys(this.state.targets[0]).map((function(t){return Object(C.jsxs)("div",{children:[Object(C.jsxs)("b",{children:[t,":"]})," ",e.state.targets[0][t]]})})),s=Object.keys(this.state.primers).map((function(t){var s=e.state.primers[t];if(e.state.selectedArms&&e.state.selectedArms[t]){var i=e.state.selectedArms[t];return Object(C.jsxs)("div",{children:[Object(C.jsx)("div",{className:"",children:Object(C.jsx)("b",{children:t})}),Object(C.jsxs)("div",{className:"",children:[Object(C.jsx)("div",{children:i[7]}),Object(C.jsx)("div",{children:Object(C.jsxs)("div",{children:["Tm: ",i[3]]})}),Object(C.jsx)("div",{children:Object(C.jsxs)("div",{children:["GC%: ",i[4]]})}),Object(C.jsx)("div",{children:Object(C.jsxs)("div",{children:["Any (Self Complementarity): ",i[5]]})}),Object(C.jsx)("div",{children:Object(C.jsxs)("div",{children:["3' (Self Complementarity): ",i[6]]})})]}),Object(C.jsx)("br",{})]})}return Object(C.jsxs)("div",{children:[Object(C.jsx)("div",{className:"",children:Object(C.jsx)("b",{children:t})}),s.map((function(e){return Object(C.jsxs)("div",{className:"",children:[Object(C.jsx)("div",{children:e[7]}),Object(C.jsx)("div",{children:Object(C.jsxs)("div",{children:["Tm: ",e[3]]})}),Object(C.jsx)("div",{children:Object(C.jsxs)("div",{children:["GC%: ",e[4]]})}),Object(C.jsx)("div",{children:Object(C.jsxs)("div",{children:["Any (Self Complementarity): ",e[5]]})}),Object(C.jsx)("div",{children:Object(C.jsxs)("div",{children:["3' (Self Complementarity): ",e[6]]})})]})})),Object(C.jsx)("br",{})]})})),i=Object(C.jsxs)("div",{children:[Object(C.jsx)("h2",{children:"Design Info"}),Object(C.jsxs)("div",{children:[Object(C.jsx)("h3",{children:"Target Info"}),t]}),Object(C.jsxs)("div",{children:[Object(C.jsx)("h3",{children:"Homology Info"}),s]}),Object(C.jsxs)("div",{children:[Object(C.jsx)("h3",{children:"Oligo Info"}),Object(C.jsxs)("div",{children:[Object(C.jsx)("b",{children:"Sense: "}),this.state.oligos.sense]}),Object(C.jsxs)("div",{children:[Object(C.jsx)("b",{children:"Antisense: "}),this.state.oligos.antisense]})]})]});this.setState({popup:{show:!0,message:i,image:null,stayOpen:!1}})}},{key:"saveCurrentHighlight",value:function(){var e=this,t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:null,s=arguments.length>1&&void 0!==arguments[1]?arguments[1]:null,i=JSON.parse(JSON.stringify(this.state.currentHighlight));t&&(i.color=t);var n=this.state.highlights;s?n[s]=i:n[i.name]=i,"targetSearch"==i.name?this.searchForTargets():this.setState({highlights:n},(function(){console.log(e.state)}))}},{key:"changeCurrentHighlight",value:function(e){var t=this.state.currentHighlight;t.location=e,this.setState({currentHighlight:t})}},{key:"stringLocation",value:function(){var e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:null,t=arguments.length>1?arguments[1]:void 0;if(!t)return this.state.sequence.indexOf(e);var s=this.state.sequence.indexOf(e);console.log("location",s);e.length;if(-1==s){var i=this.revComp(e);console.log("rev",i),s=this.state.sequence.indexOf(i)}return s}},{key:"highlightString",value:function(e){var t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:null,s=arguments.length>2&&void 0!==arguments[2]?arguments[2]:null;console.log("string: ",e," color: ",t);var i=this.stringLocation(e,s);console.log(i),-1==i&&(i=this.stringLocation(this.revComp(e),s)),-1==i&&(i=0);var n=e.length;t||(t="rgba(252, 210, 126, 0.3)"),this.setState({currentHighlight:{location:i,length:n,color:t,name:s||"cutsite"}})}},{key:"clearHighlight",value:function(){}},{key:"revComp",value:function(e){for(var t=[],s=0;sc.length?e.push(c.slice(s,c.length)):e.push(c.slice(s,s+10)),e.push(""),s+=10}return e.join(" ")}()),x=e.state.geneName+".ape",O=new Blob([v],{type:"text/plain;charset=utf-8"});Object(p.saveAs)(O,x)}))}))}},{key:"changePlasmidTemplate",value:function(e){var t=this,s=e.target.value;this.setState({plasmidTemplate:s},(function(){console.log(t.state.plasmidTemplate)}))}},{key:"downloadPlasmidTemplate",value:function(e){var t=this;if(e.preventDefault(),!this.state.plasmidTemplate)return!1;var s=window.location.origin+"/plasmid_folder/"+this.state.plasmidTemplate.split(" ").join("%20")+".txt";console.log(s),fetch(s).then((function(e){return e.text()})).then((function(e){var s=e.split("**arm_1_start**")[0],i=t.state.targets[0].distal+t.state.targets[0].proximal+t.state.targets[0].pam,n=t.state.sequence.search("-"===t.state.targets[0].strand?t.revComp(i):i),a=t.state.sequence.slice(n-1e3,n),c=e.split("**arm_1_end**")[1].split("**arm_2_start**")[0],l=t.state.sequence.slice(n,n+1e3),A=e.split("**arm_2_end**")[1];if(t.state.mutatedPam){var r=t.state.potentialTargets[0].strand,o="-"===r?t.revComp(t.state.target):t.state.target,h=a+l,d=h.toLowerCase().match(o.toLowerCase());a=(h="-"===r?h.substr(0,d.index)+t.state.currentPam+h.substr(d.index+3,h.length):h.substr(0,d.index+o.length-3)+t.state.currentPam+h.substr(d.index+o.length,h.length)).slice(0,Math.floor(h.length/2)+1),l=h.slice(Math.floor(h.length/2),h.length)}for(var j=e.split("**arm_1_start**")[1].split("**arm_1_end**")[0].split(""),m=0,g=e.split("**arm_2_start**")[1].split("**arm_2_end**")[0].split(""),u=0,b=0;b=i&&a0)for(var l=0;l=o&&a1?"":"none"},onClick:this.changeMenus.bind(this),"data-menu":"2",alt:"sidebar2",children:Object(C.jsx)("img",{src:m.a})}),Object(C.jsxs)("label",{onClick:this.changeScreens.bind(this),"data-screen":"2",children:[Object(C.jsx)("div",{className:"arrow-down",children:"^"}),"Select Cut Site"]}),a?Object(C.jsx)("div",{className:"target-list",style:{display:2==this.state.menu?"flex":"none"},children:a}):null]}),Object(C.jsxs)("div",{className:(3==this.state.menu?"active":"")+" menu-icon","data-menu":"3",children:[Object(C.jsx)("div",{className:"menu-image-wrapper",style:{pointerEvents:this.state.screen>2?"":"none"},onClick:this.changeMenus.bind(this),"data-menu":"3",alt:"sidebar3",children:Object(C.jsx)("img",{src:g.a,alt:"sidebar3"})}),Object(C.jsx)("label",{onClick:this.changeScreens.bind(this),"data-screen":"3",children:"Mutate Pam"}),this.state.screen<3?null:Object(C.jsx)("div",{className:"pam-box",style:{display:this.state.mutatePam?"flex":"none"},children:c})]}),Object(C.jsxs)("div",{className:(4==this.state.menu?"active":"")+" menu-icon","data-menu":"4",children:[Object(C.jsx)("div",{className:"menu-image-wrapper",style:{pointerEvents:this.state.screen>3?"":"none"},onClick:this.changeMenus.bind(this),"data-menu":"4",alt:"sidebar4",children:Object(C.jsx)("img",{src:j.a,alt:"sidebar4"})}),Object(C.jsx)("label",{onClick:this.changeScreens.bind(this),"data-screen":"4",children:"Homology Arm Primers"}),Object(C.jsx)("div",{className:"target-list homology-list",style:{display:4==this.state.menu?"flex":"none"},children:function(){if(e.state.primers){var t=Object.keys(e.state.primers).map((function(t){var s=e.state.primers[t];if(e.state.selectedArms&&e.state.selectedArms[t]){var i=e.state.selectedArms[t];return Object(C.jsxs)("div",{children:[Object(C.jsx)("div",{className:"homology-label",children:t}),Object(C.jsxs)("div",{className:"single-target",onMouseDown:e.selectHomologyArm.bind(e,i,t),onMouseLeave:e.clearHighlight.bind(e),children:[Object(C.jsx)("div",{children:i[7]}),Object(C.jsxs)("div",{children:[Object(C.jsx)("div",{children:"Tm: "}),Object(C.jsx)("div",{children:i[3]})]}),Object(C.jsxs)("div",{children:[Object(C.jsx)("div",{children:"GC%: "}),Object(C.jsx)("div",{children:i[4]})]}),Object(C.jsxs)("div",{children:[Object(C.jsx)("div",{children:"Any (Self Complementarity): "}),Object(C.jsx)("div",{children:i[5]})]}),Object(C.jsxs)("div",{children:[Object(C.jsx)("div",{children:"3' (Self Complementarity): "}),Object(C.jsx)("div",{children:i[6]})]})]})]})}return Object(C.jsxs)("div",{children:[Object(C.jsx)("div",{className:"homology-label",children:t}),s.map((function(s){return Object(C.jsxs)("div",{className:"single-target",onMouseEnter:e.highlightString.bind(e,s[7],"rgba(86, 64, 155,0.3)","homology"),onMouseDown:e.selectHomologyArm.bind(e,s,t),onMouseLeave:e.clearHighlight.bind(e),children:[Object(C.jsx)("div",{children:s[7]}),Object(C.jsxs)("div",{children:[Object(C.jsx)("div",{children:"Tm: "}),Object(C.jsx)("div",{children:s[3]})]}),Object(C.jsxs)("div",{children:[Object(C.jsx)("div",{children:"GC%: "}),Object(C.jsx)("div",{children:s[4]})]}),Object(C.jsxs)("div",{children:[Object(C.jsx)("div",{children:"Any (Self Complementarity): "}),Object(C.jsx)("div",{children:s[5]})]}),Object(C.jsxs)("div",{children:[Object(C.jsx)("div",{children:"3' (Self Complementarity): "}),Object(C.jsx)("div",{children:s[6]})]})]})}))]})}));return Object(C.jsx)("div",{children:t})}}()})]}),Object(C.jsxs)("div",{className:(5==this.state.menu?"active":"")+" menu-icon","data-menu":"5",children:[Object(C.jsx)("div",{className:"menu-image-wrapper sidebar-5",style:{pointerEvents:this.state.screen>3?"":"none"},onClick:this.changeMenus.bind(this),"data-menu":"5",alt:"sidebar5",children:Object(C.jsx)("img",{src:u.a,alt:"sidebar5"})}),Object(C.jsx)("label",{onClick:this.changeScreens.bind(this),"data-screen":"5",children:"Download Data"}),5==this.state.menu?function(){for(var t=["N terminal SSPB and mCherry tag","N terminal EGFP and SSPB tag with Extended Linker","C terminal mCherry and SSPB tag","C terminal EGFP and SSPB tag with Extended Linker","C terminal EGFP and SSPB tag","C terminal mDendra2 and SSPB tag","C terminal mScarlett and SSPB tag","N terminal EGFP and SSPB tag","N terminal mDendra2 and SSPB tag","N terminal mScarlett and SSPB tag"],s=[],i=-1;i=4?"flex":"none"},children:[Object(C.jsxs)("div",{className:"gene-name",children:["Gene: ",this.state.geneName,this.state.isoForm?" - Isoform: "+this.state.isoForm:""]}),Object(C.jsxs)("div",{className:"gene-info-wrapper",style:{fontSize:this.state.fontSize},children:[Object(C.jsx)("div",{className:"gene-info gene-info-highlights",children:null}),Object(C.jsx)("div",{className:"gene-info gene-info-sequence",children:n})]})]})]})]}),Object(C.jsxs)("div",{className:"footer",children:[Object(C.jsx)("div",{children:"Cabernard Lab"}),Object(C.jsx)("div",{children:"Sound Development Company"}),Object(C.jsx)("div",{children:"GPL3 License"}),Object(C.jsx)("div",{children:"API Docs"})]}),Object(C.jsx)("div",{className:"popups",style:{display:!0===this.state.fontMenu?"flex":"none"},children:Object(C.jsxs)("div",{className:"font-size",children:[Object(C.jsx)("div",{className:"close",onClick:this.fontMenu.bind(this),children:"X"}),Object(C.jsx)("h4",{children:"Change Font Size"}),Object(C.jsx)("form",{children:Object(C.jsx)("input",{type:"number",value:this.state.fontSize,onChange:this.changeFontSize.bind(this)})})]})}),e.state.popup?Object(C.jsx)("div",{className:"popup-wrapper",style:{display:e.state.popup.show?"flex":"none"},children:Object(C.jsxs)("div",{className:"popup",children:[e.state.popup.stayOpen?null:Object(C.jsx)("div",{className:"popup-close",onClick:e.closePopup.bind(e),children:"X"}),Object(C.jsx)("div",{className:"message",children:e.state.popup.message}),e.state.popup.image?Object(C.jsx)("img",{className:"blink",src:e.state.popup.image}):""]})}):null]})}}]),r}(o.a.Component)}).call(this,s(29).Buffer)},,,,function(e,t,s){"use strict";t.a=""},function(e,t,s){"use strict";t.a=""},function(e,t,s){"use strict";t.a=""},function(e,t,s){"use strict";t.a=""},function(e,t,s){"use strict";t.a=""},function(e,t,s){"use strict";t.a=""},function(e,t,s){"use strict";t.a=""},function(e,t,s){"use strict";t.a=""},function(e,t,s){"use strict";t.a=""},,,function(e,t,s){"use strict";s.r(t);s(3);var i=s(7),n=s.n(i),a=(s(28),s(8)),c=s(0);n.a.render(Object(c.jsx)("span",{children:Object(c.jsx)(a.a,{})}),document.getElementById("root"))},,,,,function(e,t,s){},,,,,function(e,t,s){}],[[23,1,2]]]);
-//# sourceMappingURL=main.0b9b0faa.chunk.js.map
\ No newline at end of file
diff --git a/public/build/static/js/main.0b9b0faa.chunk.js.map b/public/build/static/js/main.0b9b0faa.chunk.js.map
deleted file mode 100644
index 62fbdce..0000000
--- a/public/build/static/js/main.0b9b0faa.chunk.js.map
+++ /dev/null
@@ -1 +0,0 @@
-{"version":3,"sources":["assets/loading.png","App.js","assets/logo.png","assets/sidebar1.png","assets/sidebar2.png","assets/sidebar3.png","assets/sidebar4.png","assets/document-icon.png","assets/landing1.png","assets/landing2.png","assets/hamburger.png","index.js"],"names":["urlBase","App","props","state","menu","screen","hamburger","themeColor","highlights","currentHighlight","fontSize","fontMenu","geneInfo","popup","show","message","image","currentPam","changeMenus","bind","highlight","saveCurrentHighlight","e","parseInt","target","dataset","this","setState","console","log","mutatePam","data","size","value","design","JSON","stringify","filename","geneName","blob","Blob","type","saveAs","reader","FileReader","loading","stayOpen","onloadend","res","newState","parse","result","length","readAsText","files","targetHTML","Object","keys","targets","map","prop","primerHTML","primers","key","primerOptions","selectedArms","primerSingle","className","oligos","sense","antisense","color","name","searchForTargets","i","location","string","sequence","indexOf","revString","revComp","stringLocation","dna","push","reverse","join","preventDefault","stopPropagation","url","elements","fetch","then","json","currentState","isoForm","isoForms","options","onSubmit","pickIsoForm","isoFormSequence","makeIsoFormHighlights","startSequence","substr","stopSequence","start","stop","popupForm","chooseTerminal","isoform","terminal","tag","targetGenes","substring","response","efficiencyString","results","distal","proximal","encodeURIComponent","gene","score","scrollTop","windowHeight","window","innerHeight","document","getElementsByClassName","getBoundingClientRect","top","scrollTo","behavior","targetArea","targetSearch","primerSections","slice","primerSectionsString","Buffer","from","toString","newPam","getPrimers","selection","arm","currentArms","totalSelected","pam","origin","text","res2","targetI","feature","newFeature","loc","split","targetMatch","toLowerCase","match","revTargetMatch","index","pamStart","featureArr","date","Date","day","getDate","month","getMonth","year","getFullYear","geneArr","spaces","str","spaceArr","makeGeneArr","template","plasmidTemplate","preArm1","searchSequence","search","strand","arm1","postArm1","arm2","postArm2","mutatedPam","potentialTargets","arms","Math","floor","replaceArm1","arm1I","replaceArm2","arm2I","y","isNaN","preSplit","postSplit","root","querySelector","rootMargin","threshold","observer","IntersectionObserver","entries","forEach","entry","isIntersecting","intersectionRatio","currentHighlightEl","observe","highlightKeys","currentHighlightLocation","geneInfoPrep","letter","highlightClasses","includes","targetList","onClick","pickCutSite","onMouseEnter","highlightString","onMouseLeave","clearHighlight","offtarget","pamBox","cutsite","frameI","abs","style","backgroundColor","pamBoxReadingFrames","closeAllMenus","src","logo","alt","openMenu","display","changeScreens","saveDesign","changeThemeColor","sidebar1","pointerEvents","sidebar3","sidebar4","sidebar2","onMouseDown","selectHomologyArm","HomologyList","documentIcon","plasmidOptions","htmlOptions","default","viewFinishedDesign","downloadApeFile","downloadGuideRna","onChange","changePlasmidTemplate","downloadPlasmidTemplate","downloadOptions","landing1","for","landing2","id","openDesign","searchForGene","changeFontSize","closePopup","React","Component","ReactDOM","render","getElementById"],"mappings":"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","file":"static/js/main.0b9b0faa.chunk.js","sourcesContent":["export default \"\"","import React, { Fragment } from 'react';\nimport './App.css';\nimport logo from './assets/logo.png';\nimport sidebar1 from './assets/sidebar1.png';\nimport sidebar2 from './assets/sidebar2.png';\nimport sidebar3 from './assets/sidebar3.png';\nimport sidebar4 from './assets/sidebar4.png';\nimport documentIcon from './assets/document-icon.png';\nimport landing1 from './assets/landing1.png'; \nimport landing2 from './assets/landing2.png';\nimport hamburger from './assets/hamburger.png';\nimport loading from './assets/loading.png';\nimport { saveAs } from 'file-saver';\n\nconst urlBase = 'http://142.93.118.6';//'http://142.93.118.6';\nexport default class App extends React.Component {\n constructor(props) {\n super(props);\n this.state = {\n // Informational & API related\n menu:null,\n screen:0,\n hamburger:false,\n themeColor:false,\n highlights:[],\n currentHighlight: null,\n fontSize:23,\n fontMenu:false,\n geneInfo:null,\n popup:{\n show:false,\n message:null,\n image:null\n },\n currentPam:null,\n }\n // API\n this.changeMenus = this.changeMenus.bind(this);\n this.highlight = this.highlight.bind(this);\n this.saveCurrentHighlight = this.saveCurrentHighlight.bind(this);\n }\n\n // UI\n changeMenus(e) {\n let menu = parseInt(e.target.dataset.menu); \n //console.log(menu);\n if(menu===this.state.menu){\n menu = null;\n }\n this.setState({menu:menu},()=>{\n //console.log(this.state);\n });\n }\n changeScreens(e) {\n let screen = e.target.dataset.screen; \n console.log(screen);\n let menu = null;\n if(screen==1){\n menu=1;\n }\n this.setState({screen:parseInt(screen),hamburger:false,menu:menu},()=>{\n console.log(this.state);\n if(screen==3){\n this.setState({mutatePam:true});\n }\n });\n }\n openMenu(e) {\n let screen = e.target.dataset.screen; \n //console.log(screen);\n this.setState({hamburger:!this.state.hamburger});\n }\n changeThemeColor(e) {\n this.setState({themeColor:!this.state.themeColor});\n }\n closeAllMenus(e) {\n //this.setState({menu:null,hamburger:false});\n }\n closePopup(e) {\n this.setState({popup:{show:false}});\n }\n highlight(e,data){\n /*let highlight = parseInt(e.target.dataset.value);\n console.log(highlight);*/\n /*this.setState({highlight:highlight},()=>{\n //console.log(this.state);\n });*/\n }\n fontMenu(e) {\n this.setState({fontMenu:!this.state.fontMenu});\n }\n changeFontSize(e){\n let size = parseInt(e.target.value);\n this.setState({fontSize:size},()=>{\n //console.log(this.state);\n });\n }\n saveDesign() {\n const design = JSON.stringify(this.state);\n var filename = this.state.geneName+\".txt\";\n var blob = new Blob([design], {\n type: \"text/plain;charset=utf-8\"\n });\n saveAs(blob, filename);\n this.setState({hamburger:false});\n }\n openDesign(e) {\n const reader = new FileReader();\n this.setState({popup:{\n show:true,\n message:Uploading File
,\n image:loading,\n stayOpen:true,\n }},()=>{\n reader.onloadend = (res) => {\n let newState = JSON.parse(res.target.result);\n newState['popup'] = null;\n newState['hamburger'] = false;\n this.setState(newState,()=>{\n console.log(this.state);\n });\n };\n if(e.target.value.length) {\n reader.readAsText(e.target.files[0]);\n }\n });\n\n }\n viewFinishedDesign(){\n let targetKeys = Object.keys(this.state.targets[0]);\n let targetHTML = targetKeys.map((prop)=>{\n\n return {prop}: {this.state.targets[0][prop]}
;\n });\n let primerKeys = Object.keys(this.state.primers);\n //console.log('primer keys',primerKeys);\n let primerHTML = primerKeys.map((key)=>{\n let primerOptions = this.state.primers[key];\n //console.log('this primer',primerOptions);\n if(this.state.selectedArms&&this.state.selectedArms[key]){\n let primerSingle = this.state.selectedArms[key];\n return {key}
\n
\n
{primerSingle[7]}
\n
\n
\n
Any (Self Complementarity): {primerSingle[5]}
\n
3' (Self Complementarity): {primerSingle[6]}
\n
;\n } else {\n return {key}
{primerOptions.map((primerSingle)=>{\n return
\n
{primerSingle[7]}
\n
\n
\n
Any (Self Complementarity): {primerSingle[5]}
\n
3' (Self Complementarity): {primerSingle[6]}
\n
})}
;\n }\n });\n let message = \n
Design Info
\n
Target Info
{targetHTML}\n
Homology Info
\n {primerHTML}\n \n
\n
Oligo Info
\n
Sense: {this.state.oligos.sense}
\n
Antisense: {this.state.oligos.antisense}
\n
\n
;\n this.setState({popup:{\n show:true,\n message:message,\n image:null,\n stayOpen:false,\n }});\n }\n saveCurrentHighlight(color=null,name=null){\n let highlight = JSON.parse(JSON.stringify(this.state.currentHighlight));\n //console.log('highlight',highlight);\n if(color){\n highlight.color = color;\n }\n let highlights = this.state.highlights;\n \n if(name){\n highlights[name] = highlight;\n } else {\n highlights[highlight.name] = highlight;\n }\n //console.log(highlights);\n if(highlight.name=='targetSearch'){\n //console.log('search for targets');\n this.searchForTargets();\n } else {\n\n this.setState({highlights:highlights},()=>{\n console.log(this.state);\n \n });\n }\n }\n changeCurrentHighlight(i){\n let currentHighlight = this.state.currentHighlight;\n currentHighlight.location = i;\n this.setState({currentHighlight:currentHighlight});\n }\n stringLocation(string=null,type){\n if(!type){\n return this.state.sequence.indexOf(string);\n }\n let location = this.state.sequence.indexOf(string);\n console.log('location',location);\n let length = string.length;\n \n if(location==-1){\n \n let revString = this.revComp(string);\n console.log('rev',revString);\n location = this.state.sequence.indexOf(revString); \n //location = location+(length/2)-4;\n } else {\n // location = location+(length/2)-1;\n }\n return location;\n }\n highlightString(string,color=null,type=null){\n console.log('string: ',string,' color: ',color);\n //console.log(this.state.sequence);\n let location = this.stringLocation(string,type);\n console.log(location);\n if(location==-1){\n location = this.stringLocation(this.revComp(string),type);\n }\n if(location==-1){\n location = 0;\n }\n let length = string.length;\n if(!color){\n color = 'rgba(252, 210, 126, 0.3)';\n }\n //console.log('mousenter');\n //console.log(location,length,color);\n this.setState({currentHighlight:{\n location:location,\n length:length,\n color:color,\n name:!type?'cutsite':type\n }\n });\n }\n clearHighlight(){\n //console.log('mouseleave');\n //this.setState({currentHighlight:null});\n }\n\n revComp(dna) {\n let revComp = [];\n for(let i=0;iSearching For Gene,\n image:loading,\n stayOpen:true,\n }}, ()=>{\n fetch(url).then((res) =>{return res.json()}).then((geneInfo)=>{\n console.log('response',geneInfo);\n let currentState = this.state;\n if(geneInfo.isoForm==null){\n currentState.popup = {\n show:false,\n };\n currentState.isoForm = null;\n } else {\n\n let isoForms = JSON.parse(geneInfo.isoForms);\n //console.log('isoforms');\n let options = Choose Your IsoForm
;\n //console.log('options made');\n currentState.popup = {\n show:true,\n message:options,\n image:null\n };\n currentState.isoForm = geneInfo.isoForm;\n }\n currentState.geneName = geneInfo.name;\n currentState.screen = 2;\n currentState.sequence = geneInfo.sequence;\n currentState.isoFormSequence = geneInfo.isoFormSequence;\n \n\n this.setState(currentState,()=>{\n this.makeIsoFormHighlights();\n });\n });\n });\n }\n makeIsoFormHighlights(){\n let startSequence = this.state.isoFormSequence.substr(0,9);\n let stopSequence = this.state.isoFormSequence.substr(this.state.isoFormSequence.length-10,this.state.isoFormSequence.length);\n let startIndex = this.state.sequence.indexOf(startSequence);\n let stopIndex = this.state.sequence.indexOf(stopSequence)+7;\n //console.log(startIndex,startSequence);\n //console.log(stopIndex,stopSequence);\n let highlights = {\n start:{\n location:startIndex,\n length:3,\n color:'#93E593',\n },\n stop:{\n location:stopIndex,\n length:3,\n color:'#FF668E',\n }\n };\n let popupForm = Choose Your Tag
;\n this.setState({\n screen:2,\n popup:{\n show:false,\n },\n highlights:highlights,\n popup:{\n show:true,\n message:popupForm,\n image:null,\n stayOpen:true,\n }\n });\n }\n pickIsoForm(e){\n e.preventDefault();\n //console.log(e.target.isoform.value);\n let isoForm = e.target.isoform.value;\n //console.log(isoForm,this.state.isoForm);\n //console.log(this.state.isoFormSequence);\n if(isoForm==this.state.isoForm){\n //console.log('same isoForm');\n this.makeIsoFormHighlights();\n } else {\n let url = urlBase+'/api/?type=isoform&isoform='+isoForm;\n fetch(url).then((res) =>{return res.json()}).then((geneInfo)=>{\n //console.log('response',geneInfo);\n let currentState = this.state;\n currentState.isoForm = geneInfo.isoForm;\n currentState.isoFormSequence = geneInfo.isoFormSequence;\n\n \n let startSequence = this.state.isoFormSequence.substr(0,9);\n let stopSequence = this.state.isoFormSequence.substr(this.state.isoFormSequence.length-10,this.state.isoFormSequence.length);\n let startIndex = this.state.sequence.indexOf(startSequence);\n let stopIndex = this.state.sequence.indexOf(stopSequence)+7;\n //console.log(startIndex,startSequence);\n //console.log(stopIndex,stopSequence);\n let highlights = {\n start:{\n location:startIndex,\n length:3,\n color:'#93E593',\n },\n stop:{\n location:stopIndex,\n length:3,\n color:'#FF668E',\n }\n }\n currentState.highlights = highlights;\n let popupForm = Choose Your Tag
;\n \n currentState.popup = {\n show:true,\n message:popupForm,\n image:null,\n stayOpen:true,\n };\n /*currentState.currentHighlight = {\n location:null,\n length:100,\n color:'#FCD27E',\n name:'targetSearch'\n }*/\n //console.log(currentState);\n this.setState(currentState,function(){\n //console.log(this.state);\n });\n });\n }\n }\n pickCutSite(target){\n this.saveCurrentHighlight('rgba(252, 210, 126, 0.3)');\n this.setState({\n targets:[target],\n menu:3,\n screen:3,\n mutatePam:true,\n });\n }\n chooseTerminal(e){\n e.preventDefault();\n //console.log(e.target.tag.value);\n let i;\n let terminal = e.target.tag.value;\n if(terminal=='n'){\n i = this.state.highlights.start.location;\n } else if(terminal=='c'){\n i = this.state.highlights.stop.location;\n }\n //console.log('start',i-26,i+26);\n let targetGenes = this.state.sequence.substring(i-50,i+50); \n //console.log(targetGenes);\n let url = urlBase+'/api/?type=targetSearch&targetArea='+targetGenes;\n //console.log(url);\n this.setState({popup:{\n show:true,\n message:Finding Potential Targets.
This may take some time.
,\n image:loading,\n stayOpen:true,\n },\n terminal:terminal\n },function(){\n fetch(url).then((res) =>{return res.json()}).then((response)=>{\n //console.log(response);\n let efficiencyString = response.results.map((target)=>{\n return target.distal+target.proximal;\n });\n //console.log(encodeURIComponent(efficiencyString.join(',')));\n this.setState({popup:{\n show:true,\n message:Checking Target Efficiency
,\n image:loading,\n stayOpen:true,\n },\n targets:response.results\n },function(){\n let url = urlBase+'/api/?type=targetEfficiency&targets='+encodeURIComponent(efficiencyString.join('\\n'));\n fetch(url).then((res)=>{return res.json()}).then((response)=>{\n //console.log(response);\n let targets = [];\n for(let i=0;iFinding Potential Targets,\n image:loading,\n stayOpen:true,\n }\n },function(){\n fetch(url).then((res) =>{return res.json()}).then((response)=>{\n //console.log(response);\n let efficiencyString = response.results.map((target)=>{\n return target.distal+target.proximal;\n });\n //console.log(encodeURIComponent(efficiencyString.join(',')));\n this.setState({popup:{\n show:true,\n message:Checking Target Efficiency
,\n image:loading,\n stayOpen:true,\n },\n targets:response.results\n },function(){\n let url = urlBase+'/api/?type=targetEfficiency&targets='+encodeURIComponent(efficiencyString.join('\\n'));\n fetch(url).then((res)=>{return res.json()}).then((response)=>{\n //console.log(response);\n //console.log('got response');\n let targets = [];\n for(let i=0;iChecking Target Efficiency,\n image:loading,\n stayOpen:true,\n },\n targets:targets\n },function(){\n //console.log('added score');\n //console.log(this.state);\n });\n });\n });\n });\n });\n \n }\n getPrimers() {\n\n const targetSearch = this.state.terminal=='n'?this.state.highlights.start.location:this.state.highlights.stop.location;\n console.log('target search area',targetSearch);\n const primerSections = {\n \"5' Homology\":this.state.sequence.slice(targetSearch-1200, targetSearch-1000),\n \"5' Sequence\":this.state.sequence.slice(targetSearch-600, targetSearch-400),\n \"3' Sequence\":this.state.sequence.slice(targetSearch+400, targetSearch+600),\n \"3' Homology\":this.state.sequence.slice(targetSearch+1000, targetSearch+1200) \n }\n let primerSectionsString = Buffer.from(JSON.stringify(primerSections)).toString('base64');\n this.setState({\n popup:{\n show:true,\n message:Retreiving Homology Arm Primers
,\n image:loading,\n stayOpen:true,\n },\n },()=>{\n console.log(urlBase+'/api/?type=primers&primerSections='+primerSectionsString);\n fetch(urlBase+'/api/?type=primers&primerSections='+primerSectionsString).then(res =>{return res.json();}).then((res)=>{\n console.log(res);\n this.setState({primers:res,menu:4,popup:{\n show:false,\n message:Retreiving Homology Arm Primers
,\n image:loading,\n stayOpen:true,\n },\n },()=>{\n console.log(this.state);\n });\n })\n });\n }\n mutatePam(e){\n e.preventDefault();\n let newPam = e.target.elements.newPam.value;\n //console.log(newPam);\n this.setState({currentPam:newPam,menu:4,screen:4,mutatePam:false},()=>{\n console.log('mutated pam');\n console.log(this.state);\n if(!this.state.primers||!this.state.primers.length==0){\n this.getPrimers();\n }\n });\n }\n selectHomologyArm(selection,arm){\n let currentArms = JSON.parse(JSON.stringify(!this.state.selectedArms?{}:this.state.selectedArms));\n currentArms[arm] = selection;\n this.saveCurrentHighlight('rgba(86, 64, 155,0.3)',arm);\n this.setState({selectedArms:currentArms},()=>{\n //console.log(this.state);\n this.setState({currentHighlight:null},()=>{\n let totalSelected = Object.keys(this.state.selectedArms);\n if(totalSelected.length&&totalSelected.length==4){\n // GET OLIGO INFO\n console.log('searching');\n console.log(urlBase+'/api/?type=oligos&target='+this.state.targets[0].distal+this.state.targets[0].proximal+this.state.targets[0].pam);\n this.setState({\n popup:{\n show:true,\n message:Retreiving Oligo Information
,\n image:loading,\n stayOpen:true,\n },\n },()=>{\n fetch(urlBase+'/api/?type=oligos&target='+this.state.targets[0].distal+this.state.targets[0].proximal+this.state.targets[0].pam).then(res =>{return res.json();}).then((res)=>{\n console.log(res);\n if(!res.sense){\n this.setState({\n menu:5,\n popup: {\n show:false,\n }\n });\n }\n this.setState({\n menu:5,\n oligos:res,\n popup: {\n show:false,\n }\n });\n });\n });\n }\n });\n });\n }\n\n // UTILITIES\n\n downloadApeFile() {\n fetch(window.location.origin+'/fly_templates/empty_ape.txt').then((res)=>{return res.text();}).then((res)=>{\n const data = res;\n fetch(window.location.origin+'/fly_templates/feature.txt').then((res)=>{return res.text()}).then((res2)=>{\n const feature = res2;\n const newFeature = (loc, name, color) => {\n return feature\n .split('*featureLoc*').join(loc)\n .split('*featureName*').join(name)\n .split('*featureColor*').join(color);\n };\n let gene = this.state.sequence;\n const target = this.state.targets[0].distal.toString()+this.state.targets[0].proximal.toString();\n const targetMatch = gene.toLowerCase().match(target.toLowerCase());\n const revTargetMatch = gene.toLowerCase().match(this.revComp(target.toLowerCase()));\n let targetI;\n if (targetMatch) {\n targetI = targetMatch.index+1;\n } else if (revTargetMatch) {\n targetI = revTargetMatch.index;\n }\n const pamStart = revTargetMatch?targetI-2:targetI+20;\n const start = 1+parseInt(this.state.highlights.start.location);\n const stop = 1+parseInt(this.state.highlights.stop.location); \n gene = !this.state.currentPam?gene:gene.substr(0,pamStart-1)+this.state.currentPam+gene.substr(pamStart+2,gene.length);\n const featureArr = [\n newFeature(start+'..'+(start+2),'Start Codon','#df2935'),\n newFeature(stop+'..'+(stop+2),'Stop Codon','#df2935'),\n newFeature((parseInt(1+this.state.highlights['hom5']['location']))+'..'+(parseInt(1+this.state.highlights['hom5']['location'])+this.state.highlights['hom5']['length']),\"5' Homology Arm Primer\",'#fdca40'),\n newFeature((parseInt(1+this.state.highlights['hom3']['location']))+'..'+(parseInt(1+this.state.highlights['hom3']['location'])+this.state.highlights['hom3']['length']),\"3' Homology Arm Primer\",'#fdca40'),\n newFeature((parseInt(1+this.state.highlights['seq5']['location']))+'..'+(parseInt(1+this.state.highlights['seq5']['location'])+this.state.highlights['seq5']['length']),\"5' Sequence Primer\",'#fdca40'),\n newFeature((parseInt(1+this.state.highlights['seq3']['location']))+'..'+(parseInt(1+this.state.highlights['seq3']['location'])+this.state.highlights['seq3']['length']),\"3' Sequence Primer\",'#fdca40'),\n newFeature(targetI+'..'+(parseInt(targetI)+20),\"Target\",'#136F5E'),\n newFeature(pamStart+'..'+(parseInt(pamStart)+2),\"Pam\",'#42ED5E'),\n ];\n const makeGeneArr = () => {\n\n let geneArr = [];\n const spaces = (str) => {\n let spaceArr = [];\n for(let i=0;i<9-str.length;i++){\n spaceArr.push('');\n }\n return spaceArr;\n }\n for(let i=0;igene.length){\n geneArr.push(gene.slice(i,gene.length));\n } else {\n geneArr.push(gene.slice(i,i+10));\n }\n geneArr.push('');\n i=i+10;\n }\n return geneArr.join(' ');\n }\n const months = [\"JAN\",\"FEB\",\"MAR\",\"APR\",\"MAY\",\"JUN\",\"JUL\",\"AUG\",\"SEP\",\"OCT\",\"NOV\",\"DEC\"]\n const date = new Date();\n const day = date.getDate();\n const month = months[date.getMonth()];\n const year = date.getFullYear();\n const newData = data\n .split('*FEATURES*').join(featureArr.join(''))\n .split('*name*').join(this.state.geneName)\n .split('*length*').join(this.state.sequence.length)\n .split('*date*').join(day+'-'+month+'-'+year)\n .split('*GENE*').join(makeGeneArr())\n ;\n const design = newData;\n var filename = this.state.geneName+\".ape\";\n var blob = new Blob([design], {\n type: \"text/plain;charset=utf-8\"\n });\n saveAs(blob, filename); \n });\n });\n }\n changePlasmidTemplate(e){\n let template = e.target.value;\n\n this.setState({plasmidTemplate:template},()=>{\n console.log(this.state.plasmidTemplate);\n });\n }\n downloadPlasmidTemplate(e){\n e.preventDefault();\n if(!this.state.plasmidTemplate){return false;}\n \n const url = (window.location.origin+'/plasmid_folder/')+(this.state.plasmidTemplate.split(' ').join('%20'))+'.txt';\n console.log(url);\n fetch(url).then((res)=>{return res.text()}).then((data)=>{\n const preArm1 = data.split('**arm_1_start**')[0];\n let searchSequence = this.state.targets[0].distal+this.state.targets[0].proximal+this.state.targets[0].pam;\n const targetSearch = this.state.sequence.search(this.state.targets[0].strand==='-'?this.revComp(searchSequence):searchSequence);\n let arm1 = this.state.sequence.slice(targetSearch-1000, targetSearch);\n const postArm1 = data.split('**arm_1_end**')[1].split('**arm_2_start**')[0];\n let arm2 = this.state.sequence.slice(targetSearch, targetSearch+1000);\n const postArm2 = data.split('**arm_2_end**')[1];\n if(this.state.mutatedPam) {\n const strand = this.state.potentialTargets[0].strand;\n const target = strand==='-'?this.revComp(this.state.target):this.state.target;\n let arms = arm1+arm2;\n const targetI = arms.toLowerCase().match(target.toLowerCase());\n if(strand==='-'){\n arms = arms.substr(0,targetI.index)+this.state.currentPam+arms.substr(targetI.index+3,arms.length);\n } else {\n arms = arms.substr(0,targetI.index+target.length-3)+this.state.currentPam+arms.substr(targetI.index+target.length,arms.length);\n }\n arm1 = arms.slice(0,Math.floor(arms.length/2)+1);\n arm2 = arms.slice(Math.floor(arms.length/2),arms.length);\n }\n let replaceArm1 = data.split('**arm_1_start**')[1].split('**arm_1_end**')[0].split('');\n let arm1I = 0;\n let replaceArm2 = data.split('**arm_2_start**')[1].split('**arm_2_end**')[0].split('');\n let arm2I = 0;\n\n\n for(let y=0;y{return res.text()}).then((data)=>{\n let preSplit = data.split('**injection_start**')[0];\n let postSplit = data.split('**injection_end**')[1];\n let sense = this.state.oligos.sense.substring(0,7)+' '+this.state.oligos.sense.substring(7,17)+' '+this.state.oligos.sense.substring(17);\n const design = preSplit+sense+postSplit;\n var filename = \"pu6-guidernavector.ape\";\n \n var blob = new Blob([design], {\n type: \"text/plain;charset=utf-8\"\n });\n saveAs(blob, filename); \n });\n return;\n }\n componentDidUpdate(){\n let options = {\n root: document.querySelector('.screen-4'),\n rootMargin: '0px',\n threshold: 0\n }\n const highlightObserver = (entries)=>{\n entries.forEach(entry => {\n if (entry.isIntersecting) {\n let elem = entry.target;\n \n if (entry.intersectionRatio >= 0.75) {\n // console.log('intersecting');\n } else {\n // console.log('not intersecting');\n }\n\n }\n });\n }\n let observer = new IntersectionObserver(highlightObserver, options);\n let currentHighlightEl = document.querySelector('.main-highlight');\n if(currentHighlightEl){\n observer.observe(currentHighlightEl);\n }\n // console.log(currentHighlightEl);\n\n }\n render() {\n //console.log('render')\n const makeHighlights = () => {\n return null;\n if(!this.state.highlights){\n return null;\n }\n /*for (const highlight of this.state.highlights) {\n let geneInfoHighlights = !this.state.sequence?null:this.state.sequence.split('').map((letter,i)=>{\n return i+((highlight.highlightLength-1)/2)?' ':'highlight ')+' single-letter '} data-value={i} onMouseEnter={this.highlight.bind(this)}>{letter}
;\n });\n }*/\n let allHighlights = [];\n let currentHighlight = !this.state.sequence?null:this.state.sequence.split('').map((letter,i)=>{\n if(!this.state.currentHighlight){\n return null;\n }\n let style = {background:'rgba(255,255,255,0)'};\n let classes = '';\n if(i>=(this.state.currentHighlight.location-((this.state.currentHighlight.length-1)/2))&&i<=(this.state.currentHighlight.location+((this.state.currentHighlight.length-1)/2))){\n style = {background:this.state.currentHighlight.color,zIndex:999};\n classes = 'main-highlight';\n }\n return {letter}
;\n });\n let highlightKeys = Object.keys(this.state.highlights);\n for(let i=0;i{\n this.state.sequence.split('').map((letter,i)=>{\n let style = {background:'rgba(255,255,255,0)'};\n let className = null;\n if(i>=(highlight.location-((highlight.length-1)/2))&&i<=(highlight.location+((highlight.length-1)/2))){\n style = {background:highlight.color};\n \n }\n if(i==highlight.location){\n className = highlightKeys[i];\n }\n return {letter}
;\n })\n });\n }\n allHighlights.push({currentHighlight}
);\n return allHighlights;\n }\n const highlightKeys = !this.state.highlights?null:Object.keys(this.state.highlights);\n //console.log(!this.state.currentHighlight?null:this.state.currentHighlight);\n const currentHighlight = !this.state.currentHighlight?null:this.state.currentHighlight;\n const currentHighlightLocation = !currentHighlight?null:currentHighlight.location;\n const geneInfoPrep = !this.state.sequence?null:this.state.sequence.split('').map((letter,i)=>{\n let highlightClasses = [];\n if(currentHighlight&&i>=currentHighlightLocation&&i0){\n for(let y=0;y=start&&i{letter};\n });\n const targetList = !this.state.targets?null:this.state.targets.map((target)=>{\n return \n
{target.distal+target.proximal+target.pam}
\n
Efficiency: {!target.score?'-':target.score}
\n
Strand: {target.strand}
\n
Off Targets: {target.offtarget}
\n
;\n });\n const pamBoxReadingFrames = () => {\n if(!this.state.highlights.cutsite){\n return;\n }\n let start = parseInt(JSON.parse(JSON.stringify(this.state.highlights.start.location)));\n let cutsite = parseInt(this.state.highlights.cutsite.location);\n let string = [];\n let frameI = Math.abs((cutsite - start) % 3)+1;\n let distal = this.state.targets[0].distal.split('');\n let proximal = this.state.targets[0].proximal.split('');\n let pam = this.state.targets[0].pam.split('');\n //console.log(cutsite,' ',start,Math.abs(cutsite - start)%3,((cutsite - start) % 3),frameI);\n for(let i=0;i{distal[i]}{frameI});\n start = start+1;\n frameI = Math.abs((cutsite - start) % 3)+1;\n //console.log(cutsite,' ',start,Math.abs(cutsite - start)%3,((cutsite - start) % 3),frameI);\n }\n for(let i=0;i{proximal[i]}{frameI});\n start = start+1;\n frameI = Math.abs((cutsite - start) % 3)+1;\n //console.log(cutsite,' ',start,Math.abs(cutsite - start)%3,((cutsite - start) % 3),frameI);\n }\n string.push({' '}
);\n for(let i=0;i{pam[i]}{frameI});\n start = start+1;\n frameI = Math.abs((cutsite - start) % 3)+1;\n //console.log(cutsite,' ',start,Math.abs(cutsite - start)%3,((cutsite - start) % 3),frameI);\n }\n //let string = !this.state.targets?null:this.state.targets[0].distal+this.state.targets[0].proximal+' '+(!this.state.targets?null:this.state.targets[0].pam);\n return {string}
;\n }\n const pamBox = \n
Amino Acid Chart
\n
Target: {pamBoxReadingFrames()}
\n
\n
2nd Letter
\n
\n
1st
Letter
\n
\n
3rd
Letter
\n
\n
;\n const HomologyList = () => {\n if(!this.state.primers){\n return;\n }\n let primerKeys = Object.keys(this.state.primers);\n //console.log('primer keys',primerKeys);\n let primerHTML = primerKeys.map((key)=>{\n let primerOptions = this.state.primers[key];\n //console.log('this primer',primerOptions);\n if(this.state.selectedArms&&this.state.selectedArms[key]){\n let primerSingle = this.state.selectedArms[key];\n return {key}
\n
\n
{primerSingle[7]}
\n
\n
\n
Any (Self Complementarity):
{primerSingle[5]}
\n
3' (Self Complementarity):
{primerSingle[6]}
\n
;\n } else {\n return {key}
{primerOptions.map((primerSingle)=>{\n return
\n
{primerSingle[7]}
\n
\n
\n
Any (Self Complementarity):
{primerSingle[5]}
\n
3' (Self Complementarity):
{primerSingle[6]}
\n
})}
;\n }\n });\n return {primerHTML}
;\n }\n const popup = () => {\n if(!this.state.popup){\n return null;\n }\n return \n
{this.state.popup.stayOpen?null:
X
}\n
{this.state.popup.message}
\n {this.state.popup.image?
:''}
\n
\n } \n const downloadOptions = () => {\n const plasmidOptions = [\"N terminal SSPB and mCherry tag\",\"N terminal EGFP and SSPB tag with Extended Linker\",\"C terminal mCherry and SSPB tag\",\"C terminal EGFP and SSPB tag with Extended Linker\",\"C terminal EGFP and SSPB tag\",\"C terminal mDendra2 and SSPB tag\",\"C terminal mScarlett and SSPB tag\",\"N terminal EGFP and SSPB tag\",\"N terminal mDendra2 and SSPB tag\",\"N terminal mScarlett and SSPB tag\"];\n let htmlOptions = [];\n for(let i=-1;iChoose A Template)\n } else {\n htmlOptions.push()\n }\n }\n \n return \n
\n
Ape File
\n
\n
Guide Rna Vector
\n
\n
Plasmid Template
\n
\n
\n
;\n }\n return (\n \n
\n \n \n
\n
New/Upload Project
\n
Save Project
\n
Switch to {(this.state.themeColor===false?'Dark':'Light')} Theme
\n
\n
\n
\n \n
\n
\n
\n
\n
1?'':'none'}} onClick={this.changeMenus.bind(this)} data-menu=\"2\" alt=\"sidebar2\">
\n
\n {!targetList?null:
{targetList}
}\n
\n
\n
2?'':'none'}} onClick={this.changeMenus.bind(this)} data-menu=\"3\" alt=\"sidebar3\">
\n
\n {this.state.screen<3?null:
{pamBox}
}\n
\n
\n
3?'':'none'}} onClick={this.changeMenus.bind(this)} data-menu=\"4\" alt=\"sidebar4\">
\n
\n
{HomologyList()}
\n
\n
\n
3?'':'none'}} onClick={this.changeMenus.bind(this)} data-menu=\"5\" alt=\"sidebar5\">
\n
\n {this.state.menu==5?downloadOptions():null}\n
\n
\n
\n
\n
New Project
\n
\n
\n
\n \n
\n
\n
Gene: {this.state.geneName}{!this.state.isoForm?'':' - Isoform: '+this.state.isoForm}
\n
\n \n
{makeHighlights()}
\n
{geneInfoPrep}
\n
\n
\n
\n
Gene: {this.state.geneName}{!this.state.isoForm?'':' - Isoform: '+this.state.isoForm}
\n
\n \n
{makeHighlights()}
\n
{geneInfoPrep}
\n
\n
\n
=4?'flex':'none',}}>\n
Gene: {this.state.geneName}{!this.state.isoForm?'':' - Isoform: '+this.state.isoForm}
\n
\n
{makeHighlights()}
\n
{geneInfoPrep}
\n
\n
\n
\n \n
\n
\n
Cabernard Lab
\n
Sound Development Company
\n
GPL3 License
\n
API Docs
\n
\n
\n
\n
X
\n
Change Font Size
\n
\n
\n
\n {popup()}\n
\n\n )\n }\n}\n","export default \"\"","export default \"\"","export default \"\"","export default \"\"","export default \"\"","export default \"\"","export default \"\"","export default \"\"","export default \"\"","import React from 'react';\nimport ReactDOM from 'react-dom';\nimport './index.css';\nimport App from './App';\n\nReactDOM.render(\n \n \n ,\n document.getElementById('root')\n);\n"],"sourceRoot":""}
\ No newline at end of file
diff --git a/public/build/static/js/main.d723f0fa.chunk.js b/public/build/static/js/main.d723f0fa.chunk.js
new file mode 100644
index 0000000..63aa2d4
--- /dev/null
+++ b/public/build/static/js/main.d723f0fa.chunk.js
@@ -0,0 +1,2 @@
+(this.webpackJsonpcrispr_buildr=this.webpackJsonpcrispr_buildr||[]).push([[0],[,function(e,t,s){"use strict";t.a=""},,,,,,,function(e,t,s){"use strict";(function(e){s.d(t,"a",(function(){return N}));var i=s(9),n=s(10),a=s(11),c=s(2),l=s(22),A=s(21),r=s(3),o=s.n(r),h=(s(33),s(12)),d=s(13),j=s(14),m=s(15),g=s(16),u=s(17),b=s(18),v=s(19),x=s(20),O=s(1),p=s(4),C=s(0),f="http://142.93.118.6",N=function(t){Object(l.a)(r,t);var s=Object(A.a)(r);function r(e){var t;return Object(n.a)(this,r),(t=s.call(this,e)).state={menu:null,screen:0,hamburger:!1,themeColor:!1,highlights:[],currentHighlight:null,fontSize:23,fontMenu:!1,geneInfo:null,popup:{show:!1,message:null,image:null},currentPam:null},t.changeMenus=t.changeMenus.bind(Object(c.a)(t)),t.highlight=t.highlight.bind(Object(c.a)(t)),t.saveCurrentHighlight=t.saveCurrentHighlight.bind(Object(c.a)(t)),t}return Object(a.a)(r,[{key:"changeMenus",value:function(e){var t=parseInt(e.target.dataset.menu);t===this.state.menu&&(t=null),this.setState({menu:t},(function(){}))}},{key:"changeScreens",value:function(e){var t=this,s=e.target.dataset.screen;console.log(s);var i=null;1==s&&(i=1),this.setState({screen:parseInt(s),hamburger:!1,menu:i},(function(){console.log(t.state),3==s&&t.setState({mutatePam:!0})}))}},{key:"openMenu",value:function(e){e.target.dataset.screen;this.setState({hamburger:!this.state.hamburger})}},{key:"changeThemeColor",value:function(e){this.setState({themeColor:!this.state.themeColor})}},{key:"closeAllMenus",value:function(e){}},{key:"closePopup",value:function(e){this.setState({popup:{show:!1}})}},{key:"highlight",value:function(e,t){}},{key:"fontMenu",value:function(e){this.setState({fontMenu:!this.state.fontMenu})}},{key:"changeFontSize",value:function(e){var t=parseInt(e.target.value);this.setState({fontSize:t},(function(){}))}},{key:"saveDesign",value:function(){var e=JSON.stringify(this.state),t=this.state.geneName+".txt",s=new Blob([e],{type:"text/plain;charset=utf-8"});Object(p.saveAs)(s,t),this.setState({hamburger:!1})}},{key:"openDesign",value:function(e){var t=this,s=new FileReader;this.setState({popup:{show:!0,message:Object(C.jsx)("h2",{children:"Uploading File"}),image:O.a,stayOpen:!0}},(function(){s.onloadend=function(e){var s=JSON.parse(e.target.result);s.popup=null,s.hamburger=!1,t.setState(s,(function(){console.log(t.state)}))},e.target.value.length&&s.readAsText(e.target.files[0])}))}},{key:"viewFinishedDesign",value:function(){var e=this,t=Object.keys(this.state.targets[0]).map((function(t){return Object(C.jsxs)("div",{children:[Object(C.jsxs)("b",{children:[t,":"]})," ",e.state.targets[0][t]]})})),s=Object.keys(this.state.primers).map((function(t){var s=e.state.primers[t];if(e.state.selectedArms&&e.state.selectedArms[t]){var i=e.state.selectedArms[t];return Object(C.jsxs)("div",{children:[Object(C.jsx)("div",{className:"",children:Object(C.jsx)("b",{children:t})}),Object(C.jsxs)("div",{className:"",children:[Object(C.jsx)("div",{children:i[7]}),Object(C.jsx)("div",{children:Object(C.jsxs)("div",{children:["Tm: ",i[3]]})}),Object(C.jsx)("div",{children:Object(C.jsxs)("div",{children:["GC%: ",i[4]]})}),Object(C.jsx)("div",{children:Object(C.jsxs)("div",{children:["Any (Self Complementarity): ",i[5]]})}),Object(C.jsx)("div",{children:Object(C.jsxs)("div",{children:["3' (Self Complementarity): ",i[6]]})})]}),Object(C.jsx)("br",{})]})}return Object(C.jsxs)("div",{children:[Object(C.jsx)("div",{className:"",children:Object(C.jsx)("b",{children:t})}),s.map((function(e){return Object(C.jsxs)("div",{className:"",children:[Object(C.jsx)("div",{children:e[7]}),Object(C.jsx)("div",{children:Object(C.jsxs)("div",{children:["Tm: ",e[3]]})}),Object(C.jsx)("div",{children:Object(C.jsxs)("div",{children:["GC%: ",e[4]]})}),Object(C.jsx)("div",{children:Object(C.jsxs)("div",{children:["Any (Self Complementarity): ",e[5]]})}),Object(C.jsx)("div",{children:Object(C.jsxs)("div",{children:["3' (Self Complementarity): ",e[6]]})})]})})),Object(C.jsx)("br",{})]})})),i=Object(C.jsxs)("div",{children:[Object(C.jsx)("h2",{children:"Design Info"}),Object(C.jsxs)("div",{children:[Object(C.jsx)("h3",{children:"Target Info"}),t]}),Object(C.jsxs)("div",{children:[Object(C.jsx)("h3",{children:"Homology Info"}),s]}),Object(C.jsxs)("div",{children:[Object(C.jsx)("h3",{children:"Oligo Info"}),Object(C.jsxs)("div",{children:[Object(C.jsx)("b",{children:"Sense: "}),this.state.oligos.sense]}),Object(C.jsxs)("div",{children:[Object(C.jsx)("b",{children:"Antisense: "}),this.state.oligos.antisense]})]})]});this.setState({popup:{show:!0,message:i,image:null,stayOpen:!1}})}},{key:"saveCurrentHighlight",value:function(){var e=this,t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:null,s=arguments.length>1&&void 0!==arguments[1]?arguments[1]:null,i=JSON.parse(JSON.stringify(this.state.currentHighlight));t&&(i.color=t);var n=this.state.highlights;s?n[s]=i:n[i.name]=i,"targetSearch"==i.name?this.searchForTargets():this.setState({highlights:n},(function(){console.log(e.state)}))}},{key:"changeCurrentHighlight",value:function(e){var t=this.state.currentHighlight;t.location=e,this.setState({currentHighlight:t})}},{key:"stringLocation",value:function(){var e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:null,t=arguments.length>1?arguments[1]:void 0;if(!t)return this.state.sequence.indexOf(e);var s=this.state.sequence.indexOf(e);console.log("location",s);e.length;if(-1==s){var i=this.revComp(e);console.log("rev",i),s=this.state.sequence.indexOf(i)}return s}},{key:"highlightString",value:function(e){var t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:null,s=arguments.length>2&&void 0!==arguments[2]?arguments[2]:null;console.log("string: ",e," color: ",t);var i=this.stringLocation(e,s);console.log(i),-1==i&&(i=this.stringLocation(this.revComp(e),s)),-1==i&&(i=0);var n=e.length;t||(t="rgba(252, 210, 126, 0.3)"),this.setState({currentHighlight:{location:i,length:n,color:t,name:s||"cutsite"}})}},{key:"clearHighlight",value:function(){}},{key:"revComp",value:function(e){for(var t=[],s=0;sc.length?e.push(c.slice(s,c.length)):e.push(c.slice(s,s+10)),e.push(""),s+=10}return e.join(" ")}()),x=e.state.geneName+".ape",O=new Blob([v],{type:"text/plain;charset=utf-8"});Object(p.saveAs)(O,x)}))}))}},{key:"changePlasmidTemplate",value:function(e){var t=this,s=e.target.value;this.setState({plasmidTemplate:s},(function(){console.log(t.state.plasmidTemplate)}))}},{key:"downloadPlasmidTemplate",value:function(e){var t=this;if(e.preventDefault(),!this.state.plasmidTemplate)return!1;var s=window.location.origin+"/plasmid_folder/"+this.state.plasmidTemplate.split(" ").join("%20")+".txt";console.log(s),fetch(s).then((function(e){return e.text()})).then((function(e){var s=e.split("**arm_1_start**")[0],i=t.state.targets[0].distal+t.state.targets[0].proximal+t.state.targets[0].pam,n=t.state.sequence.search("-"===t.state.targets[0].strand?t.revComp(i):i),a=t.state.sequence.slice(n-1e3,n),c=e.split("**arm_1_end**")[1].split("**arm_2_start**")[0],l=t.state.sequence.slice(n,n+1e3),A=e.split("**arm_2_end**")[1];if(t.state.mutatedPam){var r=t.state.potentialTargets[0].strand,o="-"===r?t.revComp(t.state.target):t.state.target,h=a+l,d=h.toLowerCase().match(o.toLowerCase());a=(h="-"===r?h.substr(0,d.index)+t.state.currentPam+h.substr(d.index+3,h.length):h.substr(0,d.index+o.length-3)+t.state.currentPam+h.substr(d.index+o.length,h.length)).slice(0,Math.floor(h.length/2)+1),l=h.slice(Math.floor(h.length/2),h.length)}for(var j=e.split("**arm_1_start**")[1].split("**arm_1_end**")[0].split(""),m=0,g=e.split("**arm_2_start**")[1].split("**arm_2_end**")[0].split(""),u=0,b=0;b=i&&a0)for(var l=0;l=o&&a1?"":"none"},onClick:this.changeMenus.bind(this),"data-menu":"2",alt:"sidebar2",children:Object(C.jsx)("img",{src:m.a})}),Object(C.jsxs)("label",{onClick:this.changeScreens.bind(this),"data-screen":"2",children:[Object(C.jsx)("div",{className:"arrow-down",children:"^"}),"Select Cut Site"]}),a?Object(C.jsx)("div",{className:"target-list",style:{display:2==this.state.menu?"flex":"none"},children:a}):null]}),Object(C.jsxs)("div",{className:(3==this.state.menu?"active":"")+" menu-icon","data-menu":"3",children:[Object(C.jsx)("div",{className:"menu-image-wrapper",style:{pointerEvents:this.state.screen>2?"":"none"},onClick:this.changeMenus.bind(this),"data-menu":"3",alt:"sidebar3",children:Object(C.jsx)("img",{src:g.a,alt:"sidebar3"})}),Object(C.jsx)("label",{onClick:this.changeScreens.bind(this),"data-screen":"3",children:"Mutate Pam"}),this.state.screen<3?null:Object(C.jsx)("div",{className:"pam-box",style:{display:this.state.mutatePam?"flex":"none"},children:c})]}),Object(C.jsxs)("div",{className:(4==this.state.menu?"active":"")+" menu-icon","data-menu":"4",children:[Object(C.jsx)("div",{className:"menu-image-wrapper",style:{pointerEvents:this.state.screen>3?"":"none"},onClick:this.changeMenus.bind(this),"data-menu":"4",alt:"sidebar4",children:Object(C.jsx)("img",{src:j.a,alt:"sidebar4"})}),Object(C.jsx)("label",{onClick:this.changeScreens.bind(this),"data-screen":"4",children:"Homology Arm Primers"}),Object(C.jsx)("div",{className:"target-list homology-list",style:{display:4==this.state.menu?"flex":"none"},children:function(){if(e.state.primers){var t=Object.keys(e.state.primers).map((function(t){var s=e.state.primers[t];if(e.state.selectedArms&&e.state.selectedArms[t]){var i=e.state.selectedArms[t];return Object(C.jsxs)("div",{children:[Object(C.jsx)("div",{className:"homology-label",children:t}),Object(C.jsxs)("div",{className:"single-target",onMouseDown:e.selectHomologyArm.bind(e,i,t),onMouseLeave:e.clearHighlight.bind(e),children:[Object(C.jsx)("div",{children:i[7]}),Object(C.jsxs)("div",{children:[Object(C.jsx)("div",{children:"Tm: "}),Object(C.jsx)("div",{children:i[3]})]}),Object(C.jsxs)("div",{children:[Object(C.jsx)("div",{children:"GC%: "}),Object(C.jsx)("div",{children:i[4]})]}),Object(C.jsxs)("div",{children:[Object(C.jsx)("div",{children:"Any (Self Complementarity): "}),Object(C.jsx)("div",{children:i[5]})]}),Object(C.jsxs)("div",{children:[Object(C.jsx)("div",{children:"3' (Self Complementarity): "}),Object(C.jsx)("div",{children:i[6]})]})]})]})}return Object(C.jsxs)("div",{children:[Object(C.jsx)("div",{className:"homology-label",children:t}),s.map((function(s){return Object(C.jsxs)("div",{className:"single-target",onMouseEnter:e.highlightString.bind(e,s[7],"rgba(86, 64, 155,0.3)","homology"),onMouseDown:e.selectHomologyArm.bind(e,s,t),onMouseLeave:e.clearHighlight.bind(e),children:[Object(C.jsx)("div",{children:s[7]}),Object(C.jsxs)("div",{children:[Object(C.jsx)("div",{children:"Tm: "}),Object(C.jsx)("div",{children:s[3]})]}),Object(C.jsxs)("div",{children:[Object(C.jsx)("div",{children:"GC%: "}),Object(C.jsx)("div",{children:s[4]})]}),Object(C.jsxs)("div",{children:[Object(C.jsx)("div",{children:"Any (Self Complementarity): "}),Object(C.jsx)("div",{children:s[5]})]}),Object(C.jsxs)("div",{children:[Object(C.jsx)("div",{children:"3' (Self Complementarity): "}),Object(C.jsx)("div",{children:s[6]})]})]})}))]})}));return Object(C.jsx)("div",{children:t})}}()})]}),Object(C.jsxs)("div",{className:(5==this.state.menu?"active":"")+" menu-icon","data-menu":"5",children:[Object(C.jsx)("div",{className:"menu-image-wrapper sidebar-5",style:{pointerEvents:this.state.screen>3?"":"none"},onClick:this.changeMenus.bind(this),"data-menu":"5",alt:"sidebar5",children:Object(C.jsx)("img",{src:u.a,alt:"sidebar5"})}),Object(C.jsx)("label",{onClick:this.changeScreens.bind(this),"data-screen":"5",children:"Download Data"}),5==this.state.menu?function(){for(var t=["N terminal SSPB and mCherry tag","N terminal EGFP and SSPB tag with Extended Linker","C terminal mCherry and SSPB tag","C terminal EGFP and SSPB tag with Extended Linker","C terminal EGFP and SSPB tag","C terminal mDendra2 and SSPB tag","C terminal mScarlett and SSPB tag","N terminal EGFP and SSPB tag","N terminal mDendra2 and SSPB tag","N terminal mScarlett and SSPB tag"],s=[],i=-1;i=4?"flex":"none"},children:[Object(C.jsxs)("div",{className:"gene-name",children:["Gene: ",this.state.geneName,this.state.isoForm?" - Isoform: "+this.state.isoForm:""]}),Object(C.jsxs)("div",{className:"gene-info-wrapper",style:{fontSize:this.state.fontSize},children:[Object(C.jsx)("div",{className:"gene-info gene-info-highlights",children:null}),Object(C.jsx)("div",{className:"gene-info gene-info-sequence",children:n})]})]})]})]}),Object(C.jsxs)("div",{className:"footer",children:[Object(C.jsx)("div",{children:"Cabernard Lab"}),Object(C.jsx)("div",{children:"Sound Development Company"}),Object(C.jsx)("div",{children:"GPL3 License"}),Object(C.jsx)("div",{children:"API Docs"})]}),Object(C.jsx)("div",{className:"popups",style:{display:!0===this.state.fontMenu?"flex":"none"},children:Object(C.jsxs)("div",{className:"font-size",children:[Object(C.jsx)("div",{className:"close",onClick:this.fontMenu.bind(this),children:"X"}),Object(C.jsx)("h4",{children:"Change Font Size"}),Object(C.jsx)("form",{children:Object(C.jsx)("input",{type:"number",value:this.state.fontSize,onChange:this.changeFontSize.bind(this)})})]})}),e.state.popup?Object(C.jsx)("div",{className:"popup-wrapper",style:{display:e.state.popup.show?"flex":"none"},children:Object(C.jsxs)("div",{className:"popup",children:[e.state.popup.stayOpen?null:Object(C.jsx)("div",{className:"popup-close",onClick:e.closePopup.bind(e),children:"X"}),Object(C.jsx)("div",{className:"message",children:e.state.popup.message}),e.state.popup.image?Object(C.jsx)("img",{className:"blink",src:e.state.popup.image}):""]})}):null]})}}]),r}(o.a.Component)}).call(this,s(29).Buffer)},,,,function(e,t,s){"use strict";t.a=""},function(e,t,s){"use strict";t.a=""},function(e,t,s){"use strict";t.a=""},function(e,t,s){"use strict";t.a=""},function(e,t,s){"use strict";t.a=""},function(e,t,s){"use strict";t.a=""},function(e,t,s){"use strict";t.a=""},function(e,t,s){"use strict";t.a=""},function(e,t,s){"use strict";t.a=""},,,function(e,t,s){"use strict";s.r(t);s(3);var i=s(7),n=s.n(i),a=(s(28),s(8)),c=s(0);n.a.render(Object(c.jsx)("span",{children:Object(c.jsx)(a.a,{})}),document.getElementById("root"))},,,,,function(e,t,s){},,,,,function(e,t,s){}],[[23,1,2]]]);
+//# sourceMappingURL=main.d723f0fa.chunk.js.map
\ No newline at end of file
diff --git a/public/build/static/js/main.d723f0fa.chunk.js.map b/public/build/static/js/main.d723f0fa.chunk.js.map
new file mode 100644
index 0000000..6d04d13
--- /dev/null
+++ b/public/build/static/js/main.d723f0fa.chunk.js.map
@@ -0,0 +1 @@
+{"version":3,"sources":["assets/loading.png","App.js","assets/logo.png","assets/sidebar1.png","assets/sidebar2.png","assets/sidebar3.png","assets/sidebar4.png","assets/document-icon.png","assets/landing1.png","assets/landing2.png","assets/hamburger.png","index.js"],"names":["urlBase","App","props","state","menu","screen","hamburger","themeColor","highlights","currentHighlight","fontSize","fontMenu","geneInfo","popup","show","message","image","currentPam","changeMenus","bind","highlight","saveCurrentHighlight","e","parseInt","target","dataset","this","setState","console","log","mutatePam","data","size","value","design","JSON","stringify","filename","geneName","blob","Blob","type","saveAs","reader","FileReader","loading","stayOpen","onloadend","res","newState","parse","result","length","readAsText","files","targetHTML","Object","keys","targets","map","prop","primerHTML","primers","key","primerOptions","selectedArms","primerSingle","className","oligos","sense","antisense","color","name","searchForTargets","i","location","string","sequence","indexOf","revString","revComp","stringLocation","dna","push","reverse","join","preventDefault","stopPropagation","url","elements","fetch","then","json","currentState","isoForm","isoForms","options","onSubmit","pickIsoForm","isoFormSequence","makeIsoFormHighlights","startSequence","substr","stopSequence","start","stop","popupForm","chooseTerminal","isoform","terminal","tag","targetGenes","substring","response","efficiencyString","results","distal","proximal","encodeURIComponent","gene","score","scrollTop","windowHeight","window","innerHeight","document","getElementsByClassName","getBoundingClientRect","top","scrollTo","behavior","targetArea","targetSearch","primerSections","slice","primerSectionsString","Buffer","from","toString","newPam","getPrimers","selection","arm","currentArms","totalSelected","pam","origin","text","res2","targetI","feature","newFeature","loc","split","targetMatch","toLowerCase","match","revTargetMatch","index","pamStart","featureArr","date","Date","day","getDate","month","getMonth","year","getFullYear","geneArr","spaces","str","spaceArr","makeGeneArr","template","plasmidTemplate","preArm1","searchSequence","search","strand","arm1","postArm1","arm2","postArm2","mutatedPam","potentialTargets","arms","Math","floor","replaceArm1","arm1I","replaceArm2","arm2I","y","isNaN","preSplit","postSplit","root","querySelector","rootMargin","threshold","observer","IntersectionObserver","entries","forEach","entry","isIntersecting","intersectionRatio","currentHighlightEl","observe","highlightKeys","currentHighlightLocation","geneInfoPrep","letter","highlightClasses","includes","targetList","onClick","pickCutSite","onMouseEnter","highlightString","onMouseLeave","clearHighlight","offtarget","pamBox","cutsite","frameI","abs","style","backgroundColor","pamBoxReadingFrames","closeAllMenus","src","logo","alt","openMenu","display","changeScreens","saveDesign","changeThemeColor","sidebar1","pointerEvents","sidebar3","sidebar4","sidebar2","onMouseDown","selectHomologyArm","HomologyList","documentIcon","plasmidOptions","htmlOptions","default","viewFinishedDesign","downloadApeFile","downloadGuideRna","onChange","changePlasmidTemplate","downloadPlasmidTemplate","downloadOptions","landing1","for","landing2","id","openDesign","searchForGene","changeFontSize","closePopup","React","Component","ReactDOM","render","getElementById"],"mappings":"6GAAe,suX,yPCcTA,EAAU,sBACKC,E,kDACnB,WAAYC,GAAQ,IAAD,8BACjB,cAAMA,IACDC,MAAQ,CAEXC,KAAK,KACLC,OAAO,EACPC,WAAU,EACVC,YAAW,EACXC,WAAW,GACXC,iBAAkB,KAClBC,SAAS,GACTC,UAAS,EACTC,SAAS,KACTC,MAAM,CACJC,MAAK,EACLC,QAAQ,KACRC,MAAM,MAERC,WAAW,MAGb,EAAKC,YAAc,EAAKA,YAAYC,KAAjB,gBACnB,EAAKC,UAAY,EAAKA,UAAUD,KAAf,gBACjB,EAAKE,qBAAuB,EAAKA,qBAAqBF,KAA1B,gBAvBX,E,+CA2BnB,SAAYG,GACV,IAAIlB,EAAOmB,SAASD,EAAEE,OAAOC,QAAQrB,MAElCA,IAAOsB,KAAKvB,MAAMC,OACnBA,EAAO,MAETsB,KAAKC,SAAS,CAACvB,KAAKA,IAAM,iB,2BAI5B,SAAckB,GAAI,IAAD,OACXjB,EAASiB,EAAEE,OAAOC,QAAQpB,OAC9BuB,QAAQC,IAAIxB,GACZ,IAAID,EAAO,KACA,GAARC,IACDD,EAAK,GAEPsB,KAAKC,SAAS,CAACtB,OAAOkB,SAASlB,GAAQC,WAAU,EAAMF,KAAKA,IAAM,WAChEwB,QAAQC,IAAI,EAAK1B,OACN,GAARE,GACD,EAAKsB,SAAS,CAACG,WAAU,S,sBAI/B,SAASR,GACMA,EAAEE,OAAOC,QAAQpB,OAE9BqB,KAAKC,SAAS,CAACrB,WAAWoB,KAAKvB,MAAMG,c,8BAEvC,SAAiBgB,GACfI,KAAKC,SAAS,CAACpB,YAAYmB,KAAKvB,MAAMI,e,2BAExC,SAAce,M,wBAGd,SAAWA,GACTI,KAAKC,SAAS,CAACd,MAAM,CAACC,MAAK,O,uBAE7B,SAAUQ,EAAES,M,sBAOZ,SAAST,GACPI,KAAKC,SAAS,CAAChB,UAAUe,KAAKvB,MAAMQ,a,4BAEtC,SAAeW,GACb,IAAIU,EAAOT,SAASD,EAAEE,OAAOS,OAC7BP,KAAKC,SAAS,CAACjB,SAASsB,IAAM,iB,wBAIhC,WACE,IAAME,EAASC,KAAKC,UAAUV,KAAKvB,OAC/BkC,EAAWX,KAAKvB,MAAMmC,SAAS,OAC/BC,EAAO,IAAIC,KAAK,CAACN,GAAS,CAC7BO,KAAM,6BAEPC,iBAAOH,EAAMF,GACbX,KAAKC,SAAS,CAACrB,WAAU,M,wBAE3B,SAAWgB,GAAI,IAAD,OACNqB,EAAS,IAAIC,WACnBlB,KAAKC,SAAS,CAACd,MAAM,CACnBC,MAAK,EACLC,QAAQ,gDACRC,MAAM6B,IACNC,UAAS,KACR,WACDH,EAAOI,UAAY,SAACC,GAClB,IAAIC,EAAWd,KAAKe,MAAMF,EAAIxB,OAAO2B,QACrCF,EAAQ,MAAY,KACpBA,EAAQ,WAAgB,EACxB,EAAKtB,SAASsB,GAAS,WACrBrB,QAAQC,IAAI,EAAK1B,WAGlBmB,EAAEE,OAAOS,MAAMmB,QAChBT,EAAOU,WAAW/B,EAAEE,OAAO8B,MAAM,S,gCAKvC,WAAqB,IAAD,OAEdC,EADaC,OAAOC,KAAK/B,KAAKvB,MAAMuD,QAAQ,IACpBC,KAAI,SAACC,GAE/B,OAAO,gCAAK,8BAAIA,EAAJ,OAAL,IAAqB,EAAKzD,MAAMuD,QAAQ,GAAGE,SAI9CC,EAFWL,OAAOC,KAAK/B,KAAKvB,MAAM2D,SAEVH,KAAI,SAACI,GAC/B,IAAIC,EAAgB,EAAK7D,MAAM2D,QAAQC,GAEvC,GAAG,EAAK5D,MAAM8D,cAAc,EAAK9D,MAAM8D,aAAaF,GAAK,CACvD,IAAIG,EAAe,EAAK/D,MAAM8D,aAAaF,GAC3C,OAAO,gCAAK,qBAAKI,UAAU,GAAf,SAAkB,4BAAIJ,MAChC,sBAAKI,UAAU,GAAf,UACA,8BAAOD,EAAa,KACpB,8BAAM,uCAAUA,EAAa,QAC7B,8BAAM,wCAAWA,EAAa,QAC9B,8BAAM,+DAAkCA,EAAa,QACrD,8BAAM,8DAAiCA,EAAa,WAChD,0BAEN,OAAO,gCAAK,qBAAKC,UAAU,GAAf,SAAkB,4BAAIJ,MAAeC,EAAcL,KAAI,SAACO,GAClE,OAAO,sBAAKC,UAAU,GAAf,UACP,8BAAOD,EAAa,KACpB,8BAAM,uCAAUA,EAAa,QAC7B,8BAAM,wCAAWA,EAAa,QAC9B,8BAAM,+DAAkCA,EAAa,QACrD,8BAAM,8DAAiCA,EAAa,cAC7C,6BAGXnD,EAAU,gCACZ,6CACA,gCAAK,6CAAqBwC,KAC1B,gCAAK,+CACFM,KAEH,gCACE,4CACA,gCAAK,wCAAenC,KAAKvB,MAAMiE,OAAOC,SACtC,gCAAK,4CAAmB3C,KAAKvB,MAAMiE,OAAOE,mBAG9C5C,KAAKC,SAAS,CAACd,MAAM,CACnBC,MAAK,EACLC,QAAQA,EACRC,MAAM,KACN8B,UAAS,O,kCAGb,WAA2C,IAAD,OAArByB,EAAqB,uDAAf,KAAKC,EAAU,uDAAL,KAC/BpD,EAAYe,KAAKe,MAAMf,KAAKC,UAAUV,KAAKvB,MAAMM,mBAElD8D,IACDnD,EAAUmD,MAAQA,GAEpB,IAAI/D,EAAakB,KAAKvB,MAAMK,WAEzBgE,EACDhE,EAAWgE,GAAQpD,EAEnBZ,EAAWY,EAAUoD,MAAQpD,EAGZ,gBAAhBA,EAAUoD,KAEX9C,KAAK+C,mBAGL/C,KAAKC,SAAS,CAACnB,WAAWA,IAAY,WACrCoB,QAAQC,IAAI,EAAK1B,Y,oCAKtB,SAAuBuE,GACrB,IAAIjE,EAAmBiB,KAAKvB,MAAMM,iBAClCA,EAAiBkE,SAAWD,EAC5BhD,KAAKC,SAAS,CAAClB,iBAAiBA,M,4BAElC,WAAiC,IAAlBmE,EAAiB,uDAAV,KAAKnC,EAAK,uCAC9B,IAAIA,EACF,OAAOf,KAAKvB,MAAM0E,SAASC,QAAQF,GAErC,IAAID,EAAWjD,KAAKvB,MAAM0E,SAASC,QAAQF,GAC3ChD,QAAQC,IAAI,WAAW8C,GACVC,EAAOxB,OAEpB,IAAc,GAAXuB,EAAa,CAEd,IAAII,EAAYrD,KAAKsD,QAAQJ,GAC7BhD,QAAQC,IAAI,MAAMkD,GAClBJ,EAAWjD,KAAKvB,MAAM0E,SAASC,QAAQC,GAKzC,OAAOJ,I,6BAET,SAAgBC,GAA6B,IAAtBL,EAAqB,uDAAf,KAAK9B,EAAU,uDAAL,KACrCb,QAAQC,IAAI,WAAW+C,EAAO,WAAWL,GAEzC,IAAII,EAAWjD,KAAKuD,eAAeL,EAAOnC,GAC1Cb,QAAQC,IAAI8C,IACE,GAAXA,IACDA,EAAWjD,KAAKuD,eAAevD,KAAKsD,QAAQJ,GAAQnC,KAExC,GAAXkC,IACDA,EAAW,GAEb,IAAIvB,EAASwB,EAAOxB,OAChBmB,IACFA,EAAQ,4BAIV7C,KAAKC,SAAS,CAAClB,iBAAiB,CAC9BkE,SAASA,EACTvB,OAAOA,EACPmB,MAAMA,EACNC,KAAM/B,GAAK,e,4BAIhB,c,qBAKA,SAAQyC,GAEP,IADA,IAAIF,EAAU,GACNN,EAAE,EAAEA,EAAEQ,EAAI9B,OAAOsB,IACX,MAATQ,EAAIR,GAAUM,EAAQG,KAAK,KACb,MAATD,EAAIR,GAAWM,EAAQG,KAAK,KACnB,MAATD,EAAIR,GAAWM,EAAQG,KAAK,KACnB,MAATD,EAAIR,GAAWM,EAAQG,KAAK,KACnB,MAATD,EAAIR,GAAWM,EAAQG,KAAK,KACnB,MAATD,EAAIR,GAAWM,EAAQG,KAAK,KACnB,MAATD,EAAIR,GAAWM,EAAQG,KAAK,KACnB,MAATD,EAAIR,IAAWM,EAAQG,KAAK,KAEtC,OAAOH,EAAQI,UAAUC,KAAK,M,2BAM9B,SAAc/D,GAAI,IAAD,OACZA,IACDA,EAAEgE,iBACFhE,EAAEiE,mBAGJ,IAAIC,EAAMxF,EAAQ,0BAA0BsB,EAAEE,OAAOiE,SAASnD,SAASL,MACvEP,KAAKC,SAAS,CAACd,MAAM,CACnBC,MAAK,EACLC,QAAQ,oDACRC,MAAM6B,IACNC,UAAS,KACP,WACF4C,MAAMF,GAAKG,MAAK,SAAC3C,GAAQ,OAAOA,EAAI4C,UAASD,MAAK,SAAC/E,GACjDgB,QAAQC,IAAI,WAAWjB,GACvB,IAAIiF,EAAe,EAAK1F,MACxB,GAAqB,MAAlBS,EAASkF,QACVD,EAAahF,MAAQ,CACnBC,MAAK,GAEP+E,EAAaC,QAAU,SAClB,CAEL,IAAIC,EAAW5D,KAAKe,MAAMtC,EAASmF,UAE/BC,EAAU,sBAAK7B,UAAU,eAAf,UAA8B,qDAA4B,uBAAM8B,SAAU,EAAKC,YAAY/E,KAAK,GAAtC,UAA6C,wBAAQqD,KAAK,UAAb,SACnHuB,EAASpC,KAAI,SAAAmC,GACX,OAAO,wBAAQ7D,MAAO6D,EAAf,SAAuCA,GAAVA,QAE9B,uBAAOrD,KAAK,SAASR,MAAM,iBAErC4D,EAAahF,MAAQ,CACnBC,MAAK,EACLC,QAAQiF,EACRhF,MAAM,MAER6E,EAAaC,QAAUlF,EAASkF,QAElCD,EAAavD,SAAW1B,EAAS4D,KACjCqB,EAAaxF,OAAS,EACtBwF,EAAahB,SAAWjE,EAASiE,SACjCgB,EAAaM,gBAAkBvF,EAASuF,gBAGxC,EAAKxE,SAASkE,GAAa,WACzB,EAAKO,mC,mCAKb,WACE,IAAIC,EAAgB3E,KAAKvB,MAAMgG,gBAAgBG,OAAO,EAAE,GACpDC,EAAe7E,KAAKvB,MAAMgG,gBAAgBG,OAAO5E,KAAKvB,MAAMgG,gBAAgB/C,OAAO,GAAG1B,KAAKvB,MAAMgG,gBAAgB/C,QAKjH5C,EAAa,CACfgG,MAAM,CACJ7B,SANajD,KAAKvB,MAAM0E,SAASC,QAAQuB,GAOzCjD,OAAO,EACPmB,MAAM,WAERkC,KAAK,CACH9B,SAVYjD,KAAKvB,MAAM0E,SAASC,QAAQyB,GAAc,EAWtDnD,OAAO,EACPmB,MAAM,YAGNmC,EAAY,sBAAKvC,UAAU,eAAf,UAA8B,iDAAwB,uBAAM8B,SAAUvE,KAAKiF,eAAexF,KAAKO,MAAzC,UACpE,yBAAQ8C,KAAK,MAAb,UAAmB,wBAAQvC,MAAM,IAAd,wBAAqC,wBAAQA,MAAM,IAAd,2BACxD,uBAAOQ,KAAK,SAASR,MAAM,iBAE7BP,KAAKC,SAAL,aACEtB,OAAO,EACPQ,MAAM,CACJC,MAAK,GAEPN,WAAWA,GALb,QAMQ,CACJM,MAAK,EACLC,QAAQ2F,EACR1F,MAAM,KACN8B,UAAS,O,yBAIf,SAAYxB,GAAG,IAAD,OACZA,EAAEgE,iBAEF,IAAIQ,EAAUxE,EAAEE,OAAOoF,QAAQ3E,MAG5B6D,GAASpE,KAAKvB,MAAM2F,QAErBpE,KAAK0E,wBAGLV,MADU1F,EAAQ,8BAA8B8F,GACrCH,MAAK,SAAC3C,GAAQ,OAAOA,EAAI4C,UAASD,MAAK,SAAC/E,GAEjD,IAAIiF,EAAe,EAAK1F,MACxB0F,EAAaC,QAAUlF,EAASkF,QAChCD,EAAaM,gBAAkBvF,EAASuF,gBAGxC,IAAIE,EAAgB,EAAKlG,MAAMgG,gBAAgBG,OAAO,EAAE,GACpDC,EAAe,EAAKpG,MAAMgG,gBAAgBG,OAAO,EAAKnG,MAAMgG,gBAAgB/C,OAAO,GAAG,EAAKjD,MAAMgG,gBAAgB/C,QAKjH5C,EAAa,CACfgG,MAAM,CACJ7B,SANa,EAAKxE,MAAM0E,SAASC,QAAQuB,GAOzCjD,OAAO,EACPmB,MAAM,WAERkC,KAAK,CACH9B,SAVY,EAAKxE,MAAM0E,SAASC,QAAQyB,GAAc,EAWtDnD,OAAO,EACPmB,MAAM,YAGVsB,EAAarF,WAAaA,EAC1B,IAAIkG,EAAY,sBAAKvC,UAAU,eAAf,UAA8B,iDAAwB,uBAAM8B,SAAU,EAAKU,eAAexF,KAAK,GAAzC,UACpE,yBAAQqD,KAAK,MAAb,UAAmB,wBAAQvC,MAAM,IAAd,wBAAqC,wBAAQA,MAAM,IAAd,2BACxD,uBAAOQ,KAAK,SAASR,MAAM,iBAG7B4D,EAAahF,MAAQ,CACnBC,MAAK,EACLC,QAAQ2F,EACR1F,MAAM,KACN8B,UAAS,GASX,EAAKnB,SAASkE,GAAa,oB,yBAMjC,SAAYrE,GACVE,KAAKL,qBAAqB,4BAC1BK,KAAKC,SAAS,CACZ+B,QAAQ,CAAClC,GACTpB,KAAK,EACLC,OAAO,EACPyB,WAAU,M,4BAGd,SAAeR,GAGb,IAAIoD,EAFJpD,EAAEgE,iBAGF,IAAIuB,EAAWvF,EAAEE,OAAOsF,IAAI7E,MACf,KAAV4E,EACDnC,EAAIhD,KAAKvB,MAAMK,WAAWgG,MAAM7B,SACd,KAAVkC,IACRnC,EAAIhD,KAAKvB,MAAMK,WAAWiG,KAAK9B,UAGjC,IAAIoC,EAAcrF,KAAKvB,MAAM0E,SAASmC,UAAUtC,EAAE,GAAGA,EAAE,IAEnDc,EAAMxF,EAAQ,sCAAsC+G,EAExDrF,KAAKC,SAAS,CAACd,MAAM,CACnBC,MAAK,EACLC,QAAQ,8BAAK,4DAA8B,uBAA9B,iCACbC,MAAM6B,IACNC,UAAS,GAET+D,SAASA,IACT,WAAW,IAAD,OACVnB,MAAMF,GAAKG,MAAK,SAAC3C,GAAQ,OAAOA,EAAI4C,UAASD,MAAK,SAACsB,GAEjD,IAAIC,EAAmBD,EAASE,QAAQxD,KAAI,SAACnC,GAC3C,OAAOA,EAAO4F,OAAO5F,EAAO6F,YAG9B,EAAK1F,SAAS,CAACd,MAAM,CACnBC,MAAK,EACLC,QAAQ,4DACRC,MAAM6B,IACNC,UAAS,GAETY,QAAQuD,EAASE,UACjB,WAAW,IAAD,OACN3B,EAAMxF,EAAQ,uCAAuCsH,mBAAmBJ,EAAiB7B,KAAK,OAClGK,MAAMF,GAAKG,MAAK,SAAC3C,GAAO,OAAOA,EAAI4C,UAASD,MAAK,SAACsB,GAGhD,IADA,IAAIvD,EAAU,GACNgB,EAAE,EAAEA,EAAE,EAAKvE,MAAMuD,QAAQN,OAAOsB,IAAI,CAC1C,IAAIlD,EAAS,EAAKrB,MAAMuD,QAAQgB,GAC5B6C,EAAO/F,EAAO4F,OAAO5F,EAAO6F,SAEhC7F,EAAOgG,MAAQP,EAASM,GACxB7D,EAAQyB,KAAK3D,GAEf,EAAKG,SAAS,CAACd,MAAM,CACnBC,MAAK,GAEL4C,QAAQA,EACRtD,KAAK,IACL,WACA,IACIqH,EADAZ,EAAWnF,KAAKvB,MAAM0G,SAEtBa,EAAeC,OAAOC,YAExBH,EADW,KAAVZ,EACWgB,SAASC,uBAAuB,SAAS,GAAGC,wBAAwBC,IAGpEH,SAASC,uBAAuB,QAAQ,GAAGC,wBAAwBC,IAEjFpG,QAAQC,IAAI,eAAe4F,EAAUC,GACrCG,SAASC,uBAAuB,YAAY,GAAGG,SAAS,CACtDD,IAAKP,EAAWC,EAAa,EAC7BQ,SAAU,4B,8BAQxB,WACEtG,QAAQC,IAAI,wBAEZ,IAAIsG,EAAazG,KAAKvB,MAAMM,iBAAiBkE,SACzCoC,EAAcrF,KAAKvB,MAAM0E,SAASyB,OAAO6B,EAAW,GAAG,KAC3DvG,QAAQC,IAAIsG,GAEZ,IAAI3C,EAAMxF,EAAQ,sCAAsC+G,EACxDrF,KAAKC,SAAS,CAACd,MAAM,CACnBC,MAAK,EACLC,QAAQ,2DACRC,MAAM6B,IACNC,UAAS,KAET,WAAW,IAAD,OACV4C,MAAMF,GAAKG,MAAK,SAAC3C,GAAQ,OAAOA,EAAI4C,UAASD,MAAK,SAACsB,GAEjD,IAAIC,EAAmBD,EAASE,QAAQxD,KAAI,SAACnC,GAC3C,OAAOA,EAAO4F,OAAO5F,EAAO6F,YAG9B,EAAK1F,SAAS,CAACd,MAAM,CACnBC,MAAK,EACLC,QAAQ,4DACRC,MAAM6B,IACNC,UAAS,GAETY,QAAQuD,EAASE,UACjB,WAAW,IAAD,OACN3B,EAAMxF,EAAQ,uCAAuCsH,mBAAmBJ,EAAiB7B,KAAK,OAClGK,MAAMF,GAAKG,MAAK,SAAC3C,GAAO,OAAOA,EAAI4C,UAASD,MAAK,SAACsB,GAIhD,IADA,IAAIvD,EAAU,GACNgB,EAAE,EAAEA,EAAE,EAAKvE,MAAMuD,QAAQN,OAAOsB,IAAI,CAC1C,IAAIlD,EAAS,EAAKrB,MAAMuD,QAAQgB,GAC5B6C,EAAO/F,EAAO4F,OAAO5F,EAAO6F,SAEhC7F,EAAOgG,MAAQP,EAASM,GACxB7D,EAAQyB,KAAK3D,GAGf,EAAKG,SAAS,CAACd,MAAM,CACnBC,MAAK,EACLC,QAAQ,4DACRC,MAAM6B,IACNC,UAAS,GAETY,QAAQA,IACR,6B,wBAUZ,WAAc,IAAD,OAEL0E,EAAoC,KAArB1G,KAAKvB,MAAM0G,SAAcnF,KAAKvB,MAAMK,WAAWgG,MAAM7B,SAASjD,KAAKvB,MAAMK,WAAWiG,KAAK9B,SAC9G/C,QAAQC,IAAI,qBAAqBuG,GACjC,IAAMC,EAAiB,CACrB,cAAc3G,KAAKvB,MAAM0E,SAASyD,MAAMF,EAAa,KAAMA,EAAa,KACxE,cAAc1G,KAAKvB,MAAM0E,SAASyD,MAAMF,EAAa,IAAKA,EAAa,KACvE,cAAc1G,KAAKvB,MAAM0E,SAASyD,MAAMF,EAAa,IAAKA,EAAa,KACvE,cAAc1G,KAAKvB,MAAM0E,SAASyD,MAAMF,EAAa,IAAMA,EAAa,OAEtEG,EAAuBC,EAAOC,KAAKtG,KAAKC,UAAUiG,IAAiBK,SAAS,UAChFhH,KAAKC,SAAS,CACZd,MAAM,CACJC,MAAK,EACLC,QAAQ,iEACRC,MAAM6B,IACNC,UAAS,KAEX,WACAlB,QAAQC,IAAI7B,EAAQ,qCAAqCuI,GACzD7C,MAAM1F,EAAQ,qCAAqCuI,GAAsB5C,MAAK,SAAA3C,GAAO,OAAOA,EAAI4C,UAAUD,MAAK,SAAC3C,GAC9GpB,QAAQC,IAAImB,GACZ,EAAKrB,SAAS,CAACmC,QAAQd,EAAI5C,KAAK,EAAES,MAAM,CACtCC,MAAK,EACLC,QAAQ,iEACRC,MAAM6B,IACNC,UAAS,KAET,WACAlB,QAAQC,IAAI,EAAK1B,kB,uBAKzB,SAAUmB,GAAG,IAAD,OACVA,EAAEgE,iBACF,IAAIqD,EAASrH,EAAEE,OAAOiE,SAASkD,OAAO1G,MAEtCP,KAAKC,SAAS,CAACV,WAAW0H,EAAOvI,KAAK,EAAEC,OAAO,EAAEyB,WAAU,IAAO,WAChEF,QAAQC,IAAI,eACZD,QAAQC,IAAI,EAAK1B,OACb,EAAKA,MAAM2D,SAAqC,IAA3B,EAAK3D,MAAM2D,QAAQV,QAC1C,EAAKwF,kB,+BAIX,SAAkBC,EAAUC,GAAK,IAAD,OAC1BC,EAAc5G,KAAKe,MAAMf,KAAKC,UAAWV,KAAKvB,MAAM8D,aAAgBvC,KAAKvB,MAAM8D,aAAd,KACrE8E,EAAYD,GAAOD,EACnBnH,KAAKL,qBAAqB,wBAAwByH,GAClDpH,KAAKC,SAAS,CAACsC,aAAa8E,IAAa,WAEvC,EAAKpH,SAAS,CAAClB,iBAAiB,OAAM,WACpC,IAAIuI,EAAgBxF,OAAOC,KAAK,EAAKtD,MAAM8D,cACxC+E,EAAc5F,QAA8B,GAAtB4F,EAAc5F,SAErCxB,QAAQC,IAAI,aACZD,QAAQC,IAAI7B,EAAQ,4BAA4B,EAAKG,MAAMuD,QAAQ,GAAG0D,OAAO,EAAKjH,MAAMuD,QAAQ,GAAG2D,SAAS,EAAKlH,MAAMuD,QAAQ,GAAGuF,KAClI,EAAKtH,SAAS,CACZd,MAAM,CACJC,MAAK,EACLC,QAAQ,8DACRC,MAAM6B,IACNC,UAAS,KAEX,WACA4C,MAAM1F,EAAQ,4BAA4B,EAAKG,MAAMuD,QAAQ,GAAG0D,OAAO,EAAKjH,MAAMuD,QAAQ,GAAG2D,SAAS,EAAKlH,MAAMuD,QAAQ,GAAGuF,KAAKtD,MAAK,SAAA3C,GAAO,OAAOA,EAAI4C,UAAUD,MAAK,SAAC3C,GACtKpB,QAAQC,IAAImB,GACRA,EAAIqB,OACN,EAAK1C,SAAS,CACZvB,KAAK,EACLS,MAAO,CACLC,MAAK,KAIX,EAAKa,SAAS,CACVvB,KAAK,EACLgE,OAAOpB,EACPnC,MAAO,CACPC,MAAK,oB,6BAYrB,WAAmB,IAAD,OAChB4E,MAAMiC,OAAOhD,SAASuE,OAAO,gCAAgCvD,MAAK,SAAC3C,GAAO,OAAOA,EAAImG,UAAUxD,MAAK,SAAC3C,GACnG,IAAMjB,EAAOiB,EACb0C,MAAMiC,OAAOhD,SAASuE,OAAO,8BAA8BvD,MAAK,SAAC3C,GAAO,OAAOA,EAAImG,UAASxD,MAAK,SAACyD,GAChG,IAWIC,EAXEC,EAAUF,EACVG,EAAa,SAACC,EAAKhF,EAAMD,GAC7B,OAAO+E,EACNG,MAAM,gBAAgBpE,KAAKmE,GAC3BC,MAAM,iBAAiBpE,KAAKb,GAC5BiF,MAAM,kBAAkBpE,KAAKd,IAE5BgD,EAAO,EAAKpH,MAAM0E,SAChBrD,EAAS,EAAKrB,MAAMuD,QAAQ,GAAG0D,OAAOsB,WAAW,EAAKvI,MAAMuD,QAAQ,GAAG2D,SAASqB,WAChFgB,EAAcnC,EAAKoC,cAAcC,MAAMpI,EAAOmI,eAC9CE,EAAiBtC,EAAKoC,cAAcC,MAAM,EAAK5E,QAAQxD,EAAOmI,gBAEhED,EACFL,EAAUK,EAAYI,MAAM,EACnBD,IACTR,EAAUQ,EAAeC,OAE3B,IAAMC,EAAWF,EAAeR,EAAQ,EAAEA,EAAQ,GAC5C7C,EAAQ,EAAEjF,SAAS,EAAKpB,MAAMK,WAAWgG,MAAM7B,UAC/C8B,EAAO,EAAElF,SAAS,EAAKpB,MAAMK,WAAWiG,KAAK9B,UACnD4C,EAAQ,EAAKpH,MAAMc,WAAgBsG,EAAKjB,OAAO,EAAEyD,EAAS,GAAG,EAAK5J,MAAMc,WAAWsG,EAAKjB,OAAOyD,EAAS,EAAExC,EAAKnE,QAAjFmE,EAC9B,IAAMyC,EAAa,CACjBT,EAAW/C,EAAM,MAAMA,EAAM,GAAG,cAAc,WAC9C+C,EAAW9C,EAAK,MAAMA,EAAK,GAAG,aAAa,WAC3C8C,EAAYhI,SAAS,EAAE,EAAKpB,MAAMK,WAAX,eAA4C,MAAMe,SAAS,EAAE,EAAKpB,MAAMK,WAAX,eAA2C,EAAKL,MAAMK,WAAX,aAAyC,yBAAyB,WACjM+I,EAAYhI,SAAS,EAAE,EAAKpB,MAAMK,WAAX,eAA4C,MAAMe,SAAS,EAAE,EAAKpB,MAAMK,WAAX,eAA2C,EAAKL,MAAMK,WAAX,aAAyC,yBAAyB,WACjM+I,EAAYhI,SAAS,EAAE,EAAKpB,MAAMK,WAAX,eAA4C,MAAMe,SAAS,EAAE,EAAKpB,MAAMK,WAAX,eAA2C,EAAKL,MAAMK,WAAX,aAAyC,qBAAqB,WAC7L+I,EAAYhI,SAAS,EAAE,EAAKpB,MAAMK,WAAX,eAA4C,MAAMe,SAAS,EAAE,EAAKpB,MAAMK,WAAX,eAA2C,EAAKL,MAAMK,WAAX,aAAyC,qBAAqB,WAC7L+I,EAAWF,EAAQ,MAAM9H,SAAS8H,GAAS,IAAI,SAAS,WACxDE,EAAWQ,EAAS,MAAMxI,SAASwI,GAAU,GAAG,MAAM,YA+BlDE,EAAO,IAAIC,KACXC,EAAMF,EAAKG,UACXC,EAHS,CAAC,MAAM,MAAM,MAAM,MAAM,MAAM,MAAM,MAAM,MAAM,MAAM,MAAM,MAAM,OAG7DJ,EAAKK,YACpBC,EAAON,EAAKO,cAQZtI,EAPUH,EACf0H,MAAM,cAAcpE,KAAK2E,EAAW3E,KAAK,KACzCoE,MAAM,UAAUpE,KAAK,EAAKlF,MAAMmC,UAChCmH,MAAM,YAAYpE,KAAK,EAAKlF,MAAM0E,SAASzB,QAC3CqG,MAAM,UAAUpE,KAAK8E,EAAI,IAAIE,EAAM,IAAIE,GACvCd,MAAM,UAAUpE,KAtCG,WAUlB,IARA,IAAIoF,EAAU,GACRC,EAAS,SAACC,GAEd,IADA,IAAIC,EAAW,GACPlG,EAAE,EAAEA,EAAE,EAAEiG,EAAIvH,OAAOsB,IACzBkG,EAASzF,KAAK,IAEhB,OAAOyF,GAEDlG,EAAE,EAAEA,EAAE6C,EAAKnE,QAAQ,CAIzB,GAHGsB,EAAE,KAAK,GACR+F,EAAQtF,KAAK,MAER,IAAJT,GAAOA,EAAE,KAAK,EAAG,EACEA,EAAE,GAAGgE,WACzB+B,EAAQtF,KAAKuF,EAAOhG,EAAE,GAAGW,KAAK,MAAMX,EAAE,GAAG,KAExCA,EAAE,GAAG6C,EAAKnE,OACXqH,EAAQtF,KAAKoC,EAAKe,MAAM5D,EAAE6C,EAAKnE,SAE/BqH,EAAQtF,KAAKoC,EAAKe,MAAM5D,EAAEA,EAAE,KAE9B+F,EAAQtF,KAAK,IACbT,GAAI,GAEN,OAAO+F,EAAQpF,KAAK,KAYAwF,IAGlBxI,EAAW,EAAKlC,MAAMmC,SAAS,OAC/BC,EAAO,IAAIC,KAAK,CAACN,GAAS,CAC7BO,KAAM,6BAEPC,iBAAOH,EAAMF,W,mCAInB,SAAsBf,GAAG,IAAD,OAClBwJ,EAAWxJ,EAAEE,OAAOS,MAExBP,KAAKC,SAAS,CAACoJ,gBAAgBD,IAAU,WACvClJ,QAAQC,IAAI,EAAK1B,MAAM4K,sB,qCAG3B,SAAwBzJ,GAAG,IAAD,OAExB,GADAA,EAAEgE,kBACE5D,KAAKvB,MAAM4K,gBAAiB,OAAO,EAEvC,IAAMvF,EAAOmC,OAAOhD,SAASuE,OAAO,mBAAqBxH,KAAKvB,MAAM4K,gBAAgBtB,MAAM,KAAKpE,KAAK,OAAQ,OAC5GzD,QAAQC,IAAI2D,GACZE,MAAMF,GAAKG,MAAK,SAAC3C,GAAO,OAAOA,EAAImG,UAASxD,MAAK,SAAC5D,GAChD,IAAMiJ,EAAUjJ,EAAK0H,MAAM,mBAAmB,GAC1CwB,EAAiB,EAAK9K,MAAMuD,QAAQ,GAAG0D,OAAO,EAAKjH,MAAMuD,QAAQ,GAAG2D,SAAS,EAAKlH,MAAMuD,QAAQ,GAAGuF,IACjGb,EAAe,EAAKjI,MAAM0E,SAASqG,OAAsC,MAA/B,EAAK/K,MAAMuD,QAAQ,GAAGyH,OAAa,EAAKnG,QAAQiG,GAAgBA,GAC5GG,EAAO,EAAKjL,MAAM0E,SAASyD,MAAMF,EAAa,IAAMA,GAClDiD,EAAWtJ,EAAK0H,MAAM,iBAAiB,GAAGA,MAAM,mBAAmB,GACrE6B,EAAO,EAAKnL,MAAM0E,SAASyD,MAAMF,EAAcA,EAAa,KAC1DmD,EAAWxJ,EAAK0H,MAAM,iBAAiB,GAC7C,GAAG,EAAKtJ,MAAMqL,WAAY,CACxB,IAAML,EAAS,EAAKhL,MAAMsL,iBAAiB,GAAGN,OACxC3J,EAAkB,MAAT2J,EAAa,EAAKnG,QAAQ,EAAK7E,MAAMqB,QAAQ,EAAKrB,MAAMqB,OACnEkK,EAAON,EAAKE,EACVjC,EAAUqC,EAAK/B,cAAcC,MAAMpI,EAAOmI,eAMhDyB,GAJEM,EADU,MAATP,EACMO,EAAKpF,OAAO,EAAE+C,EAAQS,OAAO,EAAK3J,MAAMc,WAAWyK,EAAKpF,OAAO+C,EAAQS,MAAM,EAAE4B,EAAKtI,QAEpFsI,EAAKpF,OAAO,EAAE+C,EAAQS,MAAMtI,EAAO4B,OAAO,GAAG,EAAKjD,MAAMc,WAAWyK,EAAKpF,OAAO+C,EAAQS,MAAMtI,EAAO4B,OAAOsI,EAAKtI,SAE7GkF,MAAM,EAAEqD,KAAKC,MAAMF,EAAKtI,OAAO,GAAG,GAC9CkI,EAAOI,EAAKpD,MAAMqD,KAAKC,MAAMF,EAAKtI,OAAO,GAAGsI,EAAKtI,QAQnD,IANA,IAAIyI,EAAc9J,EAAK0H,MAAM,mBAAmB,GAAGA,MAAM,iBAAiB,GAAGA,MAAM,IAC/EqC,EAAQ,EACRC,EAAchK,EAAK0H,MAAM,mBAAmB,GAAGA,MAAM,iBAAiB,GAAGA,MAAM,IAC/EuC,EAAQ,EAGJC,EAAE,EAAEA,EAAEJ,EAAYzI,OAAO6I,IACX,MAAjBJ,EAAYI,IAA2B,OAAjBJ,EAAYI,IAAYC,MAAML,EAAYI,MAEjEJ,EAAYI,GAAKb,EAAKU,GACtBA,KAIJ,IAAI,IAAIG,EAAE,EAAEA,EAAEF,EAAY3I,OAAO6I,IACX,MAAjBF,EAAYE,IAA2B,OAAjBF,EAAYE,IAAYC,MAAMH,EAAYE,MAEjEF,EAAYE,GAAKX,EAAKU,GACtBA,KAKJ,IACM9J,EADQ8I,EAAUa,EAAYxG,KAAK,IAAMgG,EAAWU,EAAY1G,KAAK,IAAMkG,EAE7ElJ,EAAW,EAAKlC,MAAM4K,gBAAgB,QAAQ,EAAK5K,MAAMmC,SAAS,OAClEC,EAAO,IAAIC,KAAK,CAACN,GAAS,CAC5BO,KAAM,6BAERC,iBAAOH,EAAMF,Q,8BAGjB,WAAmB,IAAD,OACVmD,EAAMmC,OAAOhD,SAASuE,OAAO,qBACnCxD,MAAMF,GAAKG,MAAK,SAAC3C,GAAO,OAAOA,EAAImG,UAASxD,MAAK,SAAC5D,GAChD,IAAIoK,EAAWpK,EAAK0H,MAAM,uBAAuB,GAC7C2C,EAAYrK,EAAK0H,MAAM,qBAAqB,GAC5CpF,EAAQ,EAAKlE,MAAMiE,OAAOC,MAAM2C,UAAU,EAAE,GAAG,IAAI,EAAK7G,MAAMiE,OAAOC,MAAM2C,UAAU,EAAE,IAAI,IAAI,EAAK7G,MAAMiE,OAAOC,MAAM2C,UAAU,IAIjIzE,EAAO,IAAIC,KAAK,CAHL2J,EAAS9H,EAAM+H,GAGA,CAC7B3J,KAAM,6BAEPC,iBAAOH,EALQ,+B,gCASnB,WACE,IAAIyD,EAAU,CACZqG,KAAMxE,SAASyE,cAAc,aAC7BC,WAAY,MACZC,UAAW,GAgBTC,EAAW,IAAIC,sBAdO,SAACC,GACzBA,EAAQC,SAAQ,SAAAC,GACd,GAAIA,EAAMC,eAAgB,CACbD,EAAMrL,OAEbqL,EAAME,wBAS2C/G,GACvDgH,EAAqBnF,SAASyE,cAAc,mBAC7CU,GACDP,EAASQ,QAAQD,K,oBAKrB,WAAU,IAAD,OA8CDE,EAAiBxL,KAAKvB,MAAMK,WAAgBgD,OAAOC,KAAK/B,KAAKvB,MAAMK,YAA5B,KAEvCC,EAAoBiB,KAAKvB,MAAMM,iBAAsBiB,KAAKvB,MAAMM,iBAAhB,KAChD0M,EAA4B1M,EAAsBA,EAAiBkE,SAAtB,KAC7CyI,EAAgB1L,KAAKvB,MAAM0E,SAAcnD,KAAKvB,MAAM0E,SAAS4E,MAAM,IAAI9F,KAAI,SAAC0J,EAAO3I,GACvF,IAAI4I,EAAmB,GAKvB,GAJG7M,GAAkBiE,GAAGyI,GAA0BzI,EAAEyI,EAAyB1M,EAAiB2C,SAC5FkK,EAAiBnI,KAAK,qBACtBmI,EAAiBnI,KAAK1E,EAAiB+D,OAEtC0I,GAAeA,EAAc9J,OAAO,EACrC,IAAI,IAAI6I,EAAE,EAAEA,EAAEiB,EAAc9J,OAAO6I,IAAI,CACrC,IAAIlI,EAAMmJ,EAAcjB,GACpBxL,EAAmB,EAAKN,MAAMK,WAAWuD,GACzCyC,EAAQ/F,EAAiBkE,SACzB8B,EAAOD,EAAM/F,EAAiB2C,OAC/BsB,GAAG8B,GAAO9B,EAAE+B,IACT6G,EAAiBC,SAASxJ,IAC5BuJ,EAAiBnI,KAAKpB,IAK9B,OAAO,qBAAMI,UAAWmJ,EAAiBjI,KAAK,KAAK,iBAA5C,SAA+DgI,OAnB9B,KAqBpCG,EAAc9L,KAAKvB,MAAMuD,QAAahC,KAAKvB,MAAMuD,QAAQC,KAAI,SAACnC,GAClE,OAAO,sBAAK2C,UAAW,kBAAmBgJ,GAAyB,YAAsCM,QAAUN,EAA8B,EAAKO,YAAYvM,KAAK,EAAKK,GAAhC,KAAyCmM,aAAc,EAAKC,gBAAgBzM,KAAK,EAAKK,EAAO4F,OAAO5F,EAAO6F,SAAS7F,EAAOyH,IAAI,2BAA2B,MAAO4E,aAAc,EAAKC,eAAe3M,KAAK,GAA7U,UACL,8BAAMK,EAAO4F,OAAO5F,EAAO6F,SAAS7F,EAAOyH,MAC3C,gCAAK,gDAA2BzH,EAAOgG,MAAUhG,EAAOgG,MAAX,OAC7C,gCAAK,4CAAsBhG,EAAO2J,UAClC,gCAAK,iDAA2B3J,EAAOuM,mBALJ,KA0CjCC,EAAS,sBAAK7J,UAAU,cAAf,UACZ,kDACA,2CApCyB,WAC1B,GAAI,EAAKhE,MAAMK,WAAWyN,QAA1B,CAWA,IARA,IAAIzH,EAAQjF,SAASY,KAAKe,MAAMf,KAAKC,UAAU,EAAKjC,MAAMK,WAAWgG,MAAM7B,YACvEsJ,EAAU1M,SAAS,EAAKpB,MAAMK,WAAWyN,QAAQtJ,UACjDC,EAAS,GACTsJ,EAASvC,KAAKwC,KAAKF,EAAUzH,GAAS,GAAG,EACzCY,EAAS,EAAKjH,MAAMuD,QAAQ,GAAG0D,OAAOqC,MAAM,IAC5CpC,EAAW,EAAKlH,MAAMuD,QAAQ,GAAG2D,SAASoC,MAAM,IAChDR,EAAM,EAAK9I,MAAMuD,QAAQ,GAAGuF,IAAIQ,MAAM,IAElC/E,EAAE,EAAEA,EAAE0C,EAAOhE,OAAOsB,IAC1BE,EAAOO,KAAK,gCAAMiC,EAAO1C,GAAG,8BAAMwJ,QAClC1H,GAAc,EACd0H,EAASvC,KAAKwC,KAAKF,EAAUzH,GAAS,GAAG,EAG3C,IAAI,IAAI9B,EAAE,EAAEA,EAAE,EAAKvE,MAAMuD,QAAQ,GAAG2D,SAASjE,OAAOsB,IAClDE,EAAOO,KAAK,gCAAMkC,EAAS3C,GAAG,8BAAMwJ,QACpC1H,GAAc,EACd0H,EAASvC,KAAKwC,KAAKF,EAAUzH,GAAS,GAAG,EAG3C5B,EAAOO,KAAK,8BAAM,OAClB,IAAI,IAAIT,EAAE,EAAEA,EAAE,EAAKvE,MAAMuD,QAAQ,GAAGuF,IAAI7F,OAAOsB,IAC7CE,EAAOO,KAAK,sBAAKiJ,MAAO,CAACC,gBAAgB,WAA7B,UAA0CpF,EAAIvE,GAAG,8BAAMwJ,QACnE1H,GAAc,EACd0H,EAASvC,KAAKwC,KAAKF,EAAUzH,GAAS,GAAG,EAI3C,OAAO,qBAAKrC,UAAU,aAAf,SAA6BS,KAIrB0J,MACd,8BAAK,uBAAMrI,SAAUvE,KAAKI,UAAUX,KAAKO,MAApC,UAA2C,uBAAO8C,KAAK,SAAS/B,KAAK,SAAS,uBAAOA,KAAK,SAASR,MAAM,gBAC9G,4CACA,sBAAKkC,UAAU,cAAf,UACC,8BAAK,qCAAO,uBAAP,cACL,sBAAKA,UAAU,QAAf,UACE,sBAAKA,UAAU,SAAf,UAAwB,qBAAKA,UAAU,OAAf,eAA6B,qBAAKA,UAAU,OAAf,eAA6B,qBAAKA,UAAU,OAAf,eAA6B,qBAAKA,UAAU,OAAf,kBAC/G,sBAAKA,UAAU,MAAf,UACE,qBAAKA,UAAU,OAAf,eACA,sBAAKA,UAAU,OAAf,UACE,sBAAKA,UAAU,WAAf,UACE,gCAAK,qBAAKA,UAAU,WAAf,iBAAmC,qBAAKA,UAAU,WAAf,oBACxC,qBAAKA,UAAU,aAAf,oBAEF,sBAAKA,UAAU,WAAf,UACE,gCAAK,qBAAKA,UAAU,WAAf,iBAAmC,qBAAKA,UAAU,WAAf,oBACxC,qBAAKA,UAAU,aAAf,uBAGJ,qBAAKA,UAAU,OAAf,SACE,sBAAKA,UAAU,WAAf,UACE,gCAAK,qBAAKA,UAAU,WAAf,iBAAmC,qBAAKA,UAAU,WAAf,iBAAmC,qBAAKA,UAAU,WAAf,iBAAmC,qBAAKA,UAAU,WAAf,oBAC9G,qBAAKA,UAAU,aAAf,sBAGJ,sBAAKA,UAAU,OAAf,UACE,sBAAKA,UAAU,WAAf,UACE,gCAAK,qBAAKA,UAAU,WAAf,iBAAmC,qBAAKA,UAAU,WAAf,oBACxC,qBAAKA,UAAU,aAAf,oBAEF,sBAAKA,UAAU,WAAf,UACA,gCAAK,qBAAKA,UAAU,WAAf,iBAAmC,qBAAKA,UAAU,WAAf,oBACtC,sBAAKA,UAAU,kBAAf,iBAAqC,uBAArC,gBAGJ,sBAAKA,UAAU,OAAf,UACE,sBAAKA,UAAU,WAAf,UACE,gCAAK,qBAAKA,UAAU,WAAf,iBAAmC,qBAAKA,UAAU,WAAf,oBACxC,qBAAKA,UAAU,aAAf,oBAEF,sBAAKA,UAAU,WAAf,UACA,gCAAK,qBAAKA,UAAU,WAAf,iBAAmC,qBAAKA,UAAU,WAAf,oBACtC,sBAAKA,UAAU,kBAAf,iBAAqC,uBAArC,gBAGJ,sBAAKA,UAAU,WAAf,UACE,oCACA,oCACA,oCACA,0CAGJ,sBAAKA,UAAU,MAAf,UACE,qBAAKA,UAAU,OAAf,eACA,qBAAKA,UAAU,OAAf,SACE,sBAAKA,UAAU,WAAf,UACE,gCAAK,qBAAKA,UAAU,WAAf,iBAAmC,qBAAKA,UAAU,WAAf,iBAAmC,qBAAKA,UAAU,WAAf,iBAAmC,qBAAKA,UAAU,WAAf,oBAC9G,qBAAKA,UAAU,aAAf,sBAGJ,qBAAKA,UAAU,OAAf,SACE,sBAAKA,UAAU,WAAf,UACE,gCAAK,qBAAKA,UAAU,WAAf,iBAAmC,qBAAKA,UAAU,WAAf,iBAAmC,qBAAKA,UAAU,WAAf,iBAAmC,qBAAKA,UAAU,WAAf,oBAC9G,qBAAKA,UAAU,aAAf,sBAGJ,sBAAKA,UAAU,OAAf,UACE,sBAAKA,UAAU,WAAf,UACE,gCAAK,qBAAKA,UAAU,WAAf,iBAAmC,qBAAKA,UAAU,WAAf,oBACxC,qBAAKA,UAAU,aAAf,oBAEF,sBAAKA,UAAU,WAAf,UACE,gCAAK,qBAAKA,UAAU,WAAf,iBAAmC,qBAAKA,UAAU,WAAf,oBACxC,qBAAKA,UAAU,aAAf,uBAGJ,qBAAKA,UAAU,OAAf,SACE,sBAAKA,UAAU,WAAf,UACE,gCAAK,qBAAKA,UAAU,WAAf,iBAAmC,qBAAKA,UAAU,WAAf,iBAAmC,qBAAKA,UAAU,WAAf,iBAAmC,qBAAKA,UAAU,WAAf,oBAC9G,qBAAKA,UAAU,aAAf,sBAGJ,sBAAKA,UAAU,WAAf,UACE,oCACA,oCACA,oCACA,0CAGJ,sBAAKA,UAAU,MAAf,UACE,qBAAKA,UAAU,OAAf,eACA,sBAAKA,UAAU,OAAf,UACE,sBAAKA,UAAU,WAAf,UACE,gCAAK,qBAAKA,UAAU,WAAf,iBAAmC,qBAAKA,UAAU,WAAf,iBAAmC,qBAAKA,UAAU,WAAf,oBAC3E,qBAAKA,UAAU,aAAf,oBAEF,sBAAKA,UAAU,WAAf,UACE,8BAAK,qBAAKA,UAAU,WAAf,mBACL,qBAAKA,UAAU,iBAAf,uBAGJ,qBAAKA,UAAU,OAAf,SACE,sBAAKA,UAAU,WAAf,UACE,gCAAK,qBAAKA,UAAU,WAAf,iBAAmC,qBAAKA,UAAU,WAAf,iBAAmC,qBAAKA,UAAU,WAAf,iBAAmC,qBAAKA,UAAU,WAAf,oBAC9G,qBAAKA,UAAU,aAAf,sBAGJ,sBAAKA,UAAU,OAAf,UACE,sBAAKA,UAAU,WAAf,UACE,gCAAK,qBAAKA,UAAU,WAAf,iBAAmC,qBAAKA,UAAU,WAAf,oBACxC,qBAAKA,UAAU,aAAf,oBAEF,sBAAKA,UAAU,WAAf,UACA,gCAAK,qBAAKA,UAAU,WAAf,iBAAmC,qBAAKA,UAAU,WAAf,oBACtC,qBAAKA,UAAU,aAAf,uBAGJ,sBAAKA,UAAU,OAAf,UACE,sBAAKA,UAAU,WAAf,UACE,gCAAK,qBAAKA,UAAU,WAAf,iBAAmC,qBAAKA,UAAU,WAAf,oBACxC,qBAAKA,UAAU,aAAf,oBAEF,sBAAKA,UAAU,WAAf,UACA,gCAAK,qBAAKA,UAAU,WAAf,iBAAmC,qBAAKA,UAAU,WAAf,oBACtC,qBAAKA,UAAU,aAAf,uBAGJ,sBAAKA,UAAU,WAAf,UACE,oCACA,oCACA,oCACA,0CAGJ,sBAAKA,UAAU,MAAf,UACE,qBAAKA,UAAU,OAAf,eACA,qBAAKA,UAAU,OAAf,SACE,sBAAKA,UAAU,WAAf,UACE,gCAAK,qBAAKA,UAAU,WAAf,iBAAmC,qBAAKA,UAAU,WAAf,iBAAmC,qBAAKA,UAAU,WAAf,iBAAmC,qBAAKA,UAAU,WAAf,oBAC9G,qBAAKA,UAAU,aAAf,sBAGJ,qBAAKA,UAAU,OAAf,SACE,sBAAKA,UAAU,WAAf,UACE,gCAAK,qBAAKA,UAAU,WAAf,iBAAmC,qBAAKA,UAAU,WAAf,iBAAmC,qBAAKA,UAAU,WAAf,iBAAmC,qBAAKA,UAAU,WAAf,oBAC9G,qBAAKA,UAAU,aAAf,sBAGJ,sBAAKA,UAAU,OAAf,UACE,sBAAKA,UAAU,WAAf,UACE,gCAAK,qBAAKA,UAAU,WAAf,iBAAmC,qBAAKA,UAAU,WAAf,oBACxC,qBAAKA,UAAU,aAAf,oBAEF,sBAAKA,UAAU,WAAf,UACA,gCAAK,qBAAKA,UAAU,WAAf,iBAAmC,qBAAKA,UAAU,WAAf,oBACtC,qBAAKA,UAAU,aAAf,uBAGJ,qBAAKA,UAAU,OAAf,SACE,sBAAKA,UAAU,WAAf,UACA,gCAAK,qBAAKA,UAAU,WAAf,iBAAmC,qBAAKA,UAAU,WAAf,iBAAmC,qBAAKA,UAAU,WAAf,iBAAmC,qBAAKA,UAAU,WAAf,oBAC5G,qBAAKA,UAAU,aAAf,sBAGJ,sBAAKA,UAAU,WAAf,UACE,oCACA,oCACA,oCACA,6CAIN,8BAAK,qCAAO,uBAAP,oBAmET,OACA,sBAAKA,UAAU,MAAMsJ,QAAS/L,KAAK6M,cAAcpN,KAAKO,MAAtD,UACE,yBAAQyC,UAAU,aAAlB,UACE,qBAAKA,UAAU,YAAf,SAA2B,qBAAKqK,IAAKC,IAAMC,IAAI,WAC/C,sBAAKvK,UAAU,OAAf,UAAsB,qBAAKqK,IAAKlO,IAAWoO,IAAI,YAAYjB,QAAS/L,KAAKiN,SAASxN,KAAKO,QACrF,sBAAKyC,UAAU,YAAYiK,MAAO,CAACQ,SAAgC,IAAvBlN,KAAKvB,MAAMG,UAAkB,OAAO,QAAhF,UACE,qBAAK6D,UAAU,YAAYsJ,QAAS/L,KAAKmN,cAAc1N,KAAKO,MAAO,cAAY,IAA/E,gCACA,qBAAKyC,UAAU,YAAYsJ,QAAS/L,KAAKoN,WAAW3N,KAAKO,MAAO,cAAY,IAA5E,0BACA,sBAAKyC,UAAU,YAAasJ,QAAS/L,KAAKqN,iBAAiB5N,KAAKO,MAAhE,UAAwE,qBAAKyC,UAAW,iBAAwC,IAAxBzC,KAAKvB,MAAMI,WAAmB,OAAO,WAA7I,cAAiM,IAAxBmB,KAAKvB,MAAMI,WAAmB,OAAO,QAA9M,YACA,sBAAK4D,UAAU,YAAYsJ,QAAS/L,KAAKf,SAASQ,KAAKO,MAAvD,UAA+D,sBAAKyC,UAAU,YAAf,UAA2B,qBAAKA,UAAU,QAAf,eAA8B,qBAAKA,UAAU,QAAf,kBAAxH,yBAIN,sBAAKA,UAAW,UAAiC,IAAxBzC,KAAKvB,MAAMI,WAAmB,QAAQ,QAA/D,UACE,sBAAK4D,UAAU,UAAf,UACI,sBAAKA,WAA6B,GAAjBzC,KAAKvB,MAAMC,KAAQ,SAAS,IAAI,aAAjD,UACE,qBAAK+D,UAAU,qBAAsBsJ,QAAS/L,KAAKR,YAAYC,KAAKO,MAAO,YAAU,IAArF,SAAyF,qBAAK8M,IAAKQ,IAAU,YAAU,IAAIN,IAAI,eAC/H,uBAAOjB,QAAS/L,KAAKmN,cAAc1N,KAAKO,MAAO,cAAY,IAA3D,gCAEF,sBAAKyC,WAA6B,GAAjBzC,KAAKvB,MAAMC,KAAQ,SAAS,IAAI,aAAjD,UACE,qBAAK+D,UAAU,qBAAqBiK,MAAO,CAACa,cAAcvN,KAAKvB,MAAME,OAAO,EAAE,GAAG,QAASoN,QAAS/L,KAAKR,YAAYC,KAAKO,MAAO,YAAU,IAAIgN,IAAI,WAAlJ,SAA6J,qBAAKF,IAAKU,QACvK,wBAAOzB,QAAS/L,KAAKmN,cAAc1N,KAAKO,MAAO,cAAY,IAA3D,UAA+D,qBAAKyC,UAAU,aAAf,eAA/D,qBACEqJ,EAAgB,qBAAKrJ,UAAU,cAAciK,MAAO,CAACQ,QAAyB,GAAjBlN,KAAKvB,MAAMC,KAAQ,OAAO,QAAvE,SAAiFoN,IAAtF,QAEf,sBAAKrJ,WAA6B,GAAjBzC,KAAKvB,MAAMC,KAAQ,SAAS,IAAI,aAAc,YAAU,IAAzE,UACE,qBAAK+D,UAAU,qBAAqBiK,MAAO,CAACa,cAAcvN,KAAKvB,MAAME,OAAO,EAAE,GAAG,QAASoN,QAAS/L,KAAKR,YAAYC,KAAKO,MAAO,YAAU,IAAIgN,IAAI,WAAlJ,SAA6J,qBAAKF,IAAKW,IAAUT,IAAI,eACrL,uBAAOjB,QAAS/L,KAAKmN,cAAc1N,KAAKO,MAAO,cAAY,IAA3D,wBACCA,KAAKvB,MAAME,OAAO,EAAE,KAAK,qBAAK8D,UAAU,UAAUiK,MAAO,CAACQ,QAASlN,KAAKvB,MAAM2B,UAAiB,OAAP,QAA/D,SAAgFkM,OAE5G,sBAAK7J,WAA6B,GAAjBzC,KAAKvB,MAAMC,KAAQ,SAAS,IAAI,aAAc,YAAU,IAAzE,UACE,qBAAK+D,UAAU,qBAAqBiK,MAAO,CAACa,cAAcvN,KAAKvB,MAAME,OAAO,EAAE,GAAG,QAASoN,QAAS/L,KAAKR,YAAYC,KAAKO,MAAO,YAAU,IAAIgN,IAAI,WAAlJ,SAA6J,qBAAKF,IAAKY,IAAWV,IAAI,eACtL,uBAAOjB,QAAS/L,KAAKmN,cAAc1N,KAAKO,MAAO,cAAY,IAA3D,kCACA,qBAAKyC,UAAU,4BAA4BiK,MAAO,CAACQ,QAAyB,GAAjBlN,KAAKvB,MAAMC,KAAQ,OAAO,QAArF,SAhGW,WACnB,GAAI,EAAKD,MAAM2D,QAAf,CAGA,IAEID,EAFaL,OAAOC,KAAK,EAAKtD,MAAM2D,SAEZH,KAAI,SAACI,GAC/B,IAAIC,EAAgB,EAAK7D,MAAM2D,QAAQC,GAEvC,GAAG,EAAK5D,MAAM8D,cAAc,EAAK9D,MAAM8D,aAAaF,GAAK,CACvD,IAAIG,EAAe,EAAK/D,MAAM8D,aAAaF,GAC3C,OAAO,gCAAK,qBAAKI,UAAU,iBAAf,SAAiCJ,IAC3C,sBAAKI,UAAU,gBAAgBkL,YAAa,EAAKC,kBAAkBnO,KAAK,EAAK+C,EAAaH,GAAM8J,aAAc,EAAKC,eAAe3M,KAAK,GAAvI,UACA,8BAAO+C,EAAa,KACpB,gCAAM,uCAAe,8BAAMA,EAAa,QACxC,gCAAM,wCAAgB,8BAAMA,EAAa,QACzC,gCAAM,+DAAuC,8BAAMA,EAAa,QAChE,gCAAM,8DAAsC,8BAAMA,EAAa,cAGjE,OAAO,gCAAK,qBAAKC,UAAU,iBAAf,SAAiCJ,IAAWC,EAAcL,KAAI,SAACO,GACzE,OAAO,sBAAKC,UAAU,gBAAgBwJ,aAAc,EAAKC,gBAAgBzM,KAAK,EAAK+C,EAAa,GAAG,wBAAwB,YAAamL,YAAa,EAAKC,kBAAkBnO,KAAK,EAAK+C,EAAaH,GAAM8J,aAAc,EAAKC,eAAe3M,KAAK,GAAzO,UACP,8BAAO+C,EAAa,KACpB,gCAAM,uCAAe,8BAAMA,EAAa,QACxC,gCAAM,wCAAgB,8BAAMA,EAAa,QACzC,gCAAM,+DAAuC,8BAAMA,EAAa,QAChE,gCAAM,8DAAsC,8BAAMA,EAAa,oBAIrE,OAAO,8BAAML,KAkE0F0L,QAEjG,sBAAKpL,WAA6B,GAAjBzC,KAAKvB,MAAMC,KAAQ,SAAS,IAAI,aAAc,YAAU,IAAzE,UACE,qBAAK+D,UAAU,+BAA+BiK,MAAO,CAACa,cAAcvN,KAAKvB,MAAME,OAAO,EAAE,GAAG,QAASoN,QAAS/L,KAAKR,YAAYC,KAAKO,MAAO,YAAU,IAAIgN,IAAI,WAA5J,SAAuK,qBAAKF,IAAKgB,IAAed,IAAI,eACpM,uBAAOjB,QAAS/L,KAAKmN,cAAc1N,KAAKO,MAAO,cAAY,IAA3D,2BACkB,GAAjBA,KAAKvB,MAAMC,KA3DE,WAGtB,IAFA,IAAMqP,EAAiB,CAAC,kCAAkC,oDAAoD,kCAAkC,oDAAoD,+BAA+B,mCAAmC,oCAAoC,+BAA+B,mCAAmC,qCACxWC,EAAc,GACVhL,GAAG,EAAEA,EAAE+K,EAAerM,OAAOsB,KAC3B,IAALA,EACDgL,EAAYvK,KAAK,wBAAQwK,SAAO,EAAf,gCAEnBD,EAAYvK,KAAK,wBAAgBlD,MAAOwN,EAAe/K,GAAtC,SAA2C+K,EAAe/K,IAA7CA,IAIhC,OAAO,sBAAKP,UAAU,gBAAf,UACL,8BAAK,wBAAQA,UAAU,MAAMkL,YAAa,EAAKO,mBAAmBzO,KAAK,GAAlE,6BACL,qBAAKgD,UAAU,iBAAf,sBACA,8BAAK,wBAAQA,UAAU,MAAMkL,YAAa,EAAKQ,gBAAgB1O,KAAK,GAA/D,wBACL,qBAAKgD,UAAU,iBAAf,8BACA,8BAAK,wBAAQA,UAAU,MAAMkL,YAAa,EAAKS,iBAAiB3O,KAAK,GAAhE,wBACL,qBAAKgD,UAAU,iBAAf,8BACA,8BAAK,wBAAQ4L,SAAU,EAAKC,sBAAsB7O,KAAK,GAAlD,SAA0DuO,MAC/D,8BAAK,wBAAQvL,UAAU,MAAMkL,YAAa,EAAKY,wBAAwB9O,KAAK,GAAvE,2BAwCqB+O,GAAkB,WAG5C,sBAAK/L,UAAW,UAAiC,IAAxBzC,KAAKvB,MAAMI,WAAmB,QAAQ,QAA/D,UACI,sBAAK4D,UAAU,kBAAmBiK,MAAO,CAACQ,QAA4B,IAApBlN,KAAKvB,MAAME,OAAW,OAAO,QAA/E,UACE,sBAAK8D,UAAU,eAAesJ,QAAS/L,KAAKmN,cAAc1N,KAAKO,MAAO,cAAY,IAAlF,UAAsF,qBAAK8M,IAAK2B,IAAUzB,IAAI,KAAI,iDAClH,wBAAO0B,IAAI,cAAcjM,UAAU,eAAnC,UAAkD,qBAAKqK,IAAK6B,IAAU3B,IAAI,KAAI,0DAAkC,uBAAO4B,GAAG,cAAc9L,KAAK,cAAcuL,SAAUrO,KAAK6O,WAAWpP,KAAKO,MAAOe,KAAK,OAAO2L,MAAO,CAACQ,QAAQ,gBAE/N,qBAAKzK,UAAU,kBAAmBiK,MAAO,CAACQ,QAA4B,IAApBlN,KAAKvB,MAAME,OAAW,OAAO,QAA/E,SACE,uBAAM8D,UAAU,cAAc8B,SAAUvE,KAAK8O,cAAcrP,KAAKO,MAAhE,UAAwE,8DAAwC,uBAAOe,KAAK,OAAO+B,KAAK,aAAa,uBAAO/B,KAAK,SAASR,MAAM,gBAElL,sBAAKkC,UAAU,kBAAkBiK,MAAO,CAACQ,QAA4B,IAApBlN,KAAKvB,MAAME,OAAW,OAAO,QAA9E,UACE,sBAAK8D,UAAU,YAAf,mBAAkCzC,KAAKvB,MAAMmC,SAAWZ,KAAKvB,MAAM2F,QAAW,eAAepE,KAAKvB,MAAM2F,QAA7B,MAC3E,sBAAK3B,UAAU,oBAAoBiK,MAAO,CAAC1N,SAASgB,KAAKvB,MAAMO,UAA/D,UAEA,qBAAKyD,UAAU,iCAAf,SAnZD,OAoZG,qBAAKA,UAAU,+BAAf,SAAgDiJ,UAGpD,sBAAKjJ,UAAU,kBAAkBiK,MAAO,CAACQ,QAA4B,IAApBlN,KAAKvB,MAAME,OAAW,OAAO,QAA9E,UACE,sBAAK8D,UAAU,YAAf,mBAAkCzC,KAAKvB,MAAMmC,SAAWZ,KAAKvB,MAAM2F,QAAW,eAAepE,KAAKvB,MAAM2F,QAA7B,MAC3E,sBAAK3B,UAAU,oBAAoBiK,MAAO,CAAC1N,SAASgB,KAAKvB,MAAMO,UAA/D,UAEA,qBAAKyD,UAAU,iCAAf,SA3ZD,OA4ZG,qBAAKA,UAAU,+BAAf,SAAgDiJ,UAGpD,sBAAKjJ,UAAU,kBAAkBiK,MAAO,CAACQ,QAAQlN,KAAKvB,MAAME,QAAQ,EAAE,OAAO,QAA7E,UACE,sBAAK8D,UAAU,YAAf,mBAAkCzC,KAAKvB,MAAMmC,SAAWZ,KAAKvB,MAAM2F,QAAW,eAAepE,KAAKvB,MAAM2F,QAA7B,MAC3E,sBAAK3B,UAAU,oBAAoBiK,MAAO,CAAC1N,SAASgB,KAAKvB,MAAMO,UAA/D,UACE,qBAAKyD,UAAU,iCAAf,SAlaH,OAmaG,qBAAKA,UAAU,+BAAf,SAAgDiJ,gBAM1D,sBAAKjJ,UAAU,SAAf,UACE,gDACA,4DACA,+CACA,8CAEF,qBAAKA,UAAU,SAASiK,MAAO,CAACQ,SAA+B,IAAtBlN,KAAKvB,MAAMQ,SAAgB,OAAO,QAA3E,SACE,sBAAKwD,UAAU,YAAf,UACE,qBAAKA,UAAU,QAAQsJ,QAAS/L,KAAKf,SAASQ,KAAKO,MAAnD,eACA,kDACA,+BAAM,uBAAOe,KAAK,SAAUR,MAAOP,KAAKvB,MAAMO,SAAUqP,SAAUrO,KAAK+O,eAAetP,KAAKO,eAnH3F,EAAKvB,MAAMU,MAGR,qBAAKsD,UAAU,gBAAgBiK,MAAO,CAACQ,QAAQ,EAAKzO,MAAMU,MAAMC,KAAK,OAAO,QAA5E,SACN,sBAAKqD,UAAU,QAAf,UAAwB,EAAKhE,MAAMU,MAAMiC,SAAS,KAAK,qBAAKqB,UAAU,cAAcsJ,QAAS,EAAKiD,WAAWvP,KAAK,GAA3D,eACxD,qBAAKgD,UAAU,UAAf,SAA0B,EAAKhE,MAAMU,MAAME,UAC1C,EAAKZ,MAAMU,MAAMG,MAAM,qBAAKmD,UAAU,QAAQqK,IAAK,EAAKrO,MAAMU,MAAMG,QAAU,QALtE,Y,GAzoCkB2P,IAAMC,a,yDCfxB,0lN,6BCAA,k5D,6BCAA,szC,6BCAA,05D,6BCAA,s3E,6BCAA,0yH,6BCAA,s1E,6BCAA,k6D,6BCAA,8Y,+BCAf,sDAKAC,IAASC,OACP,+BACE,cAAC,IAAD,MAEFjJ,SAASkJ,eAAe,U","file":"static/js/main.d723f0fa.chunk.js","sourcesContent":["export default \"\"","import React, { Fragment } from 'react';\nimport './App.css';\nimport logo from './assets/logo.png';\nimport sidebar1 from './assets/sidebar1.png';\nimport sidebar2 from './assets/sidebar2.png';\nimport sidebar3 from './assets/sidebar3.png';\nimport sidebar4 from './assets/sidebar4.png';\nimport documentIcon from './assets/document-icon.png';\nimport landing1 from './assets/landing1.png'; \nimport landing2 from './assets/landing2.png';\nimport hamburger from './assets/hamburger.png';\nimport loading from './assets/loading.png';\nimport { saveAs } from 'file-saver';\n\nconst urlBase = 'http://142.93.118.6'; // 'http://localhost:8080';\nexport default class App extends React.Component {\n constructor(props) {\n super(props);\n this.state = {\n // Informational & API related\n menu:null,\n screen:0,\n hamburger:false,\n themeColor:false,\n highlights:[],\n currentHighlight: null,\n fontSize:23,\n fontMenu:false,\n geneInfo:null,\n popup:{\n show:false,\n message:null,\n image:null\n },\n currentPam:null,\n }\n // API\n this.changeMenus = this.changeMenus.bind(this);\n this.highlight = this.highlight.bind(this);\n this.saveCurrentHighlight = this.saveCurrentHighlight.bind(this);\n }\n\n // UI\n changeMenus(e) {\n let menu = parseInt(e.target.dataset.menu); \n //console.log(menu);\n if(menu===this.state.menu){\n menu = null;\n }\n this.setState({menu:menu},()=>{\n //console.log(this.state);\n });\n }\n changeScreens(e) {\n let screen = e.target.dataset.screen; \n console.log(screen);\n let menu = null;\n if(screen==1){\n menu=1;\n }\n this.setState({screen:parseInt(screen),hamburger:false,menu:menu},()=>{\n console.log(this.state);\n if(screen==3){\n this.setState({mutatePam:true});\n }\n });\n }\n openMenu(e) {\n let screen = e.target.dataset.screen; \n //console.log(screen);\n this.setState({hamburger:!this.state.hamburger});\n }\n changeThemeColor(e) {\n this.setState({themeColor:!this.state.themeColor});\n }\n closeAllMenus(e) {\n //this.setState({menu:null,hamburger:false});\n }\n closePopup(e) {\n this.setState({popup:{show:false}});\n }\n highlight(e,data){\n /*let highlight = parseInt(e.target.dataset.value);\n console.log(highlight);*/\n /*this.setState({highlight:highlight},()=>{\n //console.log(this.state);\n });*/\n }\n fontMenu(e) {\n this.setState({fontMenu:!this.state.fontMenu});\n }\n changeFontSize(e){\n let size = parseInt(e.target.value);\n this.setState({fontSize:size},()=>{\n //console.log(this.state);\n });\n }\n saveDesign() {\n const design = JSON.stringify(this.state);\n var filename = this.state.geneName+\".txt\";\n var blob = new Blob([design], {\n type: \"text/plain;charset=utf-8\"\n });\n saveAs(blob, filename);\n this.setState({hamburger:false});\n }\n openDesign(e) {\n const reader = new FileReader();\n this.setState({popup:{\n show:true,\n message:Uploading File
,\n image:loading,\n stayOpen:true,\n }},()=>{\n reader.onloadend = (res) => {\n let newState = JSON.parse(res.target.result);\n newState['popup'] = null;\n newState['hamburger'] = false;\n this.setState(newState,()=>{\n console.log(this.state);\n });\n };\n if(e.target.value.length) {\n reader.readAsText(e.target.files[0]);\n }\n });\n\n }\n viewFinishedDesign(){\n let targetKeys = Object.keys(this.state.targets[0]);\n let targetHTML = targetKeys.map((prop)=>{\n\n return {prop}: {this.state.targets[0][prop]}
;\n });\n let primerKeys = Object.keys(this.state.primers);\n //console.log('primer keys',primerKeys);\n let primerHTML = primerKeys.map((key)=>{\n let primerOptions = this.state.primers[key];\n //console.log('this primer',primerOptions);\n if(this.state.selectedArms&&this.state.selectedArms[key]){\n let primerSingle = this.state.selectedArms[key];\n return {key}
\n
\n
{primerSingle[7]}
\n
\n
\n
Any (Self Complementarity): {primerSingle[5]}
\n
3' (Self Complementarity): {primerSingle[6]}
\n
;\n } else {\n return {key}
{primerOptions.map((primerSingle)=>{\n return
\n
{primerSingle[7]}
\n
\n
\n
Any (Self Complementarity): {primerSingle[5]}
\n
3' (Self Complementarity): {primerSingle[6]}
\n
})}
;\n }\n });\n let message = \n
Design Info
\n
Target Info
{targetHTML}\n
Homology Info
\n {primerHTML}\n \n
\n
Oligo Info
\n
Sense: {this.state.oligos.sense}
\n
Antisense: {this.state.oligos.antisense}
\n
\n
;\n this.setState({popup:{\n show:true,\n message:message,\n image:null,\n stayOpen:false,\n }});\n }\n saveCurrentHighlight(color=null,name=null){\n let highlight = JSON.parse(JSON.stringify(this.state.currentHighlight));\n //console.log('highlight',highlight);\n if(color){\n highlight.color = color;\n }\n let highlights = this.state.highlights;\n \n if(name){\n highlights[name] = highlight;\n } else {\n highlights[highlight.name] = highlight;\n }\n //console.log(highlights);\n if(highlight.name=='targetSearch'){\n //console.log('search for targets');\n this.searchForTargets();\n } else {\n\n this.setState({highlights:highlights},()=>{\n console.log(this.state);\n \n });\n }\n }\n changeCurrentHighlight(i){\n let currentHighlight = this.state.currentHighlight;\n currentHighlight.location = i;\n this.setState({currentHighlight:currentHighlight});\n }\n stringLocation(string=null,type){\n if(!type){\n return this.state.sequence.indexOf(string);\n }\n let location = this.state.sequence.indexOf(string);\n console.log('location',location);\n let length = string.length;\n \n if(location==-1){\n \n let revString = this.revComp(string);\n console.log('rev',revString);\n location = this.state.sequence.indexOf(revString); \n //location = location+(length/2)-4;\n } else {\n // location = location+(length/2)-1;\n }\n return location;\n }\n highlightString(string,color=null,type=null){\n console.log('string: ',string,' color: ',color);\n //console.log(this.state.sequence);\n let location = this.stringLocation(string,type);\n console.log(location);\n if(location==-1){\n location = this.stringLocation(this.revComp(string),type);\n }\n if(location==-1){\n location = 0;\n }\n let length = string.length;\n if(!color){\n color = 'rgba(252, 210, 126, 0.3)';\n }\n //console.log('mousenter');\n //console.log(location,length,color);\n this.setState({currentHighlight:{\n location:location,\n length:length,\n color:color,\n name:!type?'cutsite':type\n }\n });\n }\n clearHighlight(){\n //console.log('mouseleave');\n //this.setState({currentHighlight:null});\n }\n\n revComp(dna) {\n let revComp = [];\n for(let i=0;iSearching For Gene,\n image:loading,\n stayOpen:true,\n }}, ()=>{\n fetch(url).then((res) =>{return res.json()}).then((geneInfo)=>{\n console.log('response',geneInfo);\n let currentState = this.state;\n if(geneInfo.isoForm==null){\n currentState.popup = {\n show:false,\n };\n currentState.isoForm = null;\n } else {\n\n let isoForms = JSON.parse(geneInfo.isoForms);\n //console.log('isoforms');\n let options = Choose Your IsoForm
;\n //console.log('options made');\n currentState.popup = {\n show:true,\n message:options,\n image:null\n };\n currentState.isoForm = geneInfo.isoForm;\n }\n currentState.geneName = geneInfo.name;\n currentState.screen = 2;\n currentState.sequence = geneInfo.sequence;\n currentState.isoFormSequence = geneInfo.isoFormSequence;\n \n\n this.setState(currentState,()=>{\n this.makeIsoFormHighlights();\n });\n });\n });\n }\n makeIsoFormHighlights(){\n let startSequence = this.state.isoFormSequence.substr(0,9);\n let stopSequence = this.state.isoFormSequence.substr(this.state.isoFormSequence.length-10,this.state.isoFormSequence.length);\n let startIndex = this.state.sequence.indexOf(startSequence);\n let stopIndex = this.state.sequence.indexOf(stopSequence)+7;\n //console.log(startIndex,startSequence);\n //console.log(stopIndex,stopSequence);\n let highlights = {\n start:{\n location:startIndex,\n length:3,\n color:'#93E593',\n },\n stop:{\n location:stopIndex,\n length:3,\n color:'#FF668E',\n }\n };\n let popupForm = Choose Your Tag
;\n this.setState({\n screen:2,\n popup:{\n show:false,\n },\n highlights:highlights,\n popup:{\n show:true,\n message:popupForm,\n image:null,\n stayOpen:true,\n }\n });\n }\n pickIsoForm(e){\n e.preventDefault();\n //console.log(e.target.isoform.value);\n let isoForm = e.target.isoform.value;\n //console.log(isoForm,this.state.isoForm);\n //console.log(this.state.isoFormSequence);\n if(isoForm==this.state.isoForm){\n //console.log('same isoForm');\n this.makeIsoFormHighlights();\n } else {\n let url = urlBase+'/api/?type=isoform&isoform='+isoForm;\n fetch(url).then((res) =>{return res.json()}).then((geneInfo)=>{\n //console.log('response',geneInfo);\n let currentState = this.state;\n currentState.isoForm = geneInfo.isoForm;\n currentState.isoFormSequence = geneInfo.isoFormSequence;\n\n \n let startSequence = this.state.isoFormSequence.substr(0,9);\n let stopSequence = this.state.isoFormSequence.substr(this.state.isoFormSequence.length-10,this.state.isoFormSequence.length);\n let startIndex = this.state.sequence.indexOf(startSequence);\n let stopIndex = this.state.sequence.indexOf(stopSequence)+7;\n //console.log(startIndex,startSequence);\n //console.log(stopIndex,stopSequence);\n let highlights = {\n start:{\n location:startIndex,\n length:3,\n color:'#93E593',\n },\n stop:{\n location:stopIndex,\n length:3,\n color:'#FF668E',\n }\n }\n currentState.highlights = highlights;\n let popupForm = Choose Your Tag
;\n \n currentState.popup = {\n show:true,\n message:popupForm,\n image:null,\n stayOpen:true,\n };\n /*currentState.currentHighlight = {\n location:null,\n length:100,\n color:'#FCD27E',\n name:'targetSearch'\n }*/\n //console.log(currentState);\n this.setState(currentState,function(){\n //console.log(this.state);\n });\n });\n }\n }\n pickCutSite(target){\n this.saveCurrentHighlight('rgba(252, 210, 126, 0.3)');\n this.setState({\n targets:[target],\n menu:3,\n screen:3,\n mutatePam:true,\n });\n }\n chooseTerminal(e){\n e.preventDefault();\n //console.log(e.target.tag.value);\n let i;\n let terminal = e.target.tag.value;\n if(terminal=='n'){\n i = this.state.highlights.start.location;\n } else if(terminal=='c'){\n i = this.state.highlights.stop.location;\n }\n //console.log('start',i-26,i+26);\n let targetGenes = this.state.sequence.substring(i-50,i+50); \n //console.log(targetGenes);\n let url = urlBase+'/api/?type=targetSearch&targetArea='+targetGenes;\n //console.log(url);\n this.setState({popup:{\n show:true,\n message:Finding Potential Targets.
This may take some time.
,\n image:loading,\n stayOpen:true,\n },\n terminal:terminal\n },function(){\n fetch(url).then((res) =>{return res.json()}).then((response)=>{\n //console.log(response);\n let efficiencyString = response.results.map((target)=>{\n return target.distal+target.proximal;\n });\n //console.log(encodeURIComponent(efficiencyString.join(',')));\n this.setState({popup:{\n show:true,\n message:Checking Target Efficiency
,\n image:loading,\n stayOpen:true,\n },\n targets:response.results\n },function(){\n let url = urlBase+'/api/?type=targetEfficiency&targets='+encodeURIComponent(efficiencyString.join('\\n'));\n fetch(url).then((res)=>{return res.json()}).then((response)=>{\n //console.log(response);\n let targets = [];\n for(let i=0;iFinding Potential Targets,\n image:loading,\n stayOpen:true,\n }\n },function(){\n fetch(url).then((res) =>{return res.json()}).then((response)=>{\n //console.log(response);\n let efficiencyString = response.results.map((target)=>{\n return target.distal+target.proximal;\n });\n //console.log(encodeURIComponent(efficiencyString.join(',')));\n this.setState({popup:{\n show:true,\n message:Checking Target Efficiency
,\n image:loading,\n stayOpen:true,\n },\n targets:response.results\n },function(){\n let url = urlBase+'/api/?type=targetEfficiency&targets='+encodeURIComponent(efficiencyString.join('\\n'));\n fetch(url).then((res)=>{return res.json()}).then((response)=>{\n //console.log(response);\n //console.log('got response');\n let targets = [];\n for(let i=0;iChecking Target Efficiency,\n image:loading,\n stayOpen:true,\n },\n targets:targets\n },function(){\n //console.log('added score');\n //console.log(this.state);\n });\n });\n });\n });\n });\n \n }\n getPrimers() {\n\n const targetSearch = this.state.terminal=='n'?this.state.highlights.start.location:this.state.highlights.stop.location;\n console.log('target search area',targetSearch);\n const primerSections = {\n \"5' Homology\":this.state.sequence.slice(targetSearch-1200, targetSearch-1000),\n \"5' Sequence\":this.state.sequence.slice(targetSearch-600, targetSearch-400),\n \"3' Sequence\":this.state.sequence.slice(targetSearch+400, targetSearch+600),\n \"3' Homology\":this.state.sequence.slice(targetSearch+1000, targetSearch+1200) \n }\n let primerSectionsString = Buffer.from(JSON.stringify(primerSections)).toString('base64');\n this.setState({\n popup:{\n show:true,\n message:Retreiving Homology Arm Primers
,\n image:loading,\n stayOpen:true,\n },\n },()=>{\n console.log(urlBase+'/api/?type=primers&primerSections='+primerSectionsString);\n fetch(urlBase+'/api/?type=primers&primerSections='+primerSectionsString).then(res =>{return res.json();}).then((res)=>{\n console.log(res);\n this.setState({primers:res,menu:4,popup:{\n show:false,\n message:Retreiving Homology Arm Primers
,\n image:loading,\n stayOpen:true,\n },\n },()=>{\n console.log(this.state);\n });\n })\n });\n }\n mutatePam(e){\n e.preventDefault();\n let newPam = e.target.elements.newPam.value;\n //console.log(newPam);\n this.setState({currentPam:newPam,menu:4,screen:4,mutatePam:false},()=>{\n console.log('mutated pam');\n console.log(this.state);\n if(!this.state.primers||!this.state.primers.length==0){\n this.getPrimers();\n }\n });\n }\n selectHomologyArm(selection,arm){\n let currentArms = JSON.parse(JSON.stringify(!this.state.selectedArms?{}:this.state.selectedArms));\n currentArms[arm] = selection;\n this.saveCurrentHighlight('rgba(86, 64, 155,0.3)',arm);\n this.setState({selectedArms:currentArms},()=>{\n //console.log(this.state);\n this.setState({currentHighlight:null},()=>{\n let totalSelected = Object.keys(this.state.selectedArms);\n if(totalSelected.length&&totalSelected.length==4){\n // GET OLIGO INFO\n console.log('searching');\n console.log(urlBase+'/api/?type=oligos&target='+this.state.targets[0].distal+this.state.targets[0].proximal+this.state.targets[0].pam);\n this.setState({\n popup:{\n show:true,\n message:Retreiving Oligo Information
,\n image:loading,\n stayOpen:true,\n },\n },()=>{\n fetch(urlBase+'/api/?type=oligos&target='+this.state.targets[0].distal+this.state.targets[0].proximal+this.state.targets[0].pam).then(res =>{return res.json();}).then((res)=>{\n console.log(res);\n if(!res.sense){\n this.setState({\n menu:5,\n popup: {\n show:false,\n }\n });\n }\n this.setState({\n menu:5,\n oligos:res,\n popup: {\n show:false,\n }\n });\n });\n });\n }\n });\n });\n }\n\n // UTILITIES\n\n downloadApeFile() {\n fetch(window.location.origin+'/fly_templates/empty_ape.txt').then((res)=>{return res.text();}).then((res)=>{\n const data = res;\n fetch(window.location.origin+'/fly_templates/feature.txt').then((res)=>{return res.text()}).then((res2)=>{\n const feature = res2;\n const newFeature = (loc, name, color) => {\n return feature\n .split('*featureLoc*').join(loc)\n .split('*featureName*').join(name)\n .split('*featureColor*').join(color);\n };\n let gene = this.state.sequence;\n const target = this.state.targets[0].distal.toString()+this.state.targets[0].proximal.toString();\n const targetMatch = gene.toLowerCase().match(target.toLowerCase());\n const revTargetMatch = gene.toLowerCase().match(this.revComp(target.toLowerCase()));\n let targetI;\n if (targetMatch) {\n targetI = targetMatch.index+1;\n } else if (revTargetMatch) {\n targetI = revTargetMatch.index;\n }\n const pamStart = revTargetMatch?targetI-2:targetI+20;\n const start = 1+parseInt(this.state.highlights.start.location);\n const stop = 1+parseInt(this.state.highlights.stop.location); \n gene = !this.state.currentPam?gene:gene.substr(0,pamStart-1)+this.state.currentPam+gene.substr(pamStart+2,gene.length);\n const featureArr = [\n newFeature(start+'..'+(start+2),'Start Codon','#df2935'),\n newFeature(stop+'..'+(stop+2),'Stop Codon','#df2935'),\n newFeature((parseInt(1+this.state.highlights['hom5']['location']))+'..'+(parseInt(1+this.state.highlights['hom5']['location'])+this.state.highlights['hom5']['length']),\"5' Homology Arm Primer\",'#fdca40'),\n newFeature((parseInt(1+this.state.highlights['hom3']['location']))+'..'+(parseInt(1+this.state.highlights['hom3']['location'])+this.state.highlights['hom3']['length']),\"3' Homology Arm Primer\",'#fdca40'),\n newFeature((parseInt(1+this.state.highlights['seq5']['location']))+'..'+(parseInt(1+this.state.highlights['seq5']['location'])+this.state.highlights['seq5']['length']),\"5' Sequence Primer\",'#fdca40'),\n newFeature((parseInt(1+this.state.highlights['seq3']['location']))+'..'+(parseInt(1+this.state.highlights['seq3']['location'])+this.state.highlights['seq3']['length']),\"3' Sequence Primer\",'#fdca40'),\n newFeature(targetI+'..'+(parseInt(targetI)+20),\"Target\",'#136F5E'),\n newFeature(pamStart+'..'+(parseInt(pamStart)+2),\"Pam\",'#42ED5E'),\n ];\n const makeGeneArr = () => {\n\n let geneArr = [];\n const spaces = (str) => {\n let spaceArr = [];\n for(let i=0;i<9-str.length;i++){\n spaceArr.push('');\n }\n return spaceArr;\n }\n for(let i=0;igene.length){\n geneArr.push(gene.slice(i,gene.length));\n } else {\n geneArr.push(gene.slice(i,i+10));\n }\n geneArr.push('');\n i=i+10;\n }\n return geneArr.join(' ');\n }\n const months = [\"JAN\",\"FEB\",\"MAR\",\"APR\",\"MAY\",\"JUN\",\"JUL\",\"AUG\",\"SEP\",\"OCT\",\"NOV\",\"DEC\"]\n const date = new Date();\n const day = date.getDate();\n const month = months[date.getMonth()];\n const year = date.getFullYear();\n const newData = data\n .split('*FEATURES*').join(featureArr.join(''))\n .split('*name*').join(this.state.geneName)\n .split('*length*').join(this.state.sequence.length)\n .split('*date*').join(day+'-'+month+'-'+year)\n .split('*GENE*').join(makeGeneArr())\n ;\n const design = newData;\n var filename = this.state.geneName+\".ape\";\n var blob = new Blob([design], {\n type: \"text/plain;charset=utf-8\"\n });\n saveAs(blob, filename); \n });\n });\n }\n changePlasmidTemplate(e){\n let template = e.target.value;\n\n this.setState({plasmidTemplate:template},()=>{\n console.log(this.state.plasmidTemplate);\n });\n }\n downloadPlasmidTemplate(e){\n e.preventDefault();\n if(!this.state.plasmidTemplate){return false;}\n \n const url = (window.location.origin+'/plasmid_folder/')+(this.state.plasmidTemplate.split(' ').join('%20'))+'.txt';\n console.log(url);\n fetch(url).then((res)=>{return res.text()}).then((data)=>{\n const preArm1 = data.split('**arm_1_start**')[0];\n let searchSequence = this.state.targets[0].distal+this.state.targets[0].proximal+this.state.targets[0].pam;\n const targetSearch = this.state.sequence.search(this.state.targets[0].strand==='-'?this.revComp(searchSequence):searchSequence);\n let arm1 = this.state.sequence.slice(targetSearch-1000, targetSearch);\n const postArm1 = data.split('**arm_1_end**')[1].split('**arm_2_start**')[0];\n let arm2 = this.state.sequence.slice(targetSearch, targetSearch+1000);\n const postArm2 = data.split('**arm_2_end**')[1];\n if(this.state.mutatedPam) {\n const strand = this.state.potentialTargets[0].strand;\n const target = strand==='-'?this.revComp(this.state.target):this.state.target;\n let arms = arm1+arm2;\n const targetI = arms.toLowerCase().match(target.toLowerCase());\n if(strand==='-'){\n arms = arms.substr(0,targetI.index)+this.state.currentPam+arms.substr(targetI.index+3,arms.length);\n } else {\n arms = arms.substr(0,targetI.index+target.length-3)+this.state.currentPam+arms.substr(targetI.index+target.length,arms.length);\n }\n arm1 = arms.slice(0,Math.floor(arms.length/2)+1);\n arm2 = arms.slice(Math.floor(arms.length/2),arms.length);\n }\n let replaceArm1 = data.split('**arm_1_start**')[1].split('**arm_1_end**')[0].split('');\n let arm1I = 0;\n let replaceArm2 = data.split('**arm_2_start**')[1].split('**arm_2_end**')[0].split('');\n let arm2I = 0;\n\n\n for(let y=0;y{return res.text()}).then((data)=>{\n let preSplit = data.split('**injection_start**')[0];\n let postSplit = data.split('**injection_end**')[1];\n let sense = this.state.oligos.sense.substring(0,7)+' '+this.state.oligos.sense.substring(7,17)+' '+this.state.oligos.sense.substring(17);\n const design = preSplit+sense+postSplit;\n var filename = \"pu6-guidernavector.ape\";\n \n var blob = new Blob([design], {\n type: \"text/plain;charset=utf-8\"\n });\n saveAs(blob, filename); \n });\n return;\n }\n componentDidUpdate(){\n let options = {\n root: document.querySelector('.screen-4'),\n rootMargin: '0px',\n threshold: 0\n }\n const highlightObserver = (entries)=>{\n entries.forEach(entry => {\n if (entry.isIntersecting) {\n let elem = entry.target;\n \n if (entry.intersectionRatio >= 0.75) {\n // console.log('intersecting');\n } else {\n // console.log('not intersecting');\n }\n\n }\n });\n }\n let observer = new IntersectionObserver(highlightObserver, options);\n let currentHighlightEl = document.querySelector('.main-highlight');\n if(currentHighlightEl){\n observer.observe(currentHighlightEl);\n }\n // console.log(currentHighlightEl);\n\n }\n render() {\n //console.log('render')\n const makeHighlights = () => {\n return null;\n if(!this.state.highlights){\n return null;\n }\n /*for (const highlight of this.state.highlights) {\n let geneInfoHighlights = !this.state.sequence?null:this.state.sequence.split('').map((letter,i)=>{\n return i+((highlight.highlightLength-1)/2)?' ':'highlight ')+' single-letter '} data-value={i} onMouseEnter={this.highlight.bind(this)}>{letter}
;\n });\n }*/\n let allHighlights = [];\n let currentHighlight = !this.state.sequence?null:this.state.sequence.split('').map((letter,i)=>{\n if(!this.state.currentHighlight){\n return null;\n }\n let style = {background:'rgba(255,255,255,0)'};\n let classes = '';\n if(i>=(this.state.currentHighlight.location-((this.state.currentHighlight.length-1)/2))&&i<=(this.state.currentHighlight.location+((this.state.currentHighlight.length-1)/2))){\n style = {background:this.state.currentHighlight.color,zIndex:999};\n classes = 'main-highlight';\n }\n return {letter}
;\n });\n let highlightKeys = Object.keys(this.state.highlights);\n for(let i=0;i{\n this.state.sequence.split('').map((letter,i)=>{\n let style = {background:'rgba(255,255,255,0)'};\n let className = null;\n if(i>=(highlight.location-((highlight.length-1)/2))&&i<=(highlight.location+((highlight.length-1)/2))){\n style = {background:highlight.color};\n \n }\n if(i==highlight.location){\n className = highlightKeys[i];\n }\n return {letter}
;\n })\n });\n }\n allHighlights.push({currentHighlight}
);\n return allHighlights;\n }\n const highlightKeys = !this.state.highlights?null:Object.keys(this.state.highlights);\n //console.log(!this.state.currentHighlight?null:this.state.currentHighlight);\n const currentHighlight = !this.state.currentHighlight?null:this.state.currentHighlight;\n const currentHighlightLocation = !currentHighlight?null:currentHighlight.location;\n const geneInfoPrep = !this.state.sequence?null:this.state.sequence.split('').map((letter,i)=>{\n let highlightClasses = [];\n if(currentHighlight&&i>=currentHighlightLocation&&i0){\n for(let y=0;y=start&&i{letter};\n });\n const targetList = !this.state.targets?null:this.state.targets.map((target)=>{\n return \n
{target.distal+target.proximal+target.pam}
\n
Efficiency: {!target.score?'-':target.score}
\n
Strand: {target.strand}
\n
Off Targets: {target.offtarget}
\n
;\n });\n const pamBoxReadingFrames = () => {\n if(!this.state.highlights.cutsite){\n return;\n }\n let start = parseInt(JSON.parse(JSON.stringify(this.state.highlights.start.location)));\n let cutsite = parseInt(this.state.highlights.cutsite.location);\n let string = [];\n let frameI = Math.abs((cutsite - start) % 3)+1;\n let distal = this.state.targets[0].distal.split('');\n let proximal = this.state.targets[0].proximal.split('');\n let pam = this.state.targets[0].pam.split('');\n //console.log(cutsite,' ',start,Math.abs(cutsite - start)%3,((cutsite - start) % 3),frameI);\n for(let i=0;i{distal[i]}{frameI});\n start = start+1;\n frameI = Math.abs((cutsite - start) % 3)+1;\n //console.log(cutsite,' ',start,Math.abs(cutsite - start)%3,((cutsite - start) % 3),frameI);\n }\n for(let i=0;i{proximal[i]}{frameI});\n start = start+1;\n frameI = Math.abs((cutsite - start) % 3)+1;\n //console.log(cutsite,' ',start,Math.abs(cutsite - start)%3,((cutsite - start) % 3),frameI);\n }\n string.push({' '}
);\n for(let i=0;i{pam[i]}{frameI});\n start = start+1;\n frameI = Math.abs((cutsite - start) % 3)+1;\n //console.log(cutsite,' ',start,Math.abs(cutsite - start)%3,((cutsite - start) % 3),frameI);\n }\n //let string = !this.state.targets?null:this.state.targets[0].distal+this.state.targets[0].proximal+' '+(!this.state.targets?null:this.state.targets[0].pam);\n return {string}
;\n }\n const pamBox = \n
Amino Acid Chart
\n
Target: {pamBoxReadingFrames()}
\n
\n
2nd Letter
\n
\n
1st
Letter
\n
\n
3rd
Letter
\n
\n
;\n const HomologyList = () => {\n if(!this.state.primers){\n return;\n }\n let primerKeys = Object.keys(this.state.primers);\n //console.log('primer keys',primerKeys);\n let primerHTML = primerKeys.map((key)=>{\n let primerOptions = this.state.primers[key];\n //console.log('this primer',primerOptions);\n if(this.state.selectedArms&&this.state.selectedArms[key]){\n let primerSingle = this.state.selectedArms[key];\n return {key}
\n
\n
{primerSingle[7]}
\n
\n
\n
Any (Self Complementarity):
{primerSingle[5]}
\n
3' (Self Complementarity):
{primerSingle[6]}
\n
;\n } else {\n return {key}
{primerOptions.map((primerSingle)=>{\n return
\n
{primerSingle[7]}
\n
\n
\n
Any (Self Complementarity):
{primerSingle[5]}
\n
3' (Self Complementarity):
{primerSingle[6]}
\n
})}
;\n }\n });\n return {primerHTML}
;\n }\n const popup = () => {\n if(!this.state.popup){\n return null;\n }\n return \n
{this.state.popup.stayOpen?null:
X
}\n
{this.state.popup.message}
\n {this.state.popup.image?
:''}
\n
\n } \n const downloadOptions = () => {\n const plasmidOptions = [\"N terminal SSPB and mCherry tag\",\"N terminal EGFP and SSPB tag with Extended Linker\",\"C terminal mCherry and SSPB tag\",\"C terminal EGFP and SSPB tag with Extended Linker\",\"C terminal EGFP and SSPB tag\",\"C terminal mDendra2 and SSPB tag\",\"C terminal mScarlett and SSPB tag\",\"N terminal EGFP and SSPB tag\",\"N terminal mDendra2 and SSPB tag\",\"N terminal mScarlett and SSPB tag\"];\n let htmlOptions = [];\n for(let i=-1;iChoose A Template)\n } else {\n htmlOptions.push()\n }\n }\n \n return \n
\n
Ape File
\n
\n
Guide Rna Vector
\n
\n
Plasmid Template
\n
\n
\n
;\n }\n return (\n \n
\n \n \n
\n
New/Upload Project
\n
Save Project
\n
Switch to {(this.state.themeColor===false?'Dark':'Light')} Theme
\n
\n
\n
\n \n
\n
\n
\n
\n
1?'':'none'}} onClick={this.changeMenus.bind(this)} data-menu=\"2\" alt=\"sidebar2\">
\n
\n {!targetList?null:
{targetList}
}\n
\n
\n
2?'':'none'}} onClick={this.changeMenus.bind(this)} data-menu=\"3\" alt=\"sidebar3\">
\n
\n {this.state.screen<3?null:
{pamBox}
}\n
\n
\n
3?'':'none'}} onClick={this.changeMenus.bind(this)} data-menu=\"4\" alt=\"sidebar4\">
\n
\n
{HomologyList()}
\n
\n
\n
3?'':'none'}} onClick={this.changeMenus.bind(this)} data-menu=\"5\" alt=\"sidebar5\">
\n
\n {this.state.menu==5?downloadOptions():null}\n
\n
\n
\n
\n
New Project
\n
\n
\n
\n \n
\n
\n
Gene: {this.state.geneName}{!this.state.isoForm?'':' - Isoform: '+this.state.isoForm}
\n
\n \n
{makeHighlights()}
\n
{geneInfoPrep}
\n
\n
\n
\n
Gene: {this.state.geneName}{!this.state.isoForm?'':' - Isoform: '+this.state.isoForm}
\n
\n \n
{makeHighlights()}
\n
{geneInfoPrep}
\n
\n
\n
=4?'flex':'none',}}>\n
Gene: {this.state.geneName}{!this.state.isoForm?'':' - Isoform: '+this.state.isoForm}
\n
\n
{makeHighlights()}
\n
{geneInfoPrep}
\n
\n
\n
\n \n
\n
\n
Cabernard Lab
\n
Sound Development Company
\n
GPL3 License
\n
API Docs
\n
\n
\n
\n
X
\n
Change Font Size
\n
\n
\n
\n {popup()}\n
\n\n )\n }\n}\n","export default \"\"","export default \"\"","export default \"\"","export default \"\"","export default \"\"","export default \"\"","export default \"\"","export default \"\"","export default \"\"","import React from 'react';\nimport ReactDOM from 'react-dom';\nimport './index.css';\nimport App from './App';\n\nReactDOM.render(\n \n \n ,\n document.getElementById('root')\n);\n"],"sourceRoot":""}
\ No newline at end of file