x_ite 5.0.3 → 6.1.0

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 (385) hide show
  1. package/.vscode/settings.json +12 -5
  2. package/.vscode/tasks.json +25 -1
  3. package/Makefile +36 -28
  4. package/README.md +6 -11
  5. package/build/bin/dist.pl +0 -6
  6. package/build/bin/examples-and-tests.pl +75 -0
  7. package/build/bin/tests-menu.pl +57 -0
  8. package/build/bin/version.pl +7 -4
  9. package/build/parts/default.start.frag.js +3 -2
  10. package/dist/assets/components/annotation.js +3 -2
  11. package/dist/assets/components/annotation.min.js +1 -1
  12. package/dist/assets/components/cad-geometry.js +3 -2
  13. package/dist/assets/components/cad-geometry.min.js +1 -1
  14. package/dist/assets/components/cube-map-texturing.js +8 -20
  15. package/dist/assets/components/cube-map-texturing.min.js +1 -1
  16. package/dist/assets/components/dis.js +3 -2
  17. package/dist/assets/components/dis.min.js +1 -1
  18. package/dist/assets/components/event-utilities.js +4 -3
  19. package/dist/assets/components/event-utilities.min.js +1 -1
  20. package/dist/assets/components/geometry2d.js +38 -52
  21. package/dist/assets/components/geometry2d.min.js +1 -1
  22. package/dist/assets/components/geospatial.js +34 -1686
  23. package/dist/assets/components/geospatial.min.js +1 -1
  24. package/dist/assets/components/h-anim.js +71 -77
  25. package/dist/assets/components/h-anim.min.js +1 -1
  26. package/dist/assets/components/key-device-sensor.js +4 -3
  27. package/dist/assets/components/key-device-sensor.min.js +1 -1
  28. package/dist/assets/components/layout.js +101 -173
  29. package/dist/assets/components/layout.min.js +1 -1
  30. package/dist/assets/components/nurbs.js +3 -2
  31. package/dist/assets/components/nurbs.min.js +1 -1
  32. package/dist/assets/components/particle-systems.js +1926 -1669
  33. package/dist/assets/components/particle-systems.min.js +1 -1
  34. package/dist/assets/components/picking.js +34 -41
  35. package/dist/assets/components/picking.min.js +1 -1
  36. package/dist/assets/components/projective-texture-mapping.js +73 -86
  37. package/dist/assets/components/projective-texture-mapping.min.js +1 -1
  38. package/dist/assets/components/rigid-body-physics.js +37 -57
  39. package/dist/assets/components/rigid-body-physics.min.js +1 -1
  40. package/dist/assets/components/scripting.js +3 -2
  41. package/dist/assets/components/scripting.min.js +1 -1
  42. package/dist/assets/components/texturing-3d.js +27 -33
  43. package/dist/assets/components/texturing-3d.min.js +3 -3
  44. package/dist/assets/components/volume-rendering.js +12 -11
  45. package/dist/assets/components/volume-rendering.min.js +1 -1
  46. package/dist/assets/components/x_ite.js +3 -2
  47. package/dist/assets/components/x_ite.min.js +1 -1
  48. package/dist/assets/images/Shading.png +0 -0
  49. package/dist/assets/linetype/1.png +0 -0
  50. package/dist/assets/linetype/10.png +0 -0
  51. package/dist/assets/linetype/11.png +0 -0
  52. package/dist/assets/linetype/12.png +0 -0
  53. package/dist/assets/linetype/13.png +0 -0
  54. package/dist/assets/linetype/14.png +0 -0
  55. package/dist/assets/linetype/15.png +0 -0
  56. package/dist/assets/linetype/16.png +0 -0
  57. package/dist/assets/linetype/2.png +0 -0
  58. package/dist/assets/linetype/3.png +0 -0
  59. package/dist/assets/linetype/4.png +0 -0
  60. package/dist/assets/linetype/5.png +0 -0
  61. package/dist/assets/linetype/6.png +0 -0
  62. package/dist/assets/linetype/7.png +0 -0
  63. package/dist/assets/linetype/8.png +0 -0
  64. package/dist/assets/linetype/9.png +0 -0
  65. package/dist/assets/shaders/webgl1/Gouraud.vs +1 -1
  66. package/dist/assets/shaders/webgl1/Line.fs +0 -21
  67. package/dist/assets/shaders/webgl1/Line.vs +0 -10
  68. package/dist/assets/shaders/webgl1/PBR.fs +1 -1
  69. package/dist/assets/shaders/webgl1/PBR.vs +1 -1
  70. package/dist/assets/shaders/webgl1/Phong.fs +1 -1
  71. package/dist/assets/shaders/webgl1/Point.vs +1 -1
  72. package/dist/assets/shaders/webgl2/Depth.vs +29 -1
  73. package/dist/assets/shaders/webgl2/Gouraud.vs +32 -4
  74. package/dist/assets/shaders/webgl2/Line.fs +24 -12
  75. package/dist/assets/shaders/webgl2/Line.vs +36 -11
  76. package/dist/assets/shaders/webgl2/LineTransform.fs +4 -0
  77. package/dist/assets/shaders/webgl2/LineTransform.vs +57 -0
  78. package/dist/assets/shaders/webgl2/PBR.fs +1 -1
  79. package/dist/assets/shaders/webgl2/PBR.vs +35 -7
  80. package/dist/assets/shaders/webgl2/Phong.fs +1 -1
  81. package/dist/assets/shaders/webgl2/Phong.vs +31 -3
  82. package/dist/assets/shaders/webgl2/Point.vs +30 -2
  83. package/dist/assets/shaders/webgl2/Unlit.vs +31 -3
  84. package/dist/example.html +6 -6
  85. package/dist/x_ite.css +199 -224
  86. package/dist/x_ite.js +16335 -15917
  87. package/dist/x_ite.min.js +17 -17
  88. package/dist/x_ite.zip +0 -0
  89. package/docs/404.md +6 -0
  90. package/docs/Accessing-the-External-Browser.md +21 -15
  91. package/docs/Browser-Support.md +6 -0
  92. package/docs/Custom-Shaders.md +18 -25
  93. package/docs/Features.md +11 -5
  94. package/docs/Gemfile +44 -0
  95. package/docs/Gemfile.lock +122 -0
  96. package/docs/Glossary.md +6 -0
  97. package/docs/How-To-Configure-Your-Web-Server.md +6 -0
  98. package/docs/Supported-Nodes.md +9 -1
  99. package/docs/What's-New.md +93 -39
  100. package/docs/XHTML-DOM-Integration.md +6 -0
  101. package/docs/_config.yml +2 -2
  102. package/docs/assets/css/main.scss +26 -0
  103. package/docs/index.md +42 -50
  104. package/docs/reference/Browser-Services.md +9 -3
  105. package/docs/reference/Constants-Services.md +6 -0
  106. package/docs/reference/ECMAScript-Object-and-Function-Definitions.md +12 -6
  107. package/docs/reference/Field-Services-and-Objects.md +105 -1
  108. package/docs/reference/Prototype-Services.md +11 -0
  109. package/docs/reference/Route-Services.md +9 -0
  110. package/docs/reference/Scene-Services.md +17 -2
  111. package/docs/reference/Script-Node-Authoring-Interface.md +7 -1
  112. package/docs/tutorials/Adding-backgrounds.md +6 -0
  113. package/docs/tutorials/Adding-fog.md +6 -0
  114. package/docs/tutorials/Adding-sound.md +6 -0
  115. package/docs/tutorials/Animating-transforms.md +6 -0
  116. package/docs/tutorials/Basic-Nodes.md +6 -0
  117. package/docs/tutorials/Building-a-X3D-world.md +6 -0
  118. package/docs/tutorials/Building-elevation-grids.md +6 -0
  119. package/docs/tutorials/Building-extruded-shapes.md +6 -0
  120. package/docs/tutorials/Building-primitive-shapes.md +6 -0
  121. package/docs/tutorials/Building-shapes-out-of-points,-lines,-and-faces.md +6 -0
  122. package/docs/tutorials/Controlling-appearance-with-materials.md +6 -0
  123. package/docs/tutorials/Controlling-color-on-coordinate-based-geometry.md +6 -0
  124. package/docs/tutorials/Controlling-detail.md +6 -0
  125. package/docs/tutorials/Controlling-how-textures-are-mapped.md +6 -0
  126. package/docs/tutorials/Controlling-navigation.md +6 -0
  127. package/docs/tutorials/Controlling-shading-on-coordinate-based-geometry.md +6 -0
  128. package/docs/tutorials/Controlling-the-viewpoint.md +6 -0
  129. package/docs/tutorials/Creating-new-node-types.md +6 -0
  130. package/docs/tutorials/Grouping-nodes.md +6 -0
  131. package/docs/tutorials/Hello,-World!.md +6 -0
  132. package/docs/tutorials/Improving-Performance.md +6 -0
  133. package/docs/tutorials/Increasing-Rendering-Speed.md +6 -0
  134. package/docs/tutorials/Introducing-X3D.md +6 -0
  135. package/docs/tutorials/Introducing-animation.md +6 -0
  136. package/docs/tutorials/Introducing-script-use.md +6 -0
  137. package/docs/tutorials/Lighting-your-world.md +6 -0
  138. package/docs/tutorials/Mapping-textures.md +6 -0
  139. package/docs/tutorials/Naming-nodes.md +6 -0
  140. package/docs/tutorials/Providing-information-about-your-world.md +6 -0
  141. package/docs/tutorials/Sensing-the-viewer.md +6 -0
  142. package/docs/tutorials/Sensing-viewer-actions.md +6 -0
  143. package/docs/tutorials/Transforming-Shapes.md +6 -0
  144. package/docs/tutorials/Writing-program-scripts-with-ECMAScript.md +6 -0
  145. package/docs/tutorials/index.md +42 -36
  146. package/package.json +6 -7
  147. package/src/assets/components/geometry2d.js +1 -1
  148. package/src/assets/components/key-device-sensor.js +1 -1
  149. package/src/assets/components/layout.js +1 -1
  150. package/src/assets/components/particle-systems.js +1 -1
  151. package/src/assets/components/volume-rendering.js +1 -1
  152. package/src/assets/images/Shading.png +0 -0
  153. package/src/assets/linetype/1.png +0 -0
  154. package/src/assets/linetype/10.png +0 -0
  155. package/src/assets/linetype/11.png +0 -0
  156. package/src/assets/linetype/12.png +0 -0
  157. package/src/assets/linetype/13.png +0 -0
  158. package/src/assets/linetype/14.png +0 -0
  159. package/src/assets/linetype/15.png +0 -0
  160. package/src/assets/linetype/16.png +0 -0
  161. package/src/assets/linetype/2.png +0 -0
  162. package/src/assets/linetype/3.png +0 -0
  163. package/src/assets/linetype/4.png +0 -0
  164. package/src/assets/linetype/5.png +0 -0
  165. package/src/assets/linetype/6.png +0 -0
  166. package/src/assets/linetype/7.png +0 -0
  167. package/src/assets/linetype/8.png +0 -0
  168. package/src/assets/linetype/9.png +0 -0
  169. package/src/assets/shaders/Types.glsl +1 -9
  170. package/src/assets/shaders/webgl1/Gouraud.fs +1 -1
  171. package/src/assets/shaders/webgl1/Gouraud.vs +2 -3
  172. package/src/assets/shaders/webgl1/Line.fs +3 -28
  173. package/src/assets/shaders/webgl1/Line.vs +6 -20
  174. package/src/assets/shaders/webgl1/PBR.fs +6 -6
  175. package/src/assets/shaders/webgl1/PBR.vs +1 -1
  176. package/src/assets/shaders/webgl1/Phong.fs +10 -10
  177. package/src/assets/shaders/webgl1/Point.vs +2 -2
  178. package/src/assets/shaders/webgl1/Unlit.fs +4 -4
  179. package/src/assets/shaders/webgl1/include/Normal.glsl +1 -1
  180. package/src/assets/shaders/webgl1/include/Texture.glsl +3 -8
  181. package/src/assets/shaders/webgl2/Depth.vs +4 -1
  182. package/src/assets/shaders/webgl2/Gouraud.fs +1 -1
  183. package/src/assets/shaders/webgl2/Gouraud.vs +8 -6
  184. package/src/assets/shaders/webgl2/Line.fs +11 -17
  185. package/src/assets/shaders/webgl2/Line.vs +17 -21
  186. package/src/assets/shaders/webgl2/LineTransform.fs +6 -0
  187. package/src/assets/shaders/webgl2/LineTransform.vs +77 -0
  188. package/src/assets/shaders/webgl2/PBR.fs +6 -6
  189. package/src/assets/shaders/webgl2/PBR.vs +10 -7
  190. package/src/assets/shaders/webgl2/Phong.fs +11 -11
  191. package/src/assets/shaders/webgl2/Phong.vs +6 -3
  192. package/src/assets/shaders/webgl2/Point.vs +5 -4
  193. package/src/assets/shaders/webgl2/Unlit.fs +5 -5
  194. package/src/assets/shaders/webgl2/Unlit.vs +6 -3
  195. package/src/assets/shaders/webgl2/include/Line2.glsl +20 -0
  196. package/src/assets/shaders/webgl2/include/Normal.glsl +1 -1
  197. package/src/assets/shaders/webgl2/include/Particle.glsl +36 -0
  198. package/src/assets/shaders/webgl2/include/Texture.glsl +3 -3
  199. package/src/example.html +6 -6
  200. package/src/examples.js +5 -4
  201. package/src/standard/Math/Algorithm.js +12 -28
  202. package/src/standard/Math/Geometry/Line2.js +163 -0
  203. package/src/standard/Math/Geometry/Line3.js +3 -5
  204. package/src/standard/Math/Geometry/Plane3.js +0 -2
  205. package/src/standard/Math/Geometry/Triangle3.js +1 -1
  206. package/src/standard/Math/Geometry/ViewVolume.js +121 -103
  207. package/src/standard/Math/Numbers/Color3.js +6 -0
  208. package/src/standard/Math/Numbers/Color4.js +7 -0
  209. package/src/standard/Math/Numbers/Complex.js +48 -34
  210. package/src/standard/Math/Numbers/Matrix2.js +62 -2
  211. package/src/standard/Math/Numbers/Matrix3.js +129 -110
  212. package/src/standard/Math/Numbers/Matrix4.js +138 -119
  213. package/src/standard/Math/Numbers/Quaternion.js +12 -5
  214. package/src/standard/Math/Numbers/Rotation4.js +8 -1
  215. package/src/standard/Math/Numbers/Vector2.js +42 -9
  216. package/src/standard/Math/Numbers/Vector3.js +50 -14
  217. package/src/standard/Math/Numbers/Vector4.js +48 -11
  218. package/src/standard/Math/Utility/BVH.js +45 -17
  219. package/src/tests.js +68 -66
  220. package/src/x_ite/Base/X3DBaseNode.js +22 -11
  221. package/src/x_ite/Base/X3DField.js +1 -1
  222. package/src/x_ite/Browser/Core/BrowserOptions.js +24 -143
  223. package/src/x_ite/Browser/Core/BrowserTimings.js +6 -4
  224. package/src/x_ite/Browser/Core/Context.js +185 -0
  225. package/src/x_ite/Browser/Core/ContextMenu.js +398 -211
  226. package/src/x_ite/Browser/Core/Notification.js +1 -0
  227. package/src/x_ite/Browser/Core/X3DCoreContext.js +35 -146
  228. package/src/x_ite/Browser/Followers/X3DArrayFollowerTemplate.js +1 -1
  229. package/src/x_ite/Browser/Geometry2D/Disk2DOptions.js +1 -0
  230. package/src/x_ite/Browser/Geometry2D/X3DGeometry2DContext.js +2 -2
  231. package/src/x_ite/Browser/Geometry3D/X3DGeometry3DContext.js +41 -2
  232. package/src/x_ite/Browser/Geospatial/Geocentric.js +2 -2
  233. package/src/x_ite/Browser/Interpolation/CatmullRomSplineInterpolatorTemplate.js +1 -1
  234. package/src/x_ite/Browser/Layout/ScreenText.js +18 -65
  235. package/src/x_ite/Browser/Layout/X3DLayoutContext.js +59 -16
  236. package/src/x_ite/Browser/Navigation/ExamineViewer.js +13 -20
  237. package/src/x_ite/Browser/Navigation/LookAtViewer.js +1 -4
  238. package/src/x_ite/Browser/Navigation/PlaneViewer.js +0 -3
  239. package/src/x_ite/Browser/Navigation/X3DFlyViewer.js +15 -8
  240. package/src/x_ite/Browser/Navigation/X3DViewer.js +12 -20
  241. package/src/x_ite/Browser/Networking/X3DNetworkingContext.js +11 -7
  242. package/src/x_ite/Browser/ParticleSystems/BVH.glsl +183 -0
  243. package/src/x_ite/Browser/ParticleSystems/Box3.glsl +47 -0
  244. package/src/x_ite/Browser/ParticleSystems/GeometryTypes.js +66 -0
  245. package/src/x_ite/Browser/ParticleSystems/Line3.glsl +55 -0
  246. package/src/x_ite/Browser/ParticleSystems/Plane3.glsl +160 -0
  247. package/src/x_ite/Browser/PointingDeviceSensor/PointingDevice.js +27 -3
  248. package/src/x_ite/Browser/PointingDeviceSensor/X3DPointingDeviceSensorContext.js +41 -37
  249. package/src/x_ite/Browser/Rendering/X3DRenderingContext.js +21 -13
  250. package/src/x_ite/Browser/Shaders/Shader.js +33 -12
  251. package/src/x_ite/Browser/Shaders/ShaderSource.js +6 -0
  252. package/src/x_ite/Browser/Shaders/ShaderTest.js +16 -10
  253. package/src/x_ite/Browser/Shape/X3DShapeContext.js +50 -9
  254. package/src/x_ite/Browser/Text/X3DTextContext.js +4 -13
  255. package/src/x_ite/Browser/Text/X3DTextGeometry.js +2 -1
  256. package/src/x_ite/Browser/Texturing/X3DTexturingContext.js +71 -34
  257. package/src/x_ite/Browser/Texturing3D/DICOMParser.js +2 -2
  258. package/src/x_ite/Browser/Time/X3DTimeContext.js +4 -2
  259. package/src/x_ite/Browser/VERSION.js +1 -1
  260. package/src/x_ite/Browser/X3DBrowser.js +7 -6
  261. package/src/x_ite/Browser/X3DBrowserContext.js +43 -10
  262. package/src/x_ite/Components/Core/X3DNode.js +4 -0
  263. package/src/x_ite/Components/Core/X3DPrototypeInstance.js +0 -2
  264. package/src/x_ite/Components/CubeMapTexturing/ComposedCubeMapTexture.js +3 -4
  265. package/src/x_ite/Components/CubeMapTexturing/GeneratedCubeMapTexture.js +1 -12
  266. package/src/x_ite/Components/CubeMapTexturing/ImageCubeMapTexture.js +1 -2
  267. package/src/x_ite/Components/EnvironmentalEffects/TextureBackground.js +1 -1
  268. package/src/x_ite/Components/EnvironmentalEffects/X3DBackgroundNode.js +76 -77
  269. package/src/x_ite/Components/EnvironmentalEffects/X3DFogObject.js +2 -9
  270. package/src/x_ite/Components/EnvironmentalSensor/ProximitySensor.js +51 -65
  271. package/src/x_ite/Components/EventUtilities/X3DSequencerNode.js +1 -1
  272. package/src/x_ite/Components/Followers/ColorDamper.js +1 -1
  273. package/src/x_ite/Components/Followers/X3DChaserNode.js +18 -32
  274. package/src/x_ite/Components/Followers/X3DDamperNode.js +1 -6
  275. package/src/x_ite/Components/Followers/X3DFollowerNode.js +1 -1
  276. package/src/x_ite/Components/Geometry2D/Disk2D.js +30 -46
  277. package/src/x_ite/Components/Geometry2D/TriangleSet2D.js +1 -1
  278. package/src/x_ite/Components/Geometry3D/ElevationGrid.js +12 -4
  279. package/src/x_ite/Components/Geometry3D/IndexedFaceSet.js +4 -4
  280. package/src/x_ite/Components/Geospatial/GeoCoordinate.js +10 -27
  281. package/src/x_ite/Components/Geospatial/GeoLOD.js +1 -1
  282. package/src/x_ite/Components/Geospatial/GeoPositionInterpolator.js +5 -10
  283. package/src/x_ite/Components/Geospatial/GeoTouchSensor.js +9 -16
  284. package/src/x_ite/Components/Geospatial/GeoTransform.js +6 -18
  285. package/src/x_ite/Components/Geospatial/GeoViewpoint.js +26 -30
  286. package/src/x_ite/Components/Geospatial/X3DGeospatialObject.js +20 -27
  287. package/src/x_ite/Components/Grouping/X3DGroupingNode.js +8 -8
  288. package/src/x_ite/Components/Grouping/X3DTransformNode.js +0 -4
  289. package/src/x_ite/Components/HAnim/HAnimHumanoid.js +68 -75
  290. package/src/x_ite/Components/Interpolation/OrientationInterpolator.js +4 -11
  291. package/src/x_ite/Components/Interpolation/X3DInterpolatorNode.js +1 -1
  292. package/src/x_ite/Components/Layout/LayoutGroup.js +4 -9
  293. package/src/x_ite/Components/Layout/ScreenFontStyle.js +1 -1
  294. package/src/x_ite/Components/Layout/ScreenGroup.js +16 -80
  295. package/src/x_ite/Components/Lighting/DirectionalLight.js +28 -36
  296. package/src/x_ite/Components/Lighting/PointLight.js +32 -47
  297. package/src/x_ite/Components/Lighting/SpotLight.js +33 -48
  298. package/src/x_ite/Components/Navigation/Billboard.js +49 -56
  299. package/src/x_ite/Components/Navigation/LOD.js +2 -2
  300. package/src/x_ite/Components/Navigation/OrthoViewpoint.js +29 -30
  301. package/src/x_ite/Components/Navigation/Viewpoint.js +16 -20
  302. package/src/x_ite/Components/Navigation/X3DViewpointNode.js +82 -111
  303. package/src/x_ite/Components/Networking/Anchor.js +18 -7
  304. package/src/x_ite/Components/ParticleSystems/BoundedPhysicsModel.js +6 -6
  305. package/src/x_ite/Components/ParticleSystems/ConeEmitter.js +44 -36
  306. package/src/x_ite/Components/ParticleSystems/ExplosionEmitter.js +26 -17
  307. package/src/x_ite/Components/ParticleSystems/ForcePhysicsModel.js +20 -7
  308. package/src/x_ite/Components/ParticleSystems/ParticleSystem.js +463 -882
  309. package/src/x_ite/Components/ParticleSystems/PointEmitter.js +39 -35
  310. package/src/x_ite/Components/ParticleSystems/PolylineEmitter.js +112 -128
  311. package/src/x_ite/Components/ParticleSystems/SurfaceEmitter.js +105 -112
  312. package/src/x_ite/Components/ParticleSystems/VolumeEmitter.js +138 -176
  313. package/src/x_ite/Components/ParticleSystems/WindPhysicsModel.js +16 -11
  314. package/src/x_ite/Components/ParticleSystems/X3DParticleEmitterNode.js +807 -217
  315. package/src/x_ite/Components/Picking/LinePickSensor.js +31 -39
  316. package/src/x_ite/Components/PointingDeviceSensor/CylinderSensor.js +91 -108
  317. package/src/x_ite/Components/PointingDeviceSensor/PlaneSensor.js +56 -59
  318. package/src/x_ite/Components/PointingDeviceSensor/SphereSensor.js +54 -71
  319. package/src/x_ite/Components/PointingDeviceSensor/TouchSensor.js +8 -15
  320. package/src/x_ite/Components/ProjectiveTextureMapping/TextureProjectorParallel.js +43 -50
  321. package/src/x_ite/Components/ProjectiveTextureMapping/TextureProjectorPerspective.js +32 -39
  322. package/src/x_ite/Components/Rendering/ClipPlane.js +3 -11
  323. package/src/x_ite/Components/Rendering/Color.js +12 -24
  324. package/src/x_ite/Components/Rendering/ColorRGBA.js +13 -25
  325. package/src/x_ite/Components/Rendering/IndexedLineSet.js +26 -4
  326. package/src/x_ite/Components/Rendering/LineSet.js +35 -13
  327. package/src/x_ite/Components/Rendering/PointSet.js +35 -13
  328. package/src/x_ite/Components/Rendering/X3DComposedGeometryNode.js +13 -5
  329. package/src/x_ite/Components/Rendering/X3DGeometryNode.js +331 -387
  330. package/src/x_ite/Components/Rendering/X3DLineGeometryNode.js +350 -140
  331. package/src/x_ite/Components/Rendering/X3DPointGeometryNode.js +116 -126
  332. package/src/x_ite/Components/RigidBodyPhysics/DoubleAxisHingeJoint.js +24 -38
  333. package/src/x_ite/Components/RigidBodyPhysics/SingleAxisHingeJoint.js +10 -17
  334. package/src/x_ite/Components/Shaders/ComposedShader.js +35 -75
  335. package/src/x_ite/Components/Shaders/FloatVertexAttribute.js +8 -11
  336. package/src/x_ite/Components/Shaders/Matrix3VertexAttribute.js +10 -14
  337. package/src/x_ite/Components/Shaders/Matrix4VertexAttribute.js +10 -14
  338. package/src/x_ite/Components/Shaders/ShaderPart.js +1 -10
  339. package/src/x_ite/Components/Shaders/X3DProgrammableShaderObject.js +220 -210
  340. package/src/x_ite/Components/Shaders/X3DShaderNode.js +28 -10
  341. package/src/x_ite/Components/Shaders/X3DVertexAttributeNode.js +15 -1
  342. package/src/x_ite/Components/Shape/Appearance.js +37 -4
  343. package/src/x_ite/Components/Shape/FillProperties.js +12 -1
  344. package/src/x_ite/Components/Shape/LineProperties.js +33 -1
  345. package/src/x_ite/Components/Shape/PointProperties.js +24 -3
  346. package/src/x_ite/Components/Shape/Shape.js +30 -39
  347. package/src/x_ite/Components/Shape/TwoSidedMaterial.js +3 -1
  348. package/src/x_ite/Components/Sound/Sound.js +31 -41
  349. package/src/x_ite/Components/Text/Text.js +6 -20
  350. package/src/x_ite/Components/Texturing/ImageTexture.js +1 -1
  351. package/src/x_ite/Components/Texturing/MovieTexture.js +1 -1
  352. package/src/x_ite/Components/Texturing/PixelTexture.js +2 -2
  353. package/src/x_ite/Components/Texturing/TextureCoordinate.js +5 -5
  354. package/src/x_ite/Components/Texturing/TextureProperties.js +4 -4
  355. package/src/x_ite/Components/Texturing/X3DSingleTextureNode.js +5 -4
  356. package/src/x_ite/Components/Texturing/X3DTexture2DNode.js +24 -33
  357. package/src/x_ite/Components/Texturing3D/TextureCoordinate3D.js +5 -5
  358. package/src/x_ite/Components/Texturing3D/TextureCoordinate4D.js +5 -5
  359. package/src/x_ite/Components/Texturing3D/X3DTexture3DNode.js +12 -19
  360. package/src/x_ite/Components/VolumeRendering/X3DVolumeDataNode.js +8 -8
  361. package/src/x_ite/Components.js +2 -2
  362. package/src/x_ite/Fallback.js +9 -3
  363. package/src/x_ite/Fields/SFColor.js +4 -0
  364. package/src/x_ite/Fields/SFColorRGBA.js +4 -0
  365. package/src/x_ite/Fields/SFImage.js +2 -11
  366. package/src/x_ite/Fields/SFMatrixPrototypeTemplate.js +4 -0
  367. package/src/x_ite/Fields/SFRotation.js +4 -0
  368. package/src/x_ite/Fields/SFString.js +4 -0
  369. package/src/x_ite/Fields/SFVecPrototypeTemplate.js +22 -2
  370. package/src/x_ite/Parser/XMLParser.js +1 -1
  371. package/src/x_ite/Rendering/TextureBuffer.js +43 -36
  372. package/src/x_ite/Rendering/VertexArray.js +103 -0
  373. package/src/x_ite/Rendering/X3DRenderObject.js +127 -148
  374. package/src/x_ite/X3D.js +32 -26
  375. package/src/x_ite.config.js +0 -5
  376. package/src/x_ite.css +216 -175
  377. package/src/x_ite.html +15 -10
  378. package/src/x_ite.js +49 -1
  379. package/x_ite.min.html +15 -10
  380. package/dist/assets/hatching/0.png +0 -0
  381. package/dist/assets/linetype/0.png +0 -0
  382. package/src/assets/hatching/0.png +0 -0
  383. package/src/assets/linetype/0.png +0 -0
  384. package/src/spinner.css +0 -67
  385. package/src/x_ite/Browser/Shape/LineStipples.xcf +0 -0
