@plastic-software/three 0.181.3 → 0.183.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 (437) hide show
  1. package/LICENSE +1 -1
  2. package/README.md +3 -4
  3. package/build/three.cjs +11330 -10017
  4. package/build/three.core.js +10011 -9493
  5. package/build/three.core.min.js +2 -2
  6. package/build/three.module.js +1414 -631
  7. package/build/three.module.min.js +2 -2
  8. package/build/three.tsl.js +21 -13
  9. package/build/three.tsl.min.js +2 -2
  10. package/build/three.webgpu.js +8007 -5427
  11. package/build/three.webgpu.min.js +2 -2
  12. package/build/three.webgpu.nodes.js +8005 -5426
  13. package/build/three.webgpu.nodes.min.js +2 -2
  14. package/examples/jsm/Addons.js +0 -3
  15. package/examples/jsm/animation/CCDIKSolver.js +2 -2
  16. package/examples/jsm/controls/ArcballControls.js +3 -3
  17. package/examples/jsm/controls/MapControls.js +55 -1
  18. package/examples/jsm/controls/OrbitControls.js +109 -6
  19. package/examples/jsm/controls/TrackballControls.js +6 -6
  20. package/examples/jsm/csm/CSM.js +2 -1
  21. package/examples/jsm/effects/AnaglyphEffect.js +102 -7
  22. package/examples/jsm/environments/ColorEnvironment.js +59 -0
  23. package/examples/jsm/environments/RoomEnvironment.js +3 -0
  24. package/examples/jsm/exporters/EXRExporter.js +1 -1
  25. package/examples/jsm/exporters/GLTFExporter.js +131 -4
  26. package/examples/jsm/exporters/USDZExporter.js +22 -3
  27. package/examples/jsm/geometries/DecalGeometry.js +1 -1
  28. package/examples/jsm/helpers/AnimationPathHelper.js +302 -0
  29. package/examples/jsm/helpers/LightProbeHelperGPU.js +1 -1
  30. package/examples/jsm/helpers/TextureHelperGPU.js +1 -1
  31. package/examples/jsm/helpers/ViewHelper.js +67 -8
  32. package/examples/jsm/inspector/Inspector.js +74 -14
  33. package/examples/jsm/inspector/RendererInspector.js +12 -2
  34. package/examples/jsm/inspector/tabs/Console.js +41 -7
  35. package/examples/jsm/inspector/tabs/Parameters.js +18 -2
  36. package/examples/jsm/inspector/tabs/Performance.js +2 -2
  37. package/examples/jsm/inspector/tabs/Viewer.js +4 -4
  38. package/examples/jsm/inspector/ui/Profiler.js +1836 -31
  39. package/examples/jsm/inspector/ui/Style.js +973 -14
  40. package/examples/jsm/inspector/ui/Tab.js +188 -1
  41. package/examples/jsm/inspector/ui/Values.js +17 -1
  42. package/examples/jsm/libs/meshopt_decoder.module.js +6 -5
  43. package/examples/jsm/lines/LineMaterial.js +6 -0
  44. package/examples/jsm/loaders/3DMLoader.js +5 -4
  45. package/examples/jsm/loaders/3MFLoader.js +2 -2
  46. package/examples/jsm/loaders/AMFLoader.js +2 -2
  47. package/examples/jsm/loaders/ColladaLoader.js +24 -4026
  48. package/examples/jsm/loaders/DRACOLoader.js +5 -5
  49. package/examples/jsm/loaders/EXRLoader.js +5 -5
  50. package/examples/jsm/loaders/FBXLoader.js +2 -4
  51. package/examples/jsm/loaders/GCodeLoader.js +34 -8
  52. package/examples/jsm/loaders/GLTFLoader.js +122 -171
  53. package/examples/jsm/loaders/HDRLoader.js +0 -1
  54. package/examples/jsm/loaders/KMZLoader.js +5 -5
  55. package/examples/jsm/loaders/KTX2Loader.js +19 -3
  56. package/examples/jsm/loaders/LDrawLoader.js +2 -3
  57. package/examples/jsm/loaders/LWOLoader.js +7 -39
  58. package/examples/jsm/loaders/NRRDLoader.js +2 -2
  59. package/examples/jsm/loaders/PCDLoader.js +4 -2
  60. package/examples/jsm/loaders/SVGLoader.js +1 -1
  61. package/examples/jsm/loaders/TDSLoader.js +0 -2
  62. package/examples/jsm/loaders/TGALoader.js +0 -2
  63. package/examples/jsm/loaders/USDLoader.js +100 -40
  64. package/examples/jsm/loaders/UltraHDRLoader.js +285 -160
  65. package/examples/jsm/loaders/VOXLoader.js +660 -117
  66. package/examples/jsm/loaders/VRMLLoader.js +79 -2
  67. package/examples/jsm/loaders/VTKLoader.js +37 -24
  68. package/examples/jsm/loaders/collada/ColladaComposer.js +2950 -0
  69. package/examples/jsm/loaders/collada/ColladaParser.js +1962 -0
  70. package/examples/jsm/loaders/usd/USDAParser.js +447 -366
  71. package/examples/jsm/loaders/usd/USDCParser.js +1841 -6
  72. package/examples/jsm/loaders/usd/USDComposer.js +4041 -0
  73. package/examples/jsm/materials/LDrawConditionalLineNodeMaterial.js +2 -2
  74. package/examples/jsm/materials/WoodNodeMaterial.js +11 -11
  75. package/examples/jsm/math/Octree.js +131 -1
  76. package/examples/jsm/misc/Volume.js +0 -1
  77. package/examples/jsm/misc/VolumeSlice.js +0 -1
  78. package/examples/jsm/objects/LensflareMesh.js +1 -1
  79. package/examples/jsm/objects/Sky.js +76 -4
  80. package/examples/jsm/objects/SkyMesh.js +127 -10
  81. package/examples/jsm/objects/Water.js +4 -3
  82. package/examples/jsm/objects/Water2.js +5 -3
  83. package/examples/jsm/objects/WaterMesh.js +5 -7
  84. package/examples/jsm/physics/AmmoPhysics.js +12 -7
  85. package/examples/jsm/physics/JoltPhysics.js +10 -6
  86. package/examples/jsm/physics/RapierPhysics.js +9 -5
  87. package/examples/jsm/postprocessing/EffectComposer.js +7 -5
  88. package/examples/jsm/postprocessing/OutputPass.js +9 -0
  89. package/examples/jsm/postprocessing/RenderPass.js +10 -0
  90. package/examples/jsm/postprocessing/RenderTransitionPass.js +1 -1
  91. package/examples/jsm/postprocessing/UnrealBloomPass.js +48 -18
  92. package/examples/jsm/renderers/CSS3DRenderer.js +1 -1
  93. package/examples/jsm/renderers/Projector.js +268 -30
  94. package/examples/jsm/renderers/SVGRenderer.js +193 -60
  95. package/examples/jsm/shaders/GTAOShader.js +19 -6
  96. package/examples/jsm/shaders/HalftoneShader.js +12 -1
  97. package/examples/jsm/shaders/PoissonDenoiseShader.js +6 -2
  98. package/examples/jsm/shaders/SAOShader.js +17 -4
  99. package/examples/jsm/shaders/SSAOShader.js +11 -1
  100. package/examples/jsm/shaders/SSRShader.js +6 -5
  101. package/examples/jsm/shaders/UnpackDepthRGBAShader.js +2 -4
  102. package/examples/jsm/shaders/VignetteShader.js +1 -1
  103. package/examples/jsm/transpiler/AST.js +44 -0
  104. package/examples/jsm/transpiler/GLSLDecoder.js +61 -4
  105. package/examples/jsm/transpiler/ShaderToyDecoder.js +2 -0
  106. package/examples/jsm/transpiler/TSLEncoder.js +46 -3
  107. package/examples/jsm/transpiler/TranspilerUtils.js +3 -3
  108. package/examples/jsm/transpiler/WGSLEncoder.js +27 -0
  109. package/examples/jsm/tsl/display/AfterImageNode.js +1 -1
  110. package/examples/jsm/tsl/display/AnaglyphPassNode.js +458 -16
  111. package/examples/jsm/tsl/display/AnamorphicNode.js +1 -1
  112. package/examples/jsm/tsl/display/BilateralBlurNode.js +364 -0
  113. package/examples/jsm/tsl/display/BloomNode.js +16 -6
  114. package/examples/jsm/tsl/display/CRT.js +150 -0
  115. package/examples/jsm/tsl/display/DenoiseNode.js +1 -1
  116. package/examples/jsm/tsl/display/DepthOfFieldNode.js +1 -1
  117. package/examples/jsm/tsl/display/DotScreenNode.js +1 -1
  118. package/examples/jsm/tsl/display/FXAANode.js +2 -2
  119. package/examples/jsm/tsl/display/GTAONode.js +5 -4
  120. package/examples/jsm/tsl/display/GaussianBlurNode.js +11 -2
  121. package/examples/jsm/tsl/display/GodraysNode.js +624 -0
  122. package/examples/jsm/tsl/display/LensflareNode.js +1 -1
  123. package/examples/jsm/tsl/display/Lut3DNode.js +1 -1
  124. package/examples/jsm/tsl/display/OutlineNode.js +3 -3
  125. package/examples/jsm/tsl/display/ParallaxBarrierPassNode.js +2 -2
  126. package/examples/jsm/tsl/display/PixelationPassNode.js +7 -6
  127. package/examples/jsm/tsl/display/RGBShiftNode.js +2 -2
  128. package/examples/jsm/tsl/display/RetroPassNode.js +263 -0
  129. package/examples/jsm/tsl/display/SMAANode.js +2 -2
  130. package/examples/jsm/tsl/display/SSAAPassNode.js +2 -2
  131. package/examples/jsm/tsl/display/SSGINode.js +8 -20
  132. package/examples/jsm/tsl/display/SSRNode.js +8 -8
  133. package/examples/jsm/tsl/display/SSSNode.js +6 -4
  134. package/examples/jsm/tsl/display/Shape.js +29 -0
  135. package/examples/jsm/tsl/display/SobelOperatorNode.js +2 -2
  136. package/examples/jsm/tsl/display/StereoCompositePassNode.js +8 -1
  137. package/examples/jsm/tsl/display/StereoPassNode.js +1 -2
  138. package/examples/jsm/tsl/display/TRAANode.js +273 -125
  139. package/examples/jsm/tsl/display/TransitionNode.js +1 -1
  140. package/examples/jsm/tsl/display/depthAwareBlend.js +80 -0
  141. package/examples/jsm/tsl/display/radialBlur.js +68 -0
  142. package/examples/jsm/tsl/math/Bayer.js +40 -1
  143. package/examples/jsm/utils/LDrawUtils.js +1 -1
  144. package/examples/jsm/utils/ShadowMapViewer.js +24 -10
  145. package/examples/jsm/utils/ShadowMapViewerGPU.js +1 -1
  146. package/examples/jsm/utils/WebGPUTextureUtils.js +1 -1
  147. package/package.json +20 -26
  148. package/src/Three.Core.js +2 -1
  149. package/src/Three.TSL.js +19 -11
  150. package/src/Three.WebGPU.Nodes.js +2 -0
  151. package/src/Three.WebGPU.js +3 -0
  152. package/src/Three.js +1 -0
  153. package/src/animation/AnimationAction.js +1 -1
  154. package/src/animation/AnimationClip.js +1 -1
  155. package/src/animation/AnimationMixer.js +6 -0
  156. package/src/animation/AnimationUtils.js +1 -12
  157. package/src/animation/KeyframeTrack.js +47 -8
  158. package/src/animation/PropertyMixer.js +4 -4
  159. package/src/animation/tracks/BooleanKeyframeTrack.js +1 -1
  160. package/src/animation/tracks/ColorKeyframeTrack.js +1 -1
  161. package/src/animation/tracks/NumberKeyframeTrack.js +1 -1
  162. package/src/animation/tracks/QuaternionKeyframeTrack.js +1 -1
  163. package/src/animation/tracks/StringKeyframeTrack.js +1 -1
  164. package/src/animation/tracks/VectorKeyframeTrack.js +1 -1
  165. package/src/audio/Audio.js +1 -1
  166. package/src/audio/AudioListener.js +5 -3
  167. package/src/cameras/Camera.js +32 -2
  168. package/src/cameras/CubeCamera.js +20 -0
  169. package/src/constants.js +90 -5
  170. package/src/core/BufferGeometry.js +14 -2
  171. package/src/core/Clock.js +7 -0
  172. package/src/core/Object3D.js +56 -4
  173. package/src/core/Raycaster.js +2 -2
  174. package/src/core/RenderTarget.js +3 -4
  175. package/src/extras/PMREMGenerator.js +7 -18
  176. package/src/extras/TextureUtils.js +5 -1
  177. package/src/geometries/ExtrudeGeometry.js +2 -2
  178. package/src/geometries/PolyhedronGeometry.js +1 -1
  179. package/src/geometries/TorusGeometry.js +8 -3
  180. package/src/helpers/CameraHelper.js +3 -0
  181. package/src/helpers/DirectionalLightHelper.js +4 -1
  182. package/src/helpers/HemisphereLightHelper.js +3 -0
  183. package/src/helpers/PointLightHelper.js +1 -25
  184. package/src/helpers/SpotLightHelper.js +3 -0
  185. package/src/lights/DirectionalLight.js +13 -0
  186. package/src/lights/HemisphereLight.js +10 -0
  187. package/src/lights/Light.js +1 -11
  188. package/src/lights/LightProbe.js +0 -15
  189. package/src/lights/LightShadow.js +15 -6
  190. package/src/lights/PointLight.js +15 -0
  191. package/src/lights/PointLightShadow.js +0 -86
  192. package/src/lights/SpotLight.js +22 -1
  193. package/src/lights/webgpu/IESSpotLight.js +2 -1
  194. package/src/loaders/Cache.js +28 -0
  195. package/src/loaders/FileLoader.js +1 -1
  196. package/src/loaders/ImageBitmapLoader.js +8 -3
  197. package/src/loaders/Loader.js +6 -0
  198. package/src/loaders/MaterialLoader.js +2 -1
  199. package/src/loaders/ObjectLoader.js +21 -2
  200. package/src/loaders/nodes/NodeLoader.js +2 -2
  201. package/src/materials/Material.js +2 -0
  202. package/src/materials/MeshLambertMaterial.js +9 -0
  203. package/src/materials/MeshPhongMaterial.js +9 -0
  204. package/src/materials/ShaderMaterial.js +20 -1
  205. package/src/materials/nodes/Line2NodeMaterial.js +7 -7
  206. package/src/materials/nodes/MeshPhysicalNodeMaterial.js +5 -2
  207. package/src/materials/nodes/MeshStandardNodeMaterial.js +5 -4
  208. package/src/materials/nodes/NodeMaterial.js +72 -25
  209. package/src/materials/nodes/manager/NodeMaterialObserver.js +10 -4
  210. package/src/math/Line3.js +3 -5
  211. package/src/math/MathUtils.js +10 -10
  212. package/src/math/Matrix4.js +74 -65
  213. package/src/math/Quaternion.js +3 -29
  214. package/src/math/Sphere.js +1 -1
  215. package/src/math/Vector3.js +3 -5
  216. package/src/math/interpolants/BezierInterpolant.js +108 -0
  217. package/src/nodes/Nodes.js +87 -68
  218. package/src/nodes/TSL.js +6 -6
  219. package/src/nodes/accessors/Arrays.js +1 -1
  220. package/src/nodes/accessors/BatchNode.js +10 -10
  221. package/src/nodes/accessors/Bitangent.js +5 -5
  222. package/src/nodes/accessors/BufferAttributeNode.js +98 -12
  223. package/src/nodes/accessors/BufferNode.js +29 -2
  224. package/src/nodes/accessors/Camera.js +149 -28
  225. package/src/nodes/accessors/ClippingNode.js +4 -4
  226. package/src/nodes/accessors/CubeTextureNode.js +20 -1
  227. package/src/nodes/accessors/InstanceNode.js +148 -43
  228. package/src/nodes/accessors/MaterialNode.js +9 -1
  229. package/src/nodes/accessors/MaterialReferenceNode.js +1 -2
  230. package/src/nodes/accessors/ModelNode.js +1 -1
  231. package/src/nodes/accessors/Normal.js +11 -11
  232. package/src/nodes/accessors/Position.js +34 -2
  233. package/src/nodes/accessors/ReferenceBaseNode.js +4 -4
  234. package/src/nodes/accessors/ReferenceNode.js +4 -4
  235. package/src/nodes/accessors/RendererReferenceNode.js +1 -2
  236. package/src/nodes/accessors/SceneProperties.js +53 -0
  237. package/src/nodes/accessors/SkinningNode.js +27 -26
  238. package/src/nodes/accessors/StorageBufferNode.js +4 -21
  239. package/src/nodes/accessors/StorageTextureNode.js +37 -1
  240. package/src/nodes/accessors/Tangent.js +4 -14
  241. package/src/nodes/accessors/Texture3DNode.js +32 -35
  242. package/src/nodes/accessors/TextureNode.js +58 -22
  243. package/src/nodes/accessors/UniformArrayNode.js +4 -2
  244. package/src/nodes/accessors/UserDataNode.js +1 -2
  245. package/src/nodes/accessors/VertexColorNode.js +1 -2
  246. package/src/nodes/code/FunctionNode.js +1 -2
  247. package/src/nodes/core/ArrayNode.js +20 -1
  248. package/src/nodes/core/AssignNode.js +2 -2
  249. package/src/nodes/core/AttributeNode.js +2 -2
  250. package/src/nodes/core/ContextNode.js +103 -4
  251. package/src/nodes/core/MRTNode.js +48 -2
  252. package/src/nodes/core/Node.js +29 -3
  253. package/src/nodes/core/NodeBuilder.js +170 -53
  254. package/src/nodes/core/NodeError.js +28 -0
  255. package/src/nodes/core/NodeFrame.js +12 -4
  256. package/src/nodes/core/NodeUtils.js +10 -8
  257. package/src/nodes/core/OutputStructNode.js +12 -10
  258. package/src/nodes/core/ParameterNode.js +3 -3
  259. package/src/nodes/core/PropertyNode.js +19 -3
  260. package/src/nodes/core/StackNode.js +65 -16
  261. package/src/nodes/core/StackTrace.js +139 -0
  262. package/src/nodes/core/StructNode.js +16 -2
  263. package/src/nodes/core/StructTypeNode.js +11 -17
  264. package/src/nodes/core/SubBuildNode.js +1 -1
  265. package/src/nodes/core/UniformNode.js +21 -5
  266. package/src/nodes/core/VarNode.js +47 -22
  267. package/src/nodes/core/VaryingNode.js +1 -18
  268. package/src/nodes/display/BlendModes.js +0 -64
  269. package/src/nodes/display/ColorAdjustment.js +17 -0
  270. package/src/nodes/display/ColorSpaceNode.js +3 -3
  271. package/src/nodes/display/NormalMapNode.js +39 -4
  272. package/src/nodes/display/PassNode.js +98 -9
  273. package/src/nodes/display/RenderOutputNode.js +3 -3
  274. package/src/nodes/display/ScreenNode.js +3 -1
  275. package/src/nodes/display/ToneMappingNode.js +1 -1
  276. package/src/nodes/display/ToonOutlinePassNode.js +2 -2
  277. package/src/nodes/display/ViewportDepthNode.js +52 -4
  278. package/src/nodes/display/ViewportTextureNode.js +21 -4
  279. package/src/nodes/fog/Fog.js +18 -35
  280. package/src/nodes/functions/BSDF/BRDF_GGX_Multiscatter.js +3 -3
  281. package/src/nodes/functions/BSDF/DFGLUT.js +56 -0
  282. package/src/nodes/functions/BSDF/EnvironmentBRDF.js +2 -2
  283. package/src/nodes/functions/BSDF/V_GGX_SmithCorrelated_Anisotropic.js +1 -1
  284. package/src/nodes/functions/PhysicalLightingModel.js +126 -45
  285. package/src/nodes/geometry/RangeNode.js +4 -2
  286. package/src/nodes/gpgpu/ComputeBuiltinNode.js +1 -2
  287. package/src/nodes/gpgpu/ComputeNode.js +5 -4
  288. package/src/nodes/gpgpu/SubgroupFunctionNode.js +1 -1
  289. package/src/nodes/gpgpu/WorkgroupInfoNode.js +4 -4
  290. package/src/nodes/lighting/AnalyticLightNode.js +53 -0
  291. package/src/nodes/lighting/EnvironmentNode.js +28 -3
  292. package/src/nodes/lighting/LightsNode.js +2 -2
  293. package/src/nodes/lighting/PointShadowNode.js +162 -149
  294. package/src/nodes/lighting/ShadowFilterNode.js +53 -65
  295. package/src/nodes/lighting/ShadowNode.js +97 -41
  296. package/src/nodes/math/BitcountNode.js +433 -0
  297. package/src/nodes/math/ConditionalNode.js +2 -2
  298. package/src/nodes/math/MathNode.js +3 -40
  299. package/src/nodes/math/OperatorNode.js +2 -1
  300. package/src/nodes/math/PackFloatNode.js +98 -0
  301. package/src/nodes/math/UnpackFloatNode.js +96 -0
  302. package/src/nodes/pmrem/PMREMNode.js +1 -1
  303. package/src/nodes/pmrem/PMREMUtils.js +9 -15
  304. package/src/nodes/tsl/TSLCore.js +17 -14
  305. package/src/nodes/utils/ArrayElementNode.js +13 -0
  306. package/src/nodes/utils/DebugNode.js +11 -11
  307. package/src/nodes/utils/EventNode.js +1 -2
  308. package/src/nodes/utils/JoinNode.js +2 -2
  309. package/src/nodes/utils/LoopNode.js +1 -1
  310. package/src/nodes/utils/MemberNode.js +1 -1
  311. package/src/nodes/utils/Packing.js +13 -1
  312. package/src/nodes/utils/PostProcessingUtils.js +33 -1
  313. package/src/nodes/utils/RTTNode.js +1 -1
  314. package/src/nodes/utils/ReflectorNode.js +3 -4
  315. package/src/nodes/utils/SampleNode.js +1 -1
  316. package/src/nodes/utils/SpriteSheetUV.js +35 -0
  317. package/src/nodes/utils/UVUtils.js +28 -0
  318. package/src/objects/BatchedMesh.js +27 -14
  319. package/src/objects/InstancedMesh.js +11 -0
  320. package/src/objects/Line.js +1 -1
  321. package/src/objects/Mesh.js +1 -1
  322. package/src/objects/Points.js +1 -1
  323. package/src/objects/Skeleton.js +9 -0
  324. package/src/renderers/WebGLRenderer.js +178 -92
  325. package/src/renderers/common/Backend.js +29 -0
  326. package/src/renderers/common/Background.js +24 -11
  327. package/src/renderers/common/BindGroup.js +1 -9
  328. package/src/renderers/common/Binding.js +11 -0
  329. package/src/renderers/common/Bindings.js +27 -12
  330. package/src/renderers/common/BlendMode.js +143 -0
  331. package/src/renderers/common/Buffer.js +40 -0
  332. package/src/renderers/common/BundleGroup.js +1 -1
  333. package/src/renderers/common/ChainMap.js +30 -6
  334. package/src/renderers/common/CubeRenderTarget.js +50 -6
  335. package/src/renderers/common/Geometries.js +29 -3
  336. package/src/renderers/common/Lighting.js +5 -21
  337. package/src/renderers/common/Pipelines.js +4 -4
  338. package/src/renderers/common/PostProcessing.js +8 -206
  339. package/src/renderers/common/RenderBundles.js +2 -1
  340. package/src/renderers/common/RenderContext.js +16 -0
  341. package/src/renderers/common/RenderContexts.js +33 -49
  342. package/src/renderers/common/RenderLists.js +2 -1
  343. package/src/renderers/common/RenderObject.js +15 -3
  344. package/src/renderers/common/RenderObjectPipeline.js +40 -0
  345. package/src/renderers/common/RenderObjects.js +18 -2
  346. package/src/renderers/common/RenderPipeline.js +203 -17
  347. package/src/renderers/common/Renderer.js +257 -72
  348. package/src/renderers/common/Sampler.js +4 -4
  349. package/src/renderers/common/StorageBuffer.js +13 -1
  350. package/src/renderers/common/Textures.js +17 -1
  351. package/src/renderers/common/TimestampQueryPool.js +5 -3
  352. package/src/renderers/common/Uniform.js +8 -0
  353. package/src/renderers/common/UniformsGroup.js +61 -0
  354. package/src/renderers/common/XRManager.js +3 -2
  355. package/src/renderers/common/extras/PMREMGenerator.js +2 -8
  356. package/src/renderers/common/nodes/NodeBuilderState.js +1 -1
  357. package/src/renderers/common/nodes/{Nodes.js → NodeManager.js} +18 -6
  358. package/src/renderers/common/nodes/NodeStorageBuffer.js +13 -2
  359. package/src/renderers/common/nodes/NodeUniformBuffer.js +52 -0
  360. package/src/renderers/shaders/DFGLUTData.js +19 -34
  361. package/src/renderers/shaders/ShaderChunk/batching_pars_vertex.glsl.js +2 -2
  362. package/src/renderers/shaders/ShaderChunk/color_fragment.glsl.js +1 -5
  363. package/src/renderers/shaders/ShaderChunk/color_pars_fragment.glsl.js +1 -5
  364. package/src/renderers/shaders/ShaderChunk/color_pars_vertex.glsl.js +1 -5
  365. package/src/renderers/shaders/ShaderChunk/color_vertex.glsl.js +8 -10
  366. package/src/renderers/shaders/ShaderChunk/envmap_fragment.glsl.js +7 -11
  367. package/src/renderers/shaders/ShaderChunk/lights_fragment_begin.glsl.js +5 -2
  368. package/src/renderers/shaders/ShaderChunk/lights_fragment_end.glsl.js +6 -0
  369. package/src/renderers/shaders/ShaderChunk/lights_fragment_maps.glsl.js +6 -2
  370. package/src/renderers/shaders/ShaderChunk/lights_physical_fragment.glsl.js +8 -4
  371. package/src/renderers/shaders/ShaderChunk/lights_physical_pars_fragment.glsl.js +112 -51
  372. package/src/renderers/shaders/ShaderChunk/packing.glsl.js +20 -4
  373. package/src/renderers/shaders/ShaderChunk/shadowmap_pars_fragment.glsl.js +225 -186
  374. package/src/renderers/shaders/ShaderChunk/shadowmask_pars_fragment.glsl.js +1 -1
  375. package/src/renderers/shaders/ShaderChunk/transmission_fragment.glsl.js +1 -1
  376. package/src/renderers/shaders/ShaderChunk.js +3 -3
  377. package/src/renderers/shaders/ShaderLib/depth.glsl.js +3 -0
  378. package/src/renderers/shaders/ShaderLib/{distanceRGBA.glsl.js → distance.glsl.js} +1 -2
  379. package/src/renderers/shaders/ShaderLib/meshlambert.glsl.js +2 -1
  380. package/src/renderers/shaders/ShaderLib/meshnormal.glsl.js +1 -2
  381. package/src/renderers/shaders/ShaderLib/meshphong.glsl.js +2 -1
  382. package/src/renderers/shaders/ShaderLib/meshphysical.glsl.js +4 -9
  383. package/src/renderers/shaders/ShaderLib/meshtoon.glsl.js +0 -1
  384. package/src/renderers/shaders/ShaderLib/shadow.glsl.js +1 -1
  385. package/src/renderers/shaders/ShaderLib/vsm.glsl.js +4 -6
  386. package/src/renderers/shaders/ShaderLib.js +7 -5
  387. package/src/renderers/shaders/UniformsLib.js +0 -3
  388. package/src/renderers/webgl/WebGLBackground.js +2 -2
  389. package/src/renderers/webgl/WebGLBindingStates.js +99 -27
  390. package/src/renderers/webgl/WebGLCapabilities.js +3 -4
  391. package/src/renderers/webgl/WebGLEnvironments.js +228 -0
  392. package/src/renderers/webgl/WebGLGeometries.js +10 -7
  393. package/src/renderers/webgl/WebGLLights.js +18 -1
  394. package/src/renderers/webgl/WebGLMaterials.js +12 -0
  395. package/src/renderers/webgl/WebGLObjects.js +3 -1
  396. package/src/renderers/webgl/WebGLOutput.js +267 -0
  397. package/src/renderers/webgl/WebGLProgram.js +45 -109
  398. package/src/renderers/webgl/WebGLPrograms.js +45 -49
  399. package/src/renderers/webgl/WebGLRenderLists.js +15 -0
  400. package/src/renderers/webgl/WebGLShadowMap.js +188 -24
  401. package/src/renderers/webgl/WebGLState.js +32 -37
  402. package/src/renderers/webgl/WebGLTextures.js +89 -28
  403. package/src/renderers/webgl/WebGLUniforms.js +40 -3
  404. package/src/renderers/webgl/WebGLUtils.js +6 -2
  405. package/src/renderers/webgl-fallback/WebGLBackend.js +148 -18
  406. package/src/renderers/webgl-fallback/nodes/GLSLNodeBuilder.js +156 -35
  407. package/src/renderers/webgl-fallback/utils/WebGLState.js +181 -5
  408. package/src/renderers/webgl-fallback/utils/WebGLTextureUtils.js +5 -3
  409. package/src/renderers/webgl-fallback/utils/WebGLTimestampQueryPool.js +9 -9
  410. package/src/renderers/webgl-fallback/utils/WebGLUtils.js +6 -2
  411. package/src/renderers/webgpu/WebGPUBackend.js +119 -13
  412. package/src/renderers/webgpu/WebGPURenderer.js +2 -1
  413. package/src/renderers/webgpu/nodes/WGSLNodeBuilder.js +322 -68
  414. package/src/renderers/webgpu/utils/WebGPUAttributeUtils.js +4 -17
  415. package/src/renderers/webgpu/utils/WebGPUBindingUtils.js +357 -200
  416. package/src/renderers/webgpu/utils/WebGPUConstants.js +2 -0
  417. package/src/renderers/webgpu/utils/WebGPUPipelineUtils.js +61 -23
  418. package/src/renderers/webgpu/utils/WebGPUTexturePassUtils.js +152 -200
  419. package/src/renderers/webgpu/utils/WebGPUTextureUtils.js +65 -42
  420. package/src/renderers/webgpu/utils/WebGPUTimestampQueryPool.js +7 -7
  421. package/src/renderers/webgpu/utils/WebGPUUtils.js +17 -11
  422. package/src/renderers/webxr/WebXRManager.js +2 -2
  423. package/src/textures/CubeDepthTexture.js +76 -0
  424. package/src/textures/Source.js +1 -1
  425. package/src/textures/Texture.js +3 -3
  426. package/src/utils.js +258 -3
  427. package/examples/jsm/materials/MeshGouraudMaterial.js +0 -434
  428. package/examples/jsm/materials/MeshPostProcessingMaterial.js +0 -167
  429. package/examples/jsm/shaders/GodRaysShader.js +0 -333
  430. package/src/nodes/accessors/SceneNode.js +0 -145
  431. package/src/nodes/code/ScriptableNode.js +0 -726
  432. package/src/nodes/code/ScriptableValueNode.js +0 -253
  433. package/src/nodes/display/PosterizeNode.js +0 -65
  434. package/src/nodes/functions/BSDF/DFGApprox.js +0 -71
  435. package/src/nodes/utils/SpriteSheetUVNode.js +0 -90
  436. package/src/renderers/webgl/WebGLCubeMaps.js +0 -99
  437. package/src/renderers/webgl/WebGLCubeUVMaps.js +0 -134
