@kiberon-labs/behave-graph-scene 1.0.1 → 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 (214) 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 +4 -3
  5. package/CHANGELOG.md +84 -0
  6. package/README.md +1 -1
  7. package/dist/Abstractions/Drivers/DummyScene.d.ts +47 -3
  8. package/dist/Abstractions/Drivers/DummyScene.d.ts.map +1 -1
  9. package/dist/Abstractions/Drivers/DummyScene.js +57 -0
  10. package/dist/Abstractions/Drivers/DummyScene.js.map +1 -1
  11. package/dist/Abstractions/IScene.d.ts +63 -4
  12. package/dist/Abstractions/IScene.d.ts.map +1 -1
  13. package/dist/Abstractions/IScene.js +19 -0
  14. package/dist/Abstractions/IScene.js.map +1 -0
  15. package/dist/Nodes/Actions/AddLight.d.ts +21 -0
  16. package/dist/Nodes/Actions/AddLight.d.ts.map +1 -0
  17. package/dist/Nodes/Actions/AddLight.js +38 -0
  18. package/dist/Nodes/Actions/AddLight.js.map +1 -0
  19. package/dist/Nodes/Actions/CloneMesh.d.ts +16 -0
  20. package/dist/Nodes/Actions/CloneMesh.d.ts.map +1 -0
  21. package/dist/Nodes/Actions/CloneMesh.js +28 -0
  22. package/dist/Nodes/Actions/CloneMesh.js.map +1 -0
  23. package/dist/Nodes/Actions/CreateMesh.d.ts +22 -0
  24. package/dist/Nodes/Actions/CreateMesh.d.ts.map +1 -0
  25. package/dist/Nodes/Actions/CreateMesh.js +44 -0
  26. package/dist/Nodes/Actions/CreateMesh.js.map +1 -0
  27. package/dist/Nodes/Actions/DeleteMesh.d.ts +15 -0
  28. package/dist/Nodes/Actions/DeleteMesh.d.ts.map +1 -0
  29. package/dist/Nodes/Actions/DeleteMesh.js +27 -0
  30. package/dist/Nodes/Actions/DeleteMesh.js.map +1 -0
  31. package/dist/Nodes/Actions/EaseSceneProperty.d.ts +1 -1
  32. package/dist/Nodes/Actions/EaseSceneProperty.d.ts.map +1 -1
  33. package/dist/Nodes/Actions/EaseSceneProperty.js +2 -2
  34. package/dist/Nodes/Actions/EaseSceneProperty.js.map +1 -1
  35. package/dist/Nodes/Actions/LookAt.d.ts +16 -0
  36. package/dist/Nodes/Actions/LookAt.d.ts.map +1 -0
  37. package/dist/Nodes/Actions/LookAt.js +35 -0
  38. package/dist/Nodes/Actions/LookAt.js.map +1 -0
  39. package/dist/Nodes/Actions/MoveTowards.d.ts +21 -0
  40. package/dist/Nodes/Actions/MoveTowards.d.ts.map +1 -0
  41. package/dist/Nodes/Actions/MoveTowards.js +46 -0
  42. package/dist/Nodes/Actions/MoveTowards.js.map +1 -0
  43. package/dist/Nodes/Actions/RemoveLight.d.ts +15 -0
  44. package/dist/Nodes/Actions/RemoveLight.d.ts.map +1 -0
  45. package/dist/Nodes/Actions/RemoveLight.js +27 -0
  46. package/dist/Nodes/Actions/RemoveLight.js.map +1 -0
  47. package/dist/Nodes/Actions/SetLightProperty.d.ts +25 -0
  48. package/dist/Nodes/Actions/SetLightProperty.d.ts.map +1 -0
  49. package/dist/Nodes/Actions/SetLightProperty.js +64 -0
  50. package/dist/Nodes/Actions/SetLightProperty.js.map +1 -0
  51. package/dist/Nodes/Actions/SetMaterialProperty.d.ts +25 -0
  52. package/dist/Nodes/Actions/SetMaterialProperty.d.ts.map +1 -0
  53. package/dist/Nodes/Actions/SetMaterialProperty.js +69 -0
  54. package/dist/Nodes/Actions/SetMaterialProperty.js.map +1 -0
  55. package/dist/Nodes/Actions/SetMeshPosition.d.ts +18 -0
  56. package/dist/Nodes/Actions/SetMeshPosition.d.ts.map +1 -0
  57. package/dist/Nodes/Actions/SetMeshPosition.js +34 -0
  58. package/dist/Nodes/Actions/SetMeshPosition.js.map +1 -0
  59. package/dist/Nodes/Actions/SetMeshVisible.d.ts +16 -0
  60. package/dist/Nodes/Actions/SetMeshVisible.d.ts.map +1 -0
  61. package/dist/Nodes/Actions/SetMeshVisible.js +28 -0
  62. package/dist/Nodes/Actions/SetMeshVisible.js.map +1 -0
  63. package/dist/Nodes/Actions/SetSceneProperty.d.ts +12 -1
  64. package/dist/Nodes/Actions/SetSceneProperty.d.ts.map +1 -1
  65. package/dist/Nodes/Actions/SetSceneProperty.js +1 -1
  66. package/dist/Nodes/Actions/SetSceneProperty.js.map +1 -1
  67. package/dist/Nodes/Events/OnAnyMeshClicked.d.ts +13 -0
  68. package/dist/Nodes/Events/OnAnyMeshClicked.d.ts.map +1 -0
  69. package/dist/Nodes/Events/OnAnyMeshClicked.js +34 -0
  70. package/dist/Nodes/Events/OnAnyMeshClicked.js.map +1 -0
  71. package/dist/Nodes/Events/OnSceneChanged.d.ts +12 -0
  72. package/dist/Nodes/Events/OnSceneChanged.d.ts.map +1 -0
  73. package/dist/Nodes/Events/OnSceneChanged.js +28 -0
  74. package/dist/Nodes/Events/OnSceneChanged.js.map +1 -0
  75. package/dist/Nodes/Events/OnSceneNodeClick.d.ts +14 -1
  76. package/dist/Nodes/Events/OnSceneNodeClick.d.ts.map +1 -1
  77. package/dist/Nodes/Events/OnSceneNodeClick.js +1 -1
  78. package/dist/Nodes/Events/OnSceneNodeClick.js.map +1 -1
  79. package/dist/Nodes/Logic/ColorNodes.d.ts +17 -13
  80. package/dist/Nodes/Logic/ColorNodes.d.ts.map +1 -1
  81. package/dist/Nodes/Logic/EulerNodes.d.ts +16 -12
  82. package/dist/Nodes/Logic/EulerNodes.d.ts.map +1 -1
  83. package/dist/Nodes/Logic/Mat3Nodes.d.ts +26 -23
  84. package/dist/Nodes/Logic/Mat3Nodes.d.ts.map +1 -1
  85. package/dist/Nodes/Logic/Mat3Nodes.js +0 -14
  86. package/dist/Nodes/Logic/Mat3Nodes.js.map +1 -1
  87. package/dist/Nodes/Logic/Mat4Nodes.d.ts +32 -28
  88. package/dist/Nodes/Logic/Mat4Nodes.d.ts.map +1 -1
  89. package/dist/Nodes/Logic/QuatNodes.d.ts +22 -18
  90. package/dist/Nodes/Logic/QuatNodes.d.ts.map +1 -1
  91. package/dist/Nodes/Logic/Vec2Nodes.d.ts +16 -12
  92. package/dist/Nodes/Logic/Vec2Nodes.d.ts.map +1 -1
  93. package/dist/Nodes/Logic/Vec3Nodes.d.ts +17 -13
  94. package/dist/Nodes/Logic/Vec3Nodes.d.ts.map +1 -1
  95. package/dist/Nodes/Logic/Vec4Nodes.d.ts +16 -12
  96. package/dist/Nodes/Logic/Vec4Nodes.d.ts.map +1 -1
  97. package/dist/Nodes/Queries/GetDistanceBetween.d.ts +18 -0
  98. package/dist/Nodes/Queries/GetDistanceBetween.d.ts.map +1 -0
  99. package/dist/Nodes/Queries/GetDistanceBetween.js +30 -0
  100. package/dist/Nodes/Queries/GetDistanceBetween.js.map +1 -0
  101. package/dist/Nodes/Queries/GetLightProperty.d.ts +23 -0
  102. package/dist/Nodes/Queries/GetLightProperty.d.ts.map +1 -0
  103. package/dist/Nodes/Queries/GetLightProperty.js +68 -0
  104. package/dist/Nodes/Queries/GetLightProperty.js.map +1 -0
  105. package/dist/Nodes/Queries/GetMaterialProperty.d.ts +23 -0
  106. package/dist/Nodes/Queries/GetMaterialProperty.d.ts.map +1 -0
  107. package/dist/Nodes/Queries/GetMaterialProperty.js +69 -0
  108. package/dist/Nodes/Queries/GetMaterialProperty.js.map +1 -0
  109. package/dist/Nodes/Queries/GetMeshPosition.d.ts +16 -0
  110. package/dist/Nodes/Queries/GetMeshPosition.d.ts.map +1 -0
  111. package/dist/Nodes/Queries/GetMeshPosition.js +29 -0
  112. package/dist/Nodes/Queries/GetMeshPosition.js.map +1 -0
  113. package/dist/Nodes/Queries/GetSceneProperty.d.ts +10 -1
  114. package/dist/Nodes/Queries/GetSceneProperty.d.ts.map +1 -1
  115. package/dist/Nodes/Queries/GetSceneProperty.js +2 -2
  116. package/dist/Nodes/Queries/GetSceneProperty.js.map +1 -1
  117. package/dist/Values/Internal/Mat3.d.ts +1 -1
  118. package/dist/Values/Internal/Mat3.d.ts.map +1 -1
  119. package/dist/Values/Internal/Mat3.js +1 -3
  120. package/dist/Values/Internal/Mat3.js.map +1 -1
  121. package/dist/Values/Internal/Mat4.d.ts.map +1 -1
  122. package/dist/Values/Internal/Mat4.js +1 -3
  123. package/dist/Values/Internal/Mat4.js.map +1 -1
  124. package/dist/Values/Internal/Vec3.d.ts +1 -1
  125. package/dist/Values/Internal/Vec3.d.ts.map +1 -1
  126. package/dist/Values/Internal/Vec3.js +0 -2
  127. package/dist/Values/Internal/Vec3.js.map +1 -1
  128. package/dist/Values/Internal/Vec4.d.ts.map +1 -1
  129. package/dist/Values/Internal/Vec4.js +0 -1
  130. package/dist/Values/Internal/Vec4.js.map +1 -1
  131. package/dist/_virtual/rolldown_runtime.js +23 -1
  132. package/dist/behave-graph.manifest.json +6082 -0
  133. package/dist/buildScene.d.ts.map +1 -1
  134. package/dist/buildScene.js +24 -3
  135. package/dist/buildScene.js.map +1 -1
  136. package/dist/index.d.ts +29 -3
  137. package/dist/index.d.ts.map +1 -0
  138. package/dist/index.js +22 -4
  139. package/dist/manifest.source.d.ts +7 -0
  140. package/dist/manifest.source.d.ts.map +1 -0
  141. package/dist/manifest.source.js +54 -0
  142. package/dist/manifest.source.js.map +1 -0
  143. package/dist/node_modules/.pnpm/react@19.2.3/node_modules/react/cjs/react-jsx-runtime.development.js +207 -0
  144. package/dist/node_modules/.pnpm/react@19.2.3/node_modules/react/cjs/react-jsx-runtime.development.js.map +1 -0
  145. package/dist/node_modules/.pnpm/react@19.2.3/node_modules/react/cjs/react-jsx-runtime.production.js +40 -0
  146. package/dist/node_modules/.pnpm/react@19.2.3/node_modules/react/cjs/react-jsx-runtime.production.js.map +1 -0
  147. package/dist/node_modules/.pnpm/react@19.2.3/node_modules/react/cjs/react.development.js +766 -0
  148. package/dist/node_modules/.pnpm/react@19.2.3/node_modules/react/cjs/react.development.js.map +1 -0
  149. package/dist/node_modules/.pnpm/react@19.2.3/node_modules/react/cjs/react.production.js +367 -0
  150. package/dist/node_modules/.pnpm/react@19.2.3/node_modules/react/cjs/react.production.js.map +1 -0
  151. package/dist/node_modules/.pnpm/react@19.2.3/node_modules/react/index.js +15 -0
  152. package/dist/node_modules/.pnpm/react@19.2.3/node_modules/react/index.js.map +1 -0
  153. package/dist/node_modules/.pnpm/react@19.2.3/node_modules/react/jsx-runtime.js +15 -0
  154. package/dist/node_modules/.pnpm/react@19.2.3/node_modules/react/jsx-runtime.js.map +1 -0
  155. package/dist/packages/nodes/scene/package.js +7 -0
  156. package/dist/packages/nodes/scene/package.js.map +1 -0
  157. package/dist/registerSceneProfile.d.ts +3 -3
  158. package/dist/registerSceneProfile.d.ts.map +1 -1
  159. package/dist/registerSceneProfile.js +35 -1
  160. package/dist/registerSceneProfile.js.map +1 -1
  161. package/dist/ui/controls/vec3.d.ts +9 -0
  162. package/dist/ui/controls/vec3.d.ts.map +1 -0
  163. package/dist/ui/controls/vec3.js +99 -0
  164. package/dist/ui/controls/vec3.js.map +1 -0
  165. package/package.json +28 -9
  166. package/src/Abstractions/Drivers/DummyScene.ts +110 -2
  167. package/src/Abstractions/IScene.ts +74 -3
  168. package/src/Nodes/Actions/AddLight.ts +46 -0
  169. package/src/Nodes/Actions/CloneMesh.ts +31 -0
  170. package/src/Nodes/Actions/CreateMesh.ts +47 -0
  171. package/src/Nodes/Actions/DeleteMesh.ts +29 -0
  172. package/src/Nodes/Actions/EaseSceneProperty.ts +6 -2
  173. package/src/Nodes/Actions/LookAt.ts +34 -0
  174. package/src/Nodes/Actions/MoveTowards.ts +55 -0
  175. package/src/Nodes/Actions/RemoveLight.ts +29 -0
  176. package/src/Nodes/Actions/SetLightProperty.ts +60 -0
  177. package/src/Nodes/Actions/SetMaterialProperty.ts +62 -0
  178. package/src/Nodes/Actions/SetMeshPosition.ts +37 -0
  179. package/src/Nodes/Actions/SetMeshVisible.ts +31 -0
  180. package/src/Nodes/Actions/SetSceneProperty.ts +3 -5
  181. package/src/Nodes/Events/OnAnyMeshClicked.ts +48 -0
  182. package/src/Nodes/Events/OnSceneChanged.ts +43 -0
  183. package/src/Nodes/Events/OnSceneNodeClick.ts +3 -3
  184. package/src/Nodes/Logic/Mat3Nodes.ts +0 -10
  185. package/src/Nodes/Queries/GetDistanceBetween.ts +37 -0
  186. package/src/Nodes/Queries/GetLightProperty.ts +53 -0
  187. package/src/Nodes/Queries/GetMaterialProperty.ts +55 -0
  188. package/src/Nodes/Queries/GetMeshPosition.ts +32 -0
  189. package/src/Nodes/Queries/GetSceneProperty.ts +4 -5
  190. package/src/Values/Internal/Mat3.ts +3 -3
  191. package/src/Values/Internal/Mat4.ts +5 -4
  192. package/src/Values/Internal/Vec3.ts +5 -4
  193. package/src/Values/Internal/Vec4.ts +3 -2
  194. package/src/buildScene.ts +36 -2
  195. package/src/index.ts +26 -2
  196. package/src/manifest.source.ts +61 -0
  197. package/src/registerSceneProfile.ts +41 -4
  198. package/src/ui/controls/vec3.tsx +69 -0
  199. package/stories/click.stories.tsx +112 -0
  200. package/stories/components/DemoScene.ts +610 -0
  201. package/stories/components/SceneViewer.tsx +204 -0
  202. package/stories/components/SceneViewerPanel.tsx +41 -0
  203. package/stories/data/clickDemo.json +94 -0
  204. package/stories/data/rotate.json +402 -0
  205. package/stories/index.stories.tsx +90 -0
  206. package/stories/plugin/sceneViewerPlugin.tsx +88 -0
  207. package/tests/manifest.test.ts +65 -0
  208. package/tests/readSceneGraphs.test.ts +8 -1
  209. package/tests/registerSceneProfile.test.ts +6 -5
  210. package/tsconfig.json +18 -11
  211. package/tsdown.config.ts +5 -1
  212. package/vite.config.js +7 -0
  213. package/src/Values/Internal/Mat2.ts +0 -214
  214. 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
