@kiberon-labs/behave-graph-scene 1.0.0 → 2.0.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 (282) hide show
  1. package/.storybook/main.ts +18 -0
  2. package/.storybook/preview.ts +16 -0
  3. package/.storybook/vscode.css +822 -0
  4. package/.turbo/turbo-build.log +8 -0
  5. package/CHANGELOG.md +84 -0
  6. package/LICENSE +6 -0
  7. package/README.md +13 -0
  8. package/dist/Abstractions/Drivers/DummyScene.d.ts +64 -0
  9. package/dist/Abstractions/Drivers/DummyScene.d.ts.map +1 -0
  10. package/dist/Abstractions/Drivers/DummyScene.js +115 -0
  11. package/dist/Abstractions/Drivers/DummyScene.js.map +1 -0
  12. package/dist/Abstractions/IScene.d.ts +75 -0
  13. package/dist/Abstractions/IScene.d.ts.map +1 -0
  14. package/dist/Abstractions/IScene.js +19 -0
  15. package/dist/Abstractions/IScene.js.map +1 -0
  16. package/dist/GLTFJson.d.ts +33 -0
  17. package/dist/GLTFJson.d.ts.map +1 -0
  18. package/dist/Nodes/Actions/AddLight.d.ts +21 -0
  19. package/dist/Nodes/Actions/AddLight.d.ts.map +1 -0
  20. package/dist/Nodes/Actions/AddLight.js +38 -0
  21. package/dist/Nodes/Actions/AddLight.js.map +1 -0
  22. package/dist/Nodes/Actions/CloneMesh.d.ts +16 -0
  23. package/dist/Nodes/Actions/CloneMesh.d.ts.map +1 -0
  24. package/dist/Nodes/Actions/CloneMesh.js +28 -0
  25. package/dist/Nodes/Actions/CloneMesh.js.map +1 -0
  26. package/dist/Nodes/Actions/CreateMesh.d.ts +22 -0
  27. package/dist/Nodes/Actions/CreateMesh.d.ts.map +1 -0
  28. package/dist/Nodes/Actions/CreateMesh.js +44 -0
  29. package/dist/Nodes/Actions/CreateMesh.js.map +1 -0
  30. package/dist/Nodes/Actions/DeleteMesh.d.ts +15 -0
  31. package/dist/Nodes/Actions/DeleteMesh.d.ts.map +1 -0
  32. package/dist/Nodes/Actions/DeleteMesh.js +27 -0
  33. package/dist/Nodes/Actions/DeleteMesh.js.map +1 -0
  34. package/dist/Nodes/Actions/EaseSceneProperty.d.ts +23 -0
  35. package/dist/Nodes/Actions/EaseSceneProperty.d.ts.map +1 -0
  36. package/dist/Nodes/Actions/EaseSceneProperty.js +73 -0
  37. package/dist/Nodes/Actions/EaseSceneProperty.js.map +1 -0
  38. package/dist/Nodes/Actions/LookAt.d.ts +16 -0
  39. package/dist/Nodes/Actions/LookAt.d.ts.map +1 -0
  40. package/dist/Nodes/Actions/LookAt.js +35 -0
  41. package/dist/Nodes/Actions/LookAt.js.map +1 -0
  42. package/dist/Nodes/Actions/MoveTowards.d.ts +21 -0
  43. package/dist/Nodes/Actions/MoveTowards.d.ts.map +1 -0
  44. package/dist/Nodes/Actions/MoveTowards.js +46 -0
  45. package/dist/Nodes/Actions/MoveTowards.js.map +1 -0
  46. package/dist/Nodes/Actions/RemoveLight.d.ts +15 -0
  47. package/dist/Nodes/Actions/RemoveLight.d.ts.map +1 -0
  48. package/dist/Nodes/Actions/RemoveLight.js +27 -0
  49. package/dist/Nodes/Actions/RemoveLight.js.map +1 -0
  50. package/dist/Nodes/Actions/SetLightProperty.d.ts +25 -0
  51. package/dist/Nodes/Actions/SetLightProperty.d.ts.map +1 -0
  52. package/dist/Nodes/Actions/SetLightProperty.js +64 -0
  53. package/dist/Nodes/Actions/SetLightProperty.js.map +1 -0
  54. package/dist/Nodes/Actions/SetMaterialProperty.d.ts +25 -0
  55. package/dist/Nodes/Actions/SetMaterialProperty.d.ts.map +1 -0
  56. package/dist/Nodes/Actions/SetMaterialProperty.js +69 -0
  57. package/dist/Nodes/Actions/SetMaterialProperty.js.map +1 -0
  58. package/dist/Nodes/Actions/SetMeshPosition.d.ts +18 -0
  59. package/dist/Nodes/Actions/SetMeshPosition.d.ts.map +1 -0
  60. package/dist/Nodes/Actions/SetMeshPosition.js +34 -0
  61. package/dist/Nodes/Actions/SetMeshPosition.js.map +1 -0
  62. package/dist/Nodes/Actions/SetMeshVisible.d.ts +16 -0
  63. package/dist/Nodes/Actions/SetMeshVisible.d.ts.map +1 -0
  64. package/dist/Nodes/Actions/SetMeshVisible.js +28 -0
  65. package/dist/Nodes/Actions/SetMeshVisible.js.map +1 -0
  66. package/dist/Nodes/Actions/SetSceneProperty.d.ts +16 -0
  67. package/dist/Nodes/Actions/SetSceneProperty.d.ts.map +1 -0
  68. package/dist/Nodes/Actions/SetSceneProperty.js +28 -0
  69. package/dist/Nodes/Actions/SetSceneProperty.js.map +1 -0
  70. package/dist/Nodes/Events/OnAnyMeshClicked.d.ts +13 -0
  71. package/dist/Nodes/Events/OnAnyMeshClicked.d.ts.map +1 -0
  72. package/dist/Nodes/Events/OnAnyMeshClicked.js +34 -0
  73. package/dist/Nodes/Events/OnAnyMeshClicked.js.map +1 -0
  74. package/dist/Nodes/Events/OnSceneChanged.d.ts +12 -0
  75. package/dist/Nodes/Events/OnSceneChanged.d.ts.map +1 -0
  76. package/dist/Nodes/Events/OnSceneChanged.js +28 -0
  77. package/dist/Nodes/Events/OnSceneChanged.js.map +1 -0
  78. package/dist/Nodes/Events/OnSceneNodeClick.d.ts +18 -0
  79. package/dist/Nodes/Events/OnSceneNodeClick.d.ts.map +1 -0
  80. package/dist/Nodes/Events/OnSceneNodeClick.js +39 -0
  81. package/dist/Nodes/Events/OnSceneNodeClick.js.map +1 -0
  82. package/dist/Nodes/Logic/ColorNodes.d.ts +23 -0
  83. package/dist/Nodes/Logic/ColorNodes.d.ts.map +1 -0
  84. package/dist/Nodes/Logic/ColorNodes.js +137 -0
  85. package/dist/Nodes/Logic/ColorNodes.js.map +1 -0
  86. package/dist/Nodes/Logic/EulerNodes.d.ts +22 -0
  87. package/dist/Nodes/Logic/EulerNodes.d.ts.map +1 -0
  88. package/dist/Nodes/Logic/EulerNodes.js +132 -0
  89. package/dist/Nodes/Logic/EulerNodes.js.map +1 -0
  90. package/dist/Nodes/Logic/Mat3Nodes.d.ts +31 -0
  91. package/dist/Nodes/Logic/Mat3Nodes.d.ts.map +1 -0
  92. package/dist/Nodes/Logic/Mat3Nodes.js +199 -0
  93. package/dist/Nodes/Logic/Mat3Nodes.js.map +1 -0
  94. package/dist/Nodes/Logic/Mat4Nodes.d.ts +38 -0
  95. package/dist/Nodes/Logic/Mat4Nodes.d.ts.map +1 -0
  96. package/dist/Nodes/Logic/Mat4Nodes.js +267 -0
  97. package/dist/Nodes/Logic/Mat4Nodes.js.map +1 -0
  98. package/dist/Nodes/Logic/QuatNodes.d.ts +28 -0
  99. package/dist/Nodes/Logic/QuatNodes.d.ts.map +1 -0
  100. package/dist/Nodes/Logic/QuatNodes.js +173 -0
  101. package/dist/Nodes/Logic/QuatNodes.js.map +1 -0
  102. package/dist/Nodes/Logic/Vec2Nodes.d.ts +22 -0
  103. package/dist/Nodes/Logic/Vec2Nodes.d.ts.map +1 -0
  104. package/dist/Nodes/Logic/Vec2Nodes.js +115 -0
  105. package/dist/Nodes/Logic/Vec2Nodes.js.map +1 -0
  106. package/dist/Nodes/Logic/Vec3Nodes.d.ts +23 -0
  107. package/dist/Nodes/Logic/Vec3Nodes.d.ts.map +1 -0
  108. package/dist/Nodes/Logic/Vec3Nodes.js +137 -0
  109. package/dist/Nodes/Logic/Vec3Nodes.js.map +1 -0
  110. package/dist/Nodes/Logic/Vec4Nodes.d.ts +22 -0
  111. package/dist/Nodes/Logic/Vec4Nodes.d.ts.map +1 -0
  112. package/dist/Nodes/Logic/Vec4Nodes.js +132 -0
  113. package/dist/Nodes/Logic/Vec4Nodes.js.map +1 -0
  114. package/dist/Nodes/Logic/VecElements.d.ts +9 -0
  115. package/dist/Nodes/Logic/VecElements.d.ts.map +1 -0
  116. package/dist/Nodes/Logic/VecElements.js +22 -0
  117. package/dist/Nodes/Logic/VecElements.js.map +1 -0
  118. package/dist/Nodes/Queries/GetDistanceBetween.d.ts +18 -0
  119. package/dist/Nodes/Queries/GetDistanceBetween.d.ts.map +1 -0
  120. package/dist/Nodes/Queries/GetDistanceBetween.js +30 -0
  121. package/dist/Nodes/Queries/GetDistanceBetween.js.map +1 -0
  122. package/dist/Nodes/Queries/GetLightProperty.d.ts +23 -0
  123. package/dist/Nodes/Queries/GetLightProperty.d.ts.map +1 -0
  124. package/dist/Nodes/Queries/GetLightProperty.js +68 -0
  125. package/dist/Nodes/Queries/GetLightProperty.js.map +1 -0
  126. package/dist/Nodes/Queries/GetMaterialProperty.d.ts +23 -0
  127. package/dist/Nodes/Queries/GetMaterialProperty.d.ts.map +1 -0
  128. package/dist/Nodes/Queries/GetMaterialProperty.js +69 -0
  129. package/dist/Nodes/Queries/GetMaterialProperty.js.map +1 -0
  130. package/dist/Nodes/Queries/GetMeshPosition.d.ts +16 -0
  131. package/dist/Nodes/Queries/GetMeshPosition.d.ts.map +1 -0
  132. package/dist/Nodes/Queries/GetMeshPosition.js +29 -0
  133. package/dist/Nodes/Queries/GetMeshPosition.js.map +1 -0
  134. package/dist/Nodes/Queries/GetSceneProperty.d.ts +14 -0
  135. package/dist/Nodes/Queries/GetSceneProperty.d.ts.map +1 -0
  136. package/dist/Nodes/Queries/GetSceneProperty.js +23 -0
  137. package/dist/Nodes/Queries/GetSceneProperty.js.map +1 -0
  138. package/dist/Values/ColorValue.d.ts +7 -0
  139. package/dist/Values/ColorValue.d.ts.map +1 -0
  140. package/dist/Values/ColorValue.js +20 -0
  141. package/dist/Values/ColorValue.js.map +1 -0
  142. package/dist/Values/EulerValue.d.ts +7 -0
  143. package/dist/Values/EulerValue.d.ts.map +1 -0
  144. package/dist/Values/EulerValue.js +20 -0
  145. package/dist/Values/EulerValue.js.map +1 -0
  146. package/dist/Values/Internal/Mat3.d.ts +43 -0
  147. package/dist/Values/Internal/Mat3.d.ts.map +1 -0
  148. package/dist/Values/Internal/Mat3.js +276 -0
  149. package/dist/Values/Internal/Mat3.js.map +1 -0
  150. package/dist/Values/Internal/Mat4.d.ts +53 -0
  151. package/dist/Values/Internal/Mat4.d.ts.map +1 -0
  152. package/dist/Values/Internal/Mat4.js +443 -0
  153. package/dist/Values/Internal/Mat4.js.map +1 -0
  154. package/dist/Values/Internal/Vec2.d.ts +25 -0
  155. package/dist/Values/Internal/Vec2.d.ts.map +1 -0
  156. package/dist/Values/Internal/Vec2.js +64 -0
  157. package/dist/Values/Internal/Vec2.js.map +1 -0
  158. package/dist/Values/Internal/Vec3.d.ts +38 -0
  159. package/dist/Values/Internal/Vec3.d.ts.map +1 -0
  160. package/dist/Values/Internal/Vec3.js +157 -0
  161. package/dist/Values/Internal/Vec3.js.map +1 -0
  162. package/dist/Values/Internal/Vec4.d.ts +49 -0
  163. package/dist/Values/Internal/Vec4.d.ts.map +1 -0
  164. package/dist/Values/Internal/Vec4.js +190 -0
  165. package/dist/Values/Internal/Vec4.js.map +1 -0
  166. package/dist/Values/Mat3Value.d.ts +7 -0
  167. package/dist/Values/Mat3Value.d.ts.map +1 -0
  168. package/dist/Values/Mat3Value.js +16 -0
  169. package/dist/Values/Mat3Value.js.map +1 -0
  170. package/dist/Values/Mat4Value.d.ts +7 -0
  171. package/dist/Values/Mat4Value.d.ts.map +1 -0
  172. package/dist/Values/Mat4Value.js +16 -0
  173. package/dist/Values/Mat4Value.js.map +1 -0
  174. package/dist/Values/QuatValue.d.ts +7 -0
  175. package/dist/Values/QuatValue.d.ts.map +1 -0
  176. package/dist/Values/QuatValue.js +21 -0
  177. package/dist/Values/QuatValue.js.map +1 -0
  178. package/dist/Values/Vec2Value.d.ts +7 -0
  179. package/dist/Values/Vec2Value.d.ts.map +1 -0
  180. package/dist/Values/Vec2Value.js +16 -0
  181. package/dist/Values/Vec2Value.js.map +1 -0
  182. package/dist/Values/Vec3Value.d.ts +7 -0
  183. package/dist/Values/Vec3Value.d.ts.map +1 -0
  184. package/dist/Values/Vec3Value.js +20 -0
  185. package/dist/Values/Vec3Value.js.map +1 -0
  186. package/dist/Values/Vec4Value.d.ts +7 -0
  187. package/dist/Values/Vec4Value.d.ts.map +1 -0
  188. package/dist/Values/Vec4Value.js +21 -0
  189. package/dist/Values/Vec4Value.js.map +1 -0
  190. package/dist/_virtual/rolldown_runtime.js +35 -0
  191. package/dist/behave-graph.manifest.json +6082 -0
  192. package/dist/buildScene.d.ts +74 -0
  193. package/dist/buildScene.d.ts.map +1 -0
  194. package/dist/buildScene.js +304 -0
  195. package/dist/buildScene.js.map +1 -0
  196. package/dist/index.d.ts +57 -0
  197. package/dist/index.d.ts.map +1 -0
  198. package/dist/index.js +49 -0
  199. package/dist/manifest.source.d.ts +7 -0
  200. package/dist/manifest.source.d.ts.map +1 -0
  201. package/dist/manifest.source.js +54 -0
  202. package/dist/manifest.source.js.map +1 -0
  203. package/dist/node_modules/.pnpm/react@19.2.3/node_modules/react/cjs/react-jsx-runtime.development.js +207 -0
  204. package/dist/node_modules/.pnpm/react@19.2.3/node_modules/react/cjs/react-jsx-runtime.development.js.map +1 -0
  205. package/dist/node_modules/.pnpm/react@19.2.3/node_modules/react/cjs/react-jsx-runtime.production.js +40 -0
  206. package/dist/node_modules/.pnpm/react@19.2.3/node_modules/react/cjs/react-jsx-runtime.production.js.map +1 -0
  207. package/dist/node_modules/.pnpm/react@19.2.3/node_modules/react/cjs/react.development.js +766 -0
  208. package/dist/node_modules/.pnpm/react@19.2.3/node_modules/react/cjs/react.development.js.map +1 -0
  209. package/dist/node_modules/.pnpm/react@19.2.3/node_modules/react/cjs/react.production.js +367 -0
  210. package/dist/node_modules/.pnpm/react@19.2.3/node_modules/react/cjs/react.production.js.map +1 -0
  211. package/dist/node_modules/.pnpm/react@19.2.3/node_modules/react/index.js +15 -0
  212. package/dist/node_modules/.pnpm/react@19.2.3/node_modules/react/index.js.map +1 -0
  213. package/dist/node_modules/.pnpm/react@19.2.3/node_modules/react/jsx-runtime.js +15 -0
  214. package/dist/node_modules/.pnpm/react@19.2.3/node_modules/react/jsx-runtime.js.map +1 -0
  215. package/dist/packages/nodes/scene/package.js +7 -0
  216. package/dist/packages/nodes/scene/package.js.map +1 -0
  217. package/dist/registerSceneProfile.d.ts +10 -0
  218. package/dist/registerSceneProfile.d.ts.map +1 -0
  219. package/dist/registerSceneProfile.js +112 -0
  220. package/dist/registerSceneProfile.js.map +1 -0
  221. package/dist/ui/controls/vec3.d.ts +9 -0
  222. package/dist/ui/controls/vec3.d.ts.map +1 -0
  223. package/dist/ui/controls/vec3.js +99 -0
  224. package/dist/ui/controls/vec3.js.map +1 -0
  225. package/package.json +42 -13
  226. package/src/Abstractions/Drivers/DummyScene.ts +110 -2
  227. package/src/Abstractions/IScene.ts +74 -3
  228. package/src/Nodes/Actions/AddLight.ts +46 -0
  229. package/src/Nodes/Actions/CloneMesh.ts +31 -0
  230. package/src/Nodes/Actions/CreateMesh.ts +47 -0
  231. package/src/Nodes/Actions/DeleteMesh.ts +29 -0
  232. package/src/Nodes/Actions/EaseSceneProperty.ts +6 -2
  233. package/src/Nodes/Actions/LookAt.ts +34 -0
  234. package/src/Nodes/Actions/MoveTowards.ts +55 -0
  235. package/src/Nodes/Actions/RemoveLight.ts +29 -0
  236. package/src/Nodes/Actions/SetLightProperty.ts +60 -0
  237. package/src/Nodes/Actions/SetMaterialProperty.ts +62 -0
  238. package/src/Nodes/Actions/SetMeshPosition.ts +37 -0
  239. package/src/Nodes/Actions/SetMeshVisible.ts +31 -0
  240. package/src/Nodes/Actions/SetSceneProperty.ts +3 -5
  241. package/src/Nodes/Events/OnAnyMeshClicked.ts +48 -0
  242. package/src/Nodes/Events/OnSceneChanged.ts +43 -0
  243. package/src/Nodes/Events/OnSceneNodeClick.ts +3 -3
  244. package/src/Nodes/Logic/Mat3Nodes.ts +0 -10
  245. package/src/Nodes/Logic/QuatNodes.ts +11 -11
  246. package/src/Nodes/Queries/GetDistanceBetween.ts +37 -0
  247. package/src/Nodes/Queries/GetLightProperty.ts +53 -0
  248. package/src/Nodes/Queries/GetMaterialProperty.ts +55 -0
  249. package/src/Nodes/Queries/GetMeshPosition.ts +32 -0
  250. package/src/Nodes/Queries/GetSceneProperty.ts +4 -5
  251. package/src/Values/Internal/Mat3.ts +3 -3
  252. package/src/Values/Internal/Mat4.ts +5 -4
  253. package/src/Values/Internal/Vec3.ts +5 -4
  254. package/src/Values/Internal/Vec4.ts +3 -2
  255. package/src/buildScene.ts +36 -2
  256. package/src/index.ts +26 -2
  257. package/src/manifest.source.ts +61 -0
  258. package/src/registerSceneProfile.ts +41 -4
  259. package/src/ui/controls/vec3.tsx +69 -0
  260. package/stories/click.stories.tsx +112 -0
  261. package/stories/components/DemoScene.ts +610 -0
  262. package/stories/components/SceneViewer.tsx +204 -0
  263. package/stories/components/SceneViewerPanel.tsx +41 -0
  264. package/stories/data/clickDemo.json +94 -0
  265. package/stories/data/rotate.json +402 -0
  266. package/stories/index.stories.tsx +90 -0
  267. package/stories/plugin/sceneViewerPlugin.tsx +88 -0
  268. package/tests/graphs/logic/Color.json +53 -53
  269. package/tests/graphs/logic/Euler.json +53 -53
  270. package/tests/graphs/logic/Quaternion.json +56 -56
  271. package/tests/graphs/logic/Vector2.json +50 -50
  272. package/tests/graphs/logic/Vector3.json +53 -53
  273. package/tests/graphs/logic/Vector4.json +56 -56
  274. package/tests/manifest.test.ts +65 -0
  275. package/tests/readSceneGraphs.test.ts +8 -1
  276. package/tests/registerSceneProfile.test.ts +6 -5
  277. package/tests/tsconfig.json +10 -10
  278. package/tsconfig.json +61 -54
  279. package/tsdown.config.ts +5 -1
  280. package/vite.config.js +7 -0
  281. package/src/Values/Internal/Mat2.ts +0 -214
  282. package/src/loadScene.ts +0 -81
