@reactvision/react-viro 2.42.0 → 2.43.1

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 (475) hide show
  1. package/README.md +12 -6
  2. package/android/react_viro/react_viro-release.aar +0 -0
  3. package/components/AR/ViroARPlaneSelector.tsx +76 -37
  4. package/components/Utilities/ViroVersion.ts +1 -1
  5. package/dist/components/AR/ViroARPlaneSelector.d.ts +1 -1
  6. package/dist/components/AR/ViroARPlaneSelector.js +46 -18
  7. package/dist/components/Utilities/ViroVersion.d.ts +1 -1
  8. package/dist/components/Utilities/ViroVersion.js +1 -1
  9. package/dist/dynamic-index.d.ts +11 -0
  10. package/dist/dynamic-index.js +28 -0
  11. package/dist/examples/AutoDetectionExample.d.ts +10 -0
  12. package/dist/examples/AutoDetectionExample.js +91 -0
  13. package/dist/fabric-interop/NativeViro.d.ts +42 -0
  14. package/dist/fabric-interop/NativeViro.js +262 -0
  15. package/dist/fabric-interop/ViroEventsManager.d.ts +83 -0
  16. package/dist/fabric-interop/ViroEventsManager.js +222 -0
  17. package/dist/fabric-interop/ViroFabricContainer.d.ts +34 -0
  18. package/dist/fabric-interop/ViroFabricContainer.js +200 -0
  19. package/dist/fabric-interop/android/src/main/js/specs/ViroFabricContainerViewNativeComponent.d.ts +35 -0
  20. package/dist/fabric-interop/android/src/main/js/specs/ViroFabricContainerViewNativeComponent.js +20 -0
  21. package/dist/fabric-interop/components/AR/ViroARPlane.d.ts +22 -0
  22. package/dist/fabric-interop/components/AR/ViroARPlane.js +95 -0
  23. package/dist/fabric-interop/components/AR/ViroARPlaneSelector.d.ts +43 -0
  24. package/dist/fabric-interop/components/AR/ViroARPlaneSelector.js +152 -0
  25. package/dist/fabric-interop/components/AR/ViroARTrackingTargets.d.ts +55 -0
  26. package/dist/fabric-interop/components/AR/ViroARTrackingTargets.js +85 -0
  27. package/dist/fabric-interop/components/AR/ViroCommonProps.d.ts +91 -0
  28. package/dist/fabric-interop/components/AR/ViroCommonProps.js +7 -0
  29. package/dist/fabric-interop/components/Animation/ViroAnimations.d.ts +48 -0
  30. package/dist/fabric-interop/components/Animation/ViroAnimations.js +64 -0
  31. package/dist/fabric-interop/components/Material/ViroMaterials.d.ts +66 -0
  32. package/dist/fabric-interop/components/Material/ViroMaterials.js +85 -0
  33. package/dist/fabric-interop/components/Types/ViroEvents.d.ts +202 -0
  34. package/dist/fabric-interop/components/Types/ViroEvents.js +53 -0
  35. package/dist/fabric-interop/components/Types/ViroUtils.d.ts +137 -0
  36. package/dist/fabric-interop/components/Types/ViroUtils.js +7 -0
  37. package/dist/fabric-interop/components/Viro360Image.d.ts +23 -0
  38. package/dist/fabric-interop/components/Viro360Image.js +45 -0
  39. package/dist/fabric-interop/components/Viro360Video.d.ts +29 -0
  40. package/dist/fabric-interop/components/Viro360Video.js +47 -0
  41. package/dist/fabric-interop/components/Viro3DObject.d.ts +60 -0
  42. package/dist/fabric-interop/components/Viro3DObject.js +49 -0
  43. package/dist/fabric-interop/components/Viro3DSceneNavigator.d.ts +49 -0
  44. package/dist/fabric-interop/components/Viro3DSceneNavigator.js +388 -0
  45. package/dist/fabric-interop/components/ViroARCamera.d.ts +29 -0
  46. package/dist/fabric-interop/components/ViroARCamera.js +64 -0
  47. package/dist/fabric-interop/components/ViroARImageMarker.d.ts +21 -0
  48. package/dist/fabric-interop/components/ViroARImageMarker.js +71 -0
  49. package/dist/fabric-interop/components/ViroARObjectMarker.d.ts +21 -0
  50. package/dist/fabric-interop/components/ViroARObjectMarker.js +71 -0
  51. package/dist/fabric-interop/components/ViroARPlane.d.ts +24 -0
  52. package/dist/fabric-interop/components/ViroARPlane.js +88 -0
  53. package/dist/fabric-interop/components/ViroARScene.d.ts +29 -0
  54. package/dist/fabric-interop/components/ViroARScene.js +89 -0
  55. package/dist/fabric-interop/components/ViroARSceneNavigator.d.ts +29 -0
  56. package/dist/fabric-interop/components/ViroARSceneNavigator.js +76 -0
  57. package/dist/fabric-interop/components/ViroAmbientLight.d.ts +19 -0
  58. package/dist/fabric-interop/components/ViroAmbientLight.js +46 -0
  59. package/dist/fabric-interop/components/ViroAnimatedComponent.d.ts +24 -0
  60. package/dist/fabric-interop/components/ViroAnimatedComponent.js +63 -0
  61. package/dist/fabric-interop/components/ViroAnimatedImage.d.ts +28 -0
  62. package/dist/fabric-interop/components/ViroAnimatedImage.js +49 -0
  63. package/dist/fabric-interop/components/ViroBox.d.ts +20 -0
  64. package/dist/fabric-interop/components/ViroBox.js +47 -0
  65. package/dist/fabric-interop/components/ViroButton.d.ts +32 -0
  66. package/dist/fabric-interop/components/ViroButton.js +92 -0
  67. package/dist/fabric-interop/components/ViroCamera.d.ts +17 -0
  68. package/dist/fabric-interop/components/ViroCamera.js +30 -0
  69. package/dist/fabric-interop/components/ViroController.d.ts +19 -0
  70. package/dist/fabric-interop/components/ViroController.js +64 -0
  71. package/dist/fabric-interop/components/ViroDirectionalLight.d.ts +28 -0
  72. package/dist/fabric-interop/components/ViroDirectionalLight.js +55 -0
  73. package/dist/fabric-interop/components/ViroFlexView.d.ts +36 -0
  74. package/dist/fabric-interop/components/ViroFlexView.js +97 -0
  75. package/dist/fabric-interop/components/ViroGeometry.d.ts +23 -0
  76. package/dist/fabric-interop/components/ViroGeometry.js +50 -0
  77. package/dist/fabric-interop/components/ViroGlobal.d.ts +45 -0
  78. package/dist/fabric-interop/components/ViroGlobal.js +20 -0
  79. package/dist/fabric-interop/components/ViroImage.d.ts +29 -0
  80. package/dist/fabric-interop/components/ViroImage.js +52 -0
  81. package/dist/fabric-interop/components/ViroLightingEnvironment.d.ts +19 -0
  82. package/dist/fabric-interop/components/ViroLightingEnvironment.js +44 -0
  83. package/dist/fabric-interop/components/ViroMaterialVideo.d.ts +30 -0
  84. package/dist/fabric-interop/components/ViroMaterialVideo.js +48 -0
  85. package/dist/fabric-interop/components/ViroNode.d.ts +36 -0
  86. package/dist/fabric-interop/components/ViroNode.js +28 -0
  87. package/dist/fabric-interop/components/ViroOmniLight.d.ts +21 -0
  88. package/dist/fabric-interop/components/ViroOmniLight.js +48 -0
  89. package/dist/fabric-interop/components/ViroOrbitCamera.d.ts +17 -0
  90. package/dist/fabric-interop/components/ViroOrbitCamera.js +30 -0
  91. package/dist/fabric-interop/components/ViroParticleEmitter.d.ts +51 -0
  92. package/dist/fabric-interop/components/ViroParticleEmitter.js +50 -0
  93. package/dist/fabric-interop/components/ViroPolygon.d.ts +20 -0
  94. package/dist/fabric-interop/components/ViroPolygon.js +47 -0
  95. package/dist/fabric-interop/components/ViroPolyline.d.ts +19 -0
  96. package/dist/fabric-interop/components/ViroPolyline.js +46 -0
  97. package/dist/fabric-interop/components/ViroPortal.d.ts +16 -0
  98. package/dist/fabric-interop/components/ViroPortal.js +73 -0
  99. package/dist/fabric-interop/components/ViroPortalScene.d.ts +16 -0
  100. package/dist/fabric-interop/components/ViroPortalScene.js +29 -0
  101. package/dist/fabric-interop/components/ViroQuad.d.ts +39 -0
  102. package/dist/fabric-interop/components/ViroQuad.js +49 -0
  103. package/dist/fabric-interop/components/ViroScene.d.ts +29 -0
  104. package/dist/fabric-interop/components/ViroScene.js +103 -0
  105. package/dist/fabric-interop/components/ViroSceneNavigator.d.ts +23 -0
  106. package/dist/fabric-interop/components/ViroSceneNavigator.js +73 -0
  107. package/dist/fabric-interop/components/ViroSkyBox.d.ts +39 -0
  108. package/dist/fabric-interop/components/ViroSkyBox.js +44 -0
  109. package/dist/fabric-interop/components/ViroSound.d.ts +23 -0
  110. package/dist/fabric-interop/components/ViroSound.js +46 -0
  111. package/dist/fabric-interop/components/ViroSoundField.d.ts +24 -0
  112. package/dist/fabric-interop/components/ViroSoundField.js +47 -0
  113. package/dist/fabric-interop/components/ViroSpatialSound.d.ts +27 -0
  114. package/dist/fabric-interop/components/ViroSpatialSound.js +50 -0
  115. package/dist/fabric-interop/components/ViroSphere.d.ts +22 -0
  116. package/dist/fabric-interop/components/ViroSphere.js +49 -0
  117. package/dist/fabric-interop/components/ViroSpinner.d.ts +18 -0
  118. package/dist/fabric-interop/components/ViroSpinner.js +45 -0
  119. package/dist/fabric-interop/components/ViroSpotLight.d.ts +30 -0
  120. package/dist/fabric-interop/components/ViroSpotLight.js +57 -0
  121. package/dist/fabric-interop/components/ViroSurface.d.ts +38 -0
  122. package/dist/fabric-interop/components/ViroSurface.js +48 -0
  123. package/dist/fabric-interop/components/ViroText.d.ts +36 -0
  124. package/dist/fabric-interop/components/ViroText.js +59 -0
  125. package/dist/fabric-interop/components/ViroUtils.d.ts +63 -0
  126. package/dist/fabric-interop/components/ViroUtils.js +140 -0
  127. package/dist/fabric-interop/components/ViroVRSceneNavigator.d.ts +25 -0
  128. package/dist/fabric-interop/components/ViroVRSceneNavigator.js +73 -0
  129. package/dist/fabric-interop/components/ViroVideo.d.ts +32 -0
  130. package/dist/fabric-interop/components/ViroVideo.js +52 -0
  131. package/dist/fabric-interop/components/index.d.ts +62 -0
  132. package/dist/fabric-interop/components/index.js +144 -0
  133. package/dist/fabric-interop/examples/BasicSceneExample.d.ts +11 -0
  134. package/dist/fabric-interop/examples/BasicSceneExample.js +244 -0
  135. package/dist/fabric-interop/examples/ComprehensiveExample.d.ts +13 -0
  136. package/dist/fabric-interop/examples/ComprehensiveExample.js +327 -0
  137. package/dist/fabric-interop/examples/SimpleARExample.d.ts +8 -0
  138. package/dist/fabric-interop/examples/SimpleARExample.js +62 -0
  139. package/dist/fabric-interop/index.d.ts +14 -0
  140. package/dist/fabric-interop/index.js +117 -0
  141. package/dist/fabric-interop/specs/ViroEventsTurboModule.d.ts +19 -0
  142. package/dist/fabric-interop/specs/ViroEventsTurboModule.js +11 -0
  143. package/dist/fabric-interop/test/BasicFunctionalityTest.d.ts +9 -0
  144. package/dist/fabric-interop/test/BasicFunctionalityTest.js +222 -0
  145. package/dist/fabric.d.ts +13 -0
  146. package/dist/fabric.js +29 -0
  147. package/dist/plugins/withViro.d.ts +3 -0
  148. package/dist/plugins/withViro.js +19 -0
  149. package/dist/plugins/withViroAndroid.js +24 -20
  150. package/dist/plugins/withViroIos.js +20 -2
  151. package/dynamic-index-source.d.ts +77 -0
  152. package/dynamic-index.ts +41 -0
  153. package/fabric-interop/NativeViro.ts +335 -0
  154. package/fabric-interop/README.md +282 -0
  155. package/fabric-interop/ViroEventsManager.js +257 -0
  156. package/fabric-interop/ViroFabricContainer.tsx +273 -0
  157. package/fabric-interop/components/AR/ViroARPlane.tsx +108 -0
  158. package/fabric-interop/components/AR/ViroARPlaneSelector.tsx +185 -0
  159. package/fabric-interop/components/AR/ViroARTrackingTargets.ts +108 -0
  160. package/fabric-interop/components/AR/ViroCommonProps.ts +140 -0
  161. package/fabric-interop/components/Animation/ViroAnimations.ts +96 -0
  162. package/fabric-interop/components/Material/ViroMaterials.ts +127 -0
  163. package/fabric-interop/components/Resources/viro_spinner_1.png +0 -0
  164. package/fabric-interop/components/Resources/viro_spinner_1_w.png +0 -0
  165. package/fabric-interop/components/Resources/viro_spinner_1a.png +0 -0
  166. package/fabric-interop/components/Resources/viro_spinner_1a_w.png +0 -0
  167. package/fabric-interop/components/Types/ViroEvents.ts +285 -0
  168. package/fabric-interop/components/Types/ViroUtils.ts +160 -0
  169. package/fabric-interop/components/Viro360Image.tsx +70 -0
  170. package/fabric-interop/components/Viro360Video.tsx +78 -0
  171. package/fabric-interop/components/Viro3DObject.tsx +122 -0
  172. package/fabric-interop/components/Viro3DSceneNavigator.tsx +503 -0
  173. package/fabric-interop/components/ViroARCamera.tsx +105 -0
  174. package/fabric-interop/components/ViroARImageMarker.tsx +98 -0
  175. package/fabric-interop/components/ViroARObjectMarker.tsx +100 -0
  176. package/fabric-interop/components/ViroARPlane.tsx +120 -0
  177. package/fabric-interop/components/ViroARScene.tsx +127 -0
  178. package/fabric-interop/components/ViroARSceneNavigator.tsx +82 -0
  179. package/fabric-interop/components/ViroAmbientLight.tsx +62 -0
  180. package/fabric-interop/components/ViroAnimatedComponent.tsx +91 -0
  181. package/fabric-interop/components/ViroAnimatedImage.tsx +81 -0
  182. package/fabric-interop/components/ViroBox.tsx +72 -0
  183. package/fabric-interop/components/ViroButton.tsx +125 -0
  184. package/fabric-interop/components/ViroCamera.tsx +45 -0
  185. package/fabric-interop/components/ViroController.tsx +87 -0
  186. package/fabric-interop/components/ViroDirectionalLight.tsx +84 -0
  187. package/fabric-interop/components/ViroFlexView.tsx +146 -0
  188. package/fabric-interop/components/ViroGeometry.tsx +78 -0
  189. package/fabric-interop/components/ViroGlobal.ts +114 -0
  190. package/fabric-interop/components/ViroImage.tsx +85 -0
  191. package/fabric-interop/components/ViroLightingEnvironment.tsx +63 -0
  192. package/fabric-interop/components/ViroMaterialVideo.tsx +82 -0
  193. package/fabric-interop/components/ViroNode.tsx +62 -0
  194. package/fabric-interop/components/ViroOmniLight.tsx +66 -0
  195. package/fabric-interop/components/ViroOrbitCamera.tsx +45 -0
  196. package/fabric-interop/components/ViroParticleEmitter.tsx +111 -0
  197. package/fabric-interop/components/ViroPolygon.tsx +72 -0
  198. package/fabric-interop/components/ViroPolyline.tsx +71 -0
  199. package/fabric-interop/components/ViroPortal.tsx +91 -0
  200. package/fabric-interop/components/ViroPortalScene.tsx +43 -0
  201. package/fabric-interop/components/ViroQuad.tsx +82 -0
  202. package/fabric-interop/components/ViroScene.tsx +117 -0
  203. package/fabric-interop/components/ViroSceneNavigator.tsx +71 -0
  204. package/fabric-interop/components/ViroSkyBox.tsx +75 -0
  205. package/fabric-interop/components/ViroSound.tsx +71 -0
  206. package/fabric-interop/components/ViroSoundField.tsx +75 -0
  207. package/fabric-interop/components/ViroSpatialSound.tsx +81 -0
  208. package/fabric-interop/components/ViroSphere.tsx +75 -0
  209. package/fabric-interop/components/ViroSpinner.tsx +63 -0
  210. package/fabric-interop/components/ViroSpotLight.tsx +86 -0
  211. package/fabric-interop/components/ViroSurface.tsx +80 -0
  212. package/fabric-interop/components/ViroText.tsx +114 -0
  213. package/fabric-interop/components/ViroUtils.ts +208 -0
  214. package/fabric-interop/components/ViroVRSceneNavigator.tsx +75 -0
  215. package/fabric-interop/components/ViroVideo.tsx +91 -0
  216. package/fabric-interop/components/index.ts +94 -0
  217. package/fabric-interop/dist/NativeViro.d.ts +43 -0
  218. package/fabric-interop/dist/NativeViro.d.ts.map +1 -0
  219. package/fabric-interop/dist/NativeViro.js +263 -0
  220. package/fabric-interop/dist/NativeViro.js.map +1 -0
  221. package/fabric-interop/dist/ViroFabricContainer.d.ts +35 -0
  222. package/fabric-interop/dist/ViroFabricContainer.d.ts.map +1 -0
  223. package/fabric-interop/dist/ViroFabricContainer.js +201 -0
  224. package/fabric-interop/dist/ViroFabricContainer.js.map +1 -0
  225. package/fabric-interop/dist/components/AR/ViroARPlane.d.ts +23 -0
  226. package/fabric-interop/dist/components/AR/ViroARPlane.d.ts.map +1 -0
  227. package/fabric-interop/dist/components/AR/ViroARPlane.js +96 -0
  228. package/fabric-interop/dist/components/AR/ViroARPlane.js.map +1 -0
  229. package/fabric-interop/dist/components/AR/ViroARPlaneSelector.d.ts +44 -0
  230. package/fabric-interop/dist/components/AR/ViroARPlaneSelector.d.ts.map +1 -0
  231. package/fabric-interop/dist/components/AR/ViroARPlaneSelector.js +156 -0
  232. package/fabric-interop/dist/components/AR/ViroARPlaneSelector.js.map +1 -0
  233. package/fabric-interop/dist/components/AR/ViroARTrackingTargets.d.ts +56 -0
  234. package/fabric-interop/dist/components/AR/ViroARTrackingTargets.d.ts.map +1 -0
  235. package/fabric-interop/dist/components/AR/ViroARTrackingTargets.js +86 -0
  236. package/fabric-interop/dist/components/AR/ViroARTrackingTargets.js.map +1 -0
  237. package/fabric-interop/dist/components/AR/ViroCommonProps.d.ts +92 -0
  238. package/fabric-interop/dist/components/AR/ViroCommonProps.d.ts.map +1 -0
  239. package/fabric-interop/dist/components/AR/ViroCommonProps.js +8 -0
  240. package/fabric-interop/dist/components/AR/ViroCommonProps.js.map +1 -0
  241. package/fabric-interop/dist/components/Animation/ViroAnimations.d.ts +49 -0
  242. package/fabric-interop/dist/components/Animation/ViroAnimations.d.ts.map +1 -0
  243. package/fabric-interop/dist/components/Animation/ViroAnimations.js +65 -0
  244. package/fabric-interop/dist/components/Animation/ViroAnimations.js.map +1 -0
  245. package/fabric-interop/dist/components/Material/ViroMaterials.d.ts +67 -0
  246. package/fabric-interop/dist/components/Material/ViroMaterials.d.ts.map +1 -0
  247. package/fabric-interop/dist/components/Material/ViroMaterials.js +86 -0
  248. package/fabric-interop/dist/components/Material/ViroMaterials.js.map +1 -0
  249. package/fabric-interop/dist/components/Types/ViroEvents.d.ts +203 -0
  250. package/fabric-interop/dist/components/Types/ViroEvents.d.ts.map +1 -0
  251. package/fabric-interop/dist/components/Types/ViroEvents.js +54 -0
  252. package/fabric-interop/dist/components/Types/ViroEvents.js.map +1 -0
  253. package/fabric-interop/dist/components/Types/ViroUtils.d.ts +138 -0
  254. package/fabric-interop/dist/components/Types/ViroUtils.d.ts.map +1 -0
  255. package/fabric-interop/dist/components/Types/ViroUtils.js +8 -0
  256. package/fabric-interop/dist/components/Types/ViroUtils.js.map +1 -0
  257. package/fabric-interop/dist/components/Viro360Image.d.ts +24 -0
  258. package/fabric-interop/dist/components/Viro360Image.d.ts.map +1 -0
  259. package/fabric-interop/dist/components/Viro360Image.js +47 -0
  260. package/fabric-interop/dist/components/Viro360Image.js.map +1 -0
  261. package/fabric-interop/dist/components/Viro360Video.d.ts +30 -0
  262. package/fabric-interop/dist/components/Viro360Video.d.ts.map +1 -0
  263. package/fabric-interop/dist/components/Viro360Video.js +49 -0
  264. package/fabric-interop/dist/components/Viro360Video.js.map +1 -0
  265. package/fabric-interop/dist/components/Viro3DObject.d.ts +61 -0
  266. package/fabric-interop/dist/components/Viro3DObject.d.ts.map +1 -0
  267. package/fabric-interop/dist/components/Viro3DObject.js +51 -0
  268. package/fabric-interop/dist/components/Viro3DObject.js.map +1 -0
  269. package/fabric-interop/dist/components/Viro3DSceneNavigator.d.ts +50 -0
  270. package/fabric-interop/dist/components/Viro3DSceneNavigator.d.ts.map +1 -0
  271. package/fabric-interop/dist/components/Viro3DSceneNavigator.js +389 -0
  272. package/fabric-interop/dist/components/Viro3DSceneNavigator.js.map +1 -0
  273. package/fabric-interop/dist/components/ViroARCamera.d.ts +30 -0
  274. package/fabric-interop/dist/components/ViroARCamera.d.ts.map +1 -0
  275. package/fabric-interop/dist/components/ViroARCamera.js +65 -0
  276. package/fabric-interop/dist/components/ViroARCamera.js.map +1 -0
  277. package/fabric-interop/dist/components/ViroARImageMarker.d.ts +22 -0
  278. package/fabric-interop/dist/components/ViroARImageMarker.d.ts.map +1 -0
  279. package/fabric-interop/dist/components/ViroARImageMarker.js +72 -0
  280. package/fabric-interop/dist/components/ViroARImageMarker.js.map +1 -0
  281. package/fabric-interop/dist/components/ViroARObjectMarker.d.ts +22 -0
  282. package/fabric-interop/dist/components/ViroARObjectMarker.d.ts.map +1 -0
  283. package/fabric-interop/dist/components/ViroARObjectMarker.js +72 -0
  284. package/fabric-interop/dist/components/ViroARObjectMarker.js.map +1 -0
  285. package/fabric-interop/dist/components/ViroARPlane.d.ts +25 -0
  286. package/fabric-interop/dist/components/ViroARPlane.d.ts.map +1 -0
  287. package/fabric-interop/dist/components/ViroARPlane.js +89 -0
  288. package/fabric-interop/dist/components/ViroARPlane.js.map +1 -0
  289. package/fabric-interop/dist/components/ViroARScene.d.ts +30 -0
  290. package/fabric-interop/dist/components/ViroARScene.d.ts.map +1 -0
  291. package/fabric-interop/dist/components/ViroARScene.js +90 -0
  292. package/fabric-interop/dist/components/ViroARScene.js.map +1 -0
  293. package/fabric-interop/dist/components/ViroARSceneNavigator.d.ts +30 -0
  294. package/fabric-interop/dist/components/ViroARSceneNavigator.d.ts.map +1 -0
  295. package/fabric-interop/dist/components/ViroARSceneNavigator.js +78 -0
  296. package/fabric-interop/dist/components/ViroARSceneNavigator.js.map +1 -0
  297. package/fabric-interop/dist/components/ViroAmbientLight.d.ts +20 -0
  298. package/fabric-interop/dist/components/ViroAmbientLight.d.ts.map +1 -0
  299. package/fabric-interop/dist/components/ViroAmbientLight.js +48 -0
  300. package/fabric-interop/dist/components/ViroAmbientLight.js.map +1 -0
  301. package/fabric-interop/dist/components/ViroAnimatedComponent.d.ts +25 -0
  302. package/fabric-interop/dist/components/ViroAnimatedComponent.d.ts.map +1 -0
  303. package/fabric-interop/dist/components/ViroAnimatedComponent.js +65 -0
  304. package/fabric-interop/dist/components/ViroAnimatedComponent.js.map +1 -0
  305. package/fabric-interop/dist/components/ViroAnimatedImage.d.ts +29 -0
  306. package/fabric-interop/dist/components/ViroAnimatedImage.d.ts.map +1 -0
  307. package/fabric-interop/dist/components/ViroAnimatedImage.js +51 -0
  308. package/fabric-interop/dist/components/ViroAnimatedImage.js.map +1 -0
  309. package/fabric-interop/dist/components/ViroBox.d.ts +21 -0
  310. package/fabric-interop/dist/components/ViroBox.d.ts.map +1 -0
  311. package/fabric-interop/dist/components/ViroBox.js +49 -0
  312. package/fabric-interop/dist/components/ViroBox.js.map +1 -0
  313. package/fabric-interop/dist/components/ViroButton.d.ts +33 -0
  314. package/fabric-interop/dist/components/ViroButton.d.ts.map +1 -0
  315. package/fabric-interop/dist/components/ViroButton.js +94 -0
  316. package/fabric-interop/dist/components/ViroButton.js.map +1 -0
  317. package/fabric-interop/dist/components/ViroCamera.d.ts +18 -0
  318. package/fabric-interop/dist/components/ViroCamera.d.ts.map +1 -0
  319. package/fabric-interop/dist/components/ViroCamera.js +31 -0
  320. package/fabric-interop/dist/components/ViroCamera.js.map +1 -0
  321. package/fabric-interop/dist/components/ViroController.d.ts +20 -0
  322. package/fabric-interop/dist/components/ViroController.d.ts.map +1 -0
  323. package/fabric-interop/dist/components/ViroController.js +65 -0
  324. package/fabric-interop/dist/components/ViroController.js.map +1 -0
  325. package/fabric-interop/dist/components/ViroDirectionalLight.d.ts +29 -0
  326. package/fabric-interop/dist/components/ViroDirectionalLight.d.ts.map +1 -0
  327. package/fabric-interop/dist/components/ViroDirectionalLight.js +57 -0
  328. package/fabric-interop/dist/components/ViroDirectionalLight.js.map +1 -0
  329. package/fabric-interop/dist/components/ViroFlexView.d.ts +37 -0
  330. package/fabric-interop/dist/components/ViroFlexView.d.ts.map +1 -0
  331. package/fabric-interop/dist/components/ViroFlexView.js +98 -0
  332. package/fabric-interop/dist/components/ViroFlexView.js.map +1 -0
  333. package/fabric-interop/dist/components/ViroGeometry.d.ts +24 -0
  334. package/fabric-interop/dist/components/ViroGeometry.d.ts.map +1 -0
  335. package/fabric-interop/dist/components/ViroGeometry.js +52 -0
  336. package/fabric-interop/dist/components/ViroGeometry.js.map +1 -0
  337. package/fabric-interop/dist/components/ViroGlobal.d.ts +46 -0
  338. package/fabric-interop/dist/components/ViroGlobal.d.ts.map +1 -0
  339. package/fabric-interop/dist/components/ViroGlobal.js +21 -0
  340. package/fabric-interop/dist/components/ViroGlobal.js.map +1 -0
  341. package/fabric-interop/dist/components/ViroImage.d.ts +30 -0
  342. package/fabric-interop/dist/components/ViroImage.d.ts.map +1 -0
  343. package/fabric-interop/dist/components/ViroImage.js +54 -0
  344. package/fabric-interop/dist/components/ViroImage.js.map +1 -0
  345. package/fabric-interop/dist/components/ViroLightingEnvironment.d.ts +20 -0
  346. package/fabric-interop/dist/components/ViroLightingEnvironment.d.ts.map +1 -0
  347. package/fabric-interop/dist/components/ViroLightingEnvironment.js +46 -0
  348. package/fabric-interop/dist/components/ViroLightingEnvironment.js.map +1 -0
  349. package/fabric-interop/dist/components/ViroMaterialVideo.d.ts +31 -0
  350. package/fabric-interop/dist/components/ViroMaterialVideo.d.ts.map +1 -0
  351. package/fabric-interop/dist/components/ViroMaterialVideo.js +50 -0
  352. package/fabric-interop/dist/components/ViroMaterialVideo.js.map +1 -0
  353. package/fabric-interop/dist/components/ViroNode.d.ts +37 -0
  354. package/fabric-interop/dist/components/ViroNode.d.ts.map +1 -0
  355. package/fabric-interop/dist/components/ViroNode.js +29 -0
  356. package/fabric-interop/dist/components/ViroNode.js.map +1 -0
  357. package/fabric-interop/dist/components/ViroOmniLight.d.ts +22 -0
  358. package/fabric-interop/dist/components/ViroOmniLight.d.ts.map +1 -0
  359. package/fabric-interop/dist/components/ViroOmniLight.js +50 -0
  360. package/fabric-interop/dist/components/ViroOmniLight.js.map +1 -0
  361. package/fabric-interop/dist/components/ViroOrbitCamera.d.ts +18 -0
  362. package/fabric-interop/dist/components/ViroOrbitCamera.d.ts.map +1 -0
  363. package/fabric-interop/dist/components/ViroOrbitCamera.js +31 -0
  364. package/fabric-interop/dist/components/ViroOrbitCamera.js.map +1 -0
  365. package/fabric-interop/dist/components/ViroParticleEmitter.d.ts +52 -0
  366. package/fabric-interop/dist/components/ViroParticleEmitter.d.ts.map +1 -0
  367. package/fabric-interop/dist/components/ViroParticleEmitter.js +52 -0
  368. package/fabric-interop/dist/components/ViroParticleEmitter.js.map +1 -0
  369. package/fabric-interop/dist/components/ViroPolygon.d.ts +21 -0
  370. package/fabric-interop/dist/components/ViroPolygon.d.ts.map +1 -0
  371. package/fabric-interop/dist/components/ViroPolygon.js +49 -0
  372. package/fabric-interop/dist/components/ViroPolygon.js.map +1 -0
  373. package/fabric-interop/dist/components/ViroPolyline.d.ts +20 -0
  374. package/fabric-interop/dist/components/ViroPolyline.d.ts.map +1 -0
  375. package/fabric-interop/dist/components/ViroPolyline.js +48 -0
  376. package/fabric-interop/dist/components/ViroPolyline.js.map +1 -0
  377. package/fabric-interop/dist/components/ViroPortal.d.ts +17 -0
  378. package/fabric-interop/dist/components/ViroPortal.d.ts.map +1 -0
  379. package/fabric-interop/dist/components/ViroPortal.js +74 -0
  380. package/fabric-interop/dist/components/ViroPortal.js.map +1 -0
  381. package/fabric-interop/dist/components/ViroPortalScene.d.ts +17 -0
  382. package/fabric-interop/dist/components/ViroPortalScene.d.ts.map +1 -0
  383. package/fabric-interop/dist/components/ViroPortalScene.js +30 -0
  384. package/fabric-interop/dist/components/ViroPortalScene.js.map +1 -0
  385. package/fabric-interop/dist/components/ViroQuad.d.ts +40 -0
  386. package/fabric-interop/dist/components/ViroQuad.d.ts.map +1 -0
  387. package/fabric-interop/dist/components/ViroQuad.js +51 -0
  388. package/fabric-interop/dist/components/ViroQuad.js.map +1 -0
  389. package/fabric-interop/dist/components/ViroScene.d.ts +30 -0
  390. package/fabric-interop/dist/components/ViroScene.d.ts.map +1 -0
  391. package/fabric-interop/dist/components/ViroScene.js +105 -0
  392. package/fabric-interop/dist/components/ViroScene.js.map +1 -0
  393. package/fabric-interop/dist/components/ViroSceneNavigator.d.ts +24 -0
  394. package/fabric-interop/dist/components/ViroSceneNavigator.d.ts.map +1 -0
  395. package/fabric-interop/dist/components/ViroSceneNavigator.js +74 -0
  396. package/fabric-interop/dist/components/ViroSceneNavigator.js.map +1 -0
  397. package/fabric-interop/dist/components/ViroSkyBox.d.ts +40 -0
  398. package/fabric-interop/dist/components/ViroSkyBox.d.ts.map +1 -0
  399. package/fabric-interop/dist/components/ViroSkyBox.js +46 -0
  400. package/fabric-interop/dist/components/ViroSkyBox.js.map +1 -0
  401. package/fabric-interop/dist/components/ViroSound.d.ts +24 -0
  402. package/fabric-interop/dist/components/ViroSound.d.ts.map +1 -0
  403. package/fabric-interop/dist/components/ViroSound.js +48 -0
  404. package/fabric-interop/dist/components/ViroSound.js.map +1 -0
  405. package/fabric-interop/dist/components/ViroSoundField.d.ts +25 -0
  406. package/fabric-interop/dist/components/ViroSoundField.d.ts.map +1 -0
  407. package/fabric-interop/dist/components/ViroSoundField.js +49 -0
  408. package/fabric-interop/dist/components/ViroSoundField.js.map +1 -0
  409. package/fabric-interop/dist/components/ViroSpatialSound.d.ts +28 -0
  410. package/fabric-interop/dist/components/ViroSpatialSound.d.ts.map +1 -0
  411. package/fabric-interop/dist/components/ViroSpatialSound.js +52 -0
  412. package/fabric-interop/dist/components/ViroSpatialSound.js.map +1 -0
  413. package/fabric-interop/dist/components/ViroSphere.d.ts +23 -0
  414. package/fabric-interop/dist/components/ViroSphere.d.ts.map +1 -0
  415. package/fabric-interop/dist/components/ViroSphere.js +51 -0
  416. package/fabric-interop/dist/components/ViroSphere.js.map +1 -0
  417. package/fabric-interop/dist/components/ViroSpinner.d.ts +19 -0
  418. package/fabric-interop/dist/components/ViroSpinner.d.ts.map +1 -0
  419. package/fabric-interop/dist/components/ViroSpinner.js +47 -0
  420. package/fabric-interop/dist/components/ViroSpinner.js.map +1 -0
  421. package/fabric-interop/dist/components/ViroSpotLight.d.ts +31 -0
  422. package/fabric-interop/dist/components/ViroSpotLight.d.ts.map +1 -0
  423. package/fabric-interop/dist/components/ViroSpotLight.js +59 -0
  424. package/fabric-interop/dist/components/ViroSpotLight.js.map +1 -0
  425. package/fabric-interop/dist/components/ViroSurface.d.ts +39 -0
  426. package/fabric-interop/dist/components/ViroSurface.d.ts.map +1 -0
  427. package/fabric-interop/dist/components/ViroSurface.js +50 -0
  428. package/fabric-interop/dist/components/ViroSurface.js.map +1 -0
  429. package/fabric-interop/dist/components/ViroText.d.ts +37 -0
  430. package/fabric-interop/dist/components/ViroText.d.ts.map +1 -0
  431. package/fabric-interop/dist/components/ViroText.js +61 -0
  432. package/fabric-interop/dist/components/ViroText.js.map +1 -0
  433. package/fabric-interop/dist/components/ViroUtils.d.ts +64 -0
  434. package/fabric-interop/dist/components/ViroUtils.d.ts.map +1 -0
  435. package/fabric-interop/dist/components/ViroUtils.js +141 -0
  436. package/fabric-interop/dist/components/ViroUtils.js.map +1 -0
  437. package/fabric-interop/dist/components/ViroVRSceneNavigator.d.ts +26 -0
  438. package/fabric-interop/dist/components/ViroVRSceneNavigator.d.ts.map +1 -0
  439. package/fabric-interop/dist/components/ViroVRSceneNavigator.js +74 -0
  440. package/fabric-interop/dist/components/ViroVRSceneNavigator.js.map +1 -0
  441. package/fabric-interop/dist/components/ViroVideo.d.ts +33 -0
  442. package/fabric-interop/dist/components/ViroVideo.d.ts.map +1 -0
  443. package/fabric-interop/dist/components/ViroVideo.js +54 -0
  444. package/fabric-interop/dist/components/ViroVideo.js.map +1 -0
  445. package/fabric-interop/dist/components/index.d.ts +63 -0
  446. package/fabric-interop/dist/components/index.d.ts.map +1 -0
  447. package/fabric-interop/dist/components/index.js +145 -0
  448. package/fabric-interop/dist/components/index.js.map +1 -0
  449. package/fabric-interop/dist/index.d.ts +15 -0
  450. package/fabric-interop/dist/index.d.ts.map +1 -0
  451. package/fabric-interop/dist/index.js +118 -0
  452. package/fabric-interop/dist/index.js.map +1 -0
  453. package/fabric-interop/dist/specs/ViroEventsTurboModule.d.ts +20 -0
  454. package/fabric-interop/dist/specs/ViroEventsTurboModule.d.ts.map +1 -0
  455. package/fabric-interop/dist/specs/ViroEventsTurboModule.js +12 -0
  456. package/fabric-interop/dist/specs/ViroEventsTurboModule.js.map +1 -0
  457. package/fabric-interop/examples/BasicSceneExample.tsx +287 -0
  458. package/fabric-interop/examples/ComprehensiveExample.tsx +441 -0
  459. package/fabric-interop/examples/SimpleARExample.tsx +95 -0
  460. package/fabric-interop/global.d.ts +14 -0
  461. package/fabric-interop/index.ts +107 -0
  462. package/fabric-interop/metro.config.js +12 -0
  463. package/fabric-interop/package.json +40 -0
  464. package/fabric-interop/react-native.config.js +22 -0
  465. package/fabric-interop/scripts/validate-build.js +393 -0
  466. package/fabric-interop/scripts/validate-implementation.js +272 -0
  467. package/fabric-interop/specs/README.md +22 -0
  468. package/fabric-interop/specs/ViroEventsTurboModule.ts +27 -0
  469. package/fabric-interop/test/BasicFunctionalityTest.tsx +243 -0
  470. package/fabric-interop/tsconfig.json +38 -0
  471. package/fabric.d.ts +5 -0
  472. package/fabric.ts +14 -0
  473. package/ios/ViroReact.podspec +51 -11
  474. package/package.json +33 -20
  475. package/scripts/copy-types.js +46 -0
