@assistant-ui/core 0.2.10 → 0.2.11

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 (362) hide show
  1. package/dist/adapters/attachment.d.ts.map +1 -1
  2. package/dist/adapters/attachment.js +22 -12
  3. package/dist/adapters/attachment.js.map +1 -1
  4. package/dist/adapters/directive-formatter.js.map +1 -1
  5. package/dist/adapters/speech.js.map +1 -1
  6. package/dist/index.d.ts +3 -1
  7. package/dist/index.js +2 -1
  8. package/dist/index.js.map +1 -1
  9. package/dist/internal.js +1 -1
  10. package/dist/model-context/frame/host.js.map +1 -1
  11. package/dist/model-context/frame/provider.js.map +1 -1
  12. package/dist/model-context/registry.js.map +1 -1
  13. package/dist/model-context/types.js.map +1 -1
  14. package/dist/react/AssistantProvider.js +1 -1
  15. package/dist/react/AssistantRuntimeProvider.d.ts +1 -1
  16. package/dist/react/AssistantRuntimeProvider.d.ts.map +1 -1
  17. package/dist/react/AssistantRuntimeProvider.js +1 -1
  18. package/dist/react/RuntimeAdapter.js +4 -2
  19. package/dist/react/RuntimeAdapter.js.map +1 -1
  20. package/dist/react/adapters/LocalStorageThreadListAdapter.js +1 -1
  21. package/dist/react/adapters/LocalStorageThreadListAdapter.js.map +1 -1
  22. package/dist/react/client/DataRenderers.d.ts.map +1 -1
  23. package/dist/react/client/DataRenderers.js +6 -5
  24. package/dist/react/client/DataRenderers.js.map +1 -1
  25. package/dist/react/client/Interactables.d.ts.map +1 -1
  26. package/dist/react/client/Interactables.js +30 -29
  27. package/dist/react/client/Interactables.js.map +1 -1
  28. package/dist/react/client/Tools.d.ts.map +1 -1
  29. package/dist/react/client/Tools.js +10 -9
  30. package/dist/react/client/Tools.js.map +1 -1
  31. package/dist/react/index.d.ts +5 -4
  32. package/dist/react/index.js +3 -2
  33. package/dist/react/model-context/define-mcp-toolkit.js.map +1 -1
  34. package/dist/react/model-context/define-toolkit.d.ts +9 -12
  35. package/dist/react/model-context/define-toolkit.d.ts.map +1 -1
  36. package/dist/react/model-context/define-toolkit.js +1 -1
  37. package/dist/react/model-context/define-toolkit.js.map +1 -1
  38. package/dist/react/model-context/external-tool.d.ts +14 -0
  39. package/dist/react/model-context/external-tool.d.ts.map +1 -0
  40. package/dist/react/model-context/external-tool.js +17 -0
  41. package/dist/react/model-context/external-tool.js.map +1 -0
  42. package/dist/react/model-context/human-tool.d.ts +27 -0
  43. package/dist/react/model-context/human-tool.d.ts.map +1 -0
  44. package/dist/react/model-context/human-tool.js +30 -0
  45. package/dist/react/model-context/human-tool.js.map +1 -0
  46. package/dist/react/model-context/toolbox.d.ts +3 -3
  47. package/dist/react/model-context/toolbox.js.map +1 -1
  48. package/dist/react/model-context/useAssistantContext.js +1 -1
  49. package/dist/react/model-context/useAssistantContext.js.map +1 -1
  50. package/dist/react/model-context/useAssistantDataUI.js +1 -1
  51. package/dist/react/model-context/useAssistantDataUI.js.map +1 -1
  52. package/dist/react/model-context/useAssistantInstructions.js +1 -1
  53. package/dist/react/model-context/useAssistantInstructions.js.map +1 -1
  54. package/dist/react/model-context/useAssistantInteractable.js +1 -1
  55. package/dist/react/model-context/useAssistantInteractable.js.map +1 -1
  56. package/dist/react/model-context/useAssistantTool.js +1 -1
  57. package/dist/react/model-context/useAssistantTool.js.map +1 -1
  58. package/dist/react/model-context/useAssistantToolUI.js +1 -1
  59. package/dist/react/model-context/useAssistantToolUI.js.map +1 -1
  60. package/dist/react/model-context/useAuiToolOverrides.js +1 -1
  61. package/dist/react/model-context/useAuiToolOverrides.js.map +1 -1
  62. package/dist/react/model-context/useInlineRender.js +1 -1
  63. package/dist/react/model-context/useInlineRender.js.map +1 -1
  64. package/dist/react/model-context/useInteractableState.js +1 -1
  65. package/dist/react/model-context/useInteractableState.js.map +1 -1
  66. package/dist/react/model-context/useToolArgsStatus.js +1 -1
  67. package/dist/react/primitive-hooks/useActionBarCopy.js +1 -1
  68. package/dist/react/primitive-hooks/useActionBarCopy.js.map +1 -1
  69. package/dist/react/primitive-hooks/useActionBarEdit.js +1 -1
  70. package/dist/react/primitive-hooks/useActionBarEdit.js.map +1 -1
  71. package/dist/react/primitive-hooks/useActionBarFeedback.js +1 -1
  72. package/dist/react/primitive-hooks/useActionBarFeedback.js.map +1 -1
  73. package/dist/react/primitive-hooks/useActionBarReload.js +1 -1
  74. package/dist/react/primitive-hooks/useActionBarReload.js.map +1 -1
  75. package/dist/react/primitive-hooks/useActionBarSpeak.js +1 -1
  76. package/dist/react/primitive-hooks/useActionBarSpeak.js.map +1 -1
  77. package/dist/react/primitive-hooks/useActionBarStopSpeaking.js +1 -1
  78. package/dist/react/primitive-hooks/useActionBarStopSpeaking.js.map +1 -1
  79. package/dist/react/primitive-hooks/useBranchPickerNext.js +1 -1
  80. package/dist/react/primitive-hooks/useBranchPickerNext.js.map +1 -1
  81. package/dist/react/primitive-hooks/useBranchPickerPrevious.js +1 -1
  82. package/dist/react/primitive-hooks/useBranchPickerPrevious.js.map +1 -1
  83. package/dist/react/primitive-hooks/useComposerAddAttachment.js +1 -1
  84. package/dist/react/primitive-hooks/useComposerAddAttachment.js.map +1 -1
  85. package/dist/react/primitive-hooks/useComposerCancel.js +1 -1
  86. package/dist/react/primitive-hooks/useComposerCancel.js.map +1 -1
  87. package/dist/react/primitive-hooks/useComposerDictate.js +1 -1
  88. package/dist/react/primitive-hooks/useComposerDictate.js.map +1 -1
  89. package/dist/react/primitive-hooks/useComposerSend.js +1 -1
  90. package/dist/react/primitive-hooks/useComposerSend.js.map +1 -1
  91. package/dist/react/primitive-hooks/useEditComposerCancel.js +1 -1
  92. package/dist/react/primitive-hooks/useEditComposerCancel.js.map +1 -1
  93. package/dist/react/primitive-hooks/useEditComposerSend.js +1 -1
  94. package/dist/react/primitive-hooks/useEditComposerSend.js.map +1 -1
  95. package/dist/react/primitive-hooks/useMessageBranching.js +1 -1
  96. package/dist/react/primitive-hooks/useMessageBranching.js.map +1 -1
  97. package/dist/react/primitive-hooks/useMessageReload.js +1 -1
  98. package/dist/react/primitive-hooks/useMessageReload.js.map +1 -1
  99. package/dist/react/primitive-hooks/useSuggestionTrigger.js +1 -1
  100. package/dist/react/primitive-hooks/useSuggestionTrigger.js.map +1 -1
  101. package/dist/react/primitive-hooks/useThreadListItemArchive.js +1 -1
  102. package/dist/react/primitive-hooks/useThreadListItemArchive.js.map +1 -1
  103. package/dist/react/primitive-hooks/useThreadListItemDelete.js +1 -1
  104. package/dist/react/primitive-hooks/useThreadListItemDelete.js.map +1 -1
  105. package/dist/react/primitive-hooks/useThreadListItemTrigger.js +1 -1
  106. package/dist/react/primitive-hooks/useThreadListItemTrigger.js.map +1 -1
  107. package/dist/react/primitive-hooks/useThreadListItemUnarchive.js +1 -1
  108. package/dist/react/primitive-hooks/useThreadListItemUnarchive.js.map +1 -1
  109. package/dist/react/primitive-hooks/useThreadListLoadMore.js +1 -1
  110. package/dist/react/primitive-hooks/useThreadListLoadMore.js.map +1 -1
  111. package/dist/react/primitive-hooks/useThreadListNew.js +1 -1
  112. package/dist/react/primitive-hooks/useThreadListNew.js.map +1 -1
  113. package/dist/react/primitive-hooks/useVoice.js +1 -1
  114. package/dist/react/primitive-hooks/useVoice.js.map +1 -1
  115. package/dist/react/primitives/chainOfThought/ChainOfThoughtParts.d.ts +1 -1
  116. package/dist/react/primitives/chainOfThought/ChainOfThoughtParts.js +1 -1
  117. package/dist/react/primitives/chainOfThought/ChainOfThoughtParts.js.map +1 -1
  118. package/dist/react/primitives/composer/ComposerAttachments.js +1 -1
  119. package/dist/react/primitives/composer/ComposerAttachments.js.map +1 -1
  120. package/dist/react/primitives/composer/ComposerQueue.js +1 -1
  121. package/dist/react/primitives/composer/ComposerQueue.js.map +1 -1
  122. package/dist/react/primitives/generativeUI/GenerativeUI.js +1 -1
  123. package/dist/react/primitives/generativeUI/GenerativeUI.js.map +1 -1
  124. package/dist/react/primitives/message/MessageAttachments.js +1 -1
  125. package/dist/react/primitives/message/MessageAttachments.js.map +1 -1
  126. package/dist/react/primitives/message/MessageGroupedParts.js +1 -1
  127. package/dist/react/primitives/message/MessageGroupedParts.js.map +1 -1
  128. package/dist/react/primitives/message/MessageParts.d.ts +1 -1
  129. package/dist/react/primitives/message/MessageParts.js +1 -1
  130. package/dist/react/primitives/message/MessageParts.js.map +1 -1
  131. package/dist/react/primitives/message/MessageQuote.js +1 -1
  132. package/dist/react/primitives/part/PartMessages.d.ts +2 -2
  133. package/dist/react/primitives/part/PartMessages.js +3 -3
  134. package/dist/react/primitives/part/PartMessages.js.map +1 -1
  135. package/dist/react/primitives/thread/ThreadMessages.js +1 -1
  136. package/dist/react/primitives/thread/ThreadMessages.js.map +1 -1
  137. package/dist/react/primitives/thread/ThreadSuggestions.js +1 -1
  138. package/dist/react/primitives/thread/ThreadSuggestions.js.map +1 -1
  139. package/dist/react/primitives/threadList/ThreadListItems.js +1 -1
  140. package/dist/react/primitives/threadList/ThreadListItems.js.map +1 -1
  141. package/dist/react/providers/AttachmentByIndexProvider.js.map +1 -1
  142. package/dist/react/providers/ChainOfThoughtByIndicesProvider.js.map +1 -1
  143. package/dist/react/providers/ChainOfThoughtPartByIndexProvider.js.map +1 -1
  144. package/dist/react/providers/MessageByIndexProvider.js.map +1 -1
  145. package/dist/react/providers/PartByIndexProvider.js.map +1 -1
  146. package/dist/react/providers/QueueItemByIndexProvider.js.map +1 -1
  147. package/dist/react/providers/ReadonlyThreadProvider.js +1 -1
  148. package/dist/react/providers/ReadonlyThreadProvider.js.map +1 -1
  149. package/dist/react/providers/SuggestionByIndexProvider.js.map +1 -1
  150. package/dist/react/providers/TextMessagePartProvider.d.ts.map +1 -1
  151. package/dist/react/providers/TextMessagePartProvider.js +4 -3
  152. package/dist/react/providers/TextMessagePartProvider.js.map +1 -1
  153. package/dist/react/providers/ThreadListItemByIndexProvider.js.map +1 -1
  154. package/dist/react/runtimes/RemoteThreadListHookInstanceManager.d.ts +7 -0
  155. package/dist/react/runtimes/RemoteThreadListHookInstanceManager.d.ts.map +1 -1
  156. package/dist/react/runtimes/RemoteThreadListHookInstanceManager.js +1 -1
  157. package/dist/react/runtimes/RemoteThreadListHookInstanceManager.js.map +1 -1
  158. package/dist/react/runtimes/RemoteThreadListThreadListRuntimeCore.d.ts +7 -0
  159. package/dist/react/runtimes/RemoteThreadListThreadListRuntimeCore.d.ts.map +1 -1
  160. package/dist/react/runtimes/RemoteThreadListThreadListRuntimeCore.js +1 -1
  161. package/dist/react/runtimes/RemoteThreadListThreadListRuntimeCore.js.map +1 -1
  162. package/dist/react/runtimes/RuntimeAdapterProvider.js +1 -1
  163. package/dist/react/runtimes/cloud/AssistantCloudThreadHistoryAdapter.js +1 -1
  164. package/dist/react/runtimes/cloud/AssistantCloudThreadHistoryAdapter.js.map +1 -1
  165. package/dist/react/runtimes/cloud/useCloudThreadListAdapter.js +1 -1
  166. package/dist/react/runtimes/cloud/useCloudThreadListAdapter.js.map +1 -1
  167. package/dist/react/runtimes/createMessageConverter.d.ts +2 -2
  168. package/dist/react/runtimes/createMessageConverter.d.ts.map +1 -1
  169. package/dist/react/runtimes/createMessageConverter.js.map +1 -1
  170. package/dist/react/runtimes/external-message-converter.d.ts +4 -3
  171. package/dist/react/runtimes/external-message-converter.d.ts.map +1 -1
  172. package/dist/react/runtimes/external-message-converter.js +1 -1
  173. package/dist/react/runtimes/external-message-converter.js.map +1 -1
  174. package/dist/react/runtimes/useExternalStoreRuntime.js +1 -1
  175. package/dist/react/runtimes/useExternalStoreSharedOptions.js +1 -1
  176. package/dist/react/runtimes/useLocalRuntime.d.ts +2 -1
  177. package/dist/react/runtimes/useLocalRuntime.d.ts.map +1 -1
  178. package/dist/react/runtimes/useLocalRuntime.js +4 -3
  179. package/dist/react/runtimes/useLocalRuntime.js.map +1 -1
  180. package/dist/react/runtimes/useRemoteThreadListRuntime.js +1 -1
  181. package/dist/react/runtimes/useRemoteThreadListRuntime.js.map +1 -1
  182. package/dist/react/utils/groupParts.d.ts +1 -1
  183. package/dist/react/utils/groupParts.js.map +1 -1
  184. package/dist/runtime/api/attachment-runtime.js.map +1 -1
  185. package/dist/runtime/api/composer-runtime.d.ts +8 -2
  186. package/dist/runtime/api/composer-runtime.d.ts.map +1 -1
  187. package/dist/runtime/api/composer-runtime.js +14 -0
  188. package/dist/runtime/api/composer-runtime.js.map +1 -1
  189. package/dist/runtime/api/message-part-runtime.js.map +1 -1
  190. package/dist/runtime/api/message-runtime.js +1 -1
  191. package/dist/runtime/api/message-runtime.js.map +1 -1
  192. package/dist/runtime/api/thread-list-item-runtime.js.map +1 -1
  193. package/dist/runtime/api/thread-runtime.d.ts +7 -0
  194. package/dist/runtime/api/thread-runtime.d.ts.map +1 -1
  195. package/dist/runtime/api/thread-runtime.js.map +1 -1
  196. package/dist/runtime/base/base-composer-runtime-core.d.ts +4 -0
  197. package/dist/runtime/base/base-composer-runtime-core.d.ts.map +1 -1
  198. package/dist/runtime/base/base-composer-runtime-core.js +7 -1
  199. package/dist/runtime/base/base-composer-runtime-core.js.map +1 -1
  200. package/dist/runtime/base/base-thread-runtime-core.js.map +1 -1
  201. package/dist/runtime/base/default-thread-composer-runtime-core.d.ts +4 -0
  202. package/dist/runtime/base/default-thread-composer-runtime-core.d.ts.map +1 -1
  203. package/dist/runtime/base/default-thread-composer-runtime-core.js +17 -1
  204. package/dist/runtime/base/default-thread-composer-runtime-core.js.map +1 -1
  205. package/dist/runtime/interfaces/composer-runtime-core.d.ts +6 -1
  206. package/dist/runtime/interfaces/composer-runtime-core.d.ts.map +1 -1
  207. package/dist/runtime/interfaces/thread-runtime-core.d.ts +4 -0
  208. package/dist/runtime/interfaces/thread-runtime-core.d.ts.map +1 -1
  209. package/dist/runtime/queue/external-thread-queue-adapter.d.ts +20 -0
  210. package/dist/runtime/queue/external-thread-queue-adapter.d.ts.map +1 -0
  211. package/dist/runtime/queue/external-thread-queue-adapter.js +0 -0
  212. package/dist/runtime/queue/message-queue.d.ts +20 -0
  213. package/dist/runtime/queue/message-queue.d.ts.map +1 -0
  214. package/dist/runtime/queue/message-queue.js +97 -0
  215. package/dist/runtime/queue/message-queue.js.map +1 -0
  216. package/dist/runtime/utils/message-repository.js.map +1 -1
  217. package/dist/runtime/utils/thread-message-like.js.map +1 -1
  218. package/dist/runtimes/external-store/external-store-adapter.d.ts +3 -1
  219. package/dist/runtimes/external-store/external-store-adapter.d.ts.map +1 -1
  220. package/dist/runtimes/external-store/external-store-runtime-core.js.map +1 -1
  221. package/dist/runtimes/external-store/external-store-thread-runtime-core.d.ts +4 -0
  222. package/dist/runtimes/external-store/external-store-thread-runtime-core.d.ts.map +1 -1
  223. package/dist/runtimes/external-store/external-store-thread-runtime-core.js +20 -2
  224. package/dist/runtimes/external-store/external-store-thread-runtime-core.js.map +1 -1
  225. package/dist/runtimes/local/local-runtime-core.js.map +1 -1
  226. package/dist/runtimes/local/local-runtime-options.d.ts +5 -0
  227. package/dist/runtimes/local/local-runtime-options.d.ts.map +1 -1
  228. package/dist/runtimes/local/local-thread-runtime-core.d.ts +7 -0
  229. package/dist/runtimes/local/local-thread-runtime-core.d.ts.map +1 -1
  230. package/dist/runtimes/local/local-thread-runtime-core.js +45 -0
  231. package/dist/runtimes/local/local-thread-runtime-core.js.map +1 -1
  232. package/dist/runtimes/readonly/ReadonlyThreadRuntimeCore.d.ts +3 -0
  233. package/dist/runtimes/readonly/ReadonlyThreadRuntimeCore.d.ts.map +1 -1
  234. package/dist/runtimes/readonly/ReadonlyThreadRuntimeCore.js +3 -0
  235. package/dist/runtimes/readonly/ReadonlyThreadRuntimeCore.js.map +1 -1
  236. package/dist/runtimes/remote-thread-list/empty-thread-core.d.ts.map +1 -1
  237. package/dist/runtimes/remote-thread-list/empty-thread-core.js +3 -0
  238. package/dist/runtimes/remote-thread-list/empty-thread-core.js.map +1 -1
  239. package/dist/runtimes/remote-thread-list/remote-thread-state.js.map +1 -1
  240. package/dist/runtimes/tool-invocations/ToolInvocationTracker.js.map +1 -1
  241. package/dist/store/clients/chain-of-thought-client.d.ts.map +1 -1
  242. package/dist/store/clients/chain-of-thought-client.js +6 -5
  243. package/dist/store/clients/chain-of-thought-client.js.map +1 -1
  244. package/dist/store/clients/model-context-client.d.ts.map +1 -1
  245. package/dist/store/clients/model-context-client.js +6 -5
  246. package/dist/store/clients/model-context-client.js.map +1 -1
  247. package/dist/store/clients/no-op-composer-client.d.ts.map +1 -1
  248. package/dist/store/clients/no-op-composer-client.js +4 -3
  249. package/dist/store/clients/no-op-composer-client.js.map +1 -1
  250. package/dist/store/clients/runtime-adapter.d.ts.map +1 -1
  251. package/dist/store/clients/runtime-adapter.js +7 -6
  252. package/dist/store/clients/runtime-adapter.js.map +1 -1
  253. package/dist/store/clients/suggestions.d.ts.map +1 -1
  254. package/dist/store/clients/suggestions.js +7 -6
  255. package/dist/store/clients/suggestions.js.map +1 -1
  256. package/dist/store/clients/thread-message-client.d.ts.map +1 -1
  257. package/dist/store/clients/thread-message-client.js +13 -12
  258. package/dist/store/clients/thread-message-client.js.map +1 -1
  259. package/dist/store/index.d.ts +1 -1
  260. package/dist/store/runtime-clients/attachment-runtime-client.d.ts.map +1 -1
  261. package/dist/store/runtime-clients/attachment-runtime-client.js +3 -3
  262. package/dist/store/runtime-clients/attachment-runtime-client.js.map +1 -1
  263. package/dist/store/runtime-clients/composer-runtime-client.d.ts +12 -5
  264. package/dist/store/runtime-clients/composer-runtime-client.d.ts.map +1 -1
  265. package/dist/store/runtime-clients/composer-runtime-client.js +32 -16
  266. package/dist/store/runtime-clients/composer-runtime-client.js.map +1 -1
  267. package/dist/store/runtime-clients/message-part-runtime-client.d.ts.map +1 -1
  268. package/dist/store/runtime-clients/message-part-runtime-client.js +3 -3
  269. package/dist/store/runtime-clients/message-part-runtime-client.js.map +1 -1
  270. package/dist/store/runtime-clients/message-runtime-client.d.ts +6 -3
  271. package/dist/store/runtime-clients/message-runtime-client.d.ts.map +1 -1
  272. package/dist/store/runtime-clients/message-runtime-client.js +17 -16
  273. package/dist/store/runtime-clients/message-runtime-client.js.map +1 -1
  274. package/dist/store/runtime-clients/thread-list-item-runtime-client.d.ts.map +1 -1
  275. package/dist/store/runtime-clients/thread-list-item-runtime-client.js +8 -7
  276. package/dist/store/runtime-clients/thread-list-item-runtime-client.js.map +1 -1
  277. package/dist/store/runtime-clients/thread-list-runtime-client.d.ts.map +1 -1
  278. package/dist/store/runtime-clients/thread-list-runtime-client.js +11 -10
  279. package/dist/store/runtime-clients/thread-list-runtime-client.js.map +1 -1
  280. package/dist/store/runtime-clients/thread-runtime-client.d.ts.map +1 -1
  281. package/dist/store/runtime-clients/thread-runtime-client.js +15 -14
  282. package/dist/store/runtime-clients/thread-runtime-client.js.map +1 -1
  283. package/dist/store/runtime-clients/useSubscribable.d.ts +7 -0
  284. package/dist/store/runtime-clients/useSubscribable.d.ts.map +1 -0
  285. package/dist/store/runtime-clients/useSubscribable.js +16 -0
  286. package/dist/store/runtime-clients/useSubscribable.js.map +1 -0
  287. package/dist/store/scope-registration.d.ts +1 -1
  288. package/dist/store/scopes/composer.d.ts +1 -1
  289. package/dist/store/scopes/queue-item.d.ts +2 -1
  290. package/dist/store/scopes/queue-item.d.ts.map +1 -1
  291. package/dist/store/scopes/queue-item.js +6 -0
  292. package/dist/store/scopes/queue-item.js.map +1 -0
  293. package/dist/store/scopes/thread.d.ts +1 -1
  294. package/dist/store/scopes/threads.d.ts +1 -1
  295. package/dist/types/message.d.ts +2 -1
  296. package/dist/types/message.d.ts.map +1 -1
  297. package/dist/types/message.js.map +1 -1
  298. package/dist/utils/composite-context-provider.d.ts +1 -1
  299. package/dist/utils/composite-context-provider.js +3 -1
  300. package/dist/utils/composite-context-provider.js.map +1 -1
  301. package/dist/utils/json/is-json.js.map +1 -1
  302. package/dist/utils/text.js.map +1 -1
  303. package/package.json +14 -10
  304. package/src/adapters/attachment.ts +24 -4
  305. package/src/index.ts +8 -0
  306. package/src/react/RuntimeAdapter.ts +6 -4
  307. package/src/react/client/DataRenderers.ts +48 -42
  308. package/src/react/client/Interactables.ts +263 -267
  309. package/src/react/client/Tools.ts +122 -129
  310. package/src/react/index.ts +3 -1
  311. package/src/react/model-context/define-toolkit.test.ts +14 -7
  312. package/src/react/model-context/define-toolkit.ts +18 -19
  313. package/src/react/model-context/external-tool.ts +16 -0
  314. package/src/react/model-context/{hitl.ts → human-tool.ts} +13 -8
  315. package/src/react/model-context/toolbox.ts +3 -3
  316. package/src/react/primitives/message/MessageGroupedParts.tsx +1 -1
  317. package/src/react/primitives/part/PartMessages.tsx +2 -2
  318. package/src/react/providers/TextMessagePartProvider.tsx +31 -32
  319. package/src/react/runtimes/createMessageConverter.ts +2 -1
  320. package/src/react/runtimes/external-message-converter.ts +5 -3
  321. package/src/react/runtimes/useLocalRuntime.ts +2 -0
  322. package/src/runtime/api/composer-runtime.ts +26 -0
  323. package/src/runtime/base/base-composer-runtime-core.ts +11 -0
  324. package/src/runtime/base/default-thread-composer-runtime-core.ts +22 -0
  325. package/src/runtime/interfaces/composer-runtime-core.ts +7 -0
  326. package/src/runtime/interfaces/thread-runtime-core.ts +5 -0
  327. package/src/runtime/queue/external-thread-queue-adapter.ts +14 -0
  328. package/src/runtime/queue/message-queue.ts +128 -0
  329. package/src/runtimes/external-store/external-store-adapter.ts +3 -0
  330. package/src/runtimes/external-store/external-store-thread-runtime-core.ts +31 -2
  331. package/src/runtimes/local/local-runtime-options.ts +6 -0
  332. package/src/runtimes/local/local-thread-runtime-core.ts +70 -0
  333. package/src/runtimes/readonly/ReadonlyThreadRuntimeCore.ts +4 -0
  334. package/src/runtimes/remote-thread-list/empty-thread-core.ts +4 -0
  335. package/src/store/clients/chain-of-thought-client.ts +24 -25
  336. package/src/store/clients/model-context-client.ts +22 -19
  337. package/src/store/clients/no-op-composer-client.ts +69 -66
  338. package/src/store/clients/runtime-adapter.ts +9 -6
  339. package/src/store/clients/suggestions.ts +41 -40
  340. package/src/store/clients/thread-message-client.ts +127 -132
  341. package/src/store/runtime-clients/attachment-runtime-client.ts +7 -3
  342. package/src/store/runtime-clients/composer-runtime-client.ts +142 -113
  343. package/src/store/runtime-clients/message-part-runtime-client.ts +16 -14
  344. package/src/store/runtime-clients/message-runtime-client.ts +124 -122
  345. package/src/store/runtime-clients/thread-list-item-runtime-client.ts +44 -45
  346. package/src/store/runtime-clients/thread-list-runtime-client.ts +83 -80
  347. package/src/store/runtime-clients/thread-runtime-client.ts +113 -119
  348. package/src/store/runtime-clients/{tap-subscribable.ts → useSubscribable.ts} +4 -4
  349. package/src/store/scopes/queue-item.ts +2 -0
  350. package/src/tests/attachment-adapters.test.ts +86 -0
  351. package/src/tests/external-store-thread-runtime-core.test.ts +125 -0
  352. package/src/tests/message-queue.test.ts +168 -0
  353. package/src/types/message.ts +2 -0
  354. package/src/utils/composite-context-provider.ts +3 -1
  355. package/dist/react/model-context/hitl.d.ts +0 -23
  356. package/dist/react/model-context/hitl.d.ts.map +0 -1
  357. package/dist/react/model-context/hitl.js +0 -26
  358. package/dist/react/model-context/hitl.js.map +0 -1
  359. package/dist/store/runtime-clients/tap-subscribable.d.ts +0 -7
  360. package/dist/store/runtime-clients/tap-subscribable.d.ts.map +0 -1
  361. package/dist/store/runtime-clients/tap-subscribable.js +0 -16
  362. package/dist/store/runtime-clients/tap-subscribable.js.map +0 -1