@@ -36,12 +36,13 @@ export class Style {
36
36
  right: 15px;
37
37
  background-color: rgba(30, 30, 36, 0.85);
38
38
  border: 1px solid #4a4a5a54;
39
- border-radius: 6px 12px 12px 6px;
39
+ border-radius: 12px 6px 6px 12px;
40
40
  color: var(--text-primary);
41
41
  cursor: pointer;
42
42
  z-index: 1001;
43
43
  transition: all 0.2s ease-in-out;
44
- font-size: 14px;
44
+ /*font-size: 14px;*/
45
+ font-size: 15px;
45
46
  backdrop-filter: blur(8px);
46
47
  box-shadow: 0 4px 15px rgba(0, 0, 0, 0.3);
47
48
  display: flex;
@@ -92,6 +93,289 @@ export class Style {
92
93
  color: #999;
93
94
  }
94
95
 
96
+ #builtin-tabs-container {
97
+ display: flex;
98
+ align-items: stretch;
99
+ gap: 0;
100
+ border-right: 1px solid #262636;
101
+ order: -1;
102
+ }
103
+
104
+ .builtin-tab-btn {
105
+ background: transparent;
106
+ border: none;
107
+ color: var(--text-secondary);
108
+ cursor: pointer;
109
+ padding: 8px 14px;
110
+ font-family: var(--font-family);
111
+ font-size: 13px;
112
+ font-weight: 600;
113
+ transition: all 0.2s;
114
+ display: flex;
115
+ align-items: center;
116
+ justify-content: center;
117
+ min-width: 32px;
118
+ position: relative;
119
+ }
120
+
121
+ .builtin-tab-btn svg {
122
+ width: 20px;
123
+ height: 20px;
124
+ stroke: currentColor;
125
+ }
126
+
127
+ .builtin-tab-btn:hover {
128
+ background-color: rgba(255, 255, 255, 0.08);
129
+ color: var(--accent-color);
130
+ }
131
+
132
+ .builtin-tab-btn:active {
133
+ background-color: rgba(255, 255, 255, 0.12);
134
+ }
135
+
136
+ .builtin-tab-btn.active {
137
+ background-color: rgba(0, 170, 255, 0.2);
138
+ color: var(--accent-color);
139
+ }
140
+
141
+ .builtin-tab-btn.active:hover {
142
+ background-color: rgba(0, 170, 255, 0.3);
143
+ }
144
+
145
+ #profiler-mini-panel {
146
+ position: fixed;
147
+ top: 60px;
148
+ right: 15px;
149
+ background-color: rgba(30, 30, 36, 0.85);
150
+ border: 1px solid #4a4a5a54;
151
+ border-radius: 8px;
152
+ color: var(--text-primary);
153
+ z-index: 9999;
154
+ backdrop-filter: blur(8px);
155
+ box-shadow: 0 6px 24px rgba(0, 0, 0, 0.5);
156
+ font-family: var(--font-family);
157
+ font-size: 11px;
158
+ width: 350px;
159
+ max-height: calc(100vh - 100px);
160
+ overflow-y: auto;
161
+ overflow-x: hidden;
162
+ display: none;
163
+ opacity: 0;
164
+ transform: translateY(-10px) scale(0.98);
165
+ transition: opacity 0.25s cubic-bezier(0.4, 0, 0.2, 1),
166
+ transform 0.25s cubic-bezier(0.4, 0, 0.2, 1);
167
+ }
168
+
169
+ #profiler-mini-panel.visible {
170
+ display: block;
171
+ opacity: 1;
172
+ transform: translateY(0) scale(1);
173
+ }
174
+
175
+ #profiler-mini-panel::-webkit-scrollbar {
176
+ width: 6px;
177
+ }
178
+
179
+ #profiler-mini-panel::-webkit-scrollbar-track {
180
+ background: transparent;
181
+ }
182
+
183
+ #profiler-mini-panel::-webkit-scrollbar-thumb {
184
+ background: rgba(255, 255, 255, 0.15);
185
+ border-radius: 3px;
186
+ transition: background 0.2s;
187
+ }
188
+
189
+ #profiler-mini-panel::-webkit-scrollbar-thumb:hover {
190
+ background: rgba(255, 255, 255, 0.25);
191
+ }
192
+
193
+ .mini-panel-content {
194
+ padding: 0;
195
+ font-size: 11px;
196
+ line-height: 1.5;
197
+ font-family: var(--font-mono);
198
+ letter-spacing: 0.3px;
199
+ user-select: none;
200
+ -webkit-user-select: none;
201
+ }
202
+
203
+ .mini-panel-content .profiler-content {
204
+ display: block !important;
205
+ background: transparent;
206
+ }
207
+
208
+ .mini-panel-content .list-scroll-wrapper {
209
+ max-height: calc(100vh - 120px);
210
+ overflow-y: auto;
211
+ overflow-x: hidden;
212
+ }
213
+
214
+ .mini-panel-content .list-scroll-wrapper::-webkit-scrollbar {
215
+ width: 4px;
216
+ }
217
+
218
+ .mini-panel-content .list-scroll-wrapper::-webkit-scrollbar-track {
219
+ background: transparent;
220
+ }
221
+
222
+ .mini-panel-content .list-scroll-wrapper::-webkit-scrollbar-thumb {
223
+ background: rgba(255, 255, 255, 0.1);
224
+ border-radius: 2px;
225
+ }
226
+
227
+ .mini-panel-content .list-scroll-wrapper::-webkit-scrollbar-thumb:hover {
228
+ background: rgba(255, 255, 255, 0.2);
229
+ }
230
+
231
+ .mini-panel-content .parameters {
232
+ background: transparent;
233
+ border: none;
234
+ box-shadow: none;
235
+ padding: 4px;
236
+ }
237
+
238
+ .mini-panel-content .list-container.parameters {
239
+ padding: 2px 6px 0px 6px !important;
240
+ }
241
+
242
+ .mini-panel-content .list-header {
243
+ display: none;
244
+ padding: 2px 4px;
245
+ font-size: 11px;
246
+ font-weight: 600;
247
+ text-transform: uppercase;
248
+ letter-spacing: 0.5px;
249
+ }
250
+
251
+ .mini-panel-content .list-item {
252
+ border-bottom: 1px solid rgba(74, 74, 90, 0.2);
253
+ transition: background-color 0.15s;
254
+ }
255
+
256
+ .mini-panel-content .list-item:last-child {
257
+ border-bottom: none;
258
+ }
259
+
260
+ .mini-panel-content .list-item:hover {
261
+ background-color: rgba(255, 255, 255, 0.04);
262
+ }
263
+
264
+ .mini-panel-content .list-item.actionable:hover {
265
+ background-color: rgba(255, 255, 255, 0.06);
266
+ cursor: pointer;
267
+ }
268
+
269
+ /* Style adjustments for lil-gui look */
270
+ .mini-panel-content .item-row {
271
+ padding: 3px 8px;
272
+ min-height: 24px;
273
+ }
274
+
275
+ .mini-panel-content .list-item-row {
276
+ padding: 1px 4px;
277
+ gap: 8px;
278
+ min-height: 21px;
279
+ align-items: center;
280
+ }
281
+
282
+ .mini-panel-content input[type="checkbox"] {
283
+ width: 12px;
284
+ height: 12px;
285
+ }
286
+
287
+ .mini-panel-content input[type="range"] {
288
+ height: 18px;
289
+ }
290
+
291
+ .mini-panel-content .value-number input,
292
+ .mini-panel-content .value-slider input {
293
+ background-color: rgba(0, 0, 0, 0.3);
294
+ border: 1px solid rgba(74, 74, 90, 0.5);
295
+ font-size: 10px;
296
+ }
297
+
298
+ .mini-panel-content .value-number input:focus,
299
+ .mini-panel-content .value-slider input:focus {
300
+ border-color: var(--accent-color);
301
+ }
302
+
303
+ .mini-panel-content .value-slider {
304
+ gap: 6px;
305
+ }
306
+
307
+ /* Compact nested items */
308
+ .mini-panel-content .list-item .list-item {
309
+ margin-left: 8px;
310
+ }
311
+
312
+ .mini-panel-content .list-item .list-item .item-row,
313
+ .mini-panel-content .list-item .list-item .list-item-row {
314
+ padding: 2px 6px;
315
+ min-height: 22px;
316
+ }
317
+
318
+ /* Compact collapsible headers */
319
+ .mini-panel-content .collapsible .item-row,
320
+ .mini-panel-content .list-item-row.collapsible {
321
+ padding: 2px 8px;
322
+ font-weight: 600;
323
+ min-height: 16px;
324
+ display: flex;
325
+ align-items: center;
326
+ }
327
+
328
+ .mini-panel-content .collapsible-icon {
329
+ font-size: 10px;
330
+ width: 14px;
331
+ height: 14px;
332
+ }
333
+
334
+ .mini-panel-content .param-control input[type="range"] {
335
+ height: 12px;
336
+ margin-top: 1px;
337
+ padding-top: 5px;
338
+ user-select: none;
339
+ -webkit-user-select: none;
340
+ outline: none;
341
+ }
342
+
343
+ .mini-panel-content .param-control input[type="range"]::-webkit-slider-thumb {
344
+ width: 14px;
345
+ height: 14px;
346
+ margin-top: -5px;
347
+ user-select: none;
348
+ -webkit-user-select: none;
349
+ }
350
+
351
+ .mini-panel-content .param-control input[type="range"]::-moz-range-thumb {
352
+ width: 14px;
353
+ height: 14px;
354
+ user-select: none;
355
+ -moz-user-select: none;
356
+ }
357
+
358
+ .mini-panel-content .list-children-container {
359
+ padding-left: 0;
360
+ }
361
+
362
+ .mini-panel-content .param-control input[type="number"] {
363
+ flex-basis: 60px !important;
364
+ }
365
+
366
+ .mini-panel-content .param-control {
367
+ align-items: center;
368
+ }
369
+
370
+ .mini-panel-content .param-control select {
371
+ font-size: 11px;
372
+ }
373
+
374
+ .mini-panel-content .list-item-wrapper {
375
+ margin-top: 0;
376
+ margin-bottom: 0;
377
+ }
378
+
95
379
  #profiler-panel {