@@ -0,0 +1,402 @@
1
+ {
2
+ "v": "1.0.0",
3
+ "name": "Untitled Graph",
4
+ "annotations": {},
5
+ "data": {},
6
+ "flow": {
7
+ "nodes": [
8
+ {
9
+ "id": "7933216f-38df-4042-994b-8c57027db3d5",
10
+ "type": "lifecycle/onTick",
11
+ "flows": {
12
+ "flow": {
13
+ "nodeId": "c647cb90-9645-4d04-9f36-ba692f947a12",
14
+ "socket": "flow"
15
+ }
16
+ }
17
+ },
18
+ {
19
+ "id": "9a2b84eb-c66f-45f0-91ba-7e69c4708952",
20
+ "type": "scene/get/euler",
21
+ "parameters": {
22
+ "jsonPath": {
23
+ "value": "cube/rotation"
24
+ }
25
+ }
26
+ },
27
+ {
28
+ "id": "35d25c9e-7f3a-484f-94b9-0f90d008c020",
29
+ "type": "math/add/euler",
30
+ "parameters": {
31
+ "b": {
32
+ "link": {
33
+ "nodeId": "43a38425-e383-44a2-b305-a79779c18589",
34
+ "socket": "result"
35
+ }
36
+ },
37
+ "a": {
38
+ "link": {
39
+ "nodeId": "9a2b84eb-c66f-45f0-91ba-7e69c4708952",
40
+ "socket": "value"
41
+ }
42
+ }
43
+ }
44
+ },
45
+ {
46
+ "id": "c647cb90-9645-4d04-9f36-ba692f947a12",
47
+ "type": "scene/set/euler",
48
+ "parameters": {
49
+ "jsonPath": {
50
+ "value": "cube/rotation"
51
+ },
52
+ "value": {
53
+ "link": {
54
+ "nodeId": "35d25c9e-7f3a-484f-94b9-0f90d008c020",
55
+ "socket": "result"
56
+ }
57
+ }
58
+ },
59
+ "flows": {
60
+ "flow": {
61
+ "nodeId": "0b3b56fe-71f0-460e-83ae-1cf04dba010a",
62
+ "socket": "flow"
63
+ }
64
+ }
65
+ },
66
+ {
67
+ "id": "43a38425-e383-44a2-b305-a79779c18589",
68
+ "type": "math/scale/euler",
69
+ "parameters": {
70
+ "a": {
71
+ "value": [
72
+ 0,
73
+ 1,
74
+ 0
75
+ ]
76
+ },
77
+ "b": {
78
+ "link": {
79
+ "nodeId": "7933216f-38df-4042-994b-8c57027db3d5",
80
+ "socket": "deltaSeconds"
81
+ }
82
+ }
83
+ }
84
+ },
85
+ {
86
+ "id": "854d45c7-301c-40b8-aa3e-0ee4645f3489",
87
+ "type": "scene/get/euler",
88
+ "parameters": {
89
+ "jsonPath": {
90
+ "value": "torus/rotation"
91
+ }
92
+ }
93
+ },
94
+ {
95
+ "id": "73daf6b5-bfd9-4625-b719-805660217777",
96
+ "type": "math/add/euler",
97
+ "parameters": {
98
+ "a": {
99
+ "value": [
100
+ 0.1,
101
+ 0,
102
+ -0.1
103
+ ]
104
+ },
105
+ "b": {
106
+ "link": {
107
+ "nodeId": "854d45c7-301c-40b8-aa3e-0ee4645f3489",
108
+ "socket": "value"
109
+ }
110
+ }
111
+ }
112
+ },
113
+ {
114
+ "id": "0b3b56fe-71f0-460e-83ae-1cf04dba010a",
115
+ "type": "scene/set/euler",
116
+ "parameters": {
117
+ "jsonPath": {
118
+ "value": "torus/rotation"
119
+ },
120
+ "value": {
121
+ "link": {
122
+ "nodeId": "73daf6b5-bfd9-4625-b719-805660217777",
123
+ "socket": "result"
124
+ }
125
+ }
126
+ }
127
+ }
128
+ ],
129
+ "variables": [],
130
+ "customEvents": []
131
+ },
132
+ "nodes": [
133
+ {
134
+ "id": "7933216f-38df-4042-994b-8c57027db3d5",
135
+ "type": "behaveNode",
136
+ "position": {
137
+ "x": 126.18046192944144,
138
+ "y": 135.79999923706055
139
+ },
140
+ "data": {
141
+ "configuration": {},
142
+ "type": "lifecycle/onTick",
143
+ "ports": {}
144
+ },
145
+ "width": 120,
146
+ "height": 104,
147
+ "selected": false,
148
+ "dragging": false,
149
+ "positionAbsolute": {
150
+ "x": 126.18046192944144,
151
+ "y": 135.79999923706055
152
+ }
153
+ },
154
+ {
155
+ "id": "9a2b84eb-c66f-45f0-91ba-7e69c4708952",
156
+ "type": "behaveNode",
157
+ "position": {
158
+ "x": 246.50835416808889,
159
+ "y": 401.4752317127613
160
+ },
161
+ "data": {
162
+ "configuration": {},
163
+ "type": "scene/get/euler",
164
+ "ports": {
165
+ "jsonPath": "cube/rotation"
166
+ },
167
+ "annotations": {
168
+ "ui.executing": false
169
+ }
170
+ },
171
+ "width": 120,
172
+ "height": 104,
173
+ "selected": false,
174
+ "dragging": false,
175
+ "positionAbsolute": {
176
+ "x": 246.50835416808889,
177
+ "y": 401.4752317127613
178
+ }
179
+ },
180
+ {
181
+ "id": "35d25c9e-7f3a-484f-94b9-0f90d008c020",
182
+ "type": "behaveNode",
183
+ "position": {
184
+ "x": 566.7798401526775,
185
+ "y": 335.64361305869755
186
+ },
187
+ "data": {
188
+ "configuration": {},
189
+ "type": "math/add/euler",
190
+ "ports": {
191
+ "b": [
192
+ 0,
193
+ 0.1,
194
+ 0
195
+ ]
196
+ },
197
+ "annotations": {
198
+ "ui.executing": false
199
+ }
200
+ },
201
+ "width": 120,
202
+ "height": 136,
203
+ "selected": false,
204
+ "positionAbsolute": {
205
+ "x": 566.7798401526775,
206
+ "y": 335.64361305869755
207
+ },
208
+ "dragging": false
209
+ },
210
+ {
211
+ "id": "c647cb90-9645-4d04-9f36-ba692f947a12",
212
+ "type": "behaveNode",
213
+ "position": {
214
+ "x": 695.417237582175,
215
+ "y": 149.76164364252836
216
+ },
217
+ "data": {
218
+ "configuration": {},
219
+ "type": "scene/set/euler",
220
+ "ports": {
221
+ "jsonPath": "cube/rotation"
222
+ },
223
+ "annotations": {
224
+ "ui.executing": false
225
+ }
226
+ },
227
+ "width": 120,
228
+ "height": 136,
229
+ "selected": false,
230
+ "positionAbsolute": {
231
+ "x": 695.417237582175,
232
+ "y": 149.76164364252836
233
+ },
234
+ "dragging": false
235
+ },
236
+ {
237
+ "id": "43a38425-e383-44a2-b305-a79779c18589",
238
+ "type": "behaveNode",
239
+ "position": {
240
+ "x": 349.5981634660043,
241
+ "y": 222.60375588848257
242
+ },
243
+ "data": {
244
+ "configuration": {},
245
+ "type": "math/scale/euler",
246
+ "ports": {
247
+ "a": [
248
+ 0,
249
+ 1,
250
+ 0
251
+ ]
252
+ }
253
+ },
254
+ "width": 120,
255
+ "height": 136,
256
+ "selected": false,
257
+ "positionAbsolute": {
258
+ "x": 349.5981634660043,
259
+ "y": 222.60375588848257
260
+ },
261
+ "dragging": false
262
+ },
263
+ {
264
+ "id": "854d45c7-301c-40b8-aa3e-0ee4645f3489",
265
+ "type": "behaveNode",
266
+ "position": {
267
+ "x": 553.4721270320143,
268
+ "y": 573.7862679499057
269
+ },
270
+ "data": {
271
+ "configuration": {},
272
+ "type": "scene/get/euler",
273
+ "ports": {
274
+ "jsonPath": "torus/rotation"
275
+ }
276
+ },
277
+ "width": 120,
278
+ "height": 104,
279
+ "selected": false,
280
+ "positionAbsolute": {
281
+ "x": 553.4721270320143,
282
+ "y": 573.7862679499057
283
+ },
284
+ "dragging": false
285
+ },
286
+ {
287
+ "id": "73daf6b5-bfd9-4625-b719-805660217777",
288
+ "type": "behaveNode",
289
+ "position": {
290
+ "x": 847.4032303308832,
291
+ "y": 401.68187193938405
292
+ },
293
+ "data": {
294
+ "configuration": {},
295
+ "type": "math/add/euler",
296
+ "ports": {
297
+ "a": [
298
+ 0.1,
299
+ 0,
300
+ -0.1
301
+ ]
302
+ }
303
+ },
304
+ "width": 120,
305
+ "height": 136,
306
+ "selected": false,
307
+ "positionAbsolute": {
308
+ "x": 847.4032303308832,
309
+ "y": 401.68187193938405
310
+ },
311
+ "dragging": false
312
+ },
313
+ {
314
+ "id": "0b3b56fe-71f0-460e-83ae-1cf04dba010a",
315
+ "type": "behaveNode",
316
+ "position": {
317
+ "x": 961.4949085850494,
318
+ "y": 161.89597187978052
319
+ },
320
+ "data": {
321
+ "configuration": {},
322
+ "type": "scene/set/euler",
323
+ "ports": {
324
+ "jsonPath": "torus/rotation"
325
+ }
326
+ },
327
+ "width": 120,
328
+ "height": 136,
329
+ "selected": false,
330
+ "positionAbsolute": {
331
+ "x": 961.4949085850494,
332
+ "y": 161.89597187978052
333
+ },
334
+ "dragging": false
335
+ }
336
+ ],
337
+ "edges": [
338
+ {
339
+ "id": "c3410f8c-479e-4b27-919a-8fbbf4175923",
340
+ "source": "c647cb90-9645-4d04-9f36-ba692f947a12",
341
+ "target": "0b3b56fe-71f0-460e-83ae-1cf04dba010a",
342
+ "sourceHandle": "flow",
343
+ "targetHandle": "flow"
344
+ },
345
+ {
346
+ "id": "087992ae-4c68-4f8c-a907-48ba5dfc5484",
347
+ "source": "73daf6b5-bfd9-4625-b719-805660217777",
348
+ "target": "0b3b56fe-71f0-460e-83ae-1cf04dba010a",
349
+ "sourceHandle": "result",
350
+ "targetHandle": "value"
351
+ },
352
+ {
353
+ "id": "d89f17af-641e-4915-9a02-349a11d8beee",
354
+ "source": "854d45c7-301c-40b8-aa3e-0ee4645f3489",
355
+ "target": "73daf6b5-bfd9-4625-b719-805660217777",
356
+ "sourceHandle": "value",
357
+ "targetHandle": "b"
358
+ },
359
+ {
360
+ "id": "1a360ac4-d9fd-4129-ac15-cd47fc5b3dfa",
361
+ "source": "43a38425-e383-44a2-b305-a79779c18589",
362
+ "target": "35d25c9e-7f3a-484f-94b9-0f90d008c020",
363
+ "sourceHandle": "result",
364
+ "targetHandle": "b"
365
+ },
366
+ {
367
+ "id": "c602ec99-3292-43d4-a609-5c27ed10e539",
368
+ "source": "7933216f-38df-4042-994b-8c57027db3d5",
369
+ "target": "43a38425-e383-44a2-b305-a79779c18589",
370
+ "sourceHandle": "deltaSeconds",
371
+ "targetHandle": "b"
372
+ },
373
+ {
374
+ "id": "a0240d58-cc03-448a-8fc5-3169cb415ec1",
375
+ "source": "7933216f-38df-4042-994b-8c57027db3d5",
376
+ "target": "c647cb90-9645-4d04-9f36-ba692f947a12",
377
+ "sourceHandle": "flow",
378
+ "targetHandle": "flow"
379
+ },
380
+ {
381
+ "id": "514f084f-85ca-43cf-83b0-40569b4a00fe",
382
+ "source": "35d25c9e-7f3a-484f-94b9-0f90d008c020",
383
+ "target": "c647cb90-9645-4d04-9f36-ba692f947a12",
384
+ "sourceHandle": "result",
385
+ "targetHandle": "value"
386
+ },
387
+ {
388
+ "id": "672606d4-0c8a-4c36-9737-fcff4dc4d41c",
389
+ "source": "9a2b84eb-c66f-45f0-91ba-7e69c4708952",
390
+ "target": "35d25c9e-7f3a-484f-94b9-0f90d008c020",
391
+ "sourceHandle": "value",
392
+ "targetHandle": "a"
393
+ }
394
+ ],
395
+ "user": {
396
+ "viewport": {
397
+ "x": -80.62843345750235,
398
+ "y": 34.07906106637273,
399
+ "zoom": 0.5171279877973534
400
+ }
401
+ }
402
+ }
@@ -0,0 +1,90 @@
1
+ import type { Meta, StoryObj } from '@storybook/react-vite';
2
+ import {
3
+ kitchenSinkPlugin,
4
+ GraphProvider,
5
+ LayoutController,
6
+ localGraphRunnerPlugin,
7
+ System,
8
+ SystemProvider
9
+ } from '@kiberon-labs/behave-graph-flow';
10
+ import {
11
+ DefaultLogger,
12
+ ManualLifecycleEventEmitter,
13
+ registerCoreProfile
14
+ } from '@kiberon-labs/behave-graph';
15
+ import { registerSceneProfile } from '@/registerSceneProfile';
16
+ import { DemoScene } from './components/DemoScene';
17
+ import { sceneViewerPlugin } from './plugin/sceneViewerPlugin';
18
+ import { Vec3Control } from '@/ui/controls/vec3';
19
+ import rotate from './data/rotate.json';
20
+
21
+ const meta: Meta<typeof LayoutController> = {
22
+ component: LayoutController,
23
+ title: 'Apex/default',
24
+ decorators: [(Story) => <Story />],
25
+ parameters: {
26
+ layout: 'fullscreen'
27
+ }
28
+ };
29
+
30
+ export default meta;
31
+
32
+ type Story = StoryObj<typeof meta>;
33
+
34
+ // Create a demo scene instance
35
+ const demoScene = new DemoScene();
36
+
37
+ // Create the old-style registry for node definitions
38
+ const coreRegistry = registerSceneProfile(
39
+ registerCoreProfile({
40
+ nodes: {},
41
+ values: {},
42
+ dependencies: {
43
+ IScene: demoScene,
44
+ ILifecycleEventEmitter: new ManualLifecycleEventEmitter(),
45
+ ILogger: new DefaultLogger()
46
+ }
47
+ })
48
+ );
49
+
50
+ // Convert to INodeRegistry
51
+ const nodeRegistry = {
52
+ values: coreRegistry.values,
53
+ specs: []
54
+ };
55
+
56
+ const defaultSys = new System(nodeRegistry);
57
+ const defaultSession = defaultSys.createSession('graph');
58
+
59
+ defaultSys.controlStore.getState().registerControl('color', Vec3Control);
60
+ defaultSys.controlStore.getState().registerControl('vec3', Vec3Control);
61
+ defaultSys.controlStore.getState().registerControl('euler', Vec3Control);
62
+
63
+ defaultSession.graph.deseralize(rotate);
64
+ defaultSession.flowStore.getState().setGraph(rotate.flow, { skipLayout: true });
65
+
66
+ defaultSys.registerPlugin(kitchenSinkPlugin);
67
+ defaultSys.registerPlugin(localGraphRunnerPlugin, {
68
+ registry: coreRegistry,
69
+ // Use RAF-based tick strategy for smooth animation frame sync
70
+ tickStrategy: async () => {
71
+ await new Promise((resolve) => requestAnimationFrame(resolve));
72
+ }
73
+ });
74
+ defaultSys.registerPlugin(sceneViewerPlugin, {
75
+ scene: demoScene,
76
+ addMenuItem: true
77
+ });
78
+
79
+ export const Default: Story = {
80
+ render: () => {
81
+ return (
82
+ <SystemProvider value={defaultSys}>
83
+ <GraphProvider value={defaultSession}>
84
+ <LayoutController />
85
+ </GraphProvider>
86
+ </SystemProvider>
87
+ );
88
+ },
89
+ args: {}
90
+ };
@@ -0,0 +1,88 @@
1
+ import { MenuItemElement, plugin } from '@kiberon-labs/behave-graph-flow';
2
+ import type { System } from '@kiberon-labs/behave-graph-flow';
3
+ import type { DemoScene } from '../components/DemoScene';
4
+ import { SceneViewerPanel } from '../components/SceneViewerPanel';
5
+
6
+ interface SceneViewerPluginOptions {
7
+ scene: DemoScene;
8
+ addMenuItem?: boolean;
9
+ }
10
+
11
+ /**
12
+ * Plugin loader function that adds a 3D Scene Viewer tab to the system
13
+ */
14
+ const sceneViewerPluginLoader = (
15
+ system: System,
16
+ options?: SceneViewerPluginOptions
17
+ ) => {
18
+ const scene = options?.scene;
19
+
20
+ // Register the scene viewer tab
21
+ system.tabLoader.register('sceneViewer', () => {
22
+ return {
23
+ id: 'sceneViewer',
24
+ closable: true,
25
+ title: '3D Scene Viewer',
26
+ group: 'default',
27
+ content: () =>
28
+ scene ? (
29
+ <SceneViewerPanel scene={scene} />
30
+ ) : (
31
+ <div style={{ padding: 8 }}>No scene provided to the viewer.</div>
32
+ )
33
+ };
34
+ });
35
+
36
+ // Add menu item to Window menu (unless disabled)
37
+ if (options?.addMenuItem !== false) {
38
+ const menuStore = system.menubarStore;
39
+
40
+ const currentItems = menuStore.getState().items;
41
+ const windowMenu = currentItems.find((menu) => menu.name === 'window');
42
+
43
+ if (windowMenu) {
44
+ // Check if item already exists
45
+ const existingItem = windowMenu.items?.find(
46
+ (item) => 'name' in item && item.name === 'sceneViewer'
47
+ );
48
+
49
+ if (!existingItem) {
50
+ const newMenuItem = {
51
+ name: 'sceneViewer',
52
+ render: function SceneViewerMenuItem() {
53
+ return (
54
+ <MenuItemElement
55
+ onClick={() =>
56
+ system.tabStore.getState().openTab('sceneViewer')
57
+ }
58
+ >
59
+ 3D Scene Viewer
60
+ </MenuItemElement>
61
+ );
62
+ }
63
+ };
64
+
65
+ menuStore.setState({
66
+ items: currentItems.map((menu) =>
67
+ menu.name === 'window'
68
+ ? { ...menu, items: [...(menu.items || []), newMenuItem] }
69
+ : menu
70
+ )
71
+ });
72
+ }
73
+ }
74
+ }
75
+
76
+ // Automatically open the scene viewer tab
77
+ setTimeout(() => {
78
+ system.tabStore.getState().openTab('sceneViewer');
79
+ }, 100);
80
+ };
81
+
82
+ /**
83
+ * Plugin that adds a 3D Scene Viewer tab to the system
84
+ */
85
+ export const sceneViewerPlugin = plugin<SceneViewerPluginOptions>(
86
+ sceneViewerPluginLoader,
87
+ { name: 'sceneViewerPlugin' }
88
+ );
@@ -1,53 +1,53 @@
1
- {
2
- "nodes": [
3
- {
4
- "type": "lifecycle/onStart",
5
- "id": "0",
6
- "flows": {
7
- "flow": {
8
- "nodeId": "3",
9
- "socket": "flow"
10
- }
11
- }
12
- },
13
- {
14
- "type": "math/toColor/rgb",
15
- "id": "1",
16
- "parameters": {
17
- "r": {
18
- "value": 1
19
- },
20
- "g": {
21
- "value": 0
22
- },
23
- "b": {
24
- "value": 0
25
- }
26
- }
27
- },
28
- {
29
- "type": "math/toString/color",
30
- "id": "2",
31
- "parameters": {
32
- "a": {
33
- "link": {
34
- "nodeId": "1",
35
- "socket": "result"
36
- }
37
- }
38
- }
39
- },
40
- {
41
- "type": "debug/log",
42
- "id": "3",
43
- "parameters": {
44
- "text": {
45
- "link": {
46
- "nodeId": "2",
47
- "socket": "result"
48
- }
49
- }
50
- }
51
- }
52
- ]
53
- }
1
+ {
2
+ "nodes": [
3
+ {
4
+ "type": "lifecycle/onStart",
5
+ "id": "0",
6
+ "flows": {
7
+ "flow": {
8
+ "nodeId": "3",
9
+ "socket": "flow"
10
+ }
11
+ }
12
+ },
13
+ {
14
+ "type": "math/toColor/rgb",
15
+ "id": "1",
16
+ "parameters": {
17
+ "r": {
18
+ "value": 1
19
+ },
20
+ "g": {
21
+ "value": 0
22
+ },
23
+ "b": {
24
+ "value": 0
25
+ }
26
+ }
27
+ },
28
+ {
29
+ "type": "math/toString/color",
30
+ "id": "2",
31
+ "parameters": {
32
+ "a": {
33
+ "link": {
34
+ "nodeId": "1",
35
+ "socket": "result"
36
+ }
37
+ }
38
+ }
39
+ },
40
+ {
41
+ "type": "debug/log",
42
+ "id": "3",
43
+ "parameters": {
44
+ "text": {
45
+ "link": {
46
+ "nodeId": "2",
47
+ "socket": "result"
48
+ }
49
+ }
50
+ }
51
+ }
52
+ ]
53
+ }