@assistant-ui/core 0.1.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (599) hide show
  1. package/dist/adapters/attachment.d.ts +36 -0
  2. package/dist/adapters/attachment.d.ts.map +1 -0
  3. package/dist/adapters/attachment.js +148 -0
  4. package/dist/adapters/attachment.js.map +1 -0
  5. package/dist/adapters/feedback.d.ts +10 -0
  6. package/dist/adapters/feedback.d.ts.map +1 -0
  7. package/dist/adapters/feedback.js +2 -0
  8. package/dist/adapters/feedback.js.map +1 -0
  9. package/dist/adapters/index.d.ts +8 -0
  10. package/dist/adapters/index.d.ts.map +1 -0
  11. package/dist/adapters/index.js +3 -0
  12. package/dist/adapters/index.js.map +1 -0
  13. package/dist/adapters/speech.d.ts +76 -0
  14. package/dist/adapters/speech.d.ts.map +1 -0
  15. package/dist/adapters/speech.js +179 -0
  16. package/dist/adapters/speech.js.map +1 -0
  17. package/dist/adapters/suggestion.d.ts +10 -0
  18. package/dist/adapters/suggestion.d.ts.map +1 -0
  19. package/dist/adapters/suggestion.js +2 -0
  20. package/dist/adapters/suggestion.js.map +1 -0
  21. package/dist/adapters/thread-history.d.ts +43 -0
  22. package/dist/adapters/thread-history.d.ts.map +1 -0
  23. package/dist/adapters/thread-history.js +2 -0
  24. package/dist/adapters/thread-history.js.map +1 -0
  25. package/dist/index.d.ts +6 -0
  26. package/dist/index.d.ts.map +1 -0
  27. package/dist/index.js +7 -0
  28. package/dist/index.js.map +1 -0
  29. package/dist/internal.d.ts +5 -0
  30. package/dist/internal.d.ts.map +1 -0
  31. package/dist/internal.js +7 -0
  32. package/dist/internal.js.map +1 -0
  33. package/dist/model-context/frame/host.d.ts +21 -0
  34. package/dist/model-context/frame/host.d.ts.map +1 -0
  35. package/dist/model-context/frame/host.js +141 -0
  36. package/dist/model-context/frame/host.js.map +1 -0
  37. package/dist/model-context/frame/index.d.ts +5 -0
  38. package/dist/model-context/frame/index.d.ts.map +1 -0
  39. package/dist/model-context/frame/index.js +4 -0
  40. package/dist/model-context/frame/index.js.map +1 -0
  41. package/dist/model-context/frame/provider.d.ts +18 -0
  42. package/dist/model-context/frame/provider.d.ts.map +1 -0
  43. package/dist/model-context/frame/provider.js +133 -0
  44. package/dist/model-context/frame/provider.js.map +1 -0
  45. package/dist/model-context/frame/types.d.ts +29 -0
  46. package/dist/model-context/frame/types.d.ts.map +1 -0
  47. package/dist/model-context/frame/types.js +2 -0
  48. package/dist/model-context/frame/types.js.map +1 -0
  49. package/dist/model-context/index.d.ts +8 -0
  50. package/dist/model-context/index.d.ts.map +1 -0
  51. package/dist/model-context/index.js +9 -0
  52. package/dist/model-context/index.js.map +1 -0
  53. package/dist/model-context/registry-handles.d.ts +13 -0
  54. package/dist/model-context/registry-handles.d.ts.map +1 -0
  55. package/dist/model-context/registry-handles.js +2 -0
  56. package/dist/model-context/registry-handles.js.map +1 -0
  57. package/dist/model-context/registry.d.ts +17 -0
  58. package/dist/model-context/registry.d.ts.map +1 -0
  59. package/dist/model-context/registry.js +108 -0
  60. package/dist/model-context/registry.js.map +1 -0
  61. package/dist/model-context/tool.d.ts +3 -0
  62. package/dist/model-context/tool.d.ts.map +1 -0
  63. package/dist/model-context/tool.js +5 -0
  64. package/dist/model-context/tool.js.map +1 -0
  65. package/dist/model-context/types.d.ts +37 -0
  66. package/dist/model-context/types.d.ts.map +1 -0
  67. package/dist/model-context/types.js +43 -0
  68. package/dist/model-context/types.js.map +1 -0
  69. package/dist/runtime/api/assistant-runtime.d.ts +64 -0
  70. package/dist/runtime/api/assistant-runtime.d.ts.map +1 -0
  71. package/dist/runtime/api/assistant-runtime.js +46 -0
  72. package/dist/runtime/api/assistant-runtime.js.map +1 -0
  73. package/dist/runtime/api/attachment-runtime.d.ts +63 -0
  74. package/dist/runtime/api/attachment-runtime.d.ts.map +1 -0
  75. package/dist/runtime/api/attachment-runtime.js +56 -0
  76. package/dist/runtime/api/attachment-runtime.js.map +1 -0
  77. package/dist/runtime/api/bindings.d.ts +31 -0
  78. package/dist/runtime/api/bindings.d.ts.map +1 -0
  79. package/dist/runtime/api/bindings.js +2 -0
  80. package/dist/runtime/api/bindings.js.map +1 -0
  81. package/dist/runtime/api/composer-runtime.d.ts +181 -0
  82. package/dist/runtime/api/composer-runtime.d.ts.map +1 -0
  83. package/dist/runtime/api/composer-runtime.js +247 -0
  84. package/dist/runtime/api/composer-runtime.js.map +1 -0
  85. package/dist/runtime/api/message-part-runtime.d.ts +31 -0
  86. package/dist/runtime/api/message-part-runtime.d.ts.map +1 -0
  87. package/dist/runtime/api/message-part-runtime.js +67 -0
  88. package/dist/runtime/api/message-part-runtime.js.map +1 -0
  89. package/dist/runtime/api/message-runtime.d.ts +91 -0
  90. package/dist/runtime/api/message-runtime.d.ts.map +1 -0
  91. package/dist/runtime/api/message-runtime.js +199 -0
  92. package/dist/runtime/api/message-runtime.js.map +1 -0
  93. package/dist/runtime/api/paths.d.ts +64 -0
  94. package/dist/runtime/api/paths.d.ts.map +1 -0
  95. package/dist/runtime/api/paths.js +2 -0
  96. package/dist/runtime/api/paths.js.map +1 -0
  97. package/dist/runtime/api/thread-list-item-runtime.d.ts +50 -0
  98. package/dist/runtime/api/thread-list-item-runtime.d.ts.map +1 -0
  99. package/dist/runtime/api/thread-list-item-runtime.js +85 -0
  100. package/dist/runtime/api/thread-list-item-runtime.js.map +1 -0
  101. package/dist/runtime/api/thread-list-runtime.d.ts +44 -0
  102. package/dist/runtime/api/thread-list-runtime.d.ts.map +1 -0
  103. package/dist/runtime/api/thread-list-runtime.js +136 -0
  104. package/dist/runtime/api/thread-list-runtime.js.map +1 -0
  105. package/dist/runtime/api/thread-runtime.d.ts +272 -0
  106. package/dist/runtime/api/thread-runtime.d.ts.map +1 -0
  107. package/dist/runtime/api/thread-runtime.js +240 -0
  108. package/dist/runtime/api/thread-runtime.js.map +1 -0
  109. package/dist/runtime/base/base-assistant-runtime-core.d.ts +12 -0
  110. package/dist/runtime/base/base-assistant-runtime-core.d.ts.map +1 -0
  111. package/dist/runtime/base/base-assistant-runtime-core.js +11 -0
  112. package/dist/runtime/base/base-assistant-runtime-core.js.map +1 -0
  113. package/dist/runtime/base/base-composer-runtime-core.d.ts +55 -0
  114. package/dist/runtime/base/base-composer-runtime-core.d.ts.map +1 -0
  115. package/dist/runtime/base/base-composer-runtime-core.js +320 -0
  116. package/dist/runtime/base/base-composer-runtime-core.js.map +1 -0
  117. package/dist/runtime/base/base-thread-runtime-core.d.ts +67 -0
  118. package/dist/runtime/base/base-thread-runtime-core.d.ts.map +1 -0
  119. package/dist/runtime/base/base-thread-runtime-core.js +157 -0
  120. package/dist/runtime/base/base-thread-runtime-core.js.map +1 -0
  121. package/dist/runtime/base/default-edit-composer-runtime-core.d.ts +28 -0
  122. package/dist/runtime/base/default-edit-composer-runtime-core.d.ts.map +1 -0
  123. package/dist/runtime/base/default-edit-composer-runtime-core.js +49 -0
  124. package/dist/runtime/base/default-edit-composer-runtime-core.js.map +1 -0
  125. package/dist/runtime/base/default-thread-composer-runtime-core.d.ts +24 -0
  126. package/dist/runtime/base/default-thread-composer-runtime-core.d.ts.map +1 -0
  127. package/dist/runtime/base/default-thread-composer-runtime-core.js +41 -0
  128. package/dist/runtime/base/default-thread-composer-runtime-core.js.map +1 -0
  129. package/dist/runtime/index.d.ts +20 -0
  130. package/dist/runtime/index.d.ts.map +1 -0
  131. package/dist/runtime/index.js +7 -0
  132. package/dist/runtime/index.js.map +1 -0
  133. package/dist/runtime/interfaces/assistant-runtime-core.d.ts +10 -0
  134. package/dist/runtime/interfaces/assistant-runtime-core.d.ts.map +1 -0
  135. package/dist/runtime/interfaces/assistant-runtime-core.js +2 -0
  136. package/dist/runtime/interfaces/assistant-runtime-core.js.map +1 -0
  137. package/dist/runtime/interfaces/composer-runtime-core.d.ts +38 -0
  138. package/dist/runtime/interfaces/composer-runtime-core.d.ts.map +1 -0
  139. package/dist/runtime/interfaces/composer-runtime-core.js +2 -0
  140. package/dist/runtime/interfaces/composer-runtime-core.js.map +1 -0
  141. package/dist/runtime/interfaces/thread-list-runtime-core.d.ts +37 -0
  142. package/dist/runtime/interfaces/thread-list-runtime-core.d.ts.map +1 -0
  143. package/dist/runtime/interfaces/thread-list-runtime-core.js +2 -0
  144. package/dist/runtime/interfaces/thread-list-runtime-core.js.map +1 -0
  145. package/dist/runtime/interfaces/thread-runtime-core.d.ts +97 -0
  146. package/dist/runtime/interfaces/thread-runtime-core.d.ts.map +1 -0
  147. package/dist/runtime/interfaces/thread-runtime-core.js +2 -0
  148. package/dist/runtime/interfaces/thread-runtime-core.js.map +1 -0
  149. package/dist/runtime/internal.d.ts +23 -0
  150. package/dist/runtime/internal.d.ts.map +1 -0
  151. package/dist/runtime/internal.js +25 -0
  152. package/dist/runtime/internal.js.map +1 -0
  153. package/dist/runtime/utils/auto-status.d.ts +5 -0
  154. package/dist/runtime/utils/auto-status.d.ts.map +1 -0
  155. package/dist/runtime/utils/auto-status.js +32 -0
  156. package/dist/runtime/utils/auto-status.js.map +1 -0
  157. package/dist/runtime/utils/chat-model-adapter.d.ts +40 -0
  158. package/dist/runtime/utils/chat-model-adapter.d.ts.map +1 -0
  159. package/dist/runtime/utils/chat-model-adapter.js +2 -0
  160. package/dist/runtime/utils/chat-model-adapter.js.map +1 -0
  161. package/dist/runtime/utils/external-store-message.d.ts +10 -0
  162. package/dist/runtime/utils/external-store-message.d.ts.map +1 -0
  163. package/dist/runtime/utils/external-store-message.js +22 -0
  164. package/dist/runtime/utils/external-store-message.js.map +1 -0
  165. package/dist/runtime/utils/message-repository.d.ts +43 -0
  166. package/dist/runtime/utils/message-repository.d.ts.map +1 -0
  167. package/dist/runtime/utils/message-repository.js +257 -0
  168. package/dist/runtime/utils/message-repository.js.map +1 -0
  169. package/dist/runtime/utils/thread-message-like.d.ts +34 -0
  170. package/dist/runtime/utils/thread-message-like.d.ts.map +1 -0
  171. package/dist/runtime/utils/thread-message-like.js +129 -0
  172. package/dist/runtime/utils/thread-message-like.js.map +1 -0
  173. package/dist/runtimes/assistant-transport/utils.d.ts +11 -0
  174. package/dist/runtimes/assistant-transport/utils.d.ts.map +1 -0
  175. package/dist/runtimes/assistant-transport/utils.js +20 -0
  176. package/dist/runtimes/assistant-transport/utils.js.map +1 -0
  177. package/dist/runtimes/external-store/external-store-adapter.d.ts +81 -0
  178. package/dist/runtimes/external-store/external-store-adapter.d.ts.map +1 -0
  179. package/dist/runtimes/external-store/external-store-adapter.js +2 -0
  180. package/dist/runtimes/external-store/external-store-adapter.js.map +1 -0
  181. package/dist/runtimes/external-store/external-store-runtime-core.d.ts +9 -0
  182. package/dist/runtimes/external-store/external-store-runtime-core.d.ts.map +1 -0
  183. package/dist/runtimes/external-store/external-store-runtime-core.js +19 -0
  184. package/dist/runtimes/external-store/external-store-runtime-core.js.map +1 -0
  185. package/dist/runtimes/external-store/external-store-thread-list-runtime-core.d.ts +42 -0
  186. package/dist/runtimes/external-store/external-store-thread-list-runtime-core.d.ts.map +1 -0
  187. package/dist/runtimes/external-store/external-store-thread-list-runtime-core.js +174 -0
  188. package/dist/runtimes/external-store/external-store-thread-list-runtime-core.js.map +1 -0
  189. package/dist/runtimes/external-store/external-store-thread-runtime-core.d.ts +47 -0
  190. package/dist/runtimes/external-store/external-store-thread-runtime-core.d.ts.map +1 -0
  191. package/dist/runtimes/external-store/external-store-thread-runtime-core.js +260 -0
  192. package/dist/runtimes/external-store/external-store-thread-runtime-core.js.map +1 -0
  193. package/dist/runtimes/external-store/index.d.ts +8 -0
  194. package/dist/runtimes/external-store/index.d.ts.map +1 -0
  195. package/dist/runtimes/external-store/index.js +5 -0
  196. package/dist/runtimes/external-store/index.js.map +1 -0
  197. package/dist/runtimes/external-store/thread-message-converter.d.ts +7 -0
  198. package/dist/runtimes/external-store/thread-message-converter.d.ts.map +1 -0
  199. package/dist/runtimes/external-store/thread-message-converter.js +12 -0
  200. package/dist/runtimes/external-store/thread-message-converter.js.map +1 -0
  201. package/dist/runtimes/index.d.ts +6 -0
  202. package/dist/runtimes/index.d.ts.map +1 -0
  203. package/dist/runtimes/index.js +4 -0
  204. package/dist/runtimes/index.js.map +1 -0
  205. package/dist/runtimes/internal.d.ts +18 -0
  206. package/dist/runtimes/internal.d.ts.map +1 -0
  207. package/dist/runtimes/internal.js +15 -0
  208. package/dist/runtimes/internal.js.map +1 -0
  209. package/dist/runtimes/local/index.d.ts +7 -0
  210. package/dist/runtimes/local/index.d.ts.map +1 -0
  211. package/dist/runtimes/local/index.js +5 -0
  212. package/dist/runtimes/local/index.js.map +1 -0
  213. package/dist/runtimes/local/local-runtime-core.d.ts +11 -0
  214. package/dist/runtimes/local/local-runtime-core.d.ts.map +1 -0
  215. package/dist/runtimes/local/local-runtime-core.js +22 -0
  216. package/dist/runtimes/local/local-runtime-core.js.map +1 -0
  217. package/dist/runtimes/local/local-runtime-options.d.ts +23 -0
  218. package/dist/runtimes/local/local-runtime-options.d.ts.map +1 -0
  219. package/dist/runtimes/local/local-runtime-options.js +2 -0
  220. package/dist/runtimes/local/local-runtime-options.js.map +1 -0
  221. package/dist/runtimes/local/local-thread-list-runtime-core.d.ts +46 -0
  222. package/dist/runtimes/local/local-thread-list-runtime-core.d.ts.map +1 -0
  223. package/dist/runtimes/local/local-thread-list-runtime-core.js +87 -0
  224. package/dist/runtimes/local/local-thread-list-runtime-core.js.map +1 -0
  225. package/dist/runtimes/local/local-thread-runtime-core.d.ts +59 -0
  226. package/dist/runtimes/local/local-thread-runtime-core.d.ts.map +1 -0
  227. package/dist/runtimes/local/local-thread-runtime-core.js +423 -0
  228. package/dist/runtimes/local/local-thread-runtime-core.js.map +1 -0
  229. package/dist/runtimes/local/should-continue.d.ts +3 -0
  230. package/dist/runtimes/local/should-continue.d.ts.map +1 -0
  231. package/dist/runtimes/local/should-continue.js +14 -0
  232. package/dist/runtimes/local/should-continue.js.map +1 -0
  233. package/dist/runtimes/remote-thread-list/adapter/in-memory.d.ts +13 -0
  234. package/dist/runtimes/remote-thread-list/adapter/in-memory.d.ts.map +1 -0
  235. package/dist/runtimes/remote-thread-list/adapter/in-memory.js +29 -0
  236. package/dist/runtimes/remote-thread-list/adapter/in-memory.js.map +1 -0
  237. package/dist/runtimes/remote-thread-list/empty-thread-core.d.ts +3 -0
  238. package/dist/runtimes/remote-thread-list/empty-thread-core.d.ts.map +1 -0
  239. package/dist/runtimes/remote-thread-list/empty-thread-core.js +146 -0
  240. package/dist/runtimes/remote-thread-list/empty-thread-core.js.map +1 -0
  241. package/dist/runtimes/remote-thread-list/optimistic-state.d.ts +23 -0
  242. package/dist/runtimes/remote-thread-list/optimistic-state.d.ts.map +1 -0
  243. package/dist/runtimes/remote-thread-list/optimistic-state.js +57 -0
  244. package/dist/runtimes/remote-thread-list/optimistic-state.js.map +1 -0
  245. package/dist/runtimes/remote-thread-list/remote-thread-state.d.ts +37 -0
  246. package/dist/runtimes/remote-thread-list/remote-thread-state.d.ts.map +1 -0
  247. package/dist/runtimes/remote-thread-list/remote-thread-state.js +62 -0
  248. package/dist/runtimes/remote-thread-list/remote-thread-state.js.map +1 -0
  249. package/dist/runtimes/remote-thread-list/types.d.ts +38 -0
  250. package/dist/runtimes/remote-thread-list/types.d.ts.map +1 -0
  251. package/dist/runtimes/remote-thread-list/types.js +2 -0
  252. package/dist/runtimes/remote-thread-list/types.js.map +1 -0
  253. package/dist/store/clients/chain-of-thought-client.d.ts +15 -0
  254. package/dist/store/clients/chain-of-thought-client.d.ts.map +1 -0
  255. package/dist/store/clients/chain-of-thought-client.js +18 -0
  256. package/dist/store/clients/chain-of-thought-client.js.map +1 -0
  257. package/dist/store/clients/index.d.ts +6 -0
  258. package/dist/store/clients/index.d.ts.map +1 -0
  259. package/dist/store/clients/index.js +6 -0
  260. package/dist/store/clients/index.js.map +1 -0
  261. package/dist/store/clients/model-context-client.d.ts +3 -0
  262. package/dist/store/clients/model-context-client.d.ts.map +1 -0
  263. package/dist/store/clients/model-context-client.js +14 -0
  264. package/dist/store/clients/model-context-client.js.map +1 -0
  265. package/dist/store/clients/no-op-composer-client.d.ts +7 -0
  266. package/dist/store/clients/no-op-composer-client.d.ts.map +1 -0
  267. package/dist/store/clients/no-op-composer-client.js +61 -0
  268. package/dist/store/clients/no-op-composer-client.js.map +1 -0
  269. package/dist/store/clients/suggestions.d.ts +11 -0
  270. package/dist/store/clients/suggestions.d.ts.map +1 -0
  271. package/dist/store/clients/suggestions.js +37 -0
  272. package/dist/store/clients/suggestions.js.map +1 -0
  273. package/dist/store/clients/thread-message-client.d.ts +11 -0
  274. package/dist/store/clients/thread-message-client.d.ts.map +1 -0
  275. package/dist/store/clients/thread-message-client.js +112 -0
  276. package/dist/store/clients/thread-message-client.js.map +1 -0
  277. package/dist/store/index.d.ts +14 -0
  278. package/dist/store/index.d.ts.map +1 -0
  279. package/dist/store/index.js +14 -0
  280. package/dist/store/index.js.map +1 -0
  281. package/dist/store/internal.d.ts +11 -0
  282. package/dist/store/internal.d.ts.map +1 -0
  283. package/dist/store/internal.js +12 -0
  284. package/dist/store/internal.js.map +1 -0
  285. package/dist/store/runtime-clients/attachment-runtime-client.d.ts +8 -0
  286. package/dist/store/runtime-clients/attachment-runtime-client.d.ts.map +1 -0
  287. package/dist/store/runtime-clients/attachment-runtime-client.js +11 -0
  288. package/dist/store/runtime-clients/attachment-runtime-client.js.map +1 -0
  289. package/dist/store/runtime-clients/composer-runtime-client.d.ts +13 -0
  290. package/dist/store/runtime-clients/composer-runtime-client.d.ts.map +1 -0
  291. package/dist/store/runtime-clients/composer-runtime-client.js +83 -0
  292. package/dist/store/runtime-clients/composer-runtime-client.js.map +1 -0
  293. package/dist/store/runtime-clients/index.d.ts +8 -0
  294. package/dist/store/runtime-clients/index.d.ts.map +1 -0
  295. package/dist/store/runtime-clients/index.js +8 -0
  296. package/dist/store/runtime-clients/index.js.map +1 -0
  297. package/dist/store/runtime-clients/message-part-runtime-client.d.ts +8 -0
  298. package/dist/store/runtime-clients/message-part-runtime-client.d.ts.map +1 -0
  299. package/dist/store/runtime-clients/message-part-runtime-client.js +12 -0
  300. package/dist/store/runtime-clients/message-part-runtime-client.js.map +1 -0
  301. package/dist/store/runtime-clients/message-runtime-client.d.ts +11 -0
  302. package/dist/store/runtime-clients/message-runtime-client.d.ts.map +1 -0
  303. package/dist/store/runtime-clients/message-runtime-client.js +78 -0
  304. package/dist/store/runtime-clients/message-runtime-client.js.map +1 -0
  305. package/dist/store/runtime-clients/tap-subscribable.d.ts +3 -0
  306. package/dist/store/runtime-clients/tap-subscribable.d.ts.map +1 -0
  307. package/dist/store/runtime-clients/tap-subscribable.js +12 -0
  308. package/dist/store/runtime-clients/tap-subscribable.js.map +1 -0
  309. package/dist/store/runtime-clients/thread-list-item-runtime-client.d.ts +8 -0
  310. package/dist/store/runtime-clients/thread-list-item-runtime-client.d.ts.map +1 -0
  311. package/dist/store/runtime-clients/thread-list-item-runtime-client.js +41 -0
  312. package/dist/store/runtime-clients/thread-list-item-runtime-client.js.map +1 -0
  313. package/dist/store/runtime-clients/thread-list-runtime-client.d.ts +10 -0
  314. package/dist/store/runtime-clients/thread-list-runtime-client.d.ts.map +1 -0
  315. package/dist/store/runtime-clients/thread-list-runtime-client.js +54 -0
  316. package/dist/store/runtime-clients/thread-list-runtime-client.js.map +1 -0
  317. package/dist/store/runtime-clients/thread-runtime-client.d.ts +8 -0
  318. package/dist/store/runtime-clients/thread-runtime-client.d.ts.map +1 -0
  319. package/dist/store/runtime-clients/thread-runtime-client.js +91 -0
  320. package/dist/store/runtime-clients/thread-runtime-client.js.map +1 -0
  321. package/dist/store/scopes/attachment.d.ts +23 -0
  322. package/dist/store/scopes/attachment.d.ts.map +1 -0
  323. package/dist/store/scopes/attachment.js +2 -0
  324. package/dist/store/scopes/attachment.js.map +1 -0
  325. package/dist/store/scopes/chain-of-thought.d.ts +39 -0
  326. package/dist/store/scopes/chain-of-thought.d.ts.map +1 -0
  327. package/dist/store/scopes/chain-of-thought.js +2 -0
  328. package/dist/store/scopes/chain-of-thought.js.map +1 -0
  329. package/dist/store/scopes/composer.d.ts +75 -0
  330. package/dist/store/scopes/composer.d.ts.map +1 -0
  331. package/dist/store/scopes/composer.js +2 -0
  332. package/dist/store/scopes/composer.js.map +1 -0
  333. package/dist/store/scopes/index.d.ts +12 -0
  334. package/dist/store/scopes/index.d.ts.map +1 -0
  335. package/dist/store/scopes/index.js +2 -0
  336. package/dist/store/scopes/index.js.map +1 -0
  337. package/dist/store/scopes/message.d.ts +86 -0
  338. package/dist/store/scopes/message.d.ts.map +1 -0
  339. package/dist/store/scopes/message.js +2 -0
  340. package/dist/store/scopes/message.js.map +1 -0
  341. package/dist/store/scopes/model-context.d.ts +11 -0
  342. package/dist/store/scopes/model-context.d.ts.map +1 -0
  343. package/dist/store/scopes/model-context.js +2 -0
  344. package/dist/store/scopes/model-context.js.map +1 -0
  345. package/dist/store/scopes/part.d.ts +44 -0
  346. package/dist/store/scopes/part.d.ts.map +1 -0
  347. package/dist/store/scopes/part.js +2 -0
  348. package/dist/store/scopes/part.js.map +1 -0
  349. package/dist/store/scopes/suggestion.d.ts +19 -0
  350. package/dist/store/scopes/suggestion.d.ts.map +1 -0
  351. package/dist/store/scopes/suggestion.js +2 -0
  352. package/dist/store/scopes/suggestion.js.map +1 -0
  353. package/dist/store/scopes/suggestions.d.ts +19 -0
  354. package/dist/store/scopes/suggestions.d.ts.map +1 -0
  355. package/dist/store/scopes/suggestions.js +2 -0
  356. package/dist/store/scopes/suggestions.js.map +1 -0
  357. package/dist/store/scopes/thread-list-item.d.ts +50 -0
  358. package/dist/store/scopes/thread-list-item.d.ts.map +1 -0
  359. package/dist/store/scopes/thread-list-item.js +2 -0
  360. package/dist/store/scopes/thread-list-item.js.map +1 -0
  361. package/dist/store/scopes/thread.d.ts +135 -0
  362. package/dist/store/scopes/thread.d.ts.map +1 -0
  363. package/dist/store/scopes/thread.js +2 -0
  364. package/dist/store/scopes/thread.js.map +1 -0
  365. package/dist/store/scopes/threads.d.ts +29 -0
  366. package/dist/store/scopes/threads.d.ts.map +1 -0
  367. package/dist/store/scopes/threads.js +2 -0
  368. package/dist/store/scopes/threads.js.map +1 -0
  369. package/dist/store/types/client.d.ts +137 -0
  370. package/dist/store/types/client.d.ts.map +1 -0
  371. package/dist/store/types/client.js +2 -0
  372. package/dist/store/types/client.js.map +1 -0
  373. package/dist/store/types/events.d.ts +33 -0
  374. package/dist/store/types/events.d.ts.map +1 -0
  375. package/dist/store/types/events.js +8 -0
  376. package/dist/store/types/events.js.map +1 -0
  377. package/dist/store/types/index.d.ts +3 -0
  378. package/dist/store/types/index.d.ts.map +1 -0
  379. package/dist/store/types/index.js +2 -0
  380. package/dist/store/types/index.js.map +1 -0
  381. package/dist/store/utils/attach-transform-scopes.d.ts +11 -0
  382. package/dist/store/utils/attach-transform-scopes.d.ts.map +1 -0
  383. package/dist/store/utils/attach-transform-scopes.js +12 -0
  384. package/dist/store/utils/attach-transform-scopes.js.map +1 -0
  385. package/dist/store/utils/base-proxy-handler.d.ts +23 -0
  386. package/dist/store/utils/base-proxy-handler.d.ts.map +1 -0
  387. package/dist/store/utils/base-proxy-handler.js +46 -0
  388. package/dist/store/utils/base-proxy-handler.js.map +1 -0
  389. package/dist/store/utils/derived.d.ts +34 -0
  390. package/dist/store/utils/derived.d.ts.map +1 -0
  391. package/dist/store/utils/derived.js +24 -0
  392. package/dist/store/utils/derived.js.map +1 -0
  393. package/dist/store/utils/index.d.ts +7 -0
  394. package/dist/store/utils/index.d.ts.map +1 -0
  395. package/dist/store/utils/index.js +7 -0
  396. package/dist/store/utils/index.js.map +1 -0
  397. package/dist/store/utils/notification-manager.d.ts +11 -0
  398. package/dist/store/utils/notification-manager.d.ts.map +1 -0
  399. package/dist/store/utils/notification-manager.js +84 -0
  400. package/dist/store/utils/notification-manager.js.map +1 -0
  401. package/dist/store/utils/proxied-assistant-state.d.ts +8 -0
  402. package/dist/store/utils/proxied-assistant-state.d.ts.map +1 -0
  403. package/dist/store/utils/proxied-assistant-state.js +33 -0
  404. package/dist/store/utils/proxied-assistant-state.js.map +1 -0
  405. package/dist/store/utils/split-clients.d.ts +10 -0
  406. package/dist/store/utils/split-clients.d.ts.map +1 -0
  407. package/dist/store/utils/split-clients.js +53 -0
  408. package/dist/store/utils/split-clients.js.map +1 -0
  409. package/dist/store/utils/tap-assistant-context.d.ts +19 -0
  410. package/dist/store/utils/tap-assistant-context.d.ts.map +1 -0
  411. package/dist/store/utils/tap-assistant-context.js +23 -0
  412. package/dist/store/utils/tap-assistant-context.js.map +1 -0
  413. package/dist/store/utils/tap-client-list.d.ts +28 -0
  414. package/dist/store/utils/tap-client-list.d.ts.map +1 -0
  415. package/dist/store/utils/tap-client-list.js +68 -0
  416. package/dist/store/utils/tap-client-list.js.map +1 -0
  417. package/dist/store/utils/tap-client-lookup.d.ts +15 -0
  418. package/dist/store/utils/tap-client-lookup.d.ts.map +1 -0
  419. package/dist/store/utils/tap-client-lookup.js +42 -0
  420. package/dist/store/utils/tap-client-lookup.js.map +1 -0
  421. package/dist/store/utils/tap-client-resource.d.ts +13 -0
  422. package/dist/store/utils/tap-client-resource.d.ts.map +1 -0
  423. package/dist/store/utils/tap-client-resource.js +114 -0
  424. package/dist/store/utils/tap-client-resource.js.map +1 -0
  425. package/dist/store/utils/tap-client-stack-context.d.ts +23 -0
  426. package/dist/store/utils/tap-client-stack-context.d.ts.map +1 -0
  427. package/dist/store/utils/tap-client-stack-context.js +28 -0
  428. package/dist/store/utils/tap-client-stack-context.js.map +1 -0
  429. package/dist/store/utils/wrapper-resource.d.ts +3 -0
  430. package/dist/store/utils/wrapper-resource.d.ts.map +1 -0
  431. package/dist/store/utils/wrapper-resource.js +11 -0
  432. package/dist/store/utils/wrapper-resource.js.map +1 -0
  433. package/dist/subscribable/index.d.ts +3 -0
  434. package/dist/subscribable/index.d.ts.map +1 -0
  435. package/dist/subscribable/index.js +8 -0
  436. package/dist/subscribable/index.js.map +1 -0
  437. package/dist/subscribable/subscribable.d.ts +68 -0
  438. package/dist/subscribable/subscribable.d.ts.map +1 -0
  439. package/dist/subscribable/subscribable.js +237 -0
  440. package/dist/subscribable/subscribable.js.map +1 -0
  441. package/dist/types/attachment.d.ts +35 -0
  442. package/dist/types/attachment.d.ts.map +1 -0
  443. package/dist/types/attachment.js +2 -0
  444. package/dist/types/attachment.js.map +1 -0
  445. package/dist/types/index.d.ts +5 -0
  446. package/dist/types/index.d.ts.map +1 -0
  447. package/dist/types/index.js +2 -0
  448. package/dist/types/index.js.map +1 -0
  449. package/dist/types/message.d.ts +179 -0
  450. package/dist/types/message.d.ts.map +1 -0
  451. package/dist/types/message.js +2 -0
  452. package/dist/types/message.js.map +1 -0
  453. package/dist/types/quote.d.ts +5 -0
  454. package/dist/types/quote.d.ts.map +1 -0
  455. package/dist/types/quote.js +2 -0
  456. package/dist/types/quote.js.map +1 -0
  457. package/dist/types/unsubscribe.d.ts +2 -0
  458. package/dist/types/unsubscribe.d.ts.map +1 -0
  459. package/dist/types/unsubscribe.js +2 -0
  460. package/dist/types/unsubscribe.js.map +1 -0
  461. package/dist/utils/composite-context-provider.d.ts +10 -0
  462. package/dist/utils/composite-context-provider.d.ts.map +1 -0
  463. package/dist/utils/composite-context-provider.js +29 -0
  464. package/dist/utils/composite-context-provider.js.map +1 -0
  465. package/dist/utils/id.d.ts +6 -0
  466. package/dist/utils/id.d.ts.map +1 -0
  467. package/dist/utils/id.js +9 -0
  468. package/dist/utils/id.js.map +1 -0
  469. package/dist/utils/index.d.ts +4 -0
  470. package/dist/utils/index.d.ts.map +1 -0
  471. package/dist/utils/index.js +7 -0
  472. package/dist/utils/index.js.map +1 -0
  473. package/dist/utils/text.d.ts +3 -0
  474. package/dist/utils/text.d.ts.map +1 -0
  475. package/dist/utils/text.js +5 -0
  476. package/dist/utils/text.js.map +1 -0
  477. package/package.json +85 -0
  478. package/src/adapters/attachment.ts +209 -0
  479. package/src/adapters/feedback.ts +10 -0
  480. package/src/adapters/index.ts +30 -0
  481. package/src/adapters/speech.ts +338 -0
  482. package/src/adapters/suggestion.ts +14 -0
  483. package/src/adapters/thread-history.ts +72 -0
  484. package/src/index.ts +7 -0
  485. package/src/internal.ts +7 -0
  486. package/src/model-context/frame/host.ts +195 -0
  487. package/src/model-context/frame/index.ts +10 -0
  488. package/src/model-context/frame/provider.ts +193 -0
  489. package/src/model-context/frame/types.ts +40 -0
  490. package/src/model-context/index.ts +35 -0
  491. package/src/model-context/registry-handles.ts +18 -0
  492. package/src/model-context/registry.ts +159 -0
  493. package/src/model-context/tool.ts +9 -0
  494. package/src/model-context/types.ts +104 -0
  495. package/src/runtime/api/assistant-runtime.ts +115 -0
  496. package/src/runtime/api/attachment-runtime.ts +119 -0
  497. package/src/runtime/api/bindings.ts +49 -0
  498. package/src/runtime/api/composer-runtime.ts +505 -0
  499. package/src/runtime/api/message-part-runtime.ts +108 -0
  500. package/src/runtime/api/message-runtime.ts +335 -0
  501. package/src/runtime/api/paths.ts +61 -0
  502. package/src/runtime/api/thread-list-item-runtime.ts +145 -0
  503. package/src/runtime/api/thread-list-runtime.ts +227 -0
  504. package/src/runtime/api/thread-runtime.ts +568 -0
  505. package/src/runtime/base/base-assistant-runtime-core.ts +20 -0
  506. package/src/runtime/base/base-composer-runtime-core.ts +418 -0
  507. package/src/runtime/base/base-thread-runtime-core.ts +234 -0
  508. package/src/runtime/base/default-edit-composer-runtime-core.ts +71 -0
  509. package/src/runtime/base/default-thread-composer-runtime-core.ts +65 -0
  510. package/src/runtime/index.ts +108 -0
  511. package/src/runtime/interfaces/assistant-runtime-core.ts +12 -0
  512. package/src/runtime/interfaces/composer-runtime-core.ts +64 -0
  513. package/src/runtime/interfaces/thread-list-runtime-core.ts +49 -0
  514. package/src/runtime/interfaces/thread-runtime-core.ts +142 -0
  515. package/src/runtime/internal.ts +64 -0
  516. package/src/runtime/utils/auto-status.ts +67 -0
  517. package/src/runtime/utils/chat-model-adapter.ts +66 -0
  518. package/src/runtime/utils/external-store-message.ts +37 -0
  519. package/src/runtime/utils/message-repository.ts +390 -0
  520. package/src/runtime/utils/thread-message-like.ts +225 -0
  521. package/src/runtimes/assistant-transport/utils.ts +37 -0
  522. package/src/runtimes/external-store/external-store-adapter.ts +111 -0
  523. package/src/runtimes/external-store/external-store-runtime-core.ts +26 -0
  524. package/src/runtimes/external-store/external-store-thread-list-runtime-core.ts +235 -0
  525. package/src/runtimes/external-store/external-store-thread-runtime-core.ts +368 -0
  526. package/src/runtimes/external-store/index.ts +15 -0
  527. package/src/runtimes/external-store/thread-message-converter.ts +23 -0
  528. package/src/runtimes/index.ts +28 -0
  529. package/src/runtimes/internal.ts +36 -0
  530. package/src/runtimes/local/index.ts +6 -0
  531. package/src/runtimes/local/local-runtime-core.ts +32 -0
  532. package/src/runtimes/local/local-runtime-options.ts +27 -0
  533. package/src/runtimes/local/local-thread-list-runtime-core.ts +116 -0
  534. package/src/runtimes/local/local-thread-runtime-core.ts +534 -0
  535. package/src/runtimes/local/should-continue.ts +26 -0
  536. package/src/runtimes/remote-thread-list/adapter/in-memory.ts +43 -0
  537. package/src/runtimes/remote-thread-list/empty-thread-core.ts +200 -0
  538. package/src/runtimes/remote-thread-list/optimistic-state.ts +89 -0
  539. package/src/runtimes/remote-thread-list/remote-thread-state.ts +123 -0
  540. package/src/runtimes/remote-thread-list/types.ts +48 -0
  541. package/src/store/clients/chain-of-thought-client.ts +40 -0
  542. package/src/store/clients/index.ts +8 -0
  543. package/src/store/clients/model-context-client.ts +20 -0
  544. package/src/store/clients/no-op-composer-client.ts +66 -0
  545. package/src/store/clients/suggestions.ts +69 -0
  546. package/src/store/clients/thread-message-client.ts +170 -0
  547. package/src/store/index.ts +44 -0
  548. package/src/store/internal.ts +32 -0
  549. package/src/store/runtime-clients/attachment-runtime-client.ts +16 -0
  550. package/src/store/runtime-clients/composer-runtime-client.ts +131 -0
  551. package/src/store/runtime-clients/index.ts +7 -0
  552. package/src/store/runtime-clients/message-part-runtime-client.ts +17 -0
  553. package/src/store/runtime-clients/message-runtime-client.ts +141 -0
  554. package/src/store/runtime-clients/tap-subscribable.ts +16 -0
  555. package/src/store/runtime-clients/thread-list-item-runtime-client.ts +53 -0
  556. package/src/store/runtime-clients/thread-list-runtime-client.ts +86 -0
  557. package/src/store/runtime-clients/thread-runtime-client.ts +141 -0
  558. package/src/store/scopes/attachment.ts +20 -0
  559. package/src/store/scopes/chain-of-thought.ts +38 -0
  560. package/src/store/scopes/composer.ts +80 -0
  561. package/src/store/scopes/index.ts +68 -0
  562. package/src/store/scopes/message.ts +75 -0
  563. package/src/store/scopes/model-context.ts +13 -0
  564. package/src/store/scopes/part.ts +47 -0
  565. package/src/store/scopes/suggestion.ts +19 -0
  566. package/src/store/scopes/suggestions.ts +20 -0
  567. package/src/store/scopes/thread-list-item.ts +44 -0
  568. package/src/store/scopes/thread.ts +135 -0
  569. package/src/store/scopes/threads.ts +34 -0
  570. package/src/store/types/client.ts +203 -0
  571. package/src/store/types/events.ts +77 -0
  572. package/src/store/types/index.ts +23 -0
  573. package/src/store/utils/attach-transform-scopes.ts +38 -0
  574. package/src/store/utils/base-proxy-handler.ts +50 -0
  575. package/src/store/utils/derived.ts +46 -0
  576. package/src/store/utils/index.ts +28 -0
  577. package/src/store/utils/notification-manager.ts +114 -0
  578. package/src/store/utils/proxied-assistant-state.ts +55 -0
  579. package/src/store/utils/split-clients.ts +82 -0
  580. package/src/store/utils/tap-assistant-context.ts +58 -0
  581. package/src/store/utils/tap-client-list.ts +121 -0
  582. package/src/store/utils/tap-client-lookup.ts +79 -0
  583. package/src/store/utils/tap-client-resource.ts +187 -0
  584. package/src/store/utils/tap-client-stack-context.ts +51 -0
  585. package/src/store/utils/wrapper-resource.ts +17 -0
  586. package/src/subscribable/index.ts +21 -0
  587. package/src/subscribable/subscribable.ts +317 -0
  588. package/src/tests/BaseSubscribable.test.ts +54 -0
  589. package/src/tests/MessageRepository.test.ts +607 -0
  590. package/src/tests/OptimisticState-delete-crash.test.ts +206 -0
  591. package/src/types/attachment.ts +45 -0
  592. package/src/types/index.ts +39 -0
  593. package/src/types/message.ts +248 -0
  594. package/src/types/quote.ts +4 -0
  595. package/src/types/unsubscribe.ts +1 -0
  596. package/src/utils/composite-context-provider.ts +36 -0
  597. package/src/utils/id.ts +14 -0
  598. package/src/utils/index.ts +14 -0
  599. package/src/utils/text.ts +11 -0