+ );
@@ -0,0 +1,65 @@
1
+ import {
2
+ ContributionKind,
3
+ parseManifest,
4
+ runManifestSource
5
+ } from '@kiberon-labs/behave-graph';
6
+ import manifestSource from '../src/manifest.source.js';
7
+ import { describe, test, expect } from 'vitest';
8
+
9
+ describe('scene package manifest', () => {
10
+ test('generates a valid manifest from the source (no IScene driver, no node exec)', async () => {
11
+ const manifest = await runManifestSource(manifestSource);
12
+ expect(parseManifest(manifest).ok).toBe(true);
13
+ expect(manifest.package.name).toBe('@kiberon-labs/behave-graph-scene');
14
+ expect(manifest.categories).toEqual(['effect']);
15
+ expect(manifest.runtime).toBe('./index.js');
16
+ expect(manifest.nodes.length).toBeGreaterThan(100);
17
+ });
18
+
19
+ test('carries every scene value type with function-free JSON defaults', async () => {
20
+ const manifest = await runManifestSource(manifestSource);
21
+ const byName = Object.fromEntries(
22
+ manifest.values.map((v) => [v.name, v.defaultJSON])
23
+ );
24
+ expect(Object.keys(byName).sort()).toEqual([
25
+ 'color',
26
+ 'euler',
27
+ 'mat3',
28
+ 'mat4',
29
+ 'quat',
30
+ 'vec2',
31
+ 'vec3',
32
+ 'vec4'
33
+ ]);
34
+ expect(byName.vec3).toEqual([0, 0, 0]);
35
+ // identity matrix
36
+ expect(byName.mat4).toEqual([
37
+ 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1
38
+ ]);
39
+ // No functions leak into the manifest.
40
+ manifest.values.forEach((v) =>
41
+ Object.values(v).forEach((field) =>
42
+ expect(typeof field).not.toBe('function')
43
+ )
44
+ );
45
+ });
46
+
47
+ test('declares the vec3 control and a value-type contribution per scene type', async () => {
48
+ const manifest = await runManifestSource(manifestSource);
49
+ const control = manifest.contributions.find(
50
+ (c) => c.kind === ContributionKind.Control
51
+ );
52
+ expect(control?.export).toBe('./ui/controls/vec3.js#Vec3Control');
53
+ expect(control?.bind?.controlName).toBe('vec3');
54
+
55
+ const valueTypeContribs = manifest.contributions.filter(
56
+ (c) => c.kind === ContributionKind.ValueType
57
+ );
58
+ expect(valueTypeContribs).toHaveLength(8);
59
+ // Every declared value-type contribution binds to a value the manifest carries.
60
+ const valueNames = new Set(manifest.values.map((v) => v.name));
61
+ valueTypeContribs.forEach((c) =>
62
+ expect(valueNames.has(c.bind?.valueType ?? '')).toBe(true)
63
+ );
64
+ });
65
+ });
@@ -9,17 +9,24 @@ import {
9
9
  validateGraphLinks,
10
10
  registerCoreProfile,
11
11
  validateGraphAcyclic,
12
+ DefaultLogger,
13
+ ManualLifecycleEventEmitter,
12
14
  type IRegistry,
13
15
  type GraphInstance,
14
16
  type GraphJSON
15
17
  } from '@kiberon-labs/behave-graph';