96
380
  position: fixed;
97
381
  z-index: 1001 !important;
@@ -108,11 +392,12 @@ export class Style {
108
392
  z-index: 1000;
109
393
  /*box-shadow: 0 -5px 25px rgba(0, 0, 0, 0.5);*/
110
394
  transform: translateY(100%);
111
- transition: transform 0.35s cubic-bezier(0.25, 0.46, 0.45, 0.94), height 0.3s ease-out;
395
+ transition: transform 0.35s cubic-bezier(0.25, 0.46, 0.45, 0.94), height 0.3s ease-out, width 0.3s ease-out;
112
396
  font-family: var(--font-mono);
113
397
  }
114
398
 
115
- #profiler-panel.resizing {
399
+ #profiler-panel.resizing,
400
+ #profiler-panel.dragging {
116
401
  transition: none;
117
402
  }
118
403
 
@@ -124,6 +409,92 @@ export class Style {
124
409
  height: 100vh;
125
410
  }
126
411
 
412
+ /* Position-specific styles */
413
+ #profiler-panel.position-top {
414
+ bottom: auto;
415
+ top: 0;
416
+ border-top: none;
417
+ border-bottom: 2px solid var(--profiler-border);
418
+ transform: translateY(-100%);
419
+ }
420
+
421
+ #profiler-panel.position-top.visible {
422
+ transform: translateY(0);
423
+ }
424
+
425
+ #profiler-panel.position-bottom {
426
+ /* Default position - already defined above */
427
+ }
428
+
429
+ #profiler-panel.position-left {
430
+ top: 0;
431
+ bottom: 0;
432
+ left: 0;
433
+ right: auto;
434
+ width: 350px;
435
+ height: 100%;
436
+ border-top: none;
437
+ border-right: 2px solid var(--profiler-border);
438
+ transform: translateX(-100%);
439
+ }
440
+
441
+ #profiler-panel.position-left.visible {
442
+ transform: translateX(0);
443
+ }
444
+
445
+ #profiler-panel.position-right {
446
+ top: 0;
447
+ bottom: 0;
448
+ left: auto;
449
+ right: 0;
450
+ width: 350px;
451
+ height: 100%;
452
+ border-top: none;
453
+ border-left: 2px solid var(--profiler-border);
454
+ transform: translateX(100%);
455
+ }
456
+
457
+ #profiler-panel.position-right.visible {
458
+ transform: translateX(0);
459
+ }
460
+
461
+ #profiler-panel.position-floating {
462
+ border: 2px solid var(--profiler-border);
463
+ border-radius: 8px;
464
+ box-shadow: 0 8px 32px rgba(0, 0, 0, 0.4);
465
+ transform: none !important;
466
+ overflow: hidden;
467
+ }
468
+
469
+ #profiler-panel.position-floating.visible {
470
+ transform: none !important;
471
+ }
472
+
473
+ #profiler-panel.position-floating .profiler-header {
474
+ border-radius: 6px 6px 0 0;
475
+ }
476
+
477
+ #profiler-panel.position-floating .panel-resizer {
478
+ bottom: 0;
479
+ right: 0;
480
+ top: auto;
481
+ left: auto;
482
+ width: 16px;
483
+ height: 16px;
484
+ cursor: nwse-resize;
485
+ border-radius: 0 0 6px 0;
486
+ }
487
+
488
+ #profiler-panel.position-floating .panel-resizer::after {
489
+ content: '';
490
+ position: absolute;
491
+ right: 2px;
492
+ bottom: 2px;
493
+ width: 10px;
494
+ height: 10px;
495
+ background: linear-gradient(135deg, transparent 0%, transparent 45%, var(--profiler-border) 45%, var(--profiler-border) 55%, transparent 55%);
496
+ }
497
+
127
498
 
