x_ite 9.6.1 → 9.6.3

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (49) hide show
  1. package/README.md +11 -6
  2. package/dist/assets/components/Annotation.js +13 -13
  3. package/dist/assets/components/Annotation.min.js +1 -1
  4. package/dist/assets/components/CADGeometry.js +14 -14
  5. package/dist/assets/components/CADGeometry.min.js +1 -1
  6. package/dist/assets/components/CubeMapTexturing.js +27 -27
  7. package/dist/assets/components/CubeMapTexturing.min.js +1 -1
  8. package/dist/assets/components/DIS.js +13 -13
  9. package/dist/assets/components/DIS.min.js +1 -1
  10. package/dist/assets/components/EventUtilities.js +9 -9
  11. package/dist/assets/components/EventUtilities.min.js +1 -1
  12. package/dist/assets/components/Geometry2D.js +18 -18
  13. package/dist/assets/components/Geometry2D.min.js +1 -1
  14. package/dist/assets/components/Geospatial.js +33 -33
  15. package/dist/assets/components/Geospatial.min.js +1 -1
  16. package/dist/assets/components/HAnim.js +23 -23
  17. package/dist/assets/components/HAnim.min.js +1 -1
  18. package/dist/assets/components/KeyDeviceSensor.js +8 -8
  19. package/dist/assets/components/KeyDeviceSensor.min.js +1 -1
  20. package/dist/assets/components/Layout.js +27 -27
  21. package/dist/assets/components/Layout.min.js +1 -1
  22. package/dist/assets/components/NURBS.js +23 -23
  23. package/dist/assets/components/NURBS.min.js +1 -1
  24. package/dist/assets/components/ParticleSystems.js +26 -26
  25. package/dist/assets/components/ParticleSystems.min.js +1 -1
  26. package/dist/assets/components/Picking.js +18 -18
  27. package/dist/assets/components/Picking.min.js +1 -1
  28. package/dist/assets/components/RigidBodyPhysics.js +17 -17
  29. package/dist/assets/components/RigidBodyPhysics.min.js +1 -1
  30. package/dist/assets/components/Scripting.js +38 -38
  31. package/dist/assets/components/Scripting.min.js +1 -1
  32. package/dist/assets/components/Text.js +24 -24
  33. package/dist/assets/components/Text.min.js +1 -1
  34. package/dist/assets/components/TextureProjection.js +15 -15
  35. package/dist/assets/components/TextureProjection.min.js +1 -1
  36. package/dist/assets/components/Texturing3D.js +29 -29
  37. package/dist/assets/components/Texturing3D.min.js +1 -1
  38. package/dist/assets/components/VolumeRendering.js +19 -19
  39. package/dist/assets/components/VolumeRendering.min.js +1 -1
  40. package/dist/assets/components/X_ITE.js +14 -14
  41. package/dist/assets/components/X_ITE.min.js +1 -1
  42. package/dist/x_ite.css +1 -1
  43. package/dist/x_ite.d.ts +16 -7
  44. package/dist/x_ite.js +430 -246
  45. package/dist/x_ite.min.js +1 -1
  46. package/dist/x_ite.min.mjs +1 -1
  47. package/dist/x_ite.mjs +430 -246
  48. package/dist/x_ite.zip +0 -0
  49. package/package.json +2 -2