@@ -1 +1 @@
1
- {"version":3,"file":"MessageParts.js","names":[],"sources":["../../../../src/react/primitives/message/MessageParts.tsx"],"sourcesContent":["import {\n type ComponentType,\n type FC,\n type ReactNode,\n memo,\n type PropsWithChildren,\n useMemo,\n} from \"react\";\nimport {\n RenderChildrenWithAccessor,\n useAuiState,\n useAui,\n} from \"@assistant-ui/store\";\nimport type { PartState } from \"../../../store/scopes/part\";\nimport { PartByIndexProvider } from \"../../providers/PartByIndexProvider\";\nimport { TextMessagePartProvider } from \"../../providers/TextMessagePartProvider\";\nimport { ChainOfThoughtByIndicesProvider } from \"../../providers/ChainOfThoughtByIndicesProvider\";\nimport { getMessageQuote } from \"../../utils/getMessageQuote\";\nimport type {\n Unstable_AudioMessagePartComponent,\n DataMessagePartComponent,\n DataMessagePartProps,\n EmptyMessagePartComponent,\n TextMessagePartComponent,\n ImageMessagePartComponent,\n SourceMessagePartComponent,\n ToolCallMessagePartComponent,\n ToolCallMessagePartProps,\n FileMessagePartComponent,\n ReasoningMessagePartComponent,\n ReasoningGroupComponent,\n QuoteMessagePartComponent,\n GenerativeUIComponentRegistry,\n} from \"../../types/MessagePartComponentTypes\";\nimport { GenerativeUIRender } from \"../generativeUI/GenerativeUI\";\nimport {\n isMcpAppUri,\n type MessagePartStatus,\n type GenerativeUIMessagePart,\n} from \"../../../types/message\";\nimport type { DataRenderersState } from \"../../types/scopes/dataRenderers\";\nimport type { ToolsState } from \"../../types/scopes/tools\";\nimport { useShallow } from \"zustand/shallow\";\n\ntype MessagePartRange =\n | { type: \"single\"; index: number }\n | { type: \"toolGroup\"; startIndex: number; endIndex: number }\n | { type: \"reasoningGroup\"; startIndex: number; endIndex: number }\n | { type: \"chainOfThoughtGroup\"; startIndex: number; endIndex: number };\n\n/**\n * Creates a group state manager for a specific part type.\n * Returns functions to start, end, and finalize groups.\n */\nconst createGroupState = <\n T extends \"toolGroup\" | \"reasoningGroup\" | \"chainOfThoughtGroup\",\n>(\n groupType: T,\n) => {\n let start = -1;\n\n return {\n startGroup: (index: number) => {\n if (start === -1) {\n start = index;\n }\n },\n endGroup: (endIndex: number, ranges: MessagePartRange[]) => {\n if (start !== -1) {\n ranges.push({\n type: groupType,\n startIndex: start,\n endIndex,\n } as MessagePartRange);\n start = -1;\n }\n },\n finalize: (endIndex: number, ranges: MessagePartRange[]) => {\n if (start !== -1) {\n ranges.push({\n type: groupType,\n startIndex: start,\n endIndex,\n } as MessagePartRange);\n }\n },\n };\n};\n\n/**\n * Groups consecutive tool-call and reasoning message parts into ranges.\n * Always groups tool calls and reasoning parts, even if there's only one.\n * When useChainOfThought is true, groups tool-call and reasoning parts together.\n */\nconst groupMessageParts = (\n messageTypes: readonly string[],\n useChainOfThought: boolean,\n): MessagePartRange[] => {\n const ranges: MessagePartRange[] = [];\n\n if (useChainOfThought) {\n const chainOfThoughtGroup = createGroupState(\"chainOfThoughtGroup\");\n\n for (let i = 0; i < messageTypes.length; i++) {\n const type = messageTypes[i];\n\n if (type === \"tool-call\" || type === \"reasoning\") {\n chainOfThoughtGroup.startGroup(i);\n } else {\n chainOfThoughtGroup.endGroup(i - 1, ranges);\n ranges.push({ type: \"single\", index: i });\n }\n }\n\n chainOfThoughtGroup.finalize(messageTypes.length - 1, ranges);\n } else {\n const toolGroup = createGroupState(\"toolGroup\");\n const reasoningGroup = createGroupState(\"reasoningGroup\");\n\n for (let i = 0; i < messageTypes.length; i++) {\n const type = messageTypes[i];\n\n if (type === \"tool-call\") {\n reasoningGroup.endGroup(i - 1, ranges);\n toolGroup.startGroup(i);\n } else if (type === \"reasoning\") {\n toolGroup.endGroup(i - 1, ranges);\n reasoningGroup.startGroup(i);\n } else {\n toolGroup.endGroup(i - 1, ranges);\n reasoningGroup.endGroup(i - 1, ranges);\n ranges.push({ type: \"single\", index: i });\n }\n }\n\n toolGroup.finalize(messageTypes.length - 1, ranges);\n reasoningGroup.finalize(messageTypes.length - 1, ranges);\n }\n\n return ranges;\n};\n\nconst useMessagePartsGroups = (\n useChainOfThought: boolean,\n): MessagePartRange[] => {\n const messageTypes = useAuiState(\n useShallow((s) => s.message.parts.map((c: any) => c.type)),\n );\n\n return useMemo(() => {\n if (messageTypes.length === 0) {\n return [];\n }\n return groupMessageParts(messageTypes, useChainOfThought);\n }, [messageTypes, useChainOfThought]);\n};\n\nexport namespace MessagePrimitiveParts {\n type DataConfig = {\n /** Map data event names to specific components */\n by_name?: Record<string, DataMessagePartComponent | undefined> | undefined;\n /** Fallback component for unmatched data events */\n Fallback?: DataMessagePartComponent | undefined;\n };\n\n type BaseComponents = {\n /** Component for rendering empty messages */\n Empty?: EmptyMessagePartComponent | undefined;\n /** Component for rendering text content */\n Text?: TextMessagePartComponent | undefined;\n /** Component for rendering source content */\n Source?: SourceMessagePartComponent | undefined;\n /** Component for rendering image content */\n Image?: ImageMessagePartComponent | undefined;\n /** Component for rendering file content */\n File?: FileMessagePartComponent | undefined;\n /** Component for rendering audio content (experimental) */\n Unstable_Audio?: Unstable_AudioMessagePartComponent | undefined;\n /** Configuration for data part rendering */\n data?: DataConfig | undefined;\n /** Component for rendering a quoted message reference (from metadata, not parts) */\n Quote?: QuoteMessagePartComponent | undefined;\n /**\n * Configuration for generative-ui part rendering.\n *\n * `components` is the consumer-provided allowlist of React components\n * the agent's JSON spec is permitted to render. Any name not present in\n * the registry is rejected with a typed `GenerativeUIRenderError` —\n * this is the security boundary in the same-realm rendering path.\n */\n generativeUI?:\n | {\n /** The component allowlist (the security boundary). */\n components: GenerativeUIComponentRegistry;\n /** Optional fallback for unknown component names. */\n Fallback?:\n | ComponentType<{ component: string; props?: unknown }>\n | undefined;\n }\n | undefined;\n };\n\n type ToolsConfig =\n | {\n /** Map of tool names to their specific components */\n by_name?:\n | Record<string, ToolCallMessagePartComponent | undefined>\n | undefined;\n /** Fallback component for unregistered tools */\n Fallback?: ComponentType<ToolCallMessagePartProps> | undefined;\n }\n | {\n /** Override component that handles all tool calls */\n Override: ComponentType<ToolCallMessagePartProps>;\n };\n\n /**\n * Standard component configuration for rendering reasoning and tool-call parts\n * individually (with optional grouping).\n *\n * Cannot be combined with `ChainOfThought`.\n */\n type StandardComponents = BaseComponents & {\n /** Component for rendering reasoning content (typically hidden) */\n Reasoning?: ReasoningMessagePartComponent | undefined;\n /** Configuration for tool call rendering */\n tools?: ToolsConfig | undefined;\n\n /**\n * Component for rendering grouped consecutive tool calls.\n *\n * @param startIndex - Index of the first tool call in the group\n * @param endIndex - Index of the last tool call in the group\n * @param children - Rendered tool call components to display within the group\n *\n * @deprecated Use `<MessagePrimitive.GroupedParts>` with a custom `groupBy` instead.\n */\n ToolGroup?: ComponentType<\n PropsWithChildren<{ startIndex: number; endIndex: number }>\n >;\n\n /**\n * Component for rendering grouped reasoning parts.\n *\n * @param startIndex - Index of the first reasoning part in the group\n * @param endIndex - Index of the last reasoning part in the group\n * @param children - Rendered reasoning part components\n *\n * @deprecated Use `<MessagePrimitive.GroupedParts>` with a custom `groupBy` instead.\n */\n ReasoningGroup?: ReasoningGroupComponent;\n\n ChainOfThought?: never;\n };\n\n /**\n * Chain of thought component configuration.\n *\n * When `ChainOfThought` is set, it takes control of rendering ALL reasoning and\n * tool-call parts in the message. The `Reasoning`, `tools`, `ReasoningGroup`, and\n * `ToolGroup` components cannot be used alongside it.\n */\n type ChainOfThoughtComponents = BaseComponents & {\n /**\n * @deprecated Use `<MessagePrimitive.GroupedParts>` with a `groupBy`\n * that returns `[\"group-thought\", ...]` for reasoning and tool-call\n * parts. See `@assistant-ui/ui` for a worked example.\n */\n ChainOfThought: ComponentType;\n\n Reasoning?: never;\n tools?: never;\n ToolGroup?: never;\n ReasoningGroup?: never;\n };\n\n export type Props =\n | {\n /**\n * Component configuration for rendering different types of message content.\n *\n * Use either `Reasoning`/`tools`/`ToolGroup`/`ReasoningGroup` for standard rendering,\n * or `ChainOfThought` to group all reasoning and tool-call parts into a single\n * collapsible component. These two modes are mutually exclusive.\n */\n components?: StandardComponents | ChainOfThoughtComponents | undefined;\n /**\n * When enabled, shows the Empty component if the last part in the message\n * is anything other than Text or Reasoning.\n *\n * @experimental This API is experimental and may change in future versions.\n * @default true\n */\n unstable_showEmptyOnNonTextEnd?: boolean | undefined;\n children?: never;\n }\n | {\n /** Render function called for each part. Receives the enriched part state. */\n children: (value: { part: EnrichedPartState }) => ReactNode;\n components?: never;\n unstable_showEmptyOnNonTextEnd?: never;\n };\n}\n\nconst ToolUIDisplay = ({\n Fallback,\n ...props\n}: {\n Fallback: ToolCallMessagePartComponent | undefined;\n} & ToolCallMessagePartProps) => {\n const Render = useAuiState(\n (s) => s.tools.toolUIs[props.toolName]?.[0]?.render ?? Fallback,\n );\n if (!Render) return null;\n return <Render {...props} />;\n};\n\nconst getDataRenderer = (\n dataRenderers: DataRenderersState,\n name: string,\n inlineFallback: DataMessagePartComponent | undefined,\n): DataMessagePartComponent | undefined => {\n const named = dataRenderers.renderers[name]?.[0];\n if (named) return named;\n return dataRenderers.fallbacks[0] ?? inlineFallback;\n};\n\nconst DataUIDisplay = ({\n Fallback,\n ...props\n}: {\n Fallback: DataMessagePartComponent | undefined;\n} & DataMessagePartProps) => {\n const Render = useAuiState((s) =>\n getDataRenderer(s.dataRenderers, props.name, Fallback),\n );\n if (!Render) return null;\n return <Render {...props} />;\n};\n\n/**\n * Platform-agnostic no-op default components.\n * Each platform (web, RN) wraps MessagePrimitiveParts with its own defaults.\n */\nexport const defaultComponents = {\n Text: () => null,\n Reasoning: () => null,\n Source: () => null,\n Image: () => null,\n File: () => null,\n Unstable_Audio: () => null,\n ToolGroup: ({ children }: PropsWithChildren) => children,\n ReasoningGroup: ({ children }: PropsWithChildren) => children,\n} satisfies MessagePrimitiveParts.Props[\"components\"];\n\ntype MessagePartComponentProps = {\n components: MessagePrimitiveParts.Props[\"components\"];\n};\n\nexport const MessagePartComponent: FC<MessagePartComponentProps> = ({\n components: {\n Text = defaultComponents.Text,\n Reasoning = defaultComponents.Reasoning,\n Image = defaultComponents.Image,\n Source = defaultComponents.Source,\n File = defaultComponents.File,\n Unstable_Audio: Audio = defaultComponents.Unstable_Audio,\n tools = {},\n data,\n generativeUI,\n } = {},\n}) => {\n const aui = useAui();\n const part = useAuiState((s) => s.part);\n\n const type = part.type;\n if (type === \"tool-call\") {\n const addResult = aui.part().addToolResult;\n const resume = aui.part().resumeToolCall;\n const respondToApproval = aui.part().respondToToolApproval;\n if (\"Override\" in tools)\n return (\n <tools.Override\n {...part}\n addResult={addResult}\n resume={resume}\n respondToApproval={respondToApproval}\n />\n );\n const Tool = tools.by_name?.[part.toolName] ?? tools.Fallback;\n return (\n <ToolUIDisplay\n {...part}\n Fallback={Tool}\n addResult={addResult}\n resume={resume}\n respondToApproval={respondToApproval}\n />\n );\n }\n\n if (part.status?.type === \"requires-action\")\n throw new Error(\"Encountered unexpected requires-action status\");\n\n switch (type) {\n case \"text\":\n return <Text {...part} />;\n\n case \"reasoning\":\n return <Reasoning {...part} />;\n\n case \"source\":\n return <Source {...part} />;\n\n case \"image\":\n return <Image {...part} />;\n\n case \"file\":\n return <File {...part} />;\n\n case \"audio\":\n return <Audio {...part} />;\n\n case \"data\": {\n const Data = data?.by_name?.[part.name] ?? data?.Fallback;\n return <DataUIDisplay {...part} Fallback={Data} />;\n }\n\n case \"generative-ui\": {\n if (!generativeUI?.components) {\n if (\n typeof process !== \"undefined\" &&\n process.env?.NODE_ENV !== \"production\"\n ) {\n console.warn(\n \"MessagePrimitive.Parts received a generative-ui part but no \" +\n \"`components.generativeUI.components` allowlist was provided. \" +\n \"Pass an allowlist or render with <MessagePrimitive.GenerativeUI />.\",\n );\n }\n return null;\n }\n return (\n <GenerativeUIRender\n spec={(part as GenerativeUIMessagePart).spec}\n components={generativeUI.components}\n Fallback={generativeUI.Fallback}\n />\n );\n }\n\n default:\n console.warn(`Unknown message part type: ${type}`);\n return null;\n }\n};\n\nexport namespace MessagePrimitivePartByIndex {\n export type Props = {\n index: number;\n components: MessagePrimitiveParts.Props[\"components\"];\n };\n}\n\n/**\n * Renders a single message part at the specified index.\n */\nexport const MessagePrimitivePartByIndex: FC<MessagePrimitivePartByIndex.Props> =\n memo(\n ({ index, components }) => {\n return (\n <PartByIndexProvider index={index}>\n <MessagePartComponent components={components} />\n </PartByIndexProvider>\n );\n },\n (prev, next) =>\n prev.index === next.index &&\n prev.components?.Text === next.components?.Text &&\n prev.components?.Reasoning === next.components?.Reasoning &&\n prev.components?.Source === next.components?.Source &&\n prev.components?.Image === next.components?.Image &&\n prev.components?.File === next.components?.File &&\n prev.components?.Unstable_Audio === next.components?.Unstable_Audio &&\n prev.components?.tools === next.components?.tools &&\n prev.components?.data === next.components?.data &&\n prev.components?.generativeUI === next.components?.generativeUI &&\n prev.components?.ToolGroup === next.components?.ToolGroup &&\n prev.components?.ReasoningGroup === next.components?.ReasoningGroup,\n );\n\nMessagePrimitivePartByIndex.displayName = \"MessagePrimitive.PartByIndex\";\n\nconst EmptyPartFallback: FC<{\n status: MessagePartStatus;\n component: TextMessagePartComponent;\n}> = ({ status, component: Component }) => {\n return (\n <TextMessagePartProvider text=\"\" isRunning={status.type === \"running\"}>\n <Component type=\"text\" text=\"\" status={status} />\n </TextMessagePartProvider>\n );\n};\n\nconst COMPLETE_STATUS: MessagePartStatus = Object.freeze({\n type: \"complete\",\n});\n\nconst RUNNING_STATUS: MessagePartStatus = Object.freeze({\n type: \"running\",\n});\n\nconst EmptyPartsImpl: FC<MessagePartComponentProps> = ({ components }) => {\n const status = useAuiState(\n (s) => (s.message.status ?? COMPLETE_STATUS) as MessagePartStatus,\n );\n\n if (components?.Empty) return <components.Empty status={status} />;\n\n if (status.type !== \"running\") return null;\n\n return (\n <EmptyPartFallback\n status={status}\n component={components?.Text ?? defaultComponents.Text}\n />\n );\n};\n\nconst EmptyParts = memo(\n EmptyPartsImpl,\n (prev, next) =>\n prev.components?.Empty === next.components?.Empty &&\n prev.components?.Text === next.components?.Text,\n);\n\nconst ConditionalEmptyImpl: FC<{\n components: MessagePrimitiveParts.Props[\"components\"];\n enabled: boolean;\n}> = ({ components, enabled }) => {\n const shouldShowEmpty = useAuiState((s) => {\n if (!enabled) return false;\n if (s.message.parts.length === 0) return false;\n\n const lastPart = s.message.parts[s.message.parts.length - 1];\n return lastPart?.type !== \"text\" && lastPart?.type !== \"reasoning\";\n });\n\n if (!shouldShowEmpty) return null;\n return <EmptyParts components={components} />;\n};\n\nconst ConditionalEmpty = memo(\n ConditionalEmptyImpl,\n (prev, next) =>\n prev.enabled === next.enabled &&\n prev.components?.Empty === next.components?.Empty &&\n prev.components?.Text === next.components?.Text,\n);\n\nconst QuoteRendererImpl: FC<{ Quote: QuoteMessagePartComponent }> = ({\n Quote,\n}) => {\n const quoteInfo = useAuiState(getMessageQuote);\n if (!quoteInfo) return null;\n return <Quote text={quoteInfo.text} messageId={quoteInfo.messageId} />;\n};\n\nconst QuoteRenderer = memo(QuoteRendererImpl);\n\nfunction resolveToolRender(\n toolsState: ToolsState,\n part: Extract<PartState, { type: \"tool-call\" }>,\n): ToolCallMessagePartComponent | null {\n const named = toolsState.toolUIs[part.toolName]?.[0]?.render ?? null;\n if (named) return named;\n if (isMcpAppUri(part.mcp?.app?.resourceUri) && toolsState.mcpApp) {\n return toolsState.mcpApp.render;\n }\n return null;\n}\n\n/**\n * Stable propless component that renders the registered tool UI for the\n * current part context. Reads tool registry and part state from context.\n */\nconst RegisteredToolUI: FC = () => {\n const aui = useAui();\n const part = useAuiState((s) => s.part);\n const Render = useAuiState((s) =>\n s.part.type === \"tool-call\" ? resolveToolRender(s.tools, s.part) : null,\n );\n\n if (!Render || part.type !== \"tool-call\") return null;\n\n return (\n <Render\n {...part}\n addResult={aui.part().addToolResult}\n resume={aui.part().resumeToolCall}\n respondToApproval={aui.part().respondToToolApproval}\n />\n );\n};\n\n/**\n * Stable propless component that renders the registered data renderer UI\n * for the current part context.\n */\nconst RegisteredDataRendererUI: FC = () => {\n const part = useAuiState((s) => s.part);\n const Render = useAuiState((s) =>\n s.part.type === \"data\"\n ? (getDataRenderer(s.dataRenderers, s.part.name, undefined) ?? null)\n : null,\n );\n\n if (!Render || part.type !== \"data\") return null;\n\n return <Render {...(part as DataMessagePartProps)} />;\n};\n\n/**\n * Fallback component rendered when the children render function returns null.\n * Renders registered tool/data UIs via context.\n * For all other part types, renders nothing.\n *\n * This allows users to write:\n * {({ part }) => {\n * if (part.type === \"text\") return <MyText />;\n * return null; // tool UIs and data UIs still render via registry\n * }}\n *\n * To explicitly render nothing (suppressing registered UIs), return <></>.\n */\nconst DefaultPartFallback: FC = () => {\n const partType = useAuiState((s) => s.part.type);\n\n if (partType === \"tool-call\") return <RegisteredToolUI />;\n if (partType === \"data\") return <RegisteredDataRendererUI />;\n\n return null;\n};\n\nexport type { PartState };\n\n/**\n * Enriched part state passed to children render functions.\n *\n * For tool-call parts, adds `toolUI`, `addResult`, and `resume`.\n * For data parts, adds `dataRendererUI`.\n *\n * The render function is also invoked once with a synthetic empty text part\n * (`{ type: \"text\", text: \"\", status: { type: \"running\" } }`) when the\n * assistant message has no parts yet but is in the running state, so a\n * loading indicator can render. Differentiate this from a real empty text\n * via `part.status?.type === \"running\" && part.text === \"\"`.\n */\nexport type EnrichedPartState =\n | (Extract<PartState, { type: \"tool-call\" }> & {\n /** The registered tool UI element, or null if none registered. */\n readonly toolUI: ReactNode;\n /** Add a tool result to this tool call. */\n addResult: ToolCallMessagePartProps[\"addResult\"];\n /** Resume a tool call waiting for human input. */\n resume: ToolCallMessagePartProps[\"resume\"];\n /** Respond to a server-side tool approval gate. */\n respondToApproval: ToolCallMessagePartProps[\"respondToApproval\"];\n })\n | (Extract<PartState, { type: \"data\" }> & {\n /** The registered data renderer UI element, or null if none registered. */\n readonly dataRendererUI: ReactNode;\n })\n | Exclude<PartState, { type: \"tool-call\" } | { type: \"data\" }>;\n\nconst EMPTY_RUNNING_TEXT_PART: Extract<EnrichedPartState, { type: \"text\" }> =\n Object.freeze({\n type: \"text\",\n text: \"\",\n status: RUNNING_STATUS,\n });\n\n/**\n * @internal\n * Renders a single part by index, calling `children` with the\n * {@link EnrichedPartState} (tool/data UI enrichments + addResult/resume\n * for tool calls). Shared between `<MessagePrimitive.Parts>` and\n * `<MessagePrimitive.GroupedParts>`. Returns whatever `children`\n * returns — callers decide how to handle a `null` return.\n */\nexport const MessagePartChildren: FC<{\n index: number;\n children: (value: { part: EnrichedPartState }) => ReactNode;\n}> = ({ index, children }) => {\n const aui = useAui();\n // Subscribed (not snapshotted like `tools`) so fallbacks registered\n // after the first render trigger a re-render and `hasUI` re-evaluates.\n const dataRenderers = useAuiState((s) => s.dataRenderers);\n\n return (\n <PartByIndexProvider index={index}>\n <RenderChildrenWithAccessor\n getItemState={(aui) => aui.message().part({ index }).getState()}\n >\n {(getItem) =>\n children({\n get part() {\n const state = getItem();\n if (state.type === \"tool-call\") {\n const toolsState = aui.tools().getState();\n const hasUI = resolveToolRender(toolsState, state) !== null;\n const partMethods = aui.message().part({ index });\n return {\n ...state,\n toolUI: hasUI ? <RegisteredToolUI /> : null,\n addResult: partMethods.addToolResult,\n resume: partMethods.resumeToolCall,\n respondToApproval: partMethods.respondToToolApproval,\n };\n }\n if (state.type === \"data\") {\n const hasUI =\n getDataRenderer(dataRenderers, state.name, undefined) !==\n undefined;\n return {\n ...state,\n dataRendererUI: hasUI ? <RegisteredDataRendererUI /> : null,\n };\n }\n return state;\n },\n })\n }\n </RenderChildrenWithAccessor>\n </PartByIndexProvider>\n );\n};\n\nconst MessagePrimitivePartsInner: FC<{\n children: (value: { part: EnrichedPartState }) => ReactNode;\n}> = ({ children }) => {\n const contentLength = useAuiState((s) => s.message.parts.length);\n const isRunning = useAuiState(\n (s) => (s.message.status?.type ?? \"complete\") === \"running\",\n );\n const isEmptyRunning = contentLength === 0 && isRunning;\n\n if (contentLength === 0) {\n if (!isEmptyRunning) return null;\n return (\n <TextMessagePartProvider text=\"\" isRunning>\n {children({ part: EMPTY_RUNNING_TEXT_PART })}\n </TextMessagePartProvider>\n );\n }\n\n return (\n <>\n {Array.from({ length: contentLength }, (_, index) => (\n <MessagePartChildren key={index} index={index}>\n {(value) => children(value) ?? <DefaultPartFallback />}\n </MessagePartChildren>\n ))}\n </>\n );\n};\n\n/**\n * Renders the parts of a message with support for multiple content types.\n *\n * This is the platform-agnostic base. Each platform wraps this with its own\n * default components (web uses `<p>`, `<span>`; RN would use `<Text>`, etc.).\n */\nexport const MessagePrimitiveParts: FC<MessagePrimitiveParts.Props> = ({\n components,\n unstable_showEmptyOnNonTextEnd = true,\n children,\n}) => {\n if (children) {\n return <MessagePrimitivePartsInner>{children}</MessagePrimitivePartsInner>;\n }\n return (\n <MessagePrimitivePartsCompat\n components={components}\n unstable_showEmptyOnNonTextEnd={unstable_showEmptyOnNonTextEnd}\n />\n );\n};\n\nMessagePrimitiveParts.displayName = \"MessagePrimitive.Parts\";\n\nconst MessagePrimitivePartsCompat: FC<{\n components: MessagePrimitiveParts.Props[\"components\"];\n unstable_showEmptyOnNonTextEnd: boolean;\n}> = ({ components, unstable_showEmptyOnNonTextEnd }) => {\n const contentLength = useAuiState((s) => s.message.parts.length);\n const useChainOfThought = !!components?.ChainOfThought;\n const messageRanges = useMessagePartsGroups(useChainOfThought);\n\n const partsElements = useMemo(() => {\n if (contentLength === 0) {\n return <EmptyParts components={components} />;\n }\n\n return messageRanges.map((range) => {\n if (range.type === \"single\") {\n return (\n <MessagePrimitivePartByIndex\n key={range.index}\n index={range.index}\n components={components}\n />\n );\n } else if (range.type === \"chainOfThoughtGroup\") {\n const ChainOfThoughtComponent = components?.ChainOfThought;\n if (!ChainOfThoughtComponent) return null;\n return (\n <ChainOfThoughtByIndicesProvider\n key={`chainOfThought-${range.startIndex}`}\n startIndex={range.startIndex}\n endIndex={range.endIndex}\n >\n <ChainOfThoughtComponent />\n </ChainOfThoughtByIndicesProvider>\n );\n } else if (range.type === \"toolGroup\") {\n const ToolGroupComponent =\n components?.ToolGroup ?? defaultComponents.ToolGroup;\n return (\n <ToolGroupComponent\n key={`tool-${range.startIndex}`}\n startIndex={range.startIndex}\n endIndex={range.endIndex}\n >\n {Array.from(\n { length: range.endIndex - range.startIndex + 1 },\n (_, i) => {\n const partIndex = range.startIndex + i;\n return (\n <MessagePrimitivePartByIndex\n key={`part-${partIndex}`}\n index={partIndex}\n components={components}\n />\n );\n },\n )}\n </ToolGroupComponent>\n );\n } else {\n // reasoningGroup\n const ReasoningGroupComponent =\n components?.ReasoningGroup ?? defaultComponents.ReasoningGroup;\n return (\n <ReasoningGroupComponent\n key={`reasoning-${range.startIndex}`}\n startIndex={range.startIndex}\n endIndex={range.endIndex}\n >\n {Array.from(\n { length: range.endIndex - range.startIndex + 1 },\n (_, i) => {\n const partIndex = range.startIndex + i;\n return (\n <MessagePrimitivePartByIndex\n key={`part-${partIndex}`}\n index={partIndex}\n components={components}\n />\n );\n },\n )}\n </ReasoningGroupComponent>\n );\n }\n });\n }, [messageRanges, components, contentLength]);\n\n return (\n <>\n {components?.Quote && <QuoteRenderer Quote={components.Quote} />}\n {partsElements}\n <ConditionalEmpty\n components={components}\n enabled={unstable_showEmptyOnNonTextEnd}\n />\n </>\n );\n};\n"],"mappings":"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"}
1
+ {"version":3,"file":"MessageParts.js","names":[],"sources":["../../../../src/react/primitives/message/MessageParts.tsx"],"sourcesContent":["import {\n type ComponentType,\n type FC,\n type ReactNode,\n memo,\n type PropsWithChildren,\n useMemo,\n} from \"react\";\nimport {\n RenderChildrenWithAccessor,\n useAuiState,\n useAui,\n} from \"@assistant-ui/store\";\nimport type { PartState } from \"../../../store/scopes/part\";\nimport { PartByIndexProvider } from \"../../providers/PartByIndexProvider\";\nimport { TextMessagePartProvider } from \"../../providers/TextMessagePartProvider\";\nimport { ChainOfThoughtByIndicesProvider } from \"../../providers/ChainOfThoughtByIndicesProvider\";\nimport { getMessageQuote } from \"../../utils/getMessageQuote\";\nimport type {\n Unstable_AudioMessagePartComponent,\n DataMessagePartComponent,\n DataMessagePartProps,\n EmptyMessagePartComponent,\n TextMessagePartComponent,\n ImageMessagePartComponent,\n SourceMessagePartComponent,\n ToolCallMessagePartComponent,\n ToolCallMessagePartProps,\n FileMessagePartComponent,\n ReasoningMessagePartComponent,\n ReasoningGroupComponent,\n QuoteMessagePartComponent,\n GenerativeUIComponentRegistry,\n} from \"../../types/MessagePartComponentTypes\";\nimport { GenerativeUIRender } from \"../generativeUI/GenerativeUI\";\nimport {\n isMcpAppUri,\n type MessagePartStatus,\n type GenerativeUIMessagePart,\n} from \"../../../types/message\";\nimport type { DataRenderersState } from \"../../types/scopes/dataRenderers\";\nimport type { ToolsState } from \"../../types/scopes/tools\";\nimport { useShallow } from \"zustand/shallow\";\n\ntype MessagePartRange =\n | { type: \"single\"; index: number }\n | { type: \"toolGroup\"; startIndex: number; endIndex: number }\n | { type: \"reasoningGroup\"; startIndex: number; endIndex: number }\n | { type: \"chainOfThoughtGroup\"; startIndex: number; endIndex: number };\n\n/**\n * Creates a group state manager for a specific part type.\n * Returns functions to start, end, and finalize groups.\n */\nconst createGroupState = <\n T extends \"toolGroup\" | \"reasoningGroup\" | \"chainOfThoughtGroup\",\n>(\n groupType: T,\n) => {\n let start = -1;\n\n return {\n startGroup: (index: number) => {\n if (start === -1) {\n start = index;\n }\n },\n endGroup: (endIndex: number, ranges: MessagePartRange[]) => {\n if (start !== -1) {\n ranges.push({\n type: groupType,\n startIndex: start,\n endIndex,\n } as MessagePartRange);\n start = -1;\n }\n },\n finalize: (endIndex: number, ranges: MessagePartRange[]) => {\n if (start !== -1) {\n ranges.push({\n type: groupType,\n startIndex: start,\n endIndex,\n } as MessagePartRange);\n }\n },\n };\n};\n\n/**\n * Groups consecutive tool-call and reasoning message parts into ranges.\n * Always groups tool calls and reasoning parts, even if there's only one.\n * When useChainOfThought is true, groups tool-call and reasoning parts together.\n */\nconst groupMessageParts = (\n messageTypes: readonly string[],\n useChainOfThought: boolean,\n): MessagePartRange[] => {\n const ranges: MessagePartRange[] = [];\n\n if (useChainOfThought) {\n const chainOfThoughtGroup = createGroupState(\"chainOfThoughtGroup\");\n\n for (let i = 0; i < messageTypes.length; i++) {\n const type = messageTypes[i];\n\n if (type === \"tool-call\" || type === \"reasoning\") {\n chainOfThoughtGroup.startGroup(i);\n } else {\n chainOfThoughtGroup.endGroup(i - 1, ranges);\n ranges.push({ type: \"single\", index: i });\n }\n }\n\n chainOfThoughtGroup.finalize(messageTypes.length - 1, ranges);\n } else {\n const toolGroup = createGroupState(\"toolGroup\");\n const reasoningGroup = createGroupState(\"reasoningGroup\");\n\n for (let i = 0; i < messageTypes.length; i++) {\n const type = messageTypes[i];\n\n if (type === \"tool-call\") {\n reasoningGroup.endGroup(i - 1, ranges);\n toolGroup.startGroup(i);\n } else if (type === \"reasoning\") {\n toolGroup.endGroup(i - 1, ranges);\n reasoningGroup.startGroup(i);\n } else {\n toolGroup.endGroup(i - 1, ranges);\n reasoningGroup.endGroup(i - 1, ranges);\n ranges.push({ type: \"single\", index: i });\n }\n }\n\n toolGroup.finalize(messageTypes.length - 1, ranges);\n reasoningGroup.finalize(messageTypes.length - 1, ranges);\n }\n\n return ranges;\n};\n\nconst useMessagePartsGroups = (\n useChainOfThought: boolean,\n): MessagePartRange[] => {\n const messageTypes = useAuiState(\n useShallow((s) => s.message.parts.map((c: any) => c.type)),\n );\n\n return useMemo(() => {\n if (messageTypes.length === 0) {\n return [];\n }\n return groupMessageParts(messageTypes, useChainOfThought);\n }, [messageTypes, useChainOfThought]);\n};\n\nexport namespace MessagePrimitiveParts {\n type DataConfig = {\n /** Map data event names to specific components */\n by_name?: Record<string, DataMessagePartComponent | undefined> | undefined;\n /** Fallback component for unmatched data events */\n Fallback?: DataMessagePartComponent | undefined;\n };\n\n type BaseComponents = {\n /** Component for rendering empty messages */\n Empty?: EmptyMessagePartComponent | undefined;\n /** Component for rendering text content */\n Text?: TextMessagePartComponent | undefined;\n /** Component for rendering source content */\n Source?: SourceMessagePartComponent | undefined;\n /** Component for rendering image content */\n Image?: ImageMessagePartComponent | undefined;\n /** Component for rendering file content */\n File?: FileMessagePartComponent | undefined;\n /** Component for rendering audio content (experimental) */\n Unstable_Audio?: Unstable_AudioMessagePartComponent | undefined;\n /** Configuration for data part rendering */\n data?: DataConfig | undefined;\n /** Component for rendering a quoted message reference (from metadata, not parts) */\n Quote?: QuoteMessagePartComponent | undefined;\n /**\n * Configuration for generative-ui part rendering.\n *\n * `components` is the consumer-provided allowlist of React components\n * the agent's JSON spec is permitted to render. Any name not present in\n * the registry is rejected with a typed `GenerativeUIRenderError` —\n * this is the security boundary in the same-realm rendering path.\n */\n generativeUI?:\n | {\n /** The component allowlist (the security boundary). */\n components: GenerativeUIComponentRegistry;\n /** Optional fallback for unknown component names. */\n Fallback?:\n | ComponentType<{ component: string; props?: unknown }>\n | undefined;\n }\n | undefined;\n };\n\n type ToolsConfig =\n | {\n /** Map of tool names to their specific components */\n by_name?:\n | Record<string, ToolCallMessagePartComponent | undefined>\n | undefined;\n /** Fallback component for unregistered tools */\n Fallback?: ComponentType<ToolCallMessagePartProps> | undefined;\n }\n | {\n /** Override component that handles all tool calls */\n Override: ComponentType<ToolCallMessagePartProps>;\n };\n\n /**\n * Standard component configuration for rendering reasoning and tool-call parts\n * individually (with optional grouping).\n *\n * Cannot be combined with `ChainOfThought`.\n */\n type StandardComponents = BaseComponents & {\n /** Component for rendering reasoning content (typically hidden) */\n Reasoning?: ReasoningMessagePartComponent | undefined;\n /** Configuration for tool call rendering */\n tools?: ToolsConfig | undefined;\n\n /**\n * Component for rendering grouped consecutive tool calls.\n *\n * @param startIndex - Index of the first tool call in the group\n * @param endIndex - Index of the last tool call in the group\n * @param children - Rendered tool call components to display within the group\n *\n * @deprecated Use `<MessagePrimitive.GroupedParts>` with a custom `groupBy` instead.\n */\n ToolGroup?: ComponentType<\n PropsWithChildren<{ startIndex: number; endIndex: number }>\n >;\n\n /**\n * Component for rendering grouped reasoning parts.\n *\n * @param startIndex - Index of the first reasoning part in the group\n * @param endIndex - Index of the last reasoning part in the group\n * @param children - Rendered reasoning part components\n *\n * @deprecated Use `<MessagePrimitive.GroupedParts>` with a custom `groupBy` instead.\n */\n ReasoningGroup?: ReasoningGroupComponent;\n\n ChainOfThought?: never;\n };\n\n /**\n * Chain of thought component configuration.\n *\n * When `ChainOfThought` is set, it takes control of rendering ALL reasoning and\n * tool-call parts in the message. The `Reasoning`, `tools`, `ReasoningGroup`, and\n * `ToolGroup` components cannot be used alongside it.\n */\n type ChainOfThoughtComponents = BaseComponents & {\n /**\n * @deprecated Use `<MessagePrimitive.GroupedParts>` with a `groupBy`\n * that returns `[\"group-thought\", ...]` for reasoning and tool-call\n * parts. See `@assistant-ui/ui` for a worked example.\n */\n ChainOfThought: ComponentType;\n\n Reasoning?: never;\n tools?: never;\n ToolGroup?: never;\n ReasoningGroup?: never;\n };\n\n export type Props =\n | {\n /**\n * Component configuration for rendering different types of message content.\n *\n * Use either `Reasoning`/`tools`/`ToolGroup`/`ReasoningGroup` for standard rendering,\n * or `ChainOfThought` to group all reasoning and tool-call parts into a single\n * collapsible component. These two modes are mutually exclusive.\n */\n components?: StandardComponents | ChainOfThoughtComponents | undefined;\n /**\n * When enabled, shows the Empty component if the last part in the message\n * is anything other than Text or Reasoning.\n *\n * @experimental This API is experimental and may change in future versions.\n * @default true\n */\n unstable_showEmptyOnNonTextEnd?: boolean | undefined;\n children?: never;\n }\n | {\n /** Render function called for each part. Receives the enriched part state. */\n children: (value: { part: EnrichedPartState }) => ReactNode;\n components?: never;\n unstable_showEmptyOnNonTextEnd?: never;\n };\n}\n\nconst ToolUIDisplay = ({\n Fallback,\n ...props\n}: {\n Fallback: ToolCallMessagePartComponent | undefined;\n} & ToolCallMessagePartProps) => {\n const Render = useAuiState(\n (s) => s.tools.toolUIs[props.toolName]?.[0]?.render ?? Fallback,\n );\n if (!Render) return null;\n return <Render {...props} />;\n};\n\nconst getDataRenderer = (\n dataRenderers: DataRenderersState,\n name: string,\n inlineFallback: DataMessagePartComponent | undefined,\n): DataMessagePartComponent | undefined => {\n const named = dataRenderers.renderers[name]?.[0];\n if (named) return named;\n return dataRenderers.fallbacks[0] ?? inlineFallback;\n};\n\nconst DataUIDisplay = ({\n Fallback,\n ...props\n}: {\n Fallback: DataMessagePartComponent | undefined;\n} & DataMessagePartProps) => {\n const Render = useAuiState((s) =>\n getDataRenderer(s.dataRenderers, props.name, Fallback),\n );\n if (!Render) return null;\n return <Render {...props} />;\n};\n\n/**\n * Platform-agnostic no-op default components.\n * Each platform (web, RN) wraps MessagePrimitiveParts with its own defaults.\n */\nexport const defaultComponents = {\n Text: () => null,\n Reasoning: () => null,\n Source: () => null,\n Image: () => null,\n File: () => null,\n Unstable_Audio: () => null,\n ToolGroup: ({ children }: PropsWithChildren) => children,\n ReasoningGroup: ({ children }: PropsWithChildren) => children,\n} satisfies MessagePrimitiveParts.Props[\"components\"];\n\ntype MessagePartComponentProps = {\n components: MessagePrimitiveParts.Props[\"components\"];\n};\n\nexport const MessagePartComponent: FC<MessagePartComponentProps> = ({\n components: {\n Text = defaultComponents.Text,\n Reasoning = defaultComponents.Reasoning,\n Image = defaultComponents.Image,\n Source = defaultComponents.Source,\n File = defaultComponents.File,\n Unstable_Audio: Audio = defaultComponents.Unstable_Audio,\n tools = {},\n data,\n generativeUI,\n } = {},\n}) => {\n const aui = useAui();\n const part = useAuiState((s) => s.part);\n\n const type = part.type;\n if (type === \"tool-call\") {\n const addResult = aui.part().addToolResult;\n const resume = aui.part().resumeToolCall;\n const respondToApproval = aui.part().respondToToolApproval;\n if (\"Override\" in tools)\n return (\n <tools.Override\n {...part}\n addResult={addResult}\n resume={resume}\n respondToApproval={respondToApproval}\n />\n );\n const Tool = tools.by_name?.[part.toolName] ?? tools.Fallback;\n return (\n <ToolUIDisplay\n {...part}\n Fallback={Tool}\n addResult={addResult}\n resume={resume}\n respondToApproval={respondToApproval}\n />\n );\n }\n\n if (part.status?.type === \"requires-action\")\n throw new Error(\"Encountered unexpected requires-action status\");\n\n switch (type) {\n case \"text\":\n return <Text {...part} />;\n\n case \"reasoning\":\n return <Reasoning {...part} />;\n\n case \"source\":\n return <Source {...part} />;\n\n case \"image\":\n return <Image {...part} />;\n\n case \"file\":\n return <File {...part} />;\n\n case \"audio\":\n return <Audio {...part} />;\n\n case \"data\": {\n const Data = data?.by_name?.[part.name] ?? data?.Fallback;\n return <DataUIDisplay {...part} Fallback={Data} />;\n }\n\n case \"generative-ui\": {\n if (!generativeUI?.components) {\n if (\n typeof process !== \"undefined\" &&\n process.env?.NODE_ENV !== \"production\"\n ) {\n console.warn(\n \"MessagePrimitive.Parts received a generative-ui part but no \" +\n \"`components.generativeUI.components` allowlist was provided. \" +\n \"Pass an allowlist or render with <MessagePrimitive.GenerativeUI />.\",\n );\n }\n return null;\n }\n return (\n <GenerativeUIRender\n spec={(part as GenerativeUIMessagePart).spec}\n components={generativeUI.components}\n Fallback={generativeUI.Fallback}\n />\n );\n }\n\n default:\n console.warn(`Unknown message part type: ${type}`);\n return null;\n }\n};\n\nexport namespace MessagePrimitivePartByIndex {\n export type Props = {\n index: number;\n components: MessagePrimitiveParts.Props[\"components\"];\n };\n}\n\n/**\n * Renders a single message part at the specified index.\n */\nexport const MessagePrimitivePartByIndex: FC<MessagePrimitivePartByIndex.Props> =\n memo(\n ({ index, components }) => {\n return (\n <PartByIndexProvider index={index}>\n <MessagePartComponent components={components} />\n </PartByIndexProvider>\n );\n },\n (prev, next) =>\n prev.index === next.index &&\n prev.components?.Text === next.components?.Text &&\n prev.components?.Reasoning === next.components?.Reasoning &&\n prev.components?.Source === next.components?.Source &&\n prev.components?.Image === next.components?.Image &&\n prev.components?.File === next.components?.File &&\n prev.components?.Unstable_Audio === next.components?.Unstable_Audio &&\n prev.components?.tools === next.components?.tools &&\n prev.components?.data === next.components?.data &&\n prev.components?.generativeUI === next.components?.generativeUI &&\n prev.components?.ToolGroup === next.components?.ToolGroup &&\n prev.components?.ReasoningGroup === next.components?.ReasoningGroup,\n );\n\nMessagePrimitivePartByIndex.displayName = \"MessagePrimitive.PartByIndex\";\n\nconst EmptyPartFallback: FC<{\n status: MessagePartStatus;\n component: TextMessagePartComponent;\n}> = ({ status, component: Component }) => {\n return (\n <TextMessagePartProvider text=\"\" isRunning={status.type === \"running\"}>\n <Component type=\"text\" text=\"\" status={status} />\n </TextMessagePartProvider>\n );\n};\n\nconst COMPLETE_STATUS: MessagePartStatus = Object.freeze({\n type: \"complete\",\n});\n\nconst RUNNING_STATUS: MessagePartStatus = Object.freeze({\n type: \"running\",\n});\n\nconst EmptyPartsImpl: FC<MessagePartComponentProps> = ({ components }) => {\n const status = useAuiState(\n (s) => (s.message.status ?? COMPLETE_STATUS) as MessagePartStatus,\n );\n\n if (components?.Empty) return <components.Empty status={status} />;\n\n if (status.type !== \"running\") return null;\n\n return (\n <EmptyPartFallback\n status={status}\n component={components?.Text ?? defaultComponents.Text}\n />\n );\n};\n\nconst EmptyParts = memo(\n EmptyPartsImpl,\n (prev, next) =>\n prev.components?.Empty === next.components?.Empty &&\n prev.components?.Text === next.components?.Text,\n);\n\nconst ConditionalEmptyImpl: FC<{\n components: MessagePrimitiveParts.Props[\"components\"];\n enabled: boolean;\n}> = ({ components, enabled }) => {\n const shouldShowEmpty = useAuiState((s) => {\n if (!enabled) return false;\n if (s.message.parts.length === 0) return false;\n\n const lastPart = s.message.parts[s.message.parts.length - 1];\n return lastPart?.type !== \"text\" && lastPart?.type !== \"reasoning\";\n });\n\n if (!shouldShowEmpty) return null;\n return <EmptyParts components={components} />;\n};\n\nconst ConditionalEmpty = memo(\n ConditionalEmptyImpl,\n (prev, next) =>\n prev.enabled === next.enabled &&\n prev.components?.Empty === next.components?.Empty &&\n prev.components?.Text === next.components?.Text,\n);\n\nconst QuoteRendererImpl: FC<{ Quote: QuoteMessagePartComponent }> = ({\n Quote,\n}) => {\n const quoteInfo = useAuiState(getMessageQuote);\n if (!quoteInfo) return null;\n return <Quote text={quoteInfo.text} messageId={quoteInfo.messageId} />;\n};\n\nconst QuoteRenderer = memo(QuoteRendererImpl);\n\nfunction resolveToolRender(\n toolsState: ToolsState,\n part: Extract<PartState, { type: \"tool-call\" }>,\n): ToolCallMessagePartComponent | null {\n const named = toolsState.toolUIs[part.toolName]?.[0]?.render ?? null;\n if (named) return named;\n if (isMcpAppUri(part.mcp?.app?.resourceUri) && toolsState.mcpApp) {\n return toolsState.mcpApp.render;\n }\n return null;\n}\n\n/**\n * Stable propless component that renders the registered tool UI for the\n * current part context. Reads tool registry and part state from context.\n */\nconst RegisteredToolUI: FC = () => {\n const aui = useAui();\n const part = useAuiState((s) => s.part);\n const Render = useAuiState((s) =>\n s.part.type === \"tool-call\" ? resolveToolRender(s.tools, s.part) : null,\n );\n\n if (!Render || part.type !== \"tool-call\") return null;\n\n return (\n <Render\n {...part}\n addResult={aui.part().addToolResult}\n resume={aui.part().resumeToolCall}\n respondToApproval={aui.part().respondToToolApproval}\n />\n );\n};\n\n/**\n * Stable propless component that renders the registered data renderer UI\n * for the current part context.\n */\nconst RegisteredDataRendererUI: FC = () => {\n const part = useAuiState((s) => s.part);\n const Render = useAuiState((s) =>\n s.part.type === \"data\"\n ? (getDataRenderer(s.dataRenderers, s.part.name, undefined) ?? null)\n : null,\n );\n\n if (!Render || part.type !== \"data\") return null;\n\n return <Render {...(part as DataMessagePartProps)} />;\n};\n\n/**\n * Fallback component rendered when the children render function returns null.\n * Renders registered tool/data UIs via context.\n * For all other part types, renders nothing.\n *\n * This allows users to write:\n * {({ part }) => {\n * if (part.type === \"text\") return <MyText />;\n * return null; // tool UIs and data UIs still render via registry\n * }}\n *\n * To explicitly render nothing (suppressing registered UIs), return <></>.\n */\nconst DefaultPartFallback: FC = () => {\n const partType = useAuiState((s) => s.part.type);\n\n if (partType === \"tool-call\") return <RegisteredToolUI />;\n if (partType === \"data\") return <RegisteredDataRendererUI />;\n\n return null;\n};\n\nexport type { PartState };\n\n/**\n * Enriched part state passed to children render functions.\n *\n * For tool-call parts, adds `toolUI`, `addResult`, and `resume`.\n * For data parts, adds `dataRendererUI`.\n *\n * The render function is also invoked once with a synthetic empty text part\n * (`{ type: \"text\", text: \"\", status: { type: \"running\" } }`) when the\n * assistant message has no parts yet but is in the running state, so a\n * loading indicator can render. Differentiate this from a real empty text\n * via `part.status?.type === \"running\" && part.text === \"\"`.\n */\nexport type EnrichedPartState =\n | (Extract<PartState, { type: \"tool-call\" }> & {\n /** The registered tool UI element, or null if none registered. */\n readonly toolUI: ReactNode;\n /** Add a tool result to this tool call. */\n addResult: ToolCallMessagePartProps[\"addResult\"];\n /** Resume a tool call waiting for human input. */\n resume: ToolCallMessagePartProps[\"resume\"];\n /** Respond to a server-side tool approval gate. */\n respondToApproval: ToolCallMessagePartProps[\"respondToApproval\"];\n })\n | (Extract<PartState, { type: \"data\" }> & {\n /** The registered data renderer UI element, or null if none registered. */\n readonly dataRendererUI: ReactNode;\n })\n | Exclude<PartState, { type: \"tool-call\" } | { type: \"data\" }>;\n\nconst EMPTY_RUNNING_TEXT_PART: Extract<EnrichedPartState, { type: \"text\" }> =\n Object.freeze({\n type: \"text\",\n text: \"\",\n status: RUNNING_STATUS,\n });\n\n/**\n * @internal\n * Renders a single part by index, calling `children` with the\n * {@link EnrichedPartState} (tool/data UI enrichments + addResult/resume\n * for tool calls). Shared between `<MessagePrimitive.Parts>` and\n * `<MessagePrimitive.GroupedParts>`. Returns whatever `children`\n * returns — callers decide how to handle a `null` return.\n */\nexport const MessagePartChildren: FC<{\n index: number;\n children: (value: { part: EnrichedPartState }) => ReactNode;\n}> = ({ index, children }) => {\n const aui = useAui();\n // Subscribed (not snapshotted like `tools`) so fallbacks registered\n // after the first render trigger a re-render and `hasUI` re-evaluates.\n const dataRenderers = useAuiState((s) => s.dataRenderers);\n\n return (\n <PartByIndexProvider index={index}>\n <RenderChildrenWithAccessor\n getItemState={(aui) => aui.message().part({ index }).getState()}\n >\n {(getItem) =>\n children({\n get part() {\n const state = getItem();\n if (state.type === \"tool-call\") {\n const toolsState = aui.tools().getState();\n const hasUI = resolveToolRender(toolsState, state) !== null;\n const partMethods = aui.message().part({ index });\n return {\n ...state,\n toolUI: hasUI ? <RegisteredToolUI /> : null,\n addResult: partMethods.addToolResult,\n resume: partMethods.resumeToolCall,\n respondToApproval: partMethods.respondToToolApproval,\n };\n }\n if (state.type === \"data\") {\n const hasUI =\n getDataRenderer(dataRenderers, state.name, undefined) !==\n undefined;\n return {\n ...state,\n dataRendererUI: hasUI ? <RegisteredDataRendererUI /> : null,\n };\n }\n return state;\n },\n })\n }\n </RenderChildrenWithAccessor>\n </PartByIndexProvider>\n );\n};\n\nconst MessagePrimitivePartsInner: FC<{\n children: (value: { part: EnrichedPartState }) => ReactNode;\n}> = ({ children }) => {\n const contentLength = useAuiState((s) => s.message.parts.length);\n const isRunning = useAuiState(\n (s) => (s.message.status?.type ?? \"complete\") === \"running\",\n );\n const isEmptyRunning = contentLength === 0 && isRunning;\n\n if (contentLength === 0) {\n if (!isEmptyRunning) return null;\n return (\n <TextMessagePartProvider text=\"\" isRunning>\n {children({ part: EMPTY_RUNNING_TEXT_PART })}\n </TextMessagePartProvider>\n );\n }\n\n return (\n <>\n {Array.from({ length: contentLength }, (_, index) => (\n <MessagePartChildren key={index} index={index}>\n {(value) => children(value) ?? <DefaultPartFallback />}\n </MessagePartChildren>\n ))}\n </>\n );\n};\n\n/**\n * Renders the parts of a message with support for multiple content types.\n *\n * This is the platform-agnostic base. Each platform wraps this with its own\n * default components (web uses `<p>`, `<span>`; RN would use `<Text>`, etc.).\n */\nexport const MessagePrimitiveParts: FC<MessagePrimitiveParts.Props> = ({\n components,\n unstable_showEmptyOnNonTextEnd = true,\n children,\n}) => {\n if (children) {\n return <MessagePrimitivePartsInner>{children}</MessagePrimitivePartsInner>;\n }\n return (\n <MessagePrimitivePartsCompat\n components={components}\n unstable_showEmptyOnNonTextEnd={unstable_showEmptyOnNonTextEnd}\n />\n );\n};\n\nMessagePrimitiveParts.displayName = \"MessagePrimitive.Parts\";\n\nconst MessagePrimitivePartsCompat: FC<{\n components: MessagePrimitiveParts.Props[\"components\"];\n unstable_showEmptyOnNonTextEnd: boolean;\n}> = ({ components, unstable_showEmptyOnNonTextEnd }) => {\n const contentLength = useAuiState((s) => s.message.parts.length);\n const useChainOfThought = !!components?.ChainOfThought;\n const messageRanges = useMessagePartsGroups(useChainOfThought);\n\n const partsElements = useMemo(() => {\n if (contentLength === 0) {\n return <EmptyParts components={components} />;\n }\n\n return messageRanges.map((range) => {\n if (range.type === \"single\") {\n return (\n <MessagePrimitivePartByIndex\n key={range.index}\n index={range.index}\n components={components}\n />\n );\n } else if (range.type === \"chainOfThoughtGroup\") {\n const ChainOfThoughtComponent = components?.ChainOfThought;\n if (!ChainOfThoughtComponent) return null;\n return (\n <ChainOfThoughtByIndicesProvider\n key={`chainOfThought-${range.startIndex}`}\n startIndex={range.startIndex}\n endIndex={range.endIndex}\n >\n <ChainOfThoughtComponent />\n </ChainOfThoughtByIndicesProvider>\n );\n } else if (range.type === \"toolGroup\") {\n const ToolGroupComponent =\n components?.ToolGroup ?? defaultComponents.ToolGroup;\n return (\n <ToolGroupComponent\n key={`tool-${range.startIndex}`}\n startIndex={range.startIndex}\n endIndex={range.endIndex}\n >\n {Array.from(\n { length: range.endIndex - range.startIndex + 1 },\n (_, i) => {\n const partIndex = range.startIndex + i;\n return (\n <MessagePrimitivePartByIndex\n key={`part-${partIndex}`}\n index={partIndex}\n components={components}\n />\n );\n },\n )}\n </ToolGroupComponent>\n );\n } else {\n // reasoningGroup\n const ReasoningGroupComponent =\n components?.ReasoningGroup ?? defaultComponents.ReasoningGroup;\n return (\n <ReasoningGroupComponent\n key={`reasoning-${range.startIndex}`}\n startIndex={range.startIndex}\n endIndex={range.endIndex}\n >\n {Array.from(\n { length: range.endIndex - range.startIndex + 1 },\n (_, i) => {\n const partIndex = range.startIndex + i;\n return (\n <MessagePrimitivePartByIndex\n key={`part-${partIndex}`}\n index={partIndex}\n components={components}\n />\n );\n },\n )}\n </ReasoningGroupComponent>\n );\n }\n });\n }, [messageRanges, components, contentLength]);\n\n return (\n <>\n {components?.Quote && <QuoteRenderer Quote={components.Quote} />}\n {partsElements}\n <ConditionalEmpty\n components={components}\n enabled={unstable_showEmptyOnNonTextEnd}\n />\n </>\n );\n};\n"],"mappings":"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"}
@@ -1,5 +1,5 @@
1
1
  import { getMessageQuote } from "../../utils/getMessageQuote.js";
