@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,840 @@
1
+ import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from "react/jsx-runtime";
2
+ /**
3
+ * config-field.tsx — React port of the 19 Lit field renderers from config-field.ts.
4
+ *
5
+ * Each renderer is a plain function (props: FieldRenderProps) => JSX.Element.
6
+ * Styling uses Tailwind utility classes + CSS custom properties from base.css.
7
+ *
8
+ * Also exports:
9
+ * - defaultRenderers map (field type name -> renderer)
10
+ * - ConfigField wrapper component (label + renderer + help + errors)
11
+ */
12
+ import { ChevronDown, X } from "lucide-react";
13
+ import React, { useCallback, useRef, useState } from "react";
14
+ import { useApp } from "../state";
15
+ import { resolveDynamic } from "./config-catalog";
16
+ // ── Action binding helper ──────────────────────────────────────────────
17
+ /**
18
+ * Resolve DynamicValue params and fire the onAction callback.
19
+ * No-ops when the binding or onAction is missing.
20
+ */
21
+ function fireAction(props, eventName) {
22
+ const binding = props.hint.on?.[eventName];
23
+ if (!binding || !props.onAction)
24
+ return;
25
+ // Resolve any DynamicValue params against a state snapshot built from the
26
+ // current field value (keyed by the field's own key). The resolveDynamic
27
+ // function handles both literal values and { path } references.
28
+ let resolvedParams;
29
+ if (binding.params) {
30
+ const state = { [props.key]: props.value };
31
+ resolvedParams = {};
32
+ for (const [k, v] of Object.entries(binding.params)) {
33
+ resolvedParams[k] = resolveDynamic(v, state);
34
+ }
35
+ }
36
+ void props.onAction(binding.action, resolvedParams);
37
+ }
38
+ // ── Shared Tailwind class constants ─────────────────────────────────────
39
+ const INPUT_CLS = "w-full px-3 py-2 border border-[var(--border)] bg-[var(--card)] text-[13px] font-[var(--mono)] transition-all focus:border-[var(--accent)] focus:outline-none focus:ring-1 focus:ring-[var(--accent)] box-border h-[36px] rounded-sm placeholder:text-[var(--muted)] placeholder:opacity-60";
40
+ const INPUT_ERROR_CLS = "w-full px-3 py-2 border border-[var(--destructive)] bg-[color-mix(in_srgb,var(--destructive)_3%,var(--card))] text-[13px] font-[var(--mono)] transition-all focus:border-[var(--accent)] focus:outline-none focus:ring-1 focus:ring-[var(--accent)] box-border h-[36px] rounded-sm placeholder:text-[var(--muted)] placeholder:opacity-60";
41
+ function inputCls(hasError) {
42
+ return hasError ? INPUT_ERROR_CLS : INPUT_CLS;
43
+ }
44
+ // ── 1. Text ─────────────────────────────────────────────────────────────
45
+ /** Single-line text input. Fallback renderer for unresolved field types. */
46
+ export function renderTextField(props) {
47
+ const value = props.isSet ? String(props.value ?? "") : "";
48
+ const placeholder = props.hint.placeholder ??
49
+ (props.schema.default != null
50
+ ? `Default: ${props.schema.default}`
51
+ : "Enter value...");
52
+ return (_jsx("input", { className: inputCls(!!props.errors?.length), type: "text", defaultValue: value, placeholder: placeholder, "data-config-key": props.key, "data-field-type": "text", disabled: props.readonly, onChange: (e) => {
53
+ props.onChange(e.target.value);
54
+ fireAction(props, "change");
55
+ }, onBlur: () => fireAction(props, "blur"), onClick: () => fireAction(props, "click") }));
56
+ }
57
+ // ── 2. Password ─────────────────────────────────────────────────────────
58
+ /** Masked password input with show/hide toggle and async onReveal for server-backed decryption. */
59
+ export function renderPasswordField(props) {
60
+ return _jsx(PasswordFieldInner, { fp: props });
61
+ }
62
+ function PasswordFieldInner({ fp: props }) {
63
+ const maskedValue = props.isSet ? String(props.value ?? "") : "";
64
+ const placeholder = props.isSet
65
+ ? `Current: ${maskedValue || "********"} (leave blank to keep)`
66
+ : (props.hint.placeholder ?? "Enter value...");
67
+ const [visible, setVisible] = useState(false);
68
+ const [busy, setBusy] = useState(false);
69
+ const [fieldValue, setFieldValue] = useState("");
70
+ const inputRef = useRef(null);
71
+ const onReveal = props.onReveal;
72
+ const handleToggle = useCallback(async () => {
73
+ if (visible) {
74
+ // Hide — just toggle visibility, value stays in React state
75
+ setVisible(false);
76
+ return;
77
+ }
78
+ // Reveal: fetch the real value from the server
79
+ if (onReveal) {
80
+ setBusy(true);
81
+ const realValue = await onReveal();
82
+ setBusy(false);
83
+ if (realValue != null) {
84
+ setVisible(true);
85
+ setFieldValue(realValue);
86
+ props.onChange(realValue);
87
+ }
88
+ }
89
+ else {
90
+ // Fallback: just toggle type (shows whatever is in the input)
91
+ setVisible(true);
92
+ }
93
+ }, [visible, onReveal, props]);
94
+ return (_jsxs("div", { className: "flex", children: [_jsx("input", { ref: inputRef, className: "flex-1 px-3 py-2 border border-[var(--border)] border-r-0 bg-[var(--card)] text-[13px] font-[var(--mono)] transition-all focus:border-[var(--accent)] focus:outline-none focus:ring-1 focus:ring-[var(--accent)] box-border h-[36px] rounded-l-sm placeholder:text-[var(--muted)] placeholder:opacity-60", type: visible ? "text" : "password", value: fieldValue, placeholder: placeholder, "data-config-key": props.key, "data-field-type": "password", onChange: (e) => {
95
+ setFieldValue(e.target.value);
96
+ props.onChange(e.target.value);
97
+ fireAction(props, "change");
98
+ }, onBlur: () => fireAction(props, "blur") }), _jsx("button", { type: "button", className: "px-3 border border-[var(--border)] bg-[var(--bg-hover)] text-[11px] text-[var(--muted)] cursor-pointer whitespace-nowrap min-w-[56px] text-center transition-colors hover:bg-[var(--surface)] hover:text-[var(--text)] h-[36px] font-medium rounded-r-sm", onClick: () => {
99
+ void handleToggle();
100
+ fireAction(props, "click");
101
+ }, title: visible ? "Hide value" : "Reveal value", children: busy ? "\u2026" : visible ? "\u{1F441} Hide" : "\u{1F441} Show" })] }));
102
+ }
103
+ // ── 3. Number ───────────────────────────────────────────────────────────
104
+ /** Numeric input with min/max/step attributes derived from schema and hints. */
105
+ export function renderNumberField(props) {
106
+ return _jsx(NumberFieldInner, { fp: props });
107
+ }
108
+ function NumberFieldInner({ fp: props }) {
109
+ const minVal = props.schema.minimum ?? props.hint.min ?? undefined;
110
+ const maxVal = props.schema.maximum ?? props.hint.max ?? undefined;
111
+ const stepVal = props.hint.step ?? 1;
112
+ const unit = props.hint.unit;
113
+ const placeholder = props.hint.placeholder ??
114
+ (props.schema.default != null
115
+ ? `Default: ${props.schema.default}`
116
+ : "Enter number...");
117
+ const initial = props.isSet ? String(props.value ?? "") : "";
118
+ const [val, setVal] = useState(initial);
119
+ const hasRange = minVal != null || maxVal != null;
120
+ const step = (direction) => {
121
+ const current = val === "" ? 0 : Number(val);
122
+ if (Number.isNaN(current))
123
+ return;
124
+ let next = current + direction * stepVal;
125
+ if (minVal != null && next < minVal)
126
+ next = minVal;
127
+ if (maxVal != null && next > maxVal)
128
+ next = maxVal;
129
+ const s = String(next);
130
+ setVal(s);
131
+ props.onChange(s);
132
+ fireAction(props, "change");
133
+ };
134
+ return (_jsxs("div", { children: [_jsxs("div", { className: "flex items-center gap-1.5", children: [!props.readonly && (_jsx("button", { type: "button", className: "px-2 py-1.5 border border-[var(--border)] bg-transparent text-sm text-[var(--muted)] cursor-pointer transition-colors hover:bg-[var(--surface)] hover:text-[var(--text)] h-[36px] rounded-sm font-mono select-none", onClick: () => step(-1), children: "\u2212" })), _jsx("input", { className: `${inputCls(!!props.errors?.length)} ${unit ? "flex-1" : "w-full"} text-center`, type: "number", value: val, placeholder: placeholder, min: minVal, max: maxVal, step: stepVal, "data-config-key": props.key, "data-field-type": "number", disabled: props.readonly, onChange: (e) => {
135
+ setVal(e.target.value);
136
+ props.onChange(e.target.value);
137
+ fireAction(props, "change");
138
+ }, onBlur: () => fireAction(props, "blur"), onClick: () => fireAction(props, "click") }), !props.readonly && (_jsx("button", { type: "button", className: "px-2 py-1.5 border border-[var(--border)] bg-transparent text-sm text-[var(--muted)] cursor-pointer transition-colors hover:bg-[var(--surface)] hover:text-[var(--text)] h-[36px] rounded-sm font-mono select-none", onClick: () => step(1), children: "+" })), unit && (_jsx("span", { className: "text-[11px] text-[var(--muted)] font-medium shrink-0 min-w-[20px]", children: unit }))] }), hasRange && (_jsx("div", { className: "text-[10px] text-[var(--muted)] mt-0.5 opacity-70", children: minVal != null && maxVal != null
139
+ ? `Range: ${minVal}–${maxVal}${unit ? ` ${unit}` : ""}`
140
+ : minVal != null
141
+ ? `Min: ${minVal}${unit ? ` ${unit}` : ""}`
142
+ : `Max: ${maxVal}${unit ? ` ${unit}` : ""}` }))] }));
143
+ }
144
+ // ── 4. Boolean ──────────────────────────────────────────────────────────
145
+ /** Pill-shaped toggle switch. Accepts boolean or string 'true'/'false' values. */
146
+ export function renderBooleanField(props) {
147
+ return _jsx(BooleanFieldInner, { fp: props });
148
+ }
149
+ function BooleanFieldInner({ fp: props }) {
150
+ const val = props.value === true || props.value === "true" || props.value === "1";
151
+ const initialVal = props.isSet
152
+ ? val
153
+ : props.schema.default === true || props.schema.default === "true";
154
+ const [localVal, setLocalVal] = useState(initialVal);
155
+ const handleToggle = () => {
156
+ const next = !localVal;
157
+ setLocalVal(next);
158
+ props.onChange(String(next));
159
+ fireAction(props, "change");
160
+ };
161
+ return (_jsxs("button", { type: "button", className: "flex items-center gap-2.5 cursor-pointer bg-transparent border-none p-0 group", disabled: props.readonly, onClick: () => {
162
+ handleToggle();
163
+ fireAction(props, "click");
164
+ }, "data-config-key": props.key, "data-field-type": "boolean", children: [_jsx("div", { className: `relative w-10 h-[22px] rounded-full transition-colors duration-200 ${localVal ? "bg-[var(--accent)]" : "bg-[var(--muted)] opacity-40"}`, children: _jsx("div", { className: `absolute top-[3px] w-4 h-4 bg-white rounded-full shadow-sm transition-all duration-200 ${localVal ? "left-[21px]" : "left-[3px]"}` }) }), _jsx("span", { className: `text-xs transition-colors ${localVal ? "text-[var(--text)] font-medium" : "text-[var(--muted)]"}`, children: localVal ? "Enabled" : "Disabled" })] }));
165
+ }
166
+ // ── 5. URL ──────────────────────────────────────────────────────────────
167
+ /** URL input with type="url" browser validation. */
168
+ export function renderUrlField(props) {
169
+ const value = props.isSet ? String(props.value ?? "") : "";
170
+ const placeholder = props.hint.placeholder ??
171
+ (props.schema.default != null
172
+ ? `Default: ${props.schema.default}`
173
+ : "https://...");
174
+ return (_jsx("input", { className: inputCls(!!props.errors?.length), type: "url", defaultValue: value, placeholder: placeholder, "data-config-key": props.key, "data-field-type": "url", disabled: props.readonly, onChange: (e) => {
175
+ props.onChange(e.target.value);
176
+ fireAction(props, "change");
177
+ }, onBlur: () => fireAction(props, "blur"), onClick: () => fireAction(props, "click") }));
178
+ }
179
+ // ── 6. Select ───────────────────────────────────────────────────────────
180
+ /** Dropdown select. Options from hint.options or schema.enum. */
181
+ export function RenderSelectField(props) {
182
+ const { t } = useApp();
183
+ const enhancedOptions = props.hint.options;
184
+ const plainOptions = props.schema.enum ??
185
+ props.schema.oneOf?.map((o) => String(o.const ?? o.description ?? "")) ??
186
+ [];
187
+ const allOptions = enhancedOptions
188
+ ? enhancedOptions.map((o) => ({
189
+ value: o.value,
190
+ label: o.label,
191
+ description: o.description,
192
+ }))
193
+ : plainOptions.map((o) => ({
194
+ value: o,
195
+ label: o,
196
+ description: undefined,
197
+ }));
198
+ const value = props.isSet ? String(props.value ?? "") : "";
199
+ const effectiveValue = value || String(props.schema.default ?? "");
200
+ const useSearch = allOptions.length >= 5;
201
+ if (useSearch) {
202
+ return (_jsx(SearchableSelectInner, { fp: props, options: allOptions, effectiveValue: effectiveValue }));
203
+ }
204
+ return (_jsxs("select", { className: `${INPUT_CLS} appearance-auto`, defaultValue: effectiveValue, "data-config-key": props.key, "data-field-type": "select", disabled: props.readonly, onChange: (e) => {
205
+ props.onChange(e.target.value);
206
+ fireAction(props, "change");
207
+ }, onBlur: () => fireAction(props, "blur"), onClick: () => fireAction(props, "click"), children: [!props.required && (_jsx("option", { value: "", children: t("config-field.None", { defaultValue: "None" }) })), allOptions.map((opt) => (_jsxs("option", { value: opt.value, children: [opt.label, opt.description ? ` — ${opt.description}` : ""] }, opt.value)))] }));
208
+ }
209
+ function SearchableSelectInner({ fp: props, options, effectiveValue, }) {
210
+ const { t } = useApp();
211
+ const matchingOpt = options.find((o) => o.value === effectiveValue);
212
+ const [inputVal, setInputVal] = useState(matchingOpt?.label ?? effectiveValue);
213
+ const [open, setOpen] = useState(false);
214
+ const [filter, setFilter] = useState("");
215
+ const containerRef = useRef(null);
216
+ const inputRef = useRef(null);
217
+ const filtered = filter
218
+ ? options.filter((o) => o.label.toLowerCase().includes(filter.toLowerCase()) ||
219
+ o.value.toLowerCase().includes(filter.toLowerCase()))
220
+ : options;
221
+ const select = useCallback((opt) => {
222
+ props.onChange(opt.value);
223
+ setInputVal(opt.label);
224
+ setOpen(false);
225
+ setFilter("");
226
+ fireAction(props, "change");
227
+ }, [props]);
228
+ // Close on click outside
229
+ React.useEffect(() => {
230
+ if (!open)
231
+ return;
232
+ const handler = (e) => {
233
+ if (containerRef.current &&
234
+ !containerRef.current.contains(e.target)) {
235
+ setOpen(false);
236
+ setFilter("");
237
+ }
238
+ };
239
+ document.addEventListener("mousedown", handler);
240
+ return () => document.removeEventListener("mousedown", handler);
241
+ }, [open]);
242
+ return (_jsxs("div", { className: "relative", ref: containerRef, children: [_jsxs("button", { type: "button", className: `${inputCls(!!props.errors?.length)} text-left flex items-center justify-between gap-2 cursor-pointer`, disabled: props.readonly, onClick: () => {
243
+ setOpen(!open);
244
+ setFilter("");
245
+ }, "data-config-key": props.key, "data-field-type": "select", children: [_jsx("span", { className: inputVal ? "" : "text-[var(--muted)] opacity-60", children: inputVal || "Select..." }), _jsx("span", { className: "text-[var(--muted)] text-[10px] shrink-0", children: open ? "\u25B2" : "\u25BC" })] }), open && (_jsxs("div", { className: "absolute z-50 left-0 right-0 mt-1 border border-[var(--border)] bg-[var(--card)] shadow-lg max-h-[280px] flex flex-col rounded-sm", children: [_jsx("div", { className: "p-1.5 border-b border-[var(--border)]", children: _jsx("input", { ref: inputRef, className: "w-full px-2 py-1.5 border border-[var(--border)] bg-[var(--bg)] text-[12px] font-[var(--mono)] focus:border-[var(--accent)] focus:outline-none rounded-sm", type: "text", value: filter, placeholder: `Search ${options.length} models...`, onChange: (e) => setFilter(e.target.value), onKeyDown: (e) => {
246
+ if (e.key === "Escape") {
247
+ setOpen(false);
248
+ setFilter("");
249
+ }
250
+ else if (e.key === "Enter" && filtered.length === 1) {
251
+ select(filtered[0]);
252
+ }
253
+ } }) }), _jsxs("div", { className: "overflow-y-auto flex-1", children: [!props.required && (_jsx("button", { type: "button", className: "w-full text-left px-3 py-1.5 text-[12px] text-[var(--muted)] hover:bg-[var(--bg-hover)] transition-colors italic", onClick: () => {
254
+ props.onChange("");
255
+ setInputVal("");
256
+ setOpen(false);
257
+ setFilter("");
258
+ fireAction(props, "change");
259
+ }, children: t("config-field.None", { defaultValue: "None" }) })), filtered.length === 0 && (_jsx("div", { className: "px-3 py-3 text-[12px] text-[var(--muted)] text-center", children: t("config-field.NoMatches", {
260
+ defaultValue: "No matches",
261
+ }) })), filtered.map((opt) => (_jsxs("button", { type: "button", className: `w-full text-left px-3 py-1.5 text-[12px] hover:bg-[var(--bg-hover)] transition-colors ${opt.value === effectiveValue
262
+ ? "bg-[color-mix(in_srgb,var(--accent)_10%,var(--card))] text-[var(--accent)] font-medium"
263
+ : ""}`, onClick: () => select(opt), children: [opt.label, opt.description && (_jsx("span", { className: "text-[var(--muted)] ml-1.5 text-[11px]", children: opt.description }))] }, opt.value)))] }), _jsxs("div", { className: "px-3 py-1 border-t border-[var(--border)] text-[10px] text-[var(--muted)]", children: [filtered.length, " of ", options.length, " ", t("config-field.models", { defaultValue: "models" })] })] }))] }));
264
+ }
265
+ // ── 7. Textarea ─────────────────────────────────────────────────────────
266
+ /** Multi-line text input with auto-resize. Auto-detected for maxLength > 200. */
267
+ export function renderTextareaField(props) {
268
+ return _jsx(TextareaFieldInner, { fp: props });
269
+ }
270
+ function TextareaFieldInner({ fp: props }) {
271
+ const value = props.isSet ? String(props.value ?? "") : "";
272
+ const placeholder = props.hint.placeholder ?? "Enter text...";
273
+ const textareaRef = useRef(null);
274
+ const autoResize = useCallback(() => {
275
+ const el = textareaRef.current;
276
+ if (!el)
277
+ return;
278
+ // Check if field-sizing is supported — if so, CSS handles it
279
+ if (globalThis.CSS?.supports?.("field-sizing", "content"))
280
+ return;
281
+ el.style.height = "auto";
282
+ el.style.height = `${Math.max(72, el.scrollHeight)}px`;
283
+ }, []);
284
+ return (_jsx("textarea", { ref: textareaRef, className: "w-full px-3 py-2 border border-[var(--border)] bg-[var(--card)] text-[13px] font-[var(--mono)] transition-all focus:border-[var(--accent)] focus:outline-none focus:ring-1 focus:ring-[var(--accent)] box-border min-h-[72px] max-h-[400px] rounded-sm placeholder:text-[var(--muted)] placeholder:opacity-60", style: { fieldSizing: "content" }, defaultValue: value, placeholder: placeholder, "data-config-key": props.key, "data-field-type": "textarea", disabled: props.readonly, onChange: (e) => {
285
+ props.onChange(e.target.value);
286
+ fireAction(props, "change");
287
+ autoResize();
288
+ }, onBlur: () => fireAction(props, "blur"), onClick: () => fireAction(props, "click"), onFocus: autoResize }));
289
+ }
290
+ // ── 8. Email ────────────────────────────────────────────────────────────
291
+ /** Email input with type="email" browser validation. */
292
+ export function renderEmailField(props) {
293
+ const value = props.isSet ? String(props.value ?? "") : "";
294
+ const placeholder = props.hint.placeholder ?? "user@example.com";
295
+ return (_jsx("input", { className: inputCls(!!props.errors?.length), type: "email", defaultValue: value, placeholder: placeholder, "data-config-key": props.key, "data-field-type": "email", disabled: props.readonly, onChange: (e) => {
296
+ props.onChange(e.target.value);
297
+ fireAction(props, "change");
298
+ }, onBlur: () => fireAction(props, "blur"), onClick: () => fireAction(props, "click") }));
299
+ }
300
+ // ── 9. Color ────────────────────────────────────────────────────────────
301
+ /** Color picker swatch paired with a hex text input. */
302
+ export function renderColorField(props) {
303
+ return _jsx(ColorFieldInner, { fp: props });
304
+ }
305
+ function ColorFieldInner({ fp: props }) {
306
+ const initial = props.isSet ? String(props.value ?? "#000000") : "#000000";
307
+ const [color, setColor] = useState(initial);
308
+ const handleChange = (newColor) => {
309
+ setColor(newColor);
310
+ props.onChange(newColor);
311
+ fireAction(props, "change");
312
+ };
313
+ return (_jsxs("div", { className: "flex items-center gap-2", children: [_jsx("input", { className: "w-[36px] h-[36px] border border-[var(--border)] p-0.5 cursor-pointer bg-transparent rounded-sm [&::-webkit-color-swatch-wrapper]:p-0 [&::-webkit-color-swatch]:border-none [&::-webkit-color-swatch]:rounded-sm", type: "color", value: color, "data-config-key": props.key, "data-field-type": "color", disabled: props.readonly, onChange: (e) => handleChange(e.target.value), onBlur: () => fireAction(props, "blur"), onClick: () => fireAction(props, "click") }), _jsx("input", { className: `${inputCls(!!props.errors?.length)} flex-1`, type: "text", value: color, placeholder: "#000000", "data-config-key": props.key, "data-field-type": "color-text", disabled: props.readonly, onChange: (e) => handleChange(e.target.value), onBlur: () => fireAction(props, "blur"), onClick: () => fireAction(props, "click") })] }));
314
+ }
315
+ // ── 10. Radio ───────────────────────────────────────────────────────────
316
+ /** Vertical radio button group. Supports per-option descriptions. */
317
+ export function renderRadioField(props) {
318
+ return _jsx(RadioFieldInner, { fp: props });
319
+ }
320
+ function RadioFieldInner({ fp: props }) {
321
+ const options = props.hint.options ??
322
+ (props.schema.enum ?? []).map((v) => ({
323
+ value: String(v),
324
+ label: String(v),
325
+ }));
326
+ const initial = props.isSet
327
+ ? String(props.value ?? "")
328
+ : String(props.schema.default ?? "");
329
+ const [selected, setSelected] = useState(initial);
330
+ const handleChange = (val) => {
331
+ setSelected(val);
332
+ props.onChange(val);
333
+ fireAction(props, "change");
334
+ };
335
+ return (_jsx("div", { className: "flex flex-col gap-1.5", "data-config-key": props.key, "data-field-type": "radio", children: options.map((opt) => (_jsxs("label", { className: "flex items-start gap-2 cursor-pointer text-[13px]", children: [_jsx("input", { type: "radio", name: props.key, value: opt.value, checked: opt.value === selected, disabled: props.readonly || opt.disabled, onChange: () => handleChange(opt.value), onClick: () => fireAction(props, "click"), onBlur: () => fireAction(props, "blur"), className: "mt-0.5 shrink-0" }), _jsxs("span", { children: [opt.label, opt.description && (_jsx("div", { className: "text-[11px] text-[var(--muted)] mt-px", children: opt.description }))] })] }, opt.value))) }));
336
+ }
337
+ // ── 11. Multiselect ─────────────────────────────────────────────────────
338
+ /** Checkbox group for selecting multiple values from options. */
339
+ export function renderMultiselectField(props) {
340
+ return _jsx(MultiselectFieldInner, { fp: props });
341
+ }
342
+ function MultiselectFieldInner({ fp: props }) {
343
+ const options = props.hint.options ??
344
+ (props.schema.items?.enum ?? []).map((v) => ({
345
+ value: String(v),
346
+ label: String(v),
347
+ }));
348
+ const rawVal = props.isSet ? props.value : [];
349
+ const initialSet = new Set(Array.isArray(rawVal) ? rawVal.map(String) : []);
350
+ const [selected, setSelected] = useState(initialSet);
351
+ const toggle = (optValue) => {
352
+ setSelected((prev) => {
353
+ const next = new Set(prev);
354
+ if (next.has(optValue)) {
355
+ next.delete(optValue);
356
+ }
357
+ else {
358
+ next.add(optValue);
359
+ }
360
+ props.onChange([...next]);
361
+ fireAction(props, "change");
362
+ return next;
363
+ });
364
+ };
365
+ const remove = (optValue) => {
366
+ setSelected((prev) => {
367
+ const next = new Set(prev);
368
+ next.delete(optValue);
369
+ props.onChange([...next]);
370
+ fireAction(props, "change");
371
+ return next;
372
+ });
373
+ };
374
+ const selectedOptions = options.filter((o) => selected.has(o.value));
375
+ return (_jsxs("div", { className: "flex flex-col gap-2", "data-config-key": props.key, "data-field-type": "multiselect", children: [selectedOptions.length > 0 && (_jsx("div", { className: "flex flex-wrap gap-1", children: selectedOptions.map((opt) => (_jsxs("span", { className: "inline-flex items-center gap-1 px-2 py-0.5 text-[11px] bg-[var(--accent-subtle,rgba(59,130,246,0.1))] text-[var(--accent)] border border-[var(--accent)] border-opacity-30 rounded-full", children: [opt.label, !props.readonly && (_jsx("button", { type: "button", className: "inline-flex items-center justify-center w-3.5 h-3.5 text-[10px] rounded-full hover:bg-[var(--accent)] hover:text-[var(--accent-foreground,#1a1f26)] transition-colors cursor-pointer", onClick: () => remove(opt.value), children: "\u00D7" }))] }, opt.value))) })), _jsx("div", { className: "flex flex-col gap-1", children: options.map((opt) => (_jsxs("label", { className: "flex items-center gap-2 cursor-pointer text-[13px]", children: [_jsx("input", { type: "checkbox", value: opt.value, checked: selected.has(opt.value), disabled: props.readonly, onChange: () => toggle(opt.value), onClick: () => fireAction(props, "click"), onBlur: () => fireAction(props, "blur") }), _jsx("span", { children: opt.label })] }, opt.value))) })] }));
376
+ }
377
+ // ── 12. Date ────────────────────────────────────────────────────────────
378
+ /** Native date picker input. */
379
+ export function renderDateField(props) {
380
+ const value = props.isSet ? String(props.value ?? "") : "";
381
+ const inputType = props.schema.format === "date-time" ? "datetime-local" : "date";
382
+ return (_jsx("input", { className: inputCls(!!props.errors?.length), type: inputType, defaultValue: value, "data-config-key": props.key, "data-field-type": "date", disabled: props.readonly, onChange: (e) => {
383
+ props.onChange(e.target.value);
384
+ fireAction(props, "change");
385
+ }, onBlur: () => fireAction(props, "blur"), onClick: () => fireAction(props, "click") }));
386
+ }
387
+ // ── 13. JSON ────────────────────────────────────────────────────────────
388
+ /** JSON editor textarea with parse validation on blur. Shows inline error for invalid JSON. */
389
+ export function renderJsonField(props) {
390
+ return _jsx(JsonFieldInner, { fp: props });
391
+ }
392
+ function JsonFieldInner({ fp: props }) {
393
+ const { t } = useApp();
394
+ const initial = props.isSet ? String(props.value ?? "") : "";
395
+ const [jsonError, setJsonError] = useState(null);
396
+ const handleBlur = (e) => {
397
+ const val = e.target.value.trim();
398
+ if (val) {
399
+ try {
400
+ const parsed = JSON.parse(val);
401
+ const jsonStr = JSON.stringify(parsed);
402
+ if (/__proto__|constructor\s*:/.test(jsonStr)) {
403
+ setJsonError("Unsafe JSON: contains dangerous keys");
404
+ return;
405
+ }
406
+ setJsonError(null);
407
+ }
408
+ catch (err) {
409
+ setJsonError(err instanceof Error ? err.message : "Invalid JSON");
410
+ }
411
+ }
412
+ else {
413
+ setJsonError(null);
414
+ }
415
+ fireAction(props, "blur");
416
+ };
417
+ return (_jsxs("div", { children: [_jsx("textarea", { className: `w-full px-2.5 py-[7px] border ${jsonError || props.errors?.length
418
+ ? "border-[var(--destructive)]"
419
+ : "border-[var(--border)]"} bg-[var(--card)] text-[13px] font-mono transition-all focus:border-[var(--accent)] focus:outline-none focus:ring-1 focus:ring-[var(--accent)] box-border min-h-[100px] resize-y rounded-sm`, defaultValue: initial, placeholder: t("config-field.KeyValue", {
420
+ defaultValue: "Key-value JSON",
421
+ }), rows: 6, "data-config-key": props.key, "data-field-type": "json", disabled: props.readonly, onChange: (e) => {
422
+ props.onChange(e.target.value);
423
+ fireAction(props, "change");
424
+ }, onBlur: handleBlur, onClick: () => fireAction(props, "click") }), jsonError && (_jsx("div", { className: "text-[11px] text-[var(--destructive)] mt-1 leading-snug", children: jsonError }))] }));
425
+ }
426
+ // ── 14. Code ────────────────────────────────────────────────────────────
427
+ /** Monospaced code editor textarea for templates and snippets. */
428
+ export function renderCodeField(props) {
429
+ const value = props.isSet ? String(props.value ?? "") : "";
430
+ const placeholder = props.hint.placeholder ?? "Enter code...";
431
+ return (_jsx("textarea", { className: `w-full px-2.5 py-[7px] border ${props.errors?.length
432
+ ? "border-[var(--destructive)]"
433
+ : "border-[var(--border)]"} bg-[var(--card)] text-[13px] font-mono transition-all focus:border-[var(--accent)] focus:outline-none focus:ring-1 focus:ring-[var(--accent)] box-border min-h-[100px] resize-y rounded-sm`, defaultValue: value, placeholder: placeholder, rows: 6, "data-config-key": props.key, "data-field-type": "code", disabled: props.readonly, onChange: (e) => {
434
+ props.onChange(e.target.value);
435
+ fireAction(props, "change");
436
+ }, onBlur: () => fireAction(props, "blur"), onClick: () => fireAction(props, "click") }));
437
+ }
438
+ // ── 15. Array ───────────────────────────────────────────────────────────
439
+ /** Add/remove items list. Max 100 items. Parses comma-separated strings. */
440
+ export function renderArrayField(props) {
441
+ return _jsx(ArrayFieldInner, { fp: props });
442
+ }
443
+ function ArrayItem({ index, value, total, hasError, readonly, onChange, onRemove, onMoveUp, onMoveDown, onBlur, }) {
444
+ const { t } = useApp();
445
+ return (_jsxs("div", { className: "flex items-center gap-1", children: [!readonly && (_jsxs("div", { className: "flex flex-col shrink-0", children: [_jsx("button", { type: "button", className: "px-1 py-0 text-[10px] leading-tight text-[var(--muted)] cursor-pointer hover:text-[var(--text)] disabled:opacity-30 disabled:cursor-not-allowed", onClick: onMoveUp, disabled: index === 0, title: t("config-field.MoveUp", {
446
+ defaultValue: "Move up",
447
+ }), children: "\u25B2" }), _jsx("button", { type: "button", className: "px-1 py-0 text-[10px] leading-tight text-[var(--muted)] cursor-pointer hover:text-[var(--text)] disabled:opacity-30 disabled:cursor-not-allowed", onClick: onMoveDown, disabled: index === total - 1, title: t("config-field.MoveDown", {
448
+ defaultValue: "Move down",
449
+ }), children: _jsx(ChevronDown, { className: "w-3 h-3" }) })] })), _jsx("input", { className: `${inputCls(hasError)} flex-1`, type: "text", value: value, placeholder: `Item ${index + 1}`, disabled: readonly, onChange: (e) => onChange(e.target.value), onBlur: onBlur }), !readonly && (_jsx("button", { type: "button", className: "px-2 py-1.5 border border-[var(--border)] bg-[var(--bg-hover)] text-xs text-[var(--muted)] cursor-pointer transition-colors hover:bg-[var(--surface)] hover:text-[var(--destructive)] h-[36px] rounded-sm", onClick: onRemove, children: _jsx(X, { className: "w-3 h-3" }) }))] }));
450
+ }
451
+ function ArrayFieldInner({ fp: props }) {
452
+ const { t } = useApp();
453
+ const rawVal = props.isSet ? props.value : [];
454
+ const initialItems = Array.isArray(rawVal)
455
+ ? rawVal.map(String)
456
+ : [];
457
+ const [items, setItems] = useState(initialItems);
458
+ const updateItems = (nextItems) => {
459
+ setItems(nextItems);
460
+ props.onChange(nextItems);
461
+ fireAction(props, "change");
462
+ };
463
+ const MAX_ARRAY_ITEMS = 100;
464
+ const addItem = () => {
465
+ if (items.length >= MAX_ARRAY_ITEMS)
466
+ return;
467
+ updateItems([...items, ""]);
468
+ };
469
+ const removeItem = (index) => {
470
+ updateItems(items.filter((_, i) => i !== index));
471
+ };
472
+ const changeItem = (index, value) => {
473
+ const next = [...items];
474
+ next[index] = value;
475
+ updateItems(next);
476
+ };
477
+ const moveItem = (from, to) => {
478
+ const next = [...items];
479
+ const [moved] = next.splice(from, 1);
480
+ next.splice(to, 0, moved);
481
+ updateItems(next);
482
+ };
483
+ return (_jsxs("div", { className: "flex flex-col gap-1.5", "data-config-key": props.key, "data-field-type": "array", children: [items.map((item, index) => (_jsx(ArrayItem
484
+ // biome-ignore lint/suspicious/noArrayIndexKey: composite key with index as tiebreaker
485
+ , { index: index, value: item, total: items.length, hasError: !!props.errors?.length, readonly: props.readonly, onChange: (v) => changeItem(index, v), onRemove: () => {
486
+ removeItem(index);
487
+ fireAction(props, "click");
488
+ }, onMoveUp: () => moveItem(index, index - 1), onMoveDown: () => moveItem(index, index + 1), onBlur: () => fireAction(props, "blur") }, `${index}-${items.length}`))), !props.readonly && (_jsx("button", { type: "button", className: "self-start px-3 py-1.5 border border-dashed border-[var(--border)] bg-transparent text-[11px] text-[var(--muted)] cursor-pointer transition-colors hover:bg-[var(--bg-hover)] hover:text-[var(--text)] hover:border-[var(--accent)] rounded-sm", onClick: () => {
489
+ addItem();
490
+ fireAction(props, "click");
491
+ }, children: t("config-field.AddItem", { defaultValue: "Add item" }) }))] }));
492
+ }
493
+ // ── 16. Key-Value ───────────────────────────────────────────────────────
494
+ /** Key-value pair editor with add/remove rows. Blocks prototype pollution keys. */
495
+ export function renderKeyValueField(props) {
496
+ return _jsx(KeyValueFieldInner, { fp: props });
497
+ }
498
+ function KeyValueFieldInner({ fp: props }) {
499
+ const { t } = useApp();
500
+ const rawVal = props.isSet ? props.value : {};
501
+ const initialPairs = rawVal && typeof rawVal === "object" && !Array.isArray(rawVal)
502
+ ? Object.entries(rawVal).map(([k, v]) => ({
503
+ key: k,
504
+ value: String(v ?? ""),
505
+ }))
506
+ : [];
507
+ const [pairs, setPairs] = useState(initialPairs);
508
+ const emitChange = (next) => {
509
+ setPairs(next);
510
+ const obj = {};
511
+ for (const p of next) {
512
+ if (p.key)
513
+ obj[p.key] = p.value;
514
+ }
515
+ props.onChange(obj);
516
+ fireAction(props, "change");
517
+ };
518
+ const addRow = () => {
519
+ emitChange([...pairs, { key: "", value: "" }]);
520
+ };
521
+ const removeRow = (index) => {
522
+ emitChange(pairs.filter((_, i) => i !== index));
523
+ };
524
+ const BLOCKED_KEYS = ["__proto__", "constructor", "prototype"];
525
+ const updateRow = (index, field, val) => {
526
+ if (field === "key" && BLOCKED_KEYS.includes(val))
527
+ return;
528
+ const next = [...pairs];
529
+ next[index] = { ...next[index], [field]: val };
530
+ emitChange(next);
531
+ };
532
+ return (_jsxs("div", { className: "flex flex-col gap-1.5", "data-config-key": props.key, "data-field-type": "keyvalue", children: [pairs.map((pair, index) => (_jsxs("div", { className: "flex items-center gap-1", children: [_jsx("input", { className: `${inputCls(!!props.errors?.length)} flex-1`, type: "text", value: pair.key, placeholder: t("config-field.Key", { defaultValue: "Key" }), disabled: props.readonly, onChange: (e) => updateRow(index, "key", e.target.value), onBlur: () => fireAction(props, "blur") }), _jsx("input", { className: `${inputCls(!!props.errors?.length)} flex-1`, type: "text", value: pair.value, placeholder: t("config-field.Value", { defaultValue: "Value" }), disabled: props.readonly, onChange: (e) => updateRow(index, "value", e.target.value), onBlur: () => fireAction(props, "blur") }), !props.readonly && (_jsx("button", { type: "button", className: "px-2 py-1.5 border border-[var(--border)] bg-[var(--bg-hover)] text-xs text-[var(--muted)] cursor-pointer transition-colors hover:bg-[var(--surface)] hover:text-[var(--destructive)] h-[36px] rounded-sm", onClick: () => {
533
+ removeRow(index);
534
+ fireAction(props, "click");
535
+ }, children: _jsx(X, { className: "w-3 h-3" }) }))] }, `${pair.key}:${pair.value}`))), !props.readonly && (_jsx("button", { type: "button", className: "self-start px-3 py-1.5 border border-dashed border-[var(--border)] bg-transparent text-[11px] text-[var(--muted)] cursor-pointer transition-colors hover:bg-[var(--bg-hover)] hover:text-[var(--text)] hover:border-[var(--accent)] rounded-sm", onClick: () => {
536
+ addRow();
537
+ fireAction(props, "click");
538
+ }, children: t("config-field.AddRow", { defaultValue: "Add row" }) }))] }));
539
+ }
540
+ // ── 17. Datetime ────────────────────────────────────────────────────────
541
+ /** Combined date and time picker (datetime-local). */
542
+ export function renderDatetimeField(props) {
543
+ const value = props.isSet ? String(props.value ?? "") : "";
544
+ return (_jsx("input", { className: inputCls(!!props.errors?.length), type: "datetime-local", defaultValue: value, "data-config-key": props.key, "data-field-type": "datetime", disabled: props.readonly, onChange: (e) => {
545
+ props.onChange(e.target.value);
546
+ fireAction(props, "change");
547
+ }, onBlur: () => fireAction(props, "blur"), onClick: () => fireAction(props, "click") }));
548
+ }
549
+ // ── 18. File ────────────────────────────────────────────────────────────
550
+ /** File path text input with path traversal guard. */
551
+ export function RenderFileField(props) {
552
+ const { t } = useApp();
553
+ const value = props.isSet ? String(props.value ?? "") : "";
554
+ const placeholder = props.hint.placeholder ?? "/path/to/file";
555
+ return (_jsxs("div", { children: [_jsx("input", { className: inputCls(!!props.errors?.length), type: "text", defaultValue: value, placeholder: placeholder, "data-config-key": props.key, "data-field-type": "file", disabled: props.readonly, onChange: (e) => {
556
+ const v = e.target.value;
557
+ if (v.includes(".."))
558
+ return; // block path traversal
559
+ props.onChange(v);
560
+ fireAction(props, "change");
561
+ }, onBlur: () => fireAction(props, "blur"), onClick: () => fireAction(props, "click") }), _jsx("div", { className: "text-[11px] text-[var(--muted)] mt-0.5", children: t("config-field.EnterAFilePathOr", {
562
+ defaultValue: "Enter a file path or paste one here.",
563
+ }) })] }));
564
+ }
565
+ // ── 19. Custom ──────────────────────────────────────────────────────────
566
+ /** Placeholder for plugin-provided custom React components. */
567
+ export function RenderCustomField(props) {
568
+ const { t } = useApp();
569
+ const componentName = props.hint.component;
570
+ return (_jsxs("div", { className: "px-3 py-4 border border-dashed border-[var(--border)] bg-[var(--bg-hover)] text-[13px] text-[var(--muted)]", "data-config-key": props.key, "data-field-type": "custom", children: [t("config-field.CustomComponent", {
571
+ defaultValue: "Custom component:",
572
+ }), " ", componentName ?? props.fieldType] }));
573
+ }
574
+ // ── 20. Markdown ─────────────────────────────────────────────────────────
575
+ /**
576
+ * Simple markdown renderer for preview mode.
577
+ * Converts basic markdown patterns to React elements without external dependencies.
578
+ */
579
+ function renderMarkdown(text) {
580
+ if (!text)
581
+ return null;
582
+ const blocks = text.split(/\n\n+/);
583
+ const elements = [];
584
+ blocks.forEach((block) => {
585
+ const trimmed = block.trim();
586
+ if (!trimmed)
587
+ return;
588
+ // Fenced code block
589
+ if (trimmed.startsWith("```")) {
590
+ const lines = trimmed.split("\n");
591
+ const code = lines.slice(1, -1).join("\n");
592
+ elements.push(_jsx("pre", { className: "bg-[var(--bg-hover)] px-3 py-2 rounded-sm overflow-x-auto my-2", children: _jsx("code", { className: "font-mono text-[12px]", children: code }) }, `code:${code}`));
593
+ return;
594
+ }
595
+ // Heading
596
+ const headingMatch = trimmed.match(/^(#{1,6})\s+(.+)$/);
597
+ if (headingMatch) {
598
+ const level = headingMatch[1].length;
599
+ const content = processInline(headingMatch[2]);
600
+ const sizes = [
601
+ "text-xl",
602
+ "text-lg",
603
+ "text-base",
604
+ "text-sm",
605
+ "text-sm",
606
+ "text-xs",
607
+ ];
608
+ const cls = `${sizes[level - 1]} font-bold mb-1 mt-2`;
609
+ elements.push(React.createElement(`h${level}`, { key: `heading:${headingMatch[2]}`, className: cls }, content));
610
+ return;
611
+ }
612
+ // Unordered list
613
+ if (/^[-*]\s/.test(trimmed)) {
614
+ const items = trimmed.split("\n").filter((l) => /^[-*]\s/.test(l));
615
+ elements.push(_jsx("ul", { className: "list-disc pl-4 my-2 space-y-1", children: items.map((item) => (_jsx("li", { children: processInline(item.replace(/^[-*]\s/, "")) }, item))) }, `list:${trimmed}`));
616
+ return;
617
+ }
618
+ // Regular paragraph
619
+ elements.push(_jsx("p", { className: "my-2", children: processInline(trimmed) }, `paragraph:${trimmed}`));
620
+ });
621
+ return _jsx(_Fragment, { children: elements });
622
+ }
623
+ /**
624
+ * Process inline markdown patterns (bold, italic, code, links).
625
+ */
626
+ function processInline(text) {
627
+ const parts = [];
628
+ let remaining = text;
629
+ let key = 0;
630
+ while (remaining) {
631
+ // Link: [text](url)
632
+ const linkMatch = remaining.match(/\[([^\]]+)\]\(([^)]+)\)/);
633
+ if (linkMatch) {
634
+ const before = remaining.substring(0, linkMatch.index);
635
+ if (before)
636
+ parts.push(processSimpleInline(before, key++));
637
+ parts.push(_jsx("a", { href: linkMatch[2], target: "_blank", rel: "noopener noreferrer", className: "text-[var(--accent)] underline", children: linkMatch[1] }, key++));
638
+ const linkIndex = linkMatch.index ?? 0;
639
+ remaining = remaining.substring(linkIndex + linkMatch[0].length);
640
+ continue;
641
+ }
642
+ // Inline code: `code`
643
+ const codeMatch = remaining.match(/`([^`]+)`/);
644
+ if (codeMatch) {
645
+ const before = remaining.substring(0, codeMatch.index);
646
+ if (before)
647
+ parts.push(processSimpleInline(before, key++));
648
+ parts.push(_jsx("code", { className: "bg-[var(--bg-hover)] px-1 py-0.5 rounded font-mono text-[12px]", children: codeMatch[1] }, key++));
649
+ const codeIndex = codeMatch.index ?? 0;
650
+ remaining = remaining.substring(codeIndex + codeMatch[0].length);
651
+ continue;
652
+ }
653
+ // Bold: **text**
654
+ const boldMatch = remaining.match(/\*\*([^*]+)\*\*/);
655
+ if (boldMatch) {
656
+ const before = remaining.substring(0, boldMatch.index);
657
+ if (before)
658
+ parts.push(processSimpleInline(before, key++));
659
+ parts.push(_jsx("strong", { children: boldMatch[1] }, key++));
660
+ const boldIndex = boldMatch.index ?? 0;
661
+ remaining = remaining.substring(boldIndex + boldMatch[0].length);
662
+ continue;
663
+ }
664
+ // Italic: *text* or _text_
665
+ const italicMatch = remaining.match(/(\*|_)([^*_]+)\1/);
666
+ if (italicMatch) {
667
+ const before = remaining.substring(0, italicMatch.index);
668
+ if (before)
669
+ parts.push(processSimpleInline(before, key++));
670
+ parts.push(_jsx("em", { children: italicMatch[2] }, key++));
671
+ const italicIndex = italicMatch.index ?? 0;
672
+ remaining = remaining.substring(italicIndex + italicMatch[0].length);
673
+ continue;
674
+ }
675
+ // No more patterns found
676
+ parts.push(remaining);
677
+ break;
678
+ }
679
+ return _jsx(_Fragment, { children: parts });
680
+ }
681
+ /**
682
+ * Helper to handle plain text without additional patterns.
683
+ */
684
+ function processSimpleInline(text, key) {
685
+ return _jsx("span", { children: text }, key);
686
+ }
687
+ function MarkdownFieldInner(props) {
688
+ const { t } = useApp();
689
+ const [preview, setPreview] = useState(false);
690
+ const value = typeof props.value === "string" ? props.value : "";
691
+ return (_jsxs("div", { className: "flex flex-col gap-1.5", children: [_jsxs("div", { className: "flex items-center gap-2 mb-1", children: [_jsx("button", { type: "button", className: `text-[11px] px-2 py-0.5 border transition-colors ${!preview
692
+ ? "bg-[var(--accent)] text-[var(--accent-fg)] border-[var(--accent)]"
693
+ : "bg-transparent text-[var(--muted)] border-[var(--border)] hover:text-[var(--txt)]"}`, onClick: () => setPreview(false), children: t("config-field.Edit", { defaultValue: "Edit" }) }), _jsx("button", { type: "button", className: `text-[11px] px-2 py-0.5 border transition-colors ${preview
694
+ ? "bg-[var(--accent)] text-[var(--accent-fg)] border-[var(--accent)]"
695
+ : "bg-transparent text-[var(--muted)] border-[var(--border)] hover:text-[var(--txt)]"}`, onClick: () => setPreview(true), children: t("config-field.Preview", { defaultValue: "Preview" }) })] }), preview ? (_jsx("div", { className: "min-h-[100px] px-3 py-2 border border-[var(--border)] bg-[var(--surface)] text-[13px] leading-relaxed", "data-config-key": props.key, "data-field-type": "markdown", children: value ? (renderMarkdown(value)) : (_jsx("span", { className: "text-[var(--muted)] italic", children: t("config-field.NothingToPreview", {
696
+ defaultValue: "Nothing to preview",
697
+ }) })) })) : (_jsx("textarea", { className: `${inputCls(!!props.errors?.length)} min-h-[100px] h-auto resize-y font-[var(--mono)]`, defaultValue: value, placeholder: props.hint.placeholder ?? "Markdown content...", "data-config-key": props.key, "data-field-type": "markdown", disabled: props.readonly, onChange: (e) => {
698
+ props.onChange(e.target.value);
699
+ fireAction(props, "change");
700
+ }, onBlur: () => fireAction(props, "blur") }))] }));
701
+ }
702
+ /** Markdown textarea with Edit/Preview toggle. */
703
+ export const renderMarkdownField = (props) => (_jsx(MarkdownFieldInner, { ...props }));
704
+ // ── 21. Checkbox Group ───────────────────────────────────────────────────
705
+ function CheckboxGroupInner(props) {
706
+ const { t } = useApp();
707
+ const selected = new Set(Array.isArray(props.value)
708
+ ? props.value
709
+ : typeof props.value === "string" && props.value
710
+ ? props.value.split(",").map((s) => s.trim())
711
+ : []);
712
+ const options = props.hint.options ??
713
+ props.schema.enum?.map((v) => ({
714
+ value: v,
715
+ label: v,
716
+ })) ??
717
+ [];
718
+ const toggle = (val) => {
719
+ const next = new Set(selected);
720
+ if (next.has(val))
721
+ next.delete(val);
722
+ else
723
+ next.add(val);
724
+ props.onChange([...next]);
725
+ fireAction(props, "change");
726
+ };
727
+ return (_jsxs("div", { className: "flex flex-col gap-1.5", "data-config-key": props.key, "data-field-type": "checkbox-group", children: [options.map((opt) => (_jsxs("label", { className: `flex items-start gap-2.5 px-3 py-2 border border-[var(--border)] bg-[var(--card)] cursor-pointer transition-colors hover:bg-[var(--bg-hover)] ${selected.has(opt.value)
728
+ ? "border-[var(--accent)] bg-[color-mix(in_srgb,var(--accent)_5%,var(--card))]"
729
+ : ""} ${opt.disabled ? "opacity-50 pointer-events-none" : ""}`, children: [_jsx("input", { type: "checkbox", checked: selected.has(opt.value), disabled: props.readonly || opt.disabled, onChange: () => toggle(opt.value), className: "mt-0.5 accent-[var(--accent)]" }), _jsxs("div", { className: "flex flex-col", children: [_jsx("span", { className: "text-[13px]", children: opt.label }), opt.description && (_jsx("span", { className: "text-[11px] text-[var(--muted)] mt-0.5", children: opt.description }))] })] }, opt.value))), options.length === 0 && (_jsx("span", { className: "text-[11px] text-[var(--muted)] italic", children: t("config-field.NoOptionsDefined", {
730
+ defaultValue: "No options defined",
731
+ }) }))] }));
732
+ }
733
+ /** Vertical checkbox list with per-option descriptions and accent highlighting. */
734
+ export const renderCheckboxGroupField = (props) => (_jsx(CheckboxGroupInner, { ...props }));
735
+ // ── 22. Group ────────────────────────────────────────────────────────────
736
+ /** Fieldset container with legend label. */
737
+ export const renderGroupField = (props) => {
738
+ const value = typeof props.value === "string" ? props.value : "";
739
+ return (_jsxs("fieldset", { className: "border border-[var(--border)] px-4 py-3 bg-[var(--surface)]", "data-config-key": props.key, "data-field-type": "group", children: [_jsx("legend", { className: "text-[12px] font-semibold text-[var(--muted)] px-1.5", children: props.hint.label ?? props.key }), _jsx("textarea", { className: `${inputCls(!!props.errors?.length)} min-h-[60px] h-auto resize-y`, defaultValue: value, placeholder: props.hint.placeholder ?? "Group configuration...", disabled: props.readonly, onChange: (e) => {
740
+ props.onChange(e.target.value);
741
+ fireAction(props, "change");
742
+ }, onBlur: () => fireAction(props, "blur") })] }));
743
+ };
744
+ // ── 23. Table ────────────────────────────────────────────────────────────
745
+ function TableFieldInner(props) {
746
+ const { t } = useApp();
747
+ const MAX_TABLE_ROWS = 50;
748
+ const columns = props.hint.columns ?? [
749
+ { key: "key", label: "Key" },
750
+ { key: "value", label: "Value" },
751
+ ];
752
+ const rawRows = Array.isArray(props.value)
753
+ ? props.value
754
+ : [];
755
+ const [rows, setRows] = useState(rawRows.length > 0
756
+ ? rawRows
757
+ : [Object.fromEntries(columns.map((c) => [c.key, ""]))]);
758
+ const emit = (next) => {
759
+ setRows(next);
760
+ props.onChange(next.filter((r) => columns.some((c) => r[c.key]?.trim())));
761
+ fireAction(props, "change");
762
+ };
763
+ const updateCell = (rowIdx, colKey, val) => {
764
+ if (["__proto__", "constructor", "prototype"].includes(colKey))
765
+ return;
766
+ const next = [...rows];
767
+ next[rowIdx] = { ...next[rowIdx], [colKey]: val };
768
+ emit(next);
769
+ };
770
+ const addRow = () => {
771
+ if (rows.length >= MAX_TABLE_ROWS)
772
+ return;
773
+ emit([...rows, Object.fromEntries(columns.map((c) => [c.key, ""]))]);
774
+ };
775
+ const removeRow = (idx) => {
776
+ if (rows.length <= 1)
777
+ return;
778
+ emit(rows.filter((_, i) => i !== idx));
779
+ };
780
+ return (_jsxs("div", { className: "flex flex-col gap-1.5", "data-config-key": props.key, "data-field-type": "table", children: [_jsx("div", { className: "border border-[var(--border)] overflow-x-auto", children: _jsxs("table", { className: "w-full text-[13px] border-collapse", children: [_jsx("thead", { children: _jsxs("tr", { className: "bg-[var(--surface)]", children: [columns.map((col) => (_jsx("th", { className: "text-left text-[11px] font-semibold text-[var(--muted)] px-3 py-1.5 border-b border-[var(--border)]", children: col.label }, col.key))), _jsx("th", { className: "w-[36px] border-b border-[var(--border)]" })] }) }), _jsx("tbody", { children: rows.map((row, ri) => (_jsxs("tr", { className: "border-b border-[var(--border)] last:border-b-0", children: [columns.map((col) => (_jsx("td", { className: "px-1 py-0.5", children: _jsx("input", { className: "w-full px-2 py-1 bg-transparent text-[13px] border-none outline-none focus:bg-[var(--bg-hover)]", value: row[col.key] ?? "", placeholder: col.label, disabled: props.readonly, onChange: (e) => updateCell(ri, col.key, e.target.value) }) }, col.key))), _jsx("td", { className: "text-center", children: !props.readonly && rows.length > 1 && (_jsx("button", { type: "button", className: "text-[var(--muted)] hover:text-[var(--destructive)] text-[14px] px-1", onClick: () => removeRow(ri), title: t("config-field.RemoveRow", {
781
+ defaultValue: "Remove row",
782
+ }), children: t("config-field.Times") })) })] }, JSON.stringify(row)))) })] }) }), !props.readonly && rows.length < MAX_TABLE_ROWS && (_jsx("button", { type: "button", className: "self-start text-[11px] text-[var(--accent)] hover:underline", onClick: addRow, children: t("config-field.AddRow", { defaultValue: "Add row" }) }))] }));
783
+ }
784
+ /** Tabular data editor with configurable columns. Max 50 rows. */
785
+ export const renderTableField = (props) => (_jsx(TableFieldInner, { ...props }));
786
+ // ── Default renderers map ───────────────────────────────────────────────
787
+ export const defaultRenderers = {
788
+ text: renderTextField,
789
+ password: renderPasswordField,
790
+ number: renderNumberField,
791
+ boolean: renderBooleanField,
792
+ url: renderUrlField,
793
+ select: RenderSelectField,
794
+ textarea: renderTextareaField,
795
+ email: renderEmailField,
796
+ color: renderColorField,
797
+ radio: renderRadioField,
798
+ multiselect: renderMultiselectField,
799
+ date: renderDateField,
800
+ json: renderJsonField,
801
+ code: renderCodeField,
802
+ array: renderArrayField,
803
+ keyvalue: renderKeyValueField,
804
+ datetime: renderDatetimeField,
805
+ file: RenderFileField,
806
+ custom: RenderCustomField,
807
+ markdown: renderMarkdownField,
808
+ "checkbox-group": renderCheckboxGroupField,
809
+ group: renderGroupField,
810
+ table: renderTableField,
811
+ };
812
+ // ── ConfigField wrapper component ───────────────────────────────────────
813
+ /**
814
+ * Wraps a field renderer with the standard label row, env key display,
815
+ * help text, and error messages.
816
+ */
817
+ export function ConfigField({ renderProps, renderer, pluginId, }) {
818
+ const { t } = useApp();
819
+ const label = renderProps.hint.label ?? renderProps.key;
820
+ const envKey = renderProps.key;
821
+ const labelDiffersFromKey = label !== envKey;
822
+ const errors = renderProps.errors ?? [];
823
+ const hasError = errors.length > 0;
824
+ const isRequiredEmpty = renderProps.required && !renderProps.isSet;
825
+ const renderFn = renderer ??
826
+ defaultRenderers[renderProps.fieldType] ??
827
+ defaultRenderers.text;
828
+ return (_jsxs("div", { id: pluginId
829
+ ? `field-${pluginId}-${renderProps.key}`
830
+ : `field-${renderProps.key}`, className: `py-2.5 group/field ${renderProps.readonly ? "opacity-50 pointer-events-none" : ""} ${isRequiredEmpty ? "relative" : ""}`, children: [isRequiredEmpty && (_jsx("div", { className: "absolute left-0 top-2.5 bottom-2.5 w-[2px] bg-[var(--destructive)] opacity-40 rounded-full" })), _jsxs("div", { className: isRequiredEmpty ? "pl-2.5" : "", children: [_jsxs("div", { className: "flex items-center gap-2 mb-1.5", children: [_jsx("span", { className: "font-semibold leading-tight truncate", style: {
831
+ fontSize: "var(--plugin-label-size)",
832
+ color: "var(--plugin-label)",
833
+ }, children: label }), renderProps.required && !renderProps.isSet && (_jsx("span", { className: "text-[10px] text-[var(--destructive)] font-semibold px-1.5 py-px bg-[color-mix(in_srgb,var(--destructive)_10%,transparent)] rounded-sm shrink-0", children: t("config-field.Required") })), renderProps.isSet && (_jsxs("span", { className: "inline-flex items-center gap-1 text-[10px] text-[var(--ok)] font-medium shrink-0", children: [_jsx("span", { className: "inline-block w-1.5 h-1.5 rounded-full bg-[var(--ok)]" }), t("config-field.Configured")] })), labelDiffersFromKey && (_jsx("code", { className: "text-[10px] font-mono text-[var(--muted)] opacity-0 group-hover/field:opacity-50 transition-opacity truncate ml-auto", children: envKey }))] }), renderFn(renderProps), hasError && (_jsx("div", { className: "mt-1.5 flex flex-col gap-0.5", children: errors.map((err) => (_jsxs("div", { className: "leading-snug flex items-start gap-1", style: {
834
+ fontSize: "var(--plugin-error-size)",
835
+ color: "var(--plugin-error)",
836
+ }, children: [_jsx("span", { className: "shrink-0 mt-px", children: t("config-field.Times") }), _jsx("span", { children: err })] }, err))) })), (renderProps.hint.help || renderProps.schema.description) && (_jsxs("div", { className: "mt-1 leading-relaxed line-clamp-2", style: {
837
+ fontSize: "var(--plugin-help-size)",
838
+ color: "var(--plugin-help)",
839
+ }, children: [renderProps.hint.help ?? renderProps.schema.description, renderProps.schema.default != null && (_jsxs("span", { className: "opacity-70", children: [" ", t("config-field.Default", { defaultValue: "Default" }), " ", String(renderProps.schema.default), ")"] }))] }))] })] }));
840
+ }