<html xmlns:o="urn:schemas-microsoft-com:office:office" xmlns:w="urn:schemas-microsoft-com:office:word" xmlns:m="http://schemas.microsoft.com/office/2004/12/omml" xmlns="http://www.w3.org/TR/REC-html40"><head><meta http-equiv=Content-Type content="text/html; charset=utf-8"><meta name=Generator content="Microsoft Word 15 (filtered medium)"><style><!--
/* Font Definitions */
@font-face
        {font-family:"Cambria Math";
        panose-1:2 4 5 3 5 4 6 3 2 4;}
@font-face
        {font-family:Calibri;
        panose-1:2 15 5 2 2 2 4 3 2 4;}
/* Style Definitions */
p.MsoNormal, li.MsoNormal, div.MsoNormal
        {margin:0in;
        margin-bottom:.0001pt;
        font-size:11.0pt;
        font-family:"Calibri",sans-serif;}
p.MsoListParagraph, li.MsoListParagraph, div.MsoListParagraph
        {mso-style-priority:34;
        margin-top:0in;
        margin-right:0in;
        margin-bottom:0in;
        margin-left:.5in;
        margin-bottom:.0001pt;
        font-size:11.0pt;
        font-family:"Calibri",sans-serif;}
.MsoChpDefault
        {mso-style-type:export-only;}
@page WordSection1
        {size:8.5in 11.0in;
        margin:1.0in 1.0in 1.0in 1.0in;}
div.WordSection1
        {page:WordSection1;}
/* List Definitions */
@list l0
        {mso-list-id:638655264;
        mso-list-type:hybrid;
        mso-list-template-ids:-1403591306 -1 67698713 67698715 67698703 67698713 67698715 67698703 67698713 67698715;}
@list l0:level1
        {mso-level-text:"%1\)";
        mso-level-tab-stop:none;
        mso-level-number-position:left;
        text-indent:-.25in;
        font-family:"Times New Roman",serif;
        mso-ascii-font-family:Calibri;
        mso-hansi-font-family:Calibri;
        mso-bidi-font-family:"Times New Roman";}
@list l0:level2
        {mso-level-number-format:alpha-lower;
        mso-level-tab-stop:none;
        mso-level-number-position:left;
        text-indent:-.25in;}
@list l0:level3
        {mso-level-number-format:roman-lower;
        mso-level-tab-stop:none;
        mso-level-number-position:right;
        text-indent:-9.0pt;}
@list l0:level4
        {mso-level-tab-stop:none;
        mso-level-number-position:left;
        text-indent:-.25in;}
@list l0:level5
        {mso-level-number-format:alpha-lower;
        mso-level-tab-stop:none;
        mso-level-number-position:left;
        text-indent:-.25in;}
@list l0:level6
        {mso-level-number-format:roman-lower;
        mso-level-tab-stop:none;
        mso-level-number-position:right;
        text-indent:-9.0pt;}
@list l0:level7
        {mso-level-tab-stop:none;
        mso-level-number-position:left;
        text-indent:-.25in;}
@list l0:level8
        {mso-level-number-format:alpha-lower;
        mso-level-tab-stop:none;
        mso-level-number-position:left;
        text-indent:-.25in;}
@list l0:level9
        {mso-level-number-format:roman-lower;
        mso-level-tab-stop:none;
        mso-level-number-position:right;
        text-indent:-9.0pt;}
ol
        {margin-bottom:0in;}
ul
        {margin-bottom:0in;}
--></style></head><body lang=EN-US><div class=WordSection1><p class=MsoNormal>Sorry, I was zonked all day yesterday, and just got up today. Here were my research findings when I was trying to add Scripts to X3DOM.</p><p class=MsoNormal><o:p> </o:p></p><ol style='margin-top:0in' start=1 type=1><li class=MsoListParagraph style='margin-left:0in;mso-list:l0 level1 lfo1'>There is no Script or fields for Script implemented in X3DOM AFAIK.  X3DOM uses HTML scripting.   Thus you can’t ROUTE to Script fields.  Script fields are not processed into X3DOM routes or X3DOM anything AFAIK.<o:p></o:p></li><li class=MsoListParagraph style='margin-left:0in;mso-list:l0 level1 lfo1'>It might be possible to implement fields for Script.  It shouldn’t matter what you call Script in X3DOM.  X3DScript should be fine.   I will use that from now in my discussions. That is, scripts or Scripts, embedded in X3D (scripts with fields) are X3DScripts.  You will have to figure out how to otherwise change the JavaScript X3DScript code to read and modify JavaScript variables in concordance with fields.   This is work I have done which is available in X3DJSONLD. I used eval, not new Function(). I wrote my own ROUTEing code since I removed the fields and CDATA nodes from my X3DScript, and there is a shared variable between my evals. I would like to hide this variable from the global context, but haven’t discovered the perfect way yet. If you implement the X3DScript fields in X3DOM, you should be able to leverage X3DOM’s routing/events, but I didn’t really test this sufficiently.  X3DOM’s ComposedShader fields work with ROUTEs, so I see no reason why X3DScripts couldn’t.  AFAIK, X3DScript fields currently have no implementation in X3DOM.<o:p></o:p></li><li class=MsoListParagraph style='margin-left:0in;mso-list:l0 level1 lfo1'>If someone wants to modify my code to fully add X3DScripts to X3DOM, they are welcome work with my X3DJSONLD—I have made it work for many if not all of my X3DScripts, but I have several from X3D Resources Examples that do not work. It’s probably best to start fresh with a X3DOM implementation of script field ROUTEs.<o:p></o:p></li><li class=MsoListParagraph style='margin-left:0in;mso-list:l0 level1 lfo1'>The X3DScript (non-generated) code I wrote is in a single module and does not extend outside that yet.  However, the main interface accepts JSON to find X3DScript in.   We would have to change that to DOM.<o:p></o:p></li><li class=MsoListParagraph style='margin-left:0in;mso-list:l0 level1 lfo1'>I do not have an XML implementation of X3DScripts (only JSON), so I avoid most of the HTML script tag discussion.<o:p></o:p></li><li class=MsoListParagraph style='margin-left:0in;mso-list:l0 level1 lfo1'>You may make scripts unrunnable by specifying an illegal type attribute, possibly making the CDATA/text node runnable through new Function or eval. (thanks Andreas)<o:p></o:p></li></ol><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>So the main effort involved is implementing fields and connection between JavaScript and fields and ROUTEs and fields.  I do not know if you have to replace the script tag with something else or not, but I doubt it…so what if the JavaScript runs first?   Put all your X3D code in functions! Make it a requirement that all X3DScript code be functions, if it isn’t already!<o:p></o:p></p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>Hopefully you will get something you like.<o:p></o:p></p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>If someone has JavaScript code they would like to use in an X3DScript that uses classes, imports, etc. Please give it to me for testing.   Thanks!<o:p></o:p></p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>John<o:p></o:p></p><p class=MsoNormal><o:p> </o:p></p></div></body></html>