16
18
  import { registerSceneProfile } from '@/registerSceneProfile.js';
19
+ import { DummyScene } from '@/Abstractions/Drivers/DummyScene.js';
17
20
  import { describe, test, expect } from 'vitest';
18
21
 
19
22
  let registry: IRegistry = {
20
23
  nodes: {},
21
24
  values: {},
22
- dependencies: {}
25
+ dependencies: {
26
+ ILogger: new DefaultLogger(),
27
+ ILifecycleEventEmitter: new ManualLifecycleEventEmitter(),
28
+ IScene: new DummyScene()
29
+ }
23
30
  };
24
31
  registry = registerCoreProfile(registry);
25
32
  registry = registerSceneProfile(registry);
@@ -1,11 +1,13 @@
1
1
  import {
2
2
  validateValueRegistry,
3
3
  registerCoreProfile,
4
- validateNodeRegistry,
4
+ DefaultLogger,
5
+ ManualLifecycleEventEmitter,
5
6
  type IRegistry
6
7
  } from '@kiberon-labs/behave-graph';
7
8
 
8
9
  import { registerSceneProfile } from '../src/registerSceneProfile.js';
10
+ import { DummyScene } from '../src/Abstractions/Drivers/DummyScene.js';
9
11
  import { describe, test, expect } from 'vitest';
10
12
 
11
13
  describe('scene profile', () => {
@@ -13,15 +15,14 @@ describe('scene profile', () => {
13
15
  nodes: {},
14
16
  values: {},
15
17
  dependencies: {
16
- IScene: null
18
+ ILogger: new DefaultLogger(),
19
+ ILifecycleEventEmitter: new ManualLifecycleEventEmitter(),
20
+ IScene: new DummyScene()
17
21
  }
18
22
  };
19
23
  registry = registerCoreProfile(registry);
20
24
  registry = registerSceneProfile(registry);
21
25
 
22
- test('validate node registry', () => {
23
- expect(validateNodeRegistry(registry)).toHaveLength(0);
24
- });
25
26
  test('validate value registry', () => {
26
27
  expect(validateValueRegistry(registry.values)).toHaveLength(0);
27
28
  });