128
499
  .panel-resizer {
129
500
  position: absolute;
@@ -133,6 +504,30 @@ export class Style {
133
504
  height: 5px;
134
505
  cursor: ns-resize;
135
506
  z-index: 1001;
507
+ touch-action: none;
508
+ }
509
+
510
+ #profiler-panel.position-top .panel-resizer {
511
+ top: auto;
512
+ bottom: -2px;
513
+ }
514
+
515
+ #profiler-panel.position-left .panel-resizer {
516
+ top: 0;
517
+ left: auto;
518
+ right: -2px;
519
+ width: 5px;
520
+ height: 100%;
521
+ cursor: ew-resize;
522
+ }
523
+
524
+ #profiler-panel.position-right .panel-resizer {
525
+ top: 0;
526
+ left: -2px;
527
+ right: auto;
528
+ width: 5px;
529
+ height: 100%;
530
+ cursor: ew-resize;
136
531
  }
137
532
 
138
533
  .profiler-header {
@@ -145,12 +540,181 @@ export class Style {
145
540
 
146
541
  overflow-x: auto;
147
542
  overflow-y: hidden;
148
- width: calc(100% - 89px);
543
+ width: calc(100% - 134px);
544
+ height: 38px;
545
+ user-select: none;
546
+ -webkit-user-select: none;
547
+ }
548
+
549
+ /* Adjust header width based on panel position */
550
+ #profiler-panel.position-right .profiler-header,
551
+ #profiler-panel.position-left .profiler-header {
552
+ width: calc(100% - 134px);
553
+ }
554
+
555
+ #profiler-panel.position-bottom .profiler-header,
556
+ #profiler-panel.position-top .profiler-header {
557
+ width: calc(100% - 134px);
558
+ }
559
+
560
+ /* Adjust header width when position toggle button is hidden (mobile) */
561
+ #profiler-panel.hide-position-toggle .profiler-header {
562
+ width: calc(100% - 90px);
563
+ }
564
+
565
+ /* ===== RULES FOR WHEN THERE ARE NO TABS ===== */
566
+
567
+ /* Horizontal mode (bottom/top) without tabs */
568
+ #profiler-panel.position-bottom.no-tabs:not(.maximized),
569
+ #profiler-panel.position-top.no-tabs:not(.maximized) {
570
+ height: 38px !important;
571
+ min-height: 38px !important;
572
+ }
573
+
574
+ #profiler-panel.position-bottom.no-tabs .profiler-header,
575
+ #profiler-panel.position-top.no-tabs .profiler-header {
576
+ width: 100%;
149
577
  height: 38px;