@@ -0,0 +1,441 @@
1
+ /**
2
+ * ComprehensiveExample
3
+ *
4
+ * A comprehensive example demonstrating the updated fabric-interop system with:
5
+ * - Multiple component types (3D primitives, lights, text, images)
6
+ * - Scene management and lifecycle
7
+ * - Property system with individual setters
8
+ * - Event system with JSI + fallback
9
+ * - Memory management integration
10
+ * - Material and animation management
11
+ */
12
+
13
+ import React, { useState, useEffect } from "react";
14
+ import { View, Text, Button, StyleSheet, Alert } from "react-native";
15
+ import {
16
+ ViroFabricContainer,
17
+ ViroScene,
18
+ ViroBox,
19
+ ViroSphere,
20
+ ViroText,
21
+ ViroImage,
22
+ ViroQuad,
23
+ ViroAmbientLight,
24
+ ViroDirectionalLight,
25
+ ViroSound,
26
+ createMaterial,
27
+ createAnimation,
28
+ executeAnimation,
29
+ getMemoryStats,
30
+ performMemoryCleanup,
31
+ } from "../index";
32
+
33
+ export const ComprehensiveExample: React.FC = () => {
34
+ const [sceneActive, setSceneActive] = useState(false);
35
+ const [memoryStats, setMemoryStats] = useState<Record<string, any> | null>(
36
+ null
37
+ );
38
+ const [selectedObject, setSelectedObject] = useState<string | null>(null);
39
+
40
+ // Initialize materials and animations when component mounts
41
+ useEffect(() => {
42
+ // Create materials for different objects
43
+ createMaterial("redMaterial", {
44
+ diffuseColor: "#FF0000",
45
+ shininess: 2.0,
46
+ lightingModel: "Lambert",
47
+ });
48
+
49
+ createMaterial("blueMaterial", {
50
+ diffuseColor: "#0000FF",
51
+ shininess: 2.0,
52
+ lightingModel: "Lambert",
53
+ });
54
+
55
+ createMaterial("greenMaterial", {
56
+ diffuseColor: "#00FF00",
57
+ shininess: 2.0,
58
+ lightingModel: "Lambert",
59
+ });
60
+
61
+ createMaterial("textMaterial", {
62
+ diffuseColor: "#FFFFFF",
63
+ shininess: 1.0,
64
+ lightingModel: "Lambert",
65
+ });
66
+
67
+ createMaterial("imageMaterial", {
68
+ diffuseTexture: {
69
+ uri: "https://via.placeholder.com/512x512/FF6B6B/FFFFFF?text=Viro",
70
+ },
71
+ lightingModel: "Lambert",
72
+ });
73
+
74
+ // Create animations
75
+ createAnimation("spinAnimation", {
76
+ properties: {
77
+ rotateY: "+=360",
78
+ },
79
+ duration: 2000,
80
+ easing: "Linear",
81
+ });
82
+
83
+ createAnimation("pulseAnimation", {
84
+ properties: {
85
+ scaleX: 1.5,
86
+ scaleY: 1.5,
87
+ scaleZ: 1.5,
88
+ },
89
+ duration: 1000,
90
+ easing: "EaseInEaseOut",
91
+ });
92
+
93
+ createAnimation("bounceAnimation", {
94
+ properties: {
95
+ positionY: "+=0.5",
96
+ },
97
+ duration: 800,
98
+ easing: "Bounce",
99
+ });
100
+
101
+ createAnimation("colorChangeAnimation", {
102
+ properties: {
103
+ materialDiffuseColor: "#FFFF00",
104
+ },
105
+ duration: 1500,
106
+ easing: "EaseInEaseOut",
107
+ });
108
+ }, []);
109
+
110
+ // Handle scene initialization
111
+ const handleSceneInitialized = (success: boolean) => {
112
+ console.log("Scene initialized:", success);
113
+ setSceneActive(success);
114
+
115
+ if (success) {
116
+ Alert.alert("Success", "Comprehensive Viro scene initialized!");
117
+ } else {
118
+ Alert.alert("Error", "Failed to initialize Viro scene");
119
+ }
120
+ };
121
+
122
+ // Handle object interactions
123
+ const handleObjectClick = (objectName: string, objectType: string) => {
124
+ setSelectedObject(objectName);
125
+ Alert.alert(
126
+ "Object Clicked",
127
+ `${objectType} "${objectName}" was clicked!`,
128
+ [
129
+ {
130
+ text: "Spin",
131
+ onPress: () =>
132
+ executeAnimation(objectName, "spinAnimation", {
133
+ run: true,
134
+ loop: false,
135
+ }),
136
+ },
137
+ {
138
+ text: "Pulse",
139
+ onPress: () =>
140
+ executeAnimation(objectName, "pulseAnimation", {
141
+ run: true,
142
+ loop: false,
143
+ }),
144
+ },
145
+ {
146
+ text: "Bounce",
147
+ onPress: () =>
148
+ executeAnimation(objectName, "bounceAnimation", {
149
+ run: true,
150
+ loop: false,
151
+ }),
152
+ },
153
+ { text: "OK", style: "cancel" },
154
+ ]
155
+ );
156
+ };
157
+
158
+ const handleObjectHover = (objectName: string, isHovering: boolean) => {
159
+ console.log(`${objectName} hover:`, isHovering);
160
+ if (isHovering) {
161
+ executeAnimation(objectName, "pulseAnimation", {
162
+ run: true,
163
+ loop: false,
164
+ });
165
+ }
166
+ };
167
+
168
+ // Memory management
169
+ const checkMemoryStats = () => {
170
+ const stats = getMemoryStats();
171
+ setMemoryStats(stats);
172
+
173
+ if (stats) {
174
+ Alert.alert(
175
+ "Memory Statistics",
176
+ `Total Scenes: ${stats.totalScenes || 0}\n` +
177
+ `Active Scenes: ${stats.activeScenes || 0}\n` +
178
+ `Managed Nodes: ${stats.managedNodes || 0}\n` +
179
+ `Memory Usage: ${stats.usedMemoryMB?.toFixed(1) || "N/A"} MB\n` +
180
+ `Textures: ${stats.textureCount || 0}\n` +
181
+ `Materials: ${stats.materialCount || 0}`
182
+ );
183
+ } else {
184
+ Alert.alert("Memory Stats", "Memory statistics not available");
185
+ }
186
+ };
187
+
188
+ const cleanupMemory = () => {
189
+ performMemoryCleanup();
190
+ Alert.alert("Memory Cleanup", "Memory cleanup performed successfully");
191
+ };
192
+
193
+ return (
194
+ <View style={styles.container}>
195
+ <Text style={styles.title}>Comprehensive Viro Example</Text>
196
+ <Text style={styles.subtitle}>
197
+ All Components • New Architecture • Complete Integration
198
+ </Text>
199
+
200
+ <View style={styles.controls}>
201
+ <Button
202
+ title="Memory Stats"
203
+ onPress={checkMemoryStats}
204
+ disabled={!sceneActive}
205
+ />
206
+ <Button
207
+ title="Cleanup"
208
+ onPress={cleanupMemory}
209
+ disabled={!sceneActive}
210
+ />
211
+ </View>
212
+
213
+ {selectedObject && (
214
+ <View style={styles.selection}>
215
+ <Text style={styles.selectionText}>Selected: {selectedObject}</Text>
216
+ </View>
217
+ )}
218
+
219
+ {memoryStats && (
220
+ <View style={styles.stats}>
221
+ <Text style={styles.statsTitle}>Memory Stats:</Text>
222
+ <Text>
223
+ Scenes: {memoryStats.totalScenes || 0} | Nodes:{" "}
224
+ {memoryStats.managedNodes || 0}
225
+ </Text>
226
+ <Text>
227
+ Memory: {memoryStats.usedMemoryMB?.toFixed(1) || "N/A"} MB
228
+ </Text>
229
+ </View>
230
+ )}
231
+
232
+ <ViroFabricContainer
233
+ style={styles.viroContainer}
234
+ debug={true}
235
+ arEnabled={false}
236
+ worldAlignment="Gravity"
237
+ onInitialized={handleSceneInitialized}
238
+ onMemoryWarning={(event) => {
239
+ Alert.alert(
240
+ "Memory Warning",
241
+ `Usage: ${event.memoryStats.usedMemoryMB?.toFixed(1)} MB`
242
+ );
243
+ }}
244
+ >
245
+ <ViroScene
246
+ onSceneLoadStart={() => console.log("Comprehensive scene loading...")}
247
+ onSceneLoadEnd={() => console.log("Comprehensive scene loaded!")}
248
+ >
249
+ {/* Lighting Setup */}
250
+ <ViroAmbientLight color="#404040" intensity={0.4} />
251
+ <ViroDirectionalLight
252
+ color="#FFFFFF"
253
+ direction={[0, -1, -0.2]}
254
+ intensity={1.0}
255
+ castsShadow={true}
256
+ />
257
+
258
+ {/* 3D Primitives Row */}
259
+ <ViroBox
260
+ position={[-2, 0, -4]}
261
+ scale={[0.4, 0.4, 0.4]}
262
+ materials={["redMaterial"]}
263
+ onClick={() => handleObjectClick("redBox", "Box")}
264
+ onHover={(isHovering) => handleObjectHover("redBox", isHovering)}
265
+ canClick={true}
266
+ canHover={true}
267
+ />
268
+
269
+ <ViroSphere
270
+ position={[0, 0, -4]}
271
+ radius={0.3}
272
+ materials={["blueMaterial"]}
273
+ onClick={() => handleObjectClick("blueSphere", "Sphere")}
274
+ onHover={(isHovering) =>
275
+ handleObjectHover("blueSphere", isHovering)
276
+ }
277
+ canClick={true}
278
+ canHover={true}
279
+ />
280
+
281
+ <ViroBox
282
+ position={[2, 0, -4]}
283
+ scale={[0.4, 0.4, 0.4]}
284
+ materials={["greenMaterial"]}
285
+ onClick={() => handleObjectClick("greenBox", "Box")}
286
+ onHover={(isHovering) => handleObjectHover("greenBox", isHovering)}
287
+ canClick={true}
288
+ canHover={true}
289
+ />
290
+
291
+ {/* Text Elements */}
292
+ <ViroText
293
+ text="Viro Fabric Interop"
294
+ position={[0, 1.5, -3]}
295
+ scale={[0.5, 0.5, 0.5]}
296
+ materials={["textMaterial"]}
297
+ fontSize={20}
298
+ fontWeight="bold"
299
+ textAlign="center"
300
+ onClick={() => handleObjectClick("titleText", "Text")}
301
+ canClick={true}
302
+ />
303
+
304
+ <ViroText
305
+ text="Click objects to interact!"
306
+ position={[0, -1.5, -3]}
307
+ scale={[0.3, 0.3, 0.3]}
308
+ materials={["textMaterial"]}
309
+ fontSize={16}
310
+ textAlign="center"
311
+ onClick={() => handleObjectClick("instructionText", "Text")}
312
+ canClick={true}
313
+ />
314
+
315
+ {/* Image and Quad */}
316
+ <ViroQuad
317
+ position={[-1.5, 1, -3]}
318
+ width={0.8}
319
+ height={0.8}
320
+ materials={["imageMaterial"]}
321
+ onClick={() => handleObjectClick("imageQuad", "Image Quad")}
322
+ canClick={true}
323
+ />
324
+
325
+ <ViroImage
326
+ position={[1.5, 1, -3]}
327
+ width={0.8}
328
+ height={0.8}
329
+ source={{
330
+ uri: "https://via.placeholder.com/512x512/4ECDC4/FFFFFF?text=Image",
331
+ }}
332
+ onClick={() => handleObjectClick("viroImage", "Image")}
333
+ canClick={true}
334
+ />
335
+
336
+ {/* Animated Objects */}
337
+ <ViroSphere
338
+ position={[0, 0.8, -2]}
339
+ radius={0.15}
340
+ materials={["redMaterial"]}
341
+ animation={{
342
+ name: "spinAnimation",
343
+ run: true,
344
+ loop: true,
345
+ }}
346
+ onClick={() => handleObjectClick("spinningOrb", "Spinning Orb")}
347
+ canClick={true}
348
+ />
349
+
350
+ {/* Sound (invisible but interactive) */}
351
+ <ViroSound
352
+ position={[0, 0, -3]}
353
+ source={{
354
+ uri: "https://www.soundjay.com/misc/sounds/bell-ringing-05.wav",
355
+ }}
356
+ paused={true}
357
+ volume={0.5}
358
+ onClick={() => {
359
+ Alert.alert("Sound", "Sound component clicked!");
360
+ // Note: Sound playback would be controlled through native props
361
+ }}
362
+ canClick={true}
363
+ />
364
+ </ViroScene>
365
+ </ViroFabricContainer>
366
+
367
+ <View style={styles.footer}>
368
+ <Text style={styles.footerText}>
369
+ Status: {sceneActive ? "Active" : "Loading..."}
370
+ </Text>
371
+ <Text style={styles.footerText}>
372
+ Components: Box • Sphere • Text • Image • Quad • Lights • Sound
373
+ </Text>
374
+ </View>
375
+ </View>
376
+ );
377
+ };
378
+
379
+ const styles = StyleSheet.create({
380
+ container: {
381
+ flex: 1,
382
+ backgroundColor: "#f5f5f5",
383
+ },
384
+ title: {
385
+ fontSize: 22,
386
+ fontWeight: "bold",
387
+ textAlign: "center",
388
+ marginTop: 20,
389
+ marginBottom: 5,
390
+ color: "#333",
391
+ },
392
+ subtitle: {
393
+ fontSize: 14,
394
+ textAlign: "center",
395
+ color: "#666",
396
+ marginBottom: 15,
397
+ },
398
+ controls: {
399
+ flexDirection: "row",
400
+ justifyContent: "space-around",
401
+ paddingHorizontal: 20,
402
+ marginBottom: 10,
403
+ },
404
+ selection: {
405
+ backgroundColor: "#4ECDC4",
406
+ margin: 10,
407
+ padding: 8,
408
+ borderRadius: 5,
409
+ alignItems: "center",
410
+ },
411
+ selectionText: {
412
+ color: "#fff",
413
+ fontWeight: "bold",
414
+ },
415
+ stats: {
416
+ backgroundColor: "#fff",
417
+ margin: 10,
418
+ padding: 10,
419
+ borderRadius: 5,
420
+ borderWidth: 1,
421
+ borderColor: "#ddd",
422
+ },
423
+ statsTitle: {
424
+ fontWeight: "bold",
425
+ marginBottom: 5,
426
+ color: "#333",
427
+ },
428
+ viroContainer: {
429
+ flex: 1,
430
+ backgroundColor: "#000",
431
+ },
432
+ footer: {
433
+ backgroundColor: "#333",
434
+ padding: 10,
435
+ },
436
+ footerText: {
437
+ color: "#fff",
438
+ textAlign: "center",
439
+ fontSize: 12,
440
+ },
441
+ });
@@ -0,0 +1,95 @@
1
+ /**
2
+ * SimpleARExample
3
+ *
4
+ * A simple example of using the Viro Fabric interop layer for AR.
5
+ */
6
+
7
+ import React, { useEffect } from "react";
8
+ import {
9
+ ViroARSceneNavigator,
10
+ ViroARScene,
11
+ ViroBox,
12
+ ViroText,
13
+ ViroMaterials,
14
+ ViroARTrackingTargets,
15
+ ViroARImageMarker,
16
+ } from "../components";
17
+
18
+ // Register materials
19
+ ViroMaterials.registerMaterials({
20
+ grid: {
21
+ diffuseColor: "#0000FF",
22
+ diffuseTexture: require("./assets/grid_bg.jpg"),
23
+ },
24
+ text: {
25
+ diffuseColor: "#FFFFFF",
26
+ },
27
+ });
28
+
29
+ // Register AR tracking targets
30
+ ViroARTrackingTargets.registerTargets({
31
+ logo: {
32
+ source: require("./assets/viro_logo.png"),
33
+ orientation: "Up",
34
+ physicalWidth: 0.1, // 10cm
35
+ },
36
+ });
37
+
38
+ // Main AR scene component
39
+ const ARScene = () => {
40
+ // Handle tracking state updates
41
+ const onTrackingUpdated = (state: { state: string; reason?: string }) => {
42
+ console.log("Tracking state updated:", state);
43
+ };
44
+
45
+ // Handle anchor found event
46
+ const onAnchorFound = () => {
47
+ console.log("Anchor found!");
48
+ };
49
+
50
+ return (
51
+ <ViroARScene onTrackingUpdated={onTrackingUpdated}>
52
+ {/* A simple 3D box floating 1 meter in front of the user */}
53
+ <ViroBox
54
+ position={[0, 0, -1]}
55
+ scale={[0.1, 0.1, 0.1]}
56
+ materials={["grid"]}
57
+ />
58
+
59
+ {/* Text above the box */}
60
+ <ViroText
61
+ text="Hello Viro!"
62
+ position={[0, 0.1, -1]}
63
+ scale={[0.1, 0.1, 0.1]}
64
+ color="#FFFFFF"
65
+ fontWeight="bold"
66
+ materials={["text"]}
67
+ />
68
+
69
+ {/* Image marker that places content when detected */}
70
+ <ViroARImageMarker target="logo" onAnchorFound={onAnchorFound}>
71
+ <ViroBox
72
+ position={[0, 0.1, 0]}
73
+ scale={[0.05, 0.05, 0.05]}
74
+ materials={["grid"]}
75
+ />
76
+ </ViroARImageMarker>
77
+ </ViroARScene>
78
+ );
79
+ };
80
+
81
+ // Main app component
82
+ export const SimpleARExample = () => {
83
+ return (
84
+ <ViroARSceneNavigator
85
+ initialScene={{
86
+ scene: ARScene,
87
+ }}
88
+ style={{ flex: 1 }}
89
+ worldAlignment="Gravity"
90
+ planeDetection={{ horizontal: true, vertical: true }}
91
+ />
92
+ );
93
+ };
94
+
95
+ export default SimpleARExample;
@@ -0,0 +1,14 @@
1
+ /**
2
+ * Global type declarations for Viro Fabric Interop
3
+ */
4
+
5
+ declare global {
6
+ var registerViroEventCallback:
7
+ | ((callbackId: string, handler: any) => void)
8
+ | undefined;
9
+ var handleViroEvent:
10
+ | ((callbackId: string, eventData: any) => void)
11
+ | undefined;
12
+ }
13
+
14
+ export {};
@@ -0,0 +1,107 @@
1
+ /**
2
+ * Viro Fabric Interop Layer
3
+ *
4
+ * This module provides compatibility between React Native's New Architecture (Fabric)
5
+ * and the existing Viro implementation without requiring codegen.
6
+ */
7
+
8
+ export * from "./ViroFabricContainer";
9
+
10
+ // Export components explicitly to ensure they're found by validation
11
+ export {
12
+ ViroNode,
13
+ ViroScene,
14
+ ViroARScene,
15
+ ViroFlexView,
16
+ ViroBox,
17
+ ViroSphere,
18
+ Viro3DObject,
19
+ ViroGeometry,
20
+ ViroQuad,
21
+ ViroPolygon,
22
+ ViroPolyline,
23
+ ViroSurface,
24
+ ViroText,
25
+ ViroImage,
26
+ ViroVideo,
27
+ ViroAnimatedImage,
28
+ Viro360Image,
29
+ Viro360Video,
30
+ ViroSkyBox,
31
+ ViroPortal,
32
+ ViroPortalScene,
33
+ ViroAmbientLight,
34
+ ViroDirectionalLight,
35
+ ViroSpotLight,
36
+ ViroOmniLight,
37
+ ViroLightingEnvironment,
38
+ ViroCamera,
39
+ ViroOrbitCamera,
40
+ ViroSound,
41
+ ViroSoundField,
42
+ ViroSpatialSound,
43
+ ViroButton,
44
+ ViroController,
45
+ ViroSpinner,
46
+ ViroParticleEmitter,
47
+ ViroAnimatedComponent,
48
+ ViroMaterialVideo,
49
+ ViroSceneNavigator,
50
+ ViroVRSceneNavigator,
51
+ ViroARSceneNavigator,
52
+ Viro3DSceneNavigator,
53
+ ViroARCamera,
54
+ ViroARPlane,
55
+ ViroARPlaneSelector,
56
+ ViroARImageMarker,
57
+ ViroARObjectMarker,
58
+ ViroAnimations,
59
+ ViroMaterials,
60
+ ViroARTrackingTargets,
61
+ } from "./components";
62
+
63
+ // Export utilities
64
+ export * from "./components/ViroUtils";
65
+
66
+ // Export specific functions from NativeViro to avoid conflicts
67
+ export {
68
+ generateNodeId,
69
+ generateCallbackId,
70
+ handleViroEvent,
71
+ registerEventListener,
72
+ unregisterEventListener,
73
+ initializeViro,
74
+ createScene,
75
+ activateScene,
76
+ deactivateScene,
77
+ destroyScene,
78
+ getSceneState,
79
+ getMemoryStats,
80
+ performMemoryCleanup,
81
+ createNode,
82
+ updateNode,
83
+ deleteNode,
84
+ addChild,
85
+ removeChild,
86
+ createMaterial,
87
+ createAnimation,
88
+ setARPlaneDetection,
89
+ setARImageTargets,
90
+ isViroJSIAvailable,
91
+ type ViroNodeProps,
92
+ type ViroNodeType,
93
+ type ViroEventCallback,
94
+ } from "./NativeViro";
95
+
96
+ // Re-export executeAnimation and updateMaterial with different names to avoid conflicts
97
+ export {
98
+ executeAnimation as executeNativeAnimation,
99
+ updateMaterial as updateNativeMaterial,
100
+ } from "./NativeViro";
101
+
102
+ // Also export the original names for backward compatibility
103
+ export { executeAnimation, updateMaterial } from "./NativeViro";
104
+
105
+ // Export event management utilities
106
+ export { default as ViroEventsManager } from "./ViroEventsManager";
107
+ export type { Spec as ViroEventsTurboModuleSpec } from "./specs/ViroEventsTurboModule";
@@ -0,0 +1,12 @@
1
+ const { getDefaultConfig } = require("expo/metro-config");
2
+
3
+ /** @type {import('expo/metro-config').MetroConfig} */
4
+ const config = getDefaultConfig(__dirname);
5
+
6
+ // Add resolver for fabric-interop
7
+ config.resolver.platforms = ["ios", "android"];
8
+
9
+ // Make sure to include the parent directory for proper resolution
10
+ config.watchFolders = [__dirname, "../ios", "../android"];
11
+
12
+ module.exports = config;
@@ -0,0 +1,40 @@
1
+ {
2
+ "name": "@reactvision/viro-fabric",
3
+ "version": "1.0.0",
4
+ "description": "Fabric interop layer for ReactVision",
5
+ "main": "dist/index.js",
6
+ "module": "dist/index.js",
7
+ "types": "dist/index.d.ts",
8
+ "scripts": {
9
+ "build": "tsc",
10
+ "validate": "node scripts/validate-build.js",
11
+ "postbuild": "npm run validate",
12
+ "prepare": "npm run build"
13
+ },
14
+ "keywords": [
15
+ "react-native",
16
+ "viro",
17
+ "ar",
18
+ "vr",
19
+ "fabric",
20
+ "new-architecture"
21
+ ],
22
+ "author": "ReactVision",
23
+ "license": "MIT",
24
+ "peerDependencies": {
25
+ "react": ">=18.0.0",
26
+ "react-native": ">=0.74.0"
27
+ },
28
+ "devDependencies": {
29
+ "@types/react": "^18.0.0",
30
+ "@types/react-native": "^0.74.0",
31
+ "typescript": "^5.0.0"
32
+ },
33
+ "files": [
34
+ "dist",
35
+ "ios",
36
+ "android",
37
+ "README.md",
38
+ "LICENSE"
39
+ ]
40
+ }