@@ -50,22 +50,25 @@
50
50
  define ([
51
51
  "jquery",
52
52
  "x_ite/Base/X3DBaseNode",
53
+ "x_ite/Components/Geospatial/GeoViewpoint",
53
54
  "locale/gettext",
54
- "contextMenu",
55
55
  "lib/jquery.fullscreen-min",
56
+ "jquery-mousewheel",
56
57
  ],
57
58
  function ($,
58
59
  X3DBaseNode,
60
+ GeoViewpoint,
59
61
  _)
60
62
  {
61
63
  "use strict";
62
64
 
65
+ const _userMenu = Symbol ();
66
+
63
67
  function ContextMenu (executionContext)
64
68
  {
65
69
  X3DBaseNode .call (this, executionContext);
66
70
 
67
- this .userMenu = null;
68
- this .active = false;
71
+ this [_userMenu] = null;
69
72
  }
70
73
 
71
74
  ContextMenu .prototype = Object .assign (Object .create (X3DBaseNode .prototype),
@@ -89,146 +92,61 @@ function ($,
89
92
 
90
93
  const browser = this .getBrowser ();
91
94
 
92
- if (! browser .getBrowserOptions () .getContextMenu ())
93
- return;
94
-
95
- $.contextMenu ({
96
- selector: ".x_ite-private-browser-" + browser .getNumber (),
95
+ this .init ({
96
+ element: browser .getElement (),
97
+ appendTo: browser .getShadow (),
97
98
  build: this .build .bind (this),
98
99
  animation: {duration: 500, show: "fadeIn", hide: "fadeOut"},
99
- hideOnSecondTrigger: true,
100
- events:
101
- {
102
- show: function (options)
103
- {
104
- this .active = true;
105
-
106
- if (browser .getElement () .fullScreen ())
107
- {
108
- browser .getElement () .append (options .$menu);
109
-
110
- setTimeout (function ()
111
- {
112
- browser .getElement () .append (options .$layer .css ({
113
- position: "absolute",
114
- width: "100%",
115
- height: "100%",
116
- }));
117
- },
118
- 1);
119
- }
120
- },
121
- activated: function (options)
122
- {
123
- // Display submenus on left side if there is no space on right side.
124
-
125
- if (options .$menu .hasClass ("x_ite-private-menu-submenus-left"))
126
- {
127
- options .$menu .find (".context-menu-list") .each (function (i, e)
128
- {
129
- $(e) .css ("right", $(e) .parent () .parent () .css ("width"));
130
- });
131
- }
132
- else
133
- {
134
- options .$menu .find (".context-menu-list") .each (function (i, e)
135
- {
136
- $(e) .css ("left", (parseInt ($(e) .parent () .parent () .css ("width")) - 2) + "px");
137
- });
138
- }
139
-
140
- // If the submenu is higher than vh, add scrollbars.
141
- options .$menu .find (".context-menu-list") .each (function (i, e)
142
- {
143
- if ($(e) .height () > $(window) .height ())
144
- {
145
- $(e) .css ({
146
- "overflow-y": "scroll",
147
- "max-height": "100vh",
148
- });
149
- }
150
- });
151
-
152
- // If the submenu is higher than vh, reposition it.
153
- options .$menu .find (".context-menu-item") .on ("mouseenter", function (event)
154
- {
155
- event .stopImmediatePropagation ();
156
-
157
- const
158
- t = $(event .target),
159
- e = t .children (".context-menu-list");
160
-
161
- if (!e .length)
162
- return;
163
-
164
- e .css ("top", "");
165
-
166
- const bottom = e .offset () .top + e .height () - $(window) .scrollTop () - $(window) .height ();
167
-
168
- if (bottom > 0)
169
- e .offset ({ "top": e .offset () .top - bottom });
170
- });
171
- }
172
- .bind (this),
173
- hide: function (options)
174
- {
175
- this .active = false;
176
- }
177
- .bind (this),
178
- },
179
100
  });
180
101
  },
181
102
  getUserMenu: function ()
182
103
  {
183
- return this .userMenu;
104
+ return this [_userMenu];
184
105
  },
185
106
  setUserMenu: function (userMenu)
186
107
  {
187
- this .userMenu = userMenu;
108
+ this [_userMenu] = userMenu;
188
109
  },
189
- getActive: function ()
110
+ createUserMenu: function ()
190
111
  {
191
- return this .active;
112
+ const userMenu = { };
113
+
114
+ if (typeof this [_userMenu] === "function")
115
+ {
116
+ const menu = this [_userMenu] ();
117
+
118
+ if ($.isPlainObject (menu))
119
+ {
120
+ for (const key in menu)
121
+ userMenu ["user-" + key] = menu [key];
122
+ }
123
+ }
124
+
125
+ return userMenu;
192
126
  },
193
- build: function (trigger, event)
127
+ build: function (event)
194
128
  {
195
129
  const
196
130
  browser = this .getBrowser (),
197
131
  activeLayer = browser .getActiveLayer (),
198
132
  currentViewpoint = activeLayer ? activeLayer .getViewpoint () : null,
199
- currentViewer = browser ._viewer .getValue (),
200
- fullscreen = browser .getElement () .fullScreen (),
201
- leftSubMenus = $(document) .width () - event .pageX < 370;
133
+ fullscreen = browser .getElement () .fullScreen ();
134
+
135
+ if (! browser .getBrowserOptions () .getContextMenu ())
136
+ return;
202
137
 
203
138
  const menu = {
204
- className: "x_ite-private-menu x_ite-private-menu-title",
139
+ className: "x_ite-private-menu",
205
140
  items: {
141
+ "title": {
142
+ name: browser .getName () + " Browser v" + browser .getVersion (),
143
+ className: "context-menu-title context-menu-not-selectable",
144
+ },
206
145
  "separator0": "--------",
207
146
  "viewpoints": {
208
147
  name: _("Viewpoints"),
209
148
  className: "context-menu-icon x_ite-private-icon-viewpoint",
210
149
  items: this .getViewpoints (),
211
- callback: function (viewpoint)
212
- {
213
- if (! viewpoint)
214
- return;
215
-
216
- browser .bindViewpoint (browser .getActiveLayer (), viewpoint);
217
- browser .getSurface () .focus ();
218
- }
219
- .bind (this, currentViewpoint),
220
- },
221
- "separator1": "--------",
222
- "viewer": {
223
- name: _(this .getViewerName (currentViewer)),
224
- className: "context-menu-icon x_ite-private-icon-" + currentViewer .toLowerCase () + "-viewer",
225
- callback: function (viewer)
226
- {
227
- browser ._viewer = viewer;
228
- browser .getNotification () ._string = _(this .getViewerName (viewer));
229
- browser .getSurface () .focus ();
230
- }
231
- .bind (this, currentViewer),
232
150
  },
233
151
  "available-viewers": {
234
152
  name: _("Available Viewers"),
@@ -262,7 +180,26 @@ function ($,
262
180
  .bind (this),
263
181
  },
264
182
  },
265
- "separator2": "--------",
183
+ "display-rubberband": {
184
+ name: _("Display Rubberband"),
185
+ type: "checkbox",
186
+ selected: browser .getBrowserOption ("Rubberband"),
187
+ events: {
188
+ click: function (event)
189
+ {
190
+ const rubberband = $(event .target) .is (":checked");
191
+
192
+ browser .setBrowserOption ("Rubberband", rubberband);
193
+
194
+ if (rubberband)
195
+ browser .getNotification () ._string = _("Rubberband") + ": " + _("on");
196
+ else
197
+ browser .getNotification () ._string = _("Rubberband") + ": " + _("off");
198
+ }
199
+ .bind (this),
200
+ },
201
+ },
202
+ "separator1": "--------",
266
203
  "primitive-quality": {
267
204
  name: _("Primitive Quality"),
268
205
  className: "context-menu-icon x_ite-private-icon-primitive-quality",
@@ -359,25 +296,83 @@ function ($,
359
296
  },
360
297
  },
361
298
  },
362
- "display-rubberband": {
363
- name: _("Display Rubberband"),
364
- type: "checkbox",
365
- selected: browser .getBrowserOption ("Rubberband"),
366
- events: {
367
- click: function (event)
368
- {
369
- const rubberband = $(event .target) .is (":checked");
370
-
371
- browser .setBrowserOption ("Rubberband", rubberband);
372
-
373
- if (rubberband)
374
- browser .getNotification () ._string = _("Rubberband") + ": " + _("on");
375
- else
376
- browser .getNotification () ._string = _("Rubberband") + ": " + _("off");
377
- }
378
- .bind (this),
299
+ "shading": {
300
+ name: _("Shading"),
301
+ className: "context-menu-icon x_ite-private-icon-shading",
302
+ items: {
303
+ "point": {
304
+ name: _("Point"),
305
+ type: "radio",
306
+ radio: "shading",
307
+ selected: browser .getBrowserOption ("Shading") === "POINT",
308
+ events: {
309
+ click: function ()
310
+ {
311
+ browser .setBrowserOption ("Shading", "POINT");
312
+ browser .getNotification () ._string = _("Shading") + ": " + _("Point");
313
+ }
314
+ .bind (this),
315
+ },
316
+ },
317
+ "wireframe": {
318
+ name: _("Wireframe"),
319
+ type: "radio",
320
+ radio: "shading",
321
+ selected: browser .getBrowserOption ("Shading") === "WIREFRAME",
322
+ events: {
323
+ click: function ()
324
+ {
325
+ browser .setBrowserOption ("Shading", "WIREFRAME");
326
+ browser .getNotification () ._string = _("Shading") + ": " + _("Wireframe");
327
+ }
328
+ .bind (this),
329
+ },
330
+ },
331
+ "flat": {
332
+ name: _("Flat"),
333
+ type: "radio",
334
+ radio: "shading",
335
+ selected: browser .getBrowserOption ("Shading") === "FLAT",
336
+ events: {
337
+ click: function ()
338
+ {
339
+ browser .setBrowserOption ("Shading", "FLAT");
340
+ browser .getNotification () ._string = _("Shading") + ": " + _("Flat");
341
+ }
342
+ .bind (this),
343
+ },
344
+ },
345
+ "gouraud": {
346
+ name: _("Gouraud"),
347
+ type: "radio",
348
+ radio: "shading",
349
+ selected: browser .getBrowserOption ("Shading") === "GOURAUD",
350
+ events: {
351
+ click: function ()
352
+ {
353
+ browser .setBrowserOption ("Shading", "GOURAUD");
354
+ browser .getNotification () ._string = _("Shading") + ": " + _("Gouraud");
355
+ }
356
+ .bind (this),
357
+ },
358
+ },
359
+ "phong": {
360
+ name: _("Phong"),
361
+ type: "radio",
362
+ radio: "shading",
363
+ selected: browser .getBrowserOption ("Shading") === "PHONG",
364
+ events: {
365
+ click: function ()
366
+ {
367
+ browser .setBrowserOption ("Shading", "PHONG");
368
+ browser .getNotification () ._string = _("Shading") + ": " + _("Phong");
369
+ }
370
+ .bind (this),
371
+ },
372
+ },
379
373
  },
380
374
  },
375
+ "separator2": "--------",
381
376
  "browser-timings": {
382
377
  name: _("Browser Timings"),
383
378
  type: "checkbox",
@@ -393,7 +388,9 @@ function ($,
393
388
  },
394
389
  "fullscreen": {
395
390
  name: fullscreen ? _("Leave Fullscreen") : _("Fullscreen"),
396
- className: "context-menu-icon " + (fullscreen ? "x_ite-private-icon-leave-fullscreen" : "x_ite-private-icon-fullscreen"),
391
+ className: "context-menu-icon " + (fullscreen
392
+ ? "x_ite-private-icon-leave-fullscreen"
393
+ : "x_ite-private-icon-enter-fullscreen"),
397
394
  callback: function ()
398
395
  {
399
396
  browser .getElement () .toggleFullScreen ();
@@ -401,108 +398,100 @@ function ($,
401
398
  .bind (this),
402
399
  },
403
400
  "separator3": "--------",
404
- "world-info": {
405
- name: _("Show World Info"),
406
- className: "context-menu-icon x_ite-private-icon-world-info",
407
- callback: function ()
408
- {
409
- define .show ();
410
-
411
- require (["https://cdn.jsdelivr.net/gh/showdownjs/showdown@1.9.1/dist/showdown.min.js"], function (showdown)
412
- {
413
- define .hide ();
401
+ },
402
+ };
414
403
 
415
- browser .getElement () .find (".x_ite-private-world-info") .remove ();
404
+ Object .assign (menu .items, this .createUserMenu ());
416
405
 
417
- const
418
- converter = new showdown .Converter (),
419
- priv = browser .getElement () .find (".x_ite-private-browser"),
420
- overlay = $("<div></div>") .addClass ("x_ite-private-world-info-overlay") .appendTo (priv),
421
- div = $("<div></div>") .addClass ("x_ite-private-world-info") .appendTo (overlay),
422
- worldInfo = browser .getExecutionContext () .getWorldInfos () [0],
423
- title = worldInfo .title,
424
- info = worldInfo .info;
406
+ Object .assign (menu .items, {
407
+ "separator4": "--------",
408
+ "world-info": {
409
+ name: _("Show World Info"),
410
+ className: "context-menu-icon x_ite-private-icon-world-info",
411
+ callback: function ()
412
+ {
413
+ define .show ();
425
414
 
426
- converter .setOption ("omitExtraWLInCodeBlocks", true);
427
- converter .setOption ("simplifiedAutoLink", true);
428
- converter .setOption ("excludeTrailingPunctuationFromURLs", true);
429
- converter .setOption ("literalMidWordUnderscores", true);
430
- converter .setOption ("strikethrough", true);
431
- converter .setOption ("openLinksInNewWindow", false);
415
+ require (["https://cdn.jsdelivr.net/gh/showdownjs/showdown@1.9.1/dist/showdown.min.js"], function (showdown)
416
+ {
417
+ define .hide ();
432
418
 
433
- $("<div></div>") .addClass ("x_ite-private-world-info-top") .text ("World Info") .appendTo (div);
419
+ browser .getShadow () .find (".x_ite-private-world-info") .remove ();
434
420
 
435
- if (title .length)
436
- {
437
- $("<div></div>") .addClass ("x_ite-private-world-info-title") .text (title) .appendTo (div);
438
- }
421
+ const
422
+ converter = new showdown .Converter (),
423
+ priv = browser .getShadow () .find (".x_ite-private-browser"),
424
+ overlay = $("<div></div>") .addClass ("x_ite-private-world-info-overlay") .appendTo (priv),
425
+ div = $("<div></div>") .addClass ("x_ite-private-world-info") .appendTo (overlay),
426
+ worldInfo = browser .getExecutionContext () .getWorldInfos () [0],
427
+ title = worldInfo .title,
428
+ info = worldInfo .info;
429
+
430
+ converter .setOption ("omitExtraWLInCodeBlocks", true);
431
+ converter .setOption ("simplifiedAutoLink", true);
432
+ converter .setOption ("excludeTrailingPunctuationFromURLs", true);
433
+ converter .setOption ("literalMidWordUnderscores", true);
434
+ converter .setOption ("strikethrough", true);
435
+ converter .setOption ("openLinksInNewWindow", false);
436
+
437
+ $("<div></div>") .addClass ("x_ite-private-world-info-top") .text ("World Info") .appendTo (div);
438
+
439
+ if (title .length)
440
+ {
441
+ $("<div></div>") .addClass ("x_ite-private-world-info-title") .text (title) .appendTo (div);
442
+ }
439
443
 
440
- for (const line of info)
441
- {
442
- $("<div></div>") .addClass ("x_ite-private-world-info-info") .html (converter .makeHtml (line)) .appendTo (div);
443
- }
444
+ for (const line of info)
445
+ {
446
+ $("<div></div>") .addClass ("x_ite-private-world-info-info") .html (converter .makeHtml (line)) .appendTo (div);
447
+ }
444
448
 
445
- div .find ("a") .on ("click", function (event) { event .stopPropagation (); });
449
+ div .find ("a") .on ("click", function (event) { event .stopPropagation (); });
446
450
 
447
- // Open external link in new tab.
448
- div .find ("a[href^=http]") .each (function ()
449
- {
450
- if (this .href .indexOf (location .hostname) !== -1)
451
- return;
451
+ // Open external link in new tab.
452
+ div .find ("a[href^=http]") .each (function ()
453
+ {
454
+ if (this .href .indexOf (location .hostname) !== -1)
455
+ return;
452
456
 
453
- $(this) .attr ("target", "_blank");
454
- });
457
+ $(this) .attr ("target", "_blank");
458
+ });
455
459
 
456
- overlay .on ("click", function () { overlay .remove (); });
457
- })
458
- },
460
+ overlay .on ("click", function () { overlay .remove (); });
461
+ })
459
462
  },
460
- "about": {
461
- name: _("About X_ITE"),
462
- className: "context-menu-icon x_ite-private-icon-help-about",
463
- callback: function ()
464
- {
465
- window .open (browser .getProviderUrl ());
466
- },
463
+ },
464
+ "about": {
465
+ name: _("About X_ITE"),
466
+ className: "context-menu-icon x_ite-private-icon-help-about",
467
+ callback: function ()
468
+ {
469
+ window .open (browser .getProviderUrl ());
467
470
  },
468
471
  },
469
- };
470
-
471
- if (typeof this .userMenu === "function")
472
- {
473
- const userMenu = this .userMenu ();
474
-
475
- if ($.isPlainObject (userMenu))
476
- {
477
- Object .assign (menu .items, { "separator4": "--------" });
478
-
479
- for (const key in userMenu)
480
- menu .items ["user-" + key] = userMenu [key];
481
- }
482
- }
483
-
484
- if (leftSubMenus)
485
- menu .className += " x_ite-private-menu-submenus-left";
472
+ });
486
473
 
487
474
  if ($.isEmptyObject (menu .items .viewpoints .items))
488
- {
489
- delete menu .items ["separator0"];
490
475
  delete menu .items ["viewpoints"];
491
- }
492
476
 
493
477
  if (Object .keys (menu .items ["available-viewers"] .items) .length < 2)
494
478
  {
495
479
  delete menu .items ["available-viewers"];
496
480
  }
497
481
 
498
- if (!browser .getCurrentViewer () .match (/^(?:EXAMINE|FLY)$/) || (currentViewpoint && currentViewpoint .getTypeName () === "GeoViewpoint"))
482
+ if (! browser .getCurrentViewer () .match (/^(?:EXAMINE|FLY)$/) || (currentViewpoint instanceof GeoViewpoint))
499
483
  {
500
484
  delete menu .items ["straighten-horizon"];
501
485
  }
502
486
 
487
+ if (! browser .getDebug ())
488
+ {
489
+ delete menu .items ["shading"];
490
+ }
491
+
503
492
  const worldInfo = browser .getExecutionContext () .getWorldInfos () [0];
504
493
 
505
- if (!worldInfo || (worldInfo .title .length === 0 && worldInfo .info .length === 0))
494
+ if (! worldInfo || (worldInfo .title .length === 0 && worldInfo .info .length === 0))
506
495
  {
507
496
  delete menu .items ["world-info"];
508
497
  }
@@ -599,6 +588,204 @@ function ($,
599
588
  return _("None Viewer");
600
589
  }
601
590
  },
591
+ init: function (options)
592
+ {
593
+ this .show = this .createRoot .bind (this, options);
594
+
595
+ options .element .on ("contextmenu", this .show);
596
+ },
597
+ show: function (event)
598
+ { },
599
+ hide: function (event)
600
+ { },
601
+ createRoot: function (options, event)
602
+ {
603
+ const
604
+ menu = options .build (event),
605
+ level = 1;
606
+
607
+ if (! menu) return;
608
+
609
+ // Layer
610
+
611
+ const layer = $("<div></div>")
612
+ .addClass ("context-menu-layer")
613
+ .addClass (menu .className)
614
+ .appendTo (options .appendTo);
615
+
616
+ const hide = this .hide = function ()
617
+ {
618
+ delete this .hide;
619
+
620
+ layer .remove ();
621
+
622
+ ul [options .animation .hide] (options .animation .duration, function ()
623
+ {
624
+ ul .remove ();
625
+
626
+ if (options .events && typeof options .events .hide === "function")
627
+ options .events .hide ();
628
+ });
629
+
630
+ return false;
631
+ }
632
+ .bind (this);
633
+
634
+ // Menu
635
+
636
+ const
637
+ x = event .pageX - $(document) .scrollLeft (),
638
+ y = event .pageY - $(document) .scrollTop ();
639
+
640
+ const ul = $("<ul></ul>")
641
+ .hide ()
642
+ .addClass ("context-menu-list")
643
+ .addClass (menu .className)
644
+ .addClass ("context-menu-root")
645
+ .css ({ "left": x, "top": y })
646
+ .appendTo (options .appendTo);
647
+
648
+ for (const k in menu .items)
649
+ ul .append (this .createItem (menu .items [k], "context-menu-root", k, level + 1, hide));
650
+
651
+ ul [options .animation .show] (options .animation .duration);
652
+
653
+ // Reposition menu if to right or to low.
654
+
655
+ if (ul .offset () .left - $(document) .scrollLeft () + ul .outerWidth () > $(window) .width ())
656
+ ul .offset ({ "left": $(document) .scrollLeft () + Math .max (0, $(window) .width () - ul .outerWidth ()) });
657
+
658
+ if (ul .offset () .top - $(document) .scrollTop () + ul .outerHeight () > $(window) .height ())
659
+ ul .offset ({ "top": $(document) .scrollTop () + Math .max (0, $(window) .height () - ul .outerHeight ()) });
660
+
661
+ // Display submenus on the left or right side.
662
+ // If the submenu is higher than vh, add scrollbars.
663
+
664
+ ul .find ("ul") .each (function (i, e)
665
+ {
666
+ e = $(e);
667
+
668
+ const
669
+ width = e .outerWidth () + ul .outerWidth (),
670
+ position = ul .offset () .left - $(document) .scrollLeft () + width > $(window) .width () ? "right" : "left";
671
+
672
+ e .css ("width", e .outerWidth ());
673
+ e .css (position, e .parent () .closest ("ul") .width ());
674
+
675
+ if (e .outerHeight () >= $(window) .height ())
676
+ e .css ({ "max-height": "100vh", "overflow-y": "scroll" });
677
+ });
678
+
679
+ // If the submenu is higher than vh, reposition it.
680
+
681
+ ul .find ("li") .on ("mouseenter touchstart", function (event)
682
+ {
683
+ event .stopImmediatePropagation ();
684
+
685
+ const
686
+ t = $(event .target) .closest ("li"),
687
+ e = t .children ("ul");
688
+
689
+ if (! e .length)
690
+ return;
691
+
692
+ e .css ("top", "");
693
+
694
+ const bottom = e .offset () .top + e .outerHeight () - $(window) .scrollTop () - $(window) .height ();
695
+
696
+ if (bottom > 0)
697
+ e .offset ({ "top": e .offset () .top - bottom });
698
+ });
699
+
700
+ // Layer
701
+
702
+ layer .on ("click contextmenu", hide);
703
+ ul .on ("contextmenu", hide);
704
+
705
+ // Show
706
+
707
+ if (options .events && typeof options .events .show === "function")
708
+ options .events .show (ul);
709
+
710
+ return false;
711
+ },
712
+ createItem: function (item, parent, key, level, hide)
713
+ {
714
+ const li = $("<li></li>") .addClass ("context-menu-item");
715
+
716
+ switch (typeof item)
717
+ {
718
+ case "string":
719
+ {
720
+ if (item .match (/^-+$/))
721
+ li .addClass (["context-menu-separator", "context-menu-not-selectable"]);
722
+
723
+ break;
724
+ }
725
+ case "object":
726
+ {
727
+ if (item .className)
728
+ li .addClass (item .className);
729
+
730
+ switch (item .type)
731
+ {
732
+ case "radio":
733
+ case "checkbox":
734
+ {
735
+ const
736
+ label = $("<label></label>") .appendTo (li),
737
+ input = $("<input></input>") .appendTo (label);
738
+
739
+ input
740
+ .attr ("type", item .type)
741
+ .attr ("name", "context-menu-input-" + (item .radio || parent));
742
+
743
+ $("<span></span>") .text (item .name) .appendTo (label);
744
+
745
+ if (item .selected)
746
+ input .attr ("checked", "checked");
747
+
748
+ for (const k in item .events)
749
+ {
750
+ if (typeof item .events [k] === "function")
751
+ input .on (k, item .events [k]);
752
+ }
753
+
754
+ li .addClass ("context-menu-input");
755
+
756
+ break;
757
+ }
758
+ default:
759
+ {
760
+ if (item .name)
761
+ $("<span></span>") .text (item .name) .appendTo (li);
762
+
763
+ if (typeof item .callback === "function")
764
+ li .on ("click", item .callback) .on ("click", hide);
765
+
766
+ break;
767
+ }
768
+ }
769
+
770
+ break;
771
+ }
772
+ }
773
+
774
+ if (typeof item .items === "object" && level < 3)
775
+ {
776
+ const ul = $("<ul></ul>")
777
+ .addClass ("context-menu-list")
778
+ .css ({ "z-index": level })
779
+ .appendTo (li);
780
+
781
+ for (const k in item .items)
782
+ ul .append (this .createItem (item .items [k], key, k, level + 1, hide));
783
+
784
+ li .addClass ("context-menu-submenu");
785
+ }
786
+
787
+ return li;
788
+ },
602
789
  });
603
790
 
604
791
  return ContextMenu;