578
+ border-bottom: none;
579
+ }
580
+
581
+ #profiler-panel.position-bottom.no-tabs .profiler-content-wrapper,
582
+ #profiler-panel.position-top.no-tabs .profiler-content-wrapper {
583
+ display: none;
584
+ }
585
+
586
+ #profiler-panel.position-bottom.no-tabs .panel-resizer,
587
+ #profiler-panel.position-top.no-tabs .panel-resizer {
588
+ display: none;
589
+ }
590
+
591
+ /* Vertical mode (right/left) without tabs */
592
+ #profiler-panel.position-right.no-tabs:not(.maximized),
593
+ #profiler-panel.position-left.no-tabs:not(.maximized) {
594
+ width: 45px !important;
595
+ min-width: 45px !important;
596
+ }
597
+
598
+ /* Vertical layout for header when no tabs */
599
+ #profiler-panel.position-right.no-tabs .profiler-header,
600
+ #profiler-panel.position-left.no-tabs .profiler-header {
601
+ width: 100%;
602
+ flex-direction: column;
603
+ height: 100%;
604
+ border-bottom: none;
605
+ }
606
+
607
+ /* Vertical layout for controls when no tabs */
608
+ #profiler-panel.position-right.no-tabs .profiler-controls,
609
+ #profiler-panel.position-left.no-tabs .profiler-controls {
610
+ position: static;
611
+ flex-direction: column-reverse;
612
+ justify-content: flex-end;
613
+ width: 100%;
614
+ height: 100%;
615
+ border-bottom: none;
616
+ border-left: none;
617
+ background: transparent;
618
+ }
619
+
620
+ #profiler-panel.position-right.no-tabs .profiler-controls button,
621
+ #profiler-panel.position-left.no-tabs .profiler-controls button {
622
+ width: 100%;
623
+ height: 45px;
624
+ border-left: none;
625
+ border-top: none;
626
+ border-bottom: 1px solid var(--profiler-border);
627
+ }
628
+
629
+ #profiler-panel.position-right.no-tabs .profiler-content-wrapper,
630
+ #profiler-panel.position-left.no-tabs .profiler-content-wrapper {
631
+ display: none;
632
+ }
633
+
634
+ #profiler-panel.position-right.no-tabs .profiler-tabs,
635
+ #profiler-panel.position-left.no-tabs .profiler-tabs {
636
+ display: none;
637
+ }
638
+
639
+ #profiler-panel.position-right.no-tabs .panel-resizer,
640
+ #profiler-panel.position-left.no-tabs .panel-resizer {
641
+ display: none;
642
+ }
643
+
644
+ /* Hide position toggle on mobile without tabs */
645
+ #profiler-panel.hide-position-toggle.position-right.no-tabs:not(.maximized),
646
+ #profiler-panel.hide-position-toggle.position-left.no-tabs:not(.maximized) {
647
+ width: 45px !important;
648
+ min-width: 45px !important;
649
+ }
650
+
651
+ /* Hide drag indicator on mobile devices */
652
+ #profiler-panel.hide-position-toggle .tab-btn.active::before {
653
+ display: none;
654
+ }
655
+
656
+ .profiler-header::-webkit-scrollbar {
657
+ width: 8px;
658
+ height: 8px;
659
+ }
660
+
661
+ .profiler-header::-webkit-scrollbar-track {
662
+ background: transparent;
663
+ }
664
+
665
+ .profiler-header::-webkit-scrollbar-thumb {
666
+ background-color: rgba(0, 0, 0, 0.25);
667
+ border-radius: 10px;
668
+ transition: background 0.3s ease;
669
+ }
670
+
671
+ .profiler-header::-webkit-scrollbar-thumb:hover {
672
+ background-color: rgba(0, 0, 0, 0.4);
673
+ }
674
+
675
+ .profiler-header::-webkit-scrollbar-corner {
676
+ background: transparent;
677
+ }
678
+
679
+ #profiler-panel.dragging .profiler-header {
680
+ cursor: grabbing !important;
681
+ }
682
+
683
+ #profiler-panel.dragging {
684
+ opacity: 0.8;
150
685
  }