2
- import { memo } from "react";
2
+ import { memo } from "@assistant-ui/tap/react-shim";
3
3
  import { useAuiState } from "@assistant-ui/store";
4
4
  import { Fragment as Fragment$1, jsx } from "react/jsx-runtime";
5
5
  //#region src/react/primitives/message/MessageQuote.tsx
@@ -20,7 +20,7 @@ declare namespace PartPrimitiveMessages {
20
20
  *
21
21
  * @example
22
22
  * ```tsx
23
- * const toolkit = {
23
+ * const toolkit = defineToolkit({
24
24
  * invoke_sub_agent: {
25
25
  * type: "backend",
26
26
  * render: () => (
@@ -32,7 +32,7 @@ declare namespace PartPrimitiveMessages {
32
32
  * </PartPrimitive.Messages>
33
33
  * ),
34
34
  * },
35
- * } satisfies Toolkit;
35
+ * });
36
36
  * ```
37
37
  */
38
38
  declare const PartPrimitiveMessagesImpl: FC<PartPrimitiveMessages.Props>;
@@ -1,6 +1,6 @@
1
1
  import { ReadonlyThreadProvider } from "../../providers/ReadonlyThreadProvider.js";
2
2
  import { ThreadPrimitiveMessagesImpl } from "../thread/ThreadMessages.js";
3
- import { memo } from "react";
3
+ import { memo } from "@assistant-ui/tap/react-shim";
4
4
  import { useAuiState } from "@assistant-ui/store";
5
5
  import { jsx } from "react/jsx-runtime";
6
6
  //#region src/react/primitives/part/PartMessages.tsx
@@ -20,7 +20,7 @@ const usePartMessages = () => {
20
20
  *
21
21
  * @example
22
22
  * ```tsx
23
- * const toolkit = {
23
+ * const toolkit = defineToolkit({
24
24
  * invoke_sub_agent: {
25
25
  * type: "backend",
26
26
  * render: () => (
@@ -32,7 +32,7 @@ const usePartMessages = () => {
32
32
  * </PartPrimitive.Messages>
33
33
  * ),
34
34
  * },
35
- * } satisfies Toolkit;
35
+ * });
36
36
  * ```
37
37
  */
38
38
  const PartPrimitiveMessagesImpl = ({ components, children }) => {
@@ -1 +1 @@
1
- {"version":3,"file":"PartMessages.js","names":[],"sources":["../../../../src/react/primitives/part/PartMessages.tsx"],"sourcesContent":["import { type FC, type ReactNode, memo } from \"react\";\nimport { useAuiState } from \"@assistant-ui/store\";\nimport type { ThreadMessage } from \"../../../types/message\";\nimport { ReadonlyThreadProvider } from \"../../providers/ReadonlyThreadProvider\";\nimport {\n type ThreadPrimitiveMessages,\n ThreadPrimitiveMessagesImpl,\n} from \"../thread/ThreadMessages\";\n\nexport namespace PartPrimitiveMessages {\n export type Props = {\n components?: ThreadPrimitiveMessages.Props[\"components\"];\n /** Render function called for each message. Receives the message. */\n children?: (value: { message: ThreadMessage }) => ReactNode;\n };\n}\n\nconst usePartMessages = (): readonly ThreadMessage[] | undefined => {\n return useAuiState((s) => {\n const part = s.part;\n if (part.type !== \"tool-call\") return undefined;\n return \"messages\" in part\n ? (part.messages as readonly ThreadMessage[] | undefined)\n : undefined;\n });\n};\n\n/**\n * Renders the nested messages of a tool call part (e.g. sub-agent conversation).\n *\n * This primitive reads `messages` from the current tool call part in the PartScope\n * and renders them using a readonly thread context. All existing message and part\n * primitives work inside, and parent tool UI registrations are inherited.\n *\n * @example\n * ```tsx\n * const toolkit = {\n * invoke_sub_agent: {\n * type: \"backend\",\n * render: () => (\n * <PartPrimitive.Messages>\n * {({ message }) => {\n * if (message.role === \"user\") return <MyUserMessage />;\n * return <MyAssistantMessage />;\n * }}\n * </PartPrimitive.Messages>\n * ),\n * },\n * } satisfies Toolkit;\n * ```\n */\nexport const PartPrimitiveMessagesImpl: FC<PartPrimitiveMessages.Props> = ({\n components,\n children,\n}) => {\n const messages = usePartMessages();\n\n if (!messages?.length) return null;\n\n if (children) {\n return (\n <ReadonlyThreadProvider messages={messages}>\n <ThreadPrimitiveMessagesImpl>{children}</ThreadPrimitiveMessagesImpl>\n </ReadonlyThreadProvider>\n );\n }\n\n return (\n <ReadonlyThreadProvider messages={messages}>\n <ThreadPrimitiveMessagesImpl components={components!} />\n </ReadonlyThreadProvider>\n );\n};\n\nPartPrimitiveMessagesImpl.displayName = \"PartPrimitive.Messages\";\n\nexport const PartPrimitiveMessages = memo(PartPrimitiveMessagesImpl);\n"],"mappings":";;;;;;AAiBA,MAAM,wBAA8D;CAClE,OAAO,aAAa,MAAM;EACxB,MAAM,OAAO,EAAE;EACf,IAAI,KAAK,SAAS,aAAa,OAAO,KAAA;EACtC,OAAO,cAAc,OAChB,KAAK,WACN,KAAA;CACN,CAAC;AACH;;;;;;;;;;;;;;;;;;;;;;;;;AA0BA,MAAa,6BAA8D,EACzE,YACA,eACI;CACJ,MAAM,WAAW,gBAAgB;CAEjC,IAAI,CAAC,UAAU,QAAQ,OAAO;CAE9B,IAAI,UACF,OACE,oBAAC,wBAAD;EAAkC;YAChC,oBAAC,6BAAD,EAA8B,SAAsC,CAAA;CAC9C,CAAA;CAI5B,OACE,oBAAC,wBAAD;EAAkC;YAChC,oBAAC,6BAAD,EAAyC,WAAc,CAAA;CACjC,CAAA;AAE5B;AAEA,0BAA0B,cAAc;AAExC,MAAa,wBAAwB,KAAK,yBAAyB"}
1
+ {"version":3,"file":"PartMessages.js","names":[],"sources":["../../../../src/react/primitives/part/PartMessages.tsx"],"sourcesContent":["import { type FC, type ReactNode, memo } from \"react\";\nimport { useAuiState } from \"@assistant-ui/store\";\nimport type { ThreadMessage } from \"../../../types/message\";\nimport { ReadonlyThreadProvider } from \"../../providers/ReadonlyThreadProvider\";\nimport {\n type ThreadPrimitiveMessages,\n ThreadPrimitiveMessagesImpl,\n} from \"../thread/ThreadMessages\";\n\nexport namespace PartPrimitiveMessages {\n export type Props = {\n components?: ThreadPrimitiveMessages.Props[\"components\"];\n /** Render function called for each message. Receives the message. */\n children?: (value: { message: ThreadMessage }) => ReactNode;\n };\n}\n\nconst usePartMessages = (): readonly ThreadMessage[] | undefined => {\n return useAuiState((s) => {\n const part = s.part;\n if (part.type !== \"tool-call\") return undefined;\n return \"messages\" in part\n ? (part.messages as readonly ThreadMessage[] | undefined)\n : undefined;\n });\n};\n\n/**\n * Renders the nested messages of a tool call part (e.g. sub-agent conversation).\n *\n * This primitive reads `messages` from the current tool call part in the PartScope\n * and renders them using a readonly thread context. All existing message and part\n * primitives work inside, and parent tool UI registrations are inherited.\n *\n * @example\n * ```tsx\n * const toolkit = defineToolkit({\n * invoke_sub_agent: {\n * type: \"backend\",\n * render: () => (\n * <PartPrimitive.Messages>\n * {({ message }) => {\n * if (message.role === \"user\") return <MyUserMessage />;\n * return <MyAssistantMessage />;\n * }}\n * </PartPrimitive.Messages>\n * ),\n * },\n * });\n * ```\n */\nexport const PartPrimitiveMessagesImpl: FC<PartPrimitiveMessages.Props> = ({\n components,\n children,\n}) => {\n const messages = usePartMessages();\n\n if (!messages?.length) return null;\n\n if (children) {\n return (\n <ReadonlyThreadProvider messages={messages}>\n <ThreadPrimitiveMessagesImpl>{children}</ThreadPrimitiveMessagesImpl>\n </ReadonlyThreadProvider>\n );\n }\n\n return (\n <ReadonlyThreadProvider messages={messages}>\n <ThreadPrimitiveMessagesImpl components={components!} />\n </ReadonlyThreadProvider>\n );\n};\n\nPartPrimitiveMessagesImpl.displayName = \"PartPrimitive.Messages\";\n\nexport const PartPrimitiveMessages = memo(PartPrimitiveMessagesImpl);\n"],"mappings":";;;;;;AAiBA,MAAM,wBAA8D;CAClE,OAAO,aAAa,MAAM;EACxB,MAAM,OAAO,EAAE;EACf,IAAI,KAAK,SAAS,aAAa,OAAO,KAAA;EACtC,OAAO,cAAc,OAChB,KAAK,WACN,KAAA;CACN,CAAC;AACH;;;;;;;;;;;;;;;;;;;;;;;;;AA0BA,MAAa,6BAA8D,EACzE,YACA,eACI;CACJ,MAAM,WAAW,gBAAgB;CAEjC,IAAI,CAAC,UAAU,QAAQ,OAAO;CAE9B,IAAI,UACF,OACE,oBAAC,wBAAD;EAAkC;YAChC,oBAAC,6BAAD,EAA8B,SAAsC,CAAA;CAC9C,CAAA;CAI5B,OACE,oBAAC,wBAAD;EAAkC;YAChC,oBAAC,6BAAD,EAAyC,WAAc,CAAA;CACjC,CAAA;AAE5B;AAEA,0BAA0B,cAAc;AAExC,MAAa,wBAAwB,KAAK,yBAAyB"}
@@ -1,5 +1,5 @@
1
1
  import { MessageByIndexProvider } from "../../providers/MessageByIndexProvider.js";
2
- import { memo, useMemo } from "react";
2
+ import { memo, useMemo } from "@assistant-ui/tap/react-shim";
3
3
  import { RenderChildrenWithAccessor, useAuiState } from "@assistant-ui/store";
4
4
  import { jsx } from "react/jsx-runtime";
5
5
  //#region src/react/primitives/thread/ThreadMessages.tsx
@@ -1 +1 @@
1
- {"version":3,"file":"ThreadMessages.js","names":["_exhaustiveCheck"],"sources":["../../../../src/react/primitives/thread/ThreadMessages.tsx"],"sourcesContent":["import {\n type ComponentType,\n type FC,\n type ReactNode,\n memo,\n useMemo,\n} from \"react\";\nimport { RenderChildrenWithAccessor, useAuiState } from \"@assistant-ui/store\";\nimport { MessageByIndexProvider } from \"../../providers/MessageByIndexProvider\";\nimport type { MessageState } from \"../../../store\";\n\ntype MessagesComponentConfig =\n | {\n /** Component used to render all message types */\n Message: ComponentType;\n /** Component used when editing any message type */\n EditComposer?: ComponentType | undefined;\n /** Component used when editing user messages specifically */\n UserEditComposer?: ComponentType | undefined;\n /** Component used when editing assistant messages specifically */\n AssistantEditComposer?: ComponentType | undefined;\n /** Component used when editing system messages specifically */\n SystemEditComposer?: ComponentType | undefined;\n /** Component used to render user messages specifically */\n UserMessage?: ComponentType | undefined;\n /** Component used to render assistant messages specifically */\n AssistantMessage?: ComponentType | undefined;\n /** Component used to render system messages specifically */\n SystemMessage?: ComponentType | undefined;\n }\n | {\n /** Component used to render all message types (fallback) */\n Message?: ComponentType | undefined;\n /** Component used when editing any message type */\n EditComposer?: ComponentType | undefined;\n /** Component used when editing user messages specifically */\n UserEditComposer?: ComponentType | undefined;\n /** Component used when editing assistant messages specifically */\n AssistantEditComposer?: ComponentType | undefined;\n /** Component used when editing system messages specifically */\n SystemEditComposer?: ComponentType | undefined;\n /** Component used to render user messages */\n UserMessage: ComponentType;\n /** Component used to render assistant messages */\n AssistantMessage: ComponentType;\n /** Component used to render system messages */\n SystemMessage?: ComponentType | undefined;\n };\n\nexport namespace ThreadPrimitiveMessages {\n export type Props =\n | {\n /** @deprecated Use the children render function instead. */\n components: MessagesComponentConfig;\n children?: never;\n }\n | {\n /** Render function called for each message. Receives the message. */\n children: (value: { message: MessageState }) => ReactNode;\n components?: never;\n };\n}\n\nconst isComponentsSame = (\n prev: MessagesComponentConfig,\n next: MessagesComponentConfig,\n) => {\n return (\n prev.Message === next.Message &&\n prev.EditComposer === next.EditComposer &&\n prev.UserEditComposer === next.UserEditComposer &&\n prev.AssistantEditComposer === next.AssistantEditComposer &&\n prev.SystemEditComposer === next.SystemEditComposer &&\n prev.UserMessage === next.UserMessage &&\n prev.AssistantMessage === next.AssistantMessage &&\n prev.SystemMessage === next.SystemMessage\n );\n};\n\nconst DEFAULT_SYSTEM_MESSAGE = () => null;\n\nconst getComponent = (\n components: MessagesComponentConfig,\n role: MessageState[\"role\"],\n isEditing: boolean,\n) => {\n switch (role) {\n case \"user\":\n if (isEditing) {\n return (\n components.UserEditComposer ??\n components.EditComposer ??\n components.UserMessage ??\n (components.Message as ComponentType)\n );\n } else {\n return components.UserMessage ?? (components.Message as ComponentType);\n }\n case \"assistant\":\n if (isEditing) {\n return (\n components.AssistantEditComposer ??\n components.EditComposer ??\n components.AssistantMessage ??\n (components.Message as ComponentType)\n );\n } else {\n return (\n components.AssistantMessage ?? (components.Message as ComponentType)\n );\n }\n case \"system\":\n if (isEditing) {\n return (\n components.SystemEditComposer ??\n components.EditComposer ??\n components.SystemMessage ??\n (components.Message as ComponentType)\n );\n } else {\n return (\n components.SystemMessage ??\n (components.Message as ComponentType) ??\n DEFAULT_SYSTEM_MESSAGE\n );\n }\n default: {\n const _exhaustiveCheck: never = role;\n throw new Error(`Unknown message role: ${_exhaustiveCheck}`);\n }\n }\n};\n\ntype ThreadMessageComponentProps = {\n components: MessagesComponentConfig;\n};\n\nconst ThreadMessageComponent: FC<ThreadMessageComponentProps> = ({\n components,\n}) => {\n const role = useAuiState((s) => s.message.role);\n const isEditing = useAuiState((s) => s.message.composer.isEditing);\n const Component = getComponent(components, role, isEditing);\n\n return <Component />;\n};\nexport namespace ThreadPrimitiveMessageByIndex {\n export type Props = {\n index: number;\n components: MessagesComponentConfig;\n };\n}\n\n/**\n * Renders a single message at the specified index in the current thread.\n */\nexport const ThreadPrimitiveMessageByIndex: FC<ThreadPrimitiveMessageByIndex.Props> =\n memo(\n ({ index, components }) => {\n return (\n <MessageByIndexProvider index={index}>\n <ThreadMessageComponent components={components} />\n </MessageByIndexProvider>\n );\n },\n (prev, next) =>\n prev.index === next.index &&\n isComponentsSame(prev.components, next.components),\n );\n\nThreadPrimitiveMessageByIndex.displayName = \"ThreadPrimitive.MessageByIndex\";\n\nconst ThreadPrimitiveMessagesInner: FC<{\n children: (value: { message: MessageState }) => ReactNode;\n}> = ({ children }) => {\n const messagesLength = useAuiState((s) => s.thread.messages.length);\n\n return useMemo(() => {\n if (messagesLength === 0) return null;\n return Array.from({ length: messagesLength }, (_, index) => (\n <MessageByIndexProvider key={index} index={index}>\n <RenderChildrenWithAccessor\n getItemState={(aui) => aui.thread().message({ index }).getState()}\n >\n {(getItem) =>\n children({\n get message() {\n return getItem();\n },\n })\n }\n </RenderChildrenWithAccessor>\n </MessageByIndexProvider>\n ));\n }, [messagesLength, children]);\n};\n\n/**\n * Renders all messages in the current thread.\n *\n * @example\n * ```tsx\n * <ThreadPrimitive.Messages>\n * {({ message }) => {\n * if (message.role === \"user\") return <MyUserMessage />;\n * return <MyAssistantMessage />;\n * }}\n * </ThreadPrimitive.Messages>\n * ```\n */\nexport const ThreadPrimitiveMessagesImpl: FC<ThreadPrimitiveMessages.Props> = ({\n components,\n children,\n}) => {\n if (components) {\n return (\n <ThreadPrimitiveMessagesInner>\n {() => <ThreadMessageComponent components={components} />}\n </ThreadPrimitiveMessagesInner>\n );\n }\n return (\n <ThreadPrimitiveMessagesInner>{children}</ThreadPrimitiveMessagesInner>\n );\n};\n\nThreadPrimitiveMessagesImpl.displayName = \"ThreadPrimitive.Messages\";\n\nexport const ThreadPrimitiveMessages = memo(\n ThreadPrimitiveMessagesImpl,\n (prev, next) => {\n if (prev.children || next.children) {\n return prev.children === next.children;\n }\n return isComponentsSame(prev.components!, next.components!);\n },\n);\n"],"mappings":";;;;;AA+DA,MAAM,oBACJ,MACA,SACG;CACH,OACE,KAAK,YAAY,KAAK,WACtB,KAAK,iBAAiB,KAAK,gBAC3B,KAAK,qBAAqB,KAAK,oBAC/B,KAAK,0BAA0B,KAAK,yBACpC,KAAK,uBAAuB,KAAK,sBACjC,KAAK,gBAAgB,KAAK,eAC1B,KAAK,qBAAqB,KAAK,oBAC/B,KAAK,kBAAkB,KAAK;AAEhC;AAEA,MAAM,+BAA+B;AAErC,MAAM,gBACJ,YACA,MACA,cACG;CACH,QAAQ,MAAR;EACE,KAAK,QACH,IAAI,WACF,OACE,WAAW,oBACX,WAAW,gBACX,WAAW,eACV,WAAW;OAGd,OAAO,WAAW,eAAgB,WAAW;EAEjD,KAAK,aACH,IAAI,WACF,OACE,WAAW,yBACX,WAAW,gBACX,WAAW,oBACV,WAAW;OAGd,OACE,WAAW,oBAAqB,WAAW;EAGjD,KAAK,UACH,IAAI,WACF,OACE,WAAW,sBACX,WAAW,gBACX,WAAW,iBACV,WAAW;OAGd,OACE,WAAW,iBACV,WAAW,WACZ;EAGN,SAEE,MAAM,IAAI,MAAM,yBAAyBA,MAAkB;CAE/D;AACF;AAMA,MAAM,0BAA2D,EAC/D,iBACI;CAKJ,OAAO,oBAFW,aAAa,YAFlB,aAAa,MAAM,EAAE,QAAQ,IAEI,GAD5B,aAAa,MAAM,EAAE,QAAQ,SAAS,SACC,CAEzC,GAAT,CAAY,CAAA;AACrB;;;;AAWA,MAAa,gCACX,MACG,EAAE,OAAO,iBAAiB;CACzB,OACE,oBAAC,wBAAD;EAA+B;YAC7B,oBAAC,wBAAD,EAAoC,WAAa,CAAA;CAC3B,CAAA;AAE5B,IACC,MAAM,SACL,KAAK,UAAU,KAAK,SACpB,iBAAiB,KAAK,YAAY,KAAK,UAAU,CACrD;AAEF,8BAA8B,cAAc;AAE5C,MAAM,gCAEA,EAAE,eAAe;CACrB,MAAM,iBAAiB,aAAa,MAAM,EAAE,OAAO,SAAS,MAAM;CAElE,OAAO,cAAc;EACnB,IAAI,mBAAmB,GAAG,OAAO;EACjC,OAAO,MAAM,KAAK,EAAE,QAAQ,eAAe,IAAI,GAAG,UAChD,oBAAC,wBAAD;GAA2C;aACzC,oBAAC,4BAAD;IACE,eAAe,QAAQ,IAAI,OAAO,EAAE,QAAQ,EAAE,MAAM,CAAC,EAAE,SAAS;eAE9D,YACA,SAAS,EACP,IAAI,UAAU;KACZ,OAAO,QAAQ;IACjB,EACF,CAAC;GAEuB,CAAA;EACN,GAZK,KAYL,CACzB;CACH,GAAG,CAAC,gBAAgB,QAAQ,CAAC;AAC/B;;;;;;;;;;;;;;AAeA,MAAa,+BAAkE,EAC7E,YACA,eACI;CACJ,IAAI,YACF,OACE,oBAAC,8BAAD,EAAA,gBACS,oBAAC,wBAAD,EAAoC,WAAa,CAAA,EAC5B,CAAA;CAGlC,OACE,oBAAC,8BAAD,EAA+B,SAAuC,CAAA;AAE1E;AAEA,4BAA4B,cAAc;AAE1C,MAAa,0BAA0B,KACrC,8BACC,MAAM,SAAS;CACd,IAAI,KAAK,YAAY,KAAK,UACxB,OAAO,KAAK,aAAa,KAAK;CAEhC,OAAO,iBAAiB,KAAK,YAAa,KAAK,UAAW;AAC5D,CACF"}
1
+ {"version":3,"file":"ThreadMessages.js","names":["_exhaustiveCheck"],"sources":["../../../../src/react/primitives/thread/ThreadMessages.tsx"],"sourcesContent":["import {\n type ComponentType,\n type FC,\n type ReactNode,\n memo,\n useMemo,\n} from \"react\";\nimport { RenderChildrenWithAccessor, useAuiState } from \"@assistant-ui/store\";\nimport { MessageByIndexProvider } from \"../../providers/MessageByIndexProvider\";\nimport type { MessageState } from \"../../../store\";\n\ntype MessagesComponentConfig =\n | {\n /** Component used to render all message types */\n Message: ComponentType;\n /** Component used when editing any message type */\n EditComposer?: ComponentType | undefined;\n /** Component used when editing user messages specifically */\n UserEditComposer?: ComponentType | undefined;\n /** Component used when editing assistant messages specifically */\n AssistantEditComposer?: ComponentType | undefined;\n /** Component used when editing system messages specifically */\n SystemEditComposer?: ComponentType | undefined;\n /** Component used to render user messages specifically */\n UserMessage?: ComponentType | undefined;\n /** Component used to render assistant messages specifically */\n AssistantMessage?: ComponentType | undefined;\n /** Component used to render system messages specifically */\n SystemMessage?: ComponentType | undefined;\n }\n | {\n /** Component used to render all message types (fallback) */\n Message?: ComponentType | undefined;\n /** Component used when editing any message type */\n EditComposer?: ComponentType | undefined;\n /** Component used when editing user messages specifically */\n UserEditComposer?: ComponentType | undefined;\n /** Component used when editing assistant messages specifically */\n AssistantEditComposer?: ComponentType | undefined;\n /** Component used when editing system messages specifically */\n SystemEditComposer?: ComponentType | undefined;\n /** Component used to render user messages */\n UserMessage: ComponentType;\n /** Component used to render assistant messages */\n AssistantMessage: ComponentType;\n /** Component used to render system messages */\n SystemMessage?: ComponentType | undefined;\n };\n\nexport namespace ThreadPrimitiveMessages {\n export type Props =\n | {\n /** @deprecated Use the children render function instead. */\n components: MessagesComponentConfig;\n children?: never;\n }\n | {\n /** Render function called for each message. Receives the message. */\n children: (value: { message: MessageState }) => ReactNode;\n components?: never;\n };\n}\n\nconst isComponentsSame = (\n prev: MessagesComponentConfig,\n next: MessagesComponentConfig,\n) => {\n return (\n prev.Message === next.Message &&\n prev.EditComposer === next.EditComposer &&\n prev.UserEditComposer === next.UserEditComposer &&\n prev.AssistantEditComposer === next.AssistantEditComposer &&\n prev.SystemEditComposer === next.SystemEditComposer &&\n prev.UserMessage === next.UserMessage &&\n prev.AssistantMessage === next.AssistantMessage &&\n prev.SystemMessage === next.SystemMessage\n );\n};\n\nconst DEFAULT_SYSTEM_MESSAGE = () => null;\n\nconst getComponent = (\n components: MessagesComponentConfig,\n role: MessageState[\"role\"],\n isEditing: boolean,\n) => {\n switch (role) {\n case \"user\":\n if (isEditing) {\n return (\n components.UserEditComposer ??\n components.EditComposer ??\n components.UserMessage ??\n (components.Message as ComponentType)\n );\n } else {\n return components.UserMessage ?? (components.Message as ComponentType);\n }\n case \"assistant\":\n if (isEditing) {\n return (\n components.AssistantEditComposer ??\n components.EditComposer ??\n components.AssistantMessage ??\n (components.Message as ComponentType)\n );\n } else {\n return (\n components.AssistantMessage ?? (components.Message as ComponentType)\n );\n }\n case \"system\":\n if (isEditing) {\n return (\n components.SystemEditComposer ??\n components.EditComposer ??\n components.SystemMessage ??\n (components.Message as ComponentType)\n );\n } else {\n return (\n components.SystemMessage ??\n (components.Message as ComponentType) ??\n DEFAULT_SYSTEM_MESSAGE\n );\n }\n default: {\n const _exhaustiveCheck: never = role;\n throw new Error(`Unknown message role: ${_exhaustiveCheck}`);\n }\n }\n};\n\ntype ThreadMessageComponentProps = {\n components: MessagesComponentConfig;\n};\n\nconst ThreadMessageComponent: FC<ThreadMessageComponentProps> = ({\n components,\n}) => {\n const role = useAuiState((s) => s.message.role);\n const isEditing = useAuiState((s) => s.message.composer.isEditing);\n const Component = getComponent(components, role, isEditing);\n\n return <Component />;\n};\nexport namespace ThreadPrimitiveMessageByIndex {\n export type Props = {\n index: number;\n components: MessagesComponentConfig;\n };\n}\n\n/**\n * Renders a single message at the specified index in the current thread.\n */\nexport const ThreadPrimitiveMessageByIndex: FC<ThreadPrimitiveMessageByIndex.Props> =\n memo(\n ({ index, components }) => {\n return (\n <MessageByIndexProvider index={index}>\n <ThreadMessageComponent components={components} />\n </MessageByIndexProvider>\n );\n },\n (prev, next) =>\n prev.index === next.index &&\n isComponentsSame(prev.components, next.components),\n );\n\nThreadPrimitiveMessageByIndex.displayName = \"ThreadPrimitive.MessageByIndex\";\n\nconst ThreadPrimitiveMessagesInner: FC<{\n children: (value: { message: MessageState }) => ReactNode;\n}> = ({ children }) => {\n const messagesLength = useAuiState((s) => s.thread.messages.length);\n\n return useMemo(() => {\n if (messagesLength === 0) return null;\n return Array.from({ length: messagesLength }, (_, index) => (\n <MessageByIndexProvider key={index} index={index}>\n <RenderChildrenWithAccessor\n getItemState={(aui) => aui.thread().message({ index }).getState()}\n >\n {(getItem) =>\n children({\n get message() {\n return getItem();\n },\n })\n }\n </RenderChildrenWithAccessor>\n </MessageByIndexProvider>\n ));\n }, [messagesLength, children]);\n};\n\n/**\n * Renders all messages in the current thread.\n *\n * @example\n * ```tsx\n * <ThreadPrimitive.Messages>\n * {({ message }) => {\n * if (message.role === \"user\") return <MyUserMessage />;\n * return <MyAssistantMessage />;\n * }}\n * </ThreadPrimitive.Messages>\n * ```\n */\nexport const ThreadPrimitiveMessagesImpl: FC<ThreadPrimitiveMessages.Props> = ({\n components,\n children,\n}) => {\n if (components) {\n return (\n <ThreadPrimitiveMessagesInner>\n {() => <ThreadMessageComponent components={components} />}\n </ThreadPrimitiveMessagesInner>\n );\n }\n return (\n <ThreadPrimitiveMessagesInner>{children}</ThreadPrimitiveMessagesInner>\n );\n};\n\nThreadPrimitiveMessagesImpl.displayName = \"ThreadPrimitive.Messages\";\n\nexport const ThreadPrimitiveMessages = memo(\n ThreadPrimitiveMessagesImpl,\n (prev, next) => {\n if (prev.children || next.children) {\n return prev.children === next.children;\n }\n return isComponentsSame(prev.components!, next.components!);\n },\n);\n"],"mappings":";;;;;AA+DA,MAAM,oBACJ,MACA,SACG;CACH,OACE,KAAK,YAAY,KAAK,WACtB,KAAK,iBAAiB,KAAK,gBAC3B,KAAK,qBAAqB,KAAK,oBAC/B,KAAK,0BAA0B,KAAK,yBACpC,KAAK,uBAAuB,KAAK,sBACjC,KAAK,gBAAgB,KAAK,eAC1B,KAAK,qBAAqB,KAAK,oBAC/B,KAAK,kBAAkB,KAAK;AAEhC;AAEA,MAAM,+BAA+B;AAErC,MAAM,gBACJ,YACA,MACA,cACG;CACH,QAAQ,MAAR;EACE,KAAK,QACH,IAAI,WACF,OACE,WAAW,oBACX,WAAW,gBACX,WAAW,eACV,WAAW;OAGd,OAAO,WAAW,eAAgB,WAAW;EAEjD,KAAK,aACH,IAAI,WACF,OACE,WAAW,yBACX,WAAW,gBACX,WAAW,oBACV,WAAW;OAGd,OACE,WAAW,oBAAqB,WAAW;EAGjD,KAAK,UACH,IAAI,WACF,OACE,WAAW,sBACX,WAAW,gBACX,WAAW,iBACV,WAAW;OAGd,OACE,WAAW,iBACV,WAAW,WACZ;EAGN,SAEE,MAAM,IAAI,MAAM,yBAAyBA,MAAkB;CAE/D;AACF;AAMA,MAAM,0BAA2D,EAC/D,iBACI;CAKJ,OAAO,oBAFW,aAAa,YAFlB,aAAa,MAAM,EAAE,QAAQ,IAEI,GAD5B,aAAa,MAAM,EAAE,QAAQ,SAAS,SACC,CAEzC,GAAT,CAAY,CAAA;AACrB;;;;AAWA,MAAa,gCACX,MACG,EAAE,OAAO,iBAAiB;CACzB,OACE,oBAAC,wBAAD;EAA+B;YAC7B,oBAAC,wBAAD,EAAoC,WAAa,CAAA;CAC3B,CAAA;AAE5B,IACC,MAAM,SACL,KAAK,UAAU,KAAK,SACpB,iBAAiB,KAAK,YAAY,KAAK,UAAU,CACrD;AAEF,8BAA8B,cAAc;AAE5C,MAAM,gCAEA,EAAE,eAAe;CACrB,MAAM,iBAAiB,aAAa,MAAM,EAAE,OAAO,SAAS,MAAM;CAElE,OAAO,cAAc;EACnB,IAAI,mBAAmB,GAAG,OAAO;EACjC,OAAO,MAAM,KAAK,EAAE,QAAQ,eAAe,IAAI,GAAG,UAChD,oBAAC,wBAAD;GAA2C;aACzC,oBAAC,4BAAD;IACE,eAAe,QAAQ,IAAI,OAAO,CAAC,CAAC,QAAQ,EAAE,MAAM,CAAC,CAAC,CAAC,SAAS;eAE9D,YACA,SAAS,EACP,IAAI,UAAU;KACZ,OAAO,QAAQ;IACjB,EACF,CAAC;GAEuB,CAAA;EACN,GAZK,KAYL,CACzB;CACH,GAAG,CAAC,gBAAgB,QAAQ,CAAC;AAC/B;;;;;;;;;;;;;;AAeA,MAAa,+BAAkE,EAC7E,YACA,eACI;CACJ,IAAI,YACF,OACE,oBAAC,8BAAD,EAAA,gBACS,oBAAC,wBAAD,EAAoC,WAAa,CAAA,EAC5B,CAAA;CAGlC,OACE,oBAAC,8BAAD,EAA+B,SAAuC,CAAA;AAE1E;AAEA,4BAA4B,cAAc;AAE1C,MAAa,0BAA0B,KACrC,8BACC,MAAM,SAAS;CACd,IAAI,KAAK,YAAY,KAAK,UACxB,OAAO,KAAK,aAAa,KAAK;CAEhC,OAAO,iBAAiB,KAAK,YAAa,KAAK,UAAW;AAC5D,CACF"}
@@ -1,5 +1,5 @@
1
1
  import { SuggestionByIndexProvider } from "../../providers/SuggestionByIndexProvider.js";
2
- import { memo, useMemo } from "react";
2
+ import { memo, useMemo } from "@assistant-ui/tap/react-shim";
3
3
  import { RenderChildrenWithAccessor, useAuiState } from "@assistant-ui/store";
4
4
  import { jsx } from "react/jsx-runtime";
5
5
  //#region src/react/primitives/thread/ThreadSuggestions.tsx
@@ -1 +1 @@
1
- {"version":3,"file":"ThreadSuggestions.js","names":[],"sources":["../../../../src/react/primitives/thread/ThreadSuggestions.tsx"],"sourcesContent":["import {\n type ComponentType,\n type FC,\n type ReactNode,\n memo,\n useMemo,\n} from \"react\";\nimport { RenderChildrenWithAccessor, useAuiState } from \"@assistant-ui/store\";\nimport type { SuggestionState } from \"../../../store/scopes/suggestion\";\nimport { SuggestionByIndexProvider } from \"../../providers/SuggestionByIndexProvider\";\n\ntype SuggestionsComponentConfig = {\n /** Component used to render each suggestion */\n Suggestion: ComponentType;\n};\n\nexport namespace ThreadPrimitiveSuggestions {\n export type Props =\n | {\n /** @deprecated Use the children render function instead. */\n components: SuggestionsComponentConfig;\n children?: never;\n }\n | {\n /** Render function called for each suggestion. Receives the suggestion. */\n children: (value: { suggestion: SuggestionState }) => ReactNode;\n components?: never;\n };\n}\n\ntype SuggestionComponentProps = {\n components: SuggestionsComponentConfig;\n};\n\nconst SuggestionComponent: FC<SuggestionComponentProps> = ({ components }) => {\n const Component = components.Suggestion;\n return <Component />;\n};\n\nexport namespace ThreadPrimitiveSuggestionByIndex {\n export type Props = {\n index: number;\n components: SuggestionsComponentConfig;\n };\n}\n\n/**\n * Renders a single suggestion at the specified index.\n */\nexport const ThreadPrimitiveSuggestionByIndex: FC<ThreadPrimitiveSuggestionByIndex.Props> =\n memo(\n ({ index, components }) => {\n return (\n <SuggestionByIndexProvider index={index}>\n <SuggestionComponent components={components} />\n </SuggestionByIndexProvider>\n );\n },\n (prev, next) =>\n prev.index === next.index &&\n prev.components.Suggestion === next.components.Suggestion,\n );\n\nThreadPrimitiveSuggestionByIndex.displayName =\n \"ThreadPrimitive.SuggestionByIndex\";\n\nconst ThreadPrimitiveSuggestionsInner: FC<{\n children: (value: { suggestion: SuggestionState }) => ReactNode;\n}> = ({ children }) => {\n const suggestionsLength = useAuiState(\n (s) => s.suggestions.suggestions.length,\n );\n\n return useMemo(() => {\n if (suggestionsLength === 0) return null;\n return Array.from({ length: suggestionsLength }, (_, index) => (\n <SuggestionByIndexProvider key={index} index={index}>\n <RenderChildrenWithAccessor\n getItemState={(aui) =>\n aui.suggestions().suggestion({ index }).getState()\n }\n >\n {(getItem) =>\n children({\n get suggestion() {\n return getItem();\n },\n })\n }\n </RenderChildrenWithAccessor>\n </SuggestionByIndexProvider>\n ));\n }, [suggestionsLength, children]);\n};\n\n/**\n * Renders all suggestions.\n */\nexport const ThreadPrimitiveSuggestionsImpl: FC<\n ThreadPrimitiveSuggestions.Props\n> = ({ components, children }) => {\n if (components) {\n return (\n <ThreadPrimitiveSuggestionsInner>\n {() => <SuggestionComponent components={components} />}\n </ThreadPrimitiveSuggestionsInner>\n );\n }\n return (\n <ThreadPrimitiveSuggestionsInner>\n {children}\n </ThreadPrimitiveSuggestionsInner>\n );\n};\n\nThreadPrimitiveSuggestionsImpl.displayName = \"ThreadPrimitive.Suggestions\";\n\nexport const ThreadPrimitiveSuggestions = memo(\n ThreadPrimitiveSuggestionsImpl,\n (prev, next) => {\n if (prev.children || next.children) {\n return prev.children === next.children;\n }\n return prev.components!.Suggestion === next.components!.Suggestion;\n },\n);\n"],"mappings":";;;;;AAkCA,MAAM,uBAAqD,EAAE,iBAAiB;CAC5E,MAAM,YAAY,WAAW;CAC7B,OAAO,oBAAC,WAAD,CAAY,CAAA;AACrB;;;;AAYA,MAAa,mCACX,MACG,EAAE,OAAO,iBAAiB;CACzB,OACE,oBAAC,2BAAD;EAAkC;YAChC,oBAAC,qBAAD,EAAiC,WAAa,CAAA;CACrB,CAAA;AAE/B,IACC,MAAM,SACL,KAAK,UAAU,KAAK,SACpB,KAAK,WAAW,eAAe,KAAK,WAAW,UACnD;AAEF,iCAAiC,cAC/B;AAEF,MAAM,mCAEA,EAAE,eAAe;CACrB,MAAM,oBAAoB,aACvB,MAAM,EAAE,YAAY,YAAY,MACnC;CAEA,OAAO,cAAc;EACnB,IAAI,sBAAsB,GAAG,OAAO;EACpC,OAAO,MAAM,KAAK,EAAE,QAAQ,kBAAkB,IAAI,GAAG,UACnD,oBAAC,2BAAD;GAA8C;aAC5C,oBAAC,4BAAD;IACE,eAAe,QACb,IAAI,YAAY,EAAE,WAAW,EAAE,MAAM,CAAC,EAAE,SAAS;eAGjD,YACA,SAAS,EACP,IAAI,aAAa;KACf,OAAO,QAAQ;IACjB,EACF,CAAC;GAEuB,CAAA;EACH,GAdK,KAcL,CAC5B;CACH,GAAG,CAAC,mBAAmB,QAAQ,CAAC;AAClC;;;;AAKA,MAAa,kCAER,EAAE,YAAY,eAAe;CAChC,IAAI,YACF,OACE,oBAAC,iCAAD,EAAA,gBACS,oBAAC,qBAAD,EAAiC,WAAa,CAAA,EACtB,CAAA;CAGrC,OACE,oBAAC,iCAAD,EACG,SAC8B,CAAA;AAErC;AAEA,+BAA+B,cAAc;AAE7C,MAAa,6BAA6B,KACxC,iCACC,MAAM,SAAS;CACd,IAAI,KAAK,YAAY,KAAK,UACxB,OAAO,KAAK,aAAa,KAAK;CAEhC,OAAO,KAAK,WAAY,eAAe,KAAK,WAAY;AAC1D,CACF"}
1
+ {"version":3,"file":"ThreadSuggestions.js","names":[],"sources":["../../../../src/react/primitives/thread/ThreadSuggestions.tsx"],"sourcesContent":["import {\n type ComponentType,\n type FC,\n type ReactNode,\n memo,\n useMemo,\n} from \"react\";\nimport { RenderChildrenWithAccessor, useAuiState } from \"@assistant-ui/store\";\nimport type { SuggestionState } from \"../../../store/scopes/suggestion\";\nimport { SuggestionByIndexProvider } from \"../../providers/SuggestionByIndexProvider\";\n\ntype SuggestionsComponentConfig = {\n /** Component used to render each suggestion */\n Suggestion: ComponentType;\n};\n\nexport namespace ThreadPrimitiveSuggestions {\n export type Props =\n | {\n /** @deprecated Use the children render function instead. */\n components: SuggestionsComponentConfig;\n children?: never;\n }\n | {\n /** Render function called for each suggestion. Receives the suggestion. */\n children: (value: { suggestion: SuggestionState }) => ReactNode;\n components?: never;\n };\n}\n\ntype SuggestionComponentProps = {\n components: SuggestionsComponentConfig;\n};\n\nconst SuggestionComponent: FC<SuggestionComponentProps> = ({ components }) => {\n const Component = components.Suggestion;\n return <Component />;\n};\n\nexport namespace ThreadPrimitiveSuggestionByIndex {\n export type Props = {\n index: number;\n components: SuggestionsComponentConfig;\n };\n}\n\n/**\n * Renders a single suggestion at the specified index.\n */\nexport const ThreadPrimitiveSuggestionByIndex: FC<ThreadPrimitiveSuggestionByIndex.Props> =\n memo(\n ({ index, components }) => {\n return (\n <SuggestionByIndexProvider index={index}>\n <SuggestionComponent components={components} />\n </SuggestionByIndexProvider>\n );\n },\n (prev, next) =>\n prev.index === next.index &&\n prev.components.Suggestion === next.components.Suggestion,\n );\n\nThreadPrimitiveSuggestionByIndex.displayName =\n \"ThreadPrimitive.SuggestionByIndex\";\n\nconst ThreadPrimitiveSuggestionsInner: FC<{\n children: (value: { suggestion: SuggestionState }) => ReactNode;\n}> = ({ children }) => {\n const suggestionsLength = useAuiState(\n (s) => s.suggestions.suggestions.length,\n );\n\n return useMemo(() => {\n if (suggestionsLength === 0) return null;\n return Array.from({ length: suggestionsLength }, (_, index) => (\n <SuggestionByIndexProvider key={index} index={index}>\n <RenderChildrenWithAccessor\n getItemState={(aui) =>\n aui.suggestions().suggestion({ index }).getState()\n }\n >\n {(getItem) =>\n children({\n get suggestion() {\n return getItem();\n },\n })\n }\n </RenderChildrenWithAccessor>\n </SuggestionByIndexProvider>\n ));\n }, [suggestionsLength, children]);\n};\n\n/**\n * Renders all suggestions.\n */\nexport const ThreadPrimitiveSuggestionsImpl: FC<\n ThreadPrimitiveSuggestions.Props\n> = ({ components, children }) => {\n if (components) {\n return (\n <ThreadPrimitiveSuggestionsInner>\n {() => <SuggestionComponent components={components} />}\n </ThreadPrimitiveSuggestionsInner>\n );\n }\n return (\n <ThreadPrimitiveSuggestionsInner>\n {children}\n </ThreadPrimitiveSuggestionsInner>\n );\n};\n\nThreadPrimitiveSuggestionsImpl.displayName = \"ThreadPrimitive.Suggestions\";\n\nexport const ThreadPrimitiveSuggestions = memo(\n ThreadPrimitiveSuggestionsImpl,\n (prev, next) => {\n if (prev.children || next.children) {\n return prev.children === next.children;\n }\n return prev.components!.Suggestion === next.components!.Suggestion;\n },\n);\n"],"mappings":";;;;;AAkCA,MAAM,uBAAqD,EAAE,iBAAiB;CAC5E,MAAM,YAAY,WAAW;CAC7B,OAAO,oBAAC,WAAD,CAAY,CAAA;AACrB;;;;AAYA,MAAa,mCACX,MACG,EAAE,OAAO,iBAAiB;CACzB,OACE,oBAAC,2BAAD;EAAkC;YAChC,oBAAC,qBAAD,EAAiC,WAAa,CAAA;CACrB,CAAA;AAE/B,IACC,MAAM,SACL,KAAK,UAAU,KAAK,SACpB,KAAK,WAAW,eAAe,KAAK,WAAW,UACnD;AAEF,iCAAiC,cAC/B;AAEF,MAAM,mCAEA,EAAE,eAAe;CACrB,MAAM,oBAAoB,aACvB,MAAM,EAAE,YAAY,YAAY,MACnC;CAEA,OAAO,cAAc;EACnB,IAAI,sBAAsB,GAAG,OAAO;EACpC,OAAO,MAAM,KAAK,EAAE,QAAQ,kBAAkB,IAAI,GAAG,UACnD,oBAAC,2BAAD;GAA8C;aAC5C,oBAAC,4BAAD;IACE,eAAe,QACb,IAAI,YAAY,CAAC,CAAC,WAAW,EAAE,MAAM,CAAC,CAAC,CAAC,SAAS;eAGjD,YACA,SAAS,EACP,IAAI,aAAa;KACf,OAAO,QAAQ;IACjB,EACF,CAAC;GAEuB,CAAA;EACH,GAdK,KAcL,CAC5B;CACH,GAAG,CAAC,mBAAmB,QAAQ,CAAC;AAClC;;;;AAKA,MAAa,kCAER,EAAE,YAAY,eAAe;CAChC,IAAI,YACF,OACE,oBAAC,iCAAD,EAAA,gBACS,oBAAC,qBAAD,EAAiC,WAAa,CAAA,EACtB,CAAA;CAGrC,OACE,oBAAC,iCAAD,EACG,SAC8B,CAAA;AAErC;AAEA,+BAA+B,cAAc;AAE7C,MAAa,6BAA6B,KACxC,iCACC,MAAM,SAAS;CACd,IAAI,KAAK,YAAY,KAAK,UACxB,OAAO,KAAK,aAAa,KAAK;CAEhC,OAAO,KAAK,WAAY,eAAe,KAAK,WAAY;AAC1D,CACF"}
@@ -1,5 +1,5 @@
1
1
  import { ThreadListItemByIndexProvider } from "../../providers/ThreadListItemByIndexProvider.js";
2
- import { memo, useMemo } from "react";
2
+ import { memo, useMemo } from "@assistant-ui/tap/react-shim";
3
3
  import { RenderChildrenWithAccessor, useAuiState } from "@assistant-ui/store";
4
4
  import { jsx } from "react/jsx-runtime";
5
5
  //#region src/react/primitives/threadList/ThreadListItems.tsx
@@ -1 +1 @@
1
- {"version":3,"file":"ThreadListItems.js","names":[],"sources":["../../../../src/react/primitives/threadList/ThreadListItems.tsx"],"sourcesContent":["import {\n type ComponentType,\n type FC,\n type ReactNode,\n memo,\n useMemo,\n} from \"react\";\nimport { RenderChildrenWithAccessor, useAuiState } from \"@assistant-ui/store\";\nimport type { ThreadListItemState } from \"../../../store/scopes/thread-list-item\";\nimport { ThreadListItemByIndexProvider } from \"../../providers/ThreadListItemByIndexProvider\";\n\ntype ThreadListItemsComponentConfig = {\n ThreadListItem: ComponentType;\n};\n\nexport namespace ThreadListPrimitiveItems {\n export type Props = {\n archived?: boolean | undefined;\n } & (\n | {\n /** @deprecated Use the children render function instead. */\n components: ThreadListItemsComponentConfig;\n children?: never;\n }\n | {\n /** Render function called for each thread list item. Receives the item. */\n children: (value: { threadListItem: ThreadListItemState }) => ReactNode;\n components?: never;\n }\n );\n}\n\nexport namespace ThreadListPrimitiveItemByIndex {\n export type Props = {\n index: number;\n archived?: boolean | undefined;\n components: ThreadListItemsComponentConfig;\n };\n}\n\n/**\n * Renders a single thread list item at the specified index.\n */\nexport const ThreadListPrimitiveItemByIndex: FC<ThreadListPrimitiveItemByIndex.Props> =\n memo(\n ({ index, archived = false, components }) => {\n const ThreadListItemComponent = components.ThreadListItem;\n\n return (\n <ThreadListItemByIndexProvider index={index} archived={archived}>\n <ThreadListItemComponent />\n </ThreadListItemByIndexProvider>\n );\n },\n (prev, next) =>\n prev.index === next.index &&\n prev.archived === next.archived &&\n prev.components.ThreadListItem === next.components.ThreadListItem,\n );\n\nThreadListPrimitiveItemByIndex.displayName = \"ThreadListPrimitive.ItemByIndex\";\n\nconst ThreadListPrimitiveItemsInner: FC<{\n archived: boolean;\n children: (value: { threadListItem: ThreadListItemState }) => ReactNode;\n}> = ({ archived, children }) => {\n const contentLength = useAuiState((s) =>\n archived ? s.threads.archivedThreadIds.length : s.threads.threadIds.length,\n );\n\n return useMemo(\n () =>\n Array.from({ length: contentLength }, (_, index) => (\n <ThreadListItemByIndexProvider\n key={index}\n index={index}\n archived={archived}\n >\n <RenderChildrenWithAccessor\n getItemState={(aui) =>\n aui.threads().item({ index, archived }).getState()\n }\n >\n {(getItem) =>\n children({\n get threadListItem() {\n return getItem();\n },\n })\n }\n </RenderChildrenWithAccessor>\n </ThreadListItemByIndexProvider>\n )),\n [contentLength, archived, children],\n );\n};\n\nexport const ThreadListPrimitiveItems: FC<ThreadListPrimitiveItems.Props> = ({\n archived = false,\n components,\n children,\n}) => {\n if (components) {\n const ThreadListItemComponent = components.ThreadListItem;\n return (\n <ThreadListPrimitiveItemsInner archived={archived}>\n {() => <ThreadListItemComponent />}\n </ThreadListPrimitiveItemsInner>\n );\n }\n return (\n <ThreadListPrimitiveItemsInner archived={archived}>\n {children}\n </ThreadListPrimitiveItemsInner>\n );\n};\n\nThreadListPrimitiveItems.displayName = \"ThreadListPrimitive.Items\";\n"],"mappings":";;;;;;;;AA2CA,MAAa,iCACX,MACG,EAAE,OAAO,WAAW,OAAO,iBAAiB;CAC3C,MAAM,0BAA0B,WAAW;CAE3C,OACE,oBAAC,+BAAD;EAAsC;EAAiB;YACrD,oBAAC,yBAAD,CAA0B,CAAA;CACG,CAAA;AAEnC,IACC,MAAM,SACL,KAAK,UAAU,KAAK,SACpB,KAAK,aAAa,KAAK,YACvB,KAAK,WAAW,mBAAmB,KAAK,WAAW,cACvD;AAEF,+BAA+B,cAAc;AAE7C,MAAM,iCAGA,EAAE,UAAU,eAAe;CAC/B,MAAM,gBAAgB,aAAa,MACjC,WAAW,EAAE,QAAQ,kBAAkB,SAAS,EAAE,QAAQ,UAAU,MACtE;CAEA,OAAO,cAEH,MAAM,KAAK,EAAE,QAAQ,cAAc,IAAI,GAAG,UACxC,oBAAC,+BAAD;EAES;EACG;YAEV,oBAAC,4BAAD;GACE,eAAe,QACb,IAAI,QAAQ,EAAE,KAAK;IAAE;IAAO;GAAS,CAAC,EAAE,SAAS;cAGjD,YACA,SAAS,EACP,IAAI,iBAAiB;IACnB,OAAO,QAAQ;GACjB,EACF,CAAC;EAEuB,CAAA;CACC,GAjBxB,KAiBwB,CAChC,GACH;EAAC;EAAe;EAAU;CAAQ,CACpC;AACF;AAEA,MAAa,4BAAgE,EAC3E,WAAW,OACX,YACA,eACI;CACJ,IAAI,YAAY;EACd,MAAM,0BAA0B,WAAW;EAC3C,OACE,oBAAC,+BAAD;GAAyC;mBAChC,oBAAC,yBAAD,CAA0B,CAAA;EACJ,CAAA;CAEnC;CACA,OACE,oBAAC,+BAAD;EAAyC;EACtC;CAC4B,CAAA;AAEnC;AAEA,yBAAyB,cAAc"}
1
+ {"version":3,"file":"ThreadListItems.js","names":[],"sources":["../../../../src/react/primitives/threadList/ThreadListItems.tsx"],"sourcesContent":["import {\n type ComponentType,\n type FC,\n type ReactNode,\n memo,\n useMemo,\n} from \"react\";\nimport { RenderChildrenWithAccessor, useAuiState } from \"@assistant-ui/store\";\nimport type { ThreadListItemState } from \"../../../store/scopes/thread-list-item\";\nimport { ThreadListItemByIndexProvider } from \"../../providers/ThreadListItemByIndexProvider\";\n\ntype ThreadListItemsComponentConfig = {\n ThreadListItem: ComponentType;\n};\n\nexport namespace ThreadListPrimitiveItems {\n export type Props = {\n archived?: boolean | undefined;\n } & (\n | {\n /** @deprecated Use the children render function instead. */\n components: ThreadListItemsComponentConfig;\n children?: never;\n }\n | {\n /** Render function called for each thread list item. Receives the item. */\n children: (value: { threadListItem: ThreadListItemState }) => ReactNode;\n components?: never;\n }\n );\n}\n\nexport namespace ThreadListPrimitiveItemByIndex {\n export type Props = {\n index: number;\n archived?: boolean | undefined;\n components: ThreadListItemsComponentConfig;\n };\n}\n\n/**\n * Renders a single thread list item at the specified index.\n */\nexport const ThreadListPrimitiveItemByIndex: FC<ThreadListPrimitiveItemByIndex.Props> =\n memo(\n ({ index, archived = false, components }) => {\n const ThreadListItemComponent = components.ThreadListItem;\n\n return (\n <ThreadListItemByIndexProvider index={index} archived={archived}>\n <ThreadListItemComponent />\n </ThreadListItemByIndexProvider>\n );\n },\n (prev, next) =>\n prev.index === next.index &&\n prev.archived === next.archived &&\n prev.components.ThreadListItem === next.components.ThreadListItem,\n );\n\nThreadListPrimitiveItemByIndex.displayName = \"ThreadListPrimitive.ItemByIndex\";\n\nconst ThreadListPrimitiveItemsInner: FC<{\n archived: boolean;\n children: (value: { threadListItem: ThreadListItemState }) => ReactNode;\n}> = ({ archived, children }) => {\n const contentLength = useAuiState((s) =>\n archived ? s.threads.archivedThreadIds.length : s.threads.threadIds.length,\n );\n\n return useMemo(\n () =>\n Array.from({ length: contentLength }, (_, index) => (\n <ThreadListItemByIndexProvider\n key={index}\n index={index}\n archived={archived}\n >\n <RenderChildrenWithAccessor\n getItemState={(aui) =>\n aui.threads().item({ index, archived }).getState()\n }\n >\n {(getItem) =>\n children({\n get threadListItem() {\n return getItem();\n },\n })\n }\n </RenderChildrenWithAccessor>\n </ThreadListItemByIndexProvider>\n )),\n [contentLength, archived, children],\n );\n};\n\nexport const ThreadListPrimitiveItems: FC<ThreadListPrimitiveItems.Props> = ({\n archived = false,\n components,\n children,\n}) => {\n if (components) {\n const ThreadListItemComponent = components.ThreadListItem;\n return (\n <ThreadListPrimitiveItemsInner archived={archived}>\n {() => <ThreadListItemComponent />}\n </ThreadListPrimitiveItemsInner>\n );\n }\n return (\n <ThreadListPrimitiveItemsInner archived={archived}>\n {children}\n </ThreadListPrimitiveItemsInner>\n );\n};\n\nThreadListPrimitiveItems.displayName = \"ThreadListPrimitive.Items\";\n"],"mappings":";;;;;;;;AA2CA,MAAa,iCACX,MACG,EAAE,OAAO,WAAW,OAAO,iBAAiB;CAC3C,MAAM,0BAA0B,WAAW;CAE3C,OACE,oBAAC,+BAAD;EAAsC;EAAiB;YACrD,oBAAC,yBAAD,CAA0B,CAAA;CACG,CAAA;AAEnC,IACC,MAAM,SACL,KAAK,UAAU,KAAK,SACpB,KAAK,aAAa,KAAK,YACvB,KAAK,WAAW,mBAAmB,KAAK,WAAW,cACvD;AAEF,+BAA+B,cAAc;AAE7C,MAAM,iCAGA,EAAE,UAAU,eAAe;CAC/B,MAAM,gBAAgB,aAAa,MACjC,WAAW,EAAE,QAAQ,kBAAkB,SAAS,EAAE,QAAQ,UAAU,MACtE;CAEA,OAAO,cAEH,MAAM,KAAK,EAAE,QAAQ,cAAc,IAAI,GAAG,UACxC,oBAAC,+BAAD;EAES;EACG;YAEV,oBAAC,4BAAD;GACE,eAAe,QACb,IAAI,QAAQ,CAAC,CAAC,KAAK;IAAE;IAAO;GAAS,CAAC,CAAC,CAAC,SAAS;cAGjD,YACA,SAAS,EACP,IAAI,iBAAiB;IACnB,OAAO,QAAQ;GACjB,EACF,CAAC;EAEuB,CAAA;CACC,GAjBxB,KAiBwB,CAChC,GACH;EAAC;EAAe;EAAU;CAAQ,CACpC;AACF;AAEA,MAAa,4BAAgE,EAC3E,WAAW,OACX,YACA,eACI;CACJ,IAAI,YAAY;EACd,MAAM,0BAA0B,WAAW;EAC3C,OACE,oBAAC,+BAAD;GAAyC;mBAChC,oBAAC,yBAAD,CAA0B,CAAA;EACJ,CAAA;CAEnC;CACA,OACE,oBAAC,+BAAD;EAAyC;EACtC;CAC4B,CAAA;AAEnC;AAEA,yBAAyB,cAAc"}
@@ -1 +1 @@
1
- {"version":3,"file":"AttachmentByIndexProvider.js","names":[],"sources":["../../../src/react/providers/AttachmentByIndexProvider.tsx"],"sourcesContent":["import type { FC, PropsWithChildren } from \"react\";\nimport { useAui, AuiProvider, Derived } from \"@assistant-ui/store\";\n\nexport const MessageAttachmentByIndexProvider: FC<\n PropsWithChildren<{\n index: number;\n }>\n> = ({ index, children }) => {\n const aui = useAui({\n attachment: Derived({\n source: \"message\",\n query: { type: \"index\", index },\n get: (aui) => aui.message().attachment({ index }),\n }),\n });\n\n return <AuiProvider value={aui}>{children}</AuiProvider>;\n};\n\nexport const ComposerAttachmentByIndexProvider: FC<\n PropsWithChildren<{\n index: number;\n }>\n> = ({ index, children }) => {\n const aui = useAui({\n attachment: Derived({\n source: \"composer\",\n query: { type: \"index\", index },\n get: (aui) => aui.composer().attachment({ index }),\n }),\n });\n\n return <AuiProvider value={aui}>{children}</AuiProvider>;\n};\n"],"mappings":";;;AAGA,MAAa,oCAIR,EAAE,OAAO,eAAe;CAS3B,OAAO,oBAAC,aAAD;EAAa,OARR,OAAO,EACjB,YAAY,QAAQ;GAClB,QAAQ;GACR,OAAO;IAAE,MAAM;IAAS;GAAM;GAC9B,MAAM,QAAQ,IAAI,QAAQ,EAAE,WAAW,EAAE,MAAM,CAAC;EAClD,CAAC,EACH,CAE6B;EAAI;CAAsB,CAAA;AACzD;AAEA,MAAa,qCAIR,EAAE,OAAO,eAAe;CAS3B,OAAO,oBAAC,aAAD;EAAa,OARR,OAAO,EACjB,YAAY,QAAQ;GAClB,QAAQ;GACR,OAAO;IAAE,MAAM;IAAS;GAAM;GAC9B,MAAM,QAAQ,IAAI,SAAS,EAAE,WAAW,EAAE,MAAM,CAAC;EACnD,CAAC,EACH,CAE6B;EAAI;CAAsB,CAAA;AACzD"}
1
+ {"version":3,"file":"AttachmentByIndexProvider.js","names":[],"sources":["../../../src/react/providers/AttachmentByIndexProvider.tsx"],"sourcesContent":["import type { FC, PropsWithChildren } from \"react\";\nimport { useAui, AuiProvider, Derived } from \"@assistant-ui/store\";\n\nexport const MessageAttachmentByIndexProvider: FC<\n PropsWithChildren<{\n index: number;\n }>\n> = ({ index, children }) => {\n const aui = useAui({\n attachment: Derived({\n source: \"message\",\n query: { type: \"index\", index },\n get: (aui) => aui.message().attachment({ index }),\n }),\n });\n\n return <AuiProvider value={aui}>{children}</AuiProvider>;\n};\n\nexport const ComposerAttachmentByIndexProvider: FC<\n PropsWithChildren<{\n index: number;\n }>\n> = ({ index, children }) => {\n const aui = useAui({\n attachment: Derived({\n source: \"composer\",\n query: { type: \"index\", index },\n get: (aui) => aui.composer().attachment({ index }),\n }),\n });\n\n return <AuiProvider value={aui}>{children}</AuiProvider>;\n};\n"],"mappings":";;;AAGA,MAAa,oCAIR,EAAE,OAAO,eAAe;CAS3B,OAAO,oBAAC,aAAD;EAAa,OARR,OAAO,EACjB,YAAY,QAAQ;GAClB,QAAQ;GACR,OAAO;IAAE,MAAM;IAAS;GAAM;GAC9B,MAAM,QAAQ,IAAI,QAAQ,CAAC,CAAC,WAAW,EAAE,MAAM,CAAC;EAClD,CAAC,EACH,CAE6B;EAAI;CAAsB,CAAA;AACzD;AAEA,MAAa,qCAIR,EAAE,OAAO,eAAe;CAS3B,OAAO,oBAAC,aAAD;EAAa,OARR,OAAO,EACjB,YAAY,QAAQ;GAClB,QAAQ;GACR,OAAO;IAAE,MAAM;IAAS;GAAM;GAC9B,MAAM,QAAQ,IAAI,SAAS,CAAC,CAAC,WAAW,EAAE,MAAM,CAAC;EACnD,CAAC,EACH,CAE6B;EAAI;CAAsB,CAAA;AACzD"}
@@ -1 +1 @@
1
- {"version":3,"file":"ChainOfThoughtByIndicesProvider.js","names":[],"sources":["../../../src/react/providers/ChainOfThoughtByIndicesProvider.tsx"],"sourcesContent":["import type { FC, PropsWithChildren } from \"react\";\nimport { useAui, useAuiState, AuiProvider } from \"@assistant-ui/store\";\nimport { ChainOfThoughtClient } from \"../../store/clients/chain-of-thought-client\";\nimport type { ChainOfThoughtPart } from \"../../store/scopes/chain-of-thought\";\n\nexport const ChainOfThoughtByIndicesProvider: FC<\n PropsWithChildren<{\n startIndex: number;\n endIndex: number;\n }>\n> = ({ startIndex, endIndex, children }) => {\n const parts = useAuiState((s) => s.message.parts).slice(\n startIndex,\n endIndex + 1,\n ) as ChainOfThoughtPart[];\n\n const parentAui = useAui();\n\n const aui = useAui({\n chainOfThought: ChainOfThoughtClient({\n parts,\n getMessagePart: ({ index }) => {\n if (index < 0 || index >= parts.length) {\n throw new Error(\n `ChainOfThought part index ${index} is out of bounds (0..${parts.length - 1})`,\n );\n }\n return parentAui.message().part({ index: startIndex + index });\n },\n }),\n });\n\n return <AuiProvider value={aui}>{children}</AuiProvider>;\n};\n"],"mappings":";;;;AAKA,MAAa,mCAKR,EAAE,YAAY,UAAU,eAAe;CAC1C,MAAM,QAAQ,aAAa,MAAM,EAAE,QAAQ,KAAK,EAAE,MAChD,YACA,WAAW,CACb;CAEA,MAAM,YAAY,OAAO;CAgBzB,OAAO,oBAAC,aAAD;EAAa,OAdR,OAAO,EACjB,gBAAgB,qBAAqB;GACnC;GACA,iBAAiB,EAAE,YAAY;IAC7B,IAAI,QAAQ,KAAK,SAAS,MAAM,QAC9B,MAAM,IAAI,MACR,6BAA6B,MAAM,wBAAwB,MAAM,SAAS,EAAE,EAC9E;IAEF,OAAO,UAAU,QAAQ,EAAE,KAAK,EAAE,OAAO,aAAa,MAAM,CAAC;GAC/D;EACF,CAAC,EACH,CAE6B;EAAI;CAAsB,CAAA;AACzD"}
1
+ {"version":3,"file":"ChainOfThoughtByIndicesProvider.js","names":[],"sources":["../../../src/react/providers/ChainOfThoughtByIndicesProvider.tsx"],"sourcesContent":["import type { FC, PropsWithChildren } from \"react\";\nimport { useAui, useAuiState, AuiProvider } from \"@assistant-ui/store\";\nimport { ChainOfThoughtClient } from \"../../store/clients/chain-of-thought-client\";\nimport type { ChainOfThoughtPart } from \"../../store/scopes/chain-of-thought\";\n\nexport const ChainOfThoughtByIndicesProvider: FC<\n PropsWithChildren<{\n startIndex: number;\n endIndex: number;\n }>\n> = ({ startIndex, endIndex, children }) => {\n const parts = useAuiState((s) => s.message.parts).slice(\n startIndex,\n endIndex + 1,\n ) as ChainOfThoughtPart[];\n\n const parentAui = useAui();\n\n const aui = useAui({\n chainOfThought: ChainOfThoughtClient({\n parts,\n getMessagePart: ({ index }) => {\n if (index < 0 || index >= parts.length) {\n throw new Error(\n `ChainOfThought part index ${index} is out of bounds (0..${parts.length - 1})`,\n );\n }\n return parentAui.message().part({ index: startIndex + index });\n },\n }),\n });\n\n return <AuiProvider value={aui}>{children}</AuiProvider>;\n};\n"],"mappings":";;;;AAKA,MAAa,mCAKR,EAAE,YAAY,UAAU,eAAe;CAC1C,MAAM,QAAQ,aAAa,MAAM,EAAE,QAAQ,KAAK,CAAC,CAAC,MAChD,YACA,WAAW,CACb;CAEA,MAAM,YAAY,OAAO;CAgBzB,OAAO,oBAAC,aAAD;EAAa,OAdR,OAAO,EACjB,gBAAgB,qBAAqB;GACnC;GACA,iBAAiB,EAAE,YAAY;IAC7B,IAAI,QAAQ,KAAK,SAAS,MAAM,QAC9B,MAAM,IAAI,MACR,6BAA6B,MAAM,wBAAwB,MAAM,SAAS,EAAE,EAC9E;IAEF,OAAO,UAAU,QAAQ,CAAC,CAAC,KAAK,EAAE,OAAO,aAAa,MAAM,CAAC;GAC/D;EACF,CAAC,EACH,CAE6B;EAAI;CAAsB,CAAA;AACzD"}
@@ -1 +1 @@
1
- {"version":3,"file":"ChainOfThoughtPartByIndexProvider.js","names":[],"sources":["../../../src/react/providers/ChainOfThoughtPartByIndexProvider.tsx"],"sourcesContent":["import type { FC, PropsWithChildren } from \"react\";\nimport { useAui, AuiProvider, Derived } from \"@assistant-ui/store\";\n\nexport const ChainOfThoughtPartByIndexProvider: FC<\n PropsWithChildren<{\n index: number;\n }>\n> = ({ index, children }) => {\n const aui = useAui({\n part: Derived({\n source: \"chainOfThought\",\n query: { type: \"index\", index },\n get: (aui) => aui.chainOfThought().part({ index }),\n }),\n });\n\n return <AuiProvider value={aui}>{children}</AuiProvider>;\n};\n"],"mappings":";;;AAGA,MAAa,qCAIR,EAAE,OAAO,eAAe;CAS3B,OAAO,oBAAC,aAAD;EAAa,OARR,OAAO,EACjB,MAAM,QAAQ;GACZ,QAAQ;GACR,OAAO;IAAE,MAAM;IAAS;GAAM;GAC9B,MAAM,QAAQ,IAAI,eAAe,EAAE,KAAK,EAAE,MAAM,CAAC;EACnD,CAAC,EACH,CAE6B;EAAI;CAAsB,CAAA;AACzD"}
1
+ {"version":3,"file":"ChainOfThoughtPartByIndexProvider.js","names":[],"sources":["../../../src/react/providers/ChainOfThoughtPartByIndexProvider.tsx"],"sourcesContent":["import type { FC, PropsWithChildren } from \"react\";\nimport { useAui, AuiProvider, Derived } from \"@assistant-ui/store\";\n\nexport const ChainOfThoughtPartByIndexProvider: FC<\n PropsWithChildren<{\n index: number;\n }>\n> = ({ index, children }) => {\n const aui = useAui({\n part: Derived({\n source: \"chainOfThought\",\n query: { type: \"index\", index },\n get: (aui) => aui.chainOfThought().part({ index }),\n }),\n });\n\n return <AuiProvider value={aui}>{children}</AuiProvider>;\n};\n"],"mappings":";;;AAGA,MAAa,qCAIR,EAAE,OAAO,eAAe;CAS3B,OAAO,oBAAC,aAAD;EAAa,OARR,OAAO,EACjB,MAAM,QAAQ;GACZ,QAAQ;GACR,OAAO;IAAE,MAAM;IAAS;GAAM;GAC9B,MAAM,QAAQ,IAAI,eAAe,CAAC,CAAC,KAAK,EAAE,MAAM,CAAC;EACnD,CAAC,EACH,CAE6B;EAAI;CAAsB,CAAA;AACzD"}
@@ -1 +1 @@
1
- {"version":3,"file":"MessageByIndexProvider.js","names":[],"sources":["../../../src/react/providers/MessageByIndexProvider.tsx"],"sourcesContent":["import type { FC, PropsWithChildren } from \"react\";\nimport { useAui, AuiProvider, Derived } from \"@assistant-ui/store\";\n\nexport const MessageByIndexProvider: FC<\n PropsWithChildren<{\n index: number;\n }>\n> = ({ index, children }) => {\n const aui = useAui({\n message: Derived({\n source: \"thread\",\n query: { type: \"index\", index },\n get: (aui) => aui.thread().message({ index }),\n }),\n composer: Derived({\n source: \"message\",\n query: {},\n get: (aui) => aui.thread().message({ index }).composer(),\n }),\n });\n\n return <AuiProvider value={aui}>{children}</AuiProvider>;\n};\n"],"mappings":";;;AAGA,MAAa,0BAIR,EAAE,OAAO,eAAe;CAc3B,OAAO,oBAAC,aAAD;EAAa,OAbR,OAAO;GACjB,SAAS,QAAQ;IACf,QAAQ;IACR,OAAO;KAAE,MAAM;KAAS;IAAM;IAC9B,MAAM,QAAQ,IAAI,OAAO,EAAE,QAAQ,EAAE,MAAM,CAAC;GAC9C,CAAC;GACD,UAAU,QAAQ;IAChB,QAAQ;IACR,OAAO,CAAC;IACR,MAAM,QAAQ,IAAI,OAAO,EAAE,QAAQ,EAAE,MAAM,CAAC,EAAE,SAAS;GACzD,CAAC;EACH,CAE6B;EAAI;CAAsB,CAAA;AACzD"}
1
+ {"version":3,"file":"MessageByIndexProvider.js","names":[],"sources":["../../../src/react/providers/MessageByIndexProvider.tsx"],"sourcesContent":["import type { FC, PropsWithChildren } from \"react\";\nimport { useAui, AuiProvider, Derived } from \"@assistant-ui/store\";\n\nexport const MessageByIndexProvider: FC<\n PropsWithChildren<{\n index: number;\n }>\n> = ({ index, children }) => {\n const aui = useAui({\n message: Derived({\n source: \"thread\",\n query: { type: \"index\", index },\n get: (aui) => aui.thread().message({ index }),\n }),\n composer: Derived({\n source: \"message\",\n query: {},\n get: (aui) => aui.thread().message({ index }).composer(),\n }),\n });\n\n return <AuiProvider value={aui}>{children}</AuiProvider>;\n};\n"],"mappings":";;;AAGA,MAAa,0BAIR,EAAE,OAAO,eAAe;CAc3B,OAAO,oBAAC,aAAD;EAAa,OAbR,OAAO;GACjB,SAAS,QAAQ;IACf,QAAQ;IACR,OAAO;KAAE,MAAM;KAAS;IAAM;IAC9B,MAAM,QAAQ,IAAI,OAAO,CAAC,CAAC,QAAQ,EAAE,MAAM,CAAC;GAC9C,CAAC;GACD,UAAU,QAAQ;IAChB,QAAQ;IACR,OAAO,CAAC;IACR,MAAM,QAAQ,IAAI,OAAO,CAAC,CAAC,QAAQ,EAAE,MAAM,CAAC,CAAC,CAAC,SAAS;GACzD,CAAC;EACH,CAE6B;EAAI;CAAsB,CAAA;AACzD"}
@@ -1 +1 @@
1
- {"version":3,"file":"PartByIndexProvider.js","names":[],"sources":["../../../src/react/providers/PartByIndexProvider.tsx"],"sourcesContent":["import type { FC, PropsWithChildren } from \"react\";\nimport { useAui, AuiProvider, Derived } from \"@assistant-ui/store\";\n\nexport const PartByIndexProvider: FC<\n PropsWithChildren<{\n index: number;\n }>\n> = ({ index, children }) => {\n const aui = useAui({\n part: Derived({\n source: \"message\",\n query: { type: \"index\", index },\n get: (aui) => aui.message().part({ index }),\n }),\n });\n\n return <AuiProvider value={aui}>{children}</AuiProvider>;\n};\n"],"mappings":";;;AAGA,MAAa,uBAIR,EAAE,OAAO,eAAe;CAS3B,OAAO,oBAAC,aAAD;EAAa,OARR,OAAO,EACjB,MAAM,QAAQ;GACZ,QAAQ;GACR,OAAO;IAAE,MAAM;IAAS;GAAM;GAC9B,MAAM,QAAQ,IAAI,QAAQ,EAAE,KAAK,EAAE,MAAM,CAAC;EAC5C,CAAC,EACH,CAE6B;EAAI;CAAsB,CAAA;AACzD"}
1
+ {"version":3,"file":"PartByIndexProvider.js","names":[],"sources":["../../../src/react/providers/PartByIndexProvider.tsx"],"sourcesContent":["import type { FC, PropsWithChildren } from \"react\";\nimport { useAui, AuiProvider, Derived } from \"@assistant-ui/store\";\n\nexport const PartByIndexProvider: FC<\n PropsWithChildren<{\n index: number;\n }>\n> = ({ index, children }) => {\n const aui = useAui({\n part: Derived({\n source: \"message\",\n query: { type: \"index\", index },\n get: (aui) => aui.message().part({ index }),\n }),\n });\n\n return <AuiProvider value={aui}>{children}</AuiProvider>;\n};\n"],"mappings":";;;AAGA,MAAa,uBAIR,EAAE,OAAO,eAAe;CAS3B,OAAO,oBAAC,aAAD;EAAa,OARR,OAAO,EACjB,MAAM,QAAQ;GACZ,QAAQ;GACR,OAAO;IAAE,MAAM;IAAS;GAAM;GAC9B,MAAM,QAAQ,IAAI,QAAQ,CAAC,CAAC,KAAK,EAAE,MAAM,CAAC;EAC5C,CAAC,EACH,CAE6B;EAAI;CAAsB,CAAA;AACzD"}
@@ -1 +1 @@
1
- {"version":3,"file":"QueueItemByIndexProvider.js","names":[],"sources":["../../../src/react/providers/QueueItemByIndexProvider.tsx"],"sourcesContent":["import type { FC, PropsWithChildren } from \"react\";\nimport { AuiProvider, Derived, useAui } from \"@assistant-ui/store\";\n\nexport type QueueItemByIndexProviderProps = PropsWithChildren<{\n index: number;\n}>;\n\nexport const QueueItemByIndexProvider: FC<QueueItemByIndexProviderProps> = ({\n index,\n children,\n}) => {\n const aui = useAui({\n queueItem: Derived({\n source: \"composer\",\n query: { index },\n get: (aui) => aui.composer().queueItem({ index }),\n }),\n });\n\n return <AuiProvider value={aui}>{children}</AuiProvider>;\n};\n"],"mappings":";;;AAOA,MAAa,4BAA+D,EAC1E,OACA,eACI;CASJ,OAAO,oBAAC,aAAD;EAAa,OARR,OAAO,EACjB,WAAW,QAAQ;GACjB,QAAQ;GACR,OAAO,EAAE,MAAM;GACf,MAAM,QAAQ,IAAI,SAAS,EAAE,UAAU,EAAE,MAAM,CAAC;EAClD,CAAC,EACH,CAE6B;EAAI;CAAsB,CAAA;AACzD"}
1
+ {"version":3,"file":"QueueItemByIndexProvider.js","names":[],"sources":["../../../src/react/providers/QueueItemByIndexProvider.tsx"],"sourcesContent":["import type { FC, PropsWithChildren } from \"react\";\nimport { AuiProvider, Derived, useAui } from \"@assistant-ui/store\";\n\nexport type QueueItemByIndexProviderProps = PropsWithChildren<{\n index: number;\n}>;\n\nexport const QueueItemByIndexProvider: FC<QueueItemByIndexProviderProps> = ({\n index,\n children,\n}) => {\n const aui = useAui({\n queueItem: Derived({\n source: \"composer\",\n query: { index },\n get: (aui) => aui.composer().queueItem({ index }),\n }),\n });\n\n return <AuiProvider value={aui}>{children}</AuiProvider>;\n};\n"],"mappings":";;;AAOA,MAAa,4BAA+D,EAC1E,OACA,eACI;CASJ,OAAO,oBAAC,aAAD;EAAa,OARR,OAAO,EACjB,WAAW,QAAQ;GACjB,QAAQ;GACR,OAAO,EAAE,MAAM;GACf,MAAM,QAAQ,IAAI,SAAS,CAAC,CAAC,UAAU,EAAE,MAAM,CAAC;EAClD,CAAC,EACH,CAE6B;EAAI;CAAsB,CAAA;AACzD"}
@@ -1,7 +1,7 @@
1
1
  import { ThreadRuntimeImpl } from "../../runtime/api/thread-runtime.js";
2
2
  import { ReadonlyThreadRuntimeCore } from "../../runtimes/readonly/ReadonlyThreadRuntimeCore.js";
3
3
  import { ThreadClient } from "../../store/runtime-clients/thread-runtime-client.js";
4
- import { useEffect, useMemo, useState } from "react";
4
+ import { useEffect, useMemo, useState } from "@assistant-ui/tap/react-shim";
5
5
  import { AuiProvider, Derived, useAui } from "@assistant-ui/store";
6
6
  import { jsx } from "react/jsx-runtime";
7
7
  //#region src/react/providers/ReadonlyThreadProvider.tsx
@@ -1 +1 @@
1
- {"version":3,"file":"ReadonlyThreadProvider.js","names":[],"sources":["../../../src/react/providers/ReadonlyThreadProvider.tsx"],"sourcesContent":["import {\n type FC,\n type PropsWithChildren,\n useEffect,\n useMemo,\n useState,\n} from \"react\";\nimport { useAui, AuiProvider, Derived } from \"@assistant-ui/store\";\nimport type { ThreadMessage } from \"../../types/message\";\nimport { ReadonlyThreadRuntimeCore } from \"../../runtimes/readonly/ReadonlyThreadRuntimeCore\";\nimport {\n ThreadRuntimeImpl,\n type ThreadRuntimeCoreBinding,\n type ThreadListItemRuntimeBinding,\n} from \"../../runtime/internal\";\nimport { ThreadClient } from \"../../store/runtime-clients/thread-runtime-client\";\nimport type { ThreadListItemState } from \"../../runtime/api/bindings\";\n\nconst READONLY_THREAD_PATH = Object.freeze({\n ref: \"readonly-thread\",\n threadSelector: { type: \"main\" as const },\n});\n\nconst READONLY_THREAD_LIST_ITEM: ThreadListItemState = Object.freeze({\n id: \"readonly\",\n remoteId: undefined,\n externalId: undefined,\n isMain: true,\n status: \"regular\" as const,\n title: undefined,\n});\n\nconst READONLY_THREAD_LIST_ITEM_BINDING: ThreadListItemRuntimeBinding =\n Object.freeze({\n path: READONLY_THREAD_PATH,\n getState: () => READONLY_THREAD_LIST_ITEM,\n subscribe: () => () => {},\n });\n\nexport namespace ReadonlyThreadProvider {\n export type Props = PropsWithChildren<{\n messages: readonly ThreadMessage[];\n }>;\n}\n\nexport const ReadonlyThreadProvider: FC<ReadonlyThreadProvider.Props> = ({\n messages,\n children,\n}) => {\n const [core] = useState(() => {\n const c = new ReadonlyThreadRuntimeCore();\n c.setMessages(messages);\n return c;\n });\n\n useEffect(() => {\n core.setMessages(messages);\n }, [core, messages]);\n\n const threadRuntime = useMemo(() => {\n const threadBinding: ThreadRuntimeCoreBinding = {\n path: READONLY_THREAD_PATH,\n getState: () => core,\n subscribe: (callback) => core.subscribe(callback),\n outerSubscribe: (callback) => core.subscribe(callback),\n };\n\n return new ThreadRuntimeImpl(\n threadBinding,\n READONLY_THREAD_LIST_ITEM_BINDING,\n );\n }, [core]);\n\n const aui = useAui({\n thread: ThreadClient({ runtime: threadRuntime }),\n composer: Derived({\n source: \"thread\",\n query: {},\n get: (aui) => aui.thread().composer(),\n }),\n });\n\n return <AuiProvider value={aui}>{children}</AuiProvider>;\n};\n"],"mappings":";;;;;;;AAkBA,MAAM,uBAAuB,OAAO,OAAO;CACzC,KAAK;CACL,gBAAgB,EAAE,MAAM,OAAgB;AAC1C,CAAC;AAED,MAAM,4BAAiD,OAAO,OAAO;CACnE,IAAI;CACJ,UAAU,KAAA;CACV,YAAY,KAAA;CACZ,QAAQ;CACR,QAAQ;CACR,OAAO,KAAA;AACT,CAAC;AAED,MAAM,oCACJ,OAAO,OAAO;CACZ,MAAM;CACN,gBAAgB;CAChB,uBAAuB,CAAC;AAC1B,CAAC;AAQH,MAAa,0BAA4D,EACvE,UACA,eACI;CACJ,MAAM,CAAC,QAAQ,eAAe;EAC5B,MAAM,IAAI,IAAI,0BAA0B;EACxC,EAAE,YAAY,QAAQ;EACtB,OAAO;CACT,CAAC;CAED,gBAAgB;EACd,KAAK,YAAY,QAAQ;CAC3B,GAAG,CAAC,MAAM,QAAQ,CAAC;CAyBnB,OAAO,oBAAC,aAAD;EAAa,OATR,OAAO;GACjB,QAAQ,aAAa,EAAE,SAfH,cAAc;IAQlC,OAAO,IAAI,kBACT;KAPA,MAAM;KACN,gBAAgB;KAChB,YAAY,aAAa,KAAK,UAAU,QAAQ;KAChD,iBAAiB,aAAa,KAAK,UAAU,QAAQ;IAIzC,GACZ,iCACF;GACF,GAAG,CAAC,IAAI,CAGsC,EAAE,CAAC;GAC/C,UAAU,QAAQ;IAChB,QAAQ;IACR,OAAO,CAAC;IACR,MAAM,QAAQ,IAAI,OAAO,EAAE,SAAS;GACtC,CAAC;EACH,CAE6B;EAAI;CAAsB,CAAA;AACzD"}
1
+ {"version":3,"file":"ReadonlyThreadProvider.js","names":[],"sources":["../../../src/react/providers/ReadonlyThreadProvider.tsx"],"sourcesContent":["import {\n type FC,\n type PropsWithChildren,\n useEffect,\n useMemo,\n useState,\n} from \"react\";\nimport { useAui, AuiProvider, Derived } from \"@assistant-ui/store\";\nimport type { ThreadMessage } from \"../../types/message\";\nimport { ReadonlyThreadRuntimeCore } from \"../../runtimes/readonly/ReadonlyThreadRuntimeCore\";\nimport {\n ThreadRuntimeImpl,\n type ThreadRuntimeCoreBinding,\n type ThreadListItemRuntimeBinding,\n} from \"../../runtime/internal\";\nimport { ThreadClient } from \"../../store/runtime-clients/thread-runtime-client\";\nimport type { ThreadListItemState } from \"../../runtime/api/bindings\";\n\nconst READONLY_THREAD_PATH = Object.freeze({\n ref: \"readonly-thread\",\n threadSelector: { type: \"main\" as const },\n});\n\nconst READONLY_THREAD_LIST_ITEM: ThreadListItemState = Object.freeze({\n id: \"readonly\",\n remoteId: undefined,\n externalId: undefined,\n isMain: true,\n status: \"regular\" as const,\n title: undefined,\n});\n\nconst READONLY_THREAD_LIST_ITEM_BINDING: ThreadListItemRuntimeBinding =\n Object.freeze({\n path: READONLY_THREAD_PATH,\n getState: () => READONLY_THREAD_LIST_ITEM,\n subscribe: () => () => {},\n });\n\nexport namespace ReadonlyThreadProvider {\n export type Props = PropsWithChildren<{\n messages: readonly ThreadMessage[];\n }>;\n}\n\nexport const ReadonlyThreadProvider: FC<ReadonlyThreadProvider.Props> = ({\n messages,\n children,\n}) => {\n const [core] = useState(() => {\n const c = new ReadonlyThreadRuntimeCore();\n c.setMessages(messages);\n return c;\n });\n\n useEffect(() => {\n core.setMessages(messages);\n }, [core, messages]);\n\n const threadRuntime = useMemo(() => {\n const threadBinding: ThreadRuntimeCoreBinding = {\n path: READONLY_THREAD_PATH,\n getState: () => core,\n subscribe: (callback) => core.subscribe(callback),\n outerSubscribe: (callback) => core.subscribe(callback),\n };\n\n return new ThreadRuntimeImpl(\n threadBinding,\n READONLY_THREAD_LIST_ITEM_BINDING,\n );\n }, [core]);\n\n const aui = useAui({\n thread: ThreadClient({ runtime: threadRuntime }),\n composer: Derived({\n source: \"thread\",\n query: {},\n get: (aui) => aui.thread().composer(),\n }),\n });\n\n return <AuiProvider value={aui}>{children}</AuiProvider>;\n};\n"],"mappings":";;;;;;;AAkBA,MAAM,uBAAuB,OAAO,OAAO;CACzC,KAAK;CACL,gBAAgB,EAAE,MAAM,OAAgB;AAC1C,CAAC;AAED,MAAM,4BAAiD,OAAO,OAAO;CACnE,IAAI;CACJ,UAAU,KAAA;CACV,YAAY,KAAA;CACZ,QAAQ;CACR,QAAQ;CACR,OAAO,KAAA;AACT,CAAC;AAED,MAAM,oCACJ,OAAO,OAAO;CACZ,MAAM;CACN,gBAAgB;CAChB,uBAAuB,CAAC;AAC1B,CAAC;AAQH,MAAa,0BAA4D,EACvE,UACA,eACI;CACJ,MAAM,CAAC,QAAQ,eAAe;EAC5B,MAAM,IAAI,IAAI,0BAA0B;EACxC,EAAE,YAAY,QAAQ;EACtB,OAAO;CACT,CAAC;CAED,gBAAgB;EACd,KAAK,YAAY,QAAQ;CAC3B,GAAG,CAAC,MAAM,QAAQ,CAAC;CAyBnB,OAAO,oBAAC,aAAD;EAAa,OATR,OAAO;GACjB,QAAQ,aAAa,EAAE,SAfH,cAAc;IAQlC,OAAO,IAAI,kBACT;KAPA,MAAM;KACN,gBAAgB;KAChB,YAAY,aAAa,KAAK,UAAU,QAAQ;KAChD,iBAAiB,aAAa,KAAK,UAAU,QAAQ;IAIzC,GACZ,iCACF;GACF,GAAG,CAAC,IAAI,CAGsC,EAAE,CAAC;GAC/C,UAAU,QAAQ;IAChB,QAAQ;IACR,OAAO,CAAC;IACR,MAAM,QAAQ,IAAI,OAAO,CAAC,CAAC,SAAS;GACtC,CAAC;EACH,CAE6B;EAAI;CAAsB,CAAA;AACzD"}
@@ -1 +1 @@
1
- {"version":3,"file":"SuggestionByIndexProvider.js","names":[],"sources":["../../../src/react/providers/SuggestionByIndexProvider.tsx"],"sourcesContent":["import type { FC, PropsWithChildren } from \"react\";\nimport { AuiProvider, Derived, useAui } from \"@assistant-ui/store\";\n\nexport type SuggestionByIndexProviderProps = PropsWithChildren<{\n index: number;\n}>;\n\nexport const SuggestionByIndexProvider: FC<SuggestionByIndexProviderProps> = ({\n index,\n children,\n}) => {\n const aui = useAui({\n suggestion: Derived({\n source: \"suggestions\",\n query: { index },\n get: (aui) => aui.suggestions().suggestion({ index }),\n }),\n });\n\n return <AuiProvider value={aui}>{children}</AuiProvider>;\n};\n"],"mappings":";;;AAOA,MAAa,6BAAiE,EAC5E,OACA,eACI;CASJ,OAAO,oBAAC,aAAD;EAAa,OARR,OAAO,EACjB,YAAY,QAAQ;GAClB,QAAQ;GACR,OAAO,EAAE,MAAM;GACf,MAAM,QAAQ,IAAI,YAAY,EAAE,WAAW,EAAE,MAAM,CAAC;EACtD,CAAC,EACH,CAE6B;EAAI;CAAsB,CAAA;AACzD"}
1
+ {"version":3,"file":"SuggestionByIndexProvider.js","names":[],"sources":["../../../src/react/providers/SuggestionByIndexProvider.tsx"],"sourcesContent":["import type { FC, PropsWithChildren } from \"react\";\nimport { AuiProvider, Derived, useAui } from \"@assistant-ui/store\";\n\nexport type SuggestionByIndexProviderProps = PropsWithChildren<{\n index: number;\n}>;\n\nexport const SuggestionByIndexProvider: FC<SuggestionByIndexProviderProps> = ({\n index,\n children,\n}) => {\n const aui = useAui({\n suggestion: Derived({\n source: \"suggestions\",\n query: { index },\n get: (aui) => aui.suggestions().suggestion({ index }),\n }),\n });\n\n return <AuiProvider value={aui}>{children}</AuiProvider>;\n};\n"],"mappings":";;;AAOA,MAAa,6BAAiE,EAC5E,OACA,eACI;CASJ,OAAO,oBAAC,aAAD;EAAa,OARR,OAAO,EACjB,YAAY,QAAQ;GAClB,QAAQ;GACR,OAAO,EAAE,MAAM;GACf,MAAM,QAAQ,IAAI,YAAY,CAAC,CAAC,WAAW,EAAE,MAAM,CAAC;EACtD,CAAC,EACH,CAE6B;EAAI;CAAsB,CAAA;AACzD"}
@@ -1 +1 @@
1
- {"version":3,"file":"TextMessagePartProvider.d.ts","names":[],"sources":["../../../src/react/providers/TextMessagePartProvider.tsx"],"mappings":";;;cAqCa,uBAAA,EAAyB,EAAE,CACtC,iBAAA;EACE,IAAA;EACA,SAAA;AAAA"}
1
+ {"version":3,"file":"TextMessagePartProvider.d.ts","names":[],"sources":["../../../src/react/providers/TextMessagePartProvider.tsx"],"mappings":";;;cAoCa,uBAAA,EAAyB,EAAE,CACtC,iBAAA;EACE,IAAA;EACA,SAAA;AAAA"}
@@ -1,9 +1,10 @@
1
+ import { useMemo } from "@assistant-ui/tap/react-shim";
1
2
  import { AuiProvider, useAui } from "@assistant-ui/store";
2
- import { resource, tapMemo } from "@assistant-ui/tap";
3
+ import { resource } from "@assistant-ui/tap";
3
4
  import { jsx } from "react/jsx-runtime";
4
5
  //#region src/react/providers/TextMessagePartProvider.tsx
5
- const TextMessagePartClient = resource(({ text, isRunning }) => {
6
- const state = tapMemo(() => ({
6
+ const TextMessagePartClient = resource(function TextMessagePartClient({ text, isRunning }) {
7
+ const state = useMemo(() => ({
7
8
  type: "text",
8
9
  text,
9
10
  status: isRunning ? { type: "running" } : { type: "complete" }
@@ -1 +1 @@
1
- {"version":3,"file":"TextMessagePartProvider.js","names":[],"sources":["../../../src/react/providers/TextMessagePartProvider.tsx"],"sourcesContent":["import type { FC, PropsWithChildren } from \"react\";\nimport { useAui, AuiProvider, type ClientOutput } from \"@assistant-ui/store\";\nimport type { PartState } from \"../../store/scopes/part\";\nimport { resource, tapMemo } from \"@assistant-ui/tap\";\n\nconst TextMessagePartClient = resource(\n ({\n text,\n isRunning,\n }: {\n text: string;\n isRunning: boolean;\n }): ClientOutput<\"part\"> => {\n const state = tapMemo<PartState>(\n () => ({\n type: \"text\",\n text,\n status: isRunning ? { type: \"running\" } : { type: \"complete\" },\n }),\n [text, isRunning],\n );\n\n return {\n getState: () => state,\n addToolResult: () => {\n throw new Error(\"Not supported\");\n },\n resumeToolCall: () => {\n throw new Error(\"Not supported\");\n },\n respondToToolApproval: () => {\n throw new Error(\"Not supported\");\n },\n };\n },\n);\n\nexport const TextMessagePartProvider: FC<\n PropsWithChildren<{\n text: string;\n isRunning?: boolean;\n }>\n> = ({ text, isRunning = false, children }) => {\n const aui = useAui({\n part: TextMessagePartClient({ text, isRunning }),\n });\n\n return <AuiProvider value={aui}>{children}</AuiProvider>;\n};\n"],"mappings":";;;;AAKA,MAAM,wBAAwB,UAC3B,EACC,MACA,gBAI0B;CAC1B,MAAM,QAAQ,eACL;EACL,MAAM;EACN;EACA,QAAQ,YAAY,EAAE,MAAM,UAAU,IAAI,EAAE,MAAM,WAAW;CAC/D,IACA,CAAC,MAAM,SAAS,CAClB;CAEA,OAAO;EACL,gBAAgB;EAChB,qBAAqB;GACnB,MAAM,IAAI,MAAM,eAAe;EACjC;EACA,sBAAsB;GACpB,MAAM,IAAI,MAAM,eAAe;EACjC;EACA,6BAA6B;GAC3B,MAAM,IAAI,MAAM,eAAe;EACjC;CACF;AACF,CACF;AAEA,MAAa,2BAKR,EAAE,MAAM,YAAY,OAAO,eAAe;CAK7C,OAAO,oBAAC,aAAD;EAAa,OAJR,OAAO,EACjB,MAAM,sBAAsB;GAAE;GAAM;EAAU,CAAC,EACjD,CAE6B;EAAI;CAAsB,CAAA;AACzD"}
1
+ {"version":3,"file":"TextMessagePartProvider.js","names":[],"sources":["../../../src/react/providers/TextMessagePartProvider.tsx"],"sourcesContent":["import { type FC, type PropsWithChildren, useMemo } from \"react\";\nimport { useAui, AuiProvider, type ClientOutput } from \"@assistant-ui/store\";\nimport type { PartState } from \"../../store/scopes/part\";\n\nimport { resource } from \"@assistant-ui/tap\";\n\nconst TextMessagePartClient = resource(function TextMessagePartClient({\n text,\n isRunning,\n}: {\n text: string;\n isRunning: boolean;\n}): ClientOutput<\"part\"> {\n const state = useMemo<PartState>(\n () => ({\n type: \"text\",\n text,\n status: isRunning ? { type: \"running\" } : { type: \"complete\" },\n }),\n [text, isRunning],\n );\n\n return {\n getState: () => state,\n addToolResult: () => {\n throw new Error(\"Not supported\");\n },\n resumeToolCall: () => {\n throw new Error(\"Not supported\");\n },\n respondToToolApproval: () => {\n throw new Error(\"Not supported\");\n },\n };\n});\n\nexport const TextMessagePartProvider: FC<\n PropsWithChildren<{\n text: string;\n isRunning?: boolean;\n }>\n> = ({ text, isRunning = false, children }) => {\n const aui = useAui({\n part: TextMessagePartClient({ text, isRunning }),\n });\n\n return <AuiProvider value={aui}>{children}</AuiProvider>;\n};\n"],"mappings":";;;;;AAMA,MAAM,wBAAwB,SAAS,SAAS,sBAAsB,EACpE,MACA,aAIuB;CACvB,MAAM,QAAQ,eACL;EACL,MAAM;EACN;EACA,QAAQ,YAAY,EAAE,MAAM,UAAU,IAAI,EAAE,MAAM,WAAW;CAC/D,IACA,CAAC,MAAM,SAAS,CAClB;CAEA,OAAO;EACL,gBAAgB;EAChB,qBAAqB;GACnB,MAAM,IAAI,MAAM,eAAe;EACjC;EACA,sBAAsB;GACpB,MAAM,IAAI,MAAM,eAAe;EACjC;EACA,6BAA6B;GAC3B,MAAM,IAAI,MAAM,eAAe;EACjC;CACF;AACF,CAAC;AAED,MAAa,2BAKR,EAAE,MAAM,YAAY,OAAO,eAAe;CAK7C,OAAO,oBAAC,aAAD;EAAa,OAJR,OAAO,EACjB,MAAM,sBAAsB;GAAE;GAAM;EAAU,CAAC,EACjD,CAE6B;EAAI;CAAsB,CAAA;AACzD"}
@@ -1 +1 @@
1
- {"version":3,"file":"ThreadListItemByIndexProvider.js","names":[],"sources":["../../../src/react/providers/ThreadListItemByIndexProvider.tsx"],"sourcesContent":["import type { FC, PropsWithChildren } from \"react\";\nimport { useAui, AuiProvider, Derived } from \"@assistant-ui/store\";\n\nexport const ThreadListItemByIndexProvider: FC<\n PropsWithChildren<{\n index: number;\n archived: boolean;\n }>\n> = ({ index, archived, children }) => {\n const aui = useAui({\n threadListItem: Derived({\n source: \"threads\",\n query: { type: \"index\", index, archived },\n get: (aui) => aui.threads().item({ index, archived }),\n }),\n });\n\n return <AuiProvider value={aui}>{children}</AuiProvider>;\n};\n"],"mappings":";;;AAGA,MAAa,iCAKR,EAAE,OAAO,UAAU,eAAe;CASrC,OAAO,oBAAC,aAAD;EAAa,OARR,OAAO,EACjB,gBAAgB,QAAQ;GACtB,QAAQ;GACR,OAAO;IAAE,MAAM;IAAS;IAAO;GAAS;GACxC,MAAM,QAAQ,IAAI,QAAQ,EAAE,KAAK;IAAE;IAAO;GAAS,CAAC;EACtD,CAAC,EACH,CAE6B;EAAI;CAAsB,CAAA;AACzD"}
1
+ {"version":3,"file":"ThreadListItemByIndexProvider.js","names":[],"sources":["../../../src/react/providers/ThreadListItemByIndexProvider.tsx"],"sourcesContent":["import type { FC, PropsWithChildren } from \"react\";\nimport { useAui, AuiProvider, Derived } from \"@assistant-ui/store\";\n\nexport const ThreadListItemByIndexProvider: FC<\n PropsWithChildren<{\n index: number;\n archived: boolean;\n }>\n> = ({ index, archived, children }) => {\n const aui = useAui({\n threadListItem: Derived({\n source: \"threads\",\n query: { type: \"index\", index, archived },\n get: (aui) => aui.threads().item({ index, archived }),\n }),\n });\n\n return <AuiProvider value={aui}>{children}</AuiProvider>;\n};\n"],"mappings":";;;AAGA,MAAa,iCAKR,EAAE,OAAO,UAAU,eAAe;CASrC,OAAO,oBAAC,aAAD;EAAa,OARR,OAAO,EACjB,gBAAgB,QAAQ;GACtB,QAAQ;GACR,OAAO;IAAE,MAAM;IAAS;IAAO;GAAS;GACxC,MAAM,QAAQ,IAAI,QAAQ,CAAC,CAAC,KAAK;IAAE;IAAO;GAAS,CAAC;EACtD,CAAC,EACH,CAE6B;EAAI;CAAsB,CAAA;AACzD"}
@@ -3,6 +3,7 @@ import { Unsubscribe } from "../../types/unsubscribe.js";
3
3
  import { ModelContext } from "../../model-context/types.js";
4
4
  import { ThreadMessageLike } from "../../runtime/utils/thread-message-like.js";
5
5
  import { ExportedMessageRepository } from "../../runtime/utils/message-repository.js";
6
+ import { QueueItemState } from "../../store/scopes/queue-item.js";
6
7
  import { EditComposerRuntimeCore, ThreadComposerRuntimeCore } from "../../runtime/interfaces/composer-runtime-core.js";
7
8
  import { AddToolResultOptions, RespondToToolApprovalOptions, ResumeRunConfig, ResumeToolCallOptions, RuntimeCapabilities, SpeechState, StartRunConfig, SubmitFeedbackOptions, ThreadRuntimeEventCallback, ThreadRuntimeEventType, ThreadSuggestion, VoiceSessionState } from "../../runtime/interfaces/thread-runtime-core.js";
8
9
  import { ThreadListRuntimeCore } from "../../runtime/interfaces/thread-list-runtime-core.js";
@@ -44,6 +45,9 @@ declare class RemoteThreadListHookInstanceManager extends BaseSubscribable {
44
45
  composer: ThreadComposerRuntimeCore;
45
46
  getEditComposer: (messageId: string) => EditComposerRuntimeCore | undefined;
46
47
  beginEdit: (messageId: string) => void;
48
+ getQueueItems?: () => readonly QueueItemState[];
49
+ steerQueueItem?: (queueItemId: string) => void;
50
+ removeQueueItem?: (queueItemId: string) => void;
47
51
  speech: SpeechState | undefined;
48
52
  voice: VoiceSessionState | undefined;
49
53
  capabilities: Readonly<RuntimeCapabilities>;
@@ -91,6 +95,9 @@ declare class RemoteThreadListHookInstanceManager extends BaseSubscribable {
91
95
  composer: ThreadComposerRuntimeCore;
92
96
  getEditComposer: (messageId: string) => EditComposerRuntimeCore | undefined;
93
97
  beginEdit: (messageId: string) => void;
98
+ getQueueItems?: () => readonly QueueItemState[];
99
+ steerQueueItem?: (queueItemId: string) => void;
100
+ removeQueueItem?: (queueItemId: string) => void;
94
101
  speech: SpeechState | undefined;
95
102
  voice: VoiceSessionState | undefined;
96
103
  capabilities: Readonly<RuntimeCapabilities>;
@@ -1 +1 @@
1
- {"version":3,"file":"RemoteThreadListHookInstanceManager.d.ts","names":[],"sources":["../../../src/react/runtimes/RemoteThreadListHookInstanceManager.tsx"],"mappings":";;;;;;;;;;;;;KAuBK,oBAAA,SAA6B,gBAAgB;AAAA,cAcrC,mCAAA,SAA4C,gBAAA;EAAA,QAC/C,cAAA;EAAA,QAGA,SAAA;EAAA,QACA,0BAAA;EAAA,QACA,MAAA;cAGN,WAAA,EAAa,oBAAA,EACb,MAAA,EAAQ,qBAAA;EAOH,kBAAA,CAAmB,QAAA,WAAgB,OAAA,CAAA,QAAA;;;eAPX,aAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;EA+BxB,oBAAA,CAAqB,QAAA,WAAgB,QAAA;;;eAxBF,aAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;EA8BnC,iBAAA,CAAkB,QAAA;EAKlB,cAAA,CAAe,cAAA,EAAgB,oBAAA;EAAA,QAS9B,cAAA;EAAA,QAgEA,0BAAA;EAqCD,+BAAA,EAAiC,EAAA;IACtC,QAAA,EAAU,aAAA,CAAc,iBAAA;EAAA;AAAA"}
1
+ {"version":3,"file":"RemoteThreadListHookInstanceManager.d.ts","names":[],"sources":["../../../src/react/runtimes/RemoteThreadListHookInstanceManager.tsx"],"mappings":";;;;;;;;;;;;;;KAuBK,oBAAA,SAA6B,gBAAgB;AAAA,cAcrC,mCAAA,SAA4C,gBAAA;EAAA,QAC/C,cAAA;EAAA,QAGA,SAAA;EAAA,QACA,0BAAA;EAAA,QACA,MAAA;cAGN,WAAA,EAAa,oBAAA,EACb,MAAA,EAAQ,qBAAA;EAOH,kBAAA,CAAmB,QAAA,WAAgB,OAAA,CAAA,QAAA;;;eAPX,aAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;EA+BxB,oBAAA,CAAqB,QAAA,WAAgB,QAAA;;;eAxBF,aAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;EA8BnC,iBAAA,CAAkB,QAAA;EAKlB,cAAA,CAAe,cAAA,EAAgB,oBAAA;EAAA,QAS9B,cAAA;EAAA,QAgEA,0BAAA;EAqCD,+BAAA,EAAiC,EAAA;IACtC,QAAA,EAAU,aAAA,CAAc,iBAAA;EAAA;AAAA"}
@@ -1,7 +1,7 @@
1
1
  import { BaseSubscribable } from "../../subscribable/subscribable.js";
2
2
  import { ThreadListRuntimeImpl } from "../../runtime/api/thread-list-runtime.js";
3
3
  import { ThreadListItemRuntimeProvider } from "../providers/ThreadListItemRuntimeProvider.js";
4
- import { Fragment, memo, useCallback, useEffect, useLayoutEffect, useMemo, useRef } from "react";
4
+ import { Fragment, memo, useCallback, useEffect, useLayoutEffect, useMemo, useRef } from "@assistant-ui/tap/react-shim";
5
5
  import { useAui } from "@assistant-ui/store";
6
6
  import { Fragment as Fragment$1, jsx } from "react/jsx-runtime";
7
7
  import { create } from "zustand";