@elizaos/app-core 2.0.0-alpha.73 → 2.0.0-alpha.75

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 (1143) hide show
  1. package/App.d.ts +5 -0
  2. package/App.d.ts.map +1 -0
  3. package/App.js +220 -0
  4. package/actions/character.d.ts +39 -0
  5. package/actions/character.d.ts.map +1 -0
  6. package/actions/character.js +247 -0
  7. package/actions/chat-helpers.d.ts +47 -0
  8. package/actions/chat-helpers.d.ts.map +1 -0
  9. package/actions/chat-helpers.js +79 -0
  10. package/actions/cloud.d.ts +17 -0
  11. package/actions/cloud.d.ts.map +1 -0
  12. package/actions/cloud.js +43 -0
  13. package/actions/index.d.ts +12 -0
  14. package/actions/index.d.ts.map +1 -0
  15. package/actions/index.js +11 -0
  16. package/actions/lifecycle.d.ts +43 -0
  17. package/actions/lifecycle.d.ts.map +1 -0
  18. package/actions/lifecycle.js +118 -0
  19. package/actions/onboarding.d.ts +12 -0
  20. package/actions/onboarding.d.ts.map +1 -0
  21. package/actions/onboarding.js +26 -0
  22. package/actions/triggers.d.ts +23 -0
  23. package/actions/triggers.d.ts.map +1 -0
  24. package/actions/triggers.js +148 -0
  25. package/api/client.d.ts +2736 -0
  26. package/api/client.d.ts.map +1 -0
  27. package/api/client.js +2492 -0
  28. package/api/index.d.ts +2 -0
  29. package/api/index.d.ts.map +1 -0
  30. package/autonomy/index.d.ts +48 -0
  31. package/autonomy/index.d.ts.map +1 -0
  32. package/autonomy/index.js +330 -0
  33. package/bridge/capacitor-bridge.d.ts +153 -0
  34. package/bridge/capacitor-bridge.d.ts.map +1 -0
  35. package/bridge/capacitor-bridge.js +193 -0
  36. package/bridge/electrobun-rpc.d.ts +28 -0
  37. package/bridge/electrobun-rpc.d.ts.map +1 -0
  38. package/bridge/electrobun-rpc.js +35 -0
  39. package/bridge/electrobun-runtime.d.ts +3 -0
  40. package/bridge/electrobun-runtime.d.ts.map +1 -0
  41. package/bridge/electrobun-runtime.js +17 -0
  42. package/bridge/index.d.ts +6 -0
  43. package/bridge/index.d.ts.map +1 -0
  44. package/bridge/native-plugins.d.ts +82 -0
  45. package/bridge/native-plugins.d.ts.map +1 -0
  46. package/bridge/native-plugins.js +39 -0
  47. package/bridge/plugin-bridge.d.ts +116 -0
  48. package/bridge/plugin-bridge.d.ts.map +1 -0
  49. package/bridge/plugin-bridge.js +203 -0
  50. package/bridge/storage-bridge.d.ts +39 -0
  51. package/bridge/storage-bridge.d.ts.map +1 -0
  52. package/bridge/storage-bridge.js +135 -0
  53. package/chat/index.d.ts +57 -0
  54. package/chat/index.d.ts.map +1 -0
  55. package/chat/index.js +160 -0
  56. package/coding/index.d.ts +25 -0
  57. package/coding/index.d.ts.map +1 -0
  58. package/coding/index.js +25 -0
  59. package/components/AdvancedPageView.d.ts +17 -0
  60. package/components/AdvancedPageView.d.ts.map +1 -0
  61. package/components/AdvancedPageView.js +146 -0
  62. package/components/AgentActivityBox.d.ts +7 -0
  63. package/components/AgentActivityBox.d.ts.map +1 -0
  64. package/components/AgentActivityBox.js +25 -0
  65. package/components/ApiKeyConfig.d.ts +26 -0
  66. package/components/ApiKeyConfig.d.ts.map +1 -0
  67. package/components/ApiKeyConfig.js +119 -0
  68. package/components/AppsPageView.d.ts +7 -0
  69. package/components/AppsPageView.d.ts.map +1 -0
  70. package/components/AppsPageView.js +31 -0
  71. package/components/AppsView.d.ts +8 -0
  72. package/components/AppsView.d.ts.map +1 -0
  73. package/components/AppsView.js +149 -0
  74. package/components/AvatarLoader.d.ts +13 -0
  75. package/components/AvatarLoader.d.ts.map +1 -0
  76. package/components/AvatarLoader.js +53 -0
  77. package/components/AvatarSelector.d.ts +23 -0
  78. package/components/AvatarSelector.d.ts.map +1 -0
  79. package/components/AvatarSelector.js +105 -0
  80. package/components/BscTradePanel.d.ts +22 -0
  81. package/components/BscTradePanel.d.ts.map +1 -0
  82. package/components/BscTradePanel.js +221 -0
  83. package/components/BugReportModal.d.ts +2 -0
  84. package/components/BugReportModal.d.ts.map +1 -0
  85. package/components/BugReportModal.js +219 -0
  86. package/components/CharacterRoster.d.ts +31 -0
  87. package/components/CharacterRoster.d.ts.map +1 -0
  88. package/components/CharacterRoster.js +41 -0
  89. package/components/CharacterView.d.ts +8 -0
  90. package/components/CharacterView.d.ts.map +1 -0
  91. package/components/CharacterView.js +685 -0
  92. package/components/ChatAvatar.d.ts +8 -0
  93. package/components/ChatAvatar.d.ts.map +1 -0
  94. package/components/ChatAvatar.js +89 -0
  95. package/components/ChatComposer.d.ts +37 -0
  96. package/components/ChatComposer.d.ts.map +1 -0
  97. package/components/ChatComposer.js +136 -0
  98. package/components/ChatMessage.d.ts +24 -0
  99. package/components/ChatMessage.d.ts.map +1 -0
  100. package/components/ChatMessage.js +167 -0
  101. package/components/ChatModalView.d.ts +10 -0
  102. package/components/ChatModalView.d.ts.map +1 -0
  103. package/components/ChatModalView.js +57 -0
  104. package/components/ChatView.d.ts +14 -0
  105. package/components/ChatView.d.ts.map +1 -0
  106. package/components/ChatView.js +526 -0
  107. package/components/CloudOnboarding.d.ts +7 -0
  108. package/components/CloudOnboarding.d.ts.map +1 -0
  109. package/components/CloudOnboarding.js +22 -0
  110. package/components/CloudSourceControls.d.ts +13 -0
  111. package/components/CloudSourceControls.d.ts.map +1 -0
  112. package/components/CloudSourceControls.js +16 -0
  113. package/components/CodingAgentSettingsSection.d.ts +2 -0
  114. package/components/CodingAgentSettingsSection.d.ts.map +1 -0
  115. package/components/CodingAgentSettingsSection.js +270 -0
  116. package/components/CommandPalette.d.ts +2 -0
  117. package/components/CommandPalette.d.ts.map +1 -0
  118. package/components/CommandPalette.js +181 -0
  119. package/components/CompanionSceneHost.d.ts +14 -0
  120. package/components/CompanionSceneHost.d.ts.map +1 -0
  121. package/components/CompanionSceneHost.js +360 -0
  122. package/components/CompanionShell.d.ts +17 -0
  123. package/components/CompanionShell.d.ts.map +1 -0
  124. package/components/CompanionShell.js +15 -0
  125. package/components/CompanionView.d.ts +2 -0
  126. package/components/CompanionView.d.ts.map +1 -0
  127. package/components/CompanionView.js +22 -0
  128. package/components/ConfigPageView.d.ts +11 -0
  129. package/components/ConfigPageView.d.ts.map +1 -0
  130. package/components/ConfigPageView.js +303 -0
  131. package/components/ConfigSaveFooter.d.ts +8 -0
  132. package/components/ConfigSaveFooter.d.ts.map +1 -0
  133. package/components/ConfigSaveFooter.js +10 -0
  134. package/components/ConfirmModal.d.ts +61 -0
  135. package/components/ConfirmModal.d.ts.map +1 -0
  136. package/components/ConfirmModal.js +164 -0
  137. package/components/ConnectionFailedBanner.d.ts +6 -0
  138. package/components/ConnectionFailedBanner.d.ts.map +1 -0
  139. package/components/ConnectionFailedBanner.js +22 -0
  140. package/components/ConnectorsPageView.d.ts +7 -0
  141. package/components/ConnectorsPageView.d.ts.map +1 -0
  142. package/components/ConnectorsPageView.js +8 -0
  143. package/components/ConversationsSidebar.d.ts +9 -0
  144. package/components/ConversationsSidebar.d.ts.map +1 -0
  145. package/components/ConversationsSidebar.js +116 -0
  146. package/components/CustomActionEditor.d.ts +10 -0
  147. package/components/CustomActionEditor.d.ts.map +1 -0
  148. package/components/CustomActionEditor.js +578 -0
  149. package/components/CustomActionsPanel.d.ts +9 -0
  150. package/components/CustomActionsPanel.d.ts.map +1 -0
  151. package/components/CustomActionsPanel.js +107 -0
  152. package/components/CustomActionsView.d.ts +2 -0
  153. package/components/CustomActionsView.d.ts.map +1 -0
  154. package/components/CustomActionsView.js +134 -0
  155. package/components/DatabasePageView.d.ts +5 -0
  156. package/components/DatabasePageView.d.ts.map +1 -0
  157. package/components/DatabasePageView.js +28 -0
  158. package/components/DatabaseView.d.ts +9 -0
  159. package/components/DatabaseView.d.ts.map +1 -0
  160. package/components/DatabaseView.js +311 -0
  161. package/components/ElizaCloudDashboard.d.ts +2 -0
  162. package/components/ElizaCloudDashboard.d.ts.map +1 -0
  163. package/components/ElizaCloudDashboard.js +657 -0
  164. package/components/EmotePicker.d.ts +2 -0
  165. package/components/EmotePicker.d.ts.map +1 -0
  166. package/components/EmotePicker.js +343 -0
  167. package/components/ErrorBoundary.d.ts +22 -0
  168. package/components/ErrorBoundary.d.ts.map +1 -0
  169. package/components/ErrorBoundary.js +31 -0
  170. package/components/FineTuningView.d.ts +2 -0
  171. package/components/FineTuningView.d.ts.map +1 -0
  172. package/components/FineTuningView.js +433 -0
  173. package/components/FlaminaGuide.d.ts +10 -0
  174. package/components/FlaminaGuide.d.ts.map +1 -0
  175. package/components/FlaminaGuide.js +64 -0
  176. package/components/GameView.d.ts +11 -0
  177. package/components/GameView.d.ts.map +1 -0
  178. package/components/GameView.js +294 -0
  179. package/components/GameViewOverlay.d.ts +8 -0
  180. package/components/GameViewOverlay.d.ts.map +1 -0
  181. package/components/GameViewOverlay.js +70 -0
  182. package/components/GlobalEmoteOverlay.d.ts +2 -0
  183. package/components/GlobalEmoteOverlay.d.ts.map +1 -0
  184. package/components/GlobalEmoteOverlay.js +112 -0
  185. package/components/Header.d.ts +9 -0
  186. package/components/Header.d.ts.map +1 -0
  187. package/components/Header.js +123 -0
  188. package/components/HeartbeatsView.d.ts +2 -0
  189. package/components/HeartbeatsView.d.ts.map +1 -0
  190. package/components/HeartbeatsView.js +378 -0
  191. package/components/InventoryView.d.ts +10 -0
  192. package/components/InventoryView.d.ts.map +1 -0
  193. package/components/InventoryView.js +176 -0
  194. package/components/KnowledgeView.d.ts +20 -0
  195. package/components/KnowledgeView.d.ts.map +1 -0
  196. package/components/KnowledgeView.js +480 -0
  197. package/components/LanguageDropdown.d.ts +30 -0
  198. package/components/LanguageDropdown.d.ts.map +1 -0
  199. package/components/LanguageDropdown.js +99 -0
  200. package/components/LifoMonitorPanel.d.ts +21 -0
  201. package/components/LifoMonitorPanel.d.ts.map +1 -0
  202. package/components/LifoMonitorPanel.js +24 -0
  203. package/components/LifoSandboxView.d.ts +5 -0
  204. package/components/LifoSandboxView.d.ts.map +1 -0
  205. package/components/LifoSandboxView.js +333 -0
  206. package/components/LoadingScreen.d.ts +13 -0
  207. package/components/LoadingScreen.d.ts.map +1 -0
  208. package/components/LoadingScreen.js +70 -0
  209. package/components/LogsPageView.d.ts +2 -0
  210. package/components/LogsPageView.d.ts.map +1 -0
  211. package/components/LogsPageView.js +7 -0
  212. package/components/LogsView.d.ts +5 -0
  213. package/components/LogsView.d.ts.map +1 -0
  214. package/components/LogsView.js +71 -0
  215. package/components/MediaGalleryView.d.ts +9 -0
  216. package/components/MediaGalleryView.d.ts.map +1 -0
  217. package/components/MediaGalleryView.js +236 -0
  218. package/components/MediaSettingsSection.d.ts +11 -0
  219. package/components/MediaSettingsSection.d.ts.map +1 -0
  220. package/components/MediaSettingsSection.js +329 -0
  221. package/components/MessageContent.d.ts +51 -0
  222. package/components/MessageContent.d.ts.map +1 -0
  223. package/components/MessageContent.js +553 -0
  224. package/components/OnboardingWizard.d.ts +2 -0
  225. package/components/OnboardingWizard.d.ts.map +1 -0
  226. package/components/OnboardingWizard.js +96 -0
  227. package/components/PairingView.d.ts +5 -0
  228. package/components/PairingView.d.ts.map +1 -0
  229. package/components/PairingView.js +29 -0
  230. package/components/PermissionsSection.d.ts +20 -0
  231. package/components/PermissionsSection.d.ts.map +1 -0
  232. package/components/PermissionsSection.js +573 -0
  233. package/components/PluginsPageView.d.ts +5 -0
  234. package/components/PluginsPageView.d.ts.map +1 -0
  235. package/components/PluginsPageView.js +8 -0
  236. package/components/PluginsView.d.ts +21 -0
  237. package/components/PluginsView.d.ts.map +1 -0
  238. package/components/PluginsView.js +1534 -0
  239. package/components/ProviderSwitcher.d.ts +42 -0
  240. package/components/ProviderSwitcher.d.ts.map +1 -0
  241. package/components/ProviderSwitcher.js +493 -0
  242. package/components/RestartBanner.d.ts +2 -0
  243. package/components/RestartBanner.d.ts.map +1 -0
  244. package/components/RestartBanner.js +36 -0
  245. package/components/RuntimeView.d.ts +10 -0
  246. package/components/RuntimeView.d.ts.map +1 -0
  247. package/components/RuntimeView.js +165 -0
  248. package/components/SaveCommandModal.d.ts +12 -0
  249. package/components/SaveCommandModal.d.ts.map +1 -0
  250. package/components/SaveCommandModal.js +84 -0
  251. package/components/SecretsView.d.ts +9 -0
  252. package/components/SecretsView.d.ts.map +1 -0
  253. package/components/SecretsView.js +249 -0
  254. package/components/SettingsView.d.ts +9 -0
  255. package/components/SettingsView.d.ts.map +1 -0
  256. package/components/SettingsView.js +230 -0
  257. package/components/ShellOverlays.d.ts +8 -0
  258. package/components/ShellOverlays.d.ts.map +1 -0
  259. package/components/ShellOverlays.js +10 -0
  260. package/components/ShortcutsOverlay.d.ts +2 -0
  261. package/components/ShortcutsOverlay.d.ts.map +1 -0
  262. package/components/ShortcutsOverlay.js +79 -0
  263. package/components/SkillsView.d.ts +11 -0
  264. package/components/SkillsView.d.ts.map +1 -0
  265. package/components/SkillsView.js +358 -0
  266. package/components/StartupFailureView.d.ts +8 -0
  267. package/components/StartupFailureView.d.ts.map +1 -0
  268. package/components/StartupFailureView.js +16 -0
  269. package/components/StreamView.d.ts +16 -0
  270. package/components/StreamView.d.ts.map +1 -0
  271. package/components/StreamView.js +300 -0
  272. package/components/StripeEmbeddedCheckout.d.ts +24 -0
  273. package/components/StripeEmbeddedCheckout.d.ts.map +1 -0
  274. package/components/StripeEmbeddedCheckout.js +101 -0
  275. package/components/SubscriptionStatus.d.ts +23 -0
  276. package/components/SubscriptionStatus.d.ts.map +1 -0
  277. package/components/SubscriptionStatus.js +301 -0
  278. package/components/SystemWarningBanner.d.ts +6 -0
  279. package/components/SystemWarningBanner.d.ts.map +1 -0
  280. package/components/SystemWarningBanner.js +46 -0
  281. package/components/ThemeToggle.d.ts +21 -0
  282. package/components/ThemeToggle.d.ts.map +1 -0
  283. package/components/ThemeToggle.js +24 -0
  284. package/components/TrajectoriesView.d.ts +12 -0
  285. package/components/TrajectoriesView.d.ts.map +1 -0
  286. package/components/TrajectoriesView.js +183 -0
  287. package/components/TrajectoryDetailView.d.ts +13 -0
  288. package/components/TrajectoryDetailView.d.ts.map +1 -0
  289. package/components/TrajectoryDetailView.js +112 -0
  290. package/components/TriggersView.d.ts +2 -0
  291. package/components/TriggersView.d.ts.map +1 -0
  292. package/components/VectorBrowserView.d.ts +10 -0
  293. package/components/VectorBrowserView.d.ts.map +1 -0
  294. package/components/VectorBrowserView.js +997 -0
  295. package/components/VoiceConfigView.d.ts +11 -0
  296. package/components/VoiceConfigView.d.ts.map +1 -0
  297. package/components/VoiceConfigView.js +329 -0
  298. package/components/VrmStage.d.ts +28 -0
  299. package/components/VrmStage.d.ts.map +1 -0
  300. package/components/VrmStage.js +178 -0
  301. package/components/WhatsAppQrOverlay.d.ts +8 -0
  302. package/components/WhatsAppQrOverlay.d.ts.map +1 -0
  303. package/components/WhatsAppQrOverlay.js +63 -0
  304. package/components/apps/AppDetailPane.d.ts +15 -0
  305. package/components/apps/AppDetailPane.d.ts.map +1 -0
  306. package/components/apps/AppDetailPane.js +13 -0
  307. package/components/apps/AppsCatalogGrid.d.ts +20 -0
  308. package/components/apps/AppsCatalogGrid.d.ts.map +1 -0
  309. package/components/apps/AppsCatalogGrid.js +18 -0
  310. package/components/apps/extensions/registry.d.ts +4 -0
  311. package/components/apps/extensions/registry.d.ts.map +1 -0
  312. package/components/apps/extensions/registry.js +7 -0
  313. package/components/apps/extensions/types.d.ts +7 -0
  314. package/components/apps/extensions/types.d.ts.map +1 -0
  315. package/components/apps/extensions/types.js +1 -0
  316. package/components/apps/helpers.d.ts +7 -0
  317. package/components/apps/helpers.d.ts.map +1 -0
  318. package/components/apps/helpers.js +44 -0
  319. package/components/avatar/VrmAnimationLoader.d.ts +30 -0
  320. package/components/avatar/VrmAnimationLoader.d.ts.map +1 -0
  321. package/components/avatar/VrmAnimationLoader.js +99 -0
  322. package/components/avatar/VrmBlinkController.d.ts +37 -0
  323. package/components/avatar/VrmBlinkController.d.ts.map +1 -0
  324. package/components/avatar/VrmBlinkController.js +98 -0
  325. package/components/avatar/VrmCameraManager.d.ts +57 -0
  326. package/components/avatar/VrmCameraManager.d.ts.map +1 -0
  327. package/components/avatar/VrmCameraManager.js +277 -0
  328. package/components/avatar/VrmEngine.d.ts +246 -0
  329. package/components/avatar/VrmEngine.d.ts.map +1 -0
  330. package/components/avatar/VrmEngine.js +2076 -0
  331. package/components/avatar/VrmFootShadow.d.ts +18 -0
  332. package/components/avatar/VrmFootShadow.d.ts.map +1 -0
  333. package/components/avatar/VrmFootShadow.js +83 -0
  334. package/components/avatar/VrmViewer.d.ts +60 -0
  335. package/components/avatar/VrmViewer.d.ts.map +1 -0
  336. package/components/avatar/VrmViewer.js +396 -0
  337. package/components/avatar/mixamoVRMRigMap.d.ts +3 -0
  338. package/components/avatar/mixamoVRMRigMap.d.ts.map +1 -0
  339. package/components/avatar/mixamoVRMRigMap.js +56 -0
  340. package/components/avatar/retargetMixamoFbxToVrm.d.ts +9 -0
  341. package/components/avatar/retargetMixamoFbxToVrm.d.ts.map +1 -0
  342. package/components/avatar/retargetMixamoFbxToVrm.js +88 -0
  343. package/components/avatar/retargetMixamoGltfToVrm.d.ts +11 -0
  344. package/components/avatar/retargetMixamoGltfToVrm.d.ts.map +1 -0
  345. package/components/avatar/retargetMixamoGltfToVrm.js +80 -0
  346. package/components/chainConfig.d.ts +89 -0
  347. package/components/chainConfig.d.ts.map +1 -0
  348. package/components/chainConfig.js +287 -0
  349. package/components/companion/CompanionHeader.d.ts +15 -0
  350. package/components/companion/CompanionHeader.d.ts.map +1 -0
  351. package/components/companion/CompanionHeader.js +7 -0
  352. package/components/companion/CompanionSceneHost.d.ts +2 -0
  353. package/components/companion/CompanionSceneHost.d.ts.map +1 -0
  354. package/components/companion/CompanionSceneHost.js +1 -0
  355. package/components/companion/VrmStage.d.ts +3 -0
  356. package/components/companion/VrmStage.d.ts.map +1 -0
  357. package/components/companion/VrmStage.js +1 -0
  358. package/components/companion/index.d.ts +18 -0
  359. package/components/companion/index.d.ts.map +1 -0
  360. package/components/companion/index.js +17 -0
  361. package/components/companion/walletUtils.d.ts +95 -0
  362. package/components/companion/walletUtils.d.ts.map +1 -0
  363. package/components/companion/walletUtils.js +167 -0
  364. package/components/companion-shell-styles.d.ts +38 -0
  365. package/components/companion-shell-styles.d.ts.map +1 -0
  366. package/components/companion-shell-styles.js +248 -0
  367. package/components/confirm-delete-control.d.ts +16 -0
  368. package/components/confirm-delete-control.d.ts.map +1 -0
  369. package/components/confirm-delete-control.js +12 -0
  370. package/components/conversations/ConversationListItem.d.ts +31 -0
  371. package/components/conversations/ConversationListItem.d.ts.map +1 -0
  372. package/components/conversations/ConversationListItem.js +52 -0
  373. package/components/conversations/conversation-utils.d.ts +9 -0
  374. package/components/conversations/conversation-utils.d.ts.map +1 -0
  375. package/components/conversations/conversation-utils.js +138 -0
  376. package/components/format.d.ts +54 -0
  377. package/components/format.d.ts.map +1 -0
  378. package/components/format.js +82 -0
  379. package/components/index.d.ts +96 -0
  380. package/components/index.d.ts.map +1 -0
  381. package/components/index.js +95 -0
  382. package/components/inventory/CopyableAddress.d.ts +8 -0
  383. package/components/inventory/CopyableAddress.d.ts.map +1 -0
  384. package/components/inventory/CopyableAddress.js +18 -0
  385. package/components/inventory/InventoryToolbar.d.ts +25 -0
  386. package/components/inventory/InventoryToolbar.d.ts.map +1 -0
  387. package/components/inventory/InventoryToolbar.js +28 -0
  388. package/components/inventory/NftGrid.d.ts +13 -0
  389. package/components/inventory/NftGrid.d.ts.map +1 -0
  390. package/components/inventory/NftGrid.js +29 -0
  391. package/components/inventory/TokenLogo.d.ts +12 -0
  392. package/components/inventory/TokenLogo.d.ts.map +1 -0
  393. package/components/inventory/TokenLogo.js +33 -0
  394. package/components/inventory/TokensTable.d.ts +24 -0
  395. package/components/inventory/TokensTable.d.ts.map +1 -0
  396. package/components/inventory/TokensTable.js +26 -0
  397. package/components/inventory/constants.d.ts +52 -0
  398. package/components/inventory/constants.d.ts.map +1 -0
  399. package/components/inventory/constants.js +121 -0
  400. package/components/inventory/index.d.ts +9 -0
  401. package/components/inventory/index.d.ts.map +1 -0
  402. package/components/inventory/index.js +8 -0
  403. package/components/inventory/media-url.d.ts +6 -0
  404. package/components/inventory/media-url.d.ts.map +1 -0
  405. package/components/inventory/media-url.js +28 -0
  406. package/components/inventory/useInventoryData.d.ts +53 -0
  407. package/components/inventory/useInventoryData.d.ts.map +1 -0
  408. package/components/inventory/useInventoryData.js +332 -0
  409. package/components/knowledge-upload-image.d.ts +27 -0
  410. package/components/knowledge-upload-image.d.ts.map +1 -0
  411. package/components/knowledge-upload-image.js +146 -0
  412. package/components/labels.d.ts +6 -0
  413. package/components/labels.d.ts.map +1 -0
  414. package/components/labels.js +40 -0
  415. package/components/onboarding/ActivateStep.d.ts +2 -0
  416. package/components/onboarding/ActivateStep.d.ts.map +1 -0
  417. package/components/onboarding/ActivateStep.js +10 -0
  418. package/components/onboarding/ConnectionStep.d.ts +2 -0
  419. package/components/onboarding/ConnectionStep.d.ts.map +1 -0
  420. package/components/onboarding/ConnectionStep.js +609 -0
  421. package/components/onboarding/IdentityStep.d.ts +2 -0
  422. package/components/onboarding/IdentityStep.d.ts.map +1 -0
  423. package/components/onboarding/IdentityStep.js +102 -0
  424. package/components/onboarding/OnboardingPanel.d.ts +9 -0
  425. package/components/onboarding/OnboardingPanel.d.ts.map +1 -0
  426. package/components/onboarding/OnboardingPanel.js +24 -0
  427. package/components/onboarding/OnboardingStepNav.d.ts +2 -0
  428. package/components/onboarding/OnboardingStepNav.d.ts.map +1 -0
  429. package/components/onboarding/OnboardingStepNav.js +23 -0
  430. package/components/onboarding/PermissionsStep.d.ts +2 -0
  431. package/components/onboarding/PermissionsStep.d.ts.map +1 -0
  432. package/components/onboarding/PermissionsStep.js +7 -0
  433. package/components/onboarding/RpcStep.d.ts +2 -0
  434. package/components/onboarding/RpcStep.d.ts.map +1 -0
  435. package/components/onboarding/RpcStep.js +125 -0
  436. package/components/permissions/PermissionIcon.d.ts +4 -0
  437. package/components/permissions/PermissionIcon.d.ts.map +1 -0
  438. package/components/permissions/PermissionIcon.js +12 -0
  439. package/components/permissions/StreamingPermissions.d.ts +20 -0
  440. package/components/permissions/StreamingPermissions.d.ts.map +1 -0
  441. package/components/permissions/StreamingPermissions.js +177 -0
  442. package/components/plugins/showcase-data.d.ts +7 -0
  443. package/components/plugins/showcase-data.d.ts.map +1 -0
  444. package/components/plugins/showcase-data.js +464 -0
  445. package/components/shared/ShellHeaderControls.d.ts +27 -0
  446. package/components/shared/ShellHeaderControls.d.ts.map +1 -0
  447. package/components/shared/ShellHeaderControls.js +60 -0
  448. package/components/shared-companion-scene-context.d.ts +3 -0
  449. package/components/shared-companion-scene-context.d.ts.map +1 -0
  450. package/components/shared-companion-scene-context.js +13 -0
  451. package/components/skeletons.d.ts +17 -0
  452. package/components/skeletons.d.ts.map +1 -0
  453. package/components/skeletons.js +22 -0
  454. package/components/stream/ActivityFeed.d.ts +5 -0
  455. package/components/stream/ActivityFeed.d.ts.map +1 -0
  456. package/components/stream/ActivityFeed.js +57 -0
  457. package/components/stream/AvatarPip.d.ts +5 -0
  458. package/components/stream/AvatarPip.d.ts.map +1 -0
  459. package/components/stream/AvatarPip.js +6 -0
  460. package/components/stream/ChatContent.d.ts +6 -0
  461. package/components/stream/ChatContent.d.ts.map +1 -0
  462. package/components/stream/ChatContent.js +69 -0
  463. package/components/stream/ChatTicker.d.ts +5 -0
  464. package/components/stream/ChatTicker.d.ts.map +1 -0
  465. package/components/stream/ChatTicker.js +34 -0
  466. package/components/stream/IdleContent.d.ts +5 -0
  467. package/components/stream/IdleContent.d.ts.map +1 -0
  468. package/components/stream/IdleContent.js +17 -0
  469. package/components/stream/StatusBar.d.ts +36 -0
  470. package/components/stream/StatusBar.d.ts.map +1 -0
  471. package/components/stream/StatusBar.js +140 -0
  472. package/components/stream/StreamSettings.d.ts +33 -0
  473. package/components/stream/StreamSettings.d.ts.map +1 -0
  474. package/components/stream/StreamSettings.js +99 -0
  475. package/components/stream/StreamTerminal.d.ts +2 -0
  476. package/components/stream/StreamTerminal.d.ts.map +1 -0
  477. package/components/stream/StreamTerminal.js +52 -0
  478. package/components/stream/StreamVoiceConfig.d.ts +10 -0
  479. package/components/stream/StreamVoiceConfig.d.ts.map +1 -0
  480. package/components/stream/StreamVoiceConfig.js +88 -0
  481. package/components/stream/helpers.d.ts +32 -0
  482. package/components/stream/helpers.d.ts.map +1 -0
  483. package/components/stream/helpers.js +110 -0
  484. package/components/stream/overlays/OverlayLayer.d.ts +20 -0
  485. package/components/stream/overlays/OverlayLayer.d.ts.map +1 -0
  486. package/components/stream/overlays/OverlayLayer.js +24 -0
  487. package/components/stream/overlays/built-in/ActionTickerWidget.d.ts +8 -0
  488. package/components/stream/overlays/built-in/ActionTickerWidget.d.ts.map +1 -0
  489. package/components/stream/overlays/built-in/ActionTickerWidget.js +44 -0
  490. package/components/stream/overlays/built-in/AlertPopupWidget.d.ts +7 -0
  491. package/components/stream/overlays/built-in/AlertPopupWidget.d.ts.map +1 -0
  492. package/components/stream/overlays/built-in/AlertPopupWidget.js +62 -0
  493. package/components/stream/overlays/built-in/BrandingWidget.d.ts +7 -0
  494. package/components/stream/overlays/built-in/BrandingWidget.d.ts.map +1 -0
  495. package/components/stream/overlays/built-in/BrandingWidget.js +36 -0
  496. package/components/stream/overlays/built-in/CustomHtmlWidget.d.ts +26 -0
  497. package/components/stream/overlays/built-in/CustomHtmlWidget.d.ts.map +1 -0
  498. package/components/stream/overlays/built-in/CustomHtmlWidget.js +78 -0
  499. package/components/stream/overlays/built-in/PeonGlassWidget.d.ts +11 -0
  500. package/components/stream/overlays/built-in/PeonGlassWidget.d.ts.map +1 -0
  501. package/components/stream/overlays/built-in/PeonGlassWidget.js +188 -0
  502. package/components/stream/overlays/built-in/PeonHudWidget.d.ts +10 -0
  503. package/components/stream/overlays/built-in/PeonHudWidget.d.ts.map +1 -0
  504. package/components/stream/overlays/built-in/PeonHudWidget.js +168 -0
  505. package/components/stream/overlays/built-in/PeonSakuraWidget.d.ts +11 -0
  506. package/components/stream/overlays/built-in/PeonSakuraWidget.d.ts.map +1 -0
  507. package/components/stream/overlays/built-in/PeonSakuraWidget.js +213 -0
  508. package/components/stream/overlays/built-in/ThoughtBubbleWidget.d.ts +8 -0
  509. package/components/stream/overlays/built-in/ThoughtBubbleWidget.d.ts.map +1 -0
  510. package/components/stream/overlays/built-in/ThoughtBubbleWidget.js +59 -0
  511. package/components/stream/overlays/built-in/ViewerCountWidget.d.ts +7 -0
  512. package/components/stream/overlays/built-in/ViewerCountWidget.d.ts.map +1 -0
  513. package/components/stream/overlays/built-in/ViewerCountWidget.js +34 -0
  514. package/components/stream/overlays/built-in/index.d.ts +13 -0
  515. package/components/stream/overlays/built-in/index.d.ts.map +1 -0
  516. package/components/stream/overlays/built-in/index.js +12 -0
  517. package/components/stream/overlays/registry.d.ts +11 -0
  518. package/components/stream/overlays/registry.d.ts.map +1 -0
  519. package/components/stream/overlays/registry.js +16 -0
  520. package/components/stream/overlays/types.d.ts +67 -0
  521. package/components/stream/overlays/types.d.ts.map +1 -0
  522. package/components/stream/overlays/types.js +7 -0
  523. package/components/stream/overlays/useOverlayLayout.d.ts +27 -0
  524. package/components/stream/overlays/useOverlayLayout.d.ts.map +1 -0
  525. package/components/stream/overlays/useOverlayLayout.js +162 -0
  526. package/components/trajectory-format.d.ts +6 -0
  527. package/components/trajectory-format.d.ts.map +1 -0
  528. package/components/trajectory-format.js +43 -0
  529. package/components/ui-badges.d.ts +23 -0
  530. package/components/ui-badges.d.ts.map +1 -0
  531. package/components/ui-badges.js +38 -0
  532. package/components/ui-switch.d.ts +14 -0
  533. package/components/ui-switch.d.ts.map +1 -0
  534. package/components/ui-switch.js +15 -0
  535. package/components/vector-browser-three.d.ts +4 -0
  536. package/components/vector-browser-three.d.ts.map +1 -0
  537. package/components/vector-browser-three.js +21 -0
  538. package/config/branding.d.ts +49 -0
  539. package/config/branding.d.ts.map +1 -0
  540. package/config/branding.js +16 -0
  541. package/config/config-catalog.d.ts +376 -0
  542. package/config/config-catalog.d.ts.map +1 -0
  543. package/config/config-catalog.js +724 -0
  544. package/config/config-field.d.ts +68 -0
  545. package/config/config-field.d.ts.map +1 -0
  546. package/config/config-field.js +840 -0
  547. package/config/config-renderer.d.ts +176 -0
  548. package/config/config-renderer.d.ts.map +1 -0
  549. package/config/config-renderer.js +405 -0
  550. package/config/index.d.ts +6 -0
  551. package/config/index.d.ts.map +1 -0
  552. package/config/index.js +5 -0
  553. package/config/ui-renderer.d.ts +26 -0
  554. package/config/ui-renderer.d.ts.map +1 -0
  555. package/config/ui-renderer.js +815 -0
  556. package/config/ui-spec.d.ts +164 -0
  557. package/config/ui-spec.d.ts.map +1 -0
  558. package/config/ui-spec.js +13 -0
  559. package/events/index.d.ts +47 -0
  560. package/events/index.d.ts.map +1 -0
  561. package/events/index.js +43 -0
  562. package/hooks/index.d.ts +15 -0
  563. package/hooks/index.d.ts.map +1 -0
  564. package/hooks/useBugReport.d.ts +14 -0
  565. package/hooks/useBugReport.d.ts.map +1 -0
  566. package/hooks/useBugReport.js +18 -0
  567. package/hooks/useCanvasWindow.d.ts +38 -0
  568. package/hooks/useCanvasWindow.d.ts.map +1 -0
  569. package/hooks/useCanvasWindow.js +273 -0
  570. package/hooks/useChatAvatarVoice.d.ts +10 -0
  571. package/hooks/useChatAvatarVoice.d.ts.map +1 -0
  572. package/hooks/useChatAvatarVoice.js +71 -0
  573. package/hooks/useClickOutside.d.ts +6 -0
  574. package/hooks/useClickOutside.d.ts.map +1 -0
  575. package/hooks/useClickOutside.js +25 -0
  576. package/hooks/useContextMenu.d.ts +17 -0
  577. package/hooks/useContextMenu.d.ts.map +1 -0
  578. package/hooks/useContextMenu.js +100 -0
  579. package/hooks/useKeyboardShortcuts.d.ts +17 -0
  580. package/hooks/useKeyboardShortcuts.d.ts.map +1 -0
  581. package/hooks/useKeyboardShortcuts.js +67 -0
  582. package/hooks/useLifoSync.d.ts +18 -0
  583. package/hooks/useLifoSync.d.ts.map +1 -0
  584. package/hooks/useLifoSync.js +113 -0
  585. package/hooks/useMemoryMonitor.d.ts +87 -0
  586. package/hooks/useMemoryMonitor.d.ts.map +1 -0
  587. package/hooks/useMemoryMonitor.js +209 -0
  588. package/hooks/useRenderGuard.d.ts +17 -0
  589. package/hooks/useRenderGuard.d.ts.map +1 -0
  590. package/hooks/useRenderGuard.js +36 -0
  591. package/hooks/useRetakeCapture.d.ts +12 -0
  592. package/hooks/useRetakeCapture.d.ts.map +1 -0
  593. package/hooks/useRetakeCapture.js +60 -0
  594. package/hooks/useStreamPopoutNavigation.d.ts +3 -0
  595. package/hooks/useStreamPopoutNavigation.d.ts.map +1 -0
  596. package/hooks/useStreamPopoutNavigation.js +17 -0
  597. package/hooks/useTimeout.d.ts +11 -0
  598. package/hooks/useTimeout.d.ts.map +1 -0
  599. package/hooks/useTimeout.js +32 -0
  600. package/hooks/useVoiceChat.d.ts +94 -0
  601. package/hooks/useVoiceChat.d.ts.map +1 -0
  602. package/hooks/useVoiceChat.js +1074 -0
  603. package/hooks/useWhatsAppPairing.d.ts +11 -0
  604. package/hooks/useWhatsAppPairing.d.ts.map +1 -0
  605. package/hooks/useWhatsAppPairing.js +95 -0
  606. package/i18n/index.d.ts +7 -0
  607. package/i18n/index.d.ts.map +1 -0
  608. package/i18n/index.js +53 -0
  609. package/i18n/locales/en.json +1239 -0
  610. package/i18n/locales/es.json +1236 -0
  611. package/i18n/locales/ko.json +1236 -0
  612. package/i18n/locales/pt.json +1236 -0
  613. package/i18n/locales/zh-CN.json +1236 -0
  614. package/i18n/messages.d.ts +6 -0
  615. package/i18n/messages.d.ts.map +1 -0
  616. package/i18n/messages.js +14 -0
  617. package/index.d.ts +5 -0
  618. package/index.d.ts.map +1 -0
  619. package/navigation/index.d.ts +27 -0
  620. package/navigation/index.d.ts.map +1 -0
  621. package/navigation/index.js +232 -0
  622. package/onboarding-config.d.ts +25 -0
  623. package/onboarding-config.d.ts.map +1 -0
  624. package/onboarding-config.js +76 -0
  625. package/package.json +143 -53
  626. package/platform/browser-launch.d.ts +2 -0
  627. package/platform/browser-launch.d.ts.map +1 -0
  628. package/platform/browser-launch.js +109 -0
  629. package/platform/index.d.ts +14 -0
  630. package/platform/index.d.ts.map +1 -0
  631. package/platform/index.js +24 -0
  632. package/platform/init.d.ts +40 -0
  633. package/platform/init.d.ts.map +1 -0
  634. package/platform/init.js +160 -0
  635. package/platform/lifo.d.ts +51 -0
  636. package/platform/lifo.d.ts.map +1 -0
  637. package/platform/lifo.js +138 -0
  638. package/providers/index.d.ts +19 -0
  639. package/providers/index.d.ts.map +1 -0
  640. package/providers/index.js +80 -0
  641. package/shell-params.d.ts +12 -0
  642. package/shell-params.d.ts.map +1 -0
  643. package/shell-params.js +19 -0
  644. package/state/AppContext.d.ts +12 -0
  645. package/state/AppContext.d.ts.map +1 -0
  646. package/state/AppContext.js +5060 -0
  647. package/state/index.d.ts +7 -0
  648. package/state/index.d.ts.map +1 -0
  649. package/state/internal.d.ts +7 -0
  650. package/state/internal.d.ts.map +1 -0
  651. package/state/internal.js +6 -0
  652. package/state/onboarding-resume.d.ts +11 -0
  653. package/state/onboarding-resume.d.ts.map +1 -0
  654. package/state/onboarding-resume.js +189 -0
  655. package/state/parsers.d.ts +26 -0
  656. package/state/parsers.d.ts.map +1 -0
  657. package/state/parsers.js +255 -0
  658. package/state/persistence.d.ts +59 -0
  659. package/state/persistence.d.ts.map +1 -0
  660. package/state/persistence.js +326 -0
  661. package/state/shell-routing.d.ts +12 -0
  662. package/state/shell-routing.d.ts.map +1 -0
  663. package/state/shell-routing.js +25 -0
  664. package/state/types.d.ts +421 -0
  665. package/state/types.d.ts.map +1 -0
  666. package/state/types.js +75 -0
  667. package/state/ui-preferences.d.ts +3 -0
  668. package/state/ui-preferences.d.ts.map +1 -0
  669. package/state/ui-preferences.js +1 -0
  670. package/state/useApp.d.ts +4 -0
  671. package/state/useApp.d.ts.map +1 -0
  672. package/state/useApp.js +22 -0
  673. package/state/vrm.d.ts +30 -0
  674. package/state/vrm.d.ts.map +1 -0
  675. package/state/vrm.js +82 -0
  676. package/styles/anime.css +6321 -0
  677. package/styles/onboarding-game.css +1092 -0
  678. package/types/index.d.ts +657 -0
  679. package/types/index.d.ts.map +1 -0
  680. package/types/index.js +1 -0
  681. package/utils/asset-url.d.ts +26 -0
  682. package/utils/asset-url.d.ts.map +1 -0
  683. package/utils/asset-url.js +99 -0
  684. package/utils/assistant-text.d.ts +2 -0
  685. package/utils/assistant-text.d.ts.map +1 -0
  686. package/utils/assistant-text.js +161 -0
  687. package/utils/clipboard.d.ts +2 -0
  688. package/utils/clipboard.d.ts.map +1 -0
  689. package/utils/clipboard.js +38 -0
  690. package/utils/desktop-dialogs.d.ts +19 -0
  691. package/utils/desktop-dialogs.d.ts.map +1 -0
  692. package/utils/desktop-dialogs.js +50 -0
  693. package/utils/eliza-globals.d.ts +11 -0
  694. package/utils/eliza-globals.d.ts.map +1 -0
  695. package/utils/eliza-globals.js +33 -0
  696. package/utils/index.d.ts +8 -0
  697. package/utils/index.d.ts.map +1 -0
  698. package/utils/number-parsing.d.ts +44 -0
  699. package/utils/number-parsing.d.ts.map +1 -0
  700. package/utils/number-parsing.js +56 -0
  701. package/utils/openExternalUrl.d.ts +2 -0
  702. package/utils/openExternalUrl.d.ts.map +1 -0
  703. package/utils/openExternalUrl.js +17 -0
  704. package/utils/spoken-text.d.ts +2 -0
  705. package/utils/spoken-text.d.ts.map +1 -0
  706. package/utils/spoken-text.js +56 -0
  707. package/utils/streaming-text.d.ts +3 -0
  708. package/utils/streaming-text.d.ts.map +1 -0
  709. package/utils/streaming-text.js +87 -0
  710. package/voice/index.d.ts +2 -0
  711. package/voice/index.d.ts.map +1 -0
  712. package/voice/types.d.ts +25 -0
  713. package/voice/types.d.ts.map +1 -0
  714. package/voice/types.js +166 -0
  715. package/wallet-rpc.d.ts +8 -0
  716. package/wallet-rpc.d.ts.map +1 -0
  717. package/wallet-rpc.js +131 -0
  718. package/.turbo/turbo-build.log +0 -5
  719. package/src/App.tsx +0 -504
  720. package/src/actions/character.test.ts +0 -139
  721. package/src/actions/character.ts +0 -334
  722. package/src/actions/chat-helpers.ts +0 -100
  723. package/src/actions/cloud.ts +0 -59
  724. package/src/actions/index.ts +0 -12
  725. package/src/actions/lifecycle.ts +0 -175
  726. package/src/actions/onboarding.ts +0 -38
  727. package/src/actions/triggers.ts +0 -190
  728. package/src/ambient.d.ts +0 -33
  729. package/src/api/client.ts +0 -5659
  730. package/src/autonomy/index.ts +0 -477
  731. package/src/bridge/capacitor-bridge.ts +0 -295
  732. package/src/bridge/electrobun-rpc.ts +0 -78
  733. package/src/bridge/electrobun-runtime.ts +0 -28
  734. package/src/bridge/native-plugins.ts +0 -138
  735. package/src/bridge/plugin-bridge.ts +0 -352
  736. package/src/bridge/storage-bridge.ts +0 -162
  737. package/src/chat/index.ts +0 -250
  738. package/src/coding/index.ts +0 -43
  739. package/src/components/AdvancedPageView.tsx +0 -382
  740. package/src/components/AgentActivityBox.tsx +0 -49
  741. package/src/components/ApiKeyConfig.tsx +0 -222
  742. package/src/components/AppsPageView.tsx +0 -52
  743. package/src/components/AppsView.tsx +0 -293
  744. package/src/components/AvatarLoader.tsx +0 -104
  745. package/src/components/AvatarSelector.tsx +0 -223
  746. package/src/components/BscTradePanel.tsx +0 -549
  747. package/src/components/BugReportModal.tsx +0 -499
  748. package/src/components/CharacterRoster.tsx +0 -143
  749. package/src/components/CharacterView.tsx +0 -1575
  750. package/src/components/ChatAvatar.test.ts +0 -97
  751. package/src/components/ChatAvatar.tsx +0 -147
  752. package/src/components/ChatComposer.tsx +0 -330
  753. package/src/components/ChatMessage.tsx +0 -448
  754. package/src/components/ChatModalView.test.tsx +0 -118
  755. package/src/components/ChatModalView.tsx +0 -125
  756. package/src/components/ChatView.tsx +0 -992
  757. package/src/components/CloudOnboarding.tsx +0 -81
  758. package/src/components/CloudSourceControls.tsx +0 -85
  759. package/src/components/CodingAgentSettingsSection.tsx +0 -537
  760. package/src/components/CommandPalette.tsx +0 -284
  761. package/src/components/CompanionSceneHost.tsx +0 -517
  762. package/src/components/CompanionShell.tsx +0 -31
  763. package/src/components/CompanionView.tsx +0 -110
  764. package/src/components/ConfigPageView.tsx +0 -763
  765. package/src/components/ConfigSaveFooter.tsx +0 -41
  766. package/src/components/ConfirmModal.tsx +0 -379
  767. package/src/components/ConnectionFailedBanner.tsx +0 -91
  768. package/src/components/ConnectorsPageView.tsx +0 -13
  769. package/src/components/ConversationsSidebar.tsx +0 -279
  770. package/src/components/CustomActionEditor.tsx +0 -1127
  771. package/src/components/CustomActionsPanel.tsx +0 -288
  772. package/src/components/CustomActionsView.tsx +0 -325
  773. package/src/components/DatabasePageView.tsx +0 -55
  774. package/src/components/DatabaseView.tsx +0 -814
  775. package/src/components/ElizaCloudDashboard.tsx +0 -1696
  776. package/src/components/EmotePicker.tsx +0 -529
  777. package/src/components/ErrorBoundary.tsx +0 -76
  778. package/src/components/FineTuningView.tsx +0 -1080
  779. package/src/components/FlaminaGuide.test.tsx +0 -61
  780. package/src/components/FlaminaGuide.tsx +0 -212
  781. package/src/components/GameView.tsx +0 -551
  782. package/src/components/GameViewOverlay.tsx +0 -133
  783. package/src/components/GlobalEmoteOverlay.tsx +0 -152
  784. package/src/components/Header.test.tsx +0 -413
  785. package/src/components/Header.tsx +0 -400
  786. package/src/components/HeartbeatsView.tsx +0 -1003
  787. package/src/components/InventoryView.tsx +0 -393
  788. package/src/components/KnowledgeView.tsx +0 -1128
  789. package/src/components/LanguageDropdown.tsx +0 -192
  790. package/src/components/LifoMonitorPanel.tsx +0 -196
  791. package/src/components/LifoSandboxView.tsx +0 -499
  792. package/src/components/LoadingScreen.tsx +0 -112
  793. package/src/components/LogsPageView.tsx +0 -17
  794. package/src/components/LogsView.tsx +0 -239
  795. package/src/components/MediaGalleryView.tsx +0 -431
  796. package/src/components/MediaSettingsSection.tsx +0 -893
  797. package/src/components/MessageContent.tsx +0 -815
  798. package/src/components/MiladyBar.tsx +0 -103
  799. package/src/components/MiladyBarSettings.tsx +0 -872
  800. package/src/components/OnboardingWizard.test.tsx +0 -104
  801. package/src/components/OnboardingWizard.tsx +0 -249
  802. package/src/components/PairingView.tsx +0 -109
  803. package/src/components/PermissionsSection.tsx +0 -1184
  804. package/src/components/PluginsPageView.tsx +0 -9
  805. package/src/components/PluginsView.tsx +0 -3129
  806. package/src/components/ProviderSwitcher.tsx +0 -903
  807. package/src/components/RestartBanner.tsx +0 -76
  808. package/src/components/RuntimeView.tsx +0 -460
  809. package/src/components/SaveCommandModal.tsx +0 -211
  810. package/src/components/SecretsView.tsx +0 -569
  811. package/src/components/SecurityPageView.tsx +0 -242
  812. package/src/components/SettingsView.tsx +0 -825
  813. package/src/components/ShellOverlays.tsx +0 -41
  814. package/src/components/ShortcutsOverlay.tsx +0 -155
  815. package/src/components/SkillsView.tsx +0 -1435
  816. package/src/components/StartupFailureView.tsx +0 -63
  817. package/src/components/StreamView.tsx +0 -481
  818. package/src/components/StripeEmbeddedCheckout.tsx +0 -155
  819. package/src/components/SubscriptionStatus.tsx +0 -640
  820. package/src/components/SystemWarningBanner.tsx +0 -71
  821. package/src/components/ThemeToggle.tsx +0 -103
  822. package/src/components/TrajectoriesView.tsx +0 -526
  823. package/src/components/TrajectoryDetailView.tsx +0 -426
  824. package/src/components/VectorBrowserView.tsx +0 -1633
  825. package/src/components/VoiceConfigView.tsx +0 -674
  826. package/src/components/VrmStage.test.ts +0 -176
  827. package/src/components/VrmStage.tsx +0 -309
  828. package/src/components/WhatsAppQrOverlay.tsx +0 -230
  829. package/src/components/__tests__/chainConfig.test.ts +0 -220
  830. package/src/components/apps/AppDetailPane.tsx +0 -242
  831. package/src/components/apps/AppsCatalogGrid.tsx +0 -137
  832. package/src/components/apps/extensions/registry.ts +0 -13
  833. package/src/components/apps/extensions/types.ts +0 -9
  834. package/src/components/apps/helpers.ts +0 -43
  835. package/src/components/avatar/VrmAnimationLoader.test.ts +0 -164
  836. package/src/components/avatar/VrmAnimationLoader.ts +0 -151
  837. package/src/components/avatar/VrmBlinkController.ts +0 -118
  838. package/src/components/avatar/VrmCameraManager.ts +0 -407
  839. package/src/components/avatar/VrmEngine.ts +0 -2767
  840. package/src/components/avatar/VrmFootShadow.ts +0 -96
  841. package/src/components/avatar/VrmViewer.tsx +0 -421
  842. package/src/components/avatar/__tests__/VrmCameraManager.test.ts +0 -168
  843. package/src/components/avatar/__tests__/VrmEngine.test.ts +0 -1574
  844. package/src/components/avatar/mixamoVRMRigMap.ts +0 -62
  845. package/src/components/avatar/retargetMixamoFbxToVrm.ts +0 -144
  846. package/src/components/avatar/retargetMixamoGltfToVrm.ts +0 -119
  847. package/src/components/chainConfig.ts +0 -400
  848. package/src/components/companion/CompanionHeader.tsx +0 -50
  849. package/src/components/companion/CompanionSceneHost.tsx +0 -5
  850. package/src/components/companion/VrmStage.tsx +0 -2
  851. package/src/components/companion/__tests__/walletUtils.test.ts +0 -742
  852. package/src/components/companion/index.ts +0 -18
  853. package/src/components/companion/walletUtils.ts +0 -290
  854. package/src/components/companion-shell-styles.test.ts +0 -142
  855. package/src/components/companion-shell-styles.ts +0 -270
  856. package/src/components/confirm-delete-control.tsx +0 -69
  857. package/src/components/conversations/ConversationListItem.tsx +0 -185
  858. package/src/components/conversations/conversation-utils.ts +0 -151
  859. package/src/components/format.ts +0 -131
  860. package/src/components/index.ts +0 -96
  861. package/src/components/inventory/CopyableAddress.tsx +0 -41
  862. package/src/components/inventory/InventoryToolbar.tsx +0 -142
  863. package/src/components/inventory/NftGrid.tsx +0 -99
  864. package/src/components/inventory/TokenLogo.tsx +0 -71
  865. package/src/components/inventory/TokensTable.tsx +0 -216
  866. package/src/components/inventory/constants.ts +0 -170
  867. package/src/components/inventory/index.ts +0 -29
  868. package/src/components/inventory/media-url.test.ts +0 -38
  869. package/src/components/inventory/media-url.ts +0 -36
  870. package/src/components/inventory/useInventoryData.ts +0 -460
  871. package/src/components/knowledge-upload-image.ts +0 -215
  872. package/src/components/labels.ts +0 -46
  873. package/src/components/milady-bar/CloudCreditsChip.tsx +0 -61
  874. package/src/components/milady-bar/ProviderDropdown.tsx +0 -166
  875. package/src/components/milady-bar/WalletSummary.tsx +0 -61
  876. package/src/components/milady-bar/index.ts +0 -3
  877. package/src/components/onboarding/ActivateStep.tsx +0 -34
  878. package/src/components/onboarding/ConnectionStep.tsx +0 -1591
  879. package/src/components/onboarding/IdentityStep.tsx +0 -251
  880. package/src/components/onboarding/OnboardingPanel.tsx +0 -39
  881. package/src/components/onboarding/OnboardingStepNav.tsx +0 -41
  882. package/src/components/onboarding/PermissionsStep.tsx +0 -20
  883. package/src/components/onboarding/RpcStep.tsx +0 -402
  884. package/src/components/permissions/PermissionIcon.tsx +0 -25
  885. package/src/components/permissions/StreamingPermissions.tsx +0 -413
  886. package/src/components/plugins/showcase-data.ts +0 -481
  887. package/src/components/shared/ShellHeaderControls.tsx +0 -198
  888. package/src/components/shared-companion-scene-context.ts +0 -15
  889. package/src/components/skeletons.tsx +0 -88
  890. package/src/components/stream/ActivityFeed.tsx +0 -113
  891. package/src/components/stream/AvatarPip.tsx +0 -10
  892. package/src/components/stream/ChatContent.tsx +0 -126
  893. package/src/components/stream/ChatTicker.tsx +0 -55
  894. package/src/components/stream/IdleContent.tsx +0 -73
  895. package/src/components/stream/StatusBar.tsx +0 -463
  896. package/src/components/stream/StreamSettings.tsx +0 -506
  897. package/src/components/stream/StreamTerminal.tsx +0 -94
  898. package/src/components/stream/StreamVoiceConfig.tsx +0 -160
  899. package/src/components/stream/helpers.ts +0 -134
  900. package/src/components/stream/overlays/OverlayLayer.tsx +0 -75
  901. package/src/components/stream/overlays/built-in/ActionTickerWidget.tsx +0 -64
  902. package/src/components/stream/overlays/built-in/AlertPopupWidget.tsx +0 -87
  903. package/src/components/stream/overlays/built-in/BrandingWidget.tsx +0 -51
  904. package/src/components/stream/overlays/built-in/CustomHtmlWidget.tsx +0 -105
  905. package/src/components/stream/overlays/built-in/PeonGlassWidget.tsx +0 -265
  906. package/src/components/stream/overlays/built-in/PeonHudWidget.tsx +0 -247
  907. package/src/components/stream/overlays/built-in/PeonSakuraWidget.tsx +0 -278
  908. package/src/components/stream/overlays/built-in/ThoughtBubbleWidget.tsx +0 -77
  909. package/src/components/stream/overlays/built-in/ViewerCountWidget.tsx +0 -46
  910. package/src/components/stream/overlays/built-in/index.ts +0 -13
  911. package/src/components/stream/overlays/registry.ts +0 -22
  912. package/src/components/stream/overlays/types.ts +0 -90
  913. package/src/components/stream/overlays/useOverlayLayout.ts +0 -218
  914. package/src/components/trajectory-format.ts +0 -50
  915. package/src/components/ui-badges.tsx +0 -109
  916. package/src/components/ui-switch.tsx +0 -57
  917. package/src/components/vector-browser-three.ts +0 -29
  918. package/src/config/branding.ts +0 -67
  919. package/src/config/config-catalog.ts +0 -1092
  920. package/src/config/config-field.tsx +0 -1924
  921. package/src/config/config-renderer.tsx +0 -734
  922. package/src/config/index.ts +0 -12
  923. package/src/config/ui-renderer.tsx +0 -1751
  924. package/src/config/ui-spec.ts +0 -256
  925. package/src/events/index.ts +0 -96
  926. package/src/hooks/useBugReport.tsx +0 -43
  927. package/src/hooks/useCanvasWindow.ts +0 -372
  928. package/src/hooks/useChatAvatarVoice.ts +0 -111
  929. package/src/hooks/useClickOutside.ts +0 -31
  930. package/src/hooks/useContextMenu.ts +0 -127
  931. package/src/hooks/useKeyboardShortcuts.ts +0 -86
  932. package/src/hooks/useLifoSync.ts +0 -143
  933. package/src/hooks/useMemoryMonitor.ts +0 -334
  934. package/src/hooks/useMiladyBar.ts +0 -594
  935. package/src/hooks/useRenderGuard.ts +0 -43
  936. package/src/hooks/useRetakeCapture.ts +0 -68
  937. package/src/hooks/useStreamPopoutNavigation.ts +0 -27
  938. package/src/hooks/useTimeout.ts +0 -37
  939. package/src/hooks/useVoiceChat.ts +0 -1442
  940. package/src/hooks/useWhatsAppPairing.ts +0 -123
  941. package/src/i18n/index.ts +0 -76
  942. package/src/i18n/locales/en.json +0 -1195
  943. package/src/i18n/locales/es.json +0 -1195
  944. package/src/i18n/locales/ko.json +0 -1195
  945. package/src/i18n/locales/pt.json +0 -1195
  946. package/src/i18n/locales/zh-CN.json +0 -1195
  947. package/src/i18n/messages.ts +0 -21
  948. package/src/navigation/index.ts +0 -286
  949. package/src/navigation.test.ts +0 -189
  950. package/src/onboarding-config.test.ts +0 -104
  951. package/src/onboarding-config.ts +0 -122
  952. package/src/platform/browser-launch.test.ts +0 -94
  953. package/src/platform/browser-launch.ts +0 -149
  954. package/src/platform/index.ts +0 -58
  955. package/src/platform/init.ts +0 -238
  956. package/src/platform/lifo.ts +0 -225
  957. package/src/providers/index.ts +0 -108
  958. package/src/shell-params.test.ts +0 -48
  959. package/src/shell-params.ts +0 -36
  960. package/src/state/AppContext.tsx +0 -6415
  961. package/src/state/internal.ts +0 -91
  962. package/src/state/onboarding-resume.test.ts +0 -135
  963. package/src/state/onboarding-resume.ts +0 -263
  964. package/src/state/parsers.test.ts +0 -124
  965. package/src/state/parsers.ts +0 -309
  966. package/src/state/persistence.ts +0 -379
  967. package/src/state/shell-routing.ts +0 -39
  968. package/src/state/types.ts +0 -724
  969. package/src/state/ui-preferences.ts +0 -3
  970. package/src/state/useApp.ts +0 -23
  971. package/src/state/vrm.ts +0 -108
  972. package/src/styles/anime.css +0 -6324
  973. package/src/styles/onboarding-game.css +0 -976
  974. package/src/types/index.ts +0 -715
  975. package/src/types/react-test-renderer.d.ts +0 -45
  976. package/src/utils/asset-url.ts +0 -110
  977. package/src/utils/assistant-text.ts +0 -172
  978. package/src/utils/clipboard.ts +0 -41
  979. package/src/utils/desktop-dialogs.ts +0 -80
  980. package/src/utils/eliza-globals.ts +0 -44
  981. package/src/utils/number-parsing.ts +0 -125
  982. package/src/utils/openExternalUrl.ts +0 -20
  983. package/src/utils/spoken-text.ts +0 -65
  984. package/src/utils/streaming-text.ts +0 -120
  985. package/src/voice/types.ts +0 -197
  986. package/src/wallet-rpc.ts +0 -176
  987. package/test/app/AppContext.pty-sessions.test.tsx +0 -143
  988. package/test/app/MessageContent.test.tsx +0 -366
  989. package/test/app/PermissionsOnboarding.test.tsx +0 -358
  990. package/test/app/PermissionsSection.test.tsx +0 -575
  991. package/test/app/advanced-trajectory-fine-tuning.e2e.test.ts +0 -396
  992. package/test/app/agent-activity-box.test.tsx +0 -132
  993. package/test/app/agent-transfer-lock.test.ts +0 -279
  994. package/test/app/api-client-electrobun-fallback.test.ts +0 -139
  995. package/test/app/api-client-electron-fallback.test.ts +0 -139
  996. package/test/app/api-client-timeout.test.ts +0 -75
  997. package/test/app/api-client-ws.test.ts +0 -98
  998. package/test/app/api-client.ws-max-reconnect.test.ts +0 -139
  999. package/test/app/api-client.ws-reconnect.test.ts +0 -157
  1000. package/test/app/app-context-autonomy-events.test.ts +0 -559
  1001. package/test/app/apps-page-view.test.ts +0 -114
  1002. package/test/app/apps-view.test.ts +0 -768
  1003. package/test/app/autonomous-workflows.e2e.test.ts +0 -765
  1004. package/test/app/autonomy-events.test.ts +0 -150
  1005. package/test/app/avatar-selector.test.tsx +0 -52
  1006. package/test/app/bsc-trade-panel.test.tsx +0 -134
  1007. package/test/app/bug-report-modal.test.tsx +0 -353
  1008. package/test/app/character-action-bar-visibility.test.ts +0 -70
  1009. package/test/app/character-customization.e2e.test.ts +0 -1384
  1010. package/test/app/character-save-journey.test.ts +0 -1245
  1011. package/test/app/chat-advanced-features.e2e.test.ts +0 -706
  1012. package/test/app/chat-composer.test.tsx +0 -181
  1013. package/test/app/chat-journey.test.ts +0 -1075
  1014. package/test/app/chat-language-header.test.ts +0 -64
  1015. package/test/app/chat-message.test.tsx +0 -222
  1016. package/test/app/chat-modal-view.test.tsx +0 -191
  1017. package/test/app/chat-routine-filter.test.ts +0 -96
  1018. package/test/app/chat-send-lock.test.ts +0 -1465
  1019. package/test/app/chat-stream-api-client.test.tsx +0 -390
  1020. package/test/app/chat-view-game-modal.test.tsx +0 -661
  1021. package/test/app/chat-view.test.tsx +0 -877
  1022. package/test/app/cloud-api.e2e.test.ts +0 -258
  1023. package/test/app/cloud-login-flow.e2e.test.ts +0 -494
  1024. package/test/app/cloud-login-lock.test.ts +0 -416
  1025. package/test/app/command-palette.test.tsx +0 -184
  1026. package/test/app/command-registry.test.ts +0 -75
  1027. package/test/app/companion-greeting-wave.test.tsx +0 -431
  1028. package/test/app/companion-scene-host.test.tsx +0 -85
  1029. package/test/app/companion-stale-conversation.test.tsx +0 -447
  1030. package/test/app/companion-view.test.tsx +0 -690
  1031. package/test/app/confirm-delete-control.test.ts +0 -79
  1032. package/test/app/confirm-modal.test.tsx +0 -219
  1033. package/test/app/connection-mode-persistence.test.ts +0 -411
  1034. package/test/app/connectors-ui.e2e.test.ts +0 -508
  1035. package/test/app/conversations-sidebar-game-modal.test.tsx +0 -265
  1036. package/test/app/conversations-sidebar.test.tsx +0 -185
  1037. package/test/app/custom-actions-smoke.test.ts +0 -387
  1038. package/test/app/custom-avatar-api-client.test.ts +0 -207
  1039. package/test/app/desktop-utils.test.ts +0 -145
  1040. package/test/app/electrobun-rpc-bridge.test.ts +0 -83
  1041. package/test/app/events.test.ts +0 -88
  1042. package/test/app/export-import-flows.e2e.test.ts +0 -700
  1043. package/test/app/fine-tuning-view.test.ts +0 -471
  1044. package/test/app/game-view-auth-session.test.tsx +0 -187
  1045. package/test/app/game-view.test.ts +0 -444
  1046. package/test/app/global-emote-overlay.test.tsx +0 -106
  1047. package/test/app/header-status.test.tsx +0 -149
  1048. package/test/app/i18n.test.ts +0 -152
  1049. package/test/app/inventory-bsc-view.test.ts +0 -940
  1050. package/test/app/knowledge-ui.e2e.test.ts +0 -762
  1051. package/test/app/knowledge-upload-helpers.test.ts +0 -124
  1052. package/test/app/lifecycle-lock.test.ts +0 -267
  1053. package/test/app/lifo-popout-utils.test.ts +0 -208
  1054. package/test/app/lifo-safe-endpoint.test.ts +0 -34
  1055. package/test/app/loading-screen.test.tsx +0 -45
  1056. package/test/app/memory-monitor.test.ts +0 -331
  1057. package/test/app/milady-bar-regression.test.tsx +0 -519
  1058. package/test/app/milady-bar-settings.test.tsx +0 -1056
  1059. package/test/app/milady-bar.test.tsx +0 -583
  1060. package/test/app/navigation.test.tsx +0 -22
  1061. package/test/app/onboarding-e2e-journey.test.ts +0 -1409
  1062. package/test/app/onboarding-finish-lock.test.ts +0 -676
  1063. package/test/app/onboarding-language.test.tsx +0 -160
  1064. package/test/app/onboarding-steps.test.tsx +0 -375
  1065. package/test/app/open-external-url.test.ts +0 -65
  1066. package/test/app/pages-navigation-smoke.e2e.test.ts +0 -646
  1067. package/test/app/pairing-lock.test.ts +0 -260
  1068. package/test/app/pairing-view.test.tsx +0 -74
  1069. package/test/app/permissions-section.test.ts +0 -432
  1070. package/test/app/plugin-bridge.test.ts +0 -109
  1071. package/test/app/plugins-ui.e2e.test.ts +0 -605
  1072. package/test/app/plugins-view-game-modal.test.tsx +0 -686
  1073. package/test/app/plugins-view-toggle-restart.test.ts +0 -129
  1074. package/test/app/provider-dropdown-default.test.tsx +0 -300
  1075. package/test/app/restart-banner.test.tsx +0 -205
  1076. package/test/app/retake-capture.test.ts +0 -84
  1077. package/test/app/sandbox-api-client.test.ts +0 -108
  1078. package/test/app/save-command-modal.test.tsx +0 -109
  1079. package/test/app/secrets-view.test.tsx +0 -92
  1080. package/test/app/settings-control-styles.test.tsx +0 -142
  1081. package/test/app/settings-reset.e2e.test.ts +0 -726
  1082. package/test/app/settings-sections.e2e.test.ts +0 -614
  1083. package/test/app/shared-format.test.ts +0 -44
  1084. package/test/app/shared-switch.test.ts +0 -69
  1085. package/test/app/shell-mode-switching.e2e.test.ts +0 -841
  1086. package/test/app/shell-mode-tab-memory.test.tsx +0 -58
  1087. package/test/app/shell-overlays.test.tsx +0 -50
  1088. package/test/app/shortcuts-overlay.test.tsx +0 -111
  1089. package/test/app/sse-interruption.test.ts +0 -122
  1090. package/test/app/startup-asset-missing.e2e.test.ts +0 -126
  1091. package/test/app/startup-backend-missing.e2e.test.ts +0 -126
  1092. package/test/app/startup-chat.e2e.test.ts +0 -323
  1093. package/test/app/startup-conversation-restore.test.tsx +0 -381
  1094. package/test/app/startup-failure-view.test.tsx +0 -103
  1095. package/test/app/startup-onboarding.e2e.test.ts +0 -712
  1096. package/test/app/startup-timeout.test.tsx +0 -80
  1097. package/test/app/startup-token-401.e2e.test.ts +0 -103
  1098. package/test/app/stream-helpers.test.ts +0 -46
  1099. package/test/app/stream-popout-navigation.test.tsx +0 -41
  1100. package/test/app/stream-status-bar.test.tsx +0 -89
  1101. package/test/app/theme-toggle.test.tsx +0 -40
  1102. package/test/app/training-api-client.test.ts +0 -128
  1103. package/test/app/trajectories-view.test.tsx +0 -220
  1104. package/test/app/triggers-api-client.test.ts +0 -77
  1105. package/test/app/triggers-navigation.test.ts +0 -113
  1106. package/test/app/triggers-view.e2e.test.ts +0 -675
  1107. package/test/app/update-channel-lock.test.ts +0 -259
  1108. package/test/app/vector-browser.async-cleanup.test.tsx +0 -367
  1109. package/test/app/vector-browser.e2e.test.ts +0 -653
  1110. package/test/app/vrm-stage.test.tsx +0 -351
  1111. package/test/app/vrm-viewer.test.tsx +0 -298
  1112. package/test/app/wallet-api-save-lock.test.ts +0 -299
  1113. package/test/app/wallet-hooks.test.ts +0 -405
  1114. package/test/app/wallet-ui-flows.e2e.test.ts +0 -556
  1115. package/test/avatar/asset-url.test.ts +0 -90
  1116. package/test/avatar/avatar-selector.test.ts +0 -173
  1117. package/test/avatar/mixamo-vrm-rig-map.test.ts +0 -111
  1118. package/test/avatar/voice-chat-streaming-text.test.ts +0 -96
  1119. package/test/avatar/voice-chat.test.ts +0 -391
  1120. package/test/browser-extension/README.md +0 -138
  1121. package/test/browser-extension/test-harness.ts +0 -499
  1122. package/test/capacitor-plugins.e2e.test.ts +0 -168
  1123. package/test/test-types.ts +0 -5
  1124. package/test/ui/command-palette-commands.test.ts +0 -57
  1125. package/test/ui/ui-renderer.test.ts +0 -39
  1126. package/test/utils/assistant-text.test.ts +0 -68
  1127. package/test/utils/eliza-globals.test.ts +0 -59
  1128. package/test/utils/package-exports.test.ts +0 -70
  1129. package/test/utils/streaming-text.test.ts +0 -89
  1130. package/tsconfig.build.json +0 -19
  1131. package/tsconfig.json +0 -20
  1132. package/tsconfig.typecheck.json +0 -12
  1133. /package/{src/api/index.ts → api/index.js} +0 -0
  1134. /package/{src/bridge/index.ts → bridge/index.js} +0 -0
  1135. /package/{src/components/TriggersView.tsx → components/TriggersView.js} +0 -0
  1136. /package/{src/hooks/index.ts → hooks/index.js} +0 -0
  1137. /package/{src/index.ts → index.js} +0 -0
  1138. /package/{src/state/index.ts → state/index.js} +0 -0
  1139. /package/{src/styles → styles}/base.css +0 -0
  1140. /package/{src/styles → styles}/styles.css +0 -0
  1141. /package/{src/styles → styles}/xterm.css +0 -0
  1142. /package/{src/utils/index.ts → utils/index.js} +0 -0
  1143. /package/{src/voice/index.ts → voice/index.js} +0 -0