151
686
 
152
687
  .profiler-tabs {
153
688
  display: flex;
689
+ cursor: grab;
690
+ position: relative;
691
+ }
692
+
693
+ .profiler-tabs:active {
694
+ cursor: grabbing;
695
+ }
696
+
697
+ .profiler-tabs::-webkit-scrollbar {
698
+ width: 8px;
699
+ height: 8px;
700
+ }
701
+
702
+ .profiler-tabs::-webkit-scrollbar-track {
703
+ background: transparent;
704
+ }
705
+
706
+ .profiler-tabs::-webkit-scrollbar-thumb {
707
+ background-color: rgba(0, 0, 0, 0.25);
708
+ border-radius: 10px;
709
+ transition: background 0.3s ease;
710
+ }
711
+
712
+ .profiler-tabs::-webkit-scrollbar-thumb:hover {
713
+ background-color: rgba(0, 0, 0, 0.4);
714
+ }
715
+
716
+ .profiler-tabs::-webkit-scrollbar-corner {
717
+ background: transparent;
154
718
  }
155
719
 
156
720
  .profiler-controls {
@@ -164,24 +728,45 @@ export class Style {
164
728
  }
165
729
 
166
730
  .tab-btn {
731
+ position: relative;
167
732
  background: transparent;
168
733
  border: none;
169
734
  /*border-right: 1px solid var(--profiler-border);*/
170
735
  color: var(--text-secondary);
171
736
  padding: 8px 18px;
172
- cursor: pointer;
737
+ cursor: default;
173
738
  display: flex;
174
739
  align-items: center;
175
740
  font-family: var(--font-family);
176
- font-weight: 600;
741
+ font-weight: 600;
177
742
  font-size: 14px;
743
+ user-select: none;
744
+ transition: opacity 0.2s, transform 0.2s;
745
+ touch-action: none;
178
746
  }
179
747
 
180
748
  .tab-btn.active {
181
- border-bottom: 2px solid var(--accent-color);
749
+ border-bottom: 2px solid var(--accent-color);
182
750
  color: white;
183
751
  }
184
752
 
753
+ .tab-btn.active::before {
754
+ content: '⋮⋮';
755
+ position: absolute;
756
+ left: 3px;
757
+ top: calc(50% - 2px);
758
+ transform: translateY(-50%);
759
+ color: var(--profiler-border);
760
+ font-size: 18px;
761
+ letter-spacing: -2px;
762
+ opacity: 0.6;
763
+ }
764
+
765
+ .tab-btn.no-detach.active::before {
766
+ display: none;
767
+ }
768
+
769
+ #floating-btn,
185
770
  #maximize-btn,
186
771
  #hide-panel-btn {
187
772
  background: transparent;
@@ -189,19 +774,40 @@ export class Style {
189
774
  border-left: 1px solid var(--profiler-border);
190
775
  color: var(--text-secondary);
191
776
  width: 45px;
777
+ height: 100%;
192
778
  cursor: pointer;
193
779
  transition: all 0.2s;
194
780
  display: flex;
195
781
  align-items: center;
196
782
  justify-content: center;
783
+ flex-shrink: 0;
197
784
  }
198
785
 
786
+ /* Disable transitions in vertical mode to avoid broken animations */
787
+ #profiler-panel.position-right #floating-btn,
788
+ #profiler-panel.position-right #maximize-btn,
789
+ #profiler-panel.position-right #hide-panel-btn,
790
+ #profiler-panel.position-left #floating-btn,
791
+ #profiler-panel.position-left #maximize-btn,
792
+ #profiler-panel.position-left #hide-panel-btn {
793
+ transition: background-color 0.2s, color 0.2s;
794
+ }
795
+
796
+ #floating-btn:hover,
199
797
  #maximize-btn:hover,
