'.replace(/ID/g,f._id+"_localReader")),
f._localReader=a.$(f,"localReader"));a.$appEvent(f,"localReader_loadfile","click");a.$appEvent(f,"localReader_loadfile","click",function(){var d=a.$(f,"localReader_files")[0].files[0],c=new FileReader;c.onloadend=function(c){c.target.readyState==FileReader.DONE&&(a.$css(a.$(f,"localReader"),{display:"none"}),b.setData(d.name,a._toBytes(c.target.result)))};c.readAsArrayBuffer(d)});a.$appEvent(f,"localReader_cancel","click");a.$appEvent(f,"localReader_cancel","click",function(){a.$css(a.$(f,"localReader"),
{display:"none"});b.setData(null,"#CANCELED#")});a.$css(a.$(f,"localReader"),{display:"block"})};a._toBytes=function(b){b=new Uint8Array(b);for(var a=Clazz.newByteArray(b.length,0),d=b.length;0<=--d;)a[d]=b[d];return a};a._doAjax=function(b,f,d){b=b.toString();if(null!=d)return a._saveFile(b,d);f&&(b+="?POST?"+f);f=a._getFileData(b);return a._processData(f,a._isBinaryUrl(b))};a._saveFile=function(b,f){var d=a._serverUrl;if(a._localFileSaveFunction&&a._localFileSaveFunction(b,f))return"OK";if(!d)return"Jmol._serverUrl is not defined";
var c="string"==typeof f,e=c?"":"base64";c||(f=(JU?JU:J.util).Base64.getBase64(f).toString());b=b.substring(b.lastIndexOf("/")+1);c=0<=b.indexOf(".png")?"image/png":0<=b.indexOf(".jpg")?"image/jpg":"";a._formdiv||(a.$after("body",'
'),
a._formdiv="__jsmolform__");a.$attr(a._formdiv,"action",d+"?"+(new Date).getMilliseconds());a.$val("__jsmoldata__",f);a.$val("__jsmolfilename__",b);a.$val("__jsmolmimetype__",c);a.$val("__jsmolencoding__",e);a.$submit("__jsmolform__");a.$val("__jsmoldata__","");a.$val("__jsmolfilename__","");return"OK"};a._processData=function(b,f){"undefined"==typeof b&&(b="",f=!1);f&&(f=a._canSyncBinary());if(!f)return self.JU&&JU.SB?JU.SB.newS(b):J.util.SB.newS(b);var d;if(Clazz.instanceOf(b,self.ArrayBuffer))return a._toBytes(b);
d=Clazz.newByteArray(b.length,0);for(var c=b.length;0<=--c;)d[c]=b.charCodeAt(c)&255;return d};a._setConsoleDiv=function(b){self.Clazz&&Clazz.setConsoleDiv(b)};a._setJmolParams=function(b,f,d){for(var c in f)if(0<=";progressbar;progresscolor;boxbgcolor;boxfgcolor;allowjavascript;boxmessage; ;messagecallback;pickcallback;animframecallback;appletreadycallback;atommovedcallback; ;echocallback;evalcallback;hovercallback;language;loadstructcallback;measurecallback; ;minimizationcallback;resizecallback;scriptcallback;statusform;statustext;statustextarea; ;synccallback;usecommandthread;syncid;appletid;startupscript;".indexOf(";"+
c.toLowerCase()+";")&&("language"!=c||a.featureDetection.supportsLocalization()))d?b.put(c,!0===f[c]?Boolean.TRUE:!1===f[c]?Boolean.FALSE:f[c]):b[c]=f[c]};a._registerApplet=function(b,f){return window[b]=a._applets[b]=a._applets[f]=f};a._readyCallback=function(b,f,d,c){var e=b.split("_object")[0];a._track(a._applets[e])._readyCallback(b,f,d,c)};a._getWrapper=function(b,f){var d;if(f){var c="";b._coverImage&&(d=' onclick="Jmol.coverApplet(ID, false)" title="'+b._coverTitle+'"',c='
"+('")+"
");d='...
IMG......
';var e=b._height,g=b._width;if("string"!==typeof e||0>e.indexOf("%"))e+="px";if("string"!==typeof g||0>g.indexOf("%"))g+="px";d=d.replace(/IMG/,c).replace(/Hpx/g,e).replace(/Wpx/g,g)}else d='......
......
......
...
';
return d.replace(/\.\.\./g,"").replace(/[\n\r]/g,"").replace(/ID/g,b._id)};a._documentWrite=function(b){if(a._document){if(a._isXHTML&&!a._XhtmlElement){var f=document.getElementsByTagName("script");a._XhtmlElement=f.item(f.length-1);a._XhtmlAppendChild=!1}a._XhtmlElement?a._domWrite(b):a._document.write(b)}return b};a._domWrite=function(b){for(var f=[0];f[0]
b.jarFile.indexOf("Signed")&&(b.jarFile=b.jarFile.replace(/Applet/,"AppletSigned")),b.use="JAVA",b.isSigned=!0)};
a._syncedApplets=[];a._syncedCommands=[];a._syncedReady=[];a._syncReady=!1;a._isJmolJSVSync=!1;a._setReady=function(b){a._syncedReady[b]=1;for(var d=0,c=0;cd[0]?-1:0}if(!b||"object"!=typeof b)return[];
for(var d=[],c=b.length-1;0<=c;c--)for(var e=0,g=b[c].length;ed.type.indexOf("touch"))return!1;d.preventDefault();
var c=a.$offset(b.id),e,g=d.originalEvent;a._mousePageX=d.pageX;a._mousePageY=d.pageY;g.targetTouches&&g.targetTouches[0]?(e=g.targetTouches[0].pageX-c.left,c=g.targetTouches[0].pageY-c.top):g.changedTouches?(e=g.changedTouches[0].pageX-c.left,c=g.changedTouches[0].pageY-c.top):(e=d.pageX-c.left,c=d.pageY-c.top);return void 0==e?null:[Math.round(e),Math.round(c),a._jsGetMouseModifiers(d)]};a._gestureUpdate=function(b,d){d.stopPropagation();d.preventDefault();var c=d.originalEvent;switch(d.type){case "touchstart":a._touching=
!0;break;case "touchend":a._touching=!1}if(!c.touches||2!=c.touches.length)return!1;switch(d.type){case "touchstart":b._touches=[[],[]];break;case "touchmove":var e=a.$offset(b.id),g=b._touches[0],j=b._touches[1];g.push([c.touches[0].pageX-e.left,c.touches[0].pageY-e.top]);j.push([c.touches[1].pageX-e.left,c.touches[1].pageY-e.top]);c=g.length;3c?-1:1,0,d]);return!1});a.$bind(b,"contextmenu",function(){return!1});a.$bind(b,"mouseout",function(){b.applet._applet&&b.applet._applet.viewer.startHoverWatcher(!1);b.isDragging=!1});a.$bind(b,"mouseenter",function(d){b.applet._applet&&b.applet._applet.viewer.startHoverWatcher(!0);if(0===d.buttons||0===d.which){b.isDragging=!1;d=a._jsGetXY(b,d);if(!d)return!1;b.applet._processEvent(502,d)}});b.applet._is2D&&a.$resize(function(){b.applet&&b.applet._resize()});a.$bind("body","mouseup touchend",
function(){b.applet&&(b.isDragging=!1);a._setMouseOwner(null)})};a._jsUnsetMouse=function(b){b.applet=null;a.$bind(b,"mousedown touchstart mousemove touchmove mouseup touchend DOMMouseScroll mousewheel contextmenu mouseout mouseenter",null);a._setMouseOwner(null)};a._setDraggable=function(b){b=b.prototype;b.setContainer=function(b){this.container=b;b.obj=this;this.ignoreMouse=this.isDragging=!1;var d=this;b.bind("mousedown touchstart",function(b){if(d.ignoreMouse)return d.ignoreMouse=!1,!0;a._setMouseOwner(d,
!0);d.isDragging=!0;d.pageX=b.pageX;d.pageY=b.pageY;return!1});b.bind("mousemove touchmove",function(b){if(d.isDragging&&a._mouseOwner==d)return d.mouseMove(b),!1});b.bind("mouseup touchend",function(b){d.mouseUp(b);a._setMouseOwner(null)})};b.mouseUp=function(b){if(this.isDragging&&a._mouseOwner==this)return this.pageX0+=b.pageX-this.pageX,this.pageY0+=b.pageY-this.pageY,this.isDragging=!1;a._setMouseOwner(null)};b.setPosition=function(){if(null===a._mousePageX){var b=a.$offset(this.applet._id+"_"+
(this.applet._is2D?"canvas2d":"canvas"));a._mousePageX=b.left;a._mousePageY=b.top}this.pageX0=a._mousePageX;this.pageY0=a._mousePageY;this.container.css({top:a._mousePageY+"px",left:a._mousePageX+"px"})};b.mouseMove=function(b){this.isDragging&&a._mouseOwner==this&&this.container.css({top:this.pageY0+(b.pageY-this.pageY)+"px",left:this.pageX0+(b.pageX-this.pageX)+"px"})};b.dragBind=function(b){this.container.unbind("mousemoveoutjsmol");this.container.unbind("touchmoveoutjsmol");this.container.unbind("mouseupoutjsmol");
this.container.unbind("touchendoutjsmol");a._setMouseOwner(null);if(b){var d=this;this.container.bind("mousemoveoutjsmol touchmoveoutjsmol",function(b,a,c){d.mouseMove(c)});this.container.bind("mouseupoutjsmol touchendoutjsmol",function(b,a,c){d.mouseUp(c)})}}};a.Dialog={count:0,htDialogs:{}};SwingController=a.Dialog;a.Dialog.JSDialog=function(){};a._setDraggable(a.Dialog.JSDialog);a.Dialog.getScreenDimensions=function(b){b.width=g(window).width();b.height=g(window).height()};a.Dialog.dispose=function(b){a.$remove(b.id+
"_mover");delete a.Dialog.htDialogs[b.id];b.container.obj.dragBind(!1);System.out.println("JmolCore.js: dispose "+b.id)};a.Dialog.register=function(b,d){b.id=d+ ++a.Dialog.count;a.Dialog.htDialogs[b.id]=b;System.out.println("JmolCore.js: register "+b.id)};a.Dialog.setDialog=function(b){a._setMouseOwner(null);a.$remove(b.id);System.out.println("removed "+b.id);var d=b.id+"_mover",c=a.$("#"+d),e;System.out.println("JmolCore.js: setDialog "+b.id);c[0]?(c.html(b.html),e=c[0].jd):(a.$after("body",""+b.html+"
"),e=new a.Dialog.JSDialog,c=a.$("#"+d),b.container=c,e.applet=b.manager.viewer.applet,e.setContainer(c),e.dialog=b,e.setPosition(),e.dragBind(!0),c[0].jd=e);a.$bind("#"+b.id+" .JButton","mousedown touchstart",function(){e.ignoreMouse=!0});a.$bind("#"+b.id+" .JComboBox","mousedown touchstart",function(){e.ignoreMouse=!0});a.$bind("#"+b.id+" .JCheckBox","mousedown touchstart",function(){e.ignoreMouse=!0});a.$bind("#"+b.id+" .JTextField",
"mousedown touchstart",function(){e.ignoreMouse=!0});a.$bind("#"+b.id+" .JTable","mousedown touchstart",function(){e.ignoreMouse=!0});a.$bind("#"+b.id+" .JScrollPane","mousedown touchstart",function(){e.ignoreMouse=!0});a.$bind("#"+b.id+" .JEditorPane","mousedown touchstart",function(){e.ignoreMouse=!0})};a.Dialog.setSelected=function(b){a.$prop(b.id,"checked",!!b.selected)};a.Dialog.setSelectedIndex=function(b){a.$prop(b.id,"selectedIndex",b.selectedIndex)};a.Dialog.setText=function(b){a.$prop(b.id,
"value",b.text)};a.Dialog.setVisible=function(b){a.$setVisible(b.id,b.visible)};a.Dialog.click=function(b,d){var c=a.Dialog.htDialogs[b.id];if(c){System.out.println("click "+b+" "+c);var e=c.toString();if(0<=e.indexOf("JCheck"))c.selected=b.checked;else if(0<=e.indexOf("JCombo"))c.selectedIndex=b.selectedIndex;else if(null!=c.text&&(c.text=b.value,d&&13!=(d.charCode||d.keyCode)))return}e=a.Dialog.htDialogs[a.$getAncestorDiv(b.id,"JDialog").id];c=c?c.name:e.registryKey+"/"+b.id;System.out.println("JmolCore.js: click "+
c);e.manager.actionPerformed(c)};a.Dialog.windowClosing=function(b){b=a.Dialog.htDialogs[a.$getAncestorDiv(b.id,"JDialog").id];System.out.println("JmolCore.js: windowClosing "+b.registryKey);b.manager.processWindowClosing(b.registryKey)};a._track=function(b){if(a._tracker&&!a._isLocal)try{var d='';a.$after("body",d)}catch(c){}delete a._tracker;return b}})(Jmol,jQuery);Jmol._debugCode=!1;Jmol._grabberOptions=[["$","NCI(small molecules)"],[":","PubChem(small molecules)"]];Jmol.say=function(a){alert(a)};Jmol._TMApplet=function(a,g,d){this._syncId=(""+Math.random()).substring(3);this._id=a;this._is2D=!0;this._isJava=!1;this._ready=!0;this._mouseDown=!1;this._jmolType="Jmol._Canvas2D (TwirlyMol)";if(d)return this;this._createCanvas(a,g);return this};
Jmol._TMApplet._getApplet=function(a,g,d){if(!Jmol.featureDetection.allowHTML5)return null;d||(d=!1);g||(g={});Jmol._addDefaultInfo(g,{color:"#FFFFFF",width:300,height:300,addSelectionOptions:!1,serverURL:"http://your.server.here/jsmol.php",defaultModel:"",readyFunction:null,use:"HTML5",bondWidth:5,shadeAtoms:!1,zoomScaling:1.5,pinchScaling:2,mouseDragFactor:0.5,touchDragFactor:0.15,multipleBondSpacing:4,spinRateX:0,spinRateY:0.5,spinFPS:20,spin:!1,noscript:!0,debug:!1});g=new Jmol._TMApplet(a,g,
d);return d?g:Jmol._registerApplet(a,g)};Jmol.getTMApplet=Jmol._TMApplet._getApplet;
(function(a){a._CPK="#FF1493 #FFFFFF #D9FFFF #CC80FF #C2FF00 #FFB5B5 #909090 #3050F8 #FF0D0D #90E050 #B3E3F5 #AB5CF2 #8AFF00 #BFA6A6 #F0C8A0 #FF8000 #FFFF30 #1FF01F #80D1E3 #8F40D4 #3DFF00 #E6E6E6 #BFC2C7 #A6A6AB #8A99C7 #9C7AC7 #E06633 #F090A0 #50D050 #C88033 #7D80B0 #C28F8F #668F8F #BD80E3 #FFA100 #A62929 #5CB8D1 #702EB0 #00FF00 #94FFFF #94E0E0 #73C2C9 #54B5B5 #3B9E9E #248F8F #0A7D8C #006985 #C0C0C0 #FFD98F #A67573 #668080 #9E63B5 #D47A00 #940094 #429EB0 #57178F #00C900".split(" ");a._elem="X H He Li Be B C N O F Ne Na Mg Al Si P S Cl Ar K Ca Sc Ti V Cr Mn Fe Co Ni Cu Zn Ga Ge As Se Br Kr Rb Sr Y Zr Nb Mo Tc Ru Rh Pd Ag Cd In Sn Sb Te I Xe Cs Ba La Ce Pr Nd Pm Sm Eu Gd Tb Dy Ho Er Tm Yb Lu Hf Ta W Re Os Ir Pt Au Hg Tl Pb Bi Po At Rn Fr Ra Ac Th Pa U Np Pu Am Cm Bk Cf Es".split(" ");
a._elemNo={};var g=a.prototype;g.spin=function(a){this.__Info.spin=a;this._spin(a)};g._spin=function(a){this._spinThread&&clearTimeout(this._spinThread);if(0==this.spinFPS||0==this.spinRateX&&0==this.spinRateY)a=!1;if(a){var c=this;a=1E3/this.spinFPS;this._mouseDown||(this._rotate(this.spinRateY,this.spinRateX),this._draw());this._spinThread=setTimeout(function(){c._spin(!0)},a)}};g._initParams=function(){this.zoom=this.__Info.defaultZoom||100;this.doSpin=this.__Info.spin||!1;this.center2D=[this._canvas.width/
2,this._canvas.height/2,0];this._getCenterAndRadius();this.rotation=new a.M3;this.shadeAtoms=!1;this._setParams()};g._setParams=function(){this.bondWidth=this.__Info.bondWidth||5;this.zoomScaling=this.__Info.zoomScaling||1.5;this.pinchScaling=this.__Info.pinchScaling||1;this.mouseDragFactor=this.__Info.mouseDragFactor||0.5;this.touchDragFactor=this.__Info.touchDragFactor||0.15;this.multipleBondSpacing=this.__Info.multipleBondSpacing||4;this.spinRateX=this.__Info.spinRateX||0;this.spinRateY=this.__Info.spinRateY||
0;this.spinFPS=this.__Info.spinFPS||0;var a=this.shadeAtoms;(this.shadeAtoms=this.__Info.shadeAtoms||!1)&&!a&&this._setAtomShades()};g._setAtomShades=function(){if(this.atoms)for(var a=this.atoms.length;0<=--a;)this.atoms[a].color50=this._getColor(this.atoms[a].color,0.5)};g._createCanvas=function(a,c){Jmol._setObject(this,a,c);this._color=this._color.replace(/0x/,"#");var e=Jmol._getWrapper(this,!0);Jmol._document?(Jmol._documentWrite(e),this._createCanvas2d(!1),e=""):e+='