@@ -1 +1 @@
1
- /* X_ITE v9.6.1 */(()=>{"use strict";var e={n:t=>{var i=t&&t.__esModule?()=>t.default:()=>t;return e.d(i,{a:i}),i},d:(t,i)=>{for(var n in i)e.o(i,n)&&!e.o(t,n)&&Object.defineProperty(t,n,{enumerable:!0,get:i[n]})},o:(e,t)=>Object.prototype.hasOwnProperty.call(e,t)};const t=window[Symbol.for("X_ITE.X3D-9.6.1")].require("x_ite/Components");var i=e.n(t);const n=window[Symbol.for("X_ITE.X3D-9.6.1")].require("x_ite/Fields");var o=e.n(n);const s=window[Symbol.for("X_ITE.X3D-9.6.1")].require("x_ite/Base/X3DFieldDefinition");var r=e.n(s);const l=window[Symbol.for("X_ITE.X3D-9.6.1")].require("x_ite/Base/FieldDefinitionArray");var a=e.n(l);const u=window[Symbol.for("X_ITE.X3D-9.6.1")].require("x_ite/Components/Core/X3DNode");var h=e.n(u);const d=window[Symbol.for("X_ITE.X3D-9.6.1")].require("x_ite/Base/X3DConstants");var c=e.n(d);const p=window[Symbol.for("X_ITE.X3D-9.6.1")].require("x_ite/Base/X3DCast");var g=e.n(p);const m=window[Symbol.for("X_ITE.X3D-9.6.1")].require("x_ite/Namespace");var f=e.n(m);function _(e){h().call(this,e),this.addType(c().Contour2D),this.childNodes=[]}function b(e,t){const i=new Set(t);return e.filter((e=>!i.has(e)))}Object.assign(Object.setPrototypeOf(_.prototype,h().prototype),{initialize(){h().prototype.initialize.call(this),this._addChildren.addInterest("set_addChildren__",this),this._removeChildren.addInterest("set_removeChildren__",this),this._children.addInterest("set_children__",this),this.set_children__()},set_addChildren__(){this._addChildren.setTainted(!0),this._addChildren.assign(b(this._addChildren,this._children));for(const e of this._addChildren)this._children.push(e);this._addChildren.length=0,this._addChildren.setTainted(!1)},set_removeChildren__(){this._removeChildren.setTainted(!0),this._children.assign(b(this._children,this._removeChildren)),this._removeChildren.length=0,this._removeChildren.setTainted(!1)},set_children__(){const e=this.childNodes;e.length=0;for(const t of this._children){const i=g()(c().NurbsCurve2D,t);if(i)e.push(i);else{const i=g()(c().ContourPolyline2D,t);if(i){e.push(i);continue}}}},addTrimmingContour(e){for(const t of this.childNodes)e.push(t.tessellate(2))}}),Object.defineProperties(_,{typeName:{value:"Contour2D",enumerable:!0},componentInfo:{value:Object.freeze({name:"NURBS",level:4}),enumerable:!0},containerField:{value:"trimmingContour",enumerable:!0},specificationRange:{value:Object.freeze({from:"3.0",to:"Infinity"}),enumerable:!0},fieldDefinitions:{value:new(a())([new(r())(c().inputOutput,"metadata",new(o().SFNode)),new(r())(c().inputOnly,"addChildren",new(o().MFNode)),new(r())(c().inputOnly,"removeChildren",new(o().MFNode)),new(r())(c().inputOutput,"children",new(o().MFNode))]),enumerable:!0}});const v=_;f().add("Contour2D","x_ite/Components/NURBS/Contour2D",v);const w=v;function y(e){h().call(this,e),this.addType(c().X3DNurbsControlCurveNode)}Object.setPrototypeOf(y.prototype,h().prototype),Object.defineProperties(y,{typeName:{value:"X3DNurbsControlCurveNode",enumerable:!0},componentInfo:{value:Object.freeze({name:"NURBS",level:1}),enumerable:!0}});const N=y;f().add("X3DNurbsControlCurveNode","x_ite/Components/NURBS/X3DNurbsControlCurveNode",N);const C=N,O=window[Symbol.for("X_ITE.X3D-9.6.1")].require("standard/Math/Numbers/Vector3");var S=e.n(O);function P(e){C.call(this,e),this.addType(c().ContourPolyline2D),this.controlPoints=[]}Object.assign(Object.setPrototypeOf(P.prototype,C.prototype),{tessellate(e){switch(e){case 0:{const e=this._controlPoint.getValue(),t=this.controlPoints,i=this._controlPoint.length;for(let n=0;n<i;++n){const i=2*n;t[i+0]=e[i+0],t[i+1]=e[i+1]}return t.length=2*i,t}case 1:{const e=this._controlPoint.getValue(),t=this.controlPoints,i=this._controlPoint.length;for(let n=0;n<i;++n){const i=2*n,o=3*n;t[o+0]=e[i+0],t[o+1]=0,t[o+2]=e[i+1]}return t.length=3*i,t}case 3:{const e=this._controlPoint.getValue(),t=this.controlPoints,i=this._controlPoint.length;for(let n=0;n<i;++n){const i=2*n;t[n]=new(S())(e[i+0],e[i+1],0)}return t.length=i,t}}}}),Object.defineProperties(P,{typeName:{value:"ContourPolyline2D",enumerable:!0},componentInfo:{value:Object.freeze({name:"NURBS",level:3}),enumerable:!0},containerField:{value:"children",enumerable:!0},specificationRange:{value:Object.freeze({from:"3.0",to:"Infinity"}),enumerable:!0},fieldDefinitions:{value:new(a())([new(r())(c().inputOutput,"metadata",new(o().SFNode)),new(r())(c().inputOutput,"controlPoint",new(o().MFVec2d))]),enumerable:!0}});const D=P;f().add("ContourPolyline2D","x_ite/Components/NURBS/ContourPolyline2D",D);const I=D,F=window[Symbol.for("X_ITE.X3D-9.6.1")].require("x_ite/Components/Rendering/X3DGeometryNode");var R=e.n(F);const z=window[Symbol.for("X_ITE.X3D-9.6.1")].require("standard/Math/Numbers/Vector2");var V=e.n(z);const T=window[Symbol.for("X_ITE.X3D-9.6.1")].require("standard/Math/Numbers/Vector4");var j=e.n(T);const x={getTessellation:(e,t)=>e>0?e+1:e<0?-e*t+1:2*t+1,getClosed2D(e,t,i,n){const o=n.length;return(!(i.length===o)||i[0]===i[o-1])&&(!!n[0].equals(n[o-1])&&!!this.isPeriodic(e,o,t))},getClosed:(()=>{const e=new(S()),t=new(S());return function(i,n,o,s){const r=s.getSize();return(!(o.length===r)||o[0]===o[r-1])&&(!!s.get1Point(0,e).equals(s.get1Point(r-1,t))&&!!this.isPeriodic(i,r,n))}})(),getUClosed:(()=>{const e=new(S()),t=new(S());return function(i,n,o,s,r,l){const a=r.length===l.getSize();for(let i=0,s=o;i<s;++i){const o=i*n,s=i*n+n-1;if(a&&r[o]!==r[s])return!1;if(!l.get1Point(o,e).equals(l.get1Point(s,t)))return!1}return!!this.isPeriodic(i,n,s)}})(),getVClosed:(()=>{const e=new(S()),t=new(S());return function(i,n,o,s,r,l){const a=r.length===l.getSize();for(let i=0,s=n;i<s;++i){const s=i,u=(o-1)*n+i;if(a&&r[s]!==r[u])return!1;if(!l.get1Point(s,e).equals(l.get1Point(u,t)))return!1}return!!this.isPeriodic(i,o,s)}})(),isPeriodic(e,t,i){if(i.length===t+e){{let t=1;for(let n=1,o=e;n<o;++n)t+=i[n]===i[0];if(t===e)return!1}{let t=1;for(let n=i.length-e,o=i.length-1;n<o;++n)t+=i[n]===i[o];if(t===e)return!1}}return!0},getKnots(e,t,i,n,o){const s=e||[];for(let e=0,t=o.length;e<t;++e)s[e]=o[e];s.length=o.length;let r=!0;if(s.length===n+i){r=!1;let e=0;for(let t=1,n=s.length;t<n;++t)s[t]==s[t-1]?++e:e=0,e>i-1&&(r=!0),s[t-1]>s[t]&&(r=!0)}if(r)for(let e=0,t=n+i;e<t;++e)s[e]=e/(t-1);if(t)for(let e=1,t=i-1;e<t;++e)s.push(s.at(-1)+(s[e]-s[e-1]));return s},getWeights(e,t,i){if(i.length!==t)return;const n=e||[];for(let e=0;e<t;++e)n[e]=i[e];return n.length=t,n},getUVWeights(e,t,i,n){const o=t*i;if(n.length!==o)return;const s=e||[];for(let e=0,o=0;e<t;++e)for(let e=0;e<i;++e,++o)s[o]=n[o];return s.length=o,s},getControlPoints2D(e,t,i,n,o){const s=e||[],r=o.getValue(),l=o.length,a=!!n,u=a?S():V();s.haveWeights!==a&&(s.haveWeights=a,s.length=0);for(let e=0;e<l;++e){const t=2*e,i=s[e]||new u(0,0,0);s[e]=i.set(r[t+0],r[t+1],a?n[e]:0)}if(s.length=l,t)for(let e=1,t=i-1;e<t;++e)s.push(s[e]);return s},getControlPoints(e,t,i,n,o){const s=e||[],r=o.getSize(),l=!!n,a=l?j():S();s.haveWeights!==l&&(s.haveWeights=l,s.length=0);for(let e=0;e<r;++e){const t=s[e]=o.get1Point(e,s[e]||new a(0,0,0,0));l&&(t.w=n[e])}if(s.length=r,t)for(let e=1,t=i-1;e<t;++e)s.push(s[e]);return s},getUVControlPoints(e,t,i,n,o,s,r,l,a){const u=e||[],h=!!l,d=h?j():S();u.haveWeights!==h&&(u.haveWeights=h,u.length=0);for(let e=0;e<s;++e){let t=u[e];t||(t=u[e]=[]);for(let i=0;i<r;++i){const n=i*s+e;t[i]=a.get1Point(n,t[i]||new d(0,0,0,0)),h&&(t[i].w=l[n])}if(t.length=r,i)for(let e=1,i=o-1;e<i;++e)t.push(t[e])}if(u.length=s,t)for(let e=1,t=n-1;e<t;++e)u.push(u[e]);return u},getTexControlPoints(e,t,i,n,o,s,r,l){const a=e||[];for(let e=0;e<s;++e){let t=a[e];t||(t=a[e]=[]);for(let i=0;i<r;++i){const n=i*s+e;t[i]=l.get1Point(n,t[i]||new(j()))}if(t.length=r,i)for(let e=1,i=o-1;e<i;++e)t.push(t[e])}if(a.length=s,t)for(let e=1,t=n-1;e<t;++e)a.push(a[e]);return a}};f().add("NURBS","x_ite/Browser/NURBS/NURBS",x);const k=x;function A(e){R().call(this,e),this.addType(c().X3DParametricGeometryNode)}Object.assign(Object.setPrototypeOf(A.prototype,R().prototype),{getKnots:(e,t,i,n,o)=>k.getKnots(e,t,i,n,o)}),Object.defineProperties(A,{typeName:{value:"X3DParametricGeometryNode",enumerable:!0},componentInfo:{value:Object.freeze({name:"NURBS",level:1}),enumerable:!0}});const B=A;f().add("X3DParametricGeometryNode","x_ite/Components/NURBS/X3DParametricGeometryNode",B);const X=B,E=window[Symbol.for("X_ITE.X3D-9.6.1")].require("x_ite/Components/Rendering/X3DLineGeometryNode");var U=e.n(E);const q=function(e){return!!e&&(!!e.dtype&&new RegExp("function View[0-9]+d(:?"+e.dtype+")+").test(String(e.constructor)))};f().add("is-ndarray","lib/nurbs/src/utils/is-ndarray",q);const K=q,M=function(e){return!!e&&(void 0!==e.data&&Array.isArray(e.shape)&&void 0!==e.offset&&void 0!==e.stride)};f().add("is-ndarray-like","lib/nurbs/src/utils/is-ndarray-like",M);const G=M,W=function(e){return Array.isArray(e)||ArrayBuffer.isView(e)||void 0!==e.length};f().add("is-array-like","lib/nurbs/src/utils/is-array-like",W);const Y=W;function J(e){if(e){if(K(e)||G(e))return"generic"===e.dtype?J.GENERIC_NDARRAY:J.NDARRAY;if(Y(e)){for(var t=e;Y(t[0]);t=t[0]);return"x"in t?J.ARRAY_OF_OBJECTS:J.ARRAY_OF_ARRAYS}throw new Error("Unhandled data type. Got type: "+typeof e)}}J.ARRAY_OF_OBJECTS="Obj",J.ARRAY_OF_ARRAYS="Arr",J.NDARRAY="Nd",J.GENERIC_NDARRAY="GenNd",J.PACKED="PackArr";const L=J;f().add("infer-type","lib/nurbs/src/utils/infer-type",L);const Z=L;const H=function(e,t,i,n,o,s){var r,l,a=[],u=!1;for(r=0;r<e.splineDimension;r++){var h=Y(e.knots)&&Y(e.knots[r]);h&&(u=!0),a.push("Deg"+e.degree[r]+(h?"":"Uniform")+((l=e.boundary[r])[0].toUpperCase()+l.slice(1)))}var d=[[u?"NU":"",e.weights?"RBS":"BS"].join("")+e.dimension+"D",a.join("_")];return n&&d.push(n+"Pts"),o&&d.push(o+"Wts"),s&&d.push(s+"Kts"),t&&d.push("debug"),i&&d.push("chk"),d.join("_")};f().add("cache-key","lib/nurbs/src/utils/cache-key",H);const Q=H;var $=function e(t,i){return function(i,n){void 0===i||Array.isArray(i)||(i=[i]);for(var o=[],s=0;s<i.length;s++)o.push(e.sum(i[s]));if(n)for(i=0;i<o.length;i++)void 0!==n[i]&&(o[i]="("+o[i]+" + "+n[i]+") % "+n[i]);return t+o.join("_")}};$.sum=function(e){return 0===(e=(e=Array.isArray(e)?e:[e]).filter((e=>void 0!==e&&0!==e))).length&&e.push(0),e.join(" + ")};const ee=$;f().add("variable","lib/nurbs/src/utils/variable",ee);const te=ee;var ie=[".x",".y",".z",".w"];function ne(e){return function(t,i){void 0===t||Array.isArray(t)||(t=[t]);for(var n=[],o=0;o<t.length;o++)n.push(te.sum(t[o]));if(i)for(t=0;t<n.length;t++)void 0!==i[t]&&(n[t]="("+n[t]+" + "+i[t]+") % "+i[t]);return e(n)}}function oe(e,t){if(t)switch(Z(t)){case Z.ARRAY_OF_OBJECTS:return ne((t=>{var i=t.pop();return e+"["+t.join("][")+"]"+ie[i]}));case Z.ARRAY_OF_ARRAYS:return ne((t=>e+"["+t.join("][")+"]"));case Z.GENERIC_NDARRAY:return ne((t=>e+".get("+t.join(",")+")"));case Z.NDARRAY:return ne((t=>{for(var i=[e+"Offset"],n=0;n<t.length;n++)i.push(e+"Stride"+n+" * ("+t[n]+")");return e+"["+i.join(" + ")+"]"}));case Z.PACKED:default:return}}const se=function(e){var t,i={};return(t=oe("x",e.points))&&(i.point=t),(t=oe("w",e.weights))&&(i.weight=t),(t=oe("k",e.knots))&&(i.knot=t),i};f().add("create-accessors","lib/nurbs/src/utils/create-accessors",se);const re=se;var le=[],ae=[];const ue=function(e,t,i){if(1!==t)throw new Error("Numerical derivative not implemented for order n = "+t+".");var n,o=void 0===arguments[this.splineDimension+3]?1e-4:arguments[this.splineDimension+3];for(le.length=this.splineDimension,n=0;n<this.splineDimension;n++)le[n+1]=arguments[n+3];var s,r,l,a=this.domain,u=a[i][0],h=a[i][1],d=le[i+1],c=(h-u)*o;for("closed"===this.boundary[i]?(s=u+(d-u-c+(l=h-u))%l,r=u+(d-u+c+l)%l,c*=2):(s=Math.min(h,Math.max(u,d-c)),c=(r=Math.min(h,Math.max(u,d+c)))-s),le[i+1]=s,le[0]=ae,this.evaluate.apply(null,le),le[i+1]=r,le[0]=e,this.evaluate.apply(null,le),n=0;n<this.dimension;n++)e[n]=(e[n]-ae[n])/c;return e};f().add("numerical-derivative","lib/nurbs/src/numerical-derivative",ue);const he=ue,de=function(e,t){for(var i=1,n=0,o=[];n<e.length;n++)i*=Array.isArray(e[n])?e[n][1]-e[n][0]:e[n],o[n]=Array.isArray(e[n])?e[n][0]:0;for(var s=0;s<i;s++)for(t(o.slice()),n=e.length-1;n>=0;n--){if(o[n]!==(Array.isArray(e[n])?e[n][1]:e[n])-1){o[n]++;break}o[n]=Array.isArray(e[n])?e[n][0]:0}};f().add("ndloop","lib/nurbs/src/utils/ndloop",de);const ce=de,pe=function(e,t,i,n){var o=[];switch(Z(n)){case Z.NDARRAY:o.push(" var "+t+" = "+i+".data;"),o.push(" var "+t+"Offset = "+i+".offset;");for(var s=0;s<n.dimension;s++)o.push(" var "+t+"Stride"+s+" = "+i+".stride["+s+"];");break;case Z.ARRAY_OF_OBJECTS:case Z.ARRAY_OF_ARRAYS:o.push(" var "+t+" = "+i+";")}return o.join("\n")};f().add("accessor-preamble","lib/nurbs/src/utils/accessor-preamble",pe);const ge=pe,me=function(e,t,i){if(e){if(G(e))return t+".shape["+i+"]";for(var n=t,o=0;o<i;o++)n+="[0]";return n+".length"}return"this.size["+i+"]"};f().add("size-getter","lib/nurbs/src/utils/size-getter",me);const fe=me;var _e={},be={};const ve=function(e,t,i,n,o,s,r){var l,a,u,h,d,c,p=t.splineDimension,g=t.points,m=t.degree,f=t.weights,_=void 0!==f,b=t.knots,v=t.dimension,w=t.boundary;if(null!=r){Array.isArray(r)||(r=[r]);var y=0;for(l=0;l<p;l++)void 0===r[l]&&(r[l]=0),y+=r[l];if(_&&y>1)throw new Error("Analytical derivative not implemented for rational b-splines with order n = "+y+".")}s&&(e="Basis"+e),r&&(e="Der"+r.join("_")+"_"+e);var N=_e[e];if(n)var C="function"==typeof n?n:console.log;if(N)return n&&C(be[e]),N.bind(t);var O=[],S="evaluate"+e,P=i.point;s&&(P=function(e,t){for(var i=[],n=0;n<e.length;n++){for(var o=e[n],s=[],r=0;r<o.length;r++)0!==o[r]&&s.push(o[r]);o=s.join(" + "),t[n]&&(o="("+o+" + "+t[n]+") % "+t[n]),i.push(o+" === "+V(n))}return"(("+i.join(" && ")+") ? 1 : 0)"});var D=i.weight,I=i.knot,F=te("k"),R=te("x"),z=te("w"),V=te("i"),T=te("t"),j=n?"domain":"d",x=te(n?"size":"s"),k=te(n?"knotIndex":"j"),A=!0;for(d=0;d<p;d++)Y(b)&&Y(b[d])&&(A=!1);function B(e){O.push(" "+(e||""))}function X(e){n&&B(e)}if(s)var E=[];var U=[];for(l=0;l<p;l++)s&&E.push(V([l])),U.push(T([l]));for(O.push("function "+S+" ("+(s?"":"out, ")+U.join(", ")+(s?", "+E.join(", "):"")+") {"),B("var h, m, a, b;"),o&&(B("var "+j+" = this.domain;"),B("for (var i = 0; i < this.splineDimension; i++) {"),B(" a = arguments[i + 1];"),B(" if (a < "+j+"[i][0] || a > "+j+"[i][1] || a === undefined || isNaN(a)) {"),B(' throw new Error("Invalid Spline parameter in dimension "+i+". Valid domain is ["+'+j+'[i][0]+", "+'+j+'[i][1]+"]. but got t"+i+" = "+arguments[i + 1]+".");'),B(" }"),B("}")),d=0;d<p;d++)B("var "+x(d)+" = "+fe(g,"this.points",d)+";");function q(e,t,i){return"("+e+") ? ("+t+") : ("+i+")"}O.push(ge(t,"x","this.points",g)),_&&O.push(ge(t,"w","this.weights",f)),A||O.push(ge(t,"k","this.knots",b));var K=[];for(d=0;d<p;d++)switch(Z(b)){case Z.NDARRAY:K[d]=!0;break;case Z.ARRAY_OF_ARRAYS:K[d]=Y(b[d])}for(d=0;d<p;d++)if(K[d])for(X("\n // Bisect to locate the knot interval in dimension "+d+"\n"),B("var "+k(d)+" = 0;"),B("h = "+x(d)+";"),B("while(h > "+k(d)+" + 1) {"),B(" m = 0.5 * (h + "+k(d)+") | 0;"),B(" if ("+I([d,"m"])+" > "+T(d)+") h = m;"),B(" else "+k(d)+" = m;"),B("}"),X("\n // Fetch knots for dimension "+d+"\n"),l=1-m[d];l<=m[d];l++)"closed"===w[d]?B(l<0?"var "+F([d,l+m[d]-1])+" = "+q(k(d)+" < "+-l,I([d,0])+" + "+I([d,[x(d),k(d),l]])+" - "+I([d,[x(d)]]),I([d,[k(d),l]]))+";":l>0?"var "+F([d,l+m[d]-1])+" = "+q(k(d)+" + "+l+" > "+x(d),I([d,x(d)])+" + "+I([d,l+" + "+k(d)+" - "+x(d)])+" - "+I([d,0]),I([d,[k(d),l]]))+";":"var "+F([d,l+m[d]-1])+" = "+I([d,[k(d),l]])+";"):B("var "+F([d,l+m[d]-1])+" = "+I([d,[k(d),l]])+";");else{for(X("\n // Directly compute knot interval for dimension "+d+"\n"),"closed"===w[d]?B(k(d)+" = ("+T(d)+" | 0) % "+x(d)+";"):(B(k(d)+" = ("+T(d)+" | 0);"),B("if ("+k(d)+" < "+m[d]+") "+k(d)+" = "+m[d]+";"),B("if ("+k(d)+" > "+x(d)+" - 1) "+k(d)+" = "+x(d)+" - 1;")),X("\n // Compute and clamp knots for dimension "+d+"\n"),l=1-m[d];l<=m[d];l++)B("var "+(c=F([d,l+m[d]-1]))+" = "+k(d)+" + "+l+";");if("clamped"===w[d])for(l=1-m[d];l<=m[d];l++)c=F([d,l+m[d]-1]),l<0&&B("if ("+c+" < "+m[d]+") "+c+" = "+m[d]+";"),l>0&&B("if ("+c+" > "+x(d)+") "+c+" = "+x(d)+";");"closed"===w[d]&&(X("\n // Wrap the B-Spline parameter for closed boundary"),B(T(d)+" %= "+x(d)+";"))}for(d=0,u=[];d<p;d++)u[d]=m[d]+1;for(_&&(X("\n // Fetch weights\n"),ce(u,(function(e){for(var t=[],i=[],n=0;n<p;n++)t[n]=[k(n),e[n]-m[n]],"closed"===w[n]&&e[n]-m[n]<0&&(i[n]=x(n));B("var "+z(e)+" = "+D(t,i)+";")}))),n&&B(_?"\n // Fetch points and project into homogeneous (weighted) coordinates\n":"\n // Fetch points\n"),ce(u,(function(e){for(var t=[],i=[],n=0;n<p;n++)t[n]=[k(n),e[n]-m[n]],"closed"===w[n]&&e[n]-m[n]<0&&(i[n]=x(n));if(s)B(_?"var "+R(e)+" = "+P(t,i)+" * "+z(e)+";":"var "+R(e)+" = "+P(t,i)+";");else for(n=0;n<v;n++){var o=e.concat(n);t[p]=n,B(_?"var "+R(o)+" = "+P(t,i)+" * "+z(e)+";":"var "+R(o)+" = "+P(t,i)+";")}})),X("\n"),X('// Perform De Boor"s algorithm'),d=u.length-1;d>=0;d--)for(u[d]=[m[d],m[d]+1],l=0;l<m[d];l++)for(X("\n // Degree "+m[d]+" evaluation in dimension "+d+", step "+(l+1)+"\n"),a=m[d];a>l;a--){var M=r&&m[d]-l-r[d]<=0;M?(B("m = 1 / ("+F([d,a-l+m[d]-1])+" - "+F([d,a-1])+");"),_&&(B("a = ("+T(d)+" - "+F([d,a-1])+") * m;"),B("b = 1 - a;"))):(B("a = ("+T(d)+" - "+F([d,a-1])+") / ("+F([d,a-l+m[d]-1])+" - "+F([d,a-1])+");"),B("b = 1 - a;")),_&&ce(u,(function(e){var t=e.slice(),i=e.slice();t[d]=a,i[d]=a-1,M&&_&&B("h = "+z(t)+";"),B(z(t)+" = b * "+z(i)+" + a * "+z(t)+";")})),ce(u,(function(e){var t,i,n,o=e.slice(),r=e.slice();if(o[d]=a,r[d]=a-1,M){var u=l+1;if(s)t=_?"h * "+z(r)+" / "+z(o)+" * ":"",i=R(o)+(_?" / h":""),n=R(r)+(_?" / "+z(r):""),B(R(o)+" = "+u+" * "+t+"("+i+" - "+n+") * m;");else{var c=o.slice(),g=r.slice();for(h=0;h<v;h++)c[p]=g[p]=h,t=_?"h * "+z(r)+" / "+z(o)+" * ":"",i=R(c)+(_?" / h":""),n=R(g)+(_?" / "+z(r):""),B(R(c)+" = "+u+" * "+t+"("+i+" - "+n+") * m;")}}else if(s)B(R(o)+" = b * "+R(r)+" + a * "+R(o)+";");else for(h=0;h<v;h++)o[p]=r[p]=h,B(R(o)+" = b * "+R(r)+" + a * "+R(o)+";")})),X("\n")}if(n&&B(_?"\n // Project back from homogeneous coordinates and return final output\n":"\n // Return final output\n"),s)B(_?"return "+R(m)+" / "+z(m)+";":"return "+R(m)+";");else for(d=0;d<v;d++)B(_?"out["+d+"] = "+R(m.concat([d]))+" / "+z(m)+";":"out["+d+"] = "+R(m.concat([d]))+";");if(s||B("return out;"),O.push("}"),n){var G=O.join("\n");C(G),be[e]=G}var W=new Function([O.join("\n"),"; return ",S].join(""))();return _e[e]=W,W.bind(t)};f().add("evaluator","lib/nurbs/src/evaluator",ve);const we=ve;var ye={};const Ne=function(e,t,i,n){var o,s,r,l,a,u,h,d,c=ye[e];if(c)return c.bind(t);var p=[],g="transform"+e;p.push("function "+g+"(m) {"),p.push("var i, w;"),p.push(ge(t,"x","this.points",t.points));var m=te(n?"size":"s");for(o=0;o<t.splineDimension;o++)p.push("var "+m(o)+" = "+fe(t.points,"this.points",o)+";");for(l=[],o=0;o<t.splineDimension;o++)r="i"+o,l.push(r),p.push("for ("+r+" = "+m(o)+"- 1; "+r+" >= 0; "+r+"--) {");for(o=0;o<t.dimension;o++)p.push("x"+o+" = "+i.point(l.concat([o])));for(a=[],o=0;o<t.dimension;o++)a.push("m["+((t.dimension+1)*(o+1)-1)+"] * x"+o);for(a.push("m["+((t.dimension+1)*(t.dimension+1)-1)+"]"),p.push("var w = ("+a.join(" + ")+") || 1.0;"),o=0;o<t.dimension;o++){for(a=[],u=t.dimension,s=0;s<u;s++)a.push("m["+(s*(u+1)+o)+"] * x"+s);a.push("m["+(s*(u+1)+o)+"]"),d=i.point(l.concat([o])),h="("+a.join(" + ")+") / w",p.push(d+" = "+h+";")}for(o=t.splineDimension-1;o>=0;o--)p.push("}");p.push("return this;"),p.push("}");var f=new Function([p.join("\n"),"; return ",g].join(""))();return n&&console.log(p.join("\n")),ye[e]=f,f.bind(t)};f().add("transform","lib/nurbs/src/transform",Ne);const Ce=Ne;var Oe={};const Se=function(e,t,i,n,o){var s=Oe[e];if(s)return s.bind(t);var r,l,a,u=t.degree,h=t.knots,d=t.splineDimension,c=t.boundary,p=[],g="support"+e,m=i.knot,f=te("t"),_=n?"domain":"d",b=te(n?"size":"s"),v=te(n?"knotIndex":"i"),w=!0;for(a=0;a<d;a++)Y(h)&&Y(h[a])&&(w=!1);function y(e){p.push(" "+(e||""))}var N=[];for(r=0;r<d;r++)N.push(f([r]));p.push("function "+g+" (out, "+N.join(", ")+") {");var C=0;function O(e,t){y(void 0===t?"out["+C+++"] = "+e.join(" + ")+";":"out["+C+++"] = ("+e.join(" + ")+" + "+t+") % "+t+";")}for(y("var h, m;"),y("var c = 0;"),o&&(y("var "+_+" = this.domain;"),y("for (var i = 0; i < this.splineDimension; i++) {"),y(" a = arguments[i + 1];"),y(" if (a < "+_+"[i][0] || a > "+_+"[i][1] || a === undefined || isNaN(a)) {"),y(' throw new Error("Invalid Spline parameter in dimension "+i+". Valid domain is ["+'+_+'[i][0]+", "+'+_+'[i][1]+"]. but got t"+i+" = "+arguments[i + 1]+".");'),y(" }"),y("}")),a=0;a<d;a++)y("var "+b(a)+" = "+fe(t.points,"this.points",a)+";");w||p.push(ge(t,"k","this.knots",h));var S=[];for(a=0;a<d;a++)switch(Z(h)){case Z.NDARRAY:S[a]=!0;break;case Z.ARRAY_OF_ARRAYS:S[a]=Y(h[a])}for(a=0;a<d;a++)S[a]?(y("var "+v(a)+" = 0;"),y("h = "+b(a)+";"),y("while(h > "+v(a)+" + 1) {"),y(" m = 0.5 * (h + "+v(a)+") | 0;"),y(" if ("+m([a,"m"])+" > "+f(a)+") h = m;"),y(" else "+v(a)+" = m;"),y("}")):"closed"===c[a]?y(v(a)+" = ("+f(a)+" | 0) % "+b(a)+";"):(y(v(a)+" = ("+f(a)+" | 0);"),y("if ("+v(a)+" < "+u[a]+") "+v(a)+" = "+u[a]+";"),y("if ("+v(a)+" > "+b(a)+" - 1) "+v(a)+" = "+b(a)+" - 1;"));for(a=0,l=[];a<d;a++)l[a]=u[a]+1;ce(l,(function(e){for(var t=[],i=[],n=0;n<d;n++)t[n]=[v(n),e[n]-u[n]],"closed"===c[n]&&e[n]-u[n]<0&&(i[n]=b(n));for(n=0;n<d;n++)O(t[n],i[n])})),y("out.length = "+C+";"),y("return out;"),p.push("}"),n&&console.log(p.join("\n"));var P=new Function([p.join("\n"),"; return ",g].join(""))();return Oe[e]=P,P.bind(t)};f().add("support","lib/nurbs/src/support",Se);const Pe=Se;var De=[];const Ie=function(e,t,i){i=i||{};var n=(e=e||{}).points=e.points||[],o=e.faces=e.faces||[],s=i.haveWeights,r=t.dimension-s;if(Array.isArray(i.resolution))var l=i.resolution;else{var a=void 0===i.resolution?31:i.resolution;l=new Array(t.splineDimension).fill(a)}switch(t.splineDimension){case 1:for(var u=(f=(b=l[0])+!(w="closed"===t.boundary[0]))*r,h=(N=(_=i.domain||t.domain)[0])[1]-N[0],d=0;d<f;++d){var c=N[0]+h*d/b,p=d*r;if(t.evaluate(De,c),s)for(var g=De[r],m=0;m<r;++m)n[p+m]=De[m]/g;else for(m=0;m<r;++m)n[p+m]=De[m]}n.length=u;break;case 2:var f,_,b=l[0],v=l[1],w="closed"===t.boundary[0],y=v+!(D="closed"===t.boundary[1]),N=(u=(f=b+!w)*y*r,(_=i.domain||t.domain)[0]),C=_[1],O=(h=N[1]-N[0],C[1]-C[0]);for(d=0;d<f;++d){c=N[0]+h*d/b;for(var S=0;S<y;++S){var P=C[0]+O*S/v;p=(d+f*S)*r;if(t.evaluate(De,c,P),s)for(g=De[r],m=0;m<r;++m)n[p+m]=De[m]/g;else for(m=0;m<r;++m)n[p+m]=De[m]}}n.length=u;w=i.closed[0];var D=i.closed[1],I=0;for(d=0;d<b;++d){var F=d,R=d+1;w&&(R%=b);for(S=0;S<v;++S){var z=S,V=S+1;D&&(V%=v),o[I++]=F+f*z,o[I++]=R+f*z,o[I++]=R+f*V,o[I++]=F+f*z,o[I++]=R+f*V,o[I++]=F+f*V}}o.length=I;break;default:throw new Error("Can only sample contours and surfaces")}return e};f().add("sample","lib/nurbs/extras/sample",Ie);const Fe=Ie;var Re={open:"open",closed:"closed",clamped:"clamped"};function ze(e){return null==e}function Ve(e,t,i,n,o,s){var r,l;!e||Y(e)||K(e)?(s=s||{},this.weights=n,this.knots=i,this.degree=t,this.points=e,this.boundary=o,this.debug=s.debug,this.checkBounds=!!s.checkBounds,Object.defineProperty(this,"size",{value:s.size,writable:!0,configurable:!0})):(s=e,this.debug=e.debug,this.checkBounds=!!e.checkBounds,this.weights=e.weights,this.knots=e.knots,this.degree=e.degree,this.boundary=e.boundary,this.points=e.points,Object.defineProperty(this,"size",{value:s.size,writable:!0,configurable:!0}));var a=Z(this.points),u=Z(this.weights),h=Z(this.knots);if(this.points)switch(a){case Z.GENERIC_NDARRAY:case Z.NDARRAY:Object.defineProperties(this,{splineDimension:{value:this.points.shape.length-1,writable:!1,configurable:!0},dimension:{value:this.points.shape[this.points.shape.length-1],writable:!1,configurable:!0},size:{get:function(){return this.points.shape.slice(0,this.points.shape.length-1)},set:function(){throw new Error("Cannot assign to read only property 'size'")},configurable:!0}});break;case Z.ARRAY_OF_OBJECTS:case Z.ARRAY_OF_ARRAYS:var d=0,c=this.size||[];c.length=0;for(var p=this.points;Y(p[0]);p=p[0])d++,c.push(p.length);if(0===d)throw new Error("Expected an array of points");Object.defineProperties(this,{splineDimension:{value:d,writable:!1,configurable:!0},dimension:{value:p.length,writable:!1,configurable:!0},size:{get:function(){var e=[];e.length=0;for(var t=0,i=this.points;t<this.splineDimension;t++,i=i[0])e[t]=i.length;return e},set:function(){throw new Error('Cannot assign to read only property "size"')},configurable:!0}});break;case Z.PACKED:default:throw new Error("Expected either a packed array, array of arrays, or ndarray of points")}else{if(void 0===this.size||null===this.size)throw new Error("Either points or a control hull size must be provided.");if(Y(this.size)||Object.defineProperty(this,"size",{value:[this.size],writable:!0,configurable:!0}),0===this.size.length)throw new Error("`size` must be a number or an array of length at least one.");Object.defineProperties(this,{splineDimension:{value:this.size.length,writable:!1,configurable:!0},dimension:{value:0,writable:!1,configurable:!0}})}if(Y(this.degree)){for(r=0;r<this.splineDimension;r++)if(ze(this.degree[r]))throw new Error("Missing degree in dimension "+(r+1))}else{var g=!ze(this.degree),m=ze(this.degree)?2:this.degree;for(this.degree=[],r=0;r<this.splineDimension;r++)if(this.size[r]<=m){if(g)throw new Error("Expected at least "+(m+1)+" points for degree "+m+" spline in dimension "+(r+1)+" but got only "+this.size[r]);this.degree[r]=this.size[r]-1}else this.degree[r]=m}if(l="string"!=typeof this.boundary?"open":this.boundary,!Re[l])throw new Error("Boundary type must be one of "+Object.keys(Re)+". Got "+l);for(this.boundary=Y(this.boundary)?this.boundary:[],this.boundary.length=this.splineDimension,r=0;r<this.splineDimension;r++)if(this.boundary[r]=ze(this.boundary[r])?l:this.boundary[r],!Re[l])throw new Error("Boundary type must be one of "+Object.keys(Re)+". Got "+l+" for dimension "+(r+1));switch(h){case Z.ARRAY_OF_ARRAYS:for(Y(this.knots)&&this.knots.length>0&&!Y(this.knots[0])&&(this.knots=[this.knots]),r=0;r<this.splineDimension;r++){if(this.size[r]<=this.degree[r])throw new Error("Expected at least "+(this.degree[r]+1)+" points in dimension "+(r+1)+" but got "+this.size[r]+".");if(Y(this.knots[r])){if("closed"!==this.boundary[r]&&this.knots[r].length!==this.degree[r]+this.size[r]+1)throw new Error("Expected "+(this.degree[r]+this.size[r]+1)+" knots in dimension "+(r+1)+" but got "+this.knots[r].length+".");if("closed"===this.boundary[r]&&this.knots[r].length!==this.size[r]+1&&!(this.knots[r].length===this.size[r]+this.degree[r]+1))throw new Error("Expected "+(this.size[r]+1)+" knots for closed spline in dimension "+(r+1)+" but got "+this.knots[r].length+".")}}case Z.NDARRAY:}var f=Q(this,this.debug,this.checkBounds,a,u,h);if(f!==this.__cacheKey){this.__cacheKey=f;var _=re(this);this.evaluate=we(this.__cacheKey,this,_,this.debug,this.checkBounds,!1),this.transform=Ce(this.__cacheKey,this,_,this.debug),this.support=Pe(this.__cacheKey,this,_,this.debug,this.checkBounds),this.evaluator=function(e,t){return we(this.__cacheKey,this,_,this.debug,this.checkBounds,t,e)}}return this.numericalDerivative=he.bind(this),this}function Te(){var e,t=[],i=this.points;i?G(i)&&(e=i.shape):e=this.size;for(var n=0;n<this.splineDimension;n++){var o=e?e[n]:i.length,s=this.degree[n],r="closed"===this.boundary[n];if(this.knots&&this.knots[n]){var l=this.knots[n];t[n]=[l[r?0:s],l[o]]}else t[n]=[r?0:s,o];i&&(i=i[0])}return t}function je(e,t,i,n,o,s){var r=function(e,t,i,n,o,s){return l(e,t,i,n,o,s),r},l=Ve.bind(r);return Object.defineProperty(r,"domain",{get:Te}),l(e,t,i,n,o,s),r}je.sample=Fe;const xe=je;f().add("nurbs","lib/nurbs/nurbs",xe);const ke=xe;function Ae(e){X.call(this,e),U().call(this,e),this.addType(c().NurbsCurve),this.knots=[],this.weights=[],this.controlPoints=[],this.mesh={},this.sampleOptions={resolution:[]}}Object.assign(Object.setPrototypeOf(Ae.prototype,X.prototype),U().prototype,{initialize(){X.prototype.initialize.call(this),this._controlPoint.addInterest("set_controlPoint__",this),this.set_controlPoint__()},set_controlPoint__(){this.controlPointNode&&this.controlPointNode.removeInterest("requestRebuild",this),this.controlPointNode=g()(c().X3DCoordinateNode,this._controlPoint),this.controlPointNode&&this.controlPointNode.addInterest("requestRebuild",this)},getTessellation(e){return k.getTessellation(this._tessellation.getValue(),e-this._order.getValue())},getClosed(e,t,i,n){return!!this._closed.getValue()&&k.getClosed(e,t,i,n)},getWeights:(e,t,i)=>k.getWeights(e,t,i),getControlPoints:(e,t,i,n,o)=>k.getControlPoints(e,t,i,n,o),tessellate(){if(this._order.getValue()<2)return[];if(!this.controlPointNode)return[];if(this.controlPointNode.getSize()<this._order.getValue())return[];const e=this.getVertices(),t=[];if(e.length){const i=e.length;for(let n=0;n<i;n+=8)t.push(e[n],e[n+1],e[n+2]);t.push(e[i-4],e[i-3],e[i-2])}return t},build(){if(this._order.getValue()<2)return;if(!this.controlPointNode)return;if(this.controlPointNode.getSize()<this._order.getValue())return;const e=this.getClosed(this._order.getValue(),this._knot,this._weight,this.controlPointNode),t=this.getWeights(this.weights,this.controlPointNode.getSize(),this._weight),i=this.getControlPoints(this.controlPoints,e,this._order.getValue(),t,this.controlPointNode),n=this.getKnots(this.knots,e,this._order.getValue(),this.controlPointNode.getSize(),this._knot),o=(n.at(-1),n[0],this._order.getValue()-1),s=this.surface=(this.surface||ke)({boundary:["open"],degree:[o],knots:[n],points:i,debug:!1});this.sampleOptions.resolution[0]=this.getTessellation(n.length),this.sampleOptions.haveWeights=!!t;const r=ke.sample(this.mesh,s,this.sampleOptions).points,l=this.getVertices();for(let e=3,t=r.length;e<t;e+=3){const t=e-3;l.push(r[t],r[t+1],r[t+2],1),l.push(r[e],r[e+1],r[e+2],1)}},dispose(){X.prototype.dispose.call(this)}}),Object.defineProperties(Ae,{typeName:{value:"NurbsCurve",enumerable:!0},componentInfo:{value:Object.freeze({name:"NURBS",level:1}),enumerable:!0},containerField:{value:"geometry",enumerable:!0},specificationRange:{value:Object.freeze({from:"3.0",to:"Infinity"}),enumerable:!0},fieldDefinitions:{value:new(a())([new(r())(c().inputOutput,"metadata",new(o().SFNode)),new(r())(c().inputOutput,"tessellation",new(o().SFInt32)),new(r())(c().initializeOnly,"closed",new(o().SFBool)),new(r())(c().initializeOnly,"order",new(o().SFInt32)(3)),new(r())(c().initializeOnly,"knot",new(o().MFDouble)),new(r())(c().inputOutput,"weight",new(o().MFDouble)),new(r())(c().inputOutput,"controlPoint",new(o().SFNode))]),enumerable:!0}});const Be=Ae;f().add("NurbsCurve","x_ite/Components/NURBS/NurbsCurve",Be);const Xe=Be;function Ee(e){C.call(this,e),this.addType(c().NurbsCurve2D),this.knots=[],this.weights=[],this.controlPoints=[],this.mesh={},this.sampleOptions={resolution:[]},this.array=[]}Object.assign(Object.setPrototypeOf(Ee.prototype,C.prototype),{getTessellation(e){return k.getTessellation(this._tessellation.getValue(),e-this._order.getValue())},getClosed(e,t,i,n){return!!this._closed.getValue()&&k.getClosed2D(e,t,i,n)},getKnots:(e,t,i,n,o)=>k.getKnots(e,t,i,n,o),getWeights:(e,t,i)=>k.getWeights(e,t,i),getControlPoints:(e,t,i,n,o)=>k.getControlPoints2D(e,t,i,n,o),tessellate(e){const t=this.array;if(t.length=0,this._order.getValue()<2)return t;if(this._controlPoint.length<this._order.getValue())return t;const i=this.getClosed(this._order.getValue(),this._knot,this._weight,this._controlPoint),n=this.getWeights(this.weights,this._controlPoint.length,this._weight),o=this.getControlPoints(this.controlPoints,i,this._order.getValue(),n,this._controlPoint),s=this.getKnots(this.knots,i,this._order.getValue(),this._controlPoint.length,this._knot),r=(s.at(-1),s[0],this._order.getValue()-1),l=this.surface=(this.surface||ke)({boundary:["open"],degree:[r],knots:[s],points:o,debug:!1});this.sampleOptions.resolution[0]=this.getTessellation(s.length),this.sampleOptions.haveWeights=!!n;const a=ke.sample(this.mesh,l,this.sampleOptions).points;switch(e){case 0:for(let e=0,i=a.length;e<i;e+=2)t.push(a[e],a[e+1]);break;case 1:for(let e=0,i=a.length;e<i;e+=2)t.push(a[e],0,a[e+1]);break;case 2:for(let e=0,i=a.length;e<i;e+=2)t.push(new(S())(a[e],a[e+1],0))}return t}}),Object.defineProperties(Ee,{typeName:{value:"NurbsCurve2D",enumerable:!0},componentInfo:{value:Object.freeze({name:"NURBS",level:3}),enumerable:!0},containerField:{value:"children",enumerable:!0},specificationRange:{value:Object.freeze({from:"3.0",to:"Infinity"}),enumerable:!0},fieldDefinitions:{value:new(a())([new(r())(c().inputOutput,"metadata",new(o().SFNode)),new(r())(c().inputOutput,"tessellation",new(o().SFInt32)),new(r())(c().initializeOnly,"closed",new(o().SFBool)),new(r())(c().initializeOnly,"order",new(o().SFInt32)(3)),new(r())(c().initializeOnly,"knot",new(o().MFDouble)),new(r())(c().inputOutput,"weight",new(o().MFDouble)),new(r())(c().inputOutput,"controlPoint",new(o().MFVec2d))]),enumerable:!0}});const Ue=Ee;f().add("NurbsCurve2D","x_ite/Components/NURBS/NurbsCurve2D",Ue);const qe=Ue,Ke=window[Symbol.for("X_ITE.X3D-9.6.1")].require("x_ite/Components/Core/X3DChildNode");var Me=e.n(Ke);const Ge=window[Symbol.for("X_ITE.X3D-9.6.1")].require("x_ite/Components/Interpolation/OrientationInterpolator");var We=e.n(Ge);const Ye=window[Symbol.for("X_ITE.X3D-9.6.1")].require("standard/Math/Numbers/Rotation4");var Je=e.n(Ye);function Le(e){Me().call(this,e),this.addType(c().NurbsOrientationInterpolator),this.addChildObjects(c().inputOutput,"rebuild",new(o().SFTime)),this.interpolator=new(We())(e),this.knots=[],this.weights=[],this.controlPoints=[],this.mesh={},this.sampleOptions={resolution:[128]}}Object.assign(Object.setPrototypeOf(Le.prototype,Me().prototype),{initialize(){Me().prototype.initialize.call(this),this._order.addInterest("requestRebuild",this),this._knot.addInterest("requestRebuild",this),this._weight.addInterest("requestRebuild",this),this._controlPoint.addInterest("set_controlPoint__",this),this._rebuild.addInterest("build",this),this._set_fraction.addFieldInterest(this.interpolator._set_fraction),this.interpolator._value_changed.addFieldInterest(this._value_changed),this.interpolator.setup(),this.set_controlPoint__()},set_controlPoint__(){this.controlPointNode&&this.controlPointNode.removeInterest("requestRebuild",this),this.controlPointNode=g()(c().X3DCoordinateNode,this._controlPoint),this.controlPointNode&&this.controlPointNode.addInterest("requestRebuild",this),this.requestRebuild()},getClosed:(e,t,i,n)=>!1,getKnots:(e,t,i,n,o)=>k.getKnots(e,t,i,n,o),getWeights:(e,t,i)=>k.getWeights(e,t,i),getControlPoints:(e,t,i,n,o)=>k.getControlPoints(e,t,i,n,o),requestRebuild(){this._rebuild.addEvent()},build(){if(this._order.getValue()<2)return;if(!this.controlPointNode)return;if(this.controlPointNode.getSize()<this._order.getValue())return;const e=this.getClosed(this._order.getValue(),this._knot,this._weight,this.controlPointNode),t=this.getWeights(this.weights,this.controlPointNode.getSize(),this._weight),i=this.getControlPoints(this.controlPoints,e,this._order.getValue(),t,this.controlPointNode),n=this.getKnots(this.knots,e,this._order.getValue(),this.controlPointNode.getSize(),this._knot),o=n.at(-1)-n[0],s=this._order.getValue()-1,r=this.surface=(this.surface||ke)({boundary:["open"],degree:[s],knots:[n],points:i,debug:!1});this.sampleOptions.haveWeights=!!t;const l=ke.sample(this.mesh,r,this.sampleOptions).points,a=this.interpolator;a._key.length=0,a._keyValue.length=0;for(let t=0,i=l.length-3;t<i;t+=3){const s=new(S())(l[t+3]-l[t+0],l[t+4]-l[t+1],l[t+5]-l[t+2]);a._key.push(n[0]+t/(i-3+3*e)*o),a._keyValue.push(new(Je())(S().zAxis,s))}e&&(a._key.push(n[0]+o),a._keyValue.push(a._keyValue[0]))}}),Object.defineProperties(Le,{typeName:{value:"NurbsOrientationInterpolator",enumerable:!0},componentInfo:{value:Object.freeze({name:"NURBS",level:1}),enumerable:!0},containerField:{value:"children",enumerable:!0},specificationRange:{value:Object.freeze({from:"3.0",to:"Infinity"}),enumerable:!0},fieldDefinitions:{value:new(a())([new(r())(c().inputOutput,"metadata",new(o().SFNode)),new(r())(c().inputOnly,"set_fraction",new(o().SFFloat)),new(r())(c().inputOutput,"order",new(o().SFInt32)(3)),new(r())(c().inputOutput,"knot",new(o().MFDouble)),new(r())(c().inputOutput,"weight",new(o().MFDouble)),new(r())(c().inputOutput,"controlPoint",new(o().SFNode)),new(r())(c().outputOnly,"value_changed",new(o().SFRotation))]),enumerable:!0}});const Ze=Le;f().add("NurbsOrientationInterpolator","x_ite/Components/NURBS/NurbsOrientationInterpolator",Ze);const He=Ze,Qe=window[Symbol.for("X_ITE.X3D-9.6.1")].require("standard/Math/Algorithm");var $e=e.n(Qe);const et=window[Symbol.for("X_ITE.X3D-9.6.1")].require("standard/Math/Geometry/Triangle3");var tt=e.n(et);function it(e){X.call(this,e),this.addType(c().X3DNurbsSurfaceGeometryNode),this.tessellationScale=1,this.uKnots=[],this.vKnots=[],this.weights=[],this.controlPoints=[],this.mesh={},this.sampleOptions={resolution:[],closed:[]},this.textUKnots=[],this.textVKnots=[],this.textWeights=[],this.texControlPoints=[],this.texMesh={}}Object.assign(Object.setPrototypeOf(it.prototype,X.prototype),{initialize(){X.prototype.initialize.call(this),this._texCoord.addInterest("set_texCoord__",this),this._controlPoint.addInterest("set_controlPoint__",this),this.set_texCoord__(),this.set_controlPoint__()},set_texCoord__(){this.texCoordNode?.removeInterest("requestRebuild",this),this.nurbsTexCoordNode?.removeInterest("requestRebuild",this),this.texCoordNode=g()(c().X3DTextureCoordinateNode,this._texCoord),this.nurbsTexCoordNode=g()(c().NurbsTextureCoordinate,this._texCoord),this.texCoordNode?.addInterest("requestRebuild",this),this.nurbsTexCoordNode?.addInterest("requestRebuild",this)},set_controlPoint__(){this.controlPointNode&&this.controlPointNode.removeInterest("requestRebuild",this),this.controlPointNode=g()(c().X3DCoordinateNode,this._controlPoint),this.controlPointNode&&this.controlPointNode.addInterest("requestRebuild",this)},setTessellationScale(e){this.tessellationScale=e,this.requestRebuild()},getUTessellation(e){return Math.floor(k.getTessellation(this._uTessellation.getValue(),e-this._uOrder.getValue())*this.tessellationScale)},getVTessellation(e){return Math.floor(k.getTessellation(this._vTessellation.getValue(),e-this._vOrder.getValue())*this.tessellationScale)},getUClosed(e,t,i,n,o,s){return!!this._uClosed.getValue()&&k.getUClosed(e,t,i,n,o,s)},getVClosed(e,t,i,n,o,s){return!!this._vClosed.getValue()&&k.getVClosed(e,t,i,n,o,s)},getUVWeights:(e,t,i,n)=>k.getUVWeights(e,t,i,n),getTexControlPoints:(e,t,i,n,o,s,r,l)=>k.getTexControlPoints(e,t,i,n,o,s,r,l),getUVControlPoints:(e,t,i,n,o,s,r,l,a)=>k.getUVControlPoints(e,t,i,n,o,s,r,l,a),getTrimmingContours(){},build(){if(this._uOrder.getValue()<2)return;if(this._vOrder.getValue()<2)return;if(this._uDimension.getValue()<this._uOrder.getValue())return;if(this._vDimension.getValue()<this._vOrder.getValue())return;if(!this.controlPointNode)return;if(this.controlPointNode.getSize()!==this._uDimension.getValue()*this._vDimension.getValue())return;const e=this.getUClosed(this._uOrder.getValue(),this._uDimension.getValue(),this._vDimension.getValue(),this._uKnot,this._weight,this.controlPointNode),t=this.getVClosed(this._vOrder.getValue(),this._uDimension.getValue(),this._vDimension.getValue(),this._vKnot,this._weight,this.controlPointNode),i=this.getUVWeights(this.weights,this._uDimension.getValue(),this._vDimension.getValue(),this._weight),n=this.getUVControlPoints(this.controlPoints,e,t,this._uOrder.getValue(),this._vOrder.getValue(),this._uDimension.getValue(),this._vDimension.getValue(),i,this.controlPointNode),o=this.getKnots(this.uKnots,e,this._uOrder.getValue(),this._uDimension.getValue(),this._uKnot),s=this.getKnots(this.vKnots,t,this._vOrder.getValue(),this._vDimension.getValue(),this._vKnot),r=(o.at(-1),o[0],s.at(-1),s[0],this._uOrder.getValue()-1),l=this._vOrder.getValue()-1,a=this.surface=(this.surface||ke)({boundary:["open","open"],degree:[r,l],knots:[o,s],points:n,debug:!1}),u=this.sampleOptions;u.resolution[0]=this.getUTessellation(o.length),u.resolution[1]=this.getVTessellation(s.length),u.closed[0]=e,u.closed[1]=t,u.domain=void 0,u.haveWeights=!!i,u.trimmingContours=this.getTrimmingContours();const h=ke.sample(this.mesh,a,u),d=h.faces,c=h.points,p=this.getVertices();for(let e=0,t=d.length;e<t;++e){const t=3*d[e];p.push(c[t],c[t+1],c[t+2],1)}this.buildNurbsTexCoords(e,t,this._uOrder.getValue(),this._vOrder.getValue(),o,s,this._uDimension.getValue(),this._vDimension.getValue(),a.domain),this.buildNormals(d,c),this.setSolid(this._solid.getValue()),this.setCCW(!0)},buildNurbsTexCoords:(()=>{const e=[],t=[],i=[[[0,0,0,1],[0,1,0,1]],[[1,0,0,1],[1,1,0,1]]];function n(e,t){return e[0]=e[1]=t[0],e[2]=e[3]=t.at(-1),e}return function(o,s,r,l,a,u,h,d,c){const p=this.sampleOptions;if(this.texCoordNode&&this.texCoordNode.getSize()===h*d)var g=r-1,m=l-1,f=a,_=u,b=this.getTexControlPoints(this.texControlPoints,o,s,r,l,h,d,this.texCoordNode);else if(this.nurbsTexCoordNode&&this.nurbsTexCoordNode.isValid()){var v=this.nurbsTexCoordNode,w=(g=v._uOrder.getValue()-1,m=v._vOrder.getValue()-1,f=this.getKnots(this.texUKnots,!1,v._uOrder.getValue(),v._uDimension.getValue(),v._uKnot),_=this.getKnots(this.texVKnots,!1,v._vOrder.getValue(),v._vDimension.getValue(),v._vKnot),this.getUVWeights(this.texWeights,v._uDimension.getValue(),v._vDimension.getValue(),v._weight));b=v.getControlPoints(w)}else{g=1,m=1,f=n(e,a),_=n(t,u),b=i;p.domain=c}const y=this.texSurface=(this.texSurface||ke)({boundary:["open","open"],degree:[g,m],knots:[f,_],points:b});p.closed[0]=!1,p.closed[1]=!1,p.haveWeights=!1;const N=ke.sample(this.texMesh,y,p),C=N.faces,O=N.points,S=this.getTexCoords();for(let e=0,t=C.length;e<t;++e){const t=4*C[e];S.push(O[t],O[t+1],O[t+2],O[t+3])}this.getMultiTexCoords().push(this.getTexCoords())}})(),buildNormals(e,t){const i=this.createNormals(e,t),n=this.getNormals();for(const e of i)n.push(e.x,e.y,e.z)},createNormals(e,t){const i=new Map,n=this.createFaceNormals(e,t),o=e.length;for(let t=0;t<o;++t){const n=e[t];let o=i.get(n);o||i.set(n,o=[]),o.push(t)}return this.refineNormals(i,n,$e().radians(85))},createFaceNormals:(()=>{const e=new(S()),t=new(S()),i=new(S());return function(n,o){const s=this.faceNormals||[],r=n.length;for(let l=0;l<r;l+=3){const r=3*n[l],a=3*n[l+1],u=3*n[l+2];e.set(o[r],o[r+1],o[r+2]),t.set(o[a],o[a+1],o[a+2]),i.set(o[u],o[u+1],o[u+2]);const h=tt().normal(e,t,i,s[l]||new(S()));s[l]=h,s[l+1]=h,s[l+2]=h}return s.length=r,s}})()}),Object.defineProperties(it,{typeName:{value:"X3DNurbsSurfaceGeometryNode",enumerable:!0},componentInfo:{value:Object.freeze({name:"NURBS",level:1}),enumerable:!0}});const nt=it;f().add("X3DNurbsSurfaceGeometryNode","x_ite/Components/NURBS/X3DNurbsSurfaceGeometryNode",nt);const ot=nt;function st(e){ot.call(this,e),this.addType(c().NurbsPatchSurface)}Object.setPrototypeOf(st.prototype,ot.prototype),Object.defineProperties(st,{typeName:{value:"NurbsPatchSurface",enumerable:!0},componentInfo:{value:Object.freeze({name:"NURBS",level:1}),enumerable:!0},containerField:{value:"geometry",enumerable:!0},specificationRange:{value:Object.freeze({from:"3.0",to:"Infinity"}),enumerable:!0},fieldDefinitions:{value:new(a())([new(r())(c().inputOutput,"metadata",new(o().SFNode)),new(r())(c().inputOutput,"uTessellation",new(o().SFInt32)),new(r())(c().inputOutput,"vTessellation",new(o().SFInt32)),new(r())(c().initializeOnly,"solid",new(o().SFBool)(!0)),new(r())(c().initializeOnly,"uClosed",new(o().SFBool)),new(r())(c().initializeOnly,"vClosed",new(o().SFBool)),new(r())(c().initializeOnly,"uOrder",new(o().SFInt32)(3)),new(r())(c().initializeOnly,"vOrder",new(o().SFInt32)(3)),new(r())(c().initializeOnly,"uDimension",new(o().SFInt32)),new(r())(c().initializeOnly,"vDimension",new(o().SFInt32)),new(r())(c().initializeOnly,"uKnot",new(o().MFDouble)),new(r())(c().initializeOnly,"vKnot",new(o().MFDouble)),new(r())(c().inputOutput,"weight",new(o().MFDouble)),new(r())(c().inputOutput,"texCoord",new(o().SFNode)),new(r())(c().inputOutput,"controlPoint",new(o().SFNode))]),enumerable:!0}});const rt=st;f().add("NurbsPatchSurface","x_ite/Components/NURBS/NurbsPatchSurface",rt);const lt=rt,at=window[Symbol.for("X_ITE.X3D-9.6.1")].require("x_ite/Components/Interpolation/PositionInterpolator");var ut=e.n(at);function ht(e){Me().call(this,e),this.addType(c().NurbsPositionInterpolator),this.addChildObjects(c().inputOutput,"rebuild",new(o().SFTime)),this.interpolator=new(ut())(e),this.knots=[],this.weights=[],this.controlPoints=[],this.mesh={},this.sampleOptions={resolution:[128]}}Object.assign(Object.setPrototypeOf(ht.prototype,Me().prototype),{initialize(){Me().prototype.initialize.call(this),this._order.addInterest("requestRebuild",this),this._knot.addInterest("requestRebuild",this),this._weight.addInterest("requestRebuild",this),this._controlPoint.addInterest("set_controlPoint__",this),this._rebuild.addInterest("build",this),this._set_fraction.addFieldInterest(this.interpolator._set_fraction),this.interpolator._value_changed.addFieldInterest(this._value_changed),this.interpolator.setup(),this.set_controlPoint__()},set_controlPoint__(){this.controlPointNode&&this.controlPointNode.removeInterest("requestRebuild",this),this.controlPointNode=g()(c().X3DCoordinateNode,this._controlPoint),this.controlPointNode&&this.controlPointNode.addInterest("requestRebuild",this),this.requestRebuild()},getClosed:(e,t,i,n)=>!1,getKnots:(e,t,i,n,o)=>k.getKnots(e,t,i,n,o),getWeights:(e,t,i)=>k.getWeights(e,t,i),getControlPoints:(e,t,i,n,o)=>k.getControlPoints(e,t,i,n,o),requestRebuild(){this._rebuild.addEvent()},build(){if(this._order.getValue()<2)return;if(!this.controlPointNode)return;if(this.controlPointNode.getSize()<this._order.getValue())return;const e=this.getClosed(this._order.getValue(),this._knot,this._weight,this.controlPointNode),t=this.getWeights(this.weights,this.controlPointNode.getSize(),this._weight),i=this.getControlPoints(this.controlPoints,e,this._order.getValue(),t,this.controlPointNode),n=this.getKnots(this.knots,e,this._order.getValue(),this.controlPointNode.getSize(),this._knot),s=n.at(-1)-n[0],r=this._order.getValue()-1,l=this.surface=(this.surface||ke)({boundary:["open"],degree:[r],knots:[n],points:i,debug:!1});this.sampleOptions.haveWeights=!!t;const a=ke.sample(this.mesh,l,this.sampleOptions).points,u=this.interpolator;u._key.length=0,u._keyValue.length=0;for(let e=0,t=a.length;e<t;e+=3)u._key.push(n[0]+e/(t-3)*s),u._keyValue.push(new(o().SFVec3f)(a[e],a[e+1],a[e+2]))}}),Object.defineProperties(ht,{typeName:{value:"NurbsPositionInterpolator",enumerable:!0},componentInfo:{value:Object.freeze({name:"NURBS",level:1}),enumerable:!0},containerField:{value:"children",enumerable:!0},specificationRange:{value:Object.freeze({from:"3.0",to:"Infinity"}),enumerable:!0},fieldDefinitions:{value:new(a())([new(r())(c().inputOutput,"metadata",new(o().SFNode)),new(r())(c().inputOnly,"set_fraction",new(o().SFFloat)),new(r())(c().inputOutput,"order",new(o().SFInt32)(3)),new(r())(c().inputOutput,"knot",new(o().MFDouble)),new(r())(c().inputOutput,"weight",new(o().MFDouble)),new(r())(c().inputOutput,"controlPoint",new(o().SFNode)),new(r())(c().outputOnly,"value_changed",new(o().SFVec3f))]),enumerable:!0}});const dt=ht;f().add("NurbsPositionInterpolator","x_ite/Components/NURBS/NurbsPositionInterpolator",dt);const ct=dt,pt=window[Symbol.for("X_ITE.X3D-9.6.1")].require("x_ite/Components/Grouping/X3DBoundedObject");var gt=e.n(pt);function mt(e){Me().call(this,e),gt().call(this,e),this.addType(c().NurbsSet),this.geometryNodes=[]}function ft(e,t){const i=new Set(t);return e.filter((e=>!i.has(e)))}Object.assign(Object.setPrototypeOf(mt.prototype,Me().prototype),gt().prototype,{initialize(){Me().prototype.initialize.call(this),gt().prototype.initialize.call(this),this._tessellationScale.addInterest("set_tessellationScale__",this),this._addGeometry.addInterest("set_addGeometry__",this),this._removeGeometry.addInterest("set_removeGeometry__",this),this._geometry.addInterest("set_geometry__",this),this.set_geometry__()},getBBox(e,t){for(const t of this.geometryNodes)e.add(t.getBBox());return e},set_tessellationScale__(){const e=Math.max(0,this._tessellationScale.getValue());for(const t of this.geometryNodes)t.setTessellationScale(e)},set_addGeometry__(){this._addGeometry.setTainted(!0),this._addGeometry.assign(ft(this._addGeometry,this._geometry));for(const e of this._addGeometry)this._geometry.push(e);this._addGeometry.length=0,this._addGeometry.setTainted(!1)},set_removeGeometry__(){this._removeGeometry.setTainted(!0),this._geometry.assign(ft(this._geometry,this._removeGeometry)),this._removeGeometry.length=0,this._removeGeometry.setTainted(!1)},set_geometry__(){for(const e of this.geometryNodes)e.setTessellationScale(1);this.geometryNodes.length=0;for(const e of this._geometry){const t=g()(c().X3DNurbsSurfaceGeometryNode,e);t&&this.geometryNodes.push(t)}this.set_tessellationScale__()},dispose(){gt().prototype.dispose.call(this),Me().prototype.dispose.call(this)}}),Object.defineProperties(mt,{typeName:{value:"NurbsSet",enumerable:!0},componentInfo:{value:Object.freeze({name:"NURBS",level:2}),enumerable:!0},containerField:{value:"children",enumerable:!0},specificationRange:{value:Object.freeze({from:"3.0",to:"Infinity"}),enumerable:!0},fieldDefinitions:{value:new(a())([new(r())(c().inputOutput,"metadata",new(o().SFNode)),new(r())(c().inputOutput,"tessellationScale",new(o().SFFloat)(1)),new(r())(c().inputOutput,"visible",new(o().SFBool)(!0)),new(r())(c().inputOutput,"bboxDisplay",new(o().SFBool)),new(r())(c().initializeOnly,"bboxSize",new(o().SFVec3f)(-1,-1,-1)),new(r())(c().initializeOnly,"bboxCenter",new(o().SFVec3f)),new(r())(c().inputOnly,"addGeometry",new(o().MFNode)),new(r())(c().inputOnly,"removeGeometry",new(o().MFNode)),new(r())(c().inputOutput,"geometry",new(o().MFNode))]),enumerable:!0}});const _t=mt;f().add("NurbsSet","x_ite/Components/NURBS/NurbsSet",_t);const bt=_t,vt=window[Symbol.for("X_ITE.X3D-9.6.1")].require("standard/Math/Geometry/Line3");var wt=e.n(vt);const yt={isPointInTriangle(e,t,i,n){const o=(t.y-i.y)*(e.x-i.x)+(i.x-t.x)*(e.y-i.y);if(0==o)return!1;const s=((t.y-i.y)*(n.x-i.x)+(i.x-t.x)*(n.y-i.y))/o;if(s<0||s>1)return!1;const r=((i.y-e.y)*(n.x-i.x)+(e.x-i.x)*(n.y-i.y))/o;if(r<0||r>1)return!1;const l=1-s-r;return!(l<0||l>1)}};f().add("Triangle2","standard/Math/Geometry/Triangle2",yt);const Nt=yt;function Ct(e){Me().call(this,e),this.addType(c().NurbsSurfaceInterpolator),this.geometry=new lt(e)}Object.assign(Object.setPrototypeOf(Ct.prototype,Me().prototype),{initialize(){this._set_fraction.addInterest("set_fraction__",this),this._uOrder.addFieldInterest(this.geometry._uOrder),this._vOrder.addFieldInterest(this.geometry._vOrder),this._uDimension.addFieldInterest(this.geometry._uDimension),this._vDimension.addFieldInterest(this.geometry._vDimension),this._uKnot.addFieldInterest(this.geometry._uKnot),this._vKnot.addFieldInterest(this.geometry._vKnot),this._weight.addFieldInterest(this.geometry._weight),this._controlPoint.addFieldInterest(this.geometry._controlPoint),this.geometry._uTessellation=128,this.geometry._vTessellation=128,this.geometry._uOrder=this._uOrder,this.geometry._vOrder=this._vOrder,this.geometry._uDimension=this._uDimension,this.geometry._vDimension=this._vDimension,this.geometry._uKnot=this._uKnot,this.geometry._vKnot=this._vKnot,this.geometry._weight=this._weight,this.geometry._controlPoint=this._controlPoint,this.geometry.setup()},set_fraction__:(()=>{const e=new(S()),t=new(S()),i=new(S()),n=new(S()),o=new(wt())(S().Zero,S().zAxis),s={};return function(){const r=this._set_fraction.getValue(),l=this.geometry.getTexCoords(),a=this.geometry.getNormals(),u=this.geometry.getVertices();for(let h=0,d=0,c=l.length;h<c;h+=12,d+=9)if(e.set(l[h+0],l[h+1],0),t.set(l[h+4],l[h+5],0),i.set(l[h+7],l[h+9],0),Nt.isPointInTriangle(e,t,i,r)&&(o.set(n.set(r.x,r.y,0),S().zAxis),o.intersectsTriangle(e,t,i,s))){const e=s.u,t=s.v,i=s.t,n=new(S())(i*a[d+0]+e*a[d+3]+t*a[d+6],i*a[d+1]+e*a[d+4]+t*a[d+7],i*a[d+2]+e*a[d+5]+t*a[d+8]),o=new(S())(i*u[h+0]+e*u[h+4]+t*u[h+8],i*u[h+1]+e*u[h+5]+t*u[h+9],i*u[h+2]+e*u[h+6]+t*u[h+10]);this._normal_changed=n,this._position_changed=o}}})()}),Object.defineProperties(Ct,{typeName:{value:"NurbsSurfaceInterpolator",enumerable:!0},componentInfo:{value:Object.freeze({name:"NURBS",level:1}),enumerable:!0},containerField:{value:"children",enumerable:!0},specificationRange:{value:Object.freeze({from:"3.0",to:"Infinity"}),enumerable:!0},fieldDefinitions:{value:new(a())([new(r())(c().inputOutput,"metadata",new(o().SFNode)),new(r())(c().inputOnly,"set_fraction",new(o().SFVec2f)),new(r())(c().initializeOnly,"uOrder",new(o().SFInt32)(3)),new(r())(c().initializeOnly,"vOrder",new(o().SFInt32)(3)),new(r())(c().initializeOnly,"uDimension",new(o().SFInt32)),new(r())(c().initializeOnly,"vDimension",new(o().SFInt32)),new(r())(c().initializeOnly,"uKnot",new(o().MFDouble)),new(r())(c().initializeOnly,"vKnot",new(o().MFDouble)),new(r())(c().inputOutput,"weight",new(o().MFDouble)),new(r())(c().inputOutput,"controlPoint",new(o().SFNode)),new(r())(c().outputOnly,"normal_changed",new(o().SFVec3f)),new(r())(c().outputOnly,"position_changed",new(o().SFVec3f))]),enumerable:!0}});const Ot=Ct;f().add("NurbsSurfaceInterpolator","x_ite/Components/NURBS/NurbsSurfaceInterpolator",Ot);const St=Ot,Pt=window[Symbol.for("X_ITE.X3D-9.6.1")].require("x_ite/Components/Geometry3D/Extrusion");var Dt=e.n(Pt);function It(e){X.call(this,e),this.addType(c().NurbsSweptSurface),this.extrusion=new(Dt())(e)}Object.assign(Object.setPrototypeOf(It.prototype,X.prototype),{initialize(){X.prototype.initialize.call(this),this._crossSectionCurve.addInterest("set_crossSectionCurve__",this),this._trajectoryCurve.addInterest("set_trajectoryCurve__",this);const e=this.extrusion;e._beginCap=!1,e._endCap=!1,e._solid=!0,e._ccw=!0,e._convex=!0,e._creaseAngle=Math.PI,e.setup(),e._crossSection.setTainted(!0),e._spine.setTainted(!0),this.set_crossSectionCurve__(),this.set_trajectoryCurve__()},set_crossSectionCurve__(){this.crossSectionCurveNode&&this.crossSectionCurveNode.removeInterest("requestRebuild",this),this.crossSectionCurveNode=g()(c().X3DNurbsControlCurveNode,this._crossSectionCurve),this.crossSectionCurveNode&&this.crossSectionCurveNode.addInterest("requestRebuild",this)},set_trajectoryCurve__(){this.trajectoryCurveNode?._rebuild.removeInterest("requestRebuild",this),this.trajectoryCurveNode=g()(c().NurbsCurve,this._trajectoryCurve),this.trajectoryCurveNode?._rebuild.addInterest("requestRebuild",this)},build(){if(!this.crossSectionCurveNode)return;if(!this.trajectoryCurveNode)return;const e=this.extrusion;if(e._crossSection=this.crossSectionCurveNode.tessellate(0),e._spine=this.trajectoryCurveNode.tessellate(0),e.rebuild(),this.getColors().assign(e.getColors()),this.getTexCoords().assign(e.getTexCoords()),this.getNormals().assign(e.getNormals()),this.getVertices().assign(e.getVertices()),this.getMultiTexCoords().push(this.getTexCoords()),!this._ccw.getValue()){const e=this.getNormals();for(let t=0,i=e.length;t<i;++t)e[t]=-e[t]}this.setSolid(this._solid.getValue()),this.setCCW(this._ccw.getValue())}}),Object.defineProperties(It,{typeName:{value:"NurbsSweptSurface",enumerable:!0},componentInfo:{value:Object.freeze({name:"NURBS",level:3}),enumerable:!0},containerField:{value:"geometry",enumerable:!0},specificationRange:{value:Object.freeze({from:"3.0",to:"Infinity"}),enumerable:!0},fieldDefinitions:{value:new(a())([new(r())(c().inputOutput,"metadata",new(o().SFNode)),new(r())(c().initializeOnly,"solid",new(o().SFBool)(!0)),new(r())(c().initializeOnly,"ccw",new(o().SFBool)(!0)),new(r())(c().inputOutput,"crossSectionCurve",new(o().SFNode)),new(r())(c().inputOutput,"trajectoryCurve",new(o().SFNode))]),enumerable:!0}});const Ft=It;f().add("NurbsSweptSurface","x_ite/Components/NURBS/NurbsSweptSurface",Ft);const Rt=Ft;function zt(e){X.call(this,e),this.addType(c().NurbsSwungSurface),this.extrusion=new(Dt())(e)}Object.assign(Object.setPrototypeOf(zt.prototype,X.prototype),{initialize(){X.prototype.initialize.call(this),this._profileCurve.addInterest("set_profileCurve__",this),this._trajectoryCurve.addInterest("set_trajectoryCurve__",this);const e=this.extrusion;e._beginCap=!1,e._endCap=!1,e._solid=!0,e._ccw=!0,e._convex=!0,e._creaseAngle=Math.PI,e.setup(),e._crossSection.setTainted(!0),e._spine.setTainted(!0),this.set_profileCurve__(),this.set_trajectoryCurve__()},set_profileCurve__(){this.profileCurveNode&&this.profileCurveNode.removeInterest("requestRebuild",this),this.profileCurveNode=g()(c().X3DNurbsControlCurveNode,this._profileCurve),this.profileCurveNode&&this.profileCurveNode.addInterest("requestRebuild",this)},set_trajectoryCurve__(){this.trajectoryCurveNode&&this.trajectoryCurveNode.removeInterest("requestRebuild",this),this.trajectoryCurveNode=g()(c().X3DNurbsControlCurveNode,this._trajectoryCurve),this.trajectoryCurveNode&&this.trajectoryCurveNode.addInterest("requestRebuild",this)},build(){if(!this.profileCurveNode)return;if(!this.trajectoryCurveNode)return;const e=this.extrusion;if(e._crossSection=this.profileCurveNode.tessellate(0),e._spine=this.trajectoryCurveNode.tessellate(1),e.rebuild(),this.getColors().assign(e.getColors()),this.getTexCoords().assign(e.getTexCoords()),this.getNormals().assign(e.getNormals()),this.getVertices().assign(e.getVertices()),this.getMultiTexCoords().push(this.getTexCoords()),!this._ccw.getValue()){const e=this.getNormals();for(let t=0,i=e.length;t<i;++t)e[t]=-e[t]}this.setSolid(this._solid.getValue()),this.setCCW(this._ccw.getValue())}}),Object.defineProperties(zt,{typeName:{value:"NurbsSwungSurface",enumerable:!0},componentInfo:{value:Object.freeze({name:"NURBS",level:3}),enumerable:!0},containerField:{value:"geometry",enumerable:!0},specificationRange:{value:Object.freeze({from:"3.0",to:"Infinity"}),enumerable:!0},fieldDefinitions:{value:new(a())([new(r())(c().inputOutput,"metadata",new(o().SFNode)),new(r())(c().initializeOnly,"solid",new(o().SFBool)(!0)),new(r())(c().initializeOnly,"ccw",new(o().SFBool)(!0)),new(r())(c().inputOutput,"profileCurve",new(o().SFNode)),new(r())(c().inputOutput,"trajectoryCurve",new(o().SFNode))]),enumerable:!0}});const Vt=zt;f().add("NurbsSwungSurface","x_ite/Components/NURBS/NurbsSwungSurface",Vt);const Tt=Vt;function jt(e){h().call(this,e),this.addType(c().NurbsTextureCoordinate),this.controlPoints=[]}Object.assign(Object.setPrototypeOf(jt.prototype,h().prototype),{initialize(){h().prototype.initialize.call(this)},getControlPoints(e){const t=this._controlPoint.getValue(),i=this.controlPoints;for(let n=0,o=this._uDimension.getValue();n<o;++n){let s=i[n];s||(s=i[n]=[]);for(let i=0,r=this._vDimension.getValue();i<r;++i){const r=i*o+n,l=s[i]||new(j()),a=2*r;s[i]=l.set(t[a],t[a+1],0,e?e[r]:1)}}return i},isValid(){return!(this._uOrder.getValue()<2)&&(!(this._vOrder.getValue()<2)&&(!(this._uDimension.getValue()<this._uOrder.getValue())&&(!(this._vDimension.getValue()<this._vOrder.getValue())&&this._controlPoint.length===this._uDimension.getValue()*this._vDimension.getValue())))}}),Object.defineProperties(jt,{typeName:{value:"NurbsTextureCoordinate",enumerable:!0},componentInfo:{value:Object.freeze({name:"NURBS",level:1}),enumerable:!0},containerField:{value:"texCoord",enumerable:!0},specificationRange:{value:Object.freeze({from:"3.0",to:"Infinity"}),enumerable:!0},fieldDefinitions:{value:new(a())([new(r())(c().inputOutput,"metadata",new(o().SFNode)),new(r())(c().initializeOnly,"uOrder",new(o().SFInt32)(3)),new(r())(c().initializeOnly,"vOrder",new(o().SFInt32)(3)),new(r())(c().initializeOnly,"uDimension",new(o().SFInt32)),new(r())(c().initializeOnly,"vDimension",new(o().SFInt32)),new(r())(c().initializeOnly,"uKnot",new(o().MFDouble)),new(r())(c().initializeOnly,"vKnot",new(o().MFDouble)),new(r())(c().inputOutput,"weight",new(o().MFDouble)),new(r())(c().inputOutput,"controlPoint",new(o().MFVec2f))]),enumerable:!0}});const xt=jt;f().add("NurbsTextureCoordinate","x_ite/Components/NURBS/NurbsTextureCoordinate",xt);const kt=xt;function At(e){ot.call(this,e),this.addType(c().NurbsTrimmedSurface),this.trimmingContourNodes=[]}function Bt(e,t){const i=new Set(t);return e.filter((e=>!i.has(e)))}Object.assign(Object.setPrototypeOf(At.prototype,ot.prototype),{initialize(){ot.prototype.initialize.call(this),this._addTrimmingContour.addInterest("set_addTrimmingContour__",this),this._removeTrimmingContour.addInterest("set_removeTrimmingContour__",this),this._trimmingContour.addInterest("set_trimmingContour__",this),this.set_trimmingContour__()},set_addTrimmingContour__(){this._addTrimmingContour.setTainted(!0),this._addTrimmingContour.assign(Bt(this._addTrimmingContour,this._trimmingContour),this._addTrimmingContour.length);for(const e of this._addTrimmingContour)this._trimmingContour.push(e);this._addTrimmingContour.length=0,this._addTrimmingContour.setTainted(!1)},set_removeTrimmingContour__(){this._removeTrimmingContour.setTainted(!0),this._trimmingContour.assign(Bt(this._trimmingContour,this._removeTrimmingContour)),this._removeTrimmingContour.length=0,this._removeTrimmingContour.setTainted(!1)},set_trimmingContour__(){const e=this.trimmingContourNodes;e.length=0;for(const t of this._trimmingContour){const i=g()(c().Contour2D,t);i&&e.push(i)}},getTrimmingContours(){const e=this.trimmingContourNodes,t=[];for(const i of e)i.addTrimmingContour(t);return t}}),Object.defineProperties(At,{typeName:{value:"NurbsTrimmedSurface",enumerable:!0},componentInfo:{value:Object.freeze({name:"NURBS",level:4}),enumerable:!0},containerField:{value:"geometry",enumerable:!0},specificationRange:{value:Object.freeze({from:"3.0",to:"Infinity"}),enumerable:!0},fieldDefinitions:{value:new(a())([new(r())(c().inputOutput,"metadata",new(o().SFNode)),new(r())(c().inputOutput,"uTessellation",new(o().SFInt32)),new(r())(c().inputOutput,"vTessellation",new(o().SFInt32)),new(r())(c().initializeOnly,"solid",new(o().SFBool)(!0)),new(r())(c().initializeOnly,"uClosed",new(o().SFBool)),new(r())(c().initializeOnly,"vClosed",new(o().SFBool)),new(r())(c().initializeOnly,"uOrder",new(o().SFInt32)(3)),new(r())(c().initializeOnly,"vOrder",new(o().SFInt32)(3)),new(r())(c().initializeOnly,"uDimension",new(o().SFInt32)),new(r())(c().initializeOnly,"vDimension",new(o().SFInt32)),new(r())(c().initializeOnly,"uKnot",new(o().MFDouble)),new(r())(c().initializeOnly,"vKnot",new(o().MFDouble)),new(r())(c().inputOutput,"weight",new(o().MFDouble)),new(r())(c().inputOutput,"texCoord",new(o().SFNode)),new(r())(c().inputOutput,"controlPoint",new(o().SFNode)),new(r())(c().inputOnly,"addTrimmingContour",new(o().MFNode)),new(r())(c().inputOnly,"removeTrimmingContour",new(o().MFNode)),new(r())(c().inputOutput,"trimmingContour",new(o().MFNode))]),enumerable:!0}});const Xt=At;f().add("NurbsTrimmedSurface","x_ite/Components/NURBS/NurbsTrimmedSurface",Xt);const Et=Xt;i().add({name:"NURBS",concreteNodes:[w,I,Xe,qe,He,lt,ct,bt,St,Rt,Tt,kt,Et],abstractNodes:[C,ot,X]});const Ut=void 0;f().add("NURBS","assets/components/NURBS",Ut)})();
1
+ /* X_ITE v9.6.3 */(()=>{"use strict";var e={n:t=>{var i=t&&t.__esModule?()=>t.default:()=>t;return e.d(i,{a:i}),i},d:(t,i)=>{for(var n in i)e.o(i,n)&&!e.o(t,n)&&Object.defineProperty(t,n,{enumerable:!0,get:i[n]})},o:(e,t)=>Object.prototype.hasOwnProperty.call(e,t)};const t=window[Symbol.for("X_ITE.X3D-9.6.3")].require("x_ite/Components");var i=e.n(t);const n=window[Symbol.for("X_ITE.X3D-9.6.3")].require("x_ite/Fields");var o=e.n(n);const s=window[Symbol.for("X_ITE.X3D-9.6.3")].require("x_ite/Base/X3DFieldDefinition");var r=e.n(s);const l=window[Symbol.for("X_ITE.X3D-9.6.3")].require("x_ite/Base/FieldDefinitionArray");var a=e.n(l);const u=window[Symbol.for("X_ITE.X3D-9.6.3")].require("x_ite/Components/Core/X3DNode");var h=e.n(u);const d=window[Symbol.for("X_ITE.X3D-9.6.3")].require("x_ite/Base/X3DConstants");var c=e.n(d);const p=window[Symbol.for("X_ITE.X3D-9.6.3")].require("x_ite/Base/X3DCast");var g=e.n(p);const m=window[Symbol.for("X_ITE.X3D-9.6.3")].require("x_ite/Namespace");var f=e.n(m);function _(e){h().call(this,e),this.addType(c().Contour2D),this.childNodes=[]}function b(e,t){const i=new Set(t);return e.filter((e=>!i.has(e)))}Object.assign(Object.setPrototypeOf(_.prototype,h().prototype),{initialize(){h().prototype.initialize.call(this),this._addChildren.addInterest("set_addChildren__",this),this._removeChildren.addInterest("set_removeChildren__",this),this._children.addInterest("set_children__",this),this.set_children__()},set_addChildren__(){this._addChildren.setTainted(!0),this._addChildren.assign(b(this._addChildren,this._children));for(const e of this._addChildren)this._children.push(e);this._addChildren.length=0,this._addChildren.setTainted(!1)},set_removeChildren__(){this._removeChildren.setTainted(!0),this._children.assign(b(this._children,this._removeChildren)),this._removeChildren.length=0,this._removeChildren.setTainted(!1)},set_children__(){const e=this.childNodes;e.length=0;for(const t of this._children){const i=g()(c().NurbsCurve2D,t);if(i)e.push(i);else{const i=g()(c().ContourPolyline2D,t);if(i){e.push(i);continue}}}},addTrimmingContour(e){for(const t of this.childNodes)e.push(t.tessellate(2))}}),Object.defineProperties(_,{typeName:{value:"Contour2D",enumerable:!0},componentInfo:{value:Object.freeze({name:"NURBS",level:4}),enumerable:!0},containerField:{value:"trimmingContour",enumerable:!0},specificationRange:{value:Object.freeze({from:"3.0",to:"Infinity"}),enumerable:!0},fieldDefinitions:{value:new(a())([new(r())(c().inputOutput,"metadata",new(o().SFNode)),new(r())(c().inputOnly,"addChildren",new(o().MFNode)),new(r())(c().inputOnly,"removeChildren",new(o().MFNode)),new(r())(c().inputOutput,"children",new(o().MFNode))]),enumerable:!0}});const v=_;f().add("Contour2D","x_ite/Components/NURBS/Contour2D",v);const w=v;function y(e){h().call(this,e),this.addType(c().X3DNurbsControlCurveNode)}Object.setPrototypeOf(y.prototype,h().prototype),Object.defineProperties(y,{typeName:{value:"X3DNurbsControlCurveNode",enumerable:!0},componentInfo:{value:Object.freeze({name:"NURBS",level:1}),enumerable:!0}});const N=y;f().add("X3DNurbsControlCurveNode","x_ite/Components/NURBS/X3DNurbsControlCurveNode",N);const C=N,O=window[Symbol.for("X_ITE.X3D-9.6.3")].require("standard/Math/Numbers/Vector3");var S=e.n(O);function P(e){C.call(this,e),this.addType(c().ContourPolyline2D),this.controlPoints=[]}Object.assign(Object.setPrototypeOf(P.prototype,C.prototype),{tessellate(e){switch(e){case 0:{const e=this._controlPoint.getValue(),t=this.controlPoints,i=this._controlPoint.length;for(let n=0;n<i;++n){const i=2*n;t[i+0]=e[i+0],t[i+1]=e[i+1]}return t.length=2*i,t}case 1:{const e=this._controlPoint.getValue(),t=this.controlPoints,i=this._controlPoint.length;for(let n=0;n<i;++n){const i=2*n,o=3*n;t[o+0]=e[i+0],t[o+1]=0,t[o+2]=e[i+1]}return t.length=3*i,t}case 3:{const e=this._controlPoint.getValue(),t=this.controlPoints,i=this._controlPoint.length;for(let n=0;n<i;++n){const i=2*n;t[n]=new(S())(e[i+0],e[i+1],0)}return t.length=i,t}}}}),Object.defineProperties(P,{typeName:{value:"ContourPolyline2D",enumerable:!0},componentInfo:{value:Object.freeze({name:"NURBS",level:3}),enumerable:!0},containerField:{value:"children",enumerable:!0},specificationRange:{value:Object.freeze({from:"3.0",to:"Infinity"}),enumerable:!0},fieldDefinitions:{value:new(a())([new(r())(c().inputOutput,"metadata",new(o().SFNode)),new(r())(c().inputOutput,"controlPoint",new(o().MFVec2d))]),enumerable:!0}});const D=P;f().add("ContourPolyline2D","x_ite/Components/NURBS/ContourPolyline2D",D);const I=D,F=window[Symbol.for("X_ITE.X3D-9.6.3")].require("x_ite/Components/Rendering/X3DGeometryNode");var R=e.n(F);const z=window[Symbol.for("X_ITE.X3D-9.6.3")].require("standard/Math/Numbers/Vector2");var V=e.n(z);const T=window[Symbol.for("X_ITE.X3D-9.6.3")].require("standard/Math/Numbers/Vector4");var j=e.n(T);const x={getTessellation:(e,t)=>e>0?e+1:e<0?-e*t+1:2*t+1,getClosed2D(e,t,i,n){const o=n.length;return(!(i.length===o)||i[0]===i[o-1])&&(!!n[0].equals(n[o-1])&&!!this.isPeriodic(e,o,t))},getClosed:(()=>{const e=new(S()),t=new(S());return function(i,n,o,s){const r=s.getSize();return(!(o.length===r)||o[0]===o[r-1])&&(!!s.get1Point(0,e).equals(s.get1Point(r-1,t))&&!!this.isPeriodic(i,r,n))}})(),getUClosed:(()=>{const e=new(S()),t=new(S());return function(i,n,o,s,r,l){const a=r.length===l.getSize();for(let i=0,s=o;i<s;++i){const o=i*n,s=i*n+n-1;if(a&&r[o]!==r[s])return!1;if(!l.get1Point(o,e).equals(l.get1Point(s,t)))return!1}return!!this.isPeriodic(i,n,s)}})(),getVClosed:(()=>{const e=new(S()),t=new(S());return function(i,n,o,s,r,l){const a=r.length===l.getSize();for(let i=0,s=n;i<s;++i){const s=i,u=(o-1)*n+i;if(a&&r[s]!==r[u])return!1;if(!l.get1Point(s,e).equals(l.get1Point(u,t)))return!1}return!!this.isPeriodic(i,o,s)}})(),isPeriodic(e,t,i){if(i.length===t+e){{let t=1;for(let n=1,o=e;n<o;++n)t+=i[n]===i[0];if(t===e)return!1}{let t=1;for(let n=i.length-e,o=i.length-1;n<o;++n)t+=i[n]===i[o];if(t===e)return!1}}return!0},getKnots(e,t,i,n,o){const s=e||[];for(let e=0,t=o.length;e<t;++e)s[e]=o[e];s.length=o.length;let r=!0;if(s.length===n+i){r=!1;let e=0;for(let t=1,n=s.length;t<n;++t)s[t]==s[t-1]?++e:e=0,e>i-1&&(r=!0),s[t-1]>s[t]&&(r=!0)}if(r)for(let e=0,t=n+i;e<t;++e)s[e]=e/(t-1);if(t)for(let e=1,t=i-1;e<t;++e)s.push(s.at(-1)+(s[e]-s[e-1]));return s},getWeights(e,t,i){if(i.length!==t)return;const n=e||[];for(let e=0;e<t;++e)n[e]=i[e];return n.length=t,n},getUVWeights(e,t,i,n){const o=t*i;if(n.length!==o)return;const s=e||[];for(let e=0,o=0;e<t;++e)for(let e=0;e<i;++e,++o)s[o]=n[o];return s.length=o,s},getControlPoints2D(e,t,i,n,o){const s=e||[],r=o.getValue(),l=o.length,a=!!n,u=a?S():V();s.haveWeights!==a&&(s.haveWeights=a,s.length=0);for(let e=0;e<l;++e){const t=2*e,i=s[e]||new u(0,0,0);s[e]=i.set(r[t+0],r[t+1],a?n[e]:0)}if(s.length=l,t)for(let e=1,t=i-1;e<t;++e)s.push(s[e]);return s},getControlPoints(e,t,i,n,o){const s=e||[],r=o.getSize(),l=!!n,a=l?j():S();s.haveWeights!==l&&(s.haveWeights=l,s.length=0);for(let e=0;e<r;++e){const t=s[e]=o.get1Point(e,s[e]||new a(0,0,0,0));l&&(t.w=n[e])}if(s.length=r,t)for(let e=1,t=i-1;e<t;++e)s.push(s[e]);return s},getUVControlPoints(e,t,i,n,o,s,r,l,a){const u=e||[],h=!!l,d=h?j():S();u.haveWeights!==h&&(u.haveWeights=h,u.length=0);for(let e=0;e<s;++e){let t=u[e];t||(t=u[e]=[]);for(let i=0;i<r;++i){const n=i*s+e;t[i]=a.get1Point(n,t[i]||new d(0,0,0,0)),h&&(t[i].w=l[n])}if(t.length=r,i)for(let e=1,i=o-1;e<i;++e)t.push(t[e])}if(u.length=s,t)for(let e=1,t=n-1;e<t;++e)u.push(u[e]);return u},getTexControlPoints(e,t,i,n,o,s,r,l){const a=e||[];for(let e=0;e<s;++e){let t=a[e];t||(t=a[e]=[]);for(let i=0;i<r;++i){const n=i*s+e;t[i]=l.get1Point(n,t[i]||new(j()))}if(t.length=r,i)for(let e=1,i=o-1;e<i;++e)t.push(t[e])}if(a.length=s,t)for(let e=1,t=n-1;e<t;++e)a.push(a[e]);return a}};f().add("NURBS","x_ite/Browser/NURBS/NURBS",x);const k=x;function A(e){R().call(this,e),this.addType(c().X3DParametricGeometryNode)}Object.assign(Object.setPrototypeOf(A.prototype,R().prototype),{getKnots:(e,t,i,n,o)=>k.getKnots(e,t,i,n,o)}),Object.defineProperties(A,{typeName:{value:"X3DParametricGeometryNode",enumerable:!0},componentInfo:{value:Object.freeze({name:"NURBS",level:1}),enumerable:!0}});const B=A;f().add("X3DParametricGeometryNode","x_ite/Components/NURBS/X3DParametricGeometryNode",B);const X=B,E=window[Symbol.for("X_ITE.X3D-9.6.3")].require("x_ite/Components/Rendering/X3DLineGeometryNode");var U=e.n(E);const q=function(e){return!!e&&(!!e.dtype&&new RegExp("function View[0-9]+d(:?"+e.dtype+")+").test(String(e.constructor)))};f().add("is-ndarray","lib/nurbs/src/utils/is-ndarray",q);const K=q,M=function(e){return!!e&&(void 0!==e.data&&Array.isArray(e.shape)&&void 0!==e.offset&&void 0!==e.stride)};f().add("is-ndarray-like","lib/nurbs/src/utils/is-ndarray-like",M);const G=M,W=function(e){return Array.isArray(e)||ArrayBuffer.isView(e)||void 0!==e.length};f().add("is-array-like","lib/nurbs/src/utils/is-array-like",W);const Y=W;function J(e){if(e){if(K(e)||G(e))return"generic"===e.dtype?J.GENERIC_NDARRAY:J.NDARRAY;if(Y(e)){for(var t=e;Y(t[0]);t=t[0]);return"x"in t?J.ARRAY_OF_OBJECTS:J.ARRAY_OF_ARRAYS}throw new Error("Unhandled data type. Got type: "+typeof e)}}J.ARRAY_OF_OBJECTS="Obj",J.ARRAY_OF_ARRAYS="Arr",J.NDARRAY="Nd",J.GENERIC_NDARRAY="GenNd",J.PACKED="PackArr";const L=J;f().add("infer-type","lib/nurbs/src/utils/infer-type",L);const Z=L;const H=function(e,t,i,n,o,s){var r,l,a=[],u=!1;for(r=0;r<e.splineDimension;r++){var h=Y(e.knots)&&Y(e.knots[r]);h&&(u=!0),a.push("Deg"+e.degree[r]+(h?"":"Uniform")+((l=e.boundary[r])[0].toUpperCase()+l.slice(1)))}var d=[[u?"NU":"",e.weights?"RBS":"BS"].join("")+e.dimension+"D",a.join("_")];return n&&d.push(n+"Pts"),o&&d.push(o+"Wts"),s&&d.push(s+"Kts"),t&&d.push("debug"),i&&d.push("chk"),d.join("_")};f().add("cache-key","lib/nurbs/src/utils/cache-key",H);const Q=H;var $=function e(t,i){return function(i,n){void 0===i||Array.isArray(i)||(i=[i]);for(var o=[],s=0;s<i.length;s++)o.push(e.sum(i[s]));if(n)for(i=0;i<o.length;i++)void 0!==n[i]&&(o[i]="("+o[i]+" + "+n[i]+") % "+n[i]);return t+o.join("_")}};$.sum=function(e){return 0===(e=(e=Array.isArray(e)?e:[e]).filter((e=>void 0!==e&&0!==e))).length&&e.push(0),e.join(" + ")};const ee=$;f().add("variable","lib/nurbs/src/utils/variable",ee);const te=ee;var ie=[".x",".y",".z",".w"];function ne(e){return function(t,i){void 0===t||Array.isArray(t)||(t=[t]);for(var n=[],o=0;o<t.length;o++)n.push(te.sum(t[o]));if(i)for(t=0;t<n.length;t++)void 0!==i[t]&&(n[t]="("+n[t]+" + "+i[t]+") % "+i[t]);return e(n)}}function oe(e,t){if(t)switch(Z(t)){case Z.ARRAY_OF_OBJECTS:return ne((t=>{var i=t.pop();return e+"["+t.join("][")+"]"+ie[i]}));case Z.ARRAY_OF_ARRAYS:return ne((t=>e+"["+t.join("][")+"]"));case Z.GENERIC_NDARRAY:return ne((t=>e+".get("+t.join(",")+")"));case Z.NDARRAY:return ne((t=>{for(var i=[e+"Offset"],n=0;n<t.length;n++)i.push(e+"Stride"+n+" * ("+t[n]+")");return e+"["+i.join(" + ")+"]"}));case Z.PACKED:default:return}}const se=function(e){var t,i={};return(t=oe("x",e.points))&&(i.point=t),(t=oe("w",e.weights))&&(i.weight=t),(t=oe("k",e.knots))&&(i.knot=t),i};f().add("create-accessors","lib/nurbs/src/utils/create-accessors",se);const re=se;var le=[],ae=[];const ue=function(e,t,i){if(1!==t)throw new Error("Numerical derivative not implemented for order n = "+t+".");var n,o=void 0===arguments[this.splineDimension+3]?1e-4:arguments[this.splineDimension+3];for(le.length=this.splineDimension,n=0;n<this.splineDimension;n++)le[n+1]=arguments[n+3];var s,r,l,a=this.domain,u=a[i][0],h=a[i][1],d=le[i+1],c=(h-u)*o;for("closed"===this.boundary[i]?(s=u+(d-u-c+(l=h-u))%l,r=u+(d-u+c+l)%l,c*=2):(s=Math.min(h,Math.max(u,d-c)),c=(r=Math.min(h,Math.max(u,d+c)))-s),le[i+1]=s,le[0]=ae,this.evaluate.apply(null,le),le[i+1]=r,le[0]=e,this.evaluate.apply(null,le),n=0;n<this.dimension;n++)e[n]=(e[n]-ae[n])/c;return e};f().add("numerical-derivative","lib/nurbs/src/numerical-derivative",ue);const he=ue,de=function(e,t){for(var i=1,n=0,o=[];n<e.length;n++)i*=Array.isArray(e[n])?e[n][1]-e[n][0]:e[n],o[n]=Array.isArray(e[n])?e[n][0]:0;for(var s=0;s<i;s++)for(t(o.slice()),n=e.length-1;n>=0;n--){if(o[n]!==(Array.isArray(e[n])?e[n][1]:e[n])-1){o[n]++;break}o[n]=Array.isArray(e[n])?e[n][0]:0}};f().add("ndloop","lib/nurbs/src/utils/ndloop",de);const ce=de,pe=function(e,t,i,n){var o=[];switch(Z(n)){case Z.NDARRAY:o.push(" var "+t+" = "+i+".data;"),o.push(" var "+t+"Offset = "+i+".offset;");for(var s=0;s<n.dimension;s++)o.push(" var "+t+"Stride"+s+" = "+i+".stride["+s+"];");break;case Z.ARRAY_OF_OBJECTS:case Z.ARRAY_OF_ARRAYS:o.push(" var "+t+" = "+i+";")}return o.join("\n")};f().add("accessor-preamble","lib/nurbs/src/utils/accessor-preamble",pe);const ge=pe,me=function(e,t,i){if(e){if(G(e))return t+".shape["+i+"]";for(var n=t,o=0;o<i;o++)n+="[0]";return n+".length"}return"this.size["+i+"]"};f().add("size-getter","lib/nurbs/src/utils/size-getter",me);const fe=me;var _e={},be={};const ve=function(e,t,i,n,o,s,r){var l,a,u,h,d,c,p=t.splineDimension,g=t.points,m=t.degree,f=t.weights,_=void 0!==f,b=t.knots,v=t.dimension,w=t.boundary;if(null!=r){Array.isArray(r)||(r=[r]);var y=0;for(l=0;l<p;l++)void 0===r[l]&&(r[l]=0),y+=r[l];if(_&&y>1)throw new Error("Analytical derivative not implemented for rational b-splines with order n = "+y+".")}s&&(e="Basis"+e),r&&(e="Der"+r.join("_")+"_"+e);var N=_e[e];if(n)var C="function"==typeof n?n:console.log;if(N)return n&&C(be[e]),N.bind(t);var O=[],S="evaluate"+e,P=i.point;s&&(P=function(e,t){for(var i=[],n=0;n<e.length;n++){for(var o=e[n],s=[],r=0;r<o.length;r++)0!==o[r]&&s.push(o[r]);o=s.join(" + "),t[n]&&(o="("+o+" + "+t[n]+") % "+t[n]),i.push(o+" === "+V(n))}return"(("+i.join(" && ")+") ? 1 : 0)"});var D=i.weight,I=i.knot,F=te("k"),R=te("x"),z=te("w"),V=te("i"),T=te("t"),j=n?"domain":"d",x=te(n?"size":"s"),k=te(n?"knotIndex":"j"),A=!0;for(d=0;d<p;d++)Y(b)&&Y(b[d])&&(A=!1);function B(e){O.push(" "+(e||""))}function X(e){n&&B(e)}if(s)var E=[];var U=[];for(l=0;l<p;l++)s&&E.push(V([l])),U.push(T([l]));for(O.push("function "+S+" ("+(s?"":"out, ")+U.join(", ")+(s?", "+E.join(", "):"")+") {"),B("var h, m, a, b;"),o&&(B("var "+j+" = this.domain;"),B("for (var i = 0; i < this.splineDimension; i++) {"),B(" a = arguments[i + 1];"),B(" if (a < "+j+"[i][0] || a > "+j+"[i][1] || a === undefined || isNaN(a)) {"),B(' throw new Error("Invalid Spline parameter in dimension "+i+". Valid domain is ["+'+j+'[i][0]+", "+'+j+'[i][1]+"]. but got t"+i+" = "+arguments[i + 1]+".");'),B(" }"),B("}")),d=0;d<p;d++)B("var "+x(d)+" = "+fe(g,"this.points",d)+";");function q(e,t,i){return"("+e+") ? ("+t+") : ("+i+")"}O.push(ge(t,"x","this.points",g)),_&&O.push(ge(t,"w","this.weights",f)),A||O.push(ge(t,"k","this.knots",b));var K=[];for(d=0;d<p;d++)switch(Z(b)){case Z.NDARRAY:K[d]=!0;break;case Z.ARRAY_OF_ARRAYS:K[d]=Y(b[d])}for(d=0;d<p;d++)if(K[d])for(X("\n // Bisect to locate the knot interval in dimension "+d+"\n"),B("var "+k(d)+" = 0;"),B("h = "+x(d)+";"),B("while(h > "+k(d)+" + 1) {"),B(" m = 0.5 * (h + "+k(d)+") | 0;"),B(" if ("+I([d,"m"])+" > "+T(d)+") h = m;"),B(" else "+k(d)+" = m;"),B("}"),X("\n // Fetch knots for dimension "+d+"\n"),l=1-m[d];l<=m[d];l++)"closed"===w[d]?B(l<0?"var "+F([d,l+m[d]-1])+" = "+q(k(d)+" < "+-l,I([d,0])+" + "+I([d,[x(d),k(d),l]])+" - "+I([d,[x(d)]]),I([d,[k(d),l]]))+";":l>0?"var "+F([d,l+m[d]-1])+" = "+q(k(d)+" + "+l+" > "+x(d),I([d,x(d)])+" + "+I([d,l+" + "+k(d)+" - "+x(d)])+" - "+I([d,0]),I([d,[k(d),l]]))+";":"var "+F([d,l+m[d]-1])+" = "+I([d,[k(d),l]])+";"):B("var "+F([d,l+m[d]-1])+" = "+I([d,[k(d),l]])+";");else{for(X("\n // Directly compute knot interval for dimension "+d+"\n"),"closed"===w[d]?B(k(d)+" = ("+T(d)+" | 0) % "+x(d)+";"):(B(k(d)+" = ("+T(d)+" | 0);"),B("if ("+k(d)+" < "+m[d]+") "+k(d)+" = "+m[d]+";"),B("if ("+k(d)+" > "+x(d)+" - 1) "+k(d)+" = "+x(d)+" - 1;")),X("\n // Compute and clamp knots for dimension "+d+"\n"),l=1-m[d];l<=m[d];l++)B("var "+(c=F([d,l+m[d]-1]))+" = "+k(d)+" + "+l+";");if("clamped"===w[d])for(l=1-m[d];l<=m[d];l++)c=F([d,l+m[d]-1]),l<0&&B("if ("+c+" < "+m[d]+") "+c+" = "+m[d]+";"),l>0&&B("if ("+c+" > "+x(d)+") "+c+" = "+x(d)+";");"closed"===w[d]&&(X("\n // Wrap the B-Spline parameter for closed boundary"),B(T(d)+" %= "+x(d)+";"))}for(d=0,u=[];d<p;d++)u[d]=m[d]+1;for(_&&(X("\n // Fetch weights\n"),ce(u,(function(e){for(var t=[],i=[],n=0;n<p;n++)t[n]=[k(n),e[n]-m[n]],"closed"===w[n]&&e[n]-m[n]<0&&(i[n]=x(n));B("var "+z(e)+" = "+D(t,i)+";")}))),n&&B(_?"\n // Fetch points and project into homogeneous (weighted) coordinates\n":"\n // Fetch points\n"),ce(u,(function(e){for(var t=[],i=[],n=0;n<p;n++)t[n]=[k(n),e[n]-m[n]],"closed"===w[n]&&e[n]-m[n]<0&&(i[n]=x(n));if(s)B(_?"var "+R(e)+" = "+P(t,i)+" * "+z(e)+";":"var "+R(e)+" = "+P(t,i)+";");else for(n=0;n<v;n++){var o=e.concat(n);t[p]=n,B(_?"var "+R(o)+" = "+P(t,i)+" * "+z(e)+";":"var "+R(o)+" = "+P(t,i)+";")}})),X("\n"),X('// Perform De Boor"s algorithm'),d=u.length-1;d>=0;d--)for(u[d]=[m[d],m[d]+1],l=0;l<m[d];l++)for(X("\n // Degree "+m[d]+" evaluation in dimension "+d+", step "+(l+1)+"\n"),a=m[d];a>l;a--){var M=r&&m[d]-l-r[d]<=0;M?(B("m = 1 / ("+F([d,a-l+m[d]-1])+" - "+F([d,a-1])+");"),_&&(B("a = ("+T(d)+" - "+F([d,a-1])+") * m;"),B("b = 1 - a;"))):(B("a = ("+T(d)+" - "+F([d,a-1])+") / ("+F([d,a-l+m[d]-1])+" - "+F([d,a-1])+");"),B("b = 1 - a;")),_&&ce(u,(function(e){var t=e.slice(),i=e.slice();t[d]=a,i[d]=a-1,M&&_&&B("h = "+z(t)+";"),B(z(t)+" = b * "+z(i)+" + a * "+z(t)+";")})),ce(u,(function(e){var t,i,n,o=e.slice(),r=e.slice();if(o[d]=a,r[d]=a-1,M){var u=l+1;if(s)t=_?"h * "+z(r)+" / "+z(o)+" * ":"",i=R(o)+(_?" / h":""),n=R(r)+(_?" / "+z(r):""),B(R(o)+" = "+u+" * "+t+"("+i+" - "+n+") * m;");else{var c=o.slice(),g=r.slice();for(h=0;h<v;h++)c[p]=g[p]=h,t=_?"h * "+z(r)+" / "+z(o)+" * ":"",i=R(c)+(_?" / h":""),n=R(g)+(_?" / "+z(r):""),B(R(c)+" = "+u+" * "+t+"("+i+" - "+n+") * m;")}}else if(s)B(R(o)+" = b * "+R(r)+" + a * "+R(o)+";");else for(h=0;h<v;h++)o[p]=r[p]=h,B(R(o)+" = b * "+R(r)+" + a * "+R(o)+";")})),X("\n")}if(n&&B(_?"\n // Project back from homogeneous coordinates and return final output\n":"\n // Return final output\n"),s)B(_?"return "+R(m)+" / "+z(m)+";":"return "+R(m)+";");else for(d=0;d<v;d++)B(_?"out["+d+"] = "+R(m.concat([d]))+" / "+z(m)+";":"out["+d+"] = "+R(m.concat([d]))+";");if(s||B("return out;"),O.push("}"),n){var G=O.join("\n");C(G),be[e]=G}var W=new Function([O.join("\n"),"; return ",S].join(""))();return _e[e]=W,W.bind(t)};f().add("evaluator","lib/nurbs/src/evaluator",ve);const we=ve;var ye={};const Ne=function(e,t,i,n){var o,s,r,l,a,u,h,d,c=ye[e];if(c)return c.bind(t);var p=[],g="transform"+e;p.push("function "+g+"(m) {"),p.push("var i, w;"),p.push(ge(t,"x","this.points",t.points));var m=te(n?"size":"s");for(o=0;o<t.splineDimension;o++)p.push("var "+m(o)+" = "+fe(t.points,"this.points",o)+";");for(l=[],o=0;o<t.splineDimension;o++)r="i"+o,l.push(r),p.push("for ("+r+" = "+m(o)+"- 1; "+r+" >= 0; "+r+"--) {");for(o=0;o<t.dimension;o++)p.push("x"+o+" = "+i.point(l.concat([o])));for(a=[],o=0;o<t.dimension;o++)a.push("m["+((t.dimension+1)*(o+1)-1)+"] * x"+o);for(a.push("m["+((t.dimension+1)*(t.dimension+1)-1)+"]"),p.push("var w = ("+a.join(" + ")+") || 1.0;"),o=0;o<t.dimension;o++){for(a=[],u=t.dimension,s=0;s<u;s++)a.push("m["+(s*(u+1)+o)+"] * x"+s);a.push("m["+(s*(u+1)+o)+"]"),d=i.point(l.concat([o])),h="("+a.join(" + ")+") / w",p.push(d+" = "+h+";")}for(o=t.splineDimension-1;o>=0;o--)p.push("}");p.push("return this;"),p.push("}");var f=new Function([p.join("\n"),"; return ",g].join(""))();return n&&console.log(p.join("\n")),ye[e]=f,f.bind(t)};f().add("transform","lib/nurbs/src/transform",Ne);const Ce=Ne;var Oe={};const Se=function(e,t,i,n,o){var s=Oe[e];if(s)return s.bind(t);var r,l,a,u=t.degree,h=t.knots,d=t.splineDimension,c=t.boundary,p=[],g="support"+e,m=i.knot,f=te("t"),_=n?"domain":"d",b=te(n?"size":"s"),v=te(n?"knotIndex":"i"),w=!0;for(a=0;a<d;a++)Y(h)&&Y(h[a])&&(w=!1);function y(e){p.push(" "+(e||""))}var N=[];for(r=0;r<d;r++)N.push(f([r]));p.push("function "+g+" (out, "+N.join(", ")+") {");var C=0;function O(e,t){y(void 0===t?"out["+C+++"] = "+e.join(" + ")+";":"out["+C+++"] = ("+e.join(" + ")+" + "+t+") % "+t+";")}for(y("var h, m;"),y("var c = 0;"),o&&(y("var "+_+" = this.domain;"),y("for (var i = 0; i < this.splineDimension; i++) {"),y(" a = arguments[i + 1];"),y(" if (a < "+_+"[i][0] || a > "+_+"[i][1] || a === undefined || isNaN(a)) {"),y(' throw new Error("Invalid Spline parameter in dimension "+i+". Valid domain is ["+'+_+'[i][0]+", "+'+_+'[i][1]+"]. but got t"+i+" = "+arguments[i + 1]+".");'),y(" }"),y("}")),a=0;a<d;a++)y("var "+b(a)+" = "+fe(t.points,"this.points",a)+";");w||p.push(ge(t,"k","this.knots",h));var S=[];for(a=0;a<d;a++)switch(Z(h)){case Z.NDARRAY:S[a]=!0;break;case Z.ARRAY_OF_ARRAYS:S[a]=Y(h[a])}for(a=0;a<d;a++)S[a]?(y("var "+v(a)+" = 0;"),y("h = "+b(a)+";"),y("while(h > "+v(a)+" + 1) {"),y(" m = 0.5 * (h + "+v(a)+") | 0;"),y(" if ("+m([a,"m"])+" > "+f(a)+") h = m;"),y(" else "+v(a)+" = m;"),y("}")):"closed"===c[a]?y(v(a)+" = ("+f(a)+" | 0) % "+b(a)+";"):(y(v(a)+" = ("+f(a)+" | 0);"),y("if ("+v(a)+" < "+u[a]+") "+v(a)+" = "+u[a]+";"),y("if ("+v(a)+" > "+b(a)+" - 1) "+v(a)+" = "+b(a)+" - 1;"));for(a=0,l=[];a<d;a++)l[a]=u[a]+1;ce(l,(function(e){for(var t=[],i=[],n=0;n<d;n++)t[n]=[v(n),e[n]-u[n]],"closed"===c[n]&&e[n]-u[n]<0&&(i[n]=b(n));for(n=0;n<d;n++)O(t[n],i[n])})),y("out.length = "+C+";"),y("return out;"),p.push("}"),n&&console.log(p.join("\n"));var P=new Function([p.join("\n"),"; return ",g].join(""))();return Oe[e]=P,P.bind(t)};f().add("support","lib/nurbs/src/support",Se);const Pe=Se;var De=[];const Ie=function(e,t,i){i=i||{};var n=(e=e||{}).points=e.points||[],o=e.faces=e.faces||[],s=i.haveWeights,r=t.dimension-s;if(Array.isArray(i.resolution))var l=i.resolution;else{var a=void 0===i.resolution?31:i.resolution;l=new Array(t.splineDimension).fill(a)}switch(t.splineDimension){case 1:for(var u=(f=(b=l[0])+!(w="closed"===t.boundary[0]))*r,h=(N=(_=i.domain||t.domain)[0])[1]-N[0],d=0;d<f;++d){var c=N[0]+h*d/b,p=d*r;if(t.evaluate(De,c),s)for(var g=De[r],m=0;m<r;++m)n[p+m]=De[m]/g;else for(m=0;m<r;++m)n[p+m]=De[m]}n.length=u;break;case 2:var f,_,b=l[0],v=l[1],w="closed"===t.boundary[0],y=v+!(D="closed"===t.boundary[1]),N=(u=(f=b+!w)*y*r,(_=i.domain||t.domain)[0]),C=_[1],O=(h=N[1]-N[0],C[1]-C[0]);for(d=0;d<f;++d){c=N[0]+h*d/b;for(var S=0;S<y;++S){var P=C[0]+O*S/v;p=(d+f*S)*r;if(t.evaluate(De,c,P),s)for(g=De[r],m=0;m<r;++m)n[p+m]=De[m]/g;else for(m=0;m<r;++m)n[p+m]=De[m]}}n.length=u;w=i.closed[0];var D=i.closed[1],I=0;for(d=0;d<b;++d){var F=d,R=d+1;w&&(R%=b);for(S=0;S<v;++S){var z=S,V=S+1;D&&(V%=v),o[I++]=F+f*z,o[I++]=R+f*z,o[I++]=R+f*V,o[I++]=F+f*z,o[I++]=R+f*V,o[I++]=F+f*V}}o.length=I;break;default:throw new Error("Can only sample contours and surfaces")}return e};f().add("sample","lib/nurbs/extras/sample",Ie);const Fe=Ie;var Re={open:"open",closed:"closed",clamped:"clamped"};function ze(e){return null==e}function Ve(e,t,i,n,o,s){var r,l;!e||Y(e)||K(e)?(s=s||{},this.weights=n,this.knots=i,this.degree=t,this.points=e,this.boundary=o,this.debug=s.debug,this.checkBounds=!!s.checkBounds,Object.defineProperty(this,"size",{value:s.size,writable:!0,configurable:!0})):(s=e,this.debug=e.debug,this.checkBounds=!!e.checkBounds,this.weights=e.weights,this.knots=e.knots,this.degree=e.degree,this.boundary=e.boundary,this.points=e.points,Object.defineProperty(this,"size",{value:s.size,writable:!0,configurable:!0}));var a=Z(this.points),u=Z(this.weights),h=Z(this.knots);if(this.points)switch(a){case Z.GENERIC_NDARRAY:case Z.NDARRAY:Object.defineProperties(this,{splineDimension:{value:this.points.shape.length-1,writable:!1,configurable:!0},dimension:{value:this.points.shape[this.points.shape.length-1],writable:!1,configurable:!0},size:{get:function(){return this.points.shape.slice(0,this.points.shape.length-1)},set:function(){throw new Error("Cannot assign to read only property 'size'")},configurable:!0}});break;case Z.ARRAY_OF_OBJECTS:case Z.ARRAY_OF_ARRAYS:var d=0,c=this.size||[];c.length=0;for(var p=this.points;Y(p[0]);p=p[0])d++,c.push(p.length);if(0===d)throw new Error("Expected an array of points");Object.defineProperties(this,{splineDimension:{value:d,writable:!1,configurable:!0},dimension:{value:p.length,writable:!1,configurable:!0},size:{get:function(){var e=[];e.length=0;for(var t=0,i=this.points;t<this.splineDimension;t++,i=i[0])e[t]=i.length;return e},set:function(){throw new Error('Cannot assign to read only property "size"')},configurable:!0}});break;case Z.PACKED:default:throw new Error("Expected either a packed array, array of arrays, or ndarray of points")}else{if(void 0===this.size||null===this.size)throw new Error("Either points or a control hull size must be provided.");if(Y(this.size)||Object.defineProperty(this,"size",{value:[this.size],writable:!0,configurable:!0}),0===this.size.length)throw new Error("`size` must be a number or an array of length at least one.");Object.defineProperties(this,{splineDimension:{value:this.size.length,writable:!1,configurable:!0},dimension:{value:0,writable:!1,configurable:!0}})}if(Y(this.degree)){for(r=0;r<this.splineDimension;r++)if(ze(this.degree[r]))throw new Error("Missing degree in dimension "+(r+1))}else{var g=!ze(this.degree),m=ze(this.degree)?2:this.degree;for(this.degree=[],r=0;r<this.splineDimension;r++)if(this.size[r]<=m){if(g)throw new Error("Expected at least "+(m+1)+" points for degree "+m+" spline in dimension "+(r+1)+" but got only "+this.size[r]);this.degree[r]=this.size[r]-1}else this.degree[r]=m}if(l="string"!=typeof this.boundary?"open":this.boundary,!Re[l])throw new Error("Boundary type must be one of "+Object.keys(Re)+". Got "+l);for(this.boundary=Y(this.boundary)?this.boundary:[],this.boundary.length=this.splineDimension,r=0;r<this.splineDimension;r++)if(this.boundary[r]=ze(this.boundary[r])?l:this.boundary[r],!Re[l])throw new Error("Boundary type must be one of "+Object.keys(Re)+". Got "+l+" for dimension "+(r+1));switch(h){case Z.ARRAY_OF_ARRAYS:for(Y(this.knots)&&this.knots.length>0&&!Y(this.knots[0])&&(this.knots=[this.knots]),r=0;r<this.splineDimension;r++){if(this.size[r]<=this.degree[r])throw new Error("Expected at least "+(this.degree[r]+1)+" points in dimension "+(r+1)+" but got "+this.size[r]+".");if(Y(this.knots[r])){if("closed"!==this.boundary[r]&&this.knots[r].length!==this.degree[r]+this.size[r]+1)throw new Error("Expected "+(this.degree[r]+this.size[r]+1)+" knots in dimension "+(r+1)+" but got "+this.knots[r].length+".");if("closed"===this.boundary[r]&&this.knots[r].length!==this.size[r]+1&&!(this.knots[r].length===this.size[r]+this.degree[r]+1))throw new Error("Expected "+(this.size[r]+1)+" knots for closed spline in dimension "+(r+1)+" but got "+this.knots[r].length+".")}}case Z.NDARRAY:}var f=Q(this,this.debug,this.checkBounds,a,u,h);if(f!==this.__cacheKey){this.__cacheKey=f;var _=re(this);this.evaluate=we(this.__cacheKey,this,_,this.debug,this.checkBounds,!1),this.transform=Ce(this.__cacheKey,this,_,this.debug),this.support=Pe(this.__cacheKey,this,_,this.debug,this.checkBounds),this.evaluator=function(e,t){return we(this.__cacheKey,this,_,this.debug,this.checkBounds,t,e)}}return this.numericalDerivative=he.bind(this),this}function Te(){var e,t=[],i=this.points;i?G(i)&&(e=i.shape):e=this.size;for(var n=0;n<this.splineDimension;n++){var o=e?e[n]:i.length,s=this.degree[n],r="closed"===this.boundary[n];if(this.knots&&this.knots[n]){var l=this.knots[n];t[n]=[l[r?0:s],l[o]]}else t[n]=[r?0:s,o];i&&(i=i[0])}return t}function je(e,t,i,n,o,s){var r=function(e,t,i,n,o,s){return l(e,t,i,n,o,s),r},l=Ve.bind(r);return Object.defineProperty(r,"domain",{get:Te}),l(e,t,i,n,o,s),r}je.sample=Fe;const xe=je;f().add("nurbs","lib/nurbs/nurbs",xe);const ke=xe;function Ae(e){X.call(this,e),U().call(this,e),this.addType(c().NurbsCurve),this.knots=[],this.weights=[],this.controlPoints=[],this.mesh={},this.sampleOptions={resolution:[]}}Object.assign(Object.setPrototypeOf(Ae.prototype,X.prototype),U().prototype,{initialize(){X.prototype.initialize.call(this),this._controlPoint.addInterest("set_controlPoint__",this),this.set_controlPoint__()},set_controlPoint__(){this.controlPointNode&&this.controlPointNode.removeInterest("requestRebuild",this),this.controlPointNode=g()(c().X3DCoordinateNode,this._controlPoint),this.controlPointNode&&this.controlPointNode.addInterest("requestRebuild",this)},getTessellation(e){return k.getTessellation(this._tessellation.getValue(),e-this._order.getValue())},getClosed(e,t,i,n){return!!this._closed.getValue()&&k.getClosed(e,t,i,n)},getWeights:(e,t,i)=>k.getWeights(e,t,i),getControlPoints:(e,t,i,n,o)=>k.getControlPoints(e,t,i,n,o),tessellate(){if(this._order.getValue()<2)return[];if(!this.controlPointNode)return[];if(this.controlPointNode.getSize()<this._order.getValue())return[];const e=this.getVertices(),t=[];if(e.length){const i=e.length;for(let n=0;n<i;n+=8)t.push(e[n],e[n+1],e[n+2]);t.push(e[i-4],e[i-3],e[i-2])}return t},build(){if(this._order.getValue()<2)return;if(!this.controlPointNode)return;if(this.controlPointNode.getSize()<this._order.getValue())return;const e=this.getClosed(this._order.getValue(),this._knot,this._weight,this.controlPointNode),t=this.getWeights(this.weights,this.controlPointNode.getSize(),this._weight),i=this.getControlPoints(this.controlPoints,e,this._order.getValue(),t,this.controlPointNode),n=this.getKnots(this.knots,e,this._order.getValue(),this.controlPointNode.getSize(),this._knot),o=(n.at(-1),n[0],this._order.getValue()-1),s=this.surface=(this.surface||ke)({boundary:["open"],degree:[o],knots:[n],points:i,debug:!1});this.sampleOptions.resolution[0]=this.getTessellation(n.length),this.sampleOptions.haveWeights=!!t;const r=ke.sample(this.mesh,s,this.sampleOptions).points,l=this.getVertices();for(let e=3,t=r.length;e<t;e+=3){const t=e-3;l.push(r[t],r[t+1],r[t+2],1),l.push(r[e],r[e+1],r[e+2],1)}},dispose(){X.prototype.dispose.call(this)}}),Object.defineProperties(Ae,{typeName:{value:"NurbsCurve",enumerable:!0},componentInfo:{value:Object.freeze({name:"NURBS",level:1}),enumerable:!0},containerField:{value:"geometry",enumerable:!0},specificationRange:{value:Object.freeze({from:"3.0",to:"Infinity"}),enumerable:!0},fieldDefinitions:{value:new(a())([new(r())(c().inputOutput,"metadata",new(o().SFNode)),new(r())(c().inputOutput,"tessellation",new(o().SFInt32)),new(r())(c().initializeOnly,"closed",new(o().SFBool)),new(r())(c().initializeOnly,"order",new(o().SFInt32)(3)),new(r())(c().initializeOnly,"knot",new(o().MFDouble)),new(r())(c().inputOutput,"weight",new(o().MFDouble)),new(r())(c().inputOutput,"controlPoint",new(o().SFNode))]),enumerable:!0}});const Be=Ae;f().add("NurbsCurve","x_ite/Components/NURBS/NurbsCurve",Be);const Xe=Be;function Ee(e){C.call(this,e),this.addType(c().NurbsCurve2D),this.knots=[],this.weights=[],this.controlPoints=[],this.mesh={},this.sampleOptions={resolution:[]},this.array=[]}Object.assign(Object.setPrototypeOf(Ee.prototype,C.prototype),{getTessellation(e){return k.getTessellation(this._tessellation.getValue(),e-this._order.getValue())},getClosed(e,t,i,n){return!!this._closed.getValue()&&k.getClosed2D(e,t,i,n)},getKnots:(e,t,i,n,o)=>k.getKnots(e,t,i,n,o),getWeights:(e,t,i)=>k.getWeights(e,t,i),getControlPoints:(e,t,i,n,o)=>k.getControlPoints2D(e,t,i,n,o),tessellate(e){const t=this.array;if(t.length=0,this._order.getValue()<2)return t;if(this._controlPoint.length<this._order.getValue())return t;const i=this.getClosed(this._order.getValue(),this._knot,this._weight,this._controlPoint),n=this.getWeights(this.weights,this._controlPoint.length,this._weight),o=this.getControlPoints(this.controlPoints,i,this._order.getValue(),n,this._controlPoint),s=this.getKnots(this.knots,i,this._order.getValue(),this._controlPoint.length,this._knot),r=(s.at(-1),s[0],this._order.getValue()-1),l=this.surface=(this.surface||ke)({boundary:["open"],degree:[r],knots:[s],points:o,debug:!1});this.sampleOptions.resolution[0]=this.getTessellation(s.length),this.sampleOptions.haveWeights=!!n;const a=ke.sample(this.mesh,l,this.sampleOptions).points;switch(e){case 0:for(let e=0,i=a.length;e<i;e+=2)t.push(a[e],a[e+1]);break;case 1:for(let e=0,i=a.length;e<i;e+=2)t.push(a[e],0,a[e+1]);break;case 2:for(let e=0,i=a.length;e<i;e+=2)t.push(new(S())(a[e],a[e+1],0))}return t}}),Object.defineProperties(Ee,{typeName:{value:"NurbsCurve2D",enumerable:!0},componentInfo:{value:Object.freeze({name:"NURBS",level:3}),enumerable:!0},containerField:{value:"children",enumerable:!0},specificationRange:{value:Object.freeze({from:"3.0",to:"Infinity"}),enumerable:!0},fieldDefinitions:{value:new(a())([new(r())(c().inputOutput,"metadata",new(o().SFNode)),new(r())(c().inputOutput,"tessellation",new(o().SFInt32)),new(r())(c().initializeOnly,"closed",new(o().SFBool)),new(r())(c().initializeOnly,"order",new(o().SFInt32)(3)),new(r())(c().initializeOnly,"knot",new(o().MFDouble)),new(r())(c().inputOutput,"weight",new(o().MFDouble)),new(r())(c().inputOutput,"controlPoint",new(o().MFVec2d))]),enumerable:!0}});const Ue=Ee;f().add("NurbsCurve2D","x_ite/Components/NURBS/NurbsCurve2D",Ue);const qe=Ue,Ke=window[Symbol.for("X_ITE.X3D-9.6.3")].require("x_ite/Components/Core/X3DChildNode");var Me=e.n(Ke);const Ge=window[Symbol.for("X_ITE.X3D-9.6.3")].require("x_ite/Components/Interpolation/OrientationInterpolator");var We=e.n(Ge);const Ye=window[Symbol.for("X_ITE.X3D-9.6.3")].require("standard/Math/Numbers/Rotation4");var Je=e.n(Ye);function Le(e){Me().call(this,e),this.addType(c().NurbsOrientationInterpolator),this.addChildObjects(c().inputOutput,"rebuild",new(o().SFTime)),this.interpolator=new(We())(e),this.knots=[],this.weights=[],this.controlPoints=[],this.mesh={},this.sampleOptions={resolution:[128]}}Object.assign(Object.setPrototypeOf(Le.prototype,Me().prototype),{initialize(){Me().prototype.initialize.call(this),this._order.addInterest("requestRebuild",this),this._knot.addInterest("requestRebuild",this),this._weight.addInterest("requestRebuild",this),this._controlPoint.addInterest("set_controlPoint__",this),this._rebuild.addInterest("build",this),this._set_fraction.addFieldInterest(this.interpolator._set_fraction),this.interpolator._value_changed.addFieldInterest(this._value_changed),this.interpolator.setup(),this.set_controlPoint__()},set_controlPoint__(){this.controlPointNode&&this.controlPointNode.removeInterest("requestRebuild",this),this.controlPointNode=g()(c().X3DCoordinateNode,this._controlPoint),this.controlPointNode&&this.controlPointNode.addInterest("requestRebuild",this),this.requestRebuild()},getClosed:(e,t,i,n)=>!1,getKnots:(e,t,i,n,o)=>k.getKnots(e,t,i,n,o),getWeights:(e,t,i)=>k.getWeights(e,t,i),getControlPoints:(e,t,i,n,o)=>k.getControlPoints(e,t,i,n,o),requestRebuild(){this._rebuild.addEvent()},build(){if(this._order.getValue()<2)return;if(!this.controlPointNode)return;if(this.controlPointNode.getSize()<this._order.getValue())return;const e=this.getClosed(this._order.getValue(),this._knot,this._weight,this.controlPointNode),t=this.getWeights(this.weights,this.controlPointNode.getSize(),this._weight),i=this.getControlPoints(this.controlPoints,e,this._order.getValue(),t,this.controlPointNode),n=this.getKnots(this.knots,e,this._order.getValue(),this.controlPointNode.getSize(),this._knot),o=n.at(-1)-n[0],s=this._order.getValue()-1,r=this.surface=(this.surface||ke)({boundary:["open"],degree:[s],knots:[n],points:i,debug:!1});this.sampleOptions.haveWeights=!!t;const l=ke.sample(this.mesh,r,this.sampleOptions).points,a=this.interpolator;a._key.length=0,a._keyValue.length=0;for(let t=0,i=l.length-3;t<i;t+=3){const s=new(S())(l[t+3]-l[t+0],l[t+4]-l[t+1],l[t+5]-l[t+2]);a._key.push(n[0]+t/(i-3+3*e)*o),a._keyValue.push(new(Je())(S().zAxis,s))}e&&(a._key.push(n[0]+o),a._keyValue.push(a._keyValue[0]))}}),Object.defineProperties(Le,{typeName:{value:"NurbsOrientationInterpolator",enumerable:!0},componentInfo:{value:Object.freeze({name:"NURBS",level:1}),enumerable:!0},containerField:{value:"children",enumerable:!0},specificationRange:{value:Object.freeze({from:"3.0",to:"Infinity"}),enumerable:!0},fieldDefinitions:{value:new(a())([new(r())(c().inputOutput,"metadata",new(o().SFNode)),new(r())(c().inputOnly,"set_fraction",new(o().SFFloat)),new(r())(c().inputOutput,"order",new(o().SFInt32)(3)),new(r())(c().inputOutput,"knot",new(o().MFDouble)),new(r())(c().inputOutput,"weight",new(o().MFDouble)),new(r())(c().inputOutput,"controlPoint",new(o().SFNode)),new(r())(c().outputOnly,"value_changed",new(o().SFRotation))]),enumerable:!0}});const Ze=Le;f().add("NurbsOrientationInterpolator","x_ite/Components/NURBS/NurbsOrientationInterpolator",Ze);const He=Ze,Qe=window[Symbol.for("X_ITE.X3D-9.6.3")].require("standard/Math/Algorithm");var $e=e.n(Qe);const et=window[Symbol.for("X_ITE.X3D-9.6.3")].require("standard/Math/Geometry/Triangle3");var tt=e.n(et);function it(e){X.call(this,e),this.addType(c().X3DNurbsSurfaceGeometryNode),this.tessellationScale=1,this.uKnots=[],this.vKnots=[],this.weights=[],this.controlPoints=[],this.mesh={},this.sampleOptions={resolution:[],closed:[]},this.textUKnots=[],this.textVKnots=[],this.textWeights=[],this.texControlPoints=[],this.texMesh={}}Object.assign(Object.setPrototypeOf(it.prototype,X.prototype),{initialize(){X.prototype.initialize.call(this),this._texCoord.addInterest("set_texCoord__",this),this._controlPoint.addInterest("set_controlPoint__",this),this.set_texCoord__(),this.set_controlPoint__()},set_texCoord__(){this.texCoordNode?.removeInterest("requestRebuild",this),this.nurbsTexCoordNode?.removeInterest("requestRebuild",this),this.texCoordNode=g()(c().X3DTextureCoordinateNode,this._texCoord),this.nurbsTexCoordNode=g()(c().NurbsTextureCoordinate,this._texCoord),this.texCoordNode?.addInterest("requestRebuild",this),this.nurbsTexCoordNode?.addInterest("requestRebuild",this)},set_controlPoint__(){this.controlPointNode&&this.controlPointNode.removeInterest("requestRebuild",this),this.controlPointNode=g()(c().X3DCoordinateNode,this._controlPoint),this.controlPointNode&&this.controlPointNode.addInterest("requestRebuild",this)},setTessellationScale(e){this.tessellationScale=e,this.requestRebuild()},getUTessellation(e){return Math.floor(k.getTessellation(this._uTessellation.getValue(),e-this._uOrder.getValue())*this.tessellationScale)},getVTessellation(e){return Math.floor(k.getTessellation(this._vTessellation.getValue(),e-this._vOrder.getValue())*this.tessellationScale)},getUClosed(e,t,i,n,o,s){return!!this._uClosed.getValue()&&k.getUClosed(e,t,i,n,o,s)},getVClosed(e,t,i,n,o,s){return!!this._vClosed.getValue()&&k.getVClosed(e,t,i,n,o,s)},getUVWeights:(e,t,i,n)=>k.getUVWeights(e,t,i,n),getTexControlPoints:(e,t,i,n,o,s,r,l)=>k.getTexControlPoints(e,t,i,n,o,s,r,l),getUVControlPoints:(e,t,i,n,o,s,r,l,a)=>k.getUVControlPoints(e,t,i,n,o,s,r,l,a),getTrimmingContours(){},build(){if(this._uOrder.getValue()<2)return;if(this._vOrder.getValue()<2)return;if(this._uDimension.getValue()<this._uOrder.getValue())return;if(this._vDimension.getValue()<this._vOrder.getValue())return;if(!this.controlPointNode)return;if(this.controlPointNode.getSize()!==this._uDimension.getValue()*this._vDimension.getValue())return;const e=this.getUClosed(this._uOrder.getValue(),this._uDimension.getValue(),this._vDimension.getValue(),this._uKnot,this._weight,this.controlPointNode),t=this.getVClosed(this._vOrder.getValue(),this._uDimension.getValue(),this._vDimension.getValue(),this._vKnot,this._weight,this.controlPointNode),i=this.getUVWeights(this.weights,this._uDimension.getValue(),this._vDimension.getValue(),this._weight),n=this.getUVControlPoints(this.controlPoints,e,t,this._uOrder.getValue(),this._vOrder.getValue(),this._uDimension.getValue(),this._vDimension.getValue(),i,this.controlPointNode),o=this.getKnots(this.uKnots,e,this._uOrder.getValue(),this._uDimension.getValue(),this._uKnot),s=this.getKnots(this.vKnots,t,this._vOrder.getValue(),this._vDimension.getValue(),this._vKnot),r=(o.at(-1),o[0],s.at(-1),s[0],this._uOrder.getValue()-1),l=this._vOrder.getValue()-1,a=this.surface=(this.surface||ke)({boundary:["open","open"],degree:[r,l],knots:[o,s],points:n,debug:!1}),u=this.sampleOptions;u.resolution[0]=this.getUTessellation(o.length),u.resolution[1]=this.getVTessellation(s.length),u.closed[0]=e,u.closed[1]=t,u.domain=void 0,u.haveWeights=!!i,u.trimmingContours=this.getTrimmingContours();const h=ke.sample(this.mesh,a,u),d=h.faces,c=h.points,p=this.getVertices();for(let e=0,t=d.length;e<t;++e){const t=3*d[e];p.push(c[t],c[t+1],c[t+2],1)}this.buildNurbsTexCoords(e,t,this._uOrder.getValue(),this._vOrder.getValue(),o,s,this._uDimension.getValue(),this._vDimension.getValue(),a.domain),this.buildNormals(d,c),this.setSolid(this._solid.getValue()),this.setCCW(!0)},buildNurbsTexCoords:(()=>{const e=[],t=[],i=[[[0,0,0,1],[0,1,0,1]],[[1,0,0,1],[1,1,0,1]]];function n(e,t){return e[0]=e[1]=t[0],e[2]=e[3]=t.at(-1),e}return function(o,s,r,l,a,u,h,d,c){const p=this.sampleOptions;if(this.texCoordNode&&this.texCoordNode.getSize()===h*d)var g=r-1,m=l-1,f=a,_=u,b=this.getTexControlPoints(this.texControlPoints,o,s,r,l,h,d,this.texCoordNode);else if(this.nurbsTexCoordNode&&this.nurbsTexCoordNode.isValid()){var v=this.nurbsTexCoordNode,w=(g=v._uOrder.getValue()-1,m=v._vOrder.getValue()-1,f=this.getKnots(this.texUKnots,!1,v._uOrder.getValue(),v._uDimension.getValue(),v._uKnot),_=this.getKnots(this.texVKnots,!1,v._vOrder.getValue(),v._vDimension.getValue(),v._vKnot),this.getUVWeights(this.texWeights,v._uDimension.getValue(),v._vDimension.getValue(),v._weight));b=v.getControlPoints(w)}else{g=1,m=1,f=n(e,a),_=n(t,u),b=i;p.domain=c}const y=this.texSurface=(this.texSurface||ke)({boundary:["open","open"],degree:[g,m],knots:[f,_],points:b});p.closed[0]=!1,p.closed[1]=!1,p.haveWeights=!1;const N=ke.sample(this.texMesh,y,p),C=N.faces,O=N.points,S=this.getTexCoords();for(let e=0,t=C.length;e<t;++e){const t=4*C[e];S.push(O[t],O[t+1],O[t+2],O[t+3])}this.getMultiTexCoords().push(this.getTexCoords())}})(),buildNormals(e,t){const i=this.createNormals(e,t),n=this.getNormals();for(const e of i)n.push(e.x,e.y,e.z)},createNormals(e,t){const i=new Map,n=this.createFaceNormals(e,t),o=e.length;for(let t=0;t<o;++t){const n=e[t];let o=i.get(n);o||i.set(n,o=[]),o.push(t)}return this.refineNormals(i,n,$e().radians(85))},createFaceNormals:(()=>{const e=new(S()),t=new(S()),i=new(S());return function(n,o){const s=this.faceNormals||[],r=n.length;for(let l=0;l<r;l+=3){const r=3*n[l],a=3*n[l+1],u=3*n[l+2];e.set(o[r],o[r+1],o[r+2]),t.set(o[a],o[a+1],o[a+2]),i.set(o[u],o[u+1],o[u+2]);const h=tt().normal(e,t,i,s[l]||new(S()));s[l]=h,s[l+1]=h,s[l+2]=h}return s.length=r,s}})()}),Object.defineProperties(it,{typeName:{value:"X3DNurbsSurfaceGeometryNode",enumerable:!0},componentInfo:{value:Object.freeze({name:"NURBS",level:1}),enumerable:!0}});const nt=it;f().add("X3DNurbsSurfaceGeometryNode","x_ite/Components/NURBS/X3DNurbsSurfaceGeometryNode",nt);const ot=nt;function st(e){ot.call(this,e),this.addType(c().NurbsPatchSurface)}Object.setPrototypeOf(st.prototype,ot.prototype),Object.defineProperties(st,{typeName:{value:"NurbsPatchSurface",enumerable:!0},componentInfo:{value:Object.freeze({name:"NURBS",level:1}),enumerable:!0},containerField:{value:"geometry",enumerable:!0},specificationRange:{value:Object.freeze({from:"3.0",to:"Infinity"}),enumerable:!0},fieldDefinitions:{value:new(a())([new(r())(c().inputOutput,"metadata",new(o().SFNode)),new(r())(c().inputOutput,"uTessellation",new(o().SFInt32)),new(r())(c().inputOutput,"vTessellation",new(o().SFInt32)),new(r())(c().initializeOnly,"solid",new(o().SFBool)(!0)),new(r())(c().initializeOnly,"uClosed",new(o().SFBool)),new(r())(c().initializeOnly,"vClosed",new(o().SFBool)),new(r())(c().initializeOnly,"uOrder",new(o().SFInt32)(3)),new(r())(c().initializeOnly,"vOrder",new(o().SFInt32)(3)),new(r())(c().initializeOnly,"uDimension",new(o().SFInt32)),new(r())(c().initializeOnly,"vDimension",new(o().SFInt32)),new(r())(c().initializeOnly,"uKnot",new(o().MFDouble)),new(r())(c().initializeOnly,"vKnot",new(o().MFDouble)),new(r())(c().inputOutput,"weight",new(o().MFDouble)),new(r())(c().inputOutput,"texCoord",new(o().SFNode)),new(r())(c().inputOutput,"controlPoint",new(o().SFNode))]),enumerable:!0}});const rt=st;f().add("NurbsPatchSurface","x_ite/Components/NURBS/NurbsPatchSurface",rt);const lt=rt,at=window[Symbol.for("X_ITE.X3D-9.6.3")].require("x_ite/Components/Interpolation/PositionInterpolator");var ut=e.n(at);function ht(e){Me().call(this,e),this.addType(c().NurbsPositionInterpolator),this.addChildObjects(c().inputOutput,"rebuild",new(o().SFTime)),this.interpolator=new(ut())(e),this.knots=[],this.weights=[],this.controlPoints=[],this.mesh={},this.sampleOptions={resolution:[128]}}Object.assign(Object.setPrototypeOf(ht.prototype,Me().prototype),{initialize(){Me().prototype.initialize.call(this),this._order.addInterest("requestRebuild",this),this._knot.addInterest("requestRebuild",this),this._weight.addInterest("requestRebuild",this),this._controlPoint.addInterest("set_controlPoint__",this),this._rebuild.addInterest("build",this),this._set_fraction.addFieldInterest(this.interpolator._set_fraction),this.interpolator._value_changed.addFieldInterest(this._value_changed),this.interpolator.setup(),this.set_controlPoint__()},set_controlPoint__(){this.controlPointNode&&this.controlPointNode.removeInterest("requestRebuild",this),this.controlPointNode=g()(c().X3DCoordinateNode,this._controlPoint),this.controlPointNode&&this.controlPointNode.addInterest("requestRebuild",this),this.requestRebuild()},getClosed:(e,t,i,n)=>!1,getKnots:(e,t,i,n,o)=>k.getKnots(e,t,i,n,o),getWeights:(e,t,i)=>k.getWeights(e,t,i),getControlPoints:(e,t,i,n,o)=>k.getControlPoints(e,t,i,n,o),requestRebuild(){this._rebuild.addEvent()},build(){if(this._order.getValue()<2)return;if(!this.controlPointNode)return;if(this.controlPointNode.getSize()<this._order.getValue())return;const e=this.getClosed(this._order.getValue(),this._knot,this._weight,this.controlPointNode),t=this.getWeights(this.weights,this.controlPointNode.getSize(),this._weight),i=this.getControlPoints(this.controlPoints,e,this._order.getValue(),t,this.controlPointNode),n=this.getKnots(this.knots,e,this._order.getValue(),this.controlPointNode.getSize(),this._knot),s=n.at(-1)-n[0],r=this._order.getValue()-1,l=this.surface=(this.surface||ke)({boundary:["open"],degree:[r],knots:[n],points:i,debug:!1});this.sampleOptions.haveWeights=!!t;const a=ke.sample(this.mesh,l,this.sampleOptions).points,u=this.interpolator;u._key.length=0,u._keyValue.length=0;for(let e=0,t=a.length;e<t;e+=3)u._key.push(n[0]+e/(t-3)*s),u._keyValue.push(new(o().SFVec3f)(a[e],a[e+1],a[e+2]))}}),Object.defineProperties(ht,{typeName:{value:"NurbsPositionInterpolator",enumerable:!0},componentInfo:{value:Object.freeze({name:"NURBS",level:1}),enumerable:!0},containerField:{value:"children",enumerable:!0},specificationRange:{value:Object.freeze({from:"3.0",to:"Infinity"}),enumerable:!0},fieldDefinitions:{value:new(a())([new(r())(c().inputOutput,"metadata",new(o().SFNode)),new(r())(c().inputOnly,"set_fraction",new(o().SFFloat)),new(r())(c().inputOutput,"order",new(o().SFInt32)(3)),new(r())(c().inputOutput,"knot",new(o().MFDouble)),new(r())(c().inputOutput,"weight",new(o().MFDouble)),new(r())(c().inputOutput,"controlPoint",new(o().SFNode)),new(r())(c().outputOnly,"value_changed",new(o().SFVec3f))]),enumerable:!0}});const dt=ht;f().add("NurbsPositionInterpolator","x_ite/Components/NURBS/NurbsPositionInterpolator",dt);const ct=dt,pt=window[Symbol.for("X_ITE.X3D-9.6.3")].require("x_ite/Components/Grouping/X3DBoundedObject");var gt=e.n(pt);function mt(e){Me().call(this,e),gt().call(this,e),this.addType(c().NurbsSet),this.geometryNodes=[]}function ft(e,t){const i=new Set(t);return e.filter((e=>!i.has(e)))}Object.assign(Object.setPrototypeOf(mt.prototype,Me().prototype),gt().prototype,{initialize(){Me().prototype.initialize.call(this),gt().prototype.initialize.call(this),this._tessellationScale.addInterest("set_tessellationScale__",this),this._addGeometry.addInterest("set_addGeometry__",this),this._removeGeometry.addInterest("set_removeGeometry__",this),this._geometry.addInterest("set_geometry__",this),this.set_geometry__()},getBBox(e,t){for(const t of this.geometryNodes)e.add(t.getBBox());return e},set_tessellationScale__(){const e=Math.max(0,this._tessellationScale.getValue());for(const t of this.geometryNodes)t.setTessellationScale(e)},set_addGeometry__(){this._addGeometry.setTainted(!0),this._addGeometry.assign(ft(this._addGeometry,this._geometry));for(const e of this._addGeometry)this._geometry.push(e);this._addGeometry.length=0,this._addGeometry.setTainted(!1)},set_removeGeometry__(){this._removeGeometry.setTainted(!0),this._geometry.assign(ft(this._geometry,this._removeGeometry)),this._removeGeometry.length=0,this._removeGeometry.setTainted(!1)},set_geometry__(){for(const e of this.geometryNodes)e.setTessellationScale(1);this.geometryNodes.length=0;for(const e of this._geometry){const t=g()(c().X3DNurbsSurfaceGeometryNode,e);t&&this.geometryNodes.push(t)}this.set_tessellationScale__()},dispose(){gt().prototype.dispose.call(this),Me().prototype.dispose.call(this)}}),Object.defineProperties(mt,{typeName:{value:"NurbsSet",enumerable:!0},componentInfo:{value:Object.freeze({name:"NURBS",level:2}),enumerable:!0},containerField:{value:"children",enumerable:!0},specificationRange:{value:Object.freeze({from:"3.0",to:"Infinity"}),enumerable:!0},fieldDefinitions:{value:new(a())([new(r())(c().inputOutput,"metadata",new(o().SFNode)),new(r())(c().inputOutput,"tessellationScale",new(o().SFFloat)(1)),new(r())(c().inputOutput,"visible",new(o().SFBool)(!0)),new(r())(c().inputOutput,"bboxDisplay",new(o().SFBool)),new(r())(c().initializeOnly,"bboxSize",new(o().SFVec3f)(-1,-1,-1)),new(r())(c().initializeOnly,"bboxCenter",new(o().SFVec3f)),new(r())(c().inputOnly,"addGeometry",new(o().MFNode)),new(r())(c().inputOnly,"removeGeometry",new(o().MFNode)),new(r())(c().inputOutput,"geometry",new(o().MFNode))]),enumerable:!0}});const _t=mt;f().add("NurbsSet","x_ite/Components/NURBS/NurbsSet",_t);const bt=_t,vt=window[Symbol.for("X_ITE.X3D-9.6.3")].require("standard/Math/Geometry/Line3");var wt=e.n(vt);const yt={isPointInTriangle(e,t,i,n){const o=(t.y-i.y)*(e.x-i.x)+(i.x-t.x)*(e.y-i.y);if(0==o)return!1;const s=((t.y-i.y)*(n.x-i.x)+(i.x-t.x)*(n.y-i.y))/o;if(s<0||s>1)return!1;const r=((i.y-e.y)*(n.x-i.x)+(e.x-i.x)*(n.y-i.y))/o;if(r<0||r>1)return!1;const l=1-s-r;return!(l<0||l>1)}};f().add("Triangle2","standard/Math/Geometry/Triangle2",yt);const Nt=yt;function Ct(e){Me().call(this,e),this.addType(c().NurbsSurfaceInterpolator),this.geometry=new lt(e)}Object.assign(Object.setPrototypeOf(Ct.prototype,Me().prototype),{initialize(){this._set_fraction.addInterest("set_fraction__",this),this._uOrder.addFieldInterest(this.geometry._uOrder),this._vOrder.addFieldInterest(this.geometry._vOrder),this._uDimension.addFieldInterest(this.geometry._uDimension),this._vDimension.addFieldInterest(this.geometry._vDimension),this._uKnot.addFieldInterest(this.geometry._uKnot),this._vKnot.addFieldInterest(this.geometry._vKnot),this._weight.addFieldInterest(this.geometry._weight),this._controlPoint.addFieldInterest(this.geometry._controlPoint),this.geometry._uTessellation=128,this.geometry._vTessellation=128,this.geometry._uOrder=this._uOrder,this.geometry._vOrder=this._vOrder,this.geometry._uDimension=this._uDimension,this.geometry._vDimension=this._vDimension,this.geometry._uKnot=this._uKnot,this.geometry._vKnot=this._vKnot,this.geometry._weight=this._weight,this.geometry._controlPoint=this._controlPoint,this.geometry.setup()},set_fraction__:(()=>{const e=new(S()),t=new(S()),i=new(S()),n=new(S()),o=new(wt())(S().Zero,S().zAxis),s={};return function(){const r=this._set_fraction.getValue(),l=this.geometry.getTexCoords(),a=this.geometry.getNormals(),u=this.geometry.getVertices();for(let h=0,d=0,c=l.length;h<c;h+=12,d+=9)if(e.set(l[h+0],l[h+1],0),t.set(l[h+4],l[h+5],0),i.set(l[h+7],l[h+9],0),Nt.isPointInTriangle(e,t,i,r)&&(o.set(n.set(r.x,r.y,0),S().zAxis),o.intersectsTriangle(e,t,i,s))){const e=s.u,t=s.v,i=s.t,n=new(S())(i*a[d+0]+e*a[d+3]+t*a[d+6],i*a[d+1]+e*a[d+4]+t*a[d+7],i*a[d+2]+e*a[d+5]+t*a[d+8]),o=new(S())(i*u[h+0]+e*u[h+4]+t*u[h+8],i*u[h+1]+e*u[h+5]+t*u[h+9],i*u[h+2]+e*u[h+6]+t*u[h+10]);this._normal_changed=n,this._position_changed=o}}})()}),Object.defineProperties(Ct,{typeName:{value:"NurbsSurfaceInterpolator",enumerable:!0},componentInfo:{value:Object.freeze({name:"NURBS",level:1}),enumerable:!0},containerField:{value:"children",enumerable:!0},specificationRange:{value:Object.freeze({from:"3.0",to:"Infinity"}),enumerable:!0},fieldDefinitions:{value:new(a())([new(r())(c().inputOutput,"metadata",new(o().SFNode)),new(r())(c().inputOnly,"set_fraction",new(o().SFVec2f)),new(r())(c().initializeOnly,"uOrder",new(o().SFInt32)(3)),new(r())(c().initializeOnly,"vOrder",new(o().SFInt32)(3)),new(r())(c().initializeOnly,"uDimension",new(o().SFInt32)),new(r())(c().initializeOnly,"vDimension",new(o().SFInt32)),new(r())(c().initializeOnly,"uKnot",new(o().MFDouble)),new(r())(c().initializeOnly,"vKnot",new(o().MFDouble)),new(r())(c().inputOutput,"weight",new(o().MFDouble)),new(r())(c().inputOutput,"controlPoint",new(o().SFNode)),new(r())(c().outputOnly,"normal_changed",new(o().SFVec3f)),new(r())(c().outputOnly,"position_changed",new(o().SFVec3f))]),enumerable:!0}});const Ot=Ct;f().add("NurbsSurfaceInterpolator","x_ite/Components/NURBS/NurbsSurfaceInterpolator",Ot);const St=Ot,Pt=window[Symbol.for("X_ITE.X3D-9.6.3")].require("x_ite/Components/Geometry3D/Extrusion");var Dt=e.n(Pt);function It(e){X.call(this,e),this.addType(c().NurbsSweptSurface),this.extrusion=new(Dt())(e)}Object.assign(Object.setPrototypeOf(It.prototype,X.prototype),{initialize(){X.prototype.initialize.call(this),this._crossSectionCurve.addInterest("set_crossSectionCurve__",this),this._trajectoryCurve.addInterest("set_trajectoryCurve__",this);const e=this.extrusion;e._beginCap=!1,e._endCap=!1,e._solid=!0,e._ccw=!0,e._convex=!0,e._creaseAngle=Math.PI,e.setup(),e._crossSection.setTainted(!0),e._spine.setTainted(!0),this.set_crossSectionCurve__(),this.set_trajectoryCurve__()},set_crossSectionCurve__(){this.crossSectionCurveNode&&this.crossSectionCurveNode.removeInterest("requestRebuild",this),this.crossSectionCurveNode=g()(c().X3DNurbsControlCurveNode,this._crossSectionCurve),this.crossSectionCurveNode&&this.crossSectionCurveNode.addInterest("requestRebuild",this)},set_trajectoryCurve__(){this.trajectoryCurveNode?._rebuild.removeInterest("requestRebuild",this),this.trajectoryCurveNode=g()(c().NurbsCurve,this._trajectoryCurve),this.trajectoryCurveNode?._rebuild.addInterest("requestRebuild",this)},build(){if(!this.crossSectionCurveNode)return;if(!this.trajectoryCurveNode)return;const e=this.extrusion;if(e._crossSection=this.crossSectionCurveNode.tessellate(0),e._spine=this.trajectoryCurveNode.tessellate(0),e.rebuild(),this.getColors().assign(e.getColors()),this.getTexCoords().assign(e.getTexCoords()),this.getNormals().assign(e.getNormals()),this.getVertices().assign(e.getVertices()),this.getMultiTexCoords().push(this.getTexCoords()),!this._ccw.getValue()){const e=this.getNormals();for(let t=0,i=e.length;t<i;++t)e[t]=-e[t]}this.setSolid(this._solid.getValue()),this.setCCW(this._ccw.getValue())}}),Object.defineProperties(It,{typeName:{value:"NurbsSweptSurface",enumerable:!0},componentInfo:{value:Object.freeze({name:"NURBS",level:3}),enumerable:!0},containerField:{value:"geometry",enumerable:!0},specificationRange:{value:Object.freeze({from:"3.0",to:"Infinity"}),enumerable:!0},fieldDefinitions:{value:new(a())([new(r())(c().inputOutput,"metadata",new(o().SFNode)),new(r())(c().initializeOnly,"solid",new(o().SFBool)(!0)),new(r())(c().initializeOnly,"ccw",new(o().SFBool)(!0)),new(r())(c().inputOutput,"crossSectionCurve",new(o().SFNode)),new(r())(c().inputOutput,"trajectoryCurve",new(o().SFNode))]),enumerable:!0}});const Ft=It;f().add("NurbsSweptSurface","x_ite/Components/NURBS/NurbsSweptSurface",Ft);const Rt=Ft;function zt(e){X.call(this,e),this.addType(c().NurbsSwungSurface),this.extrusion=new(Dt())(e)}Object.assign(Object.setPrototypeOf(zt.prototype,X.prototype),{initialize(){X.prototype.initialize.call(this),this._profileCurve.addInterest("set_profileCurve__",this),this._trajectoryCurve.addInterest("set_trajectoryCurve__",this);const e=this.extrusion;e._beginCap=!1,e._endCap=!1,e._solid=!0,e._ccw=!0,e._convex=!0,e._creaseAngle=Math.PI,e.setup(),e._crossSection.setTainted(!0),e._spine.setTainted(!0),this.set_profileCurve__(),this.set_trajectoryCurve__()},set_profileCurve__(){this.profileCurveNode&&this.profileCurveNode.removeInterest("requestRebuild",this),this.profileCurveNode=g()(c().X3DNurbsControlCurveNode,this._profileCurve),this.profileCurveNode&&this.profileCurveNode.addInterest("requestRebuild",this)},set_trajectoryCurve__(){this.trajectoryCurveNode&&this.trajectoryCurveNode.removeInterest("requestRebuild",this),this.trajectoryCurveNode=g()(c().X3DNurbsControlCurveNode,this._trajectoryCurve),this.trajectoryCurveNode&&this.trajectoryCurveNode.addInterest("requestRebuild",this)},build(){if(!this.profileCurveNode)return;if(!this.trajectoryCurveNode)return;const e=this.extrusion;if(e._crossSection=this.profileCurveNode.tessellate(0),e._spine=this.trajectoryCurveNode.tessellate(1),e.rebuild(),this.getColors().assign(e.getColors()),this.getTexCoords().assign(e.getTexCoords()),this.getNormals().assign(e.getNormals()),this.getVertices().assign(e.getVertices()),this.getMultiTexCoords().push(this.getTexCoords()),!this._ccw.getValue()){const e=this.getNormals();for(let t=0,i=e.length;t<i;++t)e[t]=-e[t]}this.setSolid(this._solid.getValue()),this.setCCW(this._ccw.getValue())}}),Object.defineProperties(zt,{typeName:{value:"NurbsSwungSurface",enumerable:!0},componentInfo:{value:Object.freeze({name:"NURBS",level:3}),enumerable:!0},containerField:{value:"geometry",enumerable:!0},specificationRange:{value:Object.freeze({from:"3.0",to:"Infinity"}),enumerable:!0},fieldDefinitions:{value:new(a())([new(r())(c().inputOutput,"metadata",new(o().SFNode)),new(r())(c().initializeOnly,"solid",new(o().SFBool)(!0)),new(r())(c().initializeOnly,"ccw",new(o().SFBool)(!0)),new(r())(c().inputOutput,"profileCurve",new(o().SFNode)),new(r())(c().inputOutput,"trajectoryCurve",new(o().SFNode))]),enumerable:!0}});const Vt=zt;f().add("NurbsSwungSurface","x_ite/Components/NURBS/NurbsSwungSurface",Vt);const Tt=Vt;function jt(e){h().call(this,e),this.addType(c().NurbsTextureCoordinate),this.controlPoints=[]}Object.assign(Object.setPrototypeOf(jt.prototype,h().prototype),{initialize(){h().prototype.initialize.call(this)},getControlPoints(e){const t=this._controlPoint.getValue(),i=this.controlPoints;for(let n=0,o=this._uDimension.getValue();n<o;++n){let s=i[n];s||(s=i[n]=[]);for(let i=0,r=this._vDimension.getValue();i<r;++i){const r=i*o+n,l=s[i]||new(j()),a=2*r;s[i]=l.set(t[a],t[a+1],0,e?e[r]:1)}}return i},isValid(){return!(this._uOrder.getValue()<2)&&(!(this._vOrder.getValue()<2)&&(!(this._uDimension.getValue()<this._uOrder.getValue())&&(!(this._vDimension.getValue()<this._vOrder.getValue())&&this._controlPoint.length===this._uDimension.getValue()*this._vDimension.getValue())))}}),Object.defineProperties(jt,{typeName:{value:"NurbsTextureCoordinate",enumerable:!0},componentInfo:{value:Object.freeze({name:"NURBS",level:1}),enumerable:!0},containerField:{value:"texCoord",enumerable:!0},specificationRange:{value:Object.freeze({from:"3.0",to:"Infinity"}),enumerable:!0},fieldDefinitions:{value:new(a())([new(r())(c().inputOutput,"metadata",new(o().SFNode)),new(r())(c().initializeOnly,"uOrder",new(o().SFInt32)(3)),new(r())(c().initializeOnly,"vOrder",new(o().SFInt32)(3)),new(r())(c().initializeOnly,"uDimension",new(o().SFInt32)),new(r())(c().initializeOnly,"vDimension",new(o().SFInt32)),new(r())(c().initializeOnly,"uKnot",new(o().MFDouble)),new(r())(c().initializeOnly,"vKnot",new(o().MFDouble)),new(r())(c().inputOutput,"weight",new(o().MFDouble)),new(r())(c().inputOutput,"controlPoint",new(o().MFVec2f))]),enumerable:!0}});const xt=jt;f().add("NurbsTextureCoordinate","x_ite/Components/NURBS/NurbsTextureCoordinate",xt);const kt=xt;function At(e){ot.call(this,e),this.addType(c().NurbsTrimmedSurface),this.trimmingContourNodes=[]}function Bt(e,t){const i=new Set(t);return e.filter((e=>!i.has(e)))}Object.assign(Object.setPrototypeOf(At.prototype,ot.prototype),{initialize(){ot.prototype.initialize.call(this),this._addTrimmingContour.addInterest("set_addTrimmingContour__",this),this._removeTrimmingContour.addInterest("set_removeTrimmingContour__",this),this._trimmingContour.addInterest("set_trimmingContour__",this),this.set_trimmingContour__()},set_addTrimmingContour__(){this._addTrimmingContour.setTainted(!0),this._addTrimmingContour.assign(Bt(this._addTrimmingContour,this._trimmingContour),this._addTrimmingContour.length);for(const e of this._addTrimmingContour)this._trimmingContour.push(e);this._addTrimmingContour.length=0,this._addTrimmingContour.setTainted(!1)},set_removeTrimmingContour__(){this._removeTrimmingContour.setTainted(!0),this._trimmingContour.assign(Bt(this._trimmingContour,this._removeTrimmingContour)),this._removeTrimmingContour.length=0,this._removeTrimmingContour.setTainted(!1)},set_trimmingContour__(){const e=this.trimmingContourNodes;e.length=0;for(const t of this._trimmingContour){const i=g()(c().Contour2D,t);i&&e.push(i)}},getTrimmingContours(){const e=this.trimmingContourNodes,t=[];for(const i of e)i.addTrimmingContour(t);return t}}),Object.defineProperties(At,{typeName:{value:"NurbsTrimmedSurface",enumerable:!0},componentInfo:{value:Object.freeze({name:"NURBS",level:4}),enumerable:!0},containerField:{value:"geometry",enumerable:!0},specificationRange:{value:Object.freeze({from:"3.0",to:"Infinity"}),enumerable:!0},fieldDefinitions:{value:new(a())([new(r())(c().inputOutput,"metadata",new(o().SFNode)),new(r())(c().inputOutput,"uTessellation",new(o().SFInt32)),new(r())(c().inputOutput,"vTessellation",new(o().SFInt32)),new(r())(c().initializeOnly,"solid",new(o().SFBool)(!0)),new(r())(c().initializeOnly,"uClosed",new(o().SFBool)),new(r())(c().initializeOnly,"vClosed",new(o().SFBool)),new(r())(c().initializeOnly,"uOrder",new(o().SFInt32)(3)),new(r())(c().initializeOnly,"vOrder",new(o().SFInt32)(3)),new(r())(c().initializeOnly,"uDimension",new(o().SFInt32)),new(r())(c().initializeOnly,"vDimension",new(o().SFInt32)),new(r())(c().initializeOnly,"uKnot",new(o().MFDouble)),new(r())(c().initializeOnly,"vKnot",new(o().MFDouble)),new(r())(c().inputOutput,"weight",new(o().MFDouble)),new(r())(c().inputOutput,"texCoord",new(o().SFNode)),new(r())(c().inputOutput,"controlPoint",new(o().SFNode)),new(r())(c().inputOnly,"addTrimmingContour",new(o().MFNode)),new(r())(c().inputOnly,"removeTrimmingContour",new(o().MFNode)),new(r())(c().inputOutput,"trimmingContour",new(o().MFNode))]),enumerable:!0}});const Xt=At;f().add("NurbsTrimmedSurface","x_ite/Components/NURBS/NurbsTrimmedSurface",Xt);const Et=Xt;i().add({name:"NURBS",concreteNodes:[w,I,Xe,qe,He,lt,ct,bt,St,Rt,Tt,kt,Et],abstractNodes:[C,ot,X]});const Ut=void 0;f().add("NURBS","assets/components/NURBS",Ut)})();
@@ -1,11 +1,11 @@
1
- /* X_ITE v9.6.1 */(() => { // webpackBootstrap
1
+ /* X_ITE v9.6.3 */(() => { // webpackBootstrap
2
2
  /******/ "use strict";
3
3
  /******/ var __webpack_modules__ = ({
4
4
 
5
5
  /***/ 823:
6
6
  /***/ ((module) => {
7
7
 
8
- module.exports = window [Symbol .for ("X_ITE.X3D-9.6.1")] .require ("lib/jquery");
8
+ module.exports = window [Symbol .for ("X_ITE.X3D-9.6.3")] .require ("lib/jquery");
9
9
 
10
10
  /***/ })
11
11
 
@@ -73,28 +73,28 @@ var __webpack_exports__ = {};
73
73
  // UNUSED EXPORTS: default
74
74
 
75
75
  ;// CONCATENATED MODULE: external "window [Symbol .for (\"X_ITE.X3D\")] .require (\"x_ite/Components\")"
76
- const Components_namespaceObject = window [Symbol .for ("X_ITE.X3D-9.6.1")] .require ("x_ite/Components");
76
+ const Components_namespaceObject = window [Symbol .for ("X_ITE.X3D-9.6.3")] .require ("x_ite/Components");
77
77
  var Components_default = /*#__PURE__*/__webpack_require__.n(Components_namespaceObject);
78
78
  ;// CONCATENATED MODULE: external "window [Symbol .for (\"X_ITE.X3D\")] .require (\"x_ite/Fields\")"
79
- const Fields_namespaceObject = window [Symbol .for ("X_ITE.X3D-9.6.1")] .require ("x_ite/Fields");
79
+ const Fields_namespaceObject = window [Symbol .for ("X_ITE.X3D-9.6.3")] .require ("x_ite/Fields");
80
80
  var Fields_default = /*#__PURE__*/__webpack_require__.n(Fields_namespaceObject);
81
81
  ;// CONCATENATED MODULE: external "window [Symbol .for (\"X_ITE.X3D\")] .require (\"x_ite/Base/X3DFieldDefinition\")"
82
- const X3DFieldDefinition_namespaceObject = window [Symbol .for ("X_ITE.X3D-9.6.1")] .require ("x_ite/Base/X3DFieldDefinition");
82
+ const X3DFieldDefinition_namespaceObject = window [Symbol .for ("X_ITE.X3D-9.6.3")] .require ("x_ite/Base/X3DFieldDefinition");
83
83
  var X3DFieldDefinition_default = /*#__PURE__*/__webpack_require__.n(X3DFieldDefinition_namespaceObject);
84
84
  ;// CONCATENATED MODULE: external "window [Symbol .for (\"X_ITE.X3D\")] .require (\"x_ite/Base/FieldDefinitionArray\")"
85
- const FieldDefinitionArray_namespaceObject = window [Symbol .for ("X_ITE.X3D-9.6.1")] .require ("x_ite/Base/FieldDefinitionArray");
85
+ const FieldDefinitionArray_namespaceObject = window [Symbol .for ("X_ITE.X3D-9.6.3")] .require ("x_ite/Base/FieldDefinitionArray");
86
86
  var FieldDefinitionArray_default = /*#__PURE__*/__webpack_require__.n(FieldDefinitionArray_namespaceObject);
87
87
  ;// CONCATENATED MODULE: external "window [Symbol .for (\"X_ITE.X3D\")] .require (\"x_ite/Components/Core/X3DNode\")"
88
- const X3DNode_namespaceObject = window [Symbol .for ("X_ITE.X3D-9.6.1")] .require ("x_ite/Components/Core/X3DNode");
88
+ const X3DNode_namespaceObject = window [Symbol .for ("X_ITE.X3D-9.6.3")] .require ("x_ite/Components/Core/X3DNode");
89
89
  var X3DNode_default = /*#__PURE__*/__webpack_require__.n(X3DNode_namespaceObject);
90
90
  ;// CONCATENATED MODULE: external "window [Symbol .for (\"X_ITE.X3D\")] .require (\"x_ite/Browser/ParticleSystems/GeometryTypes\")"
91
- const GeometryTypes_namespaceObject = window [Symbol .for ("X_ITE.X3D-9.6.1")] .require ("x_ite/Browser/ParticleSystems/GeometryTypes");
91
+ const GeometryTypes_namespaceObject = window [Symbol .for ("X_ITE.X3D-9.6.3")] .require ("x_ite/Browser/ParticleSystems/GeometryTypes");
92
92
  var GeometryTypes_default = /*#__PURE__*/__webpack_require__.n(GeometryTypes_namespaceObject);
93
93
  ;// CONCATENATED MODULE: external "window [Symbol .for (\"X_ITE.X3D\")] .require (\"x_ite/Base/X3DConstants\")"
94
- const X3DConstants_namespaceObject = window [Symbol .for ("X_ITE.X3D-9.6.1")] .require ("x_ite/Base/X3DConstants");
94
+ const X3DConstants_namespaceObject = window [Symbol .for ("X_ITE.X3D-9.6.3")] .require ("x_ite/Base/X3DConstants");
95
95
  var X3DConstants_default = /*#__PURE__*/__webpack_require__.n(X3DConstants_namespaceObject);
96
96
  ;// CONCATENATED MODULE: external "window [Symbol .for (\"X_ITE.X3D\")] .require (\"x_ite/Namespace\")"
97
- const Namespace_namespaceObject = window [Symbol .for ("X_ITE.X3D-9.6.1")] .require ("x_ite/Namespace");
97
+ const Namespace_namespaceObject = window [Symbol .for ("X_ITE.X3D-9.6.3")] .require ("x_ite/Namespace");
98
98
  var Namespace_default = /*#__PURE__*/__webpack_require__.n(Namespace_namespaceObject);
99
99
  ;// CONCATENATED MODULE: ./src/x_ite/Browser/ParticleSystems/Line3.glsl.js
100
100
  const __default__ = /* glsl */ `#if defined(X3D_BOUNDED_VOLUME)||defined(X3D_VOLUME_EMITTER)
@@ -686,7 +686,7 @@ const X3DParticleEmitterNode_default_ = X3DParticleEmitterNode;
686
686
  Namespace_default().add ("X3DParticleEmitterNode", "x_ite/Components/ParticleSystems/X3DParticleEmitterNode", X3DParticleEmitterNode_default_);
687
687
  /* harmony default export */ const ParticleSystems_X3DParticleEmitterNode = (X3DParticleEmitterNode_default_);
688
688
  ;// CONCATENATED MODULE: external "window [Symbol .for (\"X_ITE.X3D\")] .require (\"standard/Math/Numbers/Vector3\")"
689
- const Vector3_namespaceObject = window [Symbol .for ("X_ITE.X3D-9.6.1")] .require ("standard/Math/Numbers/Vector3");
689
+ const Vector3_namespaceObject = window [Symbol .for ("X_ITE.X3D-9.6.3")] .require ("standard/Math/Numbers/Vector3");
690
690
  var Vector3_default = /*#__PURE__*/__webpack_require__.n(Vector3_namespaceObject);
691
691
  ;// CONCATENATED MODULE: ./src/x_ite/Components/ParticleSystems/PointEmitter.js
692
692
  /*******************************************************************************
@@ -1023,7 +1023,7 @@ const X3DParticlePhysicsModelNode_default_ = X3DParticlePhysicsModelNode;
1023
1023
  Namespace_default().add ("X3DParticlePhysicsModelNode", "x_ite/Components/ParticleSystems/X3DParticlePhysicsModelNode", X3DParticlePhysicsModelNode_default_);
1024
1024
  /* harmony default export */ const ParticleSystems_X3DParticlePhysicsModelNode = (X3DParticlePhysicsModelNode_default_);
1025
1025
  ;// CONCATENATED MODULE: external "window [Symbol .for (\"X_ITE.X3D\")] .require (\"x_ite/Base/X3DCast\")"
1026
- const X3DCast_namespaceObject = window [Symbol .for ("X_ITE.X3D-9.6.1")] .require ("x_ite/Base/X3DCast");
1026
+ const X3DCast_namespaceObject = window [Symbol .for ("X_ITE.X3D-9.6.3")] .require ("x_ite/Base/X3DCast");
1027
1027
  var X3DCast_default = /*#__PURE__*/__webpack_require__.n(X3DCast_namespaceObject);
1028
1028
  ;// CONCATENATED MODULE: ./src/x_ite/Components/ParticleSystems/BoundedPhysicsModel.js
1029
1029
  /*******************************************************************************
@@ -1640,34 +1640,34 @@ const ForcePhysicsModel_default_ = ForcePhysicsModel;
1640
1640
  Namespace_default().add ("ForcePhysicsModel", "x_ite/Components/ParticleSystems/ForcePhysicsModel", ForcePhysicsModel_default_);
1641
1641
  /* harmony default export */ const ParticleSystems_ForcePhysicsModel = (ForcePhysicsModel_default_);
1642
1642
  ;// CONCATENATED MODULE: external "window [Symbol .for (\"X_ITE.X3D\")] .require (\"x_ite/Components/Shape/X3DShapeNode\")"
1643
- const X3DShapeNode_namespaceObject = window [Symbol .for ("X_ITE.X3D-9.6.1")] .require ("x_ite/Components/Shape/X3DShapeNode");
1643
+ const X3DShapeNode_namespaceObject = window [Symbol .for ("X_ITE.X3D-9.6.3")] .require ("x_ite/Components/Shape/X3DShapeNode");
1644
1644
  var X3DShapeNode_default = /*#__PURE__*/__webpack_require__.n(X3DShapeNode_namespaceObject);
1645
1645
  ;// CONCATENATED MODULE: external "window [Symbol .for (\"X_ITE.X3D\")] .require (\"x_ite/Browser/Rendering/GeometryContext\")"
1646
- const GeometryContext_namespaceObject = window [Symbol .for ("X_ITE.X3D-9.6.1")] .require ("x_ite/Browser/Rendering/GeometryContext");
1646
+ const GeometryContext_namespaceObject = window [Symbol .for ("X_ITE.X3D-9.6.3")] .require ("x_ite/Browser/Rendering/GeometryContext");
1647
1647
  var GeometryContext_default = /*#__PURE__*/__webpack_require__.n(GeometryContext_namespaceObject);
1648
1648
  ;// CONCATENATED MODULE: external "window [Symbol .for (\"X_ITE.X3D\")] .require (\"x_ite/Rendering/VertexArray\")"
1649
- const VertexArray_namespaceObject = window [Symbol .for ("X_ITE.X3D-9.6.1")] .require ("x_ite/Rendering/VertexArray");
1649
+ const VertexArray_namespaceObject = window [Symbol .for ("X_ITE.X3D-9.6.3")] .require ("x_ite/Rendering/VertexArray");
1650
1650
  var VertexArray_default = /*#__PURE__*/__webpack_require__.n(VertexArray_namespaceObject);
1651
1651
  ;// CONCATENATED MODULE: external "window [Symbol .for (\"X_ITE.X3D\")] .require (\"x_ite/Rendering/TraverseType\")"
1652
- const TraverseType_namespaceObject = window [Symbol .for ("X_ITE.X3D-9.6.1")] .require ("x_ite/Rendering/TraverseType");
1652
+ const TraverseType_namespaceObject = window [Symbol .for ("X_ITE.X3D-9.6.3")] .require ("x_ite/Rendering/TraverseType");
1653
1653
  var TraverseType_default = /*#__PURE__*/__webpack_require__.n(TraverseType_namespaceObject);
1654
1654
  ;// CONCATENATED MODULE: external "window [Symbol .for (\"X_ITE.X3D\")] .require (\"x_ite/Browser/Shape/AlphaMode\")"
1655
- const AlphaMode_namespaceObject = window [Symbol .for ("X_ITE.X3D-9.6.1")] .require ("x_ite/Browser/Shape/AlphaMode");
1655
+ const AlphaMode_namespaceObject = window [Symbol .for ("X_ITE.X3D-9.6.3")] .require ("x_ite/Browser/Shape/AlphaMode");
1656
1656
  var AlphaMode_default = /*#__PURE__*/__webpack_require__.n(AlphaMode_namespaceObject);
1657
1657
  ;// CONCATENATED MODULE: external "window [Symbol .for (\"X_ITE.X3D\")] .require (\"x_ite/Components/Rendering/LineSet\")"
1658
- const LineSet_namespaceObject = window [Symbol .for ("X_ITE.X3D-9.6.1")] .require ("x_ite/Components/Rendering/LineSet");
1658
+ const LineSet_namespaceObject = window [Symbol .for ("X_ITE.X3D-9.6.3")] .require ("x_ite/Components/Rendering/LineSet");
1659
1659
  var LineSet_default = /*#__PURE__*/__webpack_require__.n(LineSet_namespaceObject);
1660
1660
  ;// CONCATENATED MODULE: external "window [Symbol .for (\"X_ITE.X3D\")] .require (\"x_ite/Components/Rendering/Coordinate\")"
1661
- const Coordinate_namespaceObject = window [Symbol .for ("X_ITE.X3D-9.6.1")] .require ("x_ite/Components/Rendering/Coordinate");
1661
+ const Coordinate_namespaceObject = window [Symbol .for ("X_ITE.X3D-9.6.3")] .require ("x_ite/Components/Rendering/Coordinate");
1662
1662
  var Coordinate_default = /*#__PURE__*/__webpack_require__.n(Coordinate_namespaceObject);
1663
1663
  ;// CONCATENATED MODULE: external "window [Symbol .for (\"X_ITE.X3D\")] .require (\"standard/Math/Numbers/Matrix4\")"
1664
- const Matrix4_namespaceObject = window [Symbol .for ("X_ITE.X3D-9.6.1")] .require ("standard/Math/Numbers/Matrix4");
1664
+ const Matrix4_namespaceObject = window [Symbol .for ("X_ITE.X3D-9.6.3")] .require ("standard/Math/Numbers/Matrix4");
1665
1665
  var Matrix4_default = /*#__PURE__*/__webpack_require__.n(Matrix4_namespaceObject);
1666
1666
  ;// CONCATENATED MODULE: external "window [Symbol .for (\"X_ITE.X3D\")] .require (\"standard/Math/Numbers/Matrix3\")"
1667
- const Matrix3_namespaceObject = window [Symbol .for ("X_ITE.X3D-9.6.1")] .require ("standard/Math/Numbers/Matrix3");
1667
+ const Matrix3_namespaceObject = window [Symbol .for ("X_ITE.X3D-9.6.3")] .require ("standard/Math/Numbers/Matrix3");
1668
1668
  var Matrix3_default = /*#__PURE__*/__webpack_require__.n(Matrix3_namespaceObject);
1669
1669
  ;// CONCATENATED MODULE: external "window [Symbol .for (\"X_ITE.X3D\")] .require (\"standard/Math/Geometry/Plane3\")"
1670
- const Plane3_namespaceObject = window [Symbol .for ("X_ITE.X3D-9.6.1")] .require ("standard/Math/Geometry/Plane3");
1670
+ const Plane3_namespaceObject = window [Symbol .for ("X_ITE.X3D-9.6.3")] .require ("standard/Math/Geometry/Plane3");
1671
1671
  var Plane3_default = /*#__PURE__*/__webpack_require__.n(Plane3_namespaceObject);
1672
1672
  ;// CONCATENATED MODULE: ./src/standard/Math/Algorithms/QuickSort.js
1673
1673
  /*******************************************************************************
@@ -3327,7 +3327,7 @@ const ParticleSystem_default_ = ParticleSystem;
3327
3327
  Namespace_default().add ("ParticleSystem", "x_ite/Components/ParticleSystems/ParticleSystem", ParticleSystem_default_);
3328
3328
  /* harmony default export */ const ParticleSystems_ParticleSystem = (ParticleSystem_default_);
3329
3329
  ;// CONCATENATED MODULE: external "window [Symbol .for (\"X_ITE.X3D\")] .require (\"x_ite/Components/Rendering/IndexedLineSet\")"
3330
- const IndexedLineSet_namespaceObject = window [Symbol .for ("X_ITE.X3D-9.6.1")] .require ("x_ite/Components/Rendering/IndexedLineSet");
3330
+ const IndexedLineSet_namespaceObject = window [Symbol .for ("X_ITE.X3D-9.6.3")] .require ("x_ite/Components/Rendering/IndexedLineSet");
3331
3331
  var IndexedLineSet_default = /*#__PURE__*/__webpack_require__.n(IndexedLineSet_namespaceObject);
3332
3332
  ;// CONCATENATED MODULE: ./src/x_ite/Components/ParticleSystems/PolylineEmitter.js
3333
3333
  /*******************************************************************************
@@ -3608,7 +3608,7 @@ const PolylineEmitter_default_ = PolylineEmitter;
3608
3608
  Namespace_default().add ("PolylineEmitter", "x_ite/Components/ParticleSystems/PolylineEmitter", PolylineEmitter_default_);
3609
3609
  /* harmony default export */ const ParticleSystems_PolylineEmitter = (PolylineEmitter_default_);
3610
3610
  ;// CONCATENATED MODULE: external "window [Symbol .for (\"X_ITE.X3D\")] .require (\"standard/Math/Geometry/Triangle3\")"
3611
- const Triangle3_namespaceObject = window [Symbol .for ("X_ITE.X3D-9.6.1")] .require ("standard/Math/Geometry/Triangle3");
3611
+ const Triangle3_namespaceObject = window [Symbol .for ("X_ITE.X3D-9.6.3")] .require ("standard/Math/Geometry/Triangle3");
3612
3612
  var Triangle3_default = /*#__PURE__*/__webpack_require__.n(Triangle3_namespaceObject);
3613
3613
  ;// CONCATENATED MODULE: ./src/x_ite/Components/ParticleSystems/SurfaceEmitter.js
3614
3614
  /*******************************************************************************
@@ -3905,7 +3905,7 @@ const SurfaceEmitter_default_ = SurfaceEmitter;
3905
3905
  Namespace_default().add ("SurfaceEmitter", "x_ite/Components/ParticleSystems/SurfaceEmitter", SurfaceEmitter_default_);
3906
3906
  /* harmony default export */ const ParticleSystems_SurfaceEmitter = (SurfaceEmitter_default_);
3907
3907
  ;// CONCATENATED MODULE: external "window [Symbol .for (\"X_ITE.X3D\")] .require (\"x_ite/Components/Geometry3D/IndexedFaceSet\")"
3908
- const IndexedFaceSet_namespaceObject = window [Symbol .for ("X_ITE.X3D-9.6.1")] .require ("x_ite/Components/Geometry3D/IndexedFaceSet");
3908
+ const IndexedFaceSet_namespaceObject = window [Symbol .for ("X_ITE.X3D-9.6.3")] .require ("x_ite/Components/Geometry3D/IndexedFaceSet");
3909
3909
  var IndexedFaceSet_default = /*#__PURE__*/__webpack_require__.n(IndexedFaceSet_namespaceObject);
3910
3910
  ;// CONCATENATED MODULE: ./src/x_ite/Components/ParticleSystems/VolumeEmitter.js
3911
3911
  /*******************************************************************************
@@ -4250,7 +4250,7 @@ const VolumeEmitter_default_ = VolumeEmitter;
4250
4250
  Namespace_default().add ("VolumeEmitter", "x_ite/Components/ParticleSystems/VolumeEmitter", VolumeEmitter_default_);
4251
4251
  /* harmony default export */ const ParticleSystems_VolumeEmitter = (VolumeEmitter_default_);
4252
4252
  ;// CONCATENATED MODULE: external "window [Symbol .for (\"X_ITE.X3D\")] .require (\"standard/Math/Algorithm\")"
4253
- const Algorithm_namespaceObject = window [Symbol .for ("X_ITE.X3D-9.6.1")] .require ("standard/Math/Algorithm");
4253
+ const Algorithm_namespaceObject = window [Symbol .for ("X_ITE.X3D-9.6.3")] .require ("standard/Math/Algorithm");
4254
4254
  var Algorithm_default = /*#__PURE__*/__webpack_require__.n(Algorithm_namespaceObject);
4255
4255
  ;// CONCATENATED MODULE: ./src/x_ite/Components/ParticleSystems/WindPhysicsModel.js
4256
4256
  /*******************************************************************************