200
798
  #hide-panel-btn:hover {
201
799
  background-color: rgba(255, 255, 255, 0.1);
202
800
  color: var(--text-primary);
203
801
  }
204
802
 
803
+ /* Hide maximize button when there are no tabs */
804
+ #profiler-panel.position-right.no-tabs #maximize-btn,
805
+ #profiler-panel.position-left.no-tabs #maximize-btn,
806
+ #profiler-panel.position-bottom.no-tabs #maximize-btn,
807
+ #profiler-panel.position-top.no-tabs #maximize-btn {
808
+ display: none !important;
809
+ }
810
+
205
811
  .profiler-content-wrapper {
206
812
  flex-grow: 1;
207
813
  overflow: hidden;
@@ -222,6 +828,8 @@ export class Style {
222
828
  box-sizing: border-box;
223
829
  display: flex;
224
830
  flex-direction: column;
831
+ user-select: none;
832
+ -webkit-user-select: none;
225
833
  }
226
834
 
227
835
  .profiler-content.active {
@@ -269,11 +877,23 @@ export class Style {
269
877
  transition: background-color 0.2s;
270
878
  gap: 10px;
271
879
  border-bottom: none;
880
+ user-select: none;
881
+ -webkit-user-select: none;
882
+ }
883
+
884
+ .parameters .list-item-row {
885
+ min-height: 31px;
886
+ }
887
+
888
+ .mini-panel-content .parameters .list-item-row {
889
+ min-height: 21px;
272
890
  }
273
891
 
274
892
  .list-item-wrapper {
275
893
  margin-top: 2px;
276
894
  margin-bottom: 2px;
895
+ user-select: none;
896
+ -webkit-user-select: none;
277
897
  }
278
898
 
279
899
  .list-item-wrapper:first-child {
@@ -291,6 +911,7 @@ export class Style {
291
911
 
292
912
  .list-item-wrapper.header-wrapper>.list-item-row>.list-item-cell:first-child {
293
913
  font-weight: 600;
914
+ line-height: 1;
294
915
  }
295
916
 
296
917
  .list-item-row.collapsible,
@@ -300,6 +921,7 @@ export class Style {
300
921
 
301
922
  .list-item-row.collapsible {
302
923
  background-color: rgba(0, 170, 255, 0.15) !important;
924
+ min-height: 23px;
303
925
  }
304
926
 
305
927
  .list-item-row.collapsible.alert,
@@ -326,6 +948,8 @@ export class Style {
326
948
  white-space: pre;
327
949
  display: flex;
328
950
  align-items: center;
951
+ user-select: none;
952
+ -webkit-user-select: none;
329
953
  }
330
954
 
331
955
  .list-item-cell:not(:first-child) {
@@ -343,6 +967,8 @@ export class Style {
343
967
  border-bottom: 1px solid var(--profiler-border);
344
968
  margin-bottom: 5px;
345
969
  gap: 10px;
970
+ user-select: none;
971
+ -webkit-user-select: none;
346
972
  }
347
973
 
348
974
  .list-item-wrapper.section-start {
@@ -394,10 +1020,11 @@ export class Style {
394
1020
  .list-scroll-wrapper {
395
1021
  overflow-x: auto;
396
1022
  width: 100%;
1023
+ user-select: none;
1024
+ -webkit-user-select: none;
397
1025
  }
398
1026
 
399
1027
  .list-container.parameters .list-item-row:not(.collapsible) {
400
- height: 31px;
401
1028
  }
402
1029
 
403
1030
  .graph-container {
@@ -430,7 +1057,7 @@ export class Style {
430
1057
  justify-content: space-between;
431
1058
  }
432
1059
 
433
- .console-filters-group {
1060
+ .console-buttons-group {
434
1061
  display: flex;
435
1062
  gap: 20px;
436
1063
  }
@@ -447,6 +1074,28 @@ export class Style {
447
1074
  border-radius: 15px;
448
1075
  }
449
1076
 
1077
+ .console-copy-button {
1078
+ background: transparent;
1079
+ border: none;
1080
+ color: var(--text-secondary);
1081
+ cursor: pointer;
1082
+ padding: 4px;
1083
+ display: flex;
1084
+ align-items: center;
1085
+ justify-content: center;
1086
+ border-radius: 4px;
1087
+ transition: color 0.2s, background-color 0.2s;
1088
+ }
1089
+
1090
+ .console-copy-button:hover {
1091
+ color: var(--text-primary);
1092
+ background-color: var(--profiler-hover);
1093
+ }
1094
+
1095
+ .console-copy-button.copied {
1096
+ color: var(--color-green);
1097
+ }
1098
+
450
1099
  #console-log {
451
1100
  display: flex;
452
1101
  flex-direction: column;
@@ -454,6 +1103,8 @@ export class Style {
454
1103
  padding: 10px;
455
1104
  overflow-y: auto;
456
1105
  flex-grow: 1;
1106
+ user-select: text;
1107
+ -webkit-user-select: text;
457
1108
  }
458
1109
 
459
1110
  .log-message {
@@ -558,6 +1209,7 @@ export class Style {
558
1209
  align-items: center;
559
1210
  cursor: pointer;
560
1211
  gap: 8px;
1212
+ will-change: transform;
561
1213
  }
562
1214
 
563
1215
  .custom-checkbox input {
@@ -567,7 +1219,7 @@ export class Style {
567
1219
  .custom-checkbox .checkmark {
568
1220
  width: 14px;
569
1221
  height: 14px;
570
- border: 1px solid var(--profiler-border);
1222
+ border: 1px solid var(--accent-color);
571
1223
  border-radius: 3px;
572
1224
  display: inline-flex;
573
1225
  justify-content: center;
@@ -577,8 +1229,8 @@ export class Style {
577
1229
 
578
1230
  .custom-checkbox .checkmark::after {
579
1231
  content: '';
580
- width: 8px;
581
- height: 8px;
1232
+ width: 6px;
1233
+ height: 6px;
582
1234
  background-color: var(--accent-color);
583
1235
  border-radius: 1px;
584
1236
  display: block;
@@ -636,13 +1288,320 @@ export class Style {
636
1288
  border: 1px solid var(--profiler-border);
637
1289
  }
638
1290
 
639
- @media screen and (max-width: 768px) and (orientation: portrait) {
1291
+ /* Override .param-control styles for mini-panel-content */
1292
+ .mini-panel-content input,
1293
+ .mini-panel-content select,
1294
+ .mini-panel-content button {
1295
+ padding: 2px 4px;
1296
+ height: 21px;
1297
+ line-height: 1.4;
1298
+ padding-top: 4px;
1299
+ }
1300
+
1301
+ .mini-panel-content .param-control input,
1302
+ .mini-panel-content .param-control select,
1303
+ .mini-panel-content .param-control button {
1304
+ background-color: #1e1e24c2;
1305
+ line-height: 1.0;
1306
+ }
1307
+
1308
+ .mini-panel-content .param-control select {
1309
+ padding: 2px 2px;
1310
+ padding-top: 3px;
1311
+ }
1312
+
1313
+ .mini-panel-content .param-control input[type="number"]::-webkit-outer-spin-button,
1314
+ .mini-panel-content .param-control input[type="number"]::-webkit-inner-spin-button {
1315
+ -webkit-appearance: none;
1316
+ margin: 0;
1317
+ }
1318
+
1319
+ .mini-panel-content .param-control input[type="number"] {
1320
+ -moz-appearance: textfield;
1321
+ }
1322
+
1323
+ .mini-panel-content .list-item-cell span {
1324
+ position: relative;
1325
+ top: 1px;
1326
+ margin-left: 2px;
1327
+ }
1328
+
1329
+ .mini-panel-content .custom-checkbox .checkmark {
1330
+ width: 12px;
1331
+ height: 12px;
1332
+ margin-bottom: 2px;
1333
+ will-change: transform;
1334
+ }
1335
+
1336
+ .mini-panel-content .list-container.parameters .list-item-row:not(.collapsible) {
1337
+ margin-bottom: 2px;
1338
+ }
1339
+
1340
+ @media screen and (max-width: 450px) and (orientation: portrait) {
640
1341
 
641
1342
  .console-filter-input {
642
1343
  max-width: 100px;
643
1344
  }
644
1345
 
645
1346
  }
1347
+
1348
+ /* Touch device optimizations */
1349
+ @media (hover: none) and (pointer: coarse) {
1350
+
1351
+ .panel-resizer {
1352
+ top: -10px !important;
1353
+ height: 20px !important;
1354
+ }
1355
+
1356
+ #profiler-panel.position-top .panel-resizer {
1357
+ top: auto !important;
1358
+ bottom: -10px !important;
1359
+ height: 20px !important;
1360
+ }
1361
+
1362
+ #profiler-panel.position-left .panel-resizer {
1363
+ right: -10px !important;
1364
+ width: 20px !important;
1365
+ height: 100% !important;
1366
+ }
1367
+
1368
+ #profiler-panel.position-right .panel-resizer {
1369
+ left: -10px !important;
1370
+ width: 20px !important;
1371
+ height: 100% !important;
1372
+ }
1373
+
1374
+ .detached-tab-resizer-top,
1375
+ .detached-tab-resizer-bottom {
1376
+ height: 10px !important;
1377
+ }
1378
+
1379
+ .detached-tab-resizer-left,
1380
+ .detached-tab-resizer-right {
1381
+ width: 10px !important;
1382
+ }
1383
+
1384
+ }
1385
+
1386
+ .drag-preview-indicator {
1387
+ position: fixed;
1388
+ background-color: rgba(0, 170, 255, 0.2);
1389
+ border: 2px dashed var(--accent-color);
1390
+ z-index: 999;
1391
+ pointer-events: none;
1392
+ transition: all 0.2s ease-out;
1393
+ }
1394
+
1395
+ /* Detached Tab Windows */
1396
+ .detached-tab-panel {
1397
+ position: fixed;
1398
+ width: 500px;
1399
+ height: 400px;
1400
+ background: var(--profiler-bg);
1401
+ border: 1px solid var(--profiler-border);
1402
+ border-radius: 8px;
1403
+ box-shadow: 0 10px 40px rgba(0, 0, 0, 0.5);
1404
+ z-index: 1002;
1405
+ display: flex;
1406
+ flex-direction: column;
1407
+ backdrop-filter: blur(10px);
1408
+ overflow: hidden;
1409
+ opacity: 1;
1410
+ visibility: visible;
1411
+ transition: opacity 0.2s, visibility 0.2s;
1412
+ }
1413
+
1414
+ #profiler-panel:not(.visible) ~ * .detached-tab-panel,
1415
+ body:has(#profiler-panel:not(.visible)) .detached-tab-panel {
1416
+ opacity: 0;
1417
+ visibility: hidden;
1418
+ pointer-events: none;
1419
+ }
1420
+
1421
+ .detached-tab-header {
1422
+ background: var(--profiler-header-bg);
1423
+ padding: 0 7px 0 15px;
1424
+ font-family: var(--font-family);
1425
+ font-size: 14px;
1426
+ color: var(--text-primary);
1427
+ font-weight: 600;
1428
+ display: flex;
1429
+ justify-content: space-between;
1430
+ align-items: center;
1431
+ border-bottom: 1px solid var(--profiler-border);
1432
+ cursor: grab;
1433
+ user-select: none;
1434
+ height: 38px;
1435
+ flex-shrink: 0;
1436
+ -webkit-font-smoothing: antialiased;
1437
+ -moz-osx-font-smoothing: grayscale;
1438
+ touch-action: none;
1439
+ }
1440
+
1441
+ .detached-tab-header:active {
1442
+ cursor: grabbing;
1443
+ }
1444
+
1445
+ .detached-header-controls {
1446
+ display: flex;
1447
+ gap: 5px;
1448
+ }
1449
+
1450
+ .detached-reattach-btn {
1451
+ background: transparent;
1452
+ border: none;
1453
+ color: var(--text-secondary);
1454
+ font-family: var(--font-family);
1455
+ font-size: 18px;
1456
+ line-height: 1;
1457
+ cursor: pointer;
1458
+ padding: 4px 8px;
1459
+ border-radius: 4px;
1460
+ transition: all 0.2s;
1461
+ display: flex;
1462
+ align-items: center;
1463
+ justify-content: center;
1464
+ -webkit-font-smoothing: antialiased;
1465
+ -moz-osx-font-smoothing: grayscale;
1466
+ }
1467
+
1468
+ .detached-reattach-btn:hover {
1469
+ background: rgba(0, 170, 255, 0.2);
1470
+ color: var(--accent-color);
1471
+ }
1472
+
1473
+ .detached-tab-content {
1474
+ flex: 1;
1475
+ overflow: auto;
1476
+ position: relative;
1477
+ background: var(--profiler-bg);
1478
+ }
1479
+
1480
+ .detached-tab-content::-webkit-scrollbar {
1481
+ width: 8px;
1482
+ height: 8px;
1483
+ }
1484
+
1485
+ .detached-tab-content::-webkit-scrollbar-track {
1486
+ background: transparent;
1487
+ }
1488
+
1489
+ .detached-tab-content::-webkit-scrollbar-thumb {
1490
+ background-color: rgba(0, 0, 0, 0.25);
1491
+ border-radius: 10px;
1492
+ transition: background 0.3s ease;
1493
+ }
1494
+
1495
+ .detached-tab-content::-webkit-scrollbar-thumb:hover {
1496
+ background-color: rgba(0, 0, 0, 0.4);
1497
+ }
1498
+
1499
+ .detached-tab-content::-webkit-scrollbar-corner {
1500
+ background: transparent;
1501
+ }
1502
+
1503
+ .detached-tab-content .profiler-content {
1504
+ display: block !important;
1505
+ height: 100%;
1506
+ visibility: visible !important;
1507
+ opacity: 1 !important;
1508
+ position: relative !important;
1509
+ }
1510
+
1511
+ .detached-tab-content .profiler-content > * {
1512
+ font-family: var(--font-mono);
1513
+ color: var(--text-primary);
1514
+ }
1515
+
1516
+ .detached-tab-resizer {
1517
+ position: absolute;
1518
+ bottom: 0;
1519
+ right: 0;
1520
+ width: 20px;
1521
+ height: 20px;
1522
+ cursor: nwse-resize;
1523
+ z-index: 10;
1524
+ touch-action: none;
1525
+ }
1526
+
1527
+ .detached-tab-resizer::after {
1528
+ content: '';
1529
+ position: absolute;
1530
+ bottom: 2px;
1531
+ right: 2px;
1532
+ width: 12px;
1533
+ height: 12px;
1534
+ border-right: 2px solid var(--profiler-border);
1535
+ border-bottom: 2px solid var(--profiler-border);
1536
+ border-bottom-right-radius: 6px;
1537
+ opacity: 0.5;
1538
+ }
1539
+
1540
+ .detached-tab-resizer:hover::after {
1541
+ opacity: 1;
1542
+ border-color: var(--accent-color);
1543
+ }
1544
+
1545
+ /* Edge resizers */
1546
+ .detached-tab-resizer-top {
1547
+ position: absolute;
1548
+ top: 0;
1549
+ left: 0;
1550
+ right: 0;
1551
+ height: 5px;
1552
+ cursor: ns-resize;
1553
+ z-index: 10;
1554
+ touch-action: none;
1555
+ }
1556
+
1557
+ .detached-tab-resizer-right {
1558
+ position: absolute;
1559
+ top: 0;
1560
+ right: 0;
1561
+ bottom: 0;
1562
+ width: 5px;
1563
+ cursor: ew-resize;
1564
+ z-index: 10;
1565
+ touch-action: none;
1566
+ }
1567
+
1568
+ .detached-tab-resizer-bottom {
1569
+ position: absolute;
1570
+ bottom: 0;
1571
+ left: 0;
1572
+ right: 0;
1573
+ height: 5px;
1574
+ cursor: ns-resize;
1575
+ z-index: 10;
1576
+ touch-action: none;
1577
+ }
1578
+
1579
+ .detached-tab-resizer-left {
1580
+ position: absolute;
1581
+ top: 0;
1582
+ left: 0;
1583
+ bottom: 0;
1584
+ width: 5px;
1585
+ cursor: ew-resize;
1586
+ z-index: 10;
1587
+ touch-action: none;
1588
+ }
1589
+
1590
+ /* Input number spin buttons - hide arrows */
1591
+ /* Chrome, Safari, Edge, Opera */
1592
+ #profiler-panel input[type="number"]::-webkit-outer-spin-button,
1593
+ #profiler-panel input[type="number"]::-webkit-inner-spin-button,
1594
+ .detached-tab-content input[type="number"]::-webkit-outer-spin-button,
1595
+ .detached-tab-content input[type="number"]::-webkit-inner-spin-button {
1596
+ -webkit-appearance: none;
1597
+ margin: 0;
1598
+ }
1599
+
1600
+ /* Firefox */
1601
+ #profiler-panel input[type="number"],
1602
+ .detached-tab-content input[type="number"] {
1603
+ -moz-appearance: textfield;
1604
+ }
646
1605
  `;
647
1606
  const styleElement = document.createElement( 'style' );
648
1607
  styleElement.id = 'profiler-styles';