@@ -0,0 +1,607 @@
1
+ import { describe, it, expect, beforeEach, vi, afterEach } from "vitest";
2
+ import {
3
+ MessageRepository,
4
+ ExportedMessageRepository,
5
+ } from "../runtime/utils/message-repository";
6
+ import type { ThreadMessage, TextMessagePart } from "../types";
7
+ import type { ThreadMessageLike } from "../runtime/utils/thread-message-like";
8
+
9
+ // Mock generateId and generateOptimisticId to make tests deterministic
10
+ const mockGenerateId = vi.fn();
11
+ const mockGenerateOptimisticId = vi.fn();
12
+ const mockIsOptimisticId = vi.fn((id: string) =>
13
+ id.startsWith("__optimistic__"),
14
+ );
15
+
16
+ vi.mock("../utils/id", async (importOriginal) => {
17
+ const original = await importOriginal<typeof import("../utils/id")>();
18
+ return {
19
+ ...original,
20
+ generateId: () => mockGenerateId(),
21
+ generateOptimisticId: () => mockGenerateOptimisticId(),
22
+ isOptimisticId: (id: string) => mockIsOptimisticId(id),
23
+ };
24
+ });
25
+
26
+ /**
27
+ * Tests for the MessageRepository class, which manages message threads with branching capabilities.
28
+ *
29
+ * This suite verifies that the repository:
30
+ * - Correctly manages message additions, updates, and deletions
31
+ * - Properly maintains parent-child relationships between messages
32
+ * - Handles branch creation and switching between branches
33
+ * - Successfully imports and exports repository state
34
+ * - Correctly manages optimistic messages in the thread
35
+ * - Handles edge cases and error conditions gracefully
36
+ */
37
+ describe("MessageRepository", () => {
38
+ let repository: MessageRepository;
39
+ let nextMockId = 1;
40
+
41
+ /**
42
+ * Creates a test ThreadMessage with the given overrides.
43
+ */
44
+ const createTestMessage = (overrides = {}): ThreadMessage => ({
45
+ id: "test-id",
46
+ role: "assistant",
47
+ createdAt: new Date(),
48
+ content: [{ type: "text", text: "Test message" }],
49
+ status: { type: "complete", reason: "stop" },
50
+ metadata: {
51
+ unstable_state: null,
52
+ unstable_annotations: [],
53
+ unstable_data: [],
54
+ steps: [],
55
+ custom: {},
56
+ },
57
+ ...overrides,
58
+ });
59
+
60
+ /**
61
+ * Creates a test CoreMessage with the given overrides.
62
+ */
63
+ const createThreadMessageLike = (overrides = {}): ThreadMessageLike => ({
64
+ role: "assistant",
65
+ content: [{ type: "text", text: "Test message" }],
66
+ ...overrides,
67
+ });
68
+
69
+ beforeEach(() => {
70
+ repository = new MessageRepository();
71
+ // Reset mocks with predictable counter-based values
72
+ nextMockId = 1;
73
+ mockGenerateId.mockImplementation(() => `mock-id-${nextMockId++}`);
74
+ mockGenerateOptimisticId.mockImplementation(
75
+ () => `__optimistic__mock-id-${nextMockId++}`,
76
+ );
77
+ });
78
+
79
+ afterEach(() => {
80
+ vi.clearAllMocks();
81
+ });
82
+
83
+ // Core functionality tests - these test the public contract
84
+ describe("Basic CRUD operations", () => {
85
+ it("should add a new message to the repository", () => {
86
+ const message = createTestMessage({ id: "message-id" });
87
+ repository.addOrUpdateMessage(null, message);
88
+
89
+ const messages = repository.getMessages();
90
+ expect(messages).toContain(message);
91
+ });
92
+
93
+ it("should update an existing message", () => {
94
+ const message = createTestMessage({ id: "message-id" });
95
+ repository.addOrUpdateMessage(null, message);
96
+
97
+ const updatedContent = [
98
+ { type: "text", text: "Updated message" },
99
+ ] as const;
100
+ const updatedMessage = createTestMessage({
101
+ id: "message-id",
102
+ content: updatedContent,
103
+ });
104
+
105
+ repository.addOrUpdateMessage(null, updatedMessage);
106
+
107
+ const retrievedMessage = repository.getMessage("message-id").message;
108
+ expect(retrievedMessage.content).toEqual(updatedContent);
109
+ });
110
+
111
+ it("should establish parent-child relationships between messages", () => {
112
+ const parent = createTestMessage({ id: "parent-id" });
113
+ const child = createTestMessage({ id: "child-id" });
114
+
115
+ repository.addOrUpdateMessage(null, parent);
116
+ repository.addOrUpdateMessage("parent-id", child);
117
+
118
+ const childWithParent = repository.getMessage("child-id");
119
+ expect(childWithParent.parentId).toBe("parent-id");
120
+ });
121
+
122
+ it("should throw an error when parent message is not found", () => {
123
+ const message = createTestMessage();
124
+
125
+ expect(() => {
126
+ repository.addOrUpdateMessage("non-existent-id", message);
127
+ }).toThrow(/Parent message not found/);
128
+ });
129
+
130
+ it("should retrieve all messages in the current branch", () => {
131
+ const parent = createTestMessage({ id: "parent-id" });
132
+ const child = createTestMessage({ id: "child-id" });
133
+ const grandchild = createTestMessage({ id: "grandchild-id" });
134
+
135
+ repository.addOrUpdateMessage(null, parent);
136
+ repository.addOrUpdateMessage("parent-id", child);
137
+ repository.addOrUpdateMessage("child-id", grandchild);
138
+
139
+ const messages = repository.getMessages();
140
+
141
+ expect(messages.map((m) => m.id)).toEqual([
142
+ "parent-id",
143
+ "child-id",
144
+ "grandchild-id",
145
+ ]);
146
+ });
147
+
148
+ it("should track the head message", () => {
149
+ const parent = createTestMessage({ id: "parent-id" });
150
+ const child = createTestMessage({ id: "child-id" });
151
+
152
+ repository.addOrUpdateMessage(null, parent);
153
+ expect(repository.headId).toBe("parent-id");
154
+
155
+ repository.addOrUpdateMessage("parent-id", child);
156
+ expect(repository.headId).toBe("child-id");
157
+ });
158
+
159
+ it("should delete a message and adjust the head", () => {
160
+ const parent = createTestMessage({ id: "parent-id" });
161
+ const child = createTestMessage({ id: "child-id" });
162
+
163
+ repository.addOrUpdateMessage(null, parent);
164
+ repository.addOrUpdateMessage("parent-id", child);
165
+
166
+ expect(repository.headId).toBe("child-id");
167
+
168
+ repository.deleteMessage("child-id");
169
+
170
+ expect(repository.headId).toBe("parent-id");
171
+
172
+ const messages = repository.getMessages();
173
+ expect(messages.map((m) => m.id)).toEqual(["parent-id"]);
174
+ });
175
+
176
+ it("should clear all messages", () => {
177
+ const message = createTestMessage();
178
+ repository.addOrUpdateMessage(null, message);
179
+
180
+ repository.clear();
181
+
182
+ expect(repository.getMessages()).toHaveLength(0);
183
+ expect(repository.headId).toBeNull();
184
+ });
185
+ });
186
+
187
+ describe("Branch management", () => {
188
+ it("should create multiple branches from a parent message", () => {
189
+ const parent = createTestMessage({ id: "parent-id" });
190
+ const branch1 = createTestMessage({ id: "branch1-id" });
191
+ const branch2 = createTestMessage({ id: "branch2-id" });
192
+
193
+ repository.addOrUpdateMessage(null, parent);
194
+ repository.addOrUpdateMessage("parent-id", branch1);
195
+ repository.addOrUpdateMessage("parent-id", branch2);
196
+
197
+ repository.switchToBranch("branch1-id");
198
+ expect(repository.headId).toBe("branch1-id");
199
+
200
+ repository.switchToBranch("branch2-id");
201
+ expect(repository.headId).toBe("branch2-id");
202
+
203
+ const branches = repository.getBranches("branch1-id");
204
+ expect(branches).toContain("branch1-id");
205
+ expect(branches).toContain("branch2-id");
206
+ });
207
+
208
+ it("should switch between branches and maintain branch state", () => {
209
+ const parent = createTestMessage({ id: "parent-id" });
210
+ const branch1 = createTestMessage({ id: "branch1-id" });
211
+ const branch2 = createTestMessage({ id: "branch2-id" });
212
+
213
+ repository.addOrUpdateMessage(null, parent);
214
+ repository.addOrUpdateMessage("parent-id", branch1);
215
+ repository.addOrUpdateMessage("parent-id", branch2);
216
+
217
+ repository.switchToBranch("branch1-id");
218
+ expect(repository.headId).toBe("branch1-id");
219
+
220
+ const messages1 = repository.getMessages();
221
+ expect(messages1.map((m) => m.id)).toEqual(["parent-id", "branch1-id"]);
222
+
223
+ repository.switchToBranch("branch2-id");
224
+ expect(repository.headId).toBe("branch2-id");
225
+
226
+ const messages2 = repository.getMessages();
227
+ expect(messages2.map((m) => m.id)).toEqual(["parent-id", "branch2-id"]);
228
+ });
229
+
230
+ it("should throw error when switching to a non-existent branch", () => {
231
+ expect(() => {
232
+ repository.switchToBranch("non-existent-id");
233
+ }).toThrow(/Branch not found/);
234
+ });
235
+
236
+ it("should reset head to an earlier message in the tree", () => {
237
+ const parent = createTestMessage({ id: "parent-id" });
238
+ const child = createTestMessage({ id: "child-id" });
239
+ const grandchild = createTestMessage({ id: "grandchild-id" });
240
+
241
+ repository.addOrUpdateMessage(null, parent);
242
+ repository.addOrUpdateMessage("parent-id", child);
243
+ repository.addOrUpdateMessage("child-id", grandchild);
244
+
245
+ repository.resetHead("parent-id");
246
+
247
+ expect(repository.headId).toBe("parent-id");
248
+
249
+ const messages = repository.getMessages();
250
+ expect(messages.map((m) => m.id)).toEqual(["parent-id"]);
251
+ });
252
+
253
+ it("should remove children when resetting head to a message with children", () => {
254
+ const parent = createTestMessage({ id: "parent-id" });
255
+ const child = createTestMessage({ id: "child-id" });
256
+ const grandchild1 = createTestMessage({ id: "grandchild1-id" });
257
+ const grandchild2 = createTestMessage({ id: "grandchild2-id" });
258
+ const greatGrandchild = createTestMessage({ id: "greatgrandchild-id" });
259
+
260
+ repository.addOrUpdateMessage(null, parent);
261
+ repository.addOrUpdateMessage("parent-id", child);
262
+ repository.addOrUpdateMessage("child-id", grandchild1);
263
+ repository.addOrUpdateMessage("child-id", grandchild2);
264
+ repository.addOrUpdateMessage("grandchild2-id", greatGrandchild);
265
+
266
+ repository.resetHead("child-id");
267
+
268
+ expect(repository.headId).toBe("child-id");
269
+
270
+ const messages = repository.getMessages();
271
+ expect(messages.map((m) => m.id)).toEqual(["parent-id", "child-id"]);
272
+
273
+ expect(() => repository.getMessage("grandchild1-id")).toThrow(
274
+ /Message not found/,
275
+ );
276
+ expect(() => repository.getMessage("grandchild2-id")).toThrow(
277
+ /Message not found/,
278
+ );
279
+ expect(() => repository.getMessage("greatgrandchild-id")).toThrow(
280
+ /Message not found/,
281
+ );
282
+
283
+ const branches = repository.getBranches("child-id");
284
+ expect(branches).toEqual(["child-id"]);
285
+ });
286
+
287
+ it("should reset head to null when null is passed", () => {
288
+ const message = createTestMessage();
289
+ repository.addOrUpdateMessage(null, message);
290
+
291
+ repository.resetHead(null);
292
+
293
+ expect(repository.headId).toBeNull();
294
+ expect(repository.getMessages()).toHaveLength(0);
295
+ });
296
+ });
297
+
298
+ describe("Optimistic messages", () => {
299
+ it("should create an optimistic message with a unique ID", () => {
300
+ mockGenerateOptimisticId.mockReturnValue("__optimistic__generated-id");
301
+
302
+ const coreMessage = createThreadMessageLike();
303
+ const optimisticId = repository.appendOptimisticMessage(
304
+ null,
305
+ coreMessage,
306
+ );
307
+
308
+ expect(optimisticId).toBe("__optimistic__generated-id");
309
+ expect(repository.getMessage(optimisticId).message.status?.type).toBe(
310
+ "running",
311
+ );
312
+ });
313
+
314
+ it("should create an optimistic message as a child of a specified parent", () => {
315
+ const parent = createTestMessage({ id: "parent-id" });
316
+ repository.addOrUpdateMessage(null, parent);
317
+
318
+ const coreMessage = createThreadMessageLike();
319
+ const optimisticId = repository.appendOptimisticMessage(
320
+ "parent-id",
321
+ coreMessage,
322
+ );
323
+
324
+ const result = repository.getMessage(optimisticId);
325
+ expect(result.parentId).toBe("parent-id");
326
+ });
327
+
328
+ it("should retry generating unique optimistic IDs if initial one exists", () => {
329
+ mockGenerateOptimisticId.mockReturnValueOnce("__optimistic__existing-id");
330
+
331
+ const existingMessage = createTestMessage({
332
+ id: "__optimistic__existing-id",
333
+ });
334
+ repository.addOrUpdateMessage(null, existingMessage);
335
+
336
+ mockGenerateOptimisticId.mockReturnValueOnce("__optimistic__unique-id");
337
+
338
+ const coreMessage = createThreadMessageLike();
339
+ const optimisticId = repository.appendOptimisticMessage(
340
+ null,
341
+ coreMessage,
342
+ );
343
+
344
+ expect(optimisticId).toBe("__optimistic__unique-id");
345
+ expect(mockGenerateOptimisticId).toHaveBeenCalledTimes(2);
346
+ });
347
+ });
348
+
349
+ describe("Export and import", () => {
350
+ it("should export the repository state", () => {
351
+ const parent = createTestMessage({ id: "parent-id" });
352
+ const child = createTestMessage({ id: "child-id" });
353
+
354
+ repository.addOrUpdateMessage(null, parent);
355
+ repository.addOrUpdateMessage("parent-id", child);
356
+
357
+ const exported = repository.export();
358
+
359
+ expect(exported.headId).toBe("child-id");
360
+ expect(exported.messages).toHaveLength(2);
361
+ expect(
362
+ exported.messages.find((m) => m.message.id === "parent-id")?.parentId,
363
+ ).toBeNull();
364
+ expect(
365
+ exported.messages.find((m) => m.message.id === "child-id")?.parentId,
366
+ ).toBe("parent-id");
367
+ });
368
+
369
+ it("should import repository state", () => {
370
+ const parent = createTestMessage({ id: "parent-id" });
371
+ const child = createTestMessage({ id: "child-id" });
372
+
373
+ const exported = {
374
+ headId: "child-id",
375
+ messages: [
376
+ { message: parent, parentId: null },
377
+ { message: child, parentId: "parent-id" },
378
+ ],
379
+ };
380
+
381
+ repository.import(exported);
382
+
383
+ expect(repository.headId).toBe("child-id");
384
+ const messages = repository.getMessages();
385
+ expect(messages.map((m) => m.id)).toEqual(["parent-id", "child-id"]);
386
+ });
387
+
388
+ it("should import with a specified head that is not the most recent message", () => {
389
+ const parent = createTestMessage({ id: "parent-id" });
390
+ const child1 = createTestMessage({ id: "child1-id" });
391
+ const child2 = createTestMessage({ id: "child2-id" });
392
+
393
+ const exported = {
394
+ headId: "child1-id",
395
+ messages: [
396
+ { message: parent, parentId: null },
397
+ { message: child1, parentId: "parent-id" },
398
+ { message: child2, parentId: "parent-id" },
399
+ ],
400
+ };
401
+
402
+ repository.import(exported);
403
+
404
+ expect(repository.headId).toBe("child1-id");
405
+
406
+ const messages = repository.getMessages();
407
+ expect(messages.map((m) => m.id)).toEqual(["parent-id", "child1-id"]);
408
+
409
+ repository.switchToBranch("child2-id");
410
+ expect(repository.headId).toBe("child2-id");
411
+ });
412
+
413
+ it("should throw an error when importing with invalid parent references", () => {
414
+ const child = createTestMessage({ id: "child-id" });
415
+
416
+ const exported = {
417
+ headId: "child-id",
418
+ messages: [{ message: child, parentId: "non-existent-id" }],
419
+ };
420
+
421
+ expect(() => {
422
+ repository.import(exported);
423
+ }).toThrow(/Parent message not found/);
424
+ });
425
+ });
426
+
427
+ describe("ExportedMessageRepository utility", () => {
428
+ it("should convert an array of messages to repository format", () => {
429
+ mockGenerateId.mockReturnValue("generated-id");
430
+
431
+ const messages: ThreadMessageLike[] = [
432
+ {
433
+ role: "user" as const,
434
+ content: [
435
+ { type: "text" as const, text: "Hello" },
436
+ ] as TextMessagePart[],
437
+ },
438
+ {
439
+ role: "assistant" as const,
440
+ content: [
441
+ { type: "text" as const, text: "Hi there" },
442
+ ] as TextMessagePart[],
443
+ },
444
+ ];
445
+
446
+ const result = ExportedMessageRepository.fromArray(messages);
447
+
448
+ expect(result.messages).toHaveLength(2);
449
+ expect(result.messages[0]!.parentId).toBeNull();
450
+ expect(result.messages[1]!.parentId).toBe("generated-id");
451
+ });
452
+
453
+ it("should handle empty message arrays", () => {
454
+ const result = ExportedMessageRepository.fromArray([]);
455
+ expect(result.messages).toHaveLength(0);
456
+ });
457
+ });
458
+
459
+ describe("Complex scenarios", () => {
460
+ it("should maintain tree structure after deletions", () => {
461
+ const root = createTestMessage({ id: "root-id" });
462
+ const nodeA = createTestMessage({ id: "A-id" });
463
+ const nodeB = createTestMessage({ id: "B-id" });
464
+ const nodeC = createTestMessage({ id: "C-id" });
465
+
466
+ repository.addOrUpdateMessage(null, root);
467
+ repository.addOrUpdateMessage("root-id", nodeA);
468
+ repository.addOrUpdateMessage("A-id", nodeB);
469
+ repository.addOrUpdateMessage("A-id", nodeC);
470
+
471
+ repository.deleteMessage("B-id");
472
+
473
+ repository.switchToBranch("C-id");
474
+ expect(repository.headId).toBe("C-id");
475
+
476
+ const messages = repository.getMessages();
477
+ expect(messages.map((m) => m.id)).toEqual(["root-id", "A-id", "C-id"]);
478
+ });
479
+
480
+ it("should relink children when deleting a middle node", () => {
481
+ const root = createTestMessage({ id: "root-id" });
482
+ const nodeA = createTestMessage({ id: "A-id" });
483
+ const nodeB = createTestMessage({ id: "B-id" });
484
+ const nodeC = createTestMessage({ id: "C-id" });
485
+
486
+ repository.addOrUpdateMessage(null, root);
487
+ repository.addOrUpdateMessage("root-id", nodeA);
488
+ repository.addOrUpdateMessage("A-id", nodeB);
489
+ repository.addOrUpdateMessage("B-id", nodeC);
490
+
491
+ repository.deleteMessage("B-id", "A-id");
492
+
493
+ const c = repository.getMessage("C-id");
494
+ expect(c.parentId).toBe("A-id");
495
+
496
+ repository.switchToBranch("C-id");
497
+ const messages = repository.getMessages();
498
+
499
+ expect(messages.some((m) => m.id === "root-id")).toBe(true);
500
+ expect(messages.some((m) => m.id === "A-id")).toBe(true);
501
+ expect(messages.some((m) => m.id === "C-id")).toBe(true);
502
+ expect(messages.some((m) => m.id === "B-id")).toBe(false);
503
+ });
504
+
505
+ it("should relink multiple children when deleting a parent node", () => {
506
+ const root = createTestMessage({ id: "root-id" });
507
+ const nodeA = createTestMessage({ id: "A-id" });
508
+ const nodeB = createTestMessage({ id: "B-id" });
509
+ const nodeC = createTestMessage({ id: "C-id" });
510
+ const nodeD = createTestMessage({ id: "D-id" });
511
+
512
+ repository.addOrUpdateMessage(null, root);
513
+ repository.addOrUpdateMessage("root-id", nodeA);
514
+ repository.addOrUpdateMessage("A-id", nodeB);
515
+ repository.addOrUpdateMessage("A-id", nodeC);
516
+ repository.addOrUpdateMessage("A-id", nodeD);
517
+
518
+ repository.deleteMessage("A-id", "root-id");
519
+
520
+ expect(repository.getMessage("B-id").parentId).toBe("root-id");
521
+ expect(repository.getMessage("C-id").parentId).toBe("root-id");
522
+ expect(repository.getMessage("D-id").parentId).toBe("root-id");
523
+
524
+ repository.switchToBranch("B-id");
525
+ const bMessages = repository.getMessages();
526
+ expect(bMessages.some((m) => m.id === "root-id")).toBe(true);
527
+ expect(bMessages.some((m) => m.id === "B-id")).toBe(true);
528
+ expect(bMessages.some((m) => m.id === "A-id")).toBe(false);
529
+
530
+ repository.switchToBranch("C-id");
531
+ const cMessages = repository.getMessages();
532
+ expect(cMessages.some((m) => m.id === "root-id")).toBe(true);
533
+ expect(cMessages.some((m) => m.id === "C-id")).toBe(true);
534
+ expect(cMessages.some((m) => m.id === "A-id")).toBe(false);
535
+
536
+ repository.switchToBranch("D-id");
537
+ const dMessages = repository.getMessages();
538
+ expect(dMessages.some((m) => m.id === "root-id")).toBe(true);
539
+ expect(dMessages.some((m) => m.id === "D-id")).toBe(true);
540
+ expect(dMessages.some((m) => m.id === "A-id")).toBe(false);
541
+ });
542
+
543
+ it("should preserve message position when updating content", () => {
544
+ const parent = createTestMessage({ id: "parent-id" });
545
+ const child1 = createTestMessage({ id: "child1-id" });
546
+ const child2 = createTestMessage({ id: "child2-id" });
547
+
548
+ repository.addOrUpdateMessage(null, parent);
549
+ repository.addOrUpdateMessage("parent-id", child1);
550
+ repository.addOrUpdateMessage("child1-id", child2);
551
+
552
+ const updatedChild1 = createTestMessage({
553
+ id: "child1-id",
554
+ content: [{ type: "text", text: "Updated content" }],
555
+ });
556
+
557
+ repository.addOrUpdateMessage("parent-id", updatedChild1);
558
+
559
+ const messages = repository.getMessages();
560
+ expect(messages.map((m) => m.id)).toEqual([
561
+ "parent-id",
562
+ "child1-id",
563
+ "child2-id",
564
+ ]);
565
+
566
+ const MessagePart = messages[1]!.content[0];
567
+ expect(MessagePart.type).toBe("text");
568
+ expect((MessagePart as TextMessagePart).text).toBe("Updated content");
569
+ });
570
+
571
+ it("should handle re-parenting when messages are inserted at the start", () => {
572
+ const messageA = createTestMessage({ id: "A" });
573
+ const messageB = createTestMessage({ id: "B" });
574
+ const messageC = createTestMessage({ id: "C" });
575
+
576
+ repository.addOrUpdateMessage(null, messageA);
577
+ repository.addOrUpdateMessage("A", messageB);
578
+ repository.addOrUpdateMessage("B", messageC);
579
+
580
+ expect(repository.getMessages().map((m) => m.id)).toEqual([
581
+ "A",
582
+ "B",
583
+ "C",
584
+ ]);
585
+ expect(repository.headId).toBe("C");
586
+
587
+ const messageX = createTestMessage({ id: "X" });
588
+ const messageY = createTestMessage({ id: "Y" });
589
+
590
+ repository.addOrUpdateMessage(null, messageX);
591
+ repository.addOrUpdateMessage("X", messageY);
592
+
593
+ repository.addOrUpdateMessage("Y", messageA);
594
+
595
+ const messages = repository.getMessages();
596
+ expect(messages.map((m) => m.id)).toEqual(["X", "Y", "A", "B", "C"]);
597
+
598
+ expect(repository.getMessage("X").parentId).toBeNull();
599
+ expect(repository.getMessage("Y").parentId).toBe("X");
600
+ expect(repository.getMessage("A").parentId).toBe("Y");
601
+ expect(repository.getMessage("B").parentId).toBe("A");
602
+ expect(repository.getMessage("C").parentId).toBe("B");
603
+
604
+ expect(repository.headId).toBe("C");
605
+ });
606
+ });
607
+ });