@@ -0,0 +1,815 @@
1
+ import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from "react/jsx-runtime";
2
+ /**
3
+ * ui-renderer.tsx — General-purpose json-render declarative UI renderer.
4
+ *
5
+ * Renders a UiSpec tree into React components. Supports:
6
+ * - 35+ component types (layout, typography, form, data, feedback, nav, viz, interaction)
7
+ * - State binding via statePath
8
+ * - Dynamic values via $path references
9
+ * - Conditional props via $cond expressions
10
+ * - List rendering via repeat config
11
+ * - Event bindings via on.press / on.change
12
+ */
13
+ import React, { createContext, useCallback, useContext, useMemo, useState, } from "react";
14
+ import { useApp } from "../state";
15
+ import { confirmDesktopAction, resolveAppAssetUrl } from "../utils";
16
+ import { getByPath, setByPath } from "./config-catalog";
17
+ const UiContext = createContext(null);
18
+ const BLOCKED_LINK_PROTOCOLS = new Set([
19
+ "javascript",
20
+ "data",
21
+ "vbscript",
22
+ "file",
23
+ ]);
24
+ function useUiCtx() {
25
+ const ctx = useContext(UiContext);
26
+ if (!ctx)
27
+ throw new Error("UiRenderer context missing");
28
+ return ctx;
29
+ }
30
+ // ── Dynamic value resolution ────────────────────────────────────────
31
+ function resolveProp(value, ctx) {
32
+ if (value == null)
33
+ return value;
34
+ // $data.path string prefix (simpler syntax for AI)
35
+ if (typeof value === "string" && value.startsWith("$data.")) {
36
+ const path = value.slice(6); // strip "$data."
37
+ if (path.startsWith("$item/") && ctx.repeatItem) {
38
+ return ctx.repeatItem[path.slice(6)];
39
+ }
40
+ return getByPath(ctx.state, path);
41
+ }
42
+ // $path reference
43
+ if (typeof value === "object" &&
44
+ "$path" in value) {
45
+ const path = value.$path;
46
+ if (path.startsWith("$item/") && ctx.repeatItem) {
47
+ return ctx.repeatItem[path.slice(6)];
48
+ }
49
+ return getByPath(ctx.state, path);
50
+ }
51
+ // $cond expression
52
+ if (typeof value === "object" &&
53
+ "$cond" in value) {
54
+ const expr = value;
55
+ const cond = expr.$cond;
56
+ let result = false;
57
+ if (cond.eq) {
58
+ const [a, b] = cond.eq.map((v) => resolveProp(v, ctx));
59
+ result = a === b;
60
+ }
61
+ else if (cond.neq) {
62
+ const [a, b] = cond.neq.map((v) => resolveProp(v, ctx));
63
+ result = a !== b;
64
+ }
65
+ else if (cond.gt) {
66
+ const [a, b] = cond.gt.map((v) => resolveProp(v, ctx));
67
+ result = Number(a) > Number(b);
68
+ }
69
+ else if (cond.lt) {
70
+ const [a, b] = cond.lt.map((v) => resolveProp(v, ctx));
71
+ result = Number(a) < Number(b);
72
+ }
73
+ else if (cond.truthy) {
74
+ result = !!resolveProp(cond.truthy, ctx);
75
+ }
76
+ else if (cond.falsy) {
77
+ result = !resolveProp(cond.falsy, ctx);
78
+ }
79
+ else if (cond.path) {
80
+ result = !!getByPath(ctx.state, cond.path);
81
+ }
82
+ return result ? resolveProp(expr.$then, ctx) : resolveProp(expr.$else, ctx);
83
+ }
84
+ // Object with path references
85
+ if (typeof value === "object" &&
86
+ value !== null &&
87
+ "path" in value) {
88
+ const p = value.path;
89
+ if (p.startsWith("$item/") && ctx.repeatItem) {
90
+ return ctx.repeatItem[p.slice(6)];
91
+ }
92
+ return getByPath(ctx.state, p);
93
+ }
94
+ return value;
95
+ }
96
+ function resolveProps(props, ctx) {
97
+ const resolved = {};
98
+ for (const [k, v] of Object.entries(props)) {
99
+ resolved[k] = resolveProp(v, ctx);
100
+ }
101
+ return resolved;
102
+ }
103
+ // ── Visibility evaluation ────────────────────────────────────────────
104
+ export function evaluateUiVisibility(condition, state, auth) {
105
+ if (!condition)
106
+ return true;
107
+ // Path-based
108
+ if ("path" in condition && "operator" in condition) {
109
+ const val = getByPath(state, condition.path);
110
+ const target = condition.value;
111
+ switch (condition.operator) {
112
+ case "eq":
113
+ return val === target;
114
+ case "ne":
115
+ return val !== target;
116
+ case "gt":
117
+ return Number(val) > Number(target);
118
+ case "gte":
119
+ return Number(val) >= Number(target);
120
+ case "lt":
121
+ return Number(val) < Number(target);
122
+ case "lte":
123
+ return Number(val) <= Number(target);
124
+ default:
125
+ return true;
126
+ }
127
+ }
128
+ // Auth-based
129
+ if ("auth" in condition) {
130
+ if (!auth)
131
+ return false;
132
+ switch (condition.auth) {
133
+ case "signedIn":
134
+ return auth.isSignedIn;
135
+ case "signedOut":
136
+ return !auth.isSignedIn;
137
+ case "admin":
138
+ return auth.roles?.includes("admin") ?? false;
139
+ default:
140
+ return auth.roles?.includes(condition.auth) ?? false;
141
+ }
142
+ }
143
+ // Logic combinators
144
+ if ("and" in condition)
145
+ return condition.and.every((c) => evaluateUiVisibility(c, state, auth));
146
+ if ("or" in condition)
147
+ return condition.or.some((c) => evaluateUiVisibility(c, state, auth));
148
+ if ("not" in condition)
149
+ return !evaluateUiVisibility(condition.not, state, auth);
150
+ return true;
151
+ }
152
+ export function sanitizeLinkHref(href) {
153
+ // Strip ASCII control chars (tab, LF, CR) that browsers silently remove
154
+ // during URL parsing, preventing bypass attacks like "java\nscript:alert(1)".
155
+ const raw = String(href ?? "#")
156
+ .trim()
157
+ .replace(/[\t\n\r]/g, "");
158
+ if (!raw)
159
+ return "#";
160
+ // Keep relative/hash links unchanged.
161
+ if (raw.startsWith("#") ||
162
+ raw.startsWith("/") ||
163
+ raw.startsWith("./") ||
164
+ raw.startsWith("../") ||
165
+ raw.startsWith("?")) {
166
+ return raw;
167
+ }
168
+ const match = /^([a-zA-Z][a-zA-Z\d+.-]*):/.exec(raw);
169
+ if (!match)
170
+ return raw;
171
+ const protocol = match[1].toLowerCase();
172
+ if (BLOCKED_LINK_PROTOCOLS.has(protocol))
173
+ return "#";
174
+ return raw;
175
+ }
176
+ // ── Built-in validators ─────────────────────────────────────────────
177
+ const BUILTIN_VALIDATORS = {
178
+ required: (v) => v != null && v !== "",
179
+ email: (v) => typeof v === "string" && /^[^\s@]+@[^\s@]+\.[^\s@]+$/.test(v),
180
+ minLength: (v, args) => typeof v === "string" && v.length >= Number(args?.length ?? 0),
181
+ maxLength: (v, args) => typeof v === "string" && v.length <= Number(args?.length ?? Infinity),
182
+ pattern: (v, args) => {
183
+ if (typeof v !== "string" || !args?.pattern)
184
+ return true;
185
+ try {
186
+ return new RegExp(String(args.pattern)).test(v);
187
+ }
188
+ catch {
189
+ return true;
190
+ }
191
+ },
192
+ min: (v, args) => Number(v) >= Number(args?.value ?? -Infinity),
193
+ max: (v, args) => Number(v) <= Number(args?.value ?? Infinity),
194
+ };
195
+ // ── Validation runner ───────────────────────────────────────────────
196
+ export function runValidation(checks, value, customValidators) {
197
+ const errors = [];
198
+ for (const check of checks) {
199
+ const fn = BUILTIN_VALIDATORS[check.fn] ?? customValidators?.[check.fn];
200
+ if (fn) {
201
+ const result = fn(value, check.args);
202
+ // Handle sync validators only (async handled separately)
203
+ if (result === false)
204
+ errors.push(check.message);
205
+ }
206
+ }
207
+ return errors;
208
+ }
209
+ // ── State helpers ───────────────────────────────────────────────────
210
+ function useStatePath(statePath, ctx) {
211
+ const value = statePath ? getByPath(ctx.state, statePath) : undefined;
212
+ const setValue = useCallback((v) => {
213
+ if (statePath)
214
+ ctx.setState(statePath, v);
215
+ }, [statePath, ctx]);
216
+ return [value, setValue];
217
+ }
218
+ // ── Fire event action ───────────────────────────────────────────────
219
+ function fireEvent(action, ctx) {
220
+ if (!action)
221
+ return;
222
+ const execute = () => {
223
+ if (action.action === "setState" && action.params) {
224
+ const p = action.params;
225
+ ctx.setState(p.path, p.value);
226
+ if (action.onSuccess && ctx.onAction) {
227
+ ctx.onAction(action.onSuccess.action, action.onSuccess.params);
228
+ }
229
+ }
230
+ else if (ctx.onAction) {
231
+ try {
232
+ ctx.onAction(action.action, action.params);
233
+ if (action.onSuccess)
234
+ ctx.onAction(action.onSuccess.action, action.onSuccess.params);
235
+ }
236
+ catch {
237
+ if (action.onError && ctx.onAction)
238
+ ctx.onAction(action.onError.action, action.onError.params);
239
+ }
240
+ }
241
+ };
242
+ void (async () => {
243
+ if (action.confirm) {
244
+ const ok = await confirmDesktopAction({
245
+ title: action.confirm.title,
246
+ message: action.confirm.message ?? "",
247
+ confirmLabel: "Confirm",
248
+ cancelLabel: "Cancel",
249
+ type: "question",
250
+ });
251
+ if (!ok)
252
+ return;
253
+ }
254
+ execute();
255
+ })();
256
+ }
257
+ // ── Gap / size maps ─────────────────────────────────────────────────
258
+ const GAP = {
259
+ none: "gap-0",
260
+ xs: "gap-0.5",
261
+ sm: "gap-1.5",
262
+ md: "gap-3",
263
+ lg: "gap-5",
264
+ xl: "gap-8",
265
+ };
266
+ const ALIGN = {
267
+ start: "items-start",
268
+ center: "items-center",
269
+ end: "items-end",
270
+ stretch: "items-stretch",
271
+ };
272
+ const JUSTIFY = {
273
+ start: "justify-start",
274
+ center: "justify-center",
275
+ end: "justify-end",
276
+ between: "justify-between",
277
+ around: "justify-around",
278
+ };
279
+ // ── Tailwind class constants ────────────────────────────────────────
280
+ const INPUT_CLS = "w-full px-2 py-[5px] border border-[var(--border)] bg-[var(--card)] text-xs font-[var(--mono)] transition-colors focus:border-[var(--accent)] focus:outline-none box-border h-[30px]";
281
+ // ── Layout ──────────────────────────────────────────────────────────
282
+ const StackComponent = (props, children) => {
283
+ const dir = props.direction === "horizontal" ? "flex-row" : "flex-col";
284
+ const gap = GAP[String(props.gap ?? "md")] ?? "gap-3";
285
+ const align = ALIGN[String(props.align ?? "stretch")] ?? "";
286
+ const justify = JUSTIFY[String(props.justify ?? "start")] ?? "";
287
+ return (_jsx("div", { className: `flex ${dir} ${gap} ${align} ${justify}`, children: children }));
288
+ };
289
+ const GridComponent = (props, children) => {
290
+ const cols = Number(props.columns ?? 2);
291
+ const gap = GAP[String(props.gap ?? "md")] ?? "gap-3";
292
+ return (_jsx("div", { className: `grid ${gap}`, style: { gridTemplateColumns: `repeat(${cols}, 1fr)` }, children: children }));
293
+ };
294
+ const CardComponent = (props, children) => {
295
+ const maxW = props.maxWidth === "full" ? "max-w-full" : "";
296
+ return (_jsxs("div", { className: `border border-[var(--border)] bg-[var(--card)] p-4 ${maxW}`, children: [props.title ? (_jsx("div", { className: "font-bold text-sm mb-0.5", children: String(props.title) })) : null, props.description ? (_jsx("div", { className: "text-xs text-[var(--muted)] mb-3", children: String(props.description) })) : null, children] }));
297
+ };
298
+ const SeparatorComponent = (props) => {
299
+ const isVert = props.orientation === "vertical";
300
+ return isVert ? (_jsx("div", { className: "w-px bg-[var(--border)] self-stretch" })) : (_jsx("hr", { className: "border-t border-[var(--border)] my-2" }));
301
+ };
302
+ // ── Typography ──────────────────────────────────────────────────────
303
+ const HeadingComponent = (props) => {
304
+ const text = String(props.text ?? "");
305
+ const level = String(props.level ?? "h2");
306
+ const cls = level === "h1"
307
+ ? "text-xl font-bold"
308
+ : level === "h3"
309
+ ? "text-sm font-bold"
310
+ : "text-base font-bold";
311
+ return _jsx("div", { className: cls, children: text });
312
+ };
313
+ const TextComponent = (props) => {
314
+ const text = String(props.text ?? "");
315
+ const variant = String(props.variant ?? "body");
316
+ const cls = {
317
+ body: "text-sm",
318
+ caption: "text-xs text-[var(--muted)]",
319
+ muted: "text-sm text-[var(--muted)]",
320
+ lead: "text-sm font-medium",
321
+ code: "text-xs font-mono bg-[var(--bg-hover)] px-1.5 py-0.5 border border-[var(--border)]",
322
+ };
323
+ return _jsx("div", { className: cls[variant] ?? "text-sm", children: text });
324
+ };
325
+ // ── Form ────────────────────────────────────────────────────────────
326
+ const InputComponent = (props, _children, ctx, el) => {
327
+ const [value, setValue] = useStatePath(props.statePath, ctx);
328
+ const sp = props.statePath;
329
+ const errors = sp ? ctx.fieldErrors?.[sp] : undefined;
330
+ const validateOn = el.validation?.validateOn ?? "blur";
331
+ const handleChange = (v) => {
332
+ setValue(v);
333
+ if (validateOn === "change" && sp && ctx.validateField)
334
+ ctx.validateField(sp);
335
+ };
336
+ const handleBlur = () => {
337
+ if (validateOn === "blur" && sp && ctx.validateField)
338
+ ctx.validateField(sp);
339
+ };
340
+ return (_jsxs("div", { className: "flex flex-col gap-1", children: [props.label ? (_jsx("span", { className: "text-xs font-semibold", children: String(props.label) })) : null, _jsx("input", { className: `${INPUT_CLS}${errors?.length ? " border-[var(--destructive)]" : ""}`, type: String(props.type ?? "text"), name: String(props.name ?? ""), placeholder: String(props.placeholder ?? ""), value: String(value ?? ""), onChange: (e) => handleChange(e.target.value), onBlur: handleBlur }), errors?.length ? (_jsx("div", { className: "flex flex-col gap-0.5", children: errors.map((err) => (_jsx("span", { className: "text-[10px] text-[var(--destructive)]", children: err }, err))) })) : null] }));
341
+ };
342
+ const TextareaComponent = (props, _children, ctx, el) => {
343
+ const [value, setValue] = useStatePath(props.statePath, ctx);
344
+ const sp = props.statePath;
345
+ const errors = sp ? ctx.fieldErrors?.[sp] : undefined;
346
+ const validateOn = el.validation?.validateOn ?? "blur";
347
+ const handleChange = (v) => {
348
+ setValue(v);
349
+ if (validateOn === "change" && sp && ctx.validateField)
350
+ ctx.validateField(sp);
351
+ };
352
+ const handleBlur = () => {
353
+ if (validateOn === "blur" && sp && ctx.validateField)
354
+ ctx.validateField(sp);
355
+ };
356
+ return (_jsxs("div", { className: "flex flex-col gap-1", children: [props.label ? (_jsx("span", { className: "text-xs font-semibold", children: String(props.label) })) : null, _jsx("textarea", { className: `w-full px-2 py-[5px] border border-[var(--border)] bg-[var(--card)] text-xs font-[var(--mono)] transition-colors focus:border-[var(--accent)] focus:outline-none box-border min-h-[64px] resize-y${errors?.length ? " border-[var(--destructive)]" : ""}`, name: String(props.name ?? ""), placeholder: String(props.placeholder ?? ""), rows: Number(props.rows ?? 3), value: String(value ?? ""), onChange: (e) => handleChange(e.target.value), onBlur: handleBlur }), errors?.length ? (_jsx("div", { className: "flex flex-col gap-0.5", children: errors.map((err) => (_jsx("span", { className: "text-[10px] text-[var(--destructive)]", children: err }, err))) })) : null] }));
357
+ };
358
+ const SelectComponent = (props, _children, ctx, el) => {
359
+ const [value, setValue] = useStatePath(props.statePath, ctx);
360
+ const options = props.options ?? [];
361
+ const sp = props.statePath;
362
+ const errors = sp ? ctx.fieldErrors?.[sp] : undefined;
363
+ const validateOn = el.validation?.validateOn ?? "blur";
364
+ const handleChange = (v) => {
365
+ setValue(v);
366
+ if (validateOn === "change" && sp && ctx.validateField)
367
+ ctx.validateField(sp);
368
+ };
369
+ const handleBlur = () => {
370
+ if (validateOn === "blur" && sp && ctx.validateField)
371
+ ctx.validateField(sp);
372
+ };
373
+ return (_jsxs("div", { className: "flex flex-col gap-1", children: [props.label ? (_jsx("span", { className: "text-xs font-semibold", children: String(props.label) })) : null, _jsxs("select", { className: `${INPUT_CLS} appearance-auto${errors?.length ? " border-[var(--destructive)]" : ""}`, value: String(value ?? ""), onChange: (e) => handleChange(e.target.value), onBlur: handleBlur, children: [props.placeholder ? (_jsx("option", { value: "", children: String(props.placeholder) })) : null, options.map((o) => (_jsx("option", { value: o.value, children: o.label }, o.value)))] }), errors?.length ? (_jsx("div", { className: "flex flex-col gap-0.5", children: errors.map((err) => (_jsx("span", { className: "text-[10px] text-[var(--destructive)]", children: err }, err))) })) : null] }));
374
+ };
375
+ const CheckboxComponent = (props, _children, ctx) => {
376
+ const [value, setValue] = useStatePath(props.statePath, ctx);
377
+ return (_jsxs("span", { className: "flex items-center gap-2 text-xs cursor-pointer", children: [_jsx("input", { type: "checkbox", checked: !!value, onChange: (e) => setValue(e.target.checked) }), _jsx("span", { className: "font-semibold", children: String(props.label ?? "") })] }));
378
+ };
379
+ const RadioComponent = (props, _children, ctx) => {
380
+ const [value, setValue] = useStatePath(props.statePath, ctx);
381
+ const options = props.options ?? [];
382
+ return (_jsxs("div", { className: "flex flex-col gap-1", children: [props.label ? (_jsx("span", { className: "text-xs font-semibold mb-0.5", children: String(props.label) })) : null, options.map((o) => (_jsxs("span", { className: "flex items-center gap-2 text-xs cursor-pointer", children: [_jsx("input", { type: "radio", name: String(props.name ?? ""), value: o.value, checked: value === o.value, onChange: () => setValue(o.value) }), _jsx("span", { children: o.label })] }, o.value)))] }));
383
+ };
384
+ const SwitchComponent = (props, _children, ctx) => {
385
+ const [value, setValue] = useStatePath(props.statePath, ctx);
386
+ const checked = !!value;
387
+ return (_jsxs("span", { className: "flex items-center gap-2 cursor-pointer", children: [_jsx("button", { type: "button", className: `relative w-9 h-[18px] transition-colors ${checked ? "bg-[var(--accent)]" : "bg-[var(--muted)]"}`, onClick: () => setValue(!checked), children: _jsx("div", { className: `absolute top-0.5 w-[14px] h-[14px] bg-white transition-all ${checked ? "left-5" : "left-0.5"}` }) }), _jsx("span", { className: "text-xs font-semibold", children: String(props.label ?? "") })] }));
388
+ };
389
+ const SliderComponent = (props, _children, ctx) => {
390
+ const [value, setValue] = useStatePath(props.statePath, ctx);
391
+ return (_jsxs("div", { className: "flex flex-col gap-1", children: [props.label ? (_jsxs("div", { className: "flex justify-between text-xs", children: [_jsx("span", { className: "font-semibold", children: String(props.label) }), _jsx("span", { className: "text-[var(--muted)]", children: String(value ?? props.min ?? 0) })] })) : null, _jsx("input", { type: "range", min: Number(props.min ?? 0), max: Number(props.max ?? 100), step: Number(props.step ?? 1), value: Number(value ?? props.min ?? 0), onChange: (e) => setValue(Number(e.target.value)), className: "w-full", style: { accentColor: "var(--accent)" } })] }));
392
+ };
393
+ const ToggleComponent = (props, _children, ctx, el) => {
394
+ const [value, setValue] = useStatePath(props.statePath, ctx);
395
+ const pressed = !!value;
396
+ return (_jsx("button", { type: "button", className: `px-3 py-1.5 text-xs border cursor-pointer transition-colors ${pressed
397
+ ? "bg-[var(--accent)] text-[var(--accent-foreground,#1a1f26)] border-[var(--accent)]"
398
+ : "bg-[var(--card)] text-[var(--text)] border-[var(--border)] hover:bg-[var(--bg-hover)]"}`, onClick: () => {
399
+ setValue(!pressed);
400
+ fireEvent(el.on?.press, ctx);
401
+ }, children: String(props.label ?? "Toggle") }));
402
+ };
403
+ const ToggleGroupComponent = (props, _children, ctx) => {
404
+ const [value, setValue] = useStatePath(props.statePath, ctx);
405
+ const items = props.items ?? [];
406
+ const isMultiple = props.type === "multiple";
407
+ const selected = new Set(Array.isArray(value) ? value : []);
408
+ const toggle = (v) => {
409
+ if (isMultiple) {
410
+ const next = new Set(selected);
411
+ if (next.has(v))
412
+ next.delete(v);
413
+ else
414
+ next.add(v);
415
+ setValue([...next]);
416
+ }
417
+ else {
418
+ setValue(v);
419
+ }
420
+ };
421
+ return (_jsx("div", { className: "flex gap-1", children: items.map((item) => {
422
+ const active = isMultiple
423
+ ? selected.has(item.value)
424
+ : value === item.value;
425
+ return (_jsx("button", { type: "button", className: `px-2.5 py-1 text-xs border cursor-pointer transition-colors ${active
426
+ ? "bg-[var(--accent)] text-[var(--accent-foreground,#1a1f26)] border-[var(--accent)]"
427
+ : "bg-[var(--card)] text-[var(--text)] border-[var(--border)] hover:bg-[var(--bg-hover)]"}`, onClick: () => toggle(item.value), children: item.label }, item.value));
428
+ }) }));
429
+ };
430
+ const ButtonGroupComponent = (props, _children, ctx) => {
431
+ const [value, setValue] = useStatePath(props.statePath, ctx);
432
+ const buttons = props.buttons ?? [];
433
+ return (_jsx("div", { className: "flex gap-1", children: buttons.map((btn) => {
434
+ const active = value === btn.value;
435
+ return (_jsx("button", { type: "button", className: `px-3 py-1.5 text-xs border cursor-pointer transition-colors ${active
436
+ ? "bg-[var(--accent)] text-[var(--accent-foreground,#1a1f26)] border-[var(--accent)]"
437
+ : "bg-[var(--card)] text-[var(--text)] border-[var(--border)] hover:bg-[var(--bg-hover)]"}`, onClick: () => setValue(btn.value), children: btn.label }, btn.value));
438
+ }) }));
439
+ };
440
+ // ── Data Display ────────────────────────────────────────────────────
441
+ const TableComponent = (props) => {
442
+ const columns = props.columns ?? [];
443
+ const rows = props.rows ?? [];
444
+ return (_jsxs("div", { className: "overflow-x-auto", children: [props.caption ? (_jsx("div", { className: "text-xs font-semibold mb-1.5", children: String(props.caption) })) : null, _jsxs("table", { className: "w-full text-xs border-collapse", children: [_jsx("thead", { children: _jsx("tr", { children: columns.map((col) => (_jsx("th", { className: "text-left px-2.5 py-1.5 border-b border-[var(--border)] font-semibold text-[var(--muted)]", children: col }, col))) }) }), _jsx("tbody", { children: rows.map((row) => (_jsx("tr", { className: "border-b border-[var(--border)] last:border-b-0", children: row.map((cell) => (_jsx("td", { className: "px-2.5 py-1.5", children: cell }, cell))) }, row.join("|")))) })] })] }));
445
+ };
446
+ const CarouselComponent = (props) => {
447
+ const { t } = useApp();
448
+ const items = props.items ?? [];
449
+ const [current, setCurrent] = useState(0);
450
+ return (_jsxs("div", { className: "relative", children: [_jsx("div", { className: "border border-[var(--border)] bg-[var(--bg-hover)] p-4 min-h-[60px]", children: items[current] && (_jsxs("div", { children: [_jsx("div", { className: "text-xs font-bold", children: items[current].title }), _jsx("div", { className: "text-xs text-[var(--muted)] mt-0.5", children: items[current].description })] })) }), _jsxs("div", { className: "flex justify-center gap-2 mt-2", children: [_jsx("button", { type: "button", className: "text-xs px-2 py-0.5 border border-[var(--border)] bg-[var(--card)] cursor-pointer hover:bg-[var(--bg-hover)]", onClick: () => setCurrent((p) => Math.max(0, p - 1)), disabled: current === 0, children: t("ui-renderer.Larr") }), _jsxs("span", { className: "text-[10px] text-[var(--muted)] self-center", children: [current + 1, " / ", items.length] }), _jsx("button", { type: "button", className: "text-xs px-2 py-0.5 border border-[var(--border)] bg-[var(--card)] cursor-pointer hover:bg-[var(--bg-hover)]", onClick: () => setCurrent((p) => Math.min(items.length - 1, p + 1)), disabled: current === items.length - 1, children: t("ui-renderer.Rarr") })] })] }));
451
+ };
452
+ const BadgeComponent = (props) => {
453
+ const variant = String(props.variant ?? "default");
454
+ const cls = {
455
+ default: "bg-[var(--surface)] text-[var(--text)] border-[var(--border)]",
456
+ success: "bg-[rgba(22,163,106,0.1)] text-[var(--ok)] border-[var(--ok)]",
457
+ warning: "bg-[rgba(243,156,18,0.1)] text-[var(--warn,#f39c12)] border-[var(--warn,#f39c12)]",
458
+ error: "bg-[rgba(231,76,60,0.1)] text-[var(--destructive)] border-[var(--destructive)]",
459
+ info: "bg-[rgba(52,152,219,0.1)] text-[var(--accent)] border-[var(--accent)]",
460
+ };
461
+ return (_jsx("span", { className: `inline-block text-[10px] font-medium px-2 py-0.5 border ${cls[variant] ?? cls.default}`, children: String(props.text ?? "") }));
462
+ };
463
+ const AvatarComponent = (props) => {
464
+ const name = String(props.name ?? "?");
465
+ const size = props.size === "lg"
466
+ ? "w-10 h-10 text-sm"
467
+ : props.size === "sm"
468
+ ? "w-6 h-6 text-[10px]"
469
+ : "w-8 h-8 text-xs";
470
+ const initials = name
471
+ .split(" ")
472
+ .map((w) => w[0])
473
+ .join("")
474
+ .slice(0, 2)
475
+ .toUpperCase();
476
+ return (_jsx("div", { className: `${size} rounded-full bg-[var(--accent)] text-[var(--accent-foreground,#1a1f26)] flex items-center justify-center font-bold shrink-0`, children: initials }));
477
+ };
478
+ const ImageComponent = (props) => {
479
+ const src = props.src;
480
+ const resolvedSrc = src ? resolveAppAssetUrl(src) : undefined;
481
+ const alt = String(props.alt ?? "");
482
+ const w = props.width ? `${props.width}px` : "auto";
483
+ const h = props.height ? `${props.height}px` : "auto";
484
+ return resolvedSrc ? (_jsx("img", { src: resolvedSrc, alt: alt, style: { width: w, height: h }, className: "object-cover border border-[var(--border)]" })) : (_jsx("div", { className: "bg-[var(--bg-hover)] border border-[var(--border)] flex items-center justify-center text-xs text-[var(--muted)]", style: { width: w, height: h }, children: alt || "Image" }));
485
+ };
486
+ // ── Feedback ────────────────────────────────────────────────────────
487
+ const AlertComponent = (props) => {
488
+ const type = String(props.type ?? "info");
489
+ const borderCls = {
490
+ info: "border-[var(--accent)]",
491
+ success: "border-[var(--ok)]",
492
+ warning: "border-[var(--warn,#f39c12)]",
493
+ error: "border-[var(--destructive)]",
494
+ };
495
+ const textCls = {
496
+ info: "text-[var(--accent)]",
497
+ success: "text-[var(--ok)]",
498
+ warning: "text-[var(--warn,#f39c12)]",
499
+ error: "text-[var(--destructive)]",
500
+ };
501
+ return (_jsxs("div", { className: `border-l-[3px] ${borderCls[type] ?? ""} bg-[var(--bg-hover)] px-3 py-2`, children: [props.title ? (_jsx("div", { className: `text-xs font-bold ${textCls[type] ?? ""}`, children: String(props.title) })) : null, props.message ? (_jsx("div", { className: "text-xs text-[var(--text)] mt-0.5", children: String(props.message) })) : null] }));
502
+ };
503
+ const ProgressComponent = (props) => {
504
+ const value = Number(props.value ?? 0);
505
+ const max = Number(props.max ?? 100);
506
+ const pct = Math.min(100, Math.max(0, (value / max) * 100));
507
+ return (_jsxs("div", { className: "flex flex-col gap-1", children: [props.label ? (_jsxs("div", { className: "flex justify-between text-xs", children: [_jsx("span", { className: "font-semibold", children: String(props.label) }), _jsxs("span", { className: "text-[var(--muted)]", children: [Math.round(pct), "%"] })] })) : null, _jsx("div", { className: "w-full h-2 bg-[var(--bg-hover)] border border-[var(--border)] overflow-hidden", children: _jsx("div", { className: "h-full bg-[var(--accent)] transition-[width] duration-300", style: { width: `${pct}%` } }) })] }));
508
+ };
509
+ const RatingComponent = (props) => {
510
+ const value = Number(props.value ?? 0);
511
+ const max = Number(props.max ?? 5);
512
+ return (_jsxs("div", { className: "flex flex-col gap-1", children: [props.label ? (_jsx("div", { className: "text-xs font-semibold", children: String(props.label) })) : null, _jsx("div", { className: "flex gap-0.5", children: Array.from({ length: max }, (_, i) => i + 1).map((starValue) => (_jsx("span", { className: `text-sm ${starValue <= value ? "text-[var(--warn,#f39c12)]" : "text-[var(--muted)] opacity-30"}`, children: "\u2605" }, starValue))) })] }));
513
+ };
514
+ const SkeletonComponent = (props) => {
515
+ const w = props.width ? String(props.width) : "100%";
516
+ const h = props.height ? String(props.height) : "20px";
517
+ const rounded = props.rounded ? "rounded" : "";
518
+ return (_jsx("div", { className: `bg-[var(--bg-hover)] animate-pulse ${rounded}`, style: { width: w, height: h } }));
519
+ };
520
+ const SpinnerComponent = (props) => {
521
+ const size = props.size === "lg"
522
+ ? "w-8 h-8"
523
+ : props.size === "sm"
524
+ ? "w-4 h-4"
525
+ : "w-6 h-6";
526
+ return (_jsxs("div", { className: "flex items-center gap-2", children: [_jsx("div", { className: `${size} border-2 border-[var(--border)] border-t-[var(--accent)] rounded-full animate-spin` }), props.label ? (_jsx("span", { className: "text-xs text-[var(--muted)]", children: String(props.label) })) : null] }));
527
+ };
528
+ // ── Navigation ──────────────────────────────────────────────────────
529
+ const ButtonComponent = (props, _children, ctx, el) => {
530
+ const variant = String(props.variant ?? "primary");
531
+ const cls = {
532
+ primary: "bg-[var(--accent)] text-[var(--accent-foreground,#1a1f26)] border-[var(--accent)] hover:opacity-90",
533
+ secondary: "bg-[var(--card)] text-[var(--text)] border-[var(--border)] hover:bg-[var(--bg-hover)]",
534
+ danger: "bg-[var(--destructive)] text-white border-[var(--destructive)] hover:opacity-90",
535
+ ghost: "bg-transparent text-[var(--text)] border-transparent hover:bg-[var(--bg-hover)]",
536
+ };
537
+ return (_jsx("button", { type: "button", className: `px-3 py-1.5 text-xs font-medium border cursor-pointer transition-colors ${cls[variant] ?? cls.primary}`, disabled: !!props.disabled, onClick: () => fireEvent(el.on?.press, ctx), children: String(props.label ?? "Button") }));
538
+ };
539
+ const LinkComponent = (props, _children, ctx, el) => {
540
+ const safeHref = sanitizeLinkHref(props.href);
541
+ return (_jsx("a", { href: safeHref, className: "text-xs text-[var(--accent)] underline hover:opacity-80", target: props.external ? "_blank" : undefined, rel: props.external ? "noopener noreferrer" : undefined, onClick: (e) => {
542
+ if (el.on?.press) {
543
+ e.preventDefault();
544
+ fireEvent(el.on.press, ctx);
545
+ }
546
+ }, children: String(props.label ?? props.href ?? "Link") }));
547
+ };
548
+ const DropdownMenuComponent = (props, _children, ctx) => {
549
+ const [open, setOpen] = useState(false);
550
+ const items = props.items ?? [];
551
+ return (_jsxs("div", { className: "relative inline-block", children: [_jsxs("button", { type: "button", className: "px-3 py-1.5 text-xs border border-[var(--border)] bg-[var(--card)] cursor-pointer hover:bg-[var(--bg-hover)]", onClick: () => setOpen(!open), children: [String(props.label ?? "Menu"), " \u25BE"] }), open && (_jsx("div", { className: "absolute top-full left-0 mt-1 min-w-[120px] border border-[var(--border)] bg-[var(--card)] shadow-md z-10", children: items.map((item) => (_jsx("button", { type: "button", className: "block w-full text-left px-3 py-1.5 text-xs hover:bg-[var(--bg-hover)] cursor-pointer", onClick: () => {
552
+ setOpen(false);
553
+ if (ctx.onAction)
554
+ ctx.onAction("menuSelect", {
555
+ value: item.value,
556
+ label: item.label,
557
+ });
558
+ }, children: item.label }, item.value))) }))] }));
559
+ };
560
+ const TabsComponent = (props, _children, ctx) => {
561
+ const tabs = props.tabs ??
562
+ [];
563
+ const [value, setValue] = useStatePath(props.statePath, ctx);
564
+ const active = String(value ?? props.defaultValue ?? tabs[0]?.value ?? "");
565
+ const activeTab = tabs.find((t) => t.value === active);
566
+ return (_jsxs("div", { children: [_jsx("div", { className: "flex border-b border-[var(--border)]", children: tabs.map((tab) => (_jsx("button", { type: "button", className: `px-3 py-1.5 text-xs cursor-pointer transition-colors ${tab.value === active
567
+ ? "border-b-2 border-[var(--accent)] text-[var(--accent)] font-semibold"
568
+ : "text-[var(--muted)] hover:text-[var(--text)]"}`, onClick: () => setValue(tab.value), children: tab.label }, tab.value))) }), activeTab && _jsx("div", { className: "py-3 text-xs", children: activeTab.content })] }));
569
+ };
570
+ const PaginationComponent = (props, _children, ctx) => {
571
+ const total = Number(props.totalPages ?? 1);
572
+ const [value, setValue] = useStatePath(props.statePath, ctx);
573
+ const current = Number(value ?? 1);
574
+ return (_jsxs("div", { className: "flex items-center gap-1", children: [_jsx("button", { type: "button", className: "px-2 py-1 text-xs border border-[var(--border)] bg-[var(--card)] cursor-pointer hover:bg-[var(--bg-hover)] disabled:opacity-40", disabled: current <= 1, onClick: () => setValue(current - 1), children: "\u2190" }), Array.from({ length: total }, (_, i) => i + 1).map((page) => (_jsx("button", { type: "button", className: `px-2 py-1 text-xs border cursor-pointer ${page === current
575
+ ? "bg-[var(--accent)] text-[var(--accent-foreground,#1a1f26)] border-[var(--accent)]"
576
+ : "border-[var(--border)] bg-[var(--card)] hover:bg-[var(--bg-hover)]"}`, onClick: () => setValue(page), children: page }, page))), _jsx("button", { type: "button", className: "px-2 py-1 text-xs border border-[var(--border)] bg-[var(--card)] cursor-pointer hover:bg-[var(--bg-hover)] disabled:opacity-40", disabled: current >= total, onClick: () => setValue(current + 1), children: "\u2192" })] }));
577
+ };
578
+ // ── Metric / KPI ────────────────────────────────────────────────────
579
+ const MetricComponent = (props) => {
580
+ const trend = props.trend;
581
+ const trendColor = trend === "up"
582
+ ? "text-green-400"
583
+ : trend === "down"
584
+ ? "text-red-400"
585
+ : "text-[var(--muted)]";
586
+ return (_jsxs("div", { className: "flex flex-col gap-0.5 p-3 rounded-lg border border-[var(--border)] bg-[var(--card)]", children: [_jsx("div", { className: "text-[10px] text-[var(--muted)] uppercase tracking-wider font-medium", children: String(props.label ?? "") }), _jsxs("div", { className: "flex items-baseline gap-1.5", children: [_jsx("span", { className: "text-xl font-semibold text-[var(--txt)]", children: props.value != null ? String(props.value) : "—" }), props.unit != null && (_jsx("span", { className: "text-xs text-[var(--muted)]", children: String(props.unit) }))] }), props.change != null && (_jsx("div", { className: `text-[11px] font-medium ${trendColor}`, children: String(props.change) }))] }));
587
+ };
588
+ // ── Visualization ───────────────────────────────────────────────────
589
+ const BarGraphComponent = (props) => {
590
+ const data = props.data ?? [];
591
+ const maxVal = Math.max(...data.map((d) => d.value), 1);
592
+ return (_jsxs("div", { children: [props.title ? (_jsx("div", { className: "text-xs font-bold mb-2", children: String(props.title) })) : null, _jsx("div", { className: "flex items-end gap-2 h-[100px]", children: data.map((d) => (_jsxs("div", { className: "flex-1 flex flex-col items-center gap-0.5", children: [_jsx("div", { className: "text-[9px] text-[var(--muted)]", children: d.value }), _jsx("div", { className: "w-full bg-[var(--accent)] transition-all duration-300 min-h-[2px]", style: { height: `${(d.value / maxVal) * 80}px` } }), _jsx("div", { className: "text-[9px] text-[var(--muted)] truncate max-w-full", children: d.label })] }, d.label))) })] }));
593
+ };
594
+ const LineGraphComponent = (props) => {
595
+ const data = props.data ?? [];
596
+ const maxVal = Math.max(...data.map((d) => d.value), 1);
597
+ const h = 80;
598
+ const w = 100;
599
+ const points = data.map((d, i) => ({
600
+ x: (i / Math.max(data.length - 1, 1)) * w,
601
+ y: h - (d.value / maxVal) * h,
602
+ }));
603
+ const pathD = points
604
+ .map((p, i) => `${i === 0 ? "M" : "L"} ${p.x} ${p.y}`)
605
+ .join(" ");
606
+ return (_jsxs("div", { children: [props.title ? (_jsx("div", { className: "text-xs font-bold mb-2", children: String(props.title) })) : null, _jsxs("svg", { viewBox: `0 0 ${w} ${h + 20}`, className: "w-full h-[100px]", preserveAspectRatio: "none", children: [_jsx("title", { children: String(props.title ?? "Line graph") }), _jsx("path", { d: pathD, fill: "none", stroke: "var(--accent)", strokeWidth: "2", vectorEffect: "non-scaling-stroke" }), points.map((p) => (_jsx("circle", { cx: p.x, cy: p.y, r: "3", fill: "var(--accent)", vectorEffect: "non-scaling-stroke" }, `${p.x}:${p.y}`))), data.map((d, i) => (_jsx("text", { x: points[i].x, y: h + 14, textAnchor: "middle", fontSize: "8", fill: "var(--muted)", children: d.label }, `${d.label}:${d.value}`)))] })] }));
607
+ };
608
+ // ── Interaction ─────────────────────────────────────────────────────
609
+ const TooltipComponent = (props) => {
610
+ const [show, setShow] = useState(false);
611
+ return (_jsxs("button", { type: "button", className: "relative inline-block", onMouseEnter: () => setShow(true), onMouseLeave: () => setShow(false), onFocus: () => setShow(true), onBlur: () => setShow(false), onClick: () => setShow((prev) => !prev), children: [_jsx("span", { className: "text-xs text-[var(--accent)] underline cursor-help", children: String(props.text ?? "Hover") }), show && (_jsx("div", { className: "absolute bottom-full left-1/2 -translate-x-1/2 mb-1 px-2 py-1 text-[10px] bg-[var(--text)] text-[var(--card)] whitespace-nowrap z-10", children: String(props.content ?? "") }))] }));
612
+ };
613
+ const PopoverComponent = (props) => {
614
+ const [open, setOpen] = useState(false);
615
+ return (_jsxs("div", { className: "relative inline-block", children: [_jsx("button", { type: "button", className: "text-xs text-[var(--accent)] underline cursor-pointer", onClick: () => setOpen(!open), children: String(props.trigger ?? "Click") }), open && (_jsxs("div", { className: "absolute top-full left-0 mt-1 p-3 border border-[var(--border)] bg-[var(--card)] shadow-md z-10 min-w-[150px]", children: [_jsx("div", { className: "text-xs", children: String(props.content ?? "") }), _jsx("button", { type: "button", className: "text-[10px] text-[var(--muted)] mt-1 cursor-pointer hover:text-[var(--text)]", onClick: () => setOpen(false), children: "Close" })] }))] }));
616
+ };
617
+ const CollapsibleComponent = (props, children) => {
618
+ const [open, setOpen] = useState(!!props.defaultOpen);
619
+ return (_jsxs("div", { className: "border border-[var(--border)]", children: [_jsxs("button", { type: "button", className: "w-full flex items-center gap-2 px-3 py-2 text-xs font-semibold cursor-pointer hover:bg-[var(--bg-hover)] transition-colors", onClick: () => setOpen(!open), children: [_jsx("span", { className: "text-[10px] transition-transform", style: { transform: open ? "rotate(90deg)" : "none" }, children: "\u25B6" }), String(props.title ?? "Collapsible")] }), open && _jsx("div", { className: "px-3 pb-3", children: children })] }));
620
+ };
621
+ const AccordionComponent = (props) => {
622
+ const items = props.items ?? [];
623
+ const isSingle = props.type === "single";
624
+ const [openSet, setOpenSet] = useState(new Set());
625
+ const toggle = (idx) => {
626
+ setOpenSet((prev) => {
627
+ const next = isSingle ? new Set() : new Set(prev);
628
+ if (prev.has(idx))
629
+ next.delete(idx);
630
+ else
631
+ next.add(idx);
632
+ return next;
633
+ });
634
+ };
635
+ return (_jsx("div", { className: "border border-[var(--border)] divide-y divide-[var(--border)]", children: items.map((item, i) => (_jsxs("div", { children: [_jsxs("button", { type: "button", className: "w-full flex items-center gap-2 px-3 py-2 text-xs font-semibold cursor-pointer hover:bg-[var(--bg-hover)]", onClick: () => toggle(i), children: [_jsx("span", { className: "text-[10px] transition-transform", style: { transform: openSet.has(i) ? "rotate(90deg)" : "none" }, children: "\u25B6" }), item.title] }), openSet.has(i) && (_jsx("div", { className: "px-3 pb-3 text-xs", children: item.content }))] }, `${item.title}:${item.content}`))) }));
636
+ };
637
+ const DialogComponent = (props, children, ctx) => {
638
+ const openPath = props.openPath;
639
+ const isOpen = openPath ? !!getByPath(ctx.state, openPath) : false;
640
+ if (!isOpen)
641
+ return null;
642
+ const close = () => {
643
+ if (openPath)
644
+ ctx.setState(openPath, false);
645
+ };
646
+ return (_jsx("div", { className: "fixed inset-0 z-50 flex items-center justify-center bg-black/50", onClick: (e) => {
647
+ if (e.target === e.currentTarget)
648
+ close();
649
+ }, onKeyDown: (e) => {
650
+ if (e.key === "Escape" || e.key === "Enter" || e.key === " ") {
651
+ e.preventDefault();
652
+ close();
653
+ }
654
+ }, role: "dialog", "aria-modal": "true", children: _jsxs("div", { className: "w-full max-w-md border border-[var(--border)] bg-[var(--card)] p-5 shadow-lg", children: [_jsxs("div", { className: "flex items-center justify-between mb-3", children: [_jsxs("div", { children: [props.title ? (_jsx("div", { className: "font-bold text-sm", children: String(props.title) })) : null, props.description ? (_jsx("div", { className: "text-xs text-[var(--muted)] mt-0.5", children: String(props.description) })) : null] }), _jsx("button", { type: "button", className: "text-[var(--muted)] hover:text-[var(--text)] text-lg leading-none px-1 cursor-pointer", onClick: close, children: "\u00D7" })] }), children] }) }));
655
+ };
656
+ const DrawerComponent = (props, children, ctx) => {
657
+ const openPath = props.openPath;
658
+ const isOpen = openPath ? !!getByPath(ctx.state, openPath) : false;
659
+ if (!isOpen)
660
+ return null;
661
+ const close = () => {
662
+ if (openPath)
663
+ ctx.setState(openPath, false);
664
+ };
665
+ return (_jsx("div", { className: "fixed inset-0 z-50 flex items-end bg-black/50", onClick: (e) => {
666
+ if (e.target === e.currentTarget)
667
+ close();
668
+ }, onKeyDown: (e) => {
669
+ if (e.key === "Escape" || e.key === "Enter" || e.key === " ") {
670
+ e.preventDefault();
671
+ close();
672
+ }
673
+ }, role: "dialog", "aria-modal": "true", children: _jsxs("div", { className: "w-full max-h-[80vh] border-t border-[var(--border)] bg-[var(--card)] p-5 shadow-lg overflow-y-auto animate-[slide-up_200ms_ease]", children: [_jsx("div", { className: "w-10 h-1 bg-[var(--border)] mx-auto mb-3 rounded-full" }), props.title ? (_jsx("div", { className: "font-bold text-sm", children: String(props.title) })) : null, props.description ? (_jsx("div", { className: "text-xs text-[var(--muted)] mt-0.5 mb-3", children: String(props.description) })) : null, children] }) }));
674
+ };
675
+ // ── Component map ───────────────────────────────────────────────────
676
+ const COMPONENTS = {
677
+ // Layout
678
+ Stack: StackComponent,
679
+ Grid: GridComponent,
680
+ Card: CardComponent,
681
+ Separator: SeparatorComponent,
682
+ // Typography
683
+ Heading: HeadingComponent,
684
+ Text: TextComponent,
685
+ // Form
686
+ Input: InputComponent,
687
+ Textarea: TextareaComponent,
688
+ Select: SelectComponent,
689
+ Checkbox: CheckboxComponent,
690
+ Radio: RadioComponent,
691
+ Switch: SwitchComponent,
692
+ Slider: SliderComponent,
693
+ Toggle: ToggleComponent,
694
+ ToggleGroup: ToggleGroupComponent,
695
+ ButtonGroup: ButtonGroupComponent,
696
+ // Data
697
+ Table: TableComponent,
698
+ Carousel: CarouselComponent,
699
+ Badge: BadgeComponent,
700
+ Avatar: AvatarComponent,
701
+ Image: ImageComponent,
702
+ // Feedback
703
+ Alert: AlertComponent,
704
+ Progress: ProgressComponent,
705
+ Rating: RatingComponent,
706
+ Skeleton: SkeletonComponent,
707
+ Spinner: SpinnerComponent,
708
+ // Navigation
709
+ Button: ButtonComponent,
710
+ Link: LinkComponent,
711
+ DropdownMenu: DropdownMenuComponent,
712
+ Tabs: TabsComponent,
713
+ Pagination: PaginationComponent,
714
+ // Metric
715
+ Metric: MetricComponent,
716
+ // Visualization
717
+ BarGraph: BarGraphComponent,
718
+ LineGraph: LineGraphComponent,
719
+ // Interaction
720
+ Tooltip: TooltipComponent,
721
+ Popover: PopoverComponent,
722
+ Collapsible: CollapsibleComponent,
723
+ Accordion: AccordionComponent,
724
+ Dialog: DialogComponent,
725
+ Drawer: DrawerComponent,
726
+ };
727
+ // ══════════════════════════════════════════════════════════════════════
728
+ // ELEMENT RENDERER
729
+ // ══════════════════════════════════════════════════════════════════════
730
+ function ElementRenderer({ elementId }) {
731
+ const { t } = useApp();
732
+ const ctx = useUiCtx();
733
+ const el = ctx.spec.elements[elementId];
734
+ if (!el)
735
+ return null;
736
+ // Visibility check
737
+ if (el.visible && !evaluateUiVisibility(el.visible, ctx.state, ctx.auth)) {
738
+ return null;
739
+ }
740
+ const component = COMPONENTS[el.type];
741
+ if (!component) {
742
+ return (_jsxs("div", { className: "text-[10px] text-[var(--destructive)] border border-dashed border-[var(--destructive)] p-2", children: [t("ui-renderer.UnknownComponent"), " ", el.type] }));
743
+ }
744
+ const resolvedProps = resolveProps(el.props, ctx);
745
+ // Handle repeat / list rendering
746
+ if (el.repeat) {
747
+ const listData = getByPath(ctx.state, el.repeat.path);
748
+ if (!Array.isArray(listData))
749
+ return null;
750
+ return (_jsx(_Fragment, { children: listData.map((item) => {
751
+ const itemCtx = { ...ctx, repeatItem: item };
752
+ const childNodes = el.children.map((childId) => (_jsx(UiContext.Provider, { value: itemCtx, children: _jsx(ElementRenderer, { elementId: childId }) }, childId)));
753
+ const repeatKey = el.repeat?.key;
754
+ const itemKey = String(repeatKey != null ? item[repeatKey] : Math.random());
755
+ return (_jsx(React.Fragment, { children: component(resolvedProps, childNodes, itemCtx, el) }, itemKey));
756
+ }) }));
757
+ }
758
+ // Normal rendering: resolve children
759
+ const childNodes = el.children.map((childId) => (_jsx(ElementRenderer, { elementId: childId }, childId)));
760
+ return _jsx(_Fragment, { children: component(resolvedProps, childNodes, ctx, el) });
761
+ }
762
+ export function UiRenderer({ spec, onAction, loading, auth, validators, }) {
763
+ const [state, setStateRaw] = useState(() => ({
764
+ ...spec.state,
765
+ }));
766
+ const [fieldErrors, setFieldErrors] = useState({});
767
+ const setState = useCallback((path, value) => {
768
+ setStateRaw((prev) => {
769
+ const next = { ...prev };
770
+ setByPath(next, path, value);
771
+ return next;
772
+ });
773
+ }, []);
774
+ const validateField = useCallback((statePath) => {
775
+ // Find the element that has this statePath
776
+ for (const el of Object.values(spec.elements)) {
777
+ if (el.props.statePath === statePath && el.validation) {
778
+ const value = getByPath(state, statePath);
779
+ const errors = runValidation(el.validation.checks, value, validators);
780
+ setFieldErrors((prev) => ({ ...prev, [statePath]: errors }));
781
+ return;
782
+ }
783
+ }
784
+ }, [spec.elements, state, validators]);
785
+ const ctx = useMemo(() => ({
786
+ spec,
787
+ state,
788
+ setState,
789
+ onAction,
790
+ auth,
791
+ loading,
792
+ validators,
793
+ fieldErrors,
794
+ validateField,
795
+ }), [
796
+ spec,
797
+ state,
798
+ setState,
799
+ onAction,
800
+ auth,
801
+ loading,
802
+ validators,
803
+ fieldErrors,
804
+ validateField,
805
+ ]);
806
+ // Loading skeleton when no elements
807
+ if (loading && Object.keys(spec.elements).length === 0) {
808
+ return (_jsxs("div", { className: "flex flex-col gap-3 animate-pulse", children: [_jsx("div", { className: "h-4 bg-[var(--bg-hover)] w-3/4" }), _jsx("div", { className: "h-3 bg-[var(--bg-hover)] w-1/2" }), _jsx("div", { className: "h-3 bg-[var(--bg-hover)] w-5/6" })] }));
809
+ }
810
+ return (_jsx(UiContext.Provider, { value: ctx, children: _jsx(ElementRenderer, { elementId: spec.root }) }));
811
+ }
812
+ /** Get the full list of supported component types. */
813
+ export function getSupportedComponents() {
814
+ return Object.keys(COMPONENTS);
815
+ }