@onlive.ai/common-121 0.2.70 → 0.2.179

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 (366) hide show
  1. package/README.md +0 -1
  2. package/chunk-CHMR2I4G.js +2 -0
  3. package/components/asset/asset-modal-portal.cjs +550 -0
  4. package/components/asset/asset-modal-portal.d.cts +22 -0
  5. package/components/asset/asset-modal-portal.d.ts +22 -0
  6. package/components/asset/asset-modal-portal.js +550 -0
  7. package/components/asset/asset.cjs +3536 -0
  8. package/components/asset/asset.d.cts +37 -0
  9. package/components/asset/asset.d.ts +37 -0
  10. package/components/asset/asset.js +3536 -0
  11. package/components/asset/asset.loaders.cjs +2 -0
  12. package/components/asset/asset.loaders.d.cts +17 -0
  13. package/components/asset/asset.loaders.d.ts +17 -0
  14. package/components/asset/asset.loaders.js +2 -0
  15. package/components/asset/asset.renderer.cjs +2292 -0
  16. package/components/asset/asset.renderer.d.cts +29 -0
  17. package/components/asset/asset.renderer.d.ts +29 -0
  18. package/components/asset/asset.renderer.js +2292 -0
  19. package/components/asset/asset.styles.cjs +683 -0
  20. package/components/asset/asset.styles.d.cts +6 -0
  21. package/components/asset/asset.styles.d.ts +6 -0
  22. package/components/asset/asset.styles.js +683 -0
  23. package/components/asset/asset.types.cjs +2 -0
  24. package/components/asset/asset.types.d.cts +103 -0
  25. package/components/asset/asset.types.d.ts +103 -0
  26. package/components/asset/asset.types.js +1 -0
  27. package/components/asset/index.cjs +3536 -0
  28. package/components/asset/index.d.cts +8 -0
  29. package/components/asset/index.d.ts +8 -0
  30. package/components/asset/index.js +3536 -0
  31. package/components/player/player.cjs +2044 -0
  32. package/components/player/player.d.cts +25 -0
  33. package/components/player/player.d.ts +25 -0
  34. package/components/player/player.js +2044 -0
  35. package/components/player/player.styles.cjs +16 -0
  36. package/components/player/player.styles.d.cts +6 -0
  37. package/components/player/player.styles.d.ts +6 -0
  38. package/components/player/player.styles.js +16 -0
  39. package/components/side-bar/index.cjs +3185 -0
  40. package/components/side-bar/index.d.cts +11 -0
  41. package/components/side-bar/index.d.ts +11 -0
  42. package/components/side-bar/index.js +3185 -0
  43. package/components/side-bar/side-bar.cjs +3185 -0
  44. package/components/side-bar/side-bar.d.cts +83 -0
  45. package/components/side-bar/side-bar.d.ts +83 -0
  46. package/components/side-bar/side-bar.js +3185 -0
  47. package/components/side-bar/side-bar.styles.cjs +801 -0
  48. package/components/side-bar/side-bar.styles.d.cts +6 -0
  49. package/components/side-bar/side-bar.styles.d.ts +6 -0
  50. package/components/side-bar/side-bar.styles.js +801 -0
  51. package/components/side-bar/side-bar.types.cjs +2 -0
  52. package/components/side-bar/side-bar.types.d.cts +105 -0
  53. package/components/side-bar/side-bar.types.d.ts +105 -0
  54. package/components/side-bar/side-bar.types.js +2 -0
  55. package/components/upload/index.cjs +83 -0
  56. package/components/upload/index.d.cts +4 -0
  57. package/components/upload/index.d.ts +4 -0
  58. package/components/upload/index.js +83 -0
  59. package/components/upload/upload.cjs +83 -0
  60. package/components/upload/upload.d.cts +28 -0
  61. package/components/upload/upload.d.ts +28 -0
  62. package/components/upload/upload.js +83 -0
  63. package/components/upload/upload.styles.cjs +65 -0
  64. package/components/upload/upload.styles.d.cts +6 -0
  65. package/components/upload/upload.styles.d.ts +6 -0
  66. package/components/upload/upload.styles.js +65 -0
  67. package/components/upload/upload.types.cjs +2 -0
  68. package/components/upload/upload.types.d.cts +16 -0
  69. package/components/upload/upload.types.d.ts +16 -0
  70. package/components/upload/upload.types.js +1 -0
  71. package/index.cjs +4677 -0
  72. package/index.d.cts +4397 -0
  73. package/index.d.ts +4397 -0
  74. package/index.js +4677 -0
  75. package/media-TFGJGBU2.js +2 -0
  76. package/package.json +35 -11
  77. package/react/components/asset/Asset.cjs +2 -0
  78. package/react/components/asset/Asset.jsx +2 -0
  79. package/react/components/side-bar/SideBar.cjs +2 -0
  80. package/react/components/side-bar/SideBar.jsx +2 -0
  81. package/react/components/upload/Upload.cjs +2 -0
  82. package/react/components/upload/Upload.jsx +2 -0
  83. package/services/audio.service.cjs +2 -2
  84. package/services/audio.service.d.cts +1 -0
  85. package/services/audio.service.d.ts +1 -0
  86. package/services/audio.service.js +2 -2
  87. package/services/conversation/conversation.service.cjs +2 -0
  88. package/services/conversation/conversation.service.d.cts +543 -0
  89. package/services/conversation/conversation.service.d.ts +543 -0
  90. package/services/conversation/conversation.service.js +2 -0
  91. package/services/conversation/conversation.types.cjs +2 -0
  92. package/services/conversation/conversation.types.d.cts +525 -0
  93. package/services/conversation/conversation.types.d.ts +525 -0
  94. package/services/conversation/conversation.types.js +2 -0
  95. package/services/conversation/index.cjs +2 -0
  96. package/services/conversation/index.d.cts +24 -0
  97. package/services/conversation/index.d.ts +24 -0
  98. package/services/conversation/index.js +2 -0
  99. package/services/conversation/mock/actor/agent.cjs +2 -0
  100. package/services/conversation/mock/actor/agent.d.cts +202 -0
  101. package/services/conversation/mock/actor/agent.d.ts +202 -0
  102. package/services/conversation/mock/actor/agent.js +2 -0
  103. package/services/conversation/mock/actor/index.cjs +2 -0
  104. package/services/conversation/mock/actor/index.d.cts +4 -0
  105. package/services/conversation/mock/actor/index.d.ts +4 -0
  106. package/services/conversation/mock/actor/index.js +2 -0
  107. package/services/conversation/mock/actor/strategies.cjs +2 -0
  108. package/services/conversation/mock/actor/strategies.d.cts +31 -0
  109. package/services/conversation/mock/actor/strategies.d.ts +31 -0
  110. package/services/conversation/mock/actor/strategies.js +2 -0
  111. package/services/conversation/mock/errors.cjs +2 -0
  112. package/services/conversation/mock/errors.d.cts +125 -0
  113. package/services/conversation/mock/errors.d.ts +125 -0
  114. package/services/conversation/mock/errors.js +2 -0
  115. package/services/conversation/mock/events.cjs +2 -0
  116. package/services/conversation/mock/events.d.cts +253 -0
  117. package/services/conversation/mock/events.d.ts +253 -0
  118. package/services/conversation/mock/events.js +2 -0
  119. package/services/conversation/mock/factory.cjs +2 -0
  120. package/services/conversation/mock/factory.d.cts +134 -0
  121. package/services/conversation/mock/factory.d.ts +134 -0
  122. package/services/conversation/mock/factory.js +2 -0
  123. package/services/conversation/mock/fixtures.cjs +2 -0
  124. package/services/conversation/mock/fixtures.d.cts +191 -0
  125. package/services/conversation/mock/fixtures.d.ts +191 -0
  126. package/services/conversation/mock/fixtures.js +2 -0
  127. package/services/conversation/mock/generators.cjs +2 -0
  128. package/services/conversation/mock/generators.d.cts +123 -0
  129. package/services/conversation/mock/generators.d.ts +123 -0
  130. package/services/conversation/mock/generators.js +2 -0
  131. package/services/conversation/mock/index.cjs +2 -0
  132. package/services/conversation/mock/index.d.cts +24 -0
  133. package/services/conversation/mock/index.d.ts +24 -0
  134. package/services/conversation/mock/index.js +2 -0
  135. package/services/conversation/mock/livekit/index.cjs +2 -0
  136. package/services/conversation/mock/livekit/index.d.cts +7 -0
  137. package/services/conversation/mock/livekit/index.d.ts +7 -0
  138. package/services/conversation/mock/livekit/index.js +2 -0
  139. package/services/conversation/mock/livekit/local-participant.cjs +2 -0
  140. package/services/conversation/mock/livekit/local-participant.d.cts +204 -0
  141. package/services/conversation/mock/livekit/local-participant.d.ts +204 -0
  142. package/services/conversation/mock/livekit/local-participant.js +2 -0
  143. package/services/conversation/mock/livekit/participant.cjs +2 -0
  144. package/services/conversation/mock/livekit/participant.d.cts +171 -0
  145. package/services/conversation/mock/livekit/participant.d.ts +171 -0
  146. package/services/conversation/mock/livekit/participant.js +2 -0
  147. package/services/conversation/mock/livekit/room.cjs +2 -0
  148. package/services/conversation/mock/livekit/room.d.cts +292 -0
  149. package/services/conversation/mock/livekit/room.d.ts +292 -0
  150. package/services/conversation/mock/livekit/room.js +2 -0
  151. package/services/conversation/mock/livekit/streams.cjs +2 -0
  152. package/services/conversation/mock/livekit/streams.d.cts +190 -0
  153. package/services/conversation/mock/livekit/streams.d.ts +190 -0
  154. package/services/conversation/mock/livekit/streams.js +2 -0
  155. package/services/conversation/mock/livekit/tracks.cjs +2 -0
  156. package/services/conversation/mock/livekit/tracks.d.cts +149 -0
  157. package/services/conversation/mock/livekit/tracks.d.ts +149 -0
  158. package/services/conversation/mock/livekit/tracks.js +2 -0
  159. package/services/conversation/mock/media.cjs +2 -0
  160. package/services/conversation/mock/media.d.cts +174 -0
  161. package/services/conversation/mock/media.d.ts +174 -0
  162. package/services/conversation/mock/media.js +2 -0
  163. package/services/conversation/mock/service.cjs +2 -0
  164. package/services/conversation/mock/service.d.cts +300 -0
  165. package/services/conversation/mock/service.d.ts +300 -0
  166. package/services/conversation/mock/service.js +2 -0
  167. package/services/conversation/mock/service.test.cjs +2 -0
  168. package/services/conversation/mock/service.test.d.cts +1 -0
  169. package/services/conversation/mock/service.test.d.ts +1 -0
  170. package/services/conversation/mock/service.test.js +2 -0
  171. package/services/conversation/mock/state.cjs +2 -0
  172. package/services/conversation/mock/state.d.cts +296 -0
  173. package/services/conversation/mock/state.d.ts +296 -0
  174. package/services/conversation/mock/state.js +2 -0
  175. package/services/conversation/mock/storybook.cjs +2 -0
  176. package/services/conversation/mock/storybook.d.cts +197 -0
  177. package/services/conversation/mock/storybook.d.ts +197 -0
  178. package/services/conversation/mock/storybook.js +2 -0
  179. package/services/conversation/mock/types.cjs +2 -0
  180. package/services/conversation/mock/types.d.cts +442 -0
  181. package/services/conversation/mock/types.d.ts +442 -0
  182. package/services/conversation/mock/types.js +1 -0
  183. package/services/faqs/faqs.service.cjs +2 -0
  184. package/services/faqs/faqs.service.d.cts +16 -0
  185. package/services/faqs/faqs.service.d.ts +16 -0
  186. package/services/faqs/faqs.service.js +2 -0
  187. package/services/faqs/faqs.types.cjs +2 -0
  188. package/services/faqs/faqs.types.d.cts +60 -0
  189. package/services/faqs/faqs.types.d.ts +60 -0
  190. package/services/faqs/faqs.types.js +1 -0
  191. package/services/faqs/index.cjs +2 -0
  192. package/services/faqs/index.d.cts +3 -0
  193. package/services/faqs/index.d.ts +3 -0
  194. package/services/faqs/index.js +2 -0
  195. package/services/file/file.service.cjs +2 -0
  196. package/services/file/file.service.d.cts +66 -0
  197. package/services/file/file.service.d.ts +66 -0
  198. package/services/file/file.service.js +2 -0
  199. package/services/file/file.types.cjs +2 -0
  200. package/services/file/file.types.d.cts +72 -0
  201. package/services/file/file.types.d.ts +72 -0
  202. package/services/file/file.types.js +1 -0
  203. package/services/file/index.cjs +2 -0
  204. package/services/file/index.d.cts +3 -0
  205. package/services/file/index.d.ts +3 -0
  206. package/services/file/index.js +2 -0
  207. package/services/firebase/firebase-api.cjs +2 -2
  208. package/services/firebase/firebase-api.d.cts +25 -9
  209. package/services/firebase/firebase-api.d.ts +25 -9
  210. package/services/firebase/firebase-api.js +2 -2
  211. package/services/multimedia/config.example.cjs +2 -0
  212. package/services/multimedia/config.example.d.cts +13 -0
  213. package/services/multimedia/config.example.d.ts +13 -0
  214. package/services/multimedia/config.example.js +2 -0
  215. package/services/multimedia/index.cjs +2 -0
  216. package/services/multimedia/index.d.cts +3 -0
  217. package/services/multimedia/index.d.ts +3 -0
  218. package/services/multimedia/index.js +2 -0
  219. package/services/multimedia/multimedia.service.cjs +2 -0
  220. package/services/multimedia/multimedia.service.d.cts +28 -0
  221. package/services/multimedia/multimedia.service.d.ts +28 -0
  222. package/services/multimedia/multimedia.service.js +2 -0
  223. package/services/multimedia/multimedia.types.cjs +2 -0
  224. package/services/multimedia/multimedia.types.d.cts +65 -0
  225. package/services/multimedia/multimedia.types.d.ts +65 -0
  226. package/services/multimedia/multimedia.types.js +1 -0
  227. package/services/product/index.cjs +2 -0
  228. package/services/product/index.d.cts +3 -0
  229. package/services/product/index.d.ts +3 -0
  230. package/services/product/index.js +2 -0
  231. package/services/product/product.service.cjs +2 -0
  232. package/services/product/product.service.d.cts +19 -0
  233. package/services/product/product.service.d.ts +19 -0
  234. package/services/product/product.service.js +2 -0
  235. package/services/product/product.types.cjs +2 -0
  236. package/services/product/product.types.d.cts +78 -0
  237. package/services/product/product.types.d.ts +78 -0
  238. package/services/product/product.types.js +1 -0
  239. package/services/request.provider.cjs +1 -1
  240. package/services/request.provider.d.cts +1 -0
  241. package/services/request.provider.d.ts +1 -0
  242. package/services/request.provider.js +1 -1
  243. package/services/session.service.cjs +2 -0
  244. package/services/session.service.d.cts +70 -0
  245. package/services/session.service.d.ts +70 -0
  246. package/services/session.service.js +2 -0
  247. package/services/upload/index.cjs +2 -0
  248. package/services/upload/index.d.cts +2 -0
  249. package/services/upload/index.d.ts +2 -0
  250. package/services/upload/index.js +2 -0
  251. package/services/upload/upload.service.cjs +2 -0
  252. package/services/upload/upload.service.d.cts +81 -0
  253. package/services/upload/upload.service.d.ts +81 -0
  254. package/services/upload/upload.service.js +2 -0
  255. package/themes/dark.cjs +16 -2
  256. package/themes/dark.d.cts +1 -0
  257. package/themes/dark.d.ts +1 -0
  258. package/themes/dark.js +15 -1
  259. package/themes/light.cjs +13 -2
  260. package/themes/light.d.cts +1 -0
  261. package/themes/light.d.ts +1 -0
  262. package/themes/light.js +12 -1
  263. package/types/globals.cjs +2 -0
  264. package/types/globals.d.cts +39 -0
  265. package/types/globals.d.ts +39 -0
  266. package/types/globals.js +1 -0
  267. package/types/tracking-options.cjs +2 -2
  268. package/types/tracking-options.d.cts +8 -6
  269. package/types/tracking-options.d.ts +8 -6
  270. package/types/tracking-options.js +1 -1
  271. package/utils/adopt-styles.cjs +2 -2
  272. package/utils/adopt-styles.d.cts +1 -0
  273. package/utils/adopt-styles.d.ts +1 -0
  274. package/utils/adopt-styles.js +2 -2
  275. package/utils/browser-preferences.cjs +2 -2
  276. package/utils/browser-preferences.d.cts +1 -0
  277. package/utils/browser-preferences.d.ts +1 -0
  278. package/utils/browser-preferences.js +2 -2
  279. package/utils/classify-media.cjs +1 -1
  280. package/utils/classify-media.d.cts +1 -0
  281. package/utils/classify-media.d.ts +1 -0
  282. package/utils/classify-media.js +1 -1
  283. package/utils/decorators.cjs +1 -1
  284. package/utils/decorators.d.cts +1 -0
  285. package/utils/decorators.d.ts +1 -0
  286. package/utils/decorators.js +1 -1
  287. package/utils/detected-lang.cjs +2 -2
  288. package/utils/detected-lang.d.cts +1 -0
  289. package/utils/detected-lang.d.ts +1 -0
  290. package/utils/detected-lang.js +2 -2
  291. package/utils/fullscreen.cjs +2 -2
  292. package/utils/fullscreen.d.cts +6 -5
  293. package/utils/fullscreen.d.ts +6 -5
  294. package/utils/fullscreen.js +2 -2
  295. package/utils/insert-script.cjs +1 -1
  296. package/utils/insert-script.d.cts +1 -0
  297. package/utils/insert-script.d.ts +1 -0
  298. package/utils/insert-script.js +1 -1
  299. package/utils/is-map-compatible.cjs +1 -1
  300. package/utils/is-map-compatible.d.cts +1 -0
  301. package/utils/is-map-compatible.d.ts +1 -0
  302. package/utils/is-map-compatible.js +1 -1
  303. package/utils/markdown.cjs +2 -2
  304. package/utils/markdown.d.cts +1 -0
  305. package/utils/markdown.d.ts +1 -0
  306. package/utils/markdown.js +2 -2
  307. package/utils/merge.cjs +2 -2
  308. package/utils/merge.d.cts +2 -1
  309. package/utils/merge.d.ts +2 -1
  310. package/utils/merge.js +2 -2
  311. package/utils/multiband-track-volume.cjs +2 -2
  312. package/utils/multiband-track-volume.d.cts +1 -0
  313. package/utils/multiband-track-volume.d.ts +1 -0
  314. package/utils/multiband-track-volume.js +2 -2
  315. package/utils/onlive-url-params.cjs +1 -1
  316. package/utils/onlive-url-params.d.cts +1 -0
  317. package/utils/onlive-url-params.d.ts +1 -0
  318. package/utils/onlive-url-params.js +1 -1
  319. package/utils/pretty-distance.cjs +2 -2
  320. package/utils/pretty-distance.d.cts +2 -1
  321. package/utils/pretty-distance.d.ts +2 -1
  322. package/utils/pretty-distance.js +2 -2
  323. package/utils/pretty-time.cjs +2 -0
  324. package/utils/pretty-time.d.cts +16 -0
  325. package/utils/pretty-time.d.ts +16 -0
  326. package/utils/pretty-time.js +2 -0
  327. package/utils/random-string.cjs +1 -1
  328. package/utils/random-string.d.cts +1 -0
  329. package/utils/random-string.d.ts +1 -0
  330. package/utils/random-string.js +1 -1
  331. package/utils/resource-type.cjs +1 -1
  332. package/utils/resource-type.d.cts +1 -0
  333. package/utils/resource-type.d.ts +1 -0
  334. package/utils/resource-type.js +1 -1
  335. package/utils/round-number.cjs +2 -0
  336. package/utils/round-number.d.cts +30 -0
  337. package/utils/round-number.d.ts +30 -0
  338. package/utils/round-number.js +2 -0
  339. package/utils/safe-html.cjs +2 -2
  340. package/utils/safe-html.d.cts +12 -4
  341. package/utils/safe-html.d.ts +12 -4
  342. package/utils/safe-html.js +2 -2
  343. package/utils/sanitize.cjs +2 -2
  344. package/utils/sanitize.d.cts +1 -0
  345. package/utils/sanitize.d.ts +1 -0
  346. package/utils/sanitize.js +2 -2
  347. package/utils/spread.cjs +2 -2
  348. package/utils/spread.d.cts +1 -0
  349. package/utils/spread.d.ts +1 -0
  350. package/utils/spread.js +2 -2
  351. package/utils/watch.cjs +1 -1
  352. package/utils/watch.d.cts +1 -0
  353. package/utils/watch.d.ts +1 -0
  354. package/utils/watch.js +1 -1
  355. package/services/firebase/firebase.service.cjs +0 -2
  356. package/services/firebase/firebase.service.d.cts +0 -40
  357. package/services/firebase/firebase.service.d.ts +0 -40
  358. package/services/firebase/firebase.service.js +0 -2
  359. package/services/livekit.service.cjs +0 -2
  360. package/services/livekit.service.d.cts +0 -219
  361. package/services/livekit.service.d.ts +0 -219
  362. package/services/livekit.service.js +0 -2
  363. package/types/window-context.cjs +0 -2
  364. package/types/window-context.d.cts +0 -8
  365. package/types/window-context.d.ts +0 -8
  366. package/types/window-context.js +0 -1
@@ -0,0 +1,300 @@
1
+ /*! @onlive.ai/common-121 v0.2.179 | © 2026 Onlive.ai */
2
+ import { UserApiResponse, ConversationServiceOptions, AgentData, CreateRoomOptions, EvaluateRoomOptions, GetRoomsOptions, RoomsApiResponse, PersistMessageOptions, MessagesApiResponse, GetMessagesOptions, ApiMessage, MessageReportOptions, MessageReactionOptions, MessageListener, TypingListener, ContextualEvent, RequestNewRoomOptions, RoomApiResponse, CallRequest, CallRequestListener, RoomSyncData, NewRoomRequestData } from '../conversation.types.js';
3
+ import { MockServiceConfig, MockAgentConfig, MockScenario } from './types.js';
4
+ import { MockEventEmitter } from './events.js';
5
+ import { MockRoom } from './livekit/room.js';
6
+ import { MockState } from './state.js';
7
+ import '@livekit/components-core';
8
+ import 'livekit-client';
9
+ import '../../firebase/firebase-api.js';
10
+ import 'firebase/database';
11
+ import './livekit/local-participant.js';
12
+ import './livekit/tracks.js';
13
+ import './livekit/participant.js';
14
+ import './livekit/streams.js';
15
+
16
+ /**
17
+ * @file Mock Conversation Service implementation.
18
+ *
19
+ * @summary Drop-in replacement for ConversationService that operates entirely
20
+ * in memory without real network calls or LiveKit infrastructure.
21
+ *
22
+ * @description Provides a complete mock implementation of ConversationService
23
+ * using the modular livekit/ and actor/ subsystems. Designed for unit testing,
24
+ * integration testing, and Storybook demonstrations.
25
+ *
26
+ * @example
27
+ * ```typescript
28
+ * const service = new MockConversationService({
29
+ * organizationId: 'test_org',
30
+ * latencyMs: 50,
31
+ * });
32
+ *
33
+ * await service.registerUser('user_1', 'secret', { name: 'John' });
34
+ * const room = await service.createRoom({ language: 'en', timezone: 'UTC' });
35
+ *
36
+ * // Send a message
37
+ * await service.sendMessage("Hello!");
38
+ * ```
39
+ */
40
+
41
+ /**
42
+ * Mock implementation of ConversationService.
43
+ *
44
+ * @description Provides the same API as ConversationService but operates entirely
45
+ * in memory. Supports deterministic testing, latency simulation, and event tracking.
46
+ */
47
+ declare class MockConversationService {
48
+ /** In-memory state manager */
49
+ private state;
50
+ /** Event emitter */
51
+ private events;
52
+ /** Message listeners */
53
+ private messageListeners;
54
+ /** Typing listeners */
55
+ private typingListeners;
56
+ /** Call request listeners */
57
+ private callRequestListeners;
58
+ /** Current auth token */
59
+ private _authToken;
60
+ /** Registered user data */
61
+ private _registeredUser;
62
+ /** Service configuration */
63
+ private config;
64
+ /** Active agents by ID */
65
+ private agents;
66
+ /** Custom agent response handler */
67
+ private customAgentHandler?;
68
+ /** Current mock room instance */
69
+ room: MockRoom;
70
+ /**
71
+ * Gets the current auth token.
72
+ */
73
+ get authToken(): string | null;
74
+ /**
75
+ * Gets the registered user data.
76
+ */
77
+ get registeredUser(): UserApiResponse | null;
78
+ /**
79
+ * Creates a new MockConversationService.
80
+ *
81
+ * @param options - Service configuration options.
82
+ */
83
+ constructor(options?: Partial<ConversationServiceOptions> & Partial<MockServiceConfig>);
84
+ /**
85
+ * Gets the internal state manager for testing.
86
+ */
87
+ getState(): MockState;
88
+ /**
89
+ * Gets the event emitter for subscriptions.
90
+ */
91
+ getEvents(): MockEventEmitter;
92
+ /**
93
+ * Updates mock configuration.
94
+ */
95
+ updateConfig(config: Partial<MockServiceConfig>): void;
96
+ /**
97
+ * Gets current configuration.
98
+ */
99
+ getConfig(): MockServiceConfig;
100
+ /**
101
+ * Simulates network latency.
102
+ */
103
+ simulateLatency(): Promise<void>;
104
+ private applyScenario;
105
+ private shouldThrowError;
106
+ /**
107
+ * Ensures a room instance exists.
108
+ */
109
+ ensureRoom(): MockRoom;
110
+ /**
111
+ * Registers a user for conversation access.
112
+ */
113
+ registerUser(externalId: string, _secret: string, userData?: Record<string, unknown>, _metadata?: Record<string, unknown>): Promise<UserApiResponse>;
114
+ /**
115
+ * Registers an agent for handling conversations.
116
+ */
117
+ registerAgent(externalId: string, agentData: AgentData): Promise<string>;
118
+ /**
119
+ * Creates a new conversation room.
120
+ */
121
+ createRoom(options: CreateRoomOptions, userData?: Record<string, string>): Promise<MockRoom>;
122
+ /**
123
+ * Joins an existing conversation room.
124
+ */
125
+ joinRoom(roomId: string, _timezone: string, _language: string, attributes?: Record<string, unknown>): Promise<MockRoom>;
126
+ /**
127
+ * Evaluates/rates the current room.
128
+ */
129
+ evaluateRoom(options: EvaluateRoomOptions): Promise<void>;
130
+ /**
131
+ * Closes the current room on the server.
132
+ */
133
+ closeRoom(): Promise<void>;
134
+ /**
135
+ * Disconnects from the current room.
136
+ */
137
+ disconnect(): Promise<void>;
138
+ /**
139
+ * Stops all published local tracks in the current room.
140
+ */
141
+ private stopLocalTracks;
142
+ /**
143
+ * Closes the room and disconnects.
144
+ */
145
+ disconnectAndCloseRoom(): Promise<void>;
146
+ /**
147
+ * Marks a room as read.
148
+ */
149
+ readRoom(roomId: string): Promise<void>;
150
+ /**
151
+ * Fetches a list of rooms.
152
+ */
153
+ getRooms(options: GetRoomsOptions): Promise<RoomsApiResponse>;
154
+ /**
155
+ * Sends a message in the current room.
156
+ */
157
+ sendMessage(message: string, attributes?: Record<string, string>): Promise<void>;
158
+ /**
159
+ * Persists a message to storage.
160
+ */
161
+ persistMessage(options: PersistMessageOptions): Promise<MessagesApiResponse>;
162
+ /**
163
+ * Fetches messages.
164
+ */
165
+ getMessages(options: GetMessagesOptions): Promise<ApiMessage[]>;
166
+ /**
167
+ * Reports a message.
168
+ */
169
+ sendMessageReport(_options: MessageReportOptions): Promise<void>;
170
+ /**
171
+ * Deletes a message report.
172
+ */
173
+ deleteMessageReport(_options: MessageReportOptions): Promise<void>;
174
+ /**
175
+ * Updates message reactions.
176
+ */
177
+ updateMessageReactions(_options: MessageReactionOptions): Promise<void>;
178
+ /**
179
+ * Subscribes to incoming messages.
180
+ */
181
+ subscribeMessages<M extends ApiMessage = ApiMessage>(callback: MessageListener<M>): () => void;
182
+ /**
183
+ * Sends a typing indicator.
184
+ */
185
+ sendTypingIndicator(isTyping: boolean): Promise<void>;
186
+ /**
187
+ * Subscribes to typing indicators.
188
+ */
189
+ subscribeTypingIndicators(listener: TypingListener): () => void;
190
+ /**
191
+ * Unsubscribes a typing listener.
192
+ */
193
+ unsubscribeTypingIndicators(listener: TypingListener): void;
194
+ /**
195
+ * Sends a contextual event.
196
+ */
197
+ sendContextualEvent(_event: ContextualEvent): Promise<void>;
198
+ /**
199
+ * Requests a new room (call transfer).
200
+ */
201
+ requestNewRoom(options: RequestNewRoomOptions): Promise<RoomApiResponse>;
202
+ /**
203
+ * Confirms a room request.
204
+ */
205
+ confirmRoomRequest(roomId: string): Promise<{
206
+ success: boolean;
207
+ message: string;
208
+ roomId: string;
209
+ }>;
210
+ /**
211
+ * Cancels a room request.
212
+ */
213
+ cancelRoomRequest(roomId: string): Promise<{
214
+ success: boolean;
215
+ message: string;
216
+ roomId: string;
217
+ }>;
218
+ /**
219
+ * Finishes an active call.
220
+ */
221
+ finishCall(): Promise<void>;
222
+ isFirebaseEnabled(): boolean;
223
+ onPresenceChange(_callback: (agentId: string, data: object | null) => void): () => void;
224
+ onPresenceAgentChange(_agentId: string, _callback: (agentId: string, data: object | null) => void): () => void;
225
+ createCallRequest(_requestData: Omit<CallRequest, "status" | "createdAt" | "id">): Promise<string>;
226
+ onNewCallRequest(callback: CallRequestListener): () => void;
227
+ onCallRequestChange(callback: CallRequestListener): () => void;
228
+ onCallRequestRemoved(_callback: (id: string) => void): () => void;
229
+ acceptCallRequest(_requestId: string): Promise<void>;
230
+ cancelCallRequest(_requestId: string): Promise<void>;
231
+ cancelOnDisconnect(_requestId: string): Promise<void>;
232
+ subscribePendingRequests(_callback: CallRequestListener, _options?: {
233
+ resetSeen?: boolean;
234
+ }): () => void;
235
+ subscribeRequestChanges(_callback: CallRequestListener): () => void;
236
+ tryAcceptRequest(_requestId: string): Promise<boolean>;
237
+ onRoomSync(_roomId: string, _callback: (data: RoomSyncData | null) => void): () => void;
238
+ clearRoomSync(_roomId: string, _reason?: string): Promise<void>;
239
+ onNewRoomRequest(_roomId: string, _callback: (data: NewRoomRequestData | null) => void): () => void;
240
+ unsubscribeAllFirebase(): void;
241
+ destroy(): Promise<void>;
242
+ /**
243
+ * Starts a mock agent in a room.
244
+ *
245
+ * If the agent type includes "video" or "voice", the agent will also join
246
+ * the room as a participant with the appropriate media tracks.
247
+ */
248
+ startMockAgent(roomId: string, config?: Partial<MockAgentConfig>): Promise<string>;
249
+ /**
250
+ * Stops a mock agent.
251
+ */
252
+ stopMockAgent(agentId: string): Promise<void>;
253
+ /**
254
+ * Sets a custom agent response handler.
255
+ */
256
+ setAgentResponseHandler(handler: (agentId: string, message: string) => string | Promise<string>): void;
257
+ private triggerAgentResponse;
258
+ /**
259
+ * Simulates a call request being received.
260
+ */
261
+ simulateCallRequest(requestData: Partial<CallRequest>): void;
262
+ /**
263
+ * Simulates a participant joining.
264
+ */
265
+ simulateParticipantJoin(identity: string, name?: string, role?: "user" | "agent"): void;
266
+ /**
267
+ * Simulates a participant leaving.
268
+ */
269
+ simulateParticipantLeave(identity: string): void;
270
+ /**
271
+ * Simulates receiving a message.
272
+ */
273
+ simulateIncomingMessage(participantIdentity: string, content: string): void;
274
+ /**
275
+ * Simulates room disconnection.
276
+ */
277
+ simulateDisconnect(): Promise<void>;
278
+ /**
279
+ * Resets the mock service.
280
+ */
281
+ reset(): void;
282
+ /**
283
+ * Seeds the random number generator.
284
+ */
285
+ seed(seed: number): void;
286
+ /**
287
+ * Sets a predefined scenario.
288
+ */
289
+ setScenario(scenario: MockScenario): void;
290
+ /**
291
+ * Exports current state to JSON.
292
+ */
293
+ exportState(): object;
294
+ /**
295
+ * Gets event history.
296
+ */
297
+ getEventHistory(filterType?: string): any[];
298
+ }
299
+
300
+ export { MockConversationService };
@@ -0,0 +1,2 @@
1
+ /*! @onlive.ai/common-121 v0.2.179 | © 2026 Onlive.ai */
2
+ var ot=Object.defineProperty;var at=(r,t)=>()=>(r&&(t=r(r=0)),t);var ct=(r,t)=>{for(var e in t)ot(r,e,{get:t[e],enumerable:!0})};var P={};ct(P,{SYNTHETIC_MEDIA_PRESETS:()=>it,createSyntheticAudioTrack:()=>tt,createSyntheticMedia:()=>et,createSyntheticMediaFromPreset:()=>dt,createSyntheticVideoTrack:()=>X});function X(r={}){let{width:t=640,height:e=480,fps:i=30,backgroundColor:n="#1a1a2e",foregroundColor:s="#4361ee",label:d="Mock Video",animation:o="wave"}=r,c=document.createElement("canvas");c.width=t,c.height=e;let a=c.getContext("2d"),l,S=Date.now(),C={wave:p=>{a.fillStyle=n,a.fillRect(0,0,t,e),a.strokeStyle=s,a.lineWidth=3,a.beginPath();for(let m=0;m<t;m++){let h=e/2+Math.sin(m/t*4*Math.PI+p*.002)*(e/4);m===0?a.moveTo(m,h):a.lineTo(m,h)}a.stroke()},pulse:p=>{a.fillStyle=n,a.fillRect(0,0,t,e);let m=Math.sin(p*.003)*.3+.7,h=Math.min(t,e)*.3*m;a.beginPath(),a.arc(t/2,e/2,h,0,Math.PI*2),a.fillStyle=s,a.fill()},bars:p=>{a.fillStyle=n,a.fillRect(0,0,t,e);let m=20,h=t/m,M=e*.7;a.fillStyle=s;for(let E=0;E<m;E++){let Y=Math.abs(Math.sin(E/m*Math.PI*2+p*.004))*M,st=E*h,rt=e-Y;a.fillRect(st+2,rt,h-4,Y)}},avatar:p=>{a.fillStyle=n,a.fillRect(0,0,t,e);let m=t/2,h=e/2-20,M=Math.min(t,e)*.15;a.beginPath(),a.arc(m,h,M,0,Math.PI*2),a.fillStyle=s,a.fill(),a.beginPath(),a.ellipse(m,h+M*2.2,M*1.5,M,0,Math.PI,0),a.fill(),Math.sin(p*.01)>0&&(a.beginPath(),a.arc(m,h+M*3,5+Math.sin(p*.02)*3,0,Math.PI*2),a.fillStyle="#22c55e",a.fill())},none:()=>{a.fillStyle=n,a.fillRect(0,0,t,e)}},_=()=>{a.fillStyle="rgba(255, 255, 255, 0.8)",a.font=`${Math.floor(e*.04)}px system-ui, sans-serif`,a.textAlign="center",a.fillText(d,t/2,e-20)},b=()=>{let p=Date.now()-S;C[o](p),_(),l=requestAnimationFrame(b)};b();let B=c.captureStream(i),W=B.getVideoTracks()[0];return{track:W,stream:B,cleanup:()=>{cancelAnimationFrame(l),W.stop()}}}function tt(r={}){let{frequency:t=440,volume:e=.1,waveType:i="sine",addVariation:n=!0,enabled:s=!1}=r,d=new AudioContext,o=d.createMediaStreamDestination(),c=d.createOscillator();c.type=i,c.frequency.value=t;let a=d.createGain();a.gain.value=s?e:0;let l=null,S=null;n&&(l=d.createOscillator(),l.frequency.value=.5,S=d.createGain(),S.gain.value=10,l.connect(S),S.connect(c.frequency),l.start()),c.connect(a),a.connect(o),c.start();let C=o.stream,_=C.getAudioTracks()[0];return{track:_,stream:C,setVolume:b=>{a.gain.value=Math.max(0,Math.min(1,b))},setEnabled:b=>{a.gain.value=b?e:0},cleanup:()=>{c.stop(),l?.stop(),d.close(),_.stop()}}}function et(r,t){let e=X(r),i=tt(t),n=new MediaStream([e.track,i.track]);return{videoTrack:e.track,audioTrack:i.track,combinedStream:n,setAudioVolume:i.setVolume,setAudioEnabled:i.setEnabled,cleanup:()=>{e.cleanup(),i.cleanup()}}}function dt(r){let t=it[r];return et(t.video,t.audio)}var it,w=at(()=>{"use strict";it={localCamera:{video:{width:640,height:480,animation:"avatar",label:"You",foregroundColor:"#4361ee"},audio:{enabled:!1}},agentCamera:{video:{width:640,height:480,animation:"avatar",label:"AI Agent",foregroundColor:"#22c55e",backgroundColor:"#0f172a"},audio:{enabled:!1,frequency:300}},screenShare:{video:{width:1920,height:1080,animation:"bars",label:"Screen Share",backgroundColor:"#0a0a0a",foregroundColor:"#f59e0b"},audio:{enabled:!1}},voiceOnly:{video:{width:320,height:240,animation:"wave",label:"Voice Call"},audio:{enabled:!1,volume:.05}}}});var H=0;function Q(){H=0}function g(r){return H++,`mock_${r}_${H}_${Date.now().toString(36)}`}function T(r,t,e){let i=e||new Date().toISOString(),n=typeof btoa=="function"?btoa(i).replace(/\+/g,"-").replace(/\//g,"_").replace(/=+$/,""):i.replace(/[^a-zA-Z0-9]/g,"");return`mock_token_${r}_${t}_${n}`}function Z(r){return`wss://mock-livekit.local/room/${r}`}var N={responseStrategy:"echo",responseDelayMs:100,cannedResponses:[],type:"text",nature:"ai",simulateTyping:!1,typingDelayPerChar:20};function U(r,t,e=[],i=0,n=Math.random){switch(r){case"echo":return{response:`Echo: ${t}`,nextIndex:i};case"canned":return{response:e[0]||"Default response",nextIndex:i};case"sequential":return{response:e[i]||"No more responses",nextIndex:(i+1)%Math.max(1,e.length)};case"random":{if(e.length===0)return{response:"Random response",nextIndex:i};let s=Math.floor(n()*e.length);return{response:e[s],nextIndex:i}}case"silent":return{response:"",nextIndex:i};case"error":throw new Error("Agent error");case"custom":return{response:"",nextIndex:i};default:return{response:"Default agent response",nextIndex:i}}}var I=class{constructor(t,e,i={}){this._state="idle";this.conversationHistory=[];this.responseIndex=0;this.eventListeners=new Set;this.randomFn=Math.random;this.messageCount=0;this.id=t,this.name=e,this.config={...N,...i}}get state(){return this._state}get isRunning(){return this._state==="running"}get history(){return[...this.conversationHistory]}getConfig(){return{...this.config}}updateConfig(t){this.config={...this.config,...t}}setStrategy(t){this.config.responseStrategy=t}setCannedResponses(t){this.config.cannedResponses=t,this.responseIndex=0}setCustomHandler(t){this.customHandler=t,this.config.responseStrategy="custom"}setRandomFunction(t){this.randomFn=t}async start(t){this._state!=="running"&&(this._state="starting",this.roomId=t,this.conversationHistory=[],this.responseIndex=0,this.messageCount=0,await this.delay(50),this._state="running",this.emitEvent({type:"started",agentId:this.id}))}async stop(){this._state==="running"&&(this._state="stopping",await this.delay(50),this._state="stopped",this.roomId=void 0,this.emitEvent({type:"stopped",agentId:this.id}))}async processMessage(t){if(this._state!=="running")throw new Error("Agent is not running");if(this.config.maxMessages&&this.messageCount>=this.config.maxMessages)return await this.stop(),"";this.addMessage(t,"user"),this.emitEvent({type:"message_received",agentId:this.id,message:t});let e;try{if(this.config.responseStrategy==="custom"&&this.customHandler)e=await this.customHandler(this.id,t,this.conversationHistory);else{if(this.config.responseStrategy==="silent")return"";if(this.config.responseStrategy==="error"){let i=new Error("Agent error");throw this.emitEvent({type:"error",agentId:this.id,error:i}),i}else{let i=U(this.config.responseStrategy,t,this.config.cannedResponses,this.responseIndex,this.randomFn);e=i.response,this.responseIndex=i.nextIndex}}}catch(i){throw this._state="error",i}return this.config.simulateTyping&&this.config.typingDelayPerChar&&await this.delay(e.length*this.config.typingDelayPerChar),this.config.responseDelayMs&&await this.delay(this.config.responseDelayMs),this.addMessage(e,"agent"),this.messageCount++,this.emitEvent({type:"response_sent",agentId:this.id,response:e}),e}addEventListener(t){return this.eventListeners.add(t),()=>this.eventListeners.delete(t)}clearHistory(){this.conversationHistory=[],this.responseIndex=0}reset(){this._state="idle",this.roomId=void 0,this.conversationHistory=[],this.responseIndex=0,this.messageCount=0}toJSON(){return{id:this.id,name:this.name,state:this._state,roomId:this.roomId,config:this.config,historyLength:this.conversationHistory.length,messageCount:this.messageCount}}addMessage(t,e){let i={id:g("msg"),content:t,role:e,timestamp:Date.now()};return this.conversationHistory.push(i),i}emitEvent(t){for(let e of this.eventListeners)try{e(t)}catch(i){console.error("Error in agent event listener:",i)}}delay(t){return new Promise(e=>setTimeout(e,t))}};var u=class r extends Error{constructor(t,e,i){super(e),this.name="MockLiveKitError",this.code=t,this.details=i,typeof Error.captureStackTrace=="function"&&Error.captureStackTrace(this,r)}toMockError(){return{code:this.code,message:this.message,details:this.details}}static fromMockError(t){return new r(t.code,t.message,t.details)}},v=class extends u{constructor(t){super("ROOM_NOT_FOUND",`Room not found: ${t}`,{roomId:t}),this.name="RoomNotFoundError"}},q=class extends u{constructor(t){super("ROOM_ENDED",`Room has ended: ${t}`,{roomId:t}),this.name="RoomEndedError"}},$=class extends u{constructor(t,e){super("PARTICIPANT_ALREADY_JOINED",`Participant ${t} is already in room ${e}`,{identity:t,roomId:e}),this.name="ParticipantAlreadyJoinedError"}},j=class extends u{constructor(t){super("PARTICIPANT_NOT_FOUND",`Participant not found: ${t}`,{identity:t}),this.name="ParticipantNotFoundError"}},F=class extends u{constructor(t){super("TRACK_NOT_FOUND",`Track not found: ${t}`,{trackId:t}),this.name="TrackNotFoundError"}},V=class extends u{constructor(t){super("AGENT_NOT_FOUND",`Agent not found: ${t}`,{agentId:t}),this.name="AgentNotFoundError"}},K=class extends u{constructor(t="Unauthorized"){super("UNAUTHORIZED",t),this.name="UnauthorizedError"}},G=class extends u{constructor(t="Network error occurred"){super("NETWORK_ERROR",t),this.name="NetworkError"}},J=class extends u{constructor(t,e){super("INVALID_OPERATION",t,e),this.name="InvalidOperationError"}},z=class extends u{constructor(t,e){super("TIMEOUT",`Operation timed out: ${t}`,{operation:t,timeoutMs:e}),this.name="TimeoutError"}};function O(r){switch(r.code){case"ROOM_NOT_FOUND":return new v(r.details?.roomId??"unknown");case"ROOM_ENDED":return new q(r.details?.roomId??"unknown");case"PARTICIPANT_ALREADY_JOINED":return new $(r.details?.identity??"unknown",r.details?.roomId??"unknown");case"PARTICIPANT_NOT_FOUND":return new j(r.details?.identity??"unknown");case"TRACK_NOT_FOUND":return new F(r.details?.trackId??"unknown");case"AGENT_NOT_FOUND":return new V(r.details?.agentId??"unknown");case"UNAUTHORIZED":return new K(r.message);case"NETWORK_ERROR":return new G(r.message);case"INVALID_OPERATION":return new J(r.message,r.details);case"TIMEOUT":return new z(r.details?.operation??"unknown",r.details?.timeoutMs??0);default:return u.fromMockError(r)}}function y(r){return typeof r=="object"&&r!==null&&"code"in r&&"message"in r&&typeof r.code=="string"&&typeof r.message=="string"}var L=class{constructor(){this.listeners={};this.wildcardListeners=new Set;this.eventHistory=[];this.maxHistorySize=1e3;this.recordHistory=!0}setMaxHistorySize(t){this.maxHistorySize=t,this.trimHistory()}setRecordHistory(t){this.recordHistory=t}on(t,e){return this.listeners[t]||(this.listeners[t]=new Set),this.listeners[t].add(e),()=>{this.off(t,e)}}once(t,e){let i=n=>{this.off(t,i),e(n)};return this.on(t,i)}off(t,e){this.listeners[t]?.delete(e)}onAny(t){return this.wildcardListeners.add(t),()=>{this.wildcardListeners.delete(t)}}offAny(t){this.wildcardListeners.delete(t)}removeAllListeners(t){t?delete this.listeners[t]:(this.listeners={},this.wildcardListeners.clear())}emit(t){this.recordHistory&&(this.eventHistory.push(t),this.trimHistory());let e=this.listeners[t.type];if(e)for(let i of e)try{i(t)}catch(n){console.error(`Error in mock event listener for ${t.type}:`,n)}for(let i of this.wildcardListeners)try{i(t)}catch(n){console.error("Error in mock wildcard event listener:",n)}}trimHistory(){this.eventHistory.length>this.maxHistorySize&&(this.eventHistory=this.eventHistory.slice(-this.maxHistorySize))}emitRoomCreated(t){let e={type:"roomCreated",timestamp:new Date().toISOString(),roomId:t.id,room:t};this.emit(e)}emitRoomEnded(t){let e={type:"roomEnded",timestamp:new Date().toISOString(),roomId:t};this.emit(e)}emitRoomConnectionStateChanged(t,e,i){let n={type:"roomConnectionStateChanged",timestamp:new Date().toISOString(),roomId:t,state:e,previousState:i};this.emit(n)}emitParticipantJoined(t,e){let i={type:"participantJoined",timestamp:new Date().toISOString(),roomId:t,participant:e};this.emit(i)}emitParticipantLeft(t,e){let i={type:"participantLeft",timestamp:new Date().toISOString(),roomId:t,participantIdentity:e};this.emit(i)}emitParticipantAttributesChanged(t,e,i,n){let s={type:"participantAttributesChanged",timestamp:new Date().toISOString(),roomId:t,participantIdentity:e,attributes:i,previousAttributes:n};this.emit(s)}emitTrackPublished(t,e,i){let n={type:"trackPublished",timestamp:new Date().toISOString(),roomId:t,participantIdentity:e,track:i};this.emit(n)}emitTrackUnpublished(t,e,i){let n={type:"trackUnpublished",timestamp:new Date().toISOString(),roomId:t,participantIdentity:e,trackId:i};this.emit(n)}emitTrackMuted(t,e){let i={type:"trackMuted",timestamp:new Date().toISOString(),roomId:t,trackId:e};this.emit(i)}emitTrackUnmuted(t,e){let i={type:"trackUnmuted",timestamp:new Date().toISOString(),roomId:t,trackId:e};this.emit(i)}emitMessageReceived(t,e){let i={type:"messageReceived",timestamp:new Date().toISOString(),roomId:t,message:e};this.emit(i)}emitMessageSent(t,e){let i={type:"messageSent",timestamp:new Date().toISOString(),roomId:t,message:e};this.emit(i)}emitTypingIndicator(t,e,i){let n={type:"typingIndicator",timestamp:new Date().toISOString(),roomId:t,participantIdentity:e,isTyping:i};this.emit(n)}emitAgentStarted(t,e){let i={type:"agentStarted",timestamp:new Date().toISOString(),roomId:t,agent:e};this.emit(i)}emitAgentStopped(t,e){let i={type:"agentStopped",timestamp:new Date().toISOString(),roomId:t,agentId:e};this.emit(i)}emitAgentMessage(t,e,i){let n={type:"agentMessage",timestamp:new Date().toISOString(),roomId:t,agentId:e,message:i};this.emit(n)}emitDataReceived(t,e,i,n){let s={type:"dataReceived",timestamp:new Date().toISOString(),roomId:t,participantIdentity:e,data:i,topic:n};this.emit(s)}emitError(t,e){let i={type:"error",timestamp:new Date().toISOString(),roomId:e,error:t};this.emit(i)}getHistory(t){return t?this.eventHistory.filter(e=>e.type===t):[...this.eventHistory]}getLastEvents(t,e){return(e?this.eventHistory.filter(n=>n.type===e):this.eventHistory).slice(-t)}clearHistory(){this.eventHistory=[]}listenerCount(t){return(this.listeners[t]?.size??0)+this.wildcardListeners.size}};var f=class{constructor(t,e,i,n){this.muted=!1;this.enabled=!0;this.attachedElements=new Set;this.kind=t,this.source=e,this.sid=g("TR"),this.mediaStreamTrack=i,this.mediaCleanup=n}get mediaTrack(){return this.mediaStreamTrack}attach(t){let e=t||document.createElement(this.kind==="video"?"video":"audio");if(this.mediaStreamTrack){let i=new MediaStream([this.mediaStreamTrack]);e.srcObject=i,e.autoplay=!0,this.kind==="video"&&(e.playsInline=!0,e.muted=!0)}return this.attachedElements.add(e),e}detach(t){if(t)return t.srcObject=null,this.attachedElements.delete(t),[t];let e=Array.from(this.attachedElements);for(let i of e)i.srcObject=null;return this.attachedElements.clear(),e}stop(){this.detach(),this.mediaCleanup&&this.mediaCleanup(),this.mediaStreamTrack&&this.mediaStreamTrack.stop(),this.enabled=!1}setMuted(t){this.muted=t,this.mediaStreamTrack&&(this.mediaStreamTrack.enabled=!t)}setEnabled(t){this.enabled=t,this.mediaStreamTrack&&(this.mediaStreamTrack.enabled=t)}},k=class{constructor(t,e){this.subscribed=!0;this.isEnabled=!0;this.track=t,this.trackSid=t.sid,this.trackName=e||`${t.kind}_${t.source}`,this.source=t.source,this.kind=t.kind}get isMuted(){return this.track?.muted??!1}get isSubscribed(){return this.subscribed&&this.track!==null}setSubscribed(t){this.subscribed=t}setEnabled(t){this.isEnabled=t,this.track&&(this.track.enabled=t)}setMuted(t){this.track&&this.track.setMuted(t)}};var x=class{constructor(t){this.identity="";this.sid="";this.name="";this.attributes={};this.kind="standard";this.trackPublications=new Map;this.audioTrackPublications=new Map;this.videoTrackPublications=new Map;this._cameraEnabled=!1;this._microphoneEnabled=!1;this._screenShareEnabled=!1;this.room=t,this.sid=g("PA"),this.joinedAt=new Date}get isCameraEnabled(){return this._cameraEnabled}get isMicrophoneEnabled(){return this._microphoneEnabled}get isScreenShareEnabled(){return this._screenShareEnabled}getTrackPublications(){return Array.from(this.trackPublications.values())}getTrackPublication(t){let i={camera:"camera",Camera:"camera",microphone:"microphone",Microphone:"microphone",screen_share:"screen_share",ScreenShare:"screen_share",screen_share_audio:"screen_share_audio",ScreenShareAudio:"screen_share_audio"}[t]||t;return this.trackPublications.get(i)}getTrackPublicationBySid(t){for(let e of this.trackPublications.values())if(e.trackSid===t)return e}setAttributes(t){this.attributes={...this.attributes,...t}}async setCameraEnabled(t,e){if(this._cameraEnabled=t,t){let{createSyntheticVideoTrack:n}=await Promise.resolve().then(()=>(w(),P)),{track:s,cleanup:d}=n({animation:"avatar",label:this.name||"Local Camera"}),o=new f("video","camera",s,d),c=new k(o,e?.name);return this.trackPublications.set("camera",c),this.videoTrackPublications.set(o.sid,c),this.room.emit("localTrackPublished",c,this),c}let i=this.trackPublications.get("camera");i&&(i.track?.stop(),this.trackPublications.delete("camera"),this.videoTrackPublications.delete(i.trackSid),this.room.emit("localTrackUnpublished",i,this))}async setMicrophoneEnabled(t,e){if(this._microphoneEnabled=t,t){let{createSyntheticAudioTrack:n}=await Promise.resolve().then(()=>(w(),P)),{track:s,cleanup:d}=n({enabled:!1}),o=new f("audio","microphone",s,d),c=new k(o,e?.name);return this.trackPublications.set("microphone",c),this.audioTrackPublications.set(o.sid,c),this.room.emit("localTrackPublished",c,this),c}let i=this.trackPublications.get("microphone");i&&(i.track?.stop(),this.trackPublications.delete("microphone"),this.audioTrackPublications.delete(i.trackSid),this.room.emit("localTrackUnpublished",i,this))}async setScreenShareEnabled(t,e){if(this._screenShareEnabled=t,t){let{createSyntheticVideoTrack:n}=await Promise.resolve().then(()=>(w(),P)),{track:s,cleanup:d}=n({animation:"bars",label:"Screen Share",width:1920,height:1080}),o=new f("video","screen_share",s,d),c=new k(o,e?.name||"screen");return this.trackPublications.set("screen_share",c),this.videoTrackPublications.set(o.sid,c),this.room.emit("localTrackPublished",c,this),c}let i=this.trackPublications.get("screen_share");i&&(i.track?.stop(),this.trackPublications.delete("screen_share"),this.videoTrackPublications.delete(i.trackSid),this.room.emit("localTrackUnpublished",i,this))}async publishTrack(t,e){let i=new k(t,e?.name),n=e?.source||t.source;return this.trackPublications.set(n,i),t.kind==="audio"?this.audioTrackPublications.set(t.sid,i):t.kind==="video"&&this.videoTrackPublications.set(t.sid,i),this.room.emit("localTrackPublished",i,this),i}async unpublishTrack(t){t.stop();for(let[e,i]of this.trackPublications)if(i.track===t){this.trackPublications.delete(e),t.kind==="audio"?this.audioTrackPublications.delete(t.sid):t.kind==="video"&&this.videoTrackPublications.delete(t.sid),this.room.emit("localTrackUnpublished",i,this);break}}async sendText(t,e){return{id:g("msg")}}async publishData(t,e){}async setMetadata(t){this.attributes.metadata=t}async setName(t){this.name=t}cleanup(){for(let t of this.trackPublications.values())t.track?.stop();this.trackPublications.clear(),this.audioTrackPublications.clear(),this.videoTrackPublications.clear(),this._cameraEnabled=!1,this._microphoneEnabled=!1,this._screenShareEnabled=!1}};function gt(r){switch(r){case"standard":return 0;case"ingress":return 1;case"egress":return 2;case"sip":return 3;case"agent":return 4;default:return 0}}var R=class{constructor(t,e,i={},n="standard"){this.connectionQuality="excellent";this.isSpeaking=!1;this.audioLevel=0;this.trackPublications=new Map;this.identity=t,this.sid=g("PA"),this.name=e,this.attributes=i,this._kindString=n,this.kind=gt(n),this.joinedAt=new Date}get isAgent(){return this.kind===4||this.attributes["lk.agent.name"]!==void 0}get kindString(){return this._kindString}get isCameraEnabled(){let t=this.getTrackPublication("camera");return!!(t?.track&&!t.isMuted)}get isMicrophoneEnabled(){let t=this.getTrackPublication("microphone");return!!(t?.track&&!t.isMuted)}getTrackPublication(t){for(let e of this.trackPublications.values())if(e.source===t)return e}getTrackPublicationBySid(t){return this.trackPublications.get(t)}getTrackPublications(){return Array.from(this.trackPublications.values())}getAudioTracks(){return this.getTrackPublications().filter(t=>t.kind==="audio")}getVideoTracks(){return this.getTrackPublications().filter(t=>t.kind==="video")}addTrackPublication(t){this.trackPublications.set(t.trackSid,t)}removeTrackPublication(t){let e=this.trackPublications.get(t);return e&&(this.trackPublications.delete(t),e.track?.stop()),e}setAttributes(t){this.attributes={...this.attributes,...t}}getAttribute(t){return this.attributes[t]}startSpeaking(t=.5){this.isSpeaking=!0,this.audioLevel=t}stopSpeaking(){this.isSpeaking=!1,this.audioLevel=0}setConnectionQuality(t){this.connectionQuality=t}cleanup(){for(let t of this.trackPublications.values())t.track?.stop();this.trackPublications.clear()}};var A=class{constructor(t){this.remoteParticipants=new Map;this._state="disconnected";this.eventHandlers=new Map;this.textStreamHandlers=new Map;this.rpcHandlers=new Map;this.mockService=t,this.localParticipant=new x(this),this.sid=g("RM")}get state(){return this._state}set state(t){let e=this._state;this._state=t,e!==t&&this.emit("connectionStateChanged",t,e)}get numParticipants(){return this.remoteParticipants.size+1}get isConnected(){return this._state==="connected"}async connect(t,e){this._state="connecting",this.emit("connectionStateChanged","connecting","disconnected"),await this.mockService.simulateLatency(),this._state="connected",this.connectedAt=new Date().toISOString(),this.emit("connectionStateChanged","connected","connecting"),this.emit("connected")}async disconnect(){for(let e of this.remoteParticipants.values())e.cleanup();this.remoteParticipants.clear(),this.localParticipant.cleanup();let t=this._state;this._state="disconnected",this.emit("connectionStateChanged","disconnected",t),this.emit("disconnected"),this.eventHandlers.clear()}async reconnect(){this._state="reconnecting",this.emit("connectionStateChanged","reconnecting","connected"),await this.mockService.simulateLatency(),this._state="connected",this.emit("connectionStateChanged","connected","reconnecting"),this.emit("reconnected")}on(t,e){return this.eventHandlers.has(t)||this.eventHandlers.set(t,new Set),this.eventHandlers.get(t).add(e),this}once(t,e){let i=(...n)=>{this.off(t,i),e(...n)};return this.on(t,i)}off(t,e){return this.eventHandlers.get(t)?.delete(e),this}removeAllListeners(){this.eventHandlers.clear()}emit(t,...e){let i=this.eventHandlers.get(t);if(i)for(let n of i)try{n(...e)}catch(s){console.error(`Error in mock room event handler for ${t}:`,s)}}registerRpcMethod(t,e){this.rpcHandlers.set(t,e)}unregisterRpcMethod(t){this.rpcHandlers.delete(t)}async callRpc(t,e,i,n=1e4){let s=this.rpcHandlers.get(t);if(!s)throw new Error(`RPC method not found: ${t}`);return s({callerIdentity:e,payload:i,responseTimeout:n})}registerTextStreamHandler(t,e){this.textStreamHandlers.set(t,e)}unregisterTextStreamHandler(t){this.textStreamHandlers.delete(t)}simulateTextStream(t,e){let i=this.textStreamHandlers.get(t);i&&i(e,{identity:e.participantIdentity})}getParticipantByIdentity(t){return t===this.localParticipant.identity?new R(this.localParticipant.identity,this.localParticipant.name,this.localParticipant.attributes):this.remoteParticipants.get(t)}getParticipantBySid(t){if(t===this.localParticipant.sid)return new R(this.localParticipant.identity,this.localParticipant.name,this.localParticipant.attributes);for(let e of this.remoteParticipants.values())if(e.sid===t)return e}async simulateParticipantJoin(t,e){let i=new R(t,e?.name,e?.attributes||{},e?.kind||"standard");return this.remoteParticipants.set(t,i),this.emit("participantConnected",i),e?.withCamera&&await this.simulateRemoteTrack(t,"video","camera"),e?.withMicrophone&&await this.simulateRemoteTrack(t,"audio","microphone"),i}simulateParticipantLeave(t){let e=this.remoteParticipants.get(t);if(e){for(let i of e.getTrackPublications())i.track?.stop(),this.emit("trackUnsubscribed",i.track,i,e);this.remoteParticipants.delete(t),this.emit("participantDisconnected",e)}}async simulateRemoteTrack(t,e,i){let n=this.remoteParticipants.get(t);if(!n)return;let s,d;if(e==="video"){let{createSyntheticVideoTrack:a}=await Promise.resolve().then(()=>(w(),P)),l=a({animation:n.isAgent?"avatar":"pulse",label:n.name||t,foregroundColor:n.isAgent?"#22c55e":"#4361ee"});s=l.track,d=l.cleanup}else if(e==="audio"){let{createSyntheticAudioTrack:a}=await Promise.resolve().then(()=>(w(),P)),l=a({enabled:!1});s=l.track,d=l.cleanup}let o=new f(e,i,s,d),c=new k(o);return n.addTrackPublication(c),this.emit("trackSubscribed",o,c,n),this.emit("trackPublished",c,n),o}simulateTrackUnpublished(t,e){let i=this.remoteParticipants.get(t);if(!i)return;let n=i.getTrackPublication(e);n&&(i.removeTrackPublication(n.trackSid),this.emit("trackUnpublished",n,i),this.emit("trackUnsubscribed",n.track,n,i))}async simulateAgentJoin(t,e="AI Agent"){return this.simulateParticipantJoin(t,{name:e,kind:"agent",withCamera:!0,withMicrophone:!0,attributes:{"lk.agent.name":e,"lk.agent.state":"active"}})}simulateAttributeChange(t,e){let i=this.remoteParticipants.get(t);if(i){let n={...i.attributes};i.setAttributes(e),this.emit("participantAttributesChanged",e,n,i)}}simulateTrackMuted(t,e,i){let n=this.remoteParticipants.get(t);if(!n)return;let s=n.getTrackPublication(e);s?.track&&(s.track.setMuted(i),this.emit(i?"trackMuted":"trackUnmuted",s,n))}simulateActiveSpeakersChanged(t){let e=[];for(let i of t){let n=this.remoteParticipants.get(i);n&&(n.startSpeaking(),e.push(n))}this.emit("activeSpeakersChanged",e)}simulateDataReceived(t,e,i,n){let s=this.remoteParticipants.get(e);this.emit("dataReceived",t,s,i,n)}};var D=class{constructor(t={}){this.rooms=new Map;this.participants=new Map;this.tracks=new Map;this.agents=new Map;this.messages=new Map;this.config=t,this.randomState=t.seed??Date.now()}updateConfig(t){this.config={...this.config,...t},t.seed!==void 0&&(this.randomState=t.seed)}getConfig(){return{...this.config}}random(){return this.randomState=(this.randomState*1103515245+12345)%2147483648,this.randomState/2147483648}createRoom(t,e,i){let n=g("room"),s=new Date().toISOString(),d={id:n,name:t,groupId:e||g("group"),createdAt:s,metadata:i,isActive:!0,participantIds:[],connectionState:"disconnected",wsURL:Z(n),token:T(n,"pending",s)};return this.rooms.set(n,d),this.messages.set(n,[]),d}getRoom(t){return this.rooms.get(t)}getRoomByName(t){for(let e of this.rooms.values())if(e.name===t)return e}listRooms(t=!1){let e=Array.from(this.rooms.values());return t?e.filter(i=>i.isActive):e}updateRoomConnectionState(t,e){let i=this.rooms.get(t);if(!i)return;let n=i.connectionState;return i.connectionState=e,n}endRoom(t){let e=this.rooms.get(t);if(!e||!e.isActive)return!1;e.isActive=!1,e.endedAt=new Date().toISOString(),e.connectionState="disconnected";for(let i of e.participantIds){let n=this.participants.get(i);n&&(n.isConnected=!1)}for(let i of this.agents.values())i.roomId===t&&i.status==="running"&&(i.status="stopped",i.stoppedAt=new Date().toISOString());return!0}deleteRoom(t){let e=this.rooms.get(t);if(!e)return!1;for(let i of e.participantIds)this.participants.delete(i);for(let[i,n]of this.tracks)n.roomId===t&&this.tracks.delete(i);for(let[i,n]of this.agents)n.roomId===t&&this.agents.delete(i);return this.messages.delete(t),this.rooms.delete(t),!0}addParticipant(t,e,i,n="user",s="standard",d=!1){let o=this.rooms.get(t);if(!o)return this.createError("ROOM_NOT_FOUND",`Room ${t} not found`);if(!o.isActive)return this.createError("ROOM_ENDED",`Room ${t} has ended`);let c=this.participants.get(e);if(c&&c.roomId===t&&c.isConnected)return this.config.strictMode?this.createError("PARTICIPANT_ALREADY_JOINED",`Participant ${e} is already in room ${t}`):c;let a={identity:e,name:i||e,roomId:t,joinedAt:new Date().toISOString(),isConnected:!0,trackIds:[],role:n,attributes:{},kind:s,isLocal:d};return this.participants.set(e,a),o.participantIds.push(e),a}getParticipant(t){return this.participants.get(t)}listParticipants(t,e=!0){let i=this.rooms.get(t);if(!i)return[];let n=[];for(let s of i.participantIds){let d=this.participants.get(s);d&&(!e||d.isConnected)&&n.push(d)}return n}updateParticipantAttributes(t,e){let i=this.participants.get(t);if(!i)return;let n={...i.attributes};return i.attributes={...i.attributes,...e},n}removeParticipant(t){let e=this.participants.get(t);if(!e)return;e.isConnected=!1;for(let n of e.trackIds)this.tracks.delete(n);e.trackIds=[];let i=this.rooms.get(e.roomId);if(i){let n=i.participantIds.indexOf(t);n!==-1&&i.participantIds.splice(n,1)}return e}publishTrack(t,e,i="unknown",n){let s=this.participants.get(t);if(!s)return this.createError("PARTICIPANT_NOT_FOUND",`Participant ${t} not found`);if(!s.isConnected)return this.createError("INVALID_OPERATION",`Participant ${t} is not connected`);let d=this.rooms.get(s.roomId);if(!d||!d.isActive)return this.createError("ROOM_ENDED","Room is not active");let o=g("track"),c={id:o,kind:e,source:i,participantIdentity:t,roomId:s.roomId,publishedAt:new Date().toISOString(),muted:!1,metadata:n};return this.tracks.set(o,c),s.trackIds.push(o),c}getTrack(t){return this.tracks.get(t)}listTracks(t,e){let i=[];for(let n of this.tracks.values())t&&n.roomId!==t||e&&n.participantIdentity!==e||i.push(n);return i}unpublishTrack(t){let e=this.tracks.get(t);if(!e)return;let i=this.participants.get(e.participantIdentity);if(i){let n=i.trackIds.indexOf(t);n!==-1&&i.trackIds.splice(n,1)}return this.tracks.delete(t),e}setTrackMuted(t,e){let i=this.tracks.get(t);return i?(i.muted=e,!0):!1}startAgent(t,e,i={}){let n=this.rooms.get(t);if(!n)return this.createError("ROOM_NOT_FOUND",`Room ${t} not found`);if(!n.isActive)return this.createError("ROOM_ENDED",`Room ${t} has ended`);let s=g("agent"),d={id:s,roomId:t,name:e,status:"running",startedAt:new Date().toISOString(),config:{responseStrategy:"echo",...i},messageHistory:[]};return this.agents.set(s,d),this.addParticipant(t,`agent_${s}`,e,"agent","agent",!1),d}getAgent(t){return this.agents.get(t)}listAgents(t){let e=[];for(let i of this.agents.values())i.roomId===t&&e.push(i);return e}stopAgent(t){let e=this.agents.get(t);if(e)return e.status="stopped",e.stoppedAt=new Date().toISOString(),this.removeParticipant(`agent_${t}`),e}updateAgentStatus(t,e){let i=this.agents.get(t);return i?(i.status=e,e==="stopped"&&(i.stoppedAt=new Date().toISOString()),!0):!1}addAgentMessage(t,e,i){let n=this.agents.get(t);if(!n)return;let s={id:g("msg"),content:e,role:i,timestamp:new Date().toISOString()};return n.messageHistory.push(s),s}addMessage(t,e,i,n="standard",s){if(!this.rooms.get(t))return this.createError("ROOM_NOT_FOUND",`Room ${t} not found`);let o={id:g("msg"),roomId:t,content:i,participantIdentity:e,createdAt:new Date().toISOString(),type:n,attributes:s},c=this.messages.get(t)||[];return c.push(o),this.messages.set(t,c),o}getMessages(t,e){let i=this.messages.get(t)||[];return e?i.slice(-e):i}createError(t,e,i){return{code:t,message:e,details:i}}isError(t){return typeof t=="object"&&t!==null&&"code"in t&&"message"in t}reset(){this.rooms.clear(),this.participants.clear(),this.tracks.clear(),this.agents.clear(),this.messages.clear(),this.randomState=this.config.seed??Date.now()}getSnapshot(){return{rooms:new Map(this.rooms),participants:new Map(this.participants),tracks:new Map(this.tracks),agents:new Map(this.agents),messages:new Map(this.messages),config:{...this.config},eventHistory:[]}}toJSON(){return{rooms:Object.fromEntries(this.rooms),participants:Object.fromEntries(this.participants),tracks:Object.fromEntries(this.tracks),agents:Object.fromEntries(this.agents),messages:Object.fromEntries(this.messages),config:this.config,eventHistory:[],exportedAt:new Date().toISOString()}}fromJSON(t){this.rooms=new Map(Object.entries(t.rooms)),this.participants=new Map(Object.entries(t.participants)),this.tracks=new Map(Object.entries(t.tracks)),this.agents=new Map(Object.entries(t.agents)),this.messages=new Map(Object.entries(t.messages).map(([e,i])=>[e,i])),this.config=t.config}};var nt=class{constructor(t={}){this.messageListeners=new Set;this.typingListeners=new Set;this.callRequestListeners=new Map;this._authToken=null;this._registeredUser=null;this.agents=new Map;this.config={latencyMs:t.latencyMs??0,strictMode:t.strictMode??!1,seed:t.seed,scenario:t.scenario,errorConfig:t.errorConfig,autoEmitEvents:t.autoEmitEvents??!0,organizationId:t.organizationId??"mock_org",apiUrl:t.apiUrl??"https://mock-livekit.local"},this.state=new D(this.config),this.events=new L,this.room=new A(this),this.config.scenario&&this.applyScenario(this.config.scenario)}get authToken(){return this._authToken}get registeredUser(){return this._registeredUser}getState(){return this.state}getEvents(){return this.events}updateConfig(t){this.config={...this.config,...t},this.state.updateConfig(t)}getConfig(){return{...this.config}}async simulateLatency(){this.config.latencyMs&&this.config.latencyMs>0&&await new Promise(t=>setTimeout(t,this.config.latencyMs))}applyScenario(t){switch(t){case"happy_path":this.config.errorConfig={},this.config.latencyMs=0;break;case"slow_network":this.config.latencyMs=500;break;case"network_unstable":this.config.errorConfig={errorRate:30};break;default:break}}shouldThrowError(){return this.config.errorConfig?.errorRate?this.state.random()*100<this.config.errorConfig.errorRate:!1}ensureRoom(){return this.room||(this.room=new A(this)),this.room}async registerUser(t,e,i,n){if(await this.simulateLatency(),this.config.errorConfig?.unauthorized)throw new u("UNAUTHORIZED","Registration failed");let s={id:g("user"),externalId:t,organizationId:this.config.organizationId,role:"user",token:T("pending",t,new Date().toISOString())};return this._authToken=s.token,this._registeredUser=s,this.room.localParticipant.identity=t,this.room.localParticipant.name=i?.name||t,s}async registerAgent(t,e){if(await this.simulateLatency(),this.config.errorConfig?.unauthorized)throw new u("UNAUTHORIZED","Agent registration failed");let i=T("agent",t,new Date().toISOString());return this._authToken=i,this.room.localParticipant.identity=t,this.room.localParticipant.name=e.name,i}async createRoom(t,e={}){if(await this.simulateLatency(),this.config.errorConfig?.networkError||this.shouldThrowError())throw new u("NETWORK_ERROR","Failed to create room");let i=this.state.createRoom(`room_${Date.now()}`,t.affinity?.agentId,t.metadata);this.room.id=i.id,this.room.groupId=i.groupId,this.room.createdAt=i.createdAt,this.room.connectedAt=new Date().toISOString();let n=this.room.localParticipant.identity||"local_user";return this.state.addParticipant(i.id,n,this.room.localParticipant.name,"user","standard",!0),Object.keys(e).length>0&&(this.state.updateParticipantAttributes(n,e),this.room.localParticipant.setAttributes(e)),this.state.updateRoomConnectionState(i.id,"connected"),this.config.autoEmitEvents&&(this.events.emitRoomCreated(i),this.events.emitRoomConnectionStateChanged(i.id,"connected","disconnected")),(t.affinity?.agentId||t.affinity?.agentType)&&await this.startMockAgent(i.id,{type:t.affinity?.agentType,nature:t.affinity?.nature??"ai"}),await this.room.connect(i.wsURL,i.token),this.room}async joinRoom(t,e,i,n){await this.simulateLatency();let s=this.state.getRoom(t);if(!s)throw new v(t);if(!s.isActive)throw new u("ROOM_ENDED",`Room ${t} has ended`);this.room.id=s.id,this.room.groupId=s.groupId,this.room.createdAt=s.createdAt,this.room.connectedAt=new Date().toISOString();let d=this.room.localParticipant.identity||"local_user",o=this.state.addParticipant(t,d,this.room.localParticipant.name,"user","standard",!0);if(y(o))throw O(o);if(n){let c={};for(let[a,l]of Object.entries(n))c[a]=String(l);this.state.updateParticipantAttributes(d,c)}return this.state.updateRoomConnectionState(t,"connected"),this.config.autoEmitEvents&&(this.events.emitParticipantJoined(t,o),this.events.emitRoomConnectionStateChanged(t,"connected","disconnected")),await this.room.connect(s.wsURL,s.token),this.room}async evaluateRoom(t){await this.simulateLatency();let e=t.roomId||this.room?.id;if(!e)throw new u("ROOM_NOT_FOUND","No room to evaluate");let i=this.state.getRoom(e);if(!i)throw new v(e);i.metadata||(i.metadata={}),i.metadata.evaluation={rating:t.rating,comment:t.comment,evaluatedAt:new Date().toISOString()}}async closeRoom(){await this.simulateLatency(),this.room?.id&&(this.state.endRoom(this.room.id),await this.stopLocalTracks(),this.config.autoEmitEvents&&this.events.emitRoomEnded(this.room.id))}async disconnect(){if(this.room){let t=this.room.id,e=this.room.localParticipant.identity;await this.stopLocalTracks(),this.state.removeParticipant(e),this.config.autoEmitEvents&&t&&this.events.emitParticipantLeft(t,e),this.room.removeAllListeners(),await this.room.disconnect()}}async stopLocalTracks(){let t=this.room?.localParticipant;t&&await Promise.all([t.setCameraEnabled(!1),t.setMicrophoneEnabled(!1),t.setScreenShareEnabled(!1)])}async disconnectAndCloseRoom(){await this.closeRoom(),await this.disconnect()}async readRoom(t){await this.simulateLatency();let e=this.state.getRoom(t);if(!e)throw new v(t);e.metadata||(e.metadata={}),e.metadata.lastReadAt=new Date().toISOString()}async getRooms(t){await this.simulateLatency();let e=this.state.listRooms();t.roomStatus==="active"?e=e.filter(o=>o.isActive):t.roomStatus==="closed"&&(e=e.filter(o=>!o.isActive)),t.ids?.length&&(e=e.filter(o=>t.ids.includes(o.id))),t.groupId&&(e=e.filter(o=>o.groupId===t.groupId));let i=t.offset??0,n=t.limit??20;return{items:e.slice(i,i+n).map(o=>({id:o.id,name:o.name,groupId:o.groupId,organizationId:this.config.organizationId,endedAt:o.endedAt??null,createdAt:o.createdAt,updatedAt:o.createdAt,status:o.isActive?"active":"ended",participants:this.state.listParticipants(o.id).map(c=>({id:c.identity,name:c.name||c.identity,role:c.role,isLocal:c.isLocal})),evaluations:[],_count:{messages:this.state.getMessages(o.id).length,participants:o.participantIds.length}})),count:e.length,limit:n,offset:i}}async sendMessage(t,e){if(await this.simulateLatency(),!this.room?.id)throw new u("INVALID_OPERATION","Not connected to a room");let i=this.state.addMessage(this.room.id,this.room.localParticipant.identity,t,"standard",e);if(y(i))throw O(i);let n={id:i.id,timestamp:Date.now(),message:t,content:t,createdAt:i.createdAt,from:{identity:this.room.localParticipant.identity,name:this.room.localParticipant.name,id:this.room.localParticipant.identity,role:"user"}};for(let s of this.messageListeners)s([n]);this.config.autoEmitEvents&&this.events.emitMessageSent(this.room.id,i);for(let s of this.agents.values())s.isRunning&&s.roomId===this.room.id&&this.triggerAgentResponse(s,t)}async persistMessage(t){await this.simulateLatency();let e=this.state.addMessage(t.roomId,t.identity||"system",t.content);if(y(e))throw O(e);return{items:[{id:e.id,timestamp:Date.now(),message:e.content,content:e.content,createdAt:e.createdAt}],count:1,limit:1,offset:0}}async getMessages(t){await this.simulateLatency();let e=t.roomId||this.room?.id;return e?this.state.getMessages(e,t.limit).map(n=>({id:n.id,timestamp:Date.parse(n.createdAt),message:n.content,content:n.content,createdAt:n.createdAt,from:{identity:n.participantIdentity,id:n.participantIdentity,role:"user"}})):[]}async sendMessageReport(t){await this.simulateLatency()}async deleteMessageReport(t){await this.simulateLatency()}async updateMessageReactions(t){await this.simulateLatency()}subscribeMessages(t){return this.messageListeners.add(t),()=>{this.messageListeners.delete(t)}}async sendTypingIndicator(t){if(!this.room?.id)return;let e={type:"typing",isTyping:t,timestamp:Date.now(),participantId:this.room.localParticipant.identity};for(let i of this.typingListeners)i(e);this.config.autoEmitEvents&&this.events.emitTypingIndicator(this.room.id,this.room.localParticipant.identity,t)}subscribeTypingIndicators(t){return this.typingListeners.add(t),()=>this.typingListeners.delete(t)}unsubscribeTypingIndicators(t){this.typingListeners.delete(t)}async sendContextualEvent(t){await this.simulateLatency()}async requestNewRoom(t){await this.simulateLatency();let e=this.state.createRoom(`transfer_${Date.now()}`,void 0,{originRoom:t.originRoom});return{id:e.id,groupId:e.groupId,token:e.token,wsURL:e.wsURL,createdAt:e.createdAt}}async confirmRoomRequest(t){return await this.simulateLatency(),{success:!0,message:"Request confirmed",roomId:t}}async cancelRoomRequest(t){return await this.simulateLatency(),{success:!0,message:"Request cancelled",roomId:t}}async finishCall(){await this.simulateLatency(),this.room?.id&&this.state.endRoom(this.room.id)}isFirebaseEnabled(){return!0}onPresenceChange(t){return()=>{}}onPresenceAgentChange(t,e){return()=>{}}async createCallRequest(t){return await this.simulateLatency(),g("call")}onNewCallRequest(t){return this.callRequestListeners.has("new")||this.callRequestListeners.set("new",new Set),this.callRequestListeners.get("new").add(t),()=>this.callRequestListeners.get("new")?.delete(t)}onCallRequestChange(t){return this.callRequestListeners.has("change")||this.callRequestListeners.set("change",new Set),this.callRequestListeners.get("change").add(t),()=>this.callRequestListeners.get("change")?.delete(t)}onCallRequestRemoved(t){return()=>{}}async acceptCallRequest(t){await this.simulateLatency()}async cancelCallRequest(t){await this.simulateLatency()}async cancelOnDisconnect(t){await this.simulateLatency()}subscribePendingRequests(t,e={}){return()=>{}}subscribeRequestChanges(t){return()=>{}}async tryAcceptRequest(t){return await this.simulateLatency(),!0}onRoomSync(t,e){return()=>{}}async clearRoomSync(t,e){await this.simulateLatency()}onNewRoomRequest(t,e){return()=>{}}unsubscribeAllFirebase(){this.callRequestListeners.clear()}async destroy(){this.unsubscribeAllFirebase(),this.messageListeners.clear(),this.typingListeners.clear(),await this.disconnect(),this.state.reset()}async startMockAgent(t,e){let i=e?.name||"AI Assistant",n=new I(g("agent"),i,{responseStrategy:e?.responseStrategy||"echo",responseDelayMs:e?.responseDelayMs||100,cannedResponses:e?.cannedResponses||[],type:e?.type,nature:e?.nature});await n.start(t),this.agents.set(n.id,n),this.customAgentHandler&&n.setCustomHandler((a,l)=>this.customAgentHandler(a,l));let s=e?.type,d=Array.isArray(s)?s:[s].filter(Boolean),o=d.includes("video"),c=d.includes("voice");return(o||c)&&this.room.isConnected&&await this.room.simulateParticipantJoin(n.id,{name:i,kind:"agent",withCamera:o,withMicrophone:c||o,attributes:{"lk.agent.name":i,"lk.agent.state":"active",role:"agent"}}),this.config.autoEmitEvents&&this.events.emitAgentStarted(t,{id:n.id,name:n.name,roomId:t,status:"running",config:n.getConfig(),startedAt:new Date().toISOString(),messageHistory:[]}),n.id}async stopMockAgent(t){let e=this.agents.get(t);if(e){let i=e.roomId;await e.stop(),this.agents.delete(t),this.config.autoEmitEvents&&i&&this.events.emitAgentStopped(i,t)}}setAgentResponseHandler(t){this.customAgentHandler=t;for(let e of this.agents.values())e.setCustomHandler((i,n)=>t(i,n))}async triggerAgentResponse(t,e){if(this.config.scenario!=="agent_timeout")try{let i=await t.processMessage(e);if(!i)return;let n=this.state.addMessage(t.roomId,`agent_${t.id}`,i);if(!y(n)){let s={id:n.id,timestamp:Date.now(),message:i,content:i,createdAt:n.createdAt,from:{identity:`agent_${t.id}`,name:t.name,id:t.id,role:"agent"}};for(let d of this.messageListeners)d([s]);this.config.autoEmitEvents&&this.events.emitMessageReceived(t.roomId,n)}}catch(i){console.error("Agent response error:",i)}}simulateCallRequest(t){let e={id:g("call"),guestId:t.guestId||"guest_user",name:t.name||"Guest User",createdAt:new Date().toISOString(),status:t.status||"pending",...t},i=this.callRequestListeners.get("new");if(i)for(let n of i)n(e.id,e)}simulateParticipantJoin(t,e,i="user"){if(!this.room?.id)return;let n=this.state.addParticipant(this.room.id,t,e,i,"standard",!1);!y(n)&&this.config.autoEmitEvents&&this.events.emitParticipantJoined(this.room.id,n)}simulateParticipantLeave(t){if(!this.room?.id)return;this.state.removeParticipant(t)&&this.config.autoEmitEvents&&this.events.emitParticipantLeft(this.room.id,t)}simulateIncomingMessage(t,e){if(!this.room?.id)return;let i=this.state.addMessage(this.room.id,t,e);if(y(i))return;let n={id:i.id,timestamp:Date.now(),message:e,content:e,createdAt:i.createdAt,from:{identity:t,id:t,role:"user"}};for(let s of this.messageListeners)s([n]);this.config.autoEmitEvents&&this.events.emitMessageReceived(this.room.id,i)}async simulateDisconnect(){if(!this.room?.id)return;let t=this.room.state;this.room.state="disconnected",this.config.autoEmitEvents&&this.events.emitRoomConnectionStateChanged(this.room.id,"disconnected",t),this.room.emit("connectionStateChanged","disconnected")}reset(){this.state.reset(),this.events.clearHistory(),this.messageListeners.clear(),this.typingListeners.clear(),this.callRequestListeners.clear(),this.agents.clear(),this._authToken=null,this._registeredUser=null,this.room=new A(this),Q()}seed(t){this.config.seed=t,this.state.updateConfig({seed:t})}setScenario(t){this.config.scenario=t,this.applyScenario(t)}exportState(){return{...this.state.toJSON(),eventHistory:this.events.getHistory()}}getEventHistory(t){return this.events.getHistory(t)}};export{nt as MockConversationService};
@@ -0,0 +1,2 @@
1
+ /*! @onlive.ai/common-121 v0.2.179 | © 2026 Onlive.ai */
2
+ "use strict";var qt=Object.defineProperty;var $t=(n,t)=>()=>(n&&(t=n(n=0)),t);var jt=(n,t)=>{for(var e in t)qt(n,e,{get:t[e],enumerable:!0})};var q={};jt(q,{SYNTHETIC_MEDIA_PRESETS:()=>St,createSyntheticAudioTrack:()=>yt,createSyntheticMedia:()=>Mt,createSyntheticMediaFromPreset:()=>_t,createSyntheticVideoTrack:()=>vt});function vt(n={}){let{width:t=640,height:e=480,fps:i=30,backgroundColor:s="#1a1a2e",foregroundColor:o="#4361ee",label:c="Mock Video",animation:a="wave"}=n,l=document.createElement("canvas");l.width=t,l.height=e;let g=l.getContext("2d"),h,D=Date.now(),W={wave:R=>{g.fillStyle=s,g.fillRect(0,0,t,e),g.strokeStyle=o,g.lineWidth=3,g.beginPath();for(let k=0;k<t;k++){let M=e/2+Math.sin(k/t*4*Math.PI+R*.002)*(e/4);k===0?g.moveTo(k,M):g.lineTo(k,M)}g.stroke()},pulse:R=>{g.fillStyle=s,g.fillRect(0,0,t,e);let k=Math.sin(R*.003)*.3+.7,M=Math.min(t,e)*.3*k;g.beginPath(),g.arc(t/2,e/2,M,0,Math.PI*2),g.fillStyle=o,g.fill()},bars:R=>{g.fillStyle=s,g.fillRect(0,0,t,e);let k=20,M=t/k,L=e*.7;g.fillStyle=o;for(let j=0;j<k;j++){let Pt=Math.abs(Math.sin(j/k*Math.PI*2+R*.004))*L,Nt=j*M,zt=e-Pt;g.fillRect(Nt+2,zt,M-4,Pt)}},avatar:R=>{g.fillStyle=s,g.fillRect(0,0,t,e);let k=t/2,M=e/2-20,L=Math.min(t,e)*.15;g.beginPath(),g.arc(k,M,L,0,Math.PI*2),g.fillStyle=o,g.fill(),g.beginPath(),g.ellipse(k,M+L*2.2,L*1.5,L,0,Math.PI,0),g.fill(),Math.sin(R*.01)>0&&(g.beginPath(),g.arc(k,M+L*3,5+Math.sin(R*.02)*3,0,Math.PI*2),g.fillStyle="#22c55e",g.fill())},none:()=>{g.fillStyle=s,g.fillRect(0,0,t,e)}},Q=()=>{g.fillStyle="rgba(255, 255, 255, 0.8)",g.font=`${Math.floor(e*.04)}px system-ui, sans-serif`,g.textAlign="center",g.fillText(c,t/2,e-20)},H=()=>{let R=Date.now()-D;W[a](R),Q(),h=requestAnimationFrame(H)};H();let Tt=l.captureStream(i),Ct=Tt.getVideoTracks()[0];return{track:Ct,stream:Tt,cleanup:()=>{cancelAnimationFrame(h),Ct.stop()}}}function yt(n={}){let{frequency:t=440,volume:e=.1,waveType:i="sine",addVariation:s=!0,enabled:o=!1}=n,c=new AudioContext,a=c.createMediaStreamDestination(),l=c.createOscillator();l.type=i,l.frequency.value=t;let g=c.createGain();g.gain.value=o?e:0;let h=null,D=null;s&&(h=c.createOscillator(),h.frequency.value=.5,D=c.createGain(),D.gain.value=10,h.connect(D),D.connect(l.frequency),h.start()),l.connect(g),g.connect(a),l.start();let W=a.stream,Q=W.getAudioTracks()[0];return{track:Q,stream:W,setVolume:H=>{g.gain.value=Math.max(0,Math.min(1,H))},setEnabled:H=>{g.gain.value=H?e:0},cleanup:()=>{l.stop(),h?.stop(),c.close(),Q.stop()}}}function Mt(n,t){let e=vt(n),i=yt(t),s=new MediaStream([e.track,i.track]);return{videoTrack:e.track,audioTrack:i.track,combinedStream:s,setAudioVolume:i.setVolume,setAudioEnabled:i.setEnabled,cleanup:()=>{e.cleanup(),i.cleanup()}}}function _t(n){let t=St[n];return Mt(t.video,t.audio)}var St,U=$t(()=>{"use strict";St={localCamera:{video:{width:640,height:480,animation:"avatar",label:"You",foregroundColor:"#4361ee"},audio:{enabled:!1}},agentCamera:{video:{width:640,height:480,animation:"avatar",label:"AI Agent",foregroundColor:"#22c55e",backgroundColor:"#0f172a"},audio:{enabled:!1,frequency:300}},screenShare:{video:{width:1920,height:1080,animation:"bars",label:"Screen Share",backgroundColor:"#0a0a0a",foregroundColor:"#f59e0b"},audio:{enabled:!1}},voiceOnly:{video:{width:320,height:240,animation:"wave",label:"Voice Call"},audio:{enabled:!1,volume:.05}}}});var r=require("vitest");var ht=0;function B(){ht=0}function u(n){return ht++,`mock_${n}_${ht}_${Date.now().toString(36)}`}function A(n,t,e){let i=e||new Date().toISOString(),s=typeof btoa=="function"?btoa(i).replace(/\+/g,"-").replace(/\//g,"_").replace(/=+$/,""):i.replace(/[^a-zA-Z0-9]/g,"");return`mock_token_${n}_${t}_${s}`}function F(n){return`wss://mock-livekit.local/room/${n}`}var X={responseStrategy:"echo",responseDelayMs:100,cannedResponses:[],type:"text",nature:"ai",simulateTyping:!1,typingDelayPerChar:20};function Y(n,t,e=[],i=0,s=Math.random){switch(n){case"echo":return{response:`Echo: ${t}`,nextIndex:i};case"canned":return{response:e[0]||"Default response",nextIndex:i};case"sequential":return{response:e[i]||"No more responses",nextIndex:(i+1)%Math.max(1,e.length)};case"random":{if(e.length===0)return{response:"Random response",nextIndex:i};let o=Math.floor(s()*e.length);return{response:e[o],nextIndex:i}}case"silent":return{response:"",nextIndex:i};case"error":throw new Error("Agent error");case"custom":return{response:"",nextIndex:i};default:return{response:"Default agent response",nextIndex:i}}}var N=class{constructor(t,e,i={}){this._state="idle";this.conversationHistory=[];this.responseIndex=0;this.eventListeners=new Set;this.randomFn=Math.random;this.messageCount=0;this.id=t,this.name=e,this.config={...X,...i}}get state(){return this._state}get isRunning(){return this._state==="running"}get history(){return[...this.conversationHistory]}getConfig(){return{...this.config}}updateConfig(t){this.config={...this.config,...t}}setStrategy(t){this.config.responseStrategy=t}setCannedResponses(t){this.config.cannedResponses=t,this.responseIndex=0}setCustomHandler(t){this.customHandler=t,this.config.responseStrategy="custom"}setRandomFunction(t){this.randomFn=t}async start(t){this._state!=="running"&&(this._state="starting",this.roomId=t,this.conversationHistory=[],this.responseIndex=0,this.messageCount=0,await this.delay(50),this._state="running",this.emitEvent({type:"started",agentId:this.id}))}async stop(){this._state==="running"&&(this._state="stopping",await this.delay(50),this._state="stopped",this.roomId=void 0,this.emitEvent({type:"stopped",agentId:this.id}))}async processMessage(t){if(this._state!=="running")throw new Error("Agent is not running");if(this.config.maxMessages&&this.messageCount>=this.config.maxMessages)return await this.stop(),"";this.addMessage(t,"user"),this.emitEvent({type:"message_received",agentId:this.id,message:t});let e;try{if(this.config.responseStrategy==="custom"&&this.customHandler)e=await this.customHandler(this.id,t,this.conversationHistory);else{if(this.config.responseStrategy==="silent")return"";if(this.config.responseStrategy==="error"){let i=new Error("Agent error");throw this.emitEvent({type:"error",agentId:this.id,error:i}),i}else{let i=Y(this.config.responseStrategy,t,this.config.cannedResponses,this.responseIndex,this.randomFn);e=i.response,this.responseIndex=i.nextIndex}}}catch(i){throw this._state="error",i}return this.config.simulateTyping&&this.config.typingDelayPerChar&&await this.delay(e.length*this.config.typingDelayPerChar),this.config.responseDelayMs&&await this.delay(this.config.responseDelayMs),this.addMessage(e,"agent"),this.messageCount++,this.emitEvent({type:"response_sent",agentId:this.id,response:e}),e}addEventListener(t){return this.eventListeners.add(t),()=>this.eventListeners.delete(t)}clearHistory(){this.conversationHistory=[],this.responseIndex=0}reset(){this._state="idle",this.roomId=void 0,this.conversationHistory=[],this.responseIndex=0,this.messageCount=0}toJSON(){return{id:this.id,name:this.name,state:this._state,roomId:this.roomId,config:this.config,historyLength:this.conversationHistory.length,messageCount:this.messageCount}}addMessage(t,e){let i={id:u("msg"),content:t,role:e,timestamp:Date.now()};return this.conversationHistory.push(i),i}emitEvent(t){for(let e of this.eventListeners)try{e(t)}catch(i){console.error("Error in agent event listener:",i)}}delay(t){return new Promise(e=>setTimeout(e,t))}};var m=class n extends Error{constructor(t,e,i){super(e),this.name="MockLiveKitError",this.code=t,this.details=i,typeof Error.captureStackTrace=="function"&&Error.captureStackTrace(this,n)}toMockError(){return{code:this.code,message:this.message,details:this.details}}static fromMockError(t){return new n(t.code,t.message,t.details)}},w=class extends m{constructor(t){super("ROOM_NOT_FOUND",`Room not found: ${t}`,{roomId:t}),this.name="RoomNotFoundError"}},Z=class extends m{constructor(t){super("ROOM_ENDED",`Room has ended: ${t}`,{roomId:t}),this.name="RoomEndedError"}},tt=class extends m{constructor(t,e){super("PARTICIPANT_ALREADY_JOINED",`Participant ${t} is already in room ${e}`,{identity:t,roomId:e}),this.name="ParticipantAlreadyJoinedError"}},et=class extends m{constructor(t){super("PARTICIPANT_NOT_FOUND",`Participant not found: ${t}`,{identity:t}),this.name="ParticipantNotFoundError"}},it=class extends m{constructor(t){super("TRACK_NOT_FOUND",`Track not found: ${t}`,{trackId:t}),this.name="TrackNotFoundError"}},nt=class extends m{constructor(t){super("AGENT_NOT_FOUND",`Agent not found: ${t}`,{agentId:t}),this.name="AgentNotFoundError"}},st=class extends m{constructor(t="Unauthorized"){super("UNAUTHORIZED",t),this.name="UnauthorizedError"}},rt=class extends m{constructor(t="Network error occurred"){super("NETWORK_ERROR",t),this.name="NetworkError"}},ot=class extends m{constructor(t,e){super("INVALID_OPERATION",t,e),this.name="InvalidOperationError"}},at=class extends m{constructor(t,e){super("TIMEOUT",`Operation timed out: ${t}`,{operation:t,timeoutMs:e}),this.name="TimeoutError"}};function K(n){switch(n.code){case"ROOM_NOT_FOUND":return new w(n.details?.roomId??"unknown");case"ROOM_ENDED":return new Z(n.details?.roomId??"unknown");case"PARTICIPANT_ALREADY_JOINED":return new tt(n.details?.identity??"unknown",n.details?.roomId??"unknown");case"PARTICIPANT_NOT_FOUND":return new et(n.details?.identity??"unknown");case"TRACK_NOT_FOUND":return new it(n.details?.trackId??"unknown");case"AGENT_NOT_FOUND":return new nt(n.details?.agentId??"unknown");case"UNAUTHORIZED":return new st(n.message);case"NETWORK_ERROR":return new rt(n.message);case"INVALID_OPERATION":return new ot(n.message,n.details);case"TIMEOUT":return new at(n.details?.operation??"unknown",n.details?.timeoutMs??0);default:return m.fromMockError(n)}}function I(n){return typeof n=="object"&&n!==null&&"code"in n&&"message"in n&&typeof n.code=="string"&&typeof n.message=="string"}var V=class{constructor(){this.listeners={};this.wildcardListeners=new Set;this.eventHistory=[];this.maxHistorySize=1e3;this.recordHistory=!0}setMaxHistorySize(t){this.maxHistorySize=t,this.trimHistory()}setRecordHistory(t){this.recordHistory=t}on(t,e){return this.listeners[t]||(this.listeners[t]=new Set),this.listeners[t].add(e),()=>{this.off(t,e)}}once(t,e){let i=s=>{this.off(t,i),e(s)};return this.on(t,i)}off(t,e){this.listeners[t]?.delete(e)}onAny(t){return this.wildcardListeners.add(t),()=>{this.wildcardListeners.delete(t)}}offAny(t){this.wildcardListeners.delete(t)}removeAllListeners(t){t?delete this.listeners[t]:(this.listeners={},this.wildcardListeners.clear())}emit(t){this.recordHistory&&(this.eventHistory.push(t),this.trimHistory());let e=this.listeners[t.type];if(e)for(let i of e)try{i(t)}catch(s){console.error(`Error in mock event listener for ${t.type}:`,s)}for(let i of this.wildcardListeners)try{i(t)}catch(s){console.error("Error in mock wildcard event listener:",s)}}trimHistory(){this.eventHistory.length>this.maxHistorySize&&(this.eventHistory=this.eventHistory.slice(-this.maxHistorySize))}emitRoomCreated(t){let e={type:"roomCreated",timestamp:new Date().toISOString(),roomId:t.id,room:t};this.emit(e)}emitRoomEnded(t){let e={type:"roomEnded",timestamp:new Date().toISOString(),roomId:t};this.emit(e)}emitRoomConnectionStateChanged(t,e,i){let s={type:"roomConnectionStateChanged",timestamp:new Date().toISOString(),roomId:t,state:e,previousState:i};this.emit(s)}emitParticipantJoined(t,e){let i={type:"participantJoined",timestamp:new Date().toISOString(),roomId:t,participant:e};this.emit(i)}emitParticipantLeft(t,e){let i={type:"participantLeft",timestamp:new Date().toISOString(),roomId:t,participantIdentity:e};this.emit(i)}emitParticipantAttributesChanged(t,e,i,s){let o={type:"participantAttributesChanged",timestamp:new Date().toISOString(),roomId:t,participantIdentity:e,attributes:i,previousAttributes:s};this.emit(o)}emitTrackPublished(t,e,i){let s={type:"trackPublished",timestamp:new Date().toISOString(),roomId:t,participantIdentity:e,track:i};this.emit(s)}emitTrackUnpublished(t,e,i){let s={type:"trackUnpublished",timestamp:new Date().toISOString(),roomId:t,participantIdentity:e,trackId:i};this.emit(s)}emitTrackMuted(t,e){let i={type:"trackMuted",timestamp:new Date().toISOString(),roomId:t,trackId:e};this.emit(i)}emitTrackUnmuted(t,e){let i={type:"trackUnmuted",timestamp:new Date().toISOString(),roomId:t,trackId:e};this.emit(i)}emitMessageReceived(t,e){let i={type:"messageReceived",timestamp:new Date().toISOString(),roomId:t,message:e};this.emit(i)}emitMessageSent(t,e){let i={type:"messageSent",timestamp:new Date().toISOString(),roomId:t,message:e};this.emit(i)}emitTypingIndicator(t,e,i){let s={type:"typingIndicator",timestamp:new Date().toISOString(),roomId:t,participantIdentity:e,isTyping:i};this.emit(s)}emitAgentStarted(t,e){let i={type:"agentStarted",timestamp:new Date().toISOString(),roomId:t,agent:e};this.emit(i)}emitAgentStopped(t,e){let i={type:"agentStopped",timestamp:new Date().toISOString(),roomId:t,agentId:e};this.emit(i)}emitAgentMessage(t,e,i){let s={type:"agentMessage",timestamp:new Date().toISOString(),roomId:t,agentId:e,message:i};this.emit(s)}emitDataReceived(t,e,i,s){let o={type:"dataReceived",timestamp:new Date().toISOString(),roomId:t,participantIdentity:e,data:i,topic:s};this.emit(o)}emitError(t,e){let i={type:"error",timestamp:new Date().toISOString(),roomId:e,error:t};this.emit(i)}getHistory(t){return t?this.eventHistory.filter(e=>e.type===t):[...this.eventHistory]}getLastEvents(t,e){return(e?this.eventHistory.filter(s=>s.type===e):this.eventHistory).slice(-t)}clearHistory(){this.eventHistory=[]}listenerCount(t){return(this.listeners[t]?.size??0)+this.wildcardListeners.size}};var gt=require("@onlive.ai/tracker"),z=require("livekit-client");var At=require("firebase/app"),d=require("firebase/database"),ct=class{constructor(t){this.onChildChanged=(t,e)=>(0,d.onChildChanged)(this.ref(t),i=>e(i.key||"",i.val(),i));this.onChildRemoved=(t,e)=>(0,d.onChildRemoved)(this.ref(t),i=>e(i.key||"",i.val(),i));this.onChildChangedQuery=(t,e)=>(0,d.onChildChanged)(t,i=>e(i.key||"",i.val(),i));this.onChildRemovedQuery=(t,e)=>(0,d.onChildRemoved)(t,i=>e(i.key||"",i.val(),i));let e=(0,At.initializeApp)(t.config);this.db=(0,d.getDatabase)(e)}ref(t){return(0,d.ref)(this.db,t)}async getOnce(t){let e=await(0,d.get)(this.ref(t));return e.exists()?e.val():null}async getOnceQuery(t){let e=await(0,d.get)(t),i=[];return e.exists()&&e.forEach(s=>{i.push({key:s.key||"",value:s.val()})}),i}onValue(t,e){return(0,d.onValue)(this.ref(t),i=>e(i.key??"",i.val(),i),i=>console.error("onValue error",i))}onValueQuery(t,e){return(0,d.onValue)(t,i=>e(i.key??"",i.val(),i),i=>console.error("onValueQuery error",i))}onChildAdded(t,e){return(0,d.onChildAdded)(this.ref(t),i=>e(i.key||"",i.val(),i),i=>console.error("onChildAdded error",i))}onChildAddedQuery(t,e){return(0,d.onChildAdded)(t,i=>e(i.key||"",i.val(),i),i=>console.error("onChildAddedQuery error",i))}write(t,e){return(0,d.set)(this.ref(t),e)}update(t,e){return(0,d.update)(this.ref(t),e)}remove(t){return(0,d.remove)(this.ref(t))}async push(t,e){let i=(0,d.push)(this.ref(t));return await(0,d.set)(i,e),i.key}onDisconnectUpdate(t,e){return(0,d.onDisconnect)(this.ref(t)).update(e)}cancelOnDisconnect(t){return(0,d.onDisconnect)(this.ref(t)).cancel()}transaction(t,e){return(0,d.runTransaction)(this.ref(t),i=>e(i))}query(t,e={}){let i=this.ref(t);return e.orderBy==="child"&&e.childKey&&(i=(0,d.query)(i,(0,d.orderByChild)(e.childKey))),e.orderBy==="key"&&(i=(0,d.query)(i,(0,d.orderByKey)())),e.orderBy==="value"&&(i=(0,d.query)(i,(0,d.orderByValue)())),e.startAt!=null&&(i=(0,d.query)(i,(0,d.startAt)(e.startAt))),e.endAt!=null&&(i=(0,d.query)(i,(0,d.endAt)(e.endAt))),e.equalTo!=null&&(i=(0,d.query)(i,(0,d.equalTo)(e.equalTo))),e.limitFirst!=null&&(i=(0,d.query)(i,(0,d.limitToFirst)(e.limitFirst))),e.limitLast!=null&&(i=(0,d.query)(i,(0,d.limitToLast)(e.limitLast))),i}};var p=async(n,t)=>{let e=await fetch(n,t);if(!e.ok){let i=await e.json().catch(()=>({}));throw new Error(JSON.stringify({status:e.status,statusText:e.statusText,...i}))}return e&&e.json()};var It=n=>{let t="ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789",e="";for(let i=0;i<n;i++)e+=t.charAt(Math.floor(Math.random()*t.length));return e};var v=require("@onlive.ai/tracker"),E="chatbot",dt=class n{static hasSession(){return!!v.Session.getCookie(E)}static getSession(t={role:"guest",regenerate:!1}){t.regenerate&&(v.Session.id=v.Generator.uuid(),v.Session.deleteCookie(E));let e=v.Session.getCookie(E);return e&&n.isValidSession(e,t.role)?e:n.createSession(t.role)}static createSession(t){let e={externalId:t==="agent"?String(n.getUserId()||v.Session.id):v.Session.id,secret:It(16),createdAt:new Date().toISOString()};return v.Session.setCookie(E,e,3600*24*365),e}static isValidSession(t,e){if(e==="guest")return!0;let i=n.getUserId();return!!(i&&String(i)===t.externalId)}static getUserId(){return v.Session.getCookie("user-id",{objectKey:"userId",storageKey:"user",storageType:"localStorage",ttl:3600*24*365,preserveData:!0})}static updateSessionWithRegistrationData(t){let e=v.Session.getCookie(E);if(e||(e=n.createSession("guest")),e){let i={...e,registrationData:t};v.Session.setCookie(E,i,3600*24*365)}}static hasRegistrationData(){return!!v.Session.getCookie(E)?.registrationData}static async getAgentInfo(t){return fetch(`${t}/api/v1/auth/user-info`,{credentials:"include"}).then(e=>e.json())}static getRegistrationData(){return v.Session.getCookie(E)?.registrationData}};var Et="lk.chat",Ot="lk.transcription",xt="lk.events",kt="typing-indicator";var ft=class extends z.Room{},lt=class{constructor(t){this.listeners=new Set;this.typingListeners=new Set;this.transcriptionMap=new Map;this.abortControllers={register:new AbortController,createRoom:new AbortController,closeRoom:new AbortController,evaluateRoom:new AbortController,persistMessage:new AbortController,sendMessageReport:new AbortController,deleteMessageReport:new AbortController,updateMessageReactions:new AbortController,getRooms:new AbortController};this.authToken=null;this.firebaseUnsubscribers={};this.seenRequestIds=new Set;this.lastSnapshotById=new Map;this.handleIncomingMessage=async(t,e)=>{let i=t?.info?.id,s=t.info?.attributes?.["lk.segment_id"];s&&(this.transcriptionMap.has(s)?i=this.transcriptionMap.get(s)||"":this.transcriptionMap.set(s,i));let o=e?.identity?this.room.getParticipantByIdentity(e.identity):void 0,c="";for await(let a of t)c+=a,this.emitMessage({id:i,timestamp:Date.now(),message:c,assets:JSON.parse(t.info?.attributes?.assets||"[]"),from:o});this.messagePersistence==="client"&&this.persistMessage({roomId:this.room.id,content:c,externalId:i,identity:o?.identity,kind:o?.kind})};this.emitMessage=t=>{for(let e of this.listeners)e([t])};this.handleDataReceived=(t,e,i,s)=>{if(s===kt)try{let o=JSON.parse(new TextDecoder().decode(t));if(o.type==="typing"&&o.participantId!==this.room.localParticipant.identity){let c={type:"typing",isTyping:o.isTyping,timestamp:o.timestamp,participantId:o.participantId};this.emitTypingIndicator(c)}}catch(o){console.warn("Failed to parse typing indicator:",o)}};this.emitTypingIndicator=t=>{for(let e of this.typingListeners)e(t)};this.apiUrl=t.apiUrl,this.authUrl=t.authUrl,this.organizationId=t.organizationId,this.channelTopic=t.channelTopic||Et,this.transcriptionTopic=t.transcriptionTopic||Ot,this.eventsTopic=t.eventsTopic||xt,this.messagePersistence=t.messagePersistence||"disabled",this.room=this.createRoomInstance(),t.firebaseConfig&&this.initializeFirebase(t.firebaseConfig)}createRoomInstance(){return new ft({adaptiveStream:!0,dynacast:!0})}ensureRoom(){return this.room||(this.room=this.createRoomInstance()),this.room}initializeFirebase(t){this.firebaseApi=new ct({config:t}),this.presencePath=`orgs/${this.organizationId}/presence`,this.callsPath=`orgs/${this.organizationId}/calls`}initializeRoomHandlers(){try{this.room.unregisterTextStreamHandler(this.channelTopic),this.room.unregisterTextStreamHandler(this.transcriptionTopic)}catch{}this.room.off(z.RoomEvent.DataReceived,this.handleDataReceived),this.room.registerTextStreamHandler(this.channelTopic,this.handleIncomingMessage),this.room.registerTextStreamHandler(this.transcriptionTopic,this.handleIncomingMessage),this.room.on(z.RoomEvent.DataReceived,this.handleDataReceived)}async registerUser(t,e,i,s){let o=await p(`${this.apiUrl}/users/register`,{method:"POST",body:JSON.stringify({externalId:t,secret:e,...i,metadata:s}),headers:{"X-Onlive-Organization-Id":this.organizationId,"Content-Type":"application/json"},signal:this.abortControllers.register.signal});if(!o.token)throw new Error("Registration failed: No token received from server");return this.authToken=o.token,o}async registerAgent(t,e){let i=gt.Session.getCookie("livekit-agent-token");if(i){if(this.decodeJwtPayload(i)?.username===e.name)return this.authToken=i,i;gt.Session.deleteCookie("livekit-agent-token")}let s=await p(`${this.authUrl}/admins/register`,{method:"POST",body:JSON.stringify({externalId:t,name:e.name,email:e.email,avatar:e.avatar}),headers:{"X-Onlive-Organization-Id":this.organizationId,"Content-Type":"application/json"},credentials:"include",signal:this.abortControllers.register.signal});return gt.Session.setCookie("livekit-agent-token",s.token,1440*60),this.authToken=s.token,s.token}decodeJwtPayload(t){try{let e=t.split(".");if(e.length!==3)return null;let i=e[1],s=atob(i.replace(/-/g,"+").replace(/_/g,"/"));return JSON.parse(s)}catch{return null}}async createRoom(t){if(!this.authToken)throw new Error("Cannot create room: No authentication token. Call registerUser() first.");this.room=this.ensureRoom();let{initialMessage:e,...i}=t,s=await p(`${this.apiUrl}/rooms`,{method:"POST",body:JSON.stringify(i),headers:{Authorization:`Bearer ${this.authToken}`,"X-Onlive-Organization-Id":this.organizationId,"Content-Type":"application/json"},signal:this.abortControllers.createRoom.signal});return this.setRoomMetadata(s),this.setupParticipantAttributesHandler(),this.room.connect(s.wsURL,s.token).then(async()=>{if(e)try{await this.sendMessage(e)}catch(o){console.error("[ConversationService] Failed to send initial message:",o)}}),this.initializeRoomHandlers(),this.room}async joinRoom(t,e,i,s){let o=await p(`${this.apiUrl}/rooms/${t}/join`,{method:"POST",body:JSON.stringify({timezone:e,language:i,...s??{}}),headers:{Authorization:`Bearer ${this.authToken}`,"X-Onlive-Organization-Id":this.organizationId,"Content-Type":"application/json"},signal:this.abortControllers.createRoom.signal});return this.setRoomMetadata(o),this.setupParticipantAttributesHandler(),await this.room.connect(o.wsURL,o.token),this.initializeRoomHandlers(),this.room}setRoomMetadata(t){this.room.id=t.id,this.room.groupId=t.groupId,this.room.createdAt=t.createdAt,this.room.connectedAt=new Date().toISOString(),this.room.affinity=t.affinity}setupParticipantAttributesHandler(){this.room.on(z.RoomEvent.ParticipantAttributesChanged,t=>{t.identity===this.room.localParticipant.identity&&dt.updateSessionWithRegistrationData(t.attributes)})}async evaluateRoom(t){let e=t.roomId||this.room?.id;if(!e)throw new Error("Room ID is required for evaluation");return p(`${this.apiUrl}/rooms/${e}/evaluate`,{method:"POST",body:JSON.stringify({rating:t.rating,comment:t.comment}),headers:{Authorization:`Bearer ${this.authToken}`,"X-Onlive-Organization-Id":this.organizationId,"Content-Type":"application/json"},signal:this.abortControllers.evaluateRoom.signal})}async closeRoom(){this.room&&(await p(`${this.apiUrl}/rooms/${this.room.id}/close`,{method:"POST",headers:{Authorization:`Bearer ${this.authToken}`,"X-Onlive-Organization-Id":this.organizationId,"Content-Type":"application/json"},signal:this.abortControllers.closeRoom.signal}),await this.stopAndUnpublishLocalTracks())}async disconnect(){this.room&&(await this.stopAndUnpublishLocalTracks(),this.room.removeAllListeners(),await this.room.disconnect(),this.room=null)}async stopAndUnpublishLocalTracks(){let t=this.room?.localParticipant;if(!t)return;await Promise.allSettled([t.setMicrophoneEnabled(!1),t.setCameraEnabled(!1),t.setScreenShareEnabled(!1)]);let e=Array.from(t.trackPublications.values());await Promise.all(e.map(async i=>{let s=i.track;if(s)try{await t.unpublishTrack(s,!0)}catch{s.stop()}}))}async disconnectAndCloseRoom(){await this.closeRoom(),await this.disconnect()}async readRoom(t){return p(`${this.apiUrl}/rooms/${t}/read`,{method:"POST",headers:{Authorization:`Bearer ${this.authToken}`,"X-Onlive-Organization-Id":this.organizationId,"Content-Type":"application/json"},signal:this.abortControllers.persistMessage.signal})}async getRooms(t){let e=new URLSearchParams;return t.page&&e.append("page",t.page.toString()),t.limit&&e.append("limit",t.limit.toString()),t.offset&&e.append("offset",t.offset.toString()),t.orderBy&&e.append("orderBy",t.orderBy),t.orderDir&&e.append("orderDir",t.orderDir),t.ids?.length&&e.append("ids",t.ids.join(",")),t.with?.length&&e.append("with",t.with.join(",")),t.count?.length&&e.append("count",t.count.join(",")),t.latestOnly&&e.append("latestOnly",t.latestOnly.toString()),t.includeUnread&&e.append("includeUnread",t.includeUnread.toString()),t.roomStatus&&e.append("roomStatus",t.roomStatus),t.archived&&e.append("archived",t.archived.toString()),t.participantIds?.length&&e.append("participantIds",t.participantIds.join(",")),t.participantExternalIds?.length&&e.append("participantExternalIds",t.participantExternalIds.join(",")),t.groupId&&e.append("groupId",t.groupId),t.hasMessages!==void 0&&e.append("hasMessages",t.hasMessages.toString()),p(`${this.authUrl}/rooms?${e}`,{method:"GET",headers:{"X-Onlive-Organization-Id":this.organizationId,"Content-Type":"application/json"},credentials:"include",signal:this.abortControllers.getRooms.signal})}async sendMessage(t,e){let i=await this.room.localParticipant.sendText(t,{topic:this.channelTopic,attributes:e});this.emitMessage({id:i.id,timestamp:Date.now(),message:t,assets:JSON.parse(e?.assets||"[]"),from:this.room.localParticipant}),this.messagePersistence==="client"&&this.persistMessage({roomId:this.room.id,content:t,externalId:i.id,identity:this.room.localParticipant?.identity,kind:this.room.localParticipant?.kind})}async persistMessage(t){return p(`${this.apiUrl}/messages/create`,{method:"POST",body:JSON.stringify(t),headers:{Authorization:`Bearer ${this.authToken}`,"X-Onlive-Organization-Id":this.organizationId,"Content-Type":"application/json"},signal:this.abortControllers.persistMessage.signal})}async getMessages(t){let e=new URLSearchParams;return t.limit&&e.append("limit",t.limit.toString()),t.with&&e.append("with",t.with.join(",")),(await p(`${this.apiUrl}/messages/search${e.size?`?${e.toString()}`:""}`,{method:"POST",body:JSON.stringify(t),headers:{Authorization:`Bearer ${this.authToken}`,"X-Onlive-Organization-Id":this.organizationId,"Content-Type":"application/json"},signal:this.abortControllers.createRoom.signal})).items}async sendMessageReport(t){try{return p(`${this.apiUrl}/messages/${t.messageId}/report`,{method:"POST",headers:{Authorization:`Bearer ${this.authToken}`,"X-Onlive-Organization-Id":this.organizationId,"Content-Type":"application/json"},signal:this.abortControllers.sendMessageReport.signal})}catch(e){console.error("Error sending message report:",e)}}async deleteMessageReport(t){try{return p(`${this.apiUrl}/messages/${t.messageId}/report`,{method:"DELETE",headers:{Authorization:`Bearer ${this.authToken}`,"X-Onlive-Organization-Id":this.organizationId,"Content-Type":"application/json"},signal:this.abortControllers.deleteMessageReport.signal})}catch(e){console.error("Error deleting message report:",e)}}async updateMessageReactions(t){try{return p(`${this.apiUrl}/messages/${t.messageId}/reactions`,{method:"PATCH",body:JSON.stringify({add:t.add||[],remove:t.remove||[]}),headers:{Authorization:`Bearer ${this.authToken}`,"X-Onlive-Organization-Id":this.organizationId,"Content-Type":"application/json"},signal:this.abortControllers.updateMessageReactions.signal})}catch(e){console.error("Error updating message reactions:",e)}}subscribeMessages(t){return this.listeners.add(t),()=>{this.listeners.delete(t)}}async sendTypingIndicator(t){if(!(!this.room||this.room.state!=="connected"))try{let e=new TextEncoder().encode(JSON.stringify({type:"typing",isTyping:t,timestamp:Date.now(),participantId:this.room.localParticipant.identity}));await this.room.localParticipant.publishData(e,{reliable:!1,topic:kt})}catch(e){console.warn("Failed to send typing indicator:",e)}}subscribeTypingIndicators(t){return this.typingListeners.add(t),()=>{this.typingListeners.delete(t)}}unsubscribeTypingIndicators(t){this.typingListeners.delete(t)}async sendContextualEvent(t){try{let e=JSON.stringify(t);await this.room.localParticipant.sendText(e,{topic:this.eventsTopic})}catch(e){console.warn("Failed to send event:",e)}}async requestNewRoom(t){return p(`${this.apiUrl}/rooms/request-new`,{method:"POST",body:JSON.stringify(t),headers:{Authorization:`Bearer ${this.authToken}`,"X-Onlive-Organization-Id":this.organizationId,"Content-Type":"application/json"}})}async confirmRoomRequest(t){return p(`${this.apiUrl}/rooms/confirm-call`,{method:"POST",body:JSON.stringify({roomId:t}),headers:{Authorization:`Bearer ${this.authToken}`,"X-Onlive-Organization-Id":this.organizationId,"Content-Type":"application/json"}})}async cancelRoomRequest(t){return p(`${this.apiUrl}/rooms/cancel-call`,{method:"POST",body:JSON.stringify({roomId:t}),headers:{Authorization:`Bearer ${this.authToken}`,"X-Onlive-Organization-Id":this.organizationId,"Content-Type":"application/json"}})}async finishCall(){if(this.room?.id)return p(`${this.apiUrl}/rooms/finish-call`,{method:"POST",body:JSON.stringify({roomId:this.room.id}),headers:{Authorization:`Bearer ${this.authToken}`,"X-Onlive-Organization-Id":this.organizationId,"Content-Type":"application/json"}})}isFirebaseEnabled(){return!!(this.firebaseApi&&this.presencePath&&this.callsPath)}getFirebase(){if(!this.firebaseApi||!this.presencePath||!this.callsPath)throw new Error("Firebase is not initialized. Provide firebaseConfig in constructor.");return{api:this.firebaseApi,presencePath:this.presencePath,callsPath:this.callsPath}}buildAgentPresencePath(t){return`${this.presencePath}/${t}`}onPresenceChange(t){let{api:e,presencePath:i}=this.getFirebase();return e.onChildChanged(i,(s,o)=>t(s,o))}onPresenceAgentChange(t,e){let{api:i}=this.getFirebase();return i.onValue(this.buildAgentPresencePath(t),(s,o)=>e(s,o))}async createCallRequest(t){let{api:e,callsPath:i}=this.getFirebase(),o=(await p(`${this.apiUrl}/rooms/call-request`,{method:"POST",headers:{Authorization:`Bearer ${this.authToken}`,"X-Onlive-Organization-Id":this.organizationId,"Content-Type":"application/json"},body:JSON.stringify(t)})).id;return e.onDisconnectUpdate(`${i}/${o}`,{status:"disconnected"}),o}onNewCallRequest(t){let{api:e,callsPath:i}=this.getFirebase();return e.onChildAdded(i,(s,o)=>t(s,{...o,id:s}))}onCallRequestChange(t){let{api:e,callsPath:i}=this.getFirebase();return e.onChildChanged(i,(s,o)=>t(s,{...o,id:s}))}onCallRequestRemoved(t){let{api:e,callsPath:i}=this.getFirebase();return e.onChildRemoved(i,s=>t(s))}async acceptCallRequest(t){let{api:e,callsPath:i}=this.getFirebase();return await e.cancelOnDisconnect(`${i}/${t}`),e.update(`${i}/${t}`,{status:"accepted"})}async cancelCallRequest(t){let{api:e,callsPath:i}=this.getFirebase();await e.cancelOnDisconnect(`${i}/${t}`),await p(`${this.apiUrl}/rooms/call-request/cancel`,{method:"POST",headers:{Authorization:`Bearer ${this.authToken}`,"X-Onlive-Organization-Id":this.organizationId,"Content-Type":"application/json"},body:JSON.stringify({callId:t})})}async cancelOnDisconnect(t){let{api:e,callsPath:i}=this.getFirebase();await e.cancelOnDisconnect(`${i}/${t}`)}subscribePendingRequests(t,e={}){let{api:i,callsPath:s}=this.getFirebase();e.resetSeen&&this.seenRequestIds.clear(),this.firebaseUnsubscribers["pending-requests"]?.();let o=i.query(s,{orderBy:"child",childKey:"status",equalTo:"pending"}),c=i.onChildAddedQuery(o,(a,l)=>{if(!a||this.seenRequestIds.has(a))return;let g={...l,id:a};this.seenRequestIds.add(a),t(a,g)});return this.firebaseUnsubscribers["pending-requests"]=c,()=>{c?.(),delete this.firebaseUnsubscribers["pending-requests"]}}subscribeRequestChanges(t){let{api:e,callsPath:i}=this.getFirebase();this.firebaseUnsubscribers["request-changes"]?.();let s=e.onChildChanged(i,(o,c)=>{if(!o)return;let a=JSON.stringify(c);this.lastSnapshotById.get(o)!==a&&(this.lastSnapshotById.set(o,a),t(o,{...c,id:o}))});return this.firebaseUnsubscribers["request-changes"]=s,()=>{s?.(),delete this.firebaseUnsubscribers["request-changes"]}}async tryAcceptRequest(t){let{api:e,callsPath:i}=this.getFirebase(),s=`${i}/${t}`;return await e.transaction(s,c=>c&&(c.status==="pending"?{...c,status:"accepted"}:c)),(await e.getOnce(s))?.status==="accepted"}onRoomSync(t,e){let{api:i}=this.getFirebase(),s=`orgs/${this.organizationId}/rooms/${t}/sync`;return i.onValue(s,(o,c)=>{e(c)})}async clearRoomSync(t,e){let{api:i}=this.getFirebase(),s=`orgs/${this.organizationId}/rooms/${t}/sync`;await i.write(s,{needsSync:!1,reason:e||null,timestamp:Date.now()})}onNewRoomRequest(t,e){let{api:i}=this.getFirebase(),s=`orgs/${this.organizationId}/rooms/${t}/call`;return i.onValue(s,(o,c)=>{e(c)})}unsubscribeAllFirebase(){Object.values(this.firebaseUnsubscribers).forEach(t=>t?.()),this.firebaseUnsubscribers={}}async destroy(){this.unsubscribeAllFirebase(),this.listeners.clear(),this.typingListeners.clear(),this.transcriptionMap.clear(),this.seenRequestIds.clear(),this.lastSnapshotById.clear(),Object.values(this.abortControllers).forEach(t=>t.abort()),await this.disconnect()}};var T=class{constructor(t,e,i,s){this.muted=!1;this.enabled=!0;this.attachedElements=new Set;this.kind=t,this.source=e,this.sid=u("TR"),this.mediaStreamTrack=i,this.mediaCleanup=s}get mediaTrack(){return this.mediaStreamTrack}attach(t){let e=t||document.createElement(this.kind==="video"?"video":"audio");if(this.mediaStreamTrack){let i=new MediaStream([this.mediaStreamTrack]);e.srcObject=i,e.autoplay=!0,this.kind==="video"&&(e.playsInline=!0,e.muted=!0)}return this.attachedElements.add(e),e}detach(t){if(t)return t.srcObject=null,this.attachedElements.delete(t),[t];let e=Array.from(this.attachedElements);for(let i of e)i.srcObject=null;return this.attachedElements.clear(),e}stop(){this.detach(),this.mediaCleanup&&this.mediaCleanup(),this.mediaStreamTrack&&this.mediaStreamTrack.stop(),this.enabled=!1}setMuted(t){this.muted=t,this.mediaStreamTrack&&(this.mediaStreamTrack.enabled=!t)}setEnabled(t){this.enabled=t,this.mediaStreamTrack&&(this.mediaStreamTrack.enabled=t)}},S=class{constructor(t,e){this.subscribed=!0;this.isEnabled=!0;this.track=t,this.trackSid=t.sid,this.trackName=e||`${t.kind}_${t.source}`,this.source=t.source,this.kind=t.kind}get isMuted(){return this.track?.muted??!1}get isSubscribed(){return this.subscribed&&this.track!==null}setSubscribed(t){this.subscribed=t}setEnabled(t){this.isEnabled=t,this.track&&(this.track.enabled=t)}setMuted(t){this.track&&this.track.setMuted(t)}};var $=class{constructor(t){this.identity="";this.sid="";this.name="";this.attributes={};this.kind="standard";this.trackPublications=new Map;this.audioTrackPublications=new Map;this.videoTrackPublications=new Map;this._cameraEnabled=!1;this._microphoneEnabled=!1;this._screenShareEnabled=!1;this.room=t,this.sid=u("PA"),this.joinedAt=new Date}get isCameraEnabled(){return this._cameraEnabled}get isMicrophoneEnabled(){return this._microphoneEnabled}get isScreenShareEnabled(){return this._screenShareEnabled}getTrackPublications(){return Array.from(this.trackPublications.values())}getTrackPublication(t){let i={camera:"camera",Camera:"camera",microphone:"microphone",Microphone:"microphone",screen_share:"screen_share",ScreenShare:"screen_share",screen_share_audio:"screen_share_audio",ScreenShareAudio:"screen_share_audio"}[t]||t;return this.trackPublications.get(i)}getTrackPublicationBySid(t){for(let e of this.trackPublications.values())if(e.trackSid===t)return e}setAttributes(t){this.attributes={...this.attributes,...t}}async setCameraEnabled(t,e){if(this._cameraEnabled=t,t){let{createSyntheticVideoTrack:s}=await Promise.resolve().then(()=>(U(),q)),{track:o,cleanup:c}=s({animation:"avatar",label:this.name||"Local Camera"}),a=new T("video","camera",o,c),l=new S(a,e?.name);return this.trackPublications.set("camera",l),this.videoTrackPublications.set(a.sid,l),this.room.emit("localTrackPublished",l,this),l}let i=this.trackPublications.get("camera");i&&(i.track?.stop(),this.trackPublications.delete("camera"),this.videoTrackPublications.delete(i.trackSid),this.room.emit("localTrackUnpublished",i,this))}async setMicrophoneEnabled(t,e){if(this._microphoneEnabled=t,t){let{createSyntheticAudioTrack:s}=await Promise.resolve().then(()=>(U(),q)),{track:o,cleanup:c}=s({enabled:!1}),a=new T("audio","microphone",o,c),l=new S(a,e?.name);return this.trackPublications.set("microphone",l),this.audioTrackPublications.set(a.sid,l),this.room.emit("localTrackPublished",l,this),l}let i=this.trackPublications.get("microphone");i&&(i.track?.stop(),this.trackPublications.delete("microphone"),this.audioTrackPublications.delete(i.trackSid),this.room.emit("localTrackUnpublished",i,this))}async setScreenShareEnabled(t,e){if(this._screenShareEnabled=t,t){let{createSyntheticVideoTrack:s}=await Promise.resolve().then(()=>(U(),q)),{track:o,cleanup:c}=s({animation:"bars",label:"Screen Share",width:1920,height:1080}),a=new T("video","screen_share",o,c),l=new S(a,e?.name||"screen");return this.trackPublications.set("screen_share",l),this.videoTrackPublications.set(a.sid,l),this.room.emit("localTrackPublished",l,this),l}let i=this.trackPublications.get("screen_share");i&&(i.track?.stop(),this.trackPublications.delete("screen_share"),this.videoTrackPublications.delete(i.trackSid),this.room.emit("localTrackUnpublished",i,this))}async publishTrack(t,e){let i=new S(t,e?.name),s=e?.source||t.source;return this.trackPublications.set(s,i),t.kind==="audio"?this.audioTrackPublications.set(t.sid,i):t.kind==="video"&&this.videoTrackPublications.set(t.sid,i),this.room.emit("localTrackPublished",i,this),i}async unpublishTrack(t){t.stop();for(let[e,i]of this.trackPublications)if(i.track===t){this.trackPublications.delete(e),t.kind==="audio"?this.audioTrackPublications.delete(t.sid):t.kind==="video"&&this.videoTrackPublications.delete(t.sid),this.room.emit("localTrackUnpublished",i,this);break}}async sendText(t,e){return{id:u("msg")}}async publishData(t,e){}async setMetadata(t){this.attributes.metadata=t}async setName(t){this.name=t}cleanup(){for(let t of this.trackPublications.values())t.track?.stop();this.trackPublications.clear(),this.audioTrackPublications.clear(),this.videoTrackPublications.clear(),this._cameraEnabled=!1,this._microphoneEnabled=!1,this._screenShareEnabled=!1}};function Ft(n){switch(n){case"standard":return 0;case"ingress":return 1;case"egress":return 2;case"sip":return 3;case"agent":return 4;default:return 0}}var O=class{constructor(t,e,i={},s="standard"){this.connectionQuality="excellent";this.isSpeaking=!1;this.audioLevel=0;this.trackPublications=new Map;this.identity=t,this.sid=u("PA"),this.name=e,this.attributes=i,this._kindString=s,this.kind=Ft(s),this.joinedAt=new Date}get isAgent(){return this.kind===4||this.attributes["lk.agent.name"]!==void 0}get kindString(){return this._kindString}get isCameraEnabled(){let t=this.getTrackPublication("camera");return!!(t?.track&&!t.isMuted)}get isMicrophoneEnabled(){let t=this.getTrackPublication("microphone");return!!(t?.track&&!t.isMuted)}getTrackPublication(t){for(let e of this.trackPublications.values())if(e.source===t)return e}getTrackPublicationBySid(t){return this.trackPublications.get(t)}getTrackPublications(){return Array.from(this.trackPublications.values())}getAudioTracks(){return this.getTrackPublications().filter(t=>t.kind==="audio")}getVideoTracks(){return this.getTrackPublications().filter(t=>t.kind==="video")}addTrackPublication(t){this.trackPublications.set(t.trackSid,t)}removeTrackPublication(t){let e=this.trackPublications.get(t);return e&&(this.trackPublications.delete(t),e.track?.stop()),e}setAttributes(t){this.attributes={...this.attributes,...t}}getAttribute(t){return this.attributes[t]}startSpeaking(t=.5){this.isSpeaking=!0,this.audioLevel=t}stopSpeaking(){this.isSpeaking=!1,this.audioLevel=0}setConnectionQuality(t){this.connectionQuality=t}cleanup(){for(let t of this.trackPublications.values())t.track?.stop();this.trackPublications.clear()}};var x=class{constructor(t){this.remoteParticipants=new Map;this._state="disconnected";this.eventHandlers=new Map;this.textStreamHandlers=new Map;this.rpcHandlers=new Map;this.mockService=t,this.localParticipant=new $(this),this.sid=u("RM")}get state(){return this._state}set state(t){let e=this._state;this._state=t,e!==t&&this.emit("connectionStateChanged",t,e)}get numParticipants(){return this.remoteParticipants.size+1}get isConnected(){return this._state==="connected"}async connect(t,e){this._state="connecting",this.emit("connectionStateChanged","connecting","disconnected"),await this.mockService.simulateLatency(),this._state="connected",this.connectedAt=new Date().toISOString(),this.emit("connectionStateChanged","connected","connecting"),this.emit("connected")}async disconnect(){for(let e of this.remoteParticipants.values())e.cleanup();this.remoteParticipants.clear(),this.localParticipant.cleanup();let t=this._state;this._state="disconnected",this.emit("connectionStateChanged","disconnected",t),this.emit("disconnected"),this.eventHandlers.clear()}async reconnect(){this._state="reconnecting",this.emit("connectionStateChanged","reconnecting","connected"),await this.mockService.simulateLatency(),this._state="connected",this.emit("connectionStateChanged","connected","reconnecting"),this.emit("reconnected")}on(t,e){return this.eventHandlers.has(t)||this.eventHandlers.set(t,new Set),this.eventHandlers.get(t).add(e),this}once(t,e){let i=(...s)=>{this.off(t,i),e(...s)};return this.on(t,i)}off(t,e){return this.eventHandlers.get(t)?.delete(e),this}removeAllListeners(){this.eventHandlers.clear()}emit(t,...e){let i=this.eventHandlers.get(t);if(i)for(let s of i)try{s(...e)}catch(o){console.error(`Error in mock room event handler for ${t}:`,o)}}registerRpcMethod(t,e){this.rpcHandlers.set(t,e)}unregisterRpcMethod(t){this.rpcHandlers.delete(t)}async callRpc(t,e,i,s=1e4){let o=this.rpcHandlers.get(t);if(!o)throw new Error(`RPC method not found: ${t}`);return o({callerIdentity:e,payload:i,responseTimeout:s})}registerTextStreamHandler(t,e){this.textStreamHandlers.set(t,e)}unregisterTextStreamHandler(t){this.textStreamHandlers.delete(t)}simulateTextStream(t,e){let i=this.textStreamHandlers.get(t);i&&i(e,{identity:e.participantIdentity})}getParticipantByIdentity(t){return t===this.localParticipant.identity?new O(this.localParticipant.identity,this.localParticipant.name,this.localParticipant.attributes):this.remoteParticipants.get(t)}getParticipantBySid(t){if(t===this.localParticipant.sid)return new O(this.localParticipant.identity,this.localParticipant.name,this.localParticipant.attributes);for(let e of this.remoteParticipants.values())if(e.sid===t)return e}async simulateParticipantJoin(t,e){let i=new O(t,e?.name,e?.attributes||{},e?.kind||"standard");return this.remoteParticipants.set(t,i),this.emit("participantConnected",i),e?.withCamera&&await this.simulateRemoteTrack(t,"video","camera"),e?.withMicrophone&&await this.simulateRemoteTrack(t,"audio","microphone"),i}simulateParticipantLeave(t){let e=this.remoteParticipants.get(t);if(e){for(let i of e.getTrackPublications())i.track?.stop(),this.emit("trackUnsubscribed",i.track,i,e);this.remoteParticipants.delete(t),this.emit("participantDisconnected",e)}}async simulateRemoteTrack(t,e,i){let s=this.remoteParticipants.get(t);if(!s)return;let o,c;if(e==="video"){let{createSyntheticVideoTrack:g}=await Promise.resolve().then(()=>(U(),q)),h=g({animation:s.isAgent?"avatar":"pulse",label:s.name||t,foregroundColor:s.isAgent?"#22c55e":"#4361ee"});o=h.track,c=h.cleanup}else if(e==="audio"){let{createSyntheticAudioTrack:g}=await Promise.resolve().then(()=>(U(),q)),h=g({enabled:!1});o=h.track,c=h.cleanup}let a=new T(e,i,o,c),l=new S(a);return s.addTrackPublication(l),this.emit("trackSubscribed",a,l,s),this.emit("trackPublished",l,s),a}simulateTrackUnpublished(t,e){let i=this.remoteParticipants.get(t);if(!i)return;let s=i.getTrackPublication(e);s&&(i.removeTrackPublication(s.trackSid),this.emit("trackUnpublished",s,i),this.emit("trackUnsubscribed",s.track,s,i))}async simulateAgentJoin(t,e="AI Agent"){return this.simulateParticipantJoin(t,{name:e,kind:"agent",withCamera:!0,withMicrophone:!0,attributes:{"lk.agent.name":e,"lk.agent.state":"active"}})}simulateAttributeChange(t,e){let i=this.remoteParticipants.get(t);if(i){let s={...i.attributes};i.setAttributes(e),this.emit("participantAttributesChanged",e,s,i)}}simulateTrackMuted(t,e,i){let s=this.remoteParticipants.get(t);if(!s)return;let o=s.getTrackPublication(e);o?.track&&(o.track.setMuted(i),this.emit(i?"trackMuted":"trackUnmuted",o,s))}simulateActiveSpeakersChanged(t){let e=[];for(let i of t){let s=this.remoteParticipants.get(i);s&&(s.startSpeaking(),e.push(s))}this.emit("activeSpeakersChanged",e)}simulateDataReceived(t,e,i,s){let o=this.remoteParticipants.get(e);this.emit("dataReceived",t,o,i,s)}};var J=class{constructor(t={}){this.rooms=new Map;this.participants=new Map;this.tracks=new Map;this.agents=new Map;this.messages=new Map;this.config=t,this.randomState=t.seed??Date.now()}updateConfig(t){this.config={...this.config,...t},t.seed!==void 0&&(this.randomState=t.seed)}getConfig(){return{...this.config}}random(){return this.randomState=(this.randomState*1103515245+12345)%2147483648,this.randomState/2147483648}createRoom(t,e,i){let s=u("room"),o=new Date().toISOString(),c={id:s,name:t,groupId:e||u("group"),createdAt:o,metadata:i,isActive:!0,participantIds:[],connectionState:"disconnected",wsURL:F(s),token:A(s,"pending",o)};return this.rooms.set(s,c),this.messages.set(s,[]),c}getRoom(t){return this.rooms.get(t)}getRoomByName(t){for(let e of this.rooms.values())if(e.name===t)return e}listRooms(t=!1){let e=Array.from(this.rooms.values());return t?e.filter(i=>i.isActive):e}updateRoomConnectionState(t,e){let i=this.rooms.get(t);if(!i)return;let s=i.connectionState;return i.connectionState=e,s}endRoom(t){let e=this.rooms.get(t);if(!e||!e.isActive)return!1;e.isActive=!1,e.endedAt=new Date().toISOString(),e.connectionState="disconnected";for(let i of e.participantIds){let s=this.participants.get(i);s&&(s.isConnected=!1)}for(let i of this.agents.values())i.roomId===t&&i.status==="running"&&(i.status="stopped",i.stoppedAt=new Date().toISOString());return!0}deleteRoom(t){let e=this.rooms.get(t);if(!e)return!1;for(let i of e.participantIds)this.participants.delete(i);for(let[i,s]of this.tracks)s.roomId===t&&this.tracks.delete(i);for(let[i,s]of this.agents)s.roomId===t&&this.agents.delete(i);return this.messages.delete(t),this.rooms.delete(t),!0}addParticipant(t,e,i,s="user",o="standard",c=!1){let a=this.rooms.get(t);if(!a)return this.createError("ROOM_NOT_FOUND",`Room ${t} not found`);if(!a.isActive)return this.createError("ROOM_ENDED",`Room ${t} has ended`);let l=this.participants.get(e);if(l&&l.roomId===t&&l.isConnected)return this.config.strictMode?this.createError("PARTICIPANT_ALREADY_JOINED",`Participant ${e} is already in room ${t}`):l;let g={identity:e,name:i||e,roomId:t,joinedAt:new Date().toISOString(),isConnected:!0,trackIds:[],role:s,attributes:{},kind:o,isLocal:c};return this.participants.set(e,g),a.participantIds.push(e),g}getParticipant(t){return this.participants.get(t)}listParticipants(t,e=!0){let i=this.rooms.get(t);if(!i)return[];let s=[];for(let o of i.participantIds){let c=this.participants.get(o);c&&(!e||c.isConnected)&&s.push(c)}return s}updateParticipantAttributes(t,e){let i=this.participants.get(t);if(!i)return;let s={...i.attributes};return i.attributes={...i.attributes,...e},s}removeParticipant(t){let e=this.participants.get(t);if(!e)return;e.isConnected=!1;for(let s of e.trackIds)this.tracks.delete(s);e.trackIds=[];let i=this.rooms.get(e.roomId);if(i){let s=i.participantIds.indexOf(t);s!==-1&&i.participantIds.splice(s,1)}return e}publishTrack(t,e,i="unknown",s){let o=this.participants.get(t);if(!o)return this.createError("PARTICIPANT_NOT_FOUND",`Participant ${t} not found`);if(!o.isConnected)return this.createError("INVALID_OPERATION",`Participant ${t} is not connected`);let c=this.rooms.get(o.roomId);if(!c||!c.isActive)return this.createError("ROOM_ENDED","Room is not active");let a=u("track"),l={id:a,kind:e,source:i,participantIdentity:t,roomId:o.roomId,publishedAt:new Date().toISOString(),muted:!1,metadata:s};return this.tracks.set(a,l),o.trackIds.push(a),l}getTrack(t){return this.tracks.get(t)}listTracks(t,e){let i=[];for(let s of this.tracks.values())t&&s.roomId!==t||e&&s.participantIdentity!==e||i.push(s);return i}unpublishTrack(t){let e=this.tracks.get(t);if(!e)return;let i=this.participants.get(e.participantIdentity);if(i){let s=i.trackIds.indexOf(t);s!==-1&&i.trackIds.splice(s,1)}return this.tracks.delete(t),e}setTrackMuted(t,e){let i=this.tracks.get(t);return i?(i.muted=e,!0):!1}startAgent(t,e,i={}){let s=this.rooms.get(t);if(!s)return this.createError("ROOM_NOT_FOUND",`Room ${t} not found`);if(!s.isActive)return this.createError("ROOM_ENDED",`Room ${t} has ended`);let o=u("agent"),c={id:o,roomId:t,name:e,status:"running",startedAt:new Date().toISOString(),config:{responseStrategy:"echo",...i},messageHistory:[]};return this.agents.set(o,c),this.addParticipant(t,`agent_${o}`,e,"agent","agent",!1),c}getAgent(t){return this.agents.get(t)}listAgents(t){let e=[];for(let i of this.agents.values())i.roomId===t&&e.push(i);return e}stopAgent(t){let e=this.agents.get(t);if(e)return e.status="stopped",e.stoppedAt=new Date().toISOString(),this.removeParticipant(`agent_${t}`),e}updateAgentStatus(t,e){let i=this.agents.get(t);return i?(i.status=e,e==="stopped"&&(i.stoppedAt=new Date().toISOString()),!0):!1}addAgentMessage(t,e,i){let s=this.agents.get(t);if(!s)return;let o={id:u("msg"),content:e,role:i,timestamp:new Date().toISOString()};return s.messageHistory.push(o),o}addMessage(t,e,i,s="standard",o){if(!this.rooms.get(t))return this.createError("ROOM_NOT_FOUND",`Room ${t} not found`);let a={id:u("msg"),roomId:t,content:i,participantIdentity:e,createdAt:new Date().toISOString(),type:s,attributes:o},l=this.messages.get(t)||[];return l.push(a),this.messages.set(t,l),a}getMessages(t,e){let i=this.messages.get(t)||[];return e?i.slice(-e):i}createError(t,e,i){return{code:t,message:e,details:i}}isError(t){return typeof t=="object"&&t!==null&&"code"in t&&"message"in t}reset(){this.rooms.clear(),this.participants.clear(),this.tracks.clear(),this.agents.clear(),this.messages.clear(),this.randomState=this.config.seed??Date.now()}getSnapshot(){return{rooms:new Map(this.rooms),participants:new Map(this.participants),tracks:new Map(this.tracks),agents:new Map(this.agents),messages:new Map(this.messages),config:{...this.config},eventHistory:[]}}toJSON(){return{rooms:Object.fromEntries(this.rooms),participants:Object.fromEntries(this.participants),tracks:Object.fromEntries(this.tracks),agents:Object.fromEntries(this.agents),messages:Object.fromEntries(this.messages),config:this.config,eventHistory:[],exportedAt:new Date().toISOString()}}fromJSON(t){this.rooms=new Map(Object.entries(t.rooms)),this.participants=new Map(Object.entries(t.participants)),this.tracks=new Map(Object.entries(t.tracks)),this.agents=new Map(Object.entries(t.agents)),this.messages=new Map(Object.entries(t.messages).map(([e,i])=>[e,i])),this.config=t.config}};var _=class{constructor(t={}){this.messageListeners=new Set;this.typingListeners=new Set;this.callRequestListeners=new Map;this._authToken=null;this._registeredUser=null;this.agents=new Map;this.config={latencyMs:t.latencyMs??0,strictMode:t.strictMode??!1,seed:t.seed,scenario:t.scenario,errorConfig:t.errorConfig,autoEmitEvents:t.autoEmitEvents??!0,organizationId:t.organizationId??"mock_org",apiUrl:t.apiUrl??"https://mock-livekit.local"},this.state=new J(this.config),this.events=new V,this.room=new x(this),this.config.scenario&&this.applyScenario(this.config.scenario)}get authToken(){return this._authToken}get registeredUser(){return this._registeredUser}getState(){return this.state}getEvents(){return this.events}updateConfig(t){this.config={...this.config,...t},this.state.updateConfig(t)}getConfig(){return{...this.config}}async simulateLatency(){this.config.latencyMs&&this.config.latencyMs>0&&await new Promise(t=>setTimeout(t,this.config.latencyMs))}applyScenario(t){switch(t){case"happy_path":this.config.errorConfig={},this.config.latencyMs=0;break;case"slow_network":this.config.latencyMs=500;break;case"network_unstable":this.config.errorConfig={errorRate:30};break;default:break}}shouldThrowError(){return this.config.errorConfig?.errorRate?this.state.random()*100<this.config.errorConfig.errorRate:!1}ensureRoom(){return this.room||(this.room=new x(this)),this.room}async registerUser(t,e,i,s){if(await this.simulateLatency(),this.config.errorConfig?.unauthorized)throw new m("UNAUTHORIZED","Registration failed");let o={id:u("user"),externalId:t,organizationId:this.config.organizationId,role:"user",token:A("pending",t,new Date().toISOString())};return this._authToken=o.token,this._registeredUser=o,this.room.localParticipant.identity=t,this.room.localParticipant.name=i?.name||t,o}async registerAgent(t,e){if(await this.simulateLatency(),this.config.errorConfig?.unauthorized)throw new m("UNAUTHORIZED","Agent registration failed");let i=A("agent",t,new Date().toISOString());return this._authToken=i,this.room.localParticipant.identity=t,this.room.localParticipant.name=e.name,i}async createRoom(t,e={}){if(await this.simulateLatency(),this.config.errorConfig?.networkError||this.shouldThrowError())throw new m("NETWORK_ERROR","Failed to create room");let i=this.state.createRoom(`room_${Date.now()}`,t.affinity?.agentId,t.metadata);this.room.id=i.id,this.room.groupId=i.groupId,this.room.createdAt=i.createdAt,this.room.connectedAt=new Date().toISOString();let s=this.room.localParticipant.identity||"local_user";return this.state.addParticipant(i.id,s,this.room.localParticipant.name,"user","standard",!0),Object.keys(e).length>0&&(this.state.updateParticipantAttributes(s,e),this.room.localParticipant.setAttributes(e)),this.state.updateRoomConnectionState(i.id,"connected"),this.config.autoEmitEvents&&(this.events.emitRoomCreated(i),this.events.emitRoomConnectionStateChanged(i.id,"connected","disconnected")),(t.affinity?.agentId||t.affinity?.agentType)&&await this.startMockAgent(i.id,{type:t.affinity?.agentType,nature:t.affinity?.nature??"ai"}),await this.room.connect(i.wsURL,i.token),this.room}async joinRoom(t,e,i,s){await this.simulateLatency();let o=this.state.getRoom(t);if(!o)throw new w(t);if(!o.isActive)throw new m("ROOM_ENDED",`Room ${t} has ended`);this.room.id=o.id,this.room.groupId=o.groupId,this.room.createdAt=o.createdAt,this.room.connectedAt=new Date().toISOString();let c=this.room.localParticipant.identity||"local_user",a=this.state.addParticipant(t,c,this.room.localParticipant.name,"user","standard",!0);if(I(a))throw K(a);if(s){let l={};for(let[g,h]of Object.entries(s))l[g]=String(h);this.state.updateParticipantAttributes(c,l)}return this.state.updateRoomConnectionState(t,"connected"),this.config.autoEmitEvents&&(this.events.emitParticipantJoined(t,a),this.events.emitRoomConnectionStateChanged(t,"connected","disconnected")),await this.room.connect(o.wsURL,o.token),this.room}async evaluateRoom(t){await this.simulateLatency();let e=t.roomId||this.room?.id;if(!e)throw new m("ROOM_NOT_FOUND","No room to evaluate");let i=this.state.getRoom(e);if(!i)throw new w(e);i.metadata||(i.metadata={}),i.metadata.evaluation={rating:t.rating,comment:t.comment,evaluatedAt:new Date().toISOString()}}async closeRoom(){await this.simulateLatency(),this.room?.id&&(this.state.endRoom(this.room.id),await this.stopLocalTracks(),this.config.autoEmitEvents&&this.events.emitRoomEnded(this.room.id))}async disconnect(){if(this.room){let t=this.room.id,e=this.room.localParticipant.identity;await this.stopLocalTracks(),this.state.removeParticipant(e),this.config.autoEmitEvents&&t&&this.events.emitParticipantLeft(t,e),this.room.removeAllListeners(),await this.room.disconnect()}}async stopLocalTracks(){let t=this.room?.localParticipant;t&&await Promise.all([t.setCameraEnabled(!1),t.setMicrophoneEnabled(!1),t.setScreenShareEnabled(!1)])}async disconnectAndCloseRoom(){await this.closeRoom(),await this.disconnect()}async readRoom(t){await this.simulateLatency();let e=this.state.getRoom(t);if(!e)throw new w(t);e.metadata||(e.metadata={}),e.metadata.lastReadAt=new Date().toISOString()}async getRooms(t){await this.simulateLatency();let e=this.state.listRooms();t.roomStatus==="active"?e=e.filter(a=>a.isActive):t.roomStatus==="closed"&&(e=e.filter(a=>!a.isActive)),t.ids?.length&&(e=e.filter(a=>t.ids.includes(a.id))),t.groupId&&(e=e.filter(a=>a.groupId===t.groupId));let i=t.offset??0,s=t.limit??20;return{items:e.slice(i,i+s).map(a=>({id:a.id,name:a.name,groupId:a.groupId,organizationId:this.config.organizationId,endedAt:a.endedAt??null,createdAt:a.createdAt,updatedAt:a.createdAt,status:a.isActive?"active":"ended",participants:this.state.listParticipants(a.id).map(l=>({id:l.identity,name:l.name||l.identity,role:l.role,isLocal:l.isLocal})),evaluations:[],_count:{messages:this.state.getMessages(a.id).length,participants:a.participantIds.length}})),count:e.length,limit:s,offset:i}}async sendMessage(t,e){if(await this.simulateLatency(),!this.room?.id)throw new m("INVALID_OPERATION","Not connected to a room");let i=this.state.addMessage(this.room.id,this.room.localParticipant.identity,t,"standard",e);if(I(i))throw K(i);let s={id:i.id,timestamp:Date.now(),message:t,content:t,createdAt:i.createdAt,from:{identity:this.room.localParticipant.identity,name:this.room.localParticipant.name,id:this.room.localParticipant.identity,role:"user"}};for(let o of this.messageListeners)o([s]);this.config.autoEmitEvents&&this.events.emitMessageSent(this.room.id,i);for(let o of this.agents.values())o.isRunning&&o.roomId===this.room.id&&this.triggerAgentResponse(o,t)}async persistMessage(t){await this.simulateLatency();let e=this.state.addMessage(t.roomId,t.identity||"system",t.content);if(I(e))throw K(e);return{items:[{id:e.id,timestamp:Date.now(),message:e.content,content:e.content,createdAt:e.createdAt}],count:1,limit:1,offset:0}}async getMessages(t){await this.simulateLatency();let e=t.roomId||this.room?.id;return e?this.state.getMessages(e,t.limit).map(s=>({id:s.id,timestamp:Date.parse(s.createdAt),message:s.content,content:s.content,createdAt:s.createdAt,from:{identity:s.participantIdentity,id:s.participantIdentity,role:"user"}})):[]}async sendMessageReport(t){await this.simulateLatency()}async deleteMessageReport(t){await this.simulateLatency()}async updateMessageReactions(t){await this.simulateLatency()}subscribeMessages(t){return this.messageListeners.add(t),()=>{this.messageListeners.delete(t)}}async sendTypingIndicator(t){if(!this.room?.id)return;let e={type:"typing",isTyping:t,timestamp:Date.now(),participantId:this.room.localParticipant.identity};for(let i of this.typingListeners)i(e);this.config.autoEmitEvents&&this.events.emitTypingIndicator(this.room.id,this.room.localParticipant.identity,t)}subscribeTypingIndicators(t){return this.typingListeners.add(t),()=>this.typingListeners.delete(t)}unsubscribeTypingIndicators(t){this.typingListeners.delete(t)}async sendContextualEvent(t){await this.simulateLatency()}async requestNewRoom(t){await this.simulateLatency();let e=this.state.createRoom(`transfer_${Date.now()}`,void 0,{originRoom:t.originRoom});return{id:e.id,groupId:e.groupId,token:e.token,wsURL:e.wsURL,createdAt:e.createdAt}}async confirmRoomRequest(t){return await this.simulateLatency(),{success:!0,message:"Request confirmed",roomId:t}}async cancelRoomRequest(t){return await this.simulateLatency(),{success:!0,message:"Request cancelled",roomId:t}}async finishCall(){await this.simulateLatency(),this.room?.id&&this.state.endRoom(this.room.id)}isFirebaseEnabled(){return!0}onPresenceChange(t){return()=>{}}onPresenceAgentChange(t,e){return()=>{}}async createCallRequest(t){return await this.simulateLatency(),u("call")}onNewCallRequest(t){return this.callRequestListeners.has("new")||this.callRequestListeners.set("new",new Set),this.callRequestListeners.get("new").add(t),()=>this.callRequestListeners.get("new")?.delete(t)}onCallRequestChange(t){return this.callRequestListeners.has("change")||this.callRequestListeners.set("change",new Set),this.callRequestListeners.get("change").add(t),()=>this.callRequestListeners.get("change")?.delete(t)}onCallRequestRemoved(t){return()=>{}}async acceptCallRequest(t){await this.simulateLatency()}async cancelCallRequest(t){await this.simulateLatency()}async cancelOnDisconnect(t){await this.simulateLatency()}subscribePendingRequests(t,e={}){return()=>{}}subscribeRequestChanges(t){return()=>{}}async tryAcceptRequest(t){return await this.simulateLatency(),!0}onRoomSync(t,e){return()=>{}}async clearRoomSync(t,e){await this.simulateLatency()}onNewRoomRequest(t,e){return()=>{}}unsubscribeAllFirebase(){this.callRequestListeners.clear()}async destroy(){this.unsubscribeAllFirebase(),this.messageListeners.clear(),this.typingListeners.clear(),await this.disconnect(),this.state.reset()}async startMockAgent(t,e){let i=e?.name||"AI Assistant",s=new N(u("agent"),i,{responseStrategy:e?.responseStrategy||"echo",responseDelayMs:e?.responseDelayMs||100,cannedResponses:e?.cannedResponses||[],type:e?.type,nature:e?.nature});await s.start(t),this.agents.set(s.id,s),this.customAgentHandler&&s.setCustomHandler((g,h)=>this.customAgentHandler(g,h));let o=e?.type,c=Array.isArray(o)?o:[o].filter(Boolean),a=c.includes("video"),l=c.includes("voice");return(a||l)&&this.room.isConnected&&await this.room.simulateParticipantJoin(s.id,{name:i,kind:"agent",withCamera:a,withMicrophone:l||a,attributes:{"lk.agent.name":i,"lk.agent.state":"active",role:"agent"}}),this.config.autoEmitEvents&&this.events.emitAgentStarted(t,{id:s.id,name:s.name,roomId:t,status:"running",config:s.getConfig(),startedAt:new Date().toISOString(),messageHistory:[]}),s.id}async stopMockAgent(t){let e=this.agents.get(t);if(e){let i=e.roomId;await e.stop(),this.agents.delete(t),this.config.autoEmitEvents&&i&&this.events.emitAgentStopped(i,t)}}setAgentResponseHandler(t){this.customAgentHandler=t;for(let e of this.agents.values())e.setCustomHandler((i,s)=>t(i,s))}async triggerAgentResponse(t,e){if(this.config.scenario!=="agent_timeout")try{let i=await t.processMessage(e);if(!i)return;let s=this.state.addMessage(t.roomId,`agent_${t.id}`,i);if(!I(s)){let o={id:s.id,timestamp:Date.now(),message:i,content:i,createdAt:s.createdAt,from:{identity:`agent_${t.id}`,name:t.name,id:t.id,role:"agent"}};for(let c of this.messageListeners)c([o]);this.config.autoEmitEvents&&this.events.emitMessageReceived(t.roomId,s)}}catch(i){console.error("Agent response error:",i)}}simulateCallRequest(t){let e={id:u("call"),guestId:t.guestId||"guest_user",name:t.name||"Guest User",createdAt:new Date().toISOString(),status:t.status||"pending",...t},i=this.callRequestListeners.get("new");if(i)for(let s of i)s(e.id,e)}simulateParticipantJoin(t,e,i="user"){if(!this.room?.id)return;let s=this.state.addParticipant(this.room.id,t,e,i,"standard",!1);!I(s)&&this.config.autoEmitEvents&&this.events.emitParticipantJoined(this.room.id,s)}simulateParticipantLeave(t){if(!this.room?.id)return;this.state.removeParticipant(t)&&this.config.autoEmitEvents&&this.events.emitParticipantLeft(this.room.id,t)}simulateIncomingMessage(t,e){if(!this.room?.id)return;let i=this.state.addMessage(this.room.id,t,e);if(I(i))return;let s={id:i.id,timestamp:Date.now(),message:e,content:e,createdAt:i.createdAt,from:{identity:t,id:t,role:"user"}};for(let o of this.messageListeners)o([s]);this.config.autoEmitEvents&&this.events.emitMessageReceived(this.room.id,i)}async simulateDisconnect(){if(!this.room?.id)return;let t=this.room.state;this.room.state="disconnected",this.config.autoEmitEvents&&this.events.emitRoomConnectionStateChanged(this.room.id,"disconnected",t),this.room.emit("connectionStateChanged","disconnected")}reset(){this.state.reset(),this.events.clearHistory(),this.messageListeners.clear(),this.typingListeners.clear(),this.callRequestListeners.clear(),this.agents.clear(),this._authToken=null,this._registeredUser=null,this.room=new x(this),B()}seed(t){this.config.seed=t,this.state.updateConfig({seed:t})}setScenario(t){this.config.scenario=t,this.applyScenario(t)}exportState(){return{...this.state.toJSON(),eventHistory:this.events.getHistory()}}getEventHistory(t){return this.events.getHistory(t)}};var mt={},C={MODE:"LIVEKIT_MODE",USE_MOCK:"USE_LIVEKIT_MOCK",MOCK_LATENCY:"MOCK_LIVEKIT_LATENCY_MS",MOCK_STRICT:"MOCK_LIVEKIT_STRICT",MOCK_SCENARIO:"MOCK_LIVEKIT_SCENARIO",MOCK_SEED:"MOCK_LIVEKIT_SEED",API_URL:"LIVEKIT_API_URL",AUTH_URL:"LIVEKIT_AUTH_URL",ORG_ID:"LIVEKIT_ORGANIZATION_ID"};function ut(){let n=P(C.MODE);if(n==="mock"||n==="real")return n;let t=P(C.USE_MOCK);return t==="true"||t==="1"||Jt()?"mock":"real"}function Kt(){let n={},t=P(C.MOCK_LATENCY);t&&(n.latencyMs=parseInt(t,10));let e=P(C.MOCK_STRICT);(e==="true"||e==="1")&&(n.strictMode=!0);let i=P(C.MOCK_SCENARIO);i&&(n.scenario=i);let s=P(C.MOCK_SEED);return s&&(n.seed=parseInt(s,10)),n}function Vt(){let n={},t=P(C.API_URL);t&&(n.apiUrl=t);let e=P(C.AUTH_URL);e&&(n.authUrl=e);let i=P(C.ORG_ID);return i&&(n.organizationId=i),n}function P(n){if(typeof process<"u"&&process.env)return process.env[n];if(typeof mt<"u"&&mt.env)return mt.env[`VITE_${n}`]||mt.env[n];if(typeof window<"u"&&window.__ENV__)return window.__ENV__[n]}function Jt(){return!!(typeof process<"u"&&process.env&&(process.env.NODE_ENV==="test"||process.env.VITEST||process.env.JEST_WORKER_ID)||typeof globalThis.__vitest_index__<"u")}var b=class n{static create(t){if((t.mode??ut())==="mock"){let i={...Kt(),...t.mockConfig,organizationId:t.organizationId,apiUrl:t.apiUrl};return new _(i)}if(!t.organizationId||!t.apiUrl)throw new Error("ConversationService requires organizationId and apiUrl. Provide them in options or set LIVEKIT_ORGANIZATION_ID and LIVEKIT_API_URL environment variables.");return new lt(t)}static createFromEnv(t){let e=t?.mode??ut(),i=Vt();return n.create({...i,...t,mode:e})}static createMock(t){return new _({organizationId:"mock_org",apiUrl:"https://mock-livekit.local",...t})}static createDeterministicMock(t=12345){return new _({organizationId:"mock_org",apiUrl:"https://mock-livekit.local",seed:t,strictMode:!0})}static getCurrentMode(){return ut()}static isMockMode(){return ut()==="mock"}static isMockService(t){return t instanceof _}};function y(n){return b.createMock(n)}function G(n){let t=n?.id??u("room"),e=new Date().toISOString();return{id:t,name:`Test Room ${t}`,groupId:u("group"),createdAt:e,isActive:!0,participantIds:[],connectionState:"connected",wsURL:F(t),token:A(t,"local_user",e),...n}}function Lt(n="local_user",t){let e=G(t);e.participantIds.push(n);let i={identity:n,name:"Local User",roomId:e.id,joinedAt:new Date().toISOString(),isConnected:!0,trackIds:[],role:"user",attributes:{},kind:"standard",isLocal:!0};return{room:e,localParticipant:i}}function Ut(n){let t=G(n),e=new Date().toISOString(),i={identity:"user_1",name:"User One",roomId:t.id,joinedAt:e,isConnected:!0,trackIds:[],role:"user",attributes:{},kind:"standard",isLocal:!0},s={identity:"user_2",name:"User Two",roomId:t.id,joinedAt:e,isConnected:!0,trackIds:[],role:"user",attributes:{},kind:"standard",isLocal:!1};return t.participantIds.push(i.identity,s.identity),{room:t,participant1:i,participant2:s}}function pt(n,t){let{room:e,localParticipant:i}=Lt("local_user",t),s=new Date().toISOString(),o=u("agent"),c={id:o,roomId:e.id,name:"AI Assistant",status:"running",startedAt:s,config:{responseStrategy:"echo",nature:"ai",...n},messageHistory:[]},a={identity:`agent_${o}`,name:"AI Assistant",roomId:e.id,joinedAt:s,isConnected:!0,trackIds:[],role:"agent",attributes:{},kind:"agent",isLocal:!1};return e.participantIds.push(a.identity),{room:e,localParticipant:i,agent:c,agentParticipant:a}}function Dt(n,t){return t.map((e,i)=>({id:u("msg"),roomId:n,content:e.content,participantIdentity:e.identity,createdAt:new Date(Date.now()+i*1e3).toISOString(),type:"standard"}))}function bt(){let{room:n,localParticipant:t,agent:e,agentParticipant:i}=pt(),s=Dt(n.id,[{identity:t.identity,content:"Hello, I need help"},{identity:i.identity,content:"Hi! How can I assist you today?"},{identity:t.identity,content:"I have a question about my order"},{identity:i.identity,content:"Of course! Please provide your order number."}]);return{room:n,user:t,agent:e,agentParticipant:i,messages:s}}function Rt(){let{room:n,participant1:t,participant2:e}=Ut(),i=new Date().toISOString(),s=[{id:u("track"),kind:"audio",source:"microphone",participantIdentity:t.identity,roomId:n.id,publishedAt:i,muted:!1},{id:u("track"),kind:"video",source:"camera",participantIdentity:t.identity,roomId:n.id,publishedAt:i,muted:!1},{id:u("track"),kind:"audio",source:"microphone",participantIdentity:e.identity,roomId:n.id,publishedAt:i,muted:!1},{id:u("track"),kind:"video",source:"camera",participantIdentity:e.identity,roomId:n.id,publishedAt:i,muted:!1}];return t.trackIds.push(s[0].id,s[1].id),e.trackIds.push(s[2].id,s[3].id),{room:n,participant1:t,participant2:e,tracks:s}}U();var wt=null;function f(n){return wt||(wt=y({organizationId:"storybook_org",apiUrl:"https://storybook.mock",latencyMs:50,autoEmitEvents:!0,...n})),wt}var Ht={async receiveMessage(n,t){f().simulateIncomingMessage(n,t)},simulateJoin(n,t){f().simulateParticipantJoin(n,t)},simulateLeave(n){f().simulateParticipantLeave(n)},async simulateVideoParticipant(n,t,e){let s=f().room;s&&await s.simulateParticipantJoin(n,{name:t||n,kind:"standard",withCamera:e?.withCamera??!0,withMicrophone:e?.withMicrophone??!0})},async simulateVideoAgent(n,t){let i=f().room;i&&await i.simulateAgentJoin(n,t||"AI Agent")},async enableLocalCamera(){let t=f().room;t&&await t.localParticipant.setCameraEnabled(!0)},async disableLocalCamera(){let t=f().room;t&&await t.localParticipant.setCameraEnabled(!1)},async enableLocalMicrophone(){let t=f().room;t&&await t.localParticipant.setMicrophoneEnabled(!0)},async simulateMultipleParticipants(n){let t=["Alice","Bob","Carol","David","Eve","Frank","Grace","Henry","Ivy","Jack"],i=f().room;if(i)for(let s=0;s<Math.min(n,t.length);s++)await i.simulateParticipantJoin(`participant_${s+1}`,{name:t[s],kind:"standard",withCamera:!0,withMicrophone:!0}),await new Promise(o=>setTimeout(o,100))},clearParticipants(){let t=f().room;if(t)for(let e of t.remoteParticipants.keys())t.simulateParticipantLeave(e)},simulateCallRequest(n,t){f().simulateCallRequest({name:n,guestId:t||`guest_${Date.now()}`})},async simulateDisconnect(){await f().simulateDisconnect()},getEventHistory(){return f().getEventHistory()},exportState(){return f().exportState()},getRoom(){return f().room}};typeof window<"u"&&(window.MockServiceActions=Ht);(0,r.describe)("MockConversationService",()=>{let n;(0,r.beforeEach)(()=>{B(),n=y({organizationId:"test_org",apiUrl:"https://mock.local"})}),(0,r.afterEach)(async()=>{await n.destroy()}),(0,r.describe)("initialization",()=>{(0,r.it)("should create a service with default configuration",()=>{let t=n.getConfig();(0,r.expect)(t.organizationId).toBe("test_org"),(0,r.expect)(t.apiUrl).toBe("https://mock.local"),(0,r.expect)(t.latencyMs).toBe(0),(0,r.expect)(t.strictMode).toBe(!1)}),(0,r.it)("should create a service with custom configuration",()=>{let e=y({latencyMs:100,strictMode:!0,seed:12345}).getConfig();(0,r.expect)(e.latencyMs).toBe(100),(0,r.expect)(e.strictMode).toBe(!0),(0,r.expect)(e.seed).toBe(12345)}),(0,r.it)("should have an empty room initially",()=>{(0,r.expect)(n.room).toBeDefined(),(0,r.expect)(n.room.id).toBeUndefined()})}),(0,r.describe)("user registration",()=>{(0,r.it)("should register a user successfully",async()=>{let t=await n.registerUser("user_123","secret");(0,r.expect)(t.externalId).toBe("user_123"),(0,r.expect)(t.organizationId).toBe("test_org"),(0,r.expect)(t.role).toBe("user"),(0,r.expect)(t.token).toContain("mock_token_")}),(0,r.it)("should set local participant identity after registration",async()=>{await n.registerUser("user_123","secret",{name:"Test User"}),(0,r.expect)(n.room.localParticipant.identity).toBe("user_123"),(0,r.expect)(n.room.localParticipant.name).toBe("Test User")}),(0,r.it)("should register an agent successfully",async()=>{let t=await n.registerAgent("agent_1",{name:"AI Assistant",email:"agent@test.com"});(0,r.expect)(t).toContain("mock_token_"),(0,r.expect)(n.room.localParticipant.identity).toBe("agent_1"),(0,r.expect)(n.room.localParticipant.name).toBe("AI Assistant")})}),(0,r.describe)("room lifecycle",()=>{(0,r.beforeEach)(async()=>{await n.registerUser("test_user","secret")}),(0,r.it)("should create a room successfully",async()=>{let t=await n.createRoom({language:"en",timezone:"UTC"});(0,r.expect)(t.id).toBeDefined(),(0,r.expect)(t.id).toContain("mock_room_"),(0,r.expect)(t.state).toBe("connected")}),(0,r.it)("should set room metadata on creation",async()=>{let t=await n.createRoom({language:"es",timezone:"America/New_York",metadata:{custom:"data"}});(0,r.expect)(t.groupId).toBeDefined(),(0,r.expect)(t.createdAt).toBeDefined(),(0,r.expect)(t.connectedAt).toBeDefined()}),(0,r.it)("should add local participant to room on creation",async()=>{await n.createRoom({language:"en",timezone:"UTC"});let t=n.getState().listParticipants(n.room.id);(0,r.expect)(t).toHaveLength(1),(0,r.expect)(t[0].identity).toBe("test_user"),(0,r.expect)(t[0].isLocal).toBe(!0)}),(0,r.it)("should join an existing room",async()=>{let t=await n.createRoom({language:"en",timezone:"UTC"}),e=y();await e.registerUser("user_2","secret"),e.getState().createRoom("shared_room",t.groupId);let s=e.getState().listRooms()[0].id,o=await e.joinRoom(s,"UTC","en");(0,r.expect)(o.id).toBe(s),(0,r.expect)(o.state).toBe("connected"),await e.destroy()}),(0,r.it)("should throw error when joining non-existent room",async()=>{await(0,r.expect)(n.joinRoom("non_existent_room","UTC","en")).rejects.toThrow(w)}),(0,r.it)("should close a room",async()=>{await n.createRoom({language:"en",timezone:"UTC"});let t=n.room.id;await n.closeRoom();let e=n.getState().getRoom(t);(0,r.expect)(e?.isActive).toBe(!1),(0,r.expect)(e?.endedAt).toBeDefined()}),(0,r.it)("should disconnect from a room",async()=>{await n.createRoom({language:"en",timezone:"UTC"}),await n.disconnect(),(0,r.expect)(n.room.state).toBe("disconnected")}),(0,r.it)("should list rooms",async()=>{await n.createRoom({language:"en",timezone:"UTC"}),await n.createRoom({language:"es",timezone:"UTC"});let t=await n.getRooms({});(0,r.expect)(t.items).toHaveLength(2),(0,r.expect)(t.count).toBe(2)}),(0,r.it)("should filter rooms by status",async()=>{await n.createRoom({language:"en",timezone:"UTC"});let t=n.room.id;await n.createRoom({language:"es",timezone:"UTC"}),n.getState().endRoom(t);let e=await n.getRooms({roomStatus:"active"});(0,r.expect)(e.items).toHaveLength(1);let i=await n.getRooms({roomStatus:"closed"});(0,r.expect)(i.items).toHaveLength(1)})}),(0,r.describe)("messaging",()=>{(0,r.beforeEach)(async()=>{await n.registerUser("test_user","secret"),await n.createRoom({language:"en",timezone:"UTC"})}),(0,r.it)("should send a message",async()=>{let t=[];n.subscribeMessages(e=>t.push(...e)),await n.sendMessage("Hello, world!"),(0,r.expect)(t).toHaveLength(1),(0,r.expect)(t[0].message).toBe("Hello, world!")}),(0,r.it)("should store messages in room state",async()=>{await n.sendMessage("First message"),await n.sendMessage("Second message");let t=n.getState().getMessages(n.room.id);(0,r.expect)(t).toHaveLength(2),(0,r.expect)(t[0].content).toBe("First message"),(0,r.expect)(t[1].content).toBe("Second message")}),(0,r.it)("should emit message events",async()=>{let t=n.getEvents(),e=[];t.on("messageSent",i=>e.push(i)),await n.sendMessage("Test message"),(0,r.expect)(e).toHaveLength(1)}),(0,r.it)("should get messages",async()=>{await n.sendMessage("Message 1"),await n.sendMessage("Message 2"),await n.sendMessage("Message 3");let t=await n.getMessages({limit:2});(0,r.expect)(t).toHaveLength(2)}),(0,r.it)("should handle message subscriptions",async()=>{let t=[],e=n.subscribeMessages(i=>t.push(...i));await n.sendMessage("Test"),(0,r.expect)(t).toHaveLength(1),e(),await n.sendMessage("After unsubscribe"),(0,r.expect)(t).toHaveLength(1)})}),(0,r.describe)("typing indicators",()=>{(0,r.beforeEach)(async()=>{await n.registerUser("test_user","secret"),await n.createRoom({language:"en",timezone:"UTC"})}),(0,r.it)("should send typing indicator",async()=>{let t=[];n.subscribeTypingIndicators(e=>t.push(e)),await n.sendTypingIndicator(!0),await n.sendTypingIndicator(!1),(0,r.expect)(t).toHaveLength(2),(0,r.expect)(t[0].isTyping).toBe(!0),(0,r.expect)(t[1].isTyping).toBe(!1)}),(0,r.it)("should unsubscribe from typing indicators",async()=>{let t=[],e=i=>t.push(i);n.subscribeTypingIndicators(e),await n.sendTypingIndicator(!0),(0,r.expect)(t).toHaveLength(1),n.unsubscribeTypingIndicators(e),await n.sendTypingIndicator(!1),(0,r.expect)(t).toHaveLength(1)})}),(0,r.describe)("agents",()=>{(0,r.beforeEach)(async()=>{await n.registerUser("test_user","secret"),await n.createRoom({language:"en",timezone:"UTC"})}),(0,r.it)("should start an agent in a room",async()=>{let t=await n.startMockAgent(n.room.id,{responseStrategy:"echo"});(0,r.expect)(t).toBeDefined();let e=n.getState().listAgents(n.room.id);(0,r.expect)(e).toHaveLength(1),(0,r.expect)(e[0].status).toBe("running")}),(0,r.it)("should stop an agent",async()=>{let t=await n.startMockAgent(n.room.id);await n.stopMockAgent(t);let e=n.getState().getAgent(t);(0,r.expect)(e?.status).toBe("stopped")}),(0,r.it)("should trigger echo response from agent",async()=>{await n.startMockAgent(n.room.id,{responseStrategy:"echo"});let t=[];n.subscribeMessages(i=>t.push(...i)),await n.sendMessage("Hello agent!"),(0,r.expect)(t.length).toBeGreaterThanOrEqual(2);let e=t.find(i=>i.message?.startsWith("Echo:")||i.content?.startsWith("Echo:"));(0,r.expect)(e).toBeDefined()}),(0,r.it)("should use canned responses",async()=>{await n.startMockAgent(n.room.id,{responseStrategy:"canned",cannedResponses:["Hello!","How can I help?"]});let t=[];n.subscribeMessages(i=>t.push(...i)),await n.sendMessage("Hi");let e=t.find(i=>i.message==="Hello!"||i.content==="Hello!");(0,r.expect)(e).toBeDefined()}),(0,r.it)("should use sequential responses",async()=>{await n.startMockAgent(n.room.id,{responseStrategy:"sequential",cannedResponses:["First","Second","Third"]});let t=[];n.subscribeMessages(i=>t.push(...i)),await n.sendMessage("Message 1"),await n.sendMessage("Message 2"),await n.sendMessage("Message 3");let e=t.filter(i=>!i.message?.startsWith("Message")&&!i.content?.startsWith("Message")).map(i=>i.message||i.content);(0,r.expect)(e).toContain("First"),(0,r.expect)(e).toContain("Second"),(0,r.expect)(e).toContain("Third")}),(0,r.it)("should use custom response handler",async()=>{await n.startMockAgent(n.room.id),n.setAgentResponseHandler((i,s)=>`Custom: ${s.toUpperCase()}`);let t=[];n.subscribeMessages(i=>t.push(...i)),await n.sendMessage("test");let e=t.find(i=>i.message==="Custom: TEST"||i.content==="Custom: TEST");(0,r.expect)(e).toBeDefined()}),(0,r.it)("should be silent when configured",async()=>{await n.startMockAgent(n.room.id,{responseStrategy:"silent"});let t=[];n.subscribeMessages(e=>t.push(...e)),await n.sendMessage("Hello?"),(0,r.expect)(t).toHaveLength(1)})}),(0,r.describe)("event system",()=>{(0,r.beforeEach)(async()=>{await n.registerUser("test_user","secret")}),(0,r.it)("should emit room created event",async()=>{let t=n.getEvents(),e=[];t.on("roomCreated",i=>e.push(i)),await n.createRoom({language:"en",timezone:"UTC"}),(0,r.expect)(e).toHaveLength(1)}),(0,r.it)("should emit participant joined event",async()=>{await n.createRoom({language:"en",timezone:"UTC"});let t=n.getEvents(),e=[];t.on("participantJoined",i=>e.push(i)),n.simulateParticipantJoin("new_participant","New User"),(0,r.expect)(e).toHaveLength(1),(0,r.expect)(e[0].participant.identity).toBe("new_participant")}),(0,r.it)("should emit participant left event",async()=>{await n.createRoom({language:"en",timezone:"UTC"}),n.simulateParticipantJoin("participant_1");let t=n.getEvents(),e=[];t.on("participantLeft",i=>e.push(i)),n.simulateParticipantLeave("participant_1"),(0,r.expect)(e).toHaveLength(1)}),(0,r.it)("should track event history",async()=>{await n.createRoom({language:"en",timezone:"UTC"}),await n.sendMessage("Test");let t=n.getEventHistory();(0,r.expect)(t.length).toBeGreaterThan(0);let e=n.getEventHistory("messageSent");(0,r.expect)(e).toHaveLength(1)}),(0,r.it)("should support wildcard event listeners",async()=>{let t=n.getEvents(),e=[];t.onAny(i=>e.push(i)),await n.createRoom({language:"en",timezone:"UTC"}),(0,r.expect)(e.length).toBeGreaterThan(0)})}),(0,r.describe)("simulations",()=>{(0,r.beforeEach)(async()=>{await n.registerUser("test_user","secret"),await n.createRoom({language:"en",timezone:"UTC"})}),(0,r.it)("should simulate incoming message",async()=>{let t=[];n.subscribeMessages(e=>t.push(...e)),n.simulateIncomingMessage("other_user","Hello from outside!"),(0,r.expect)(t).toHaveLength(1),(0,r.expect)(t[0].message).toBe("Hello from outside!")}),(0,r.it)("should simulate room disconnect",async()=>{let t=n.getEvents(),e=[];t.on("roomConnectionStateChanged",i=>e.push(i)),await n.simulateDisconnect(),(0,r.expect)(n.room.state).toBe("disconnected"),(0,r.expect)(e).toHaveLength(1)}),(0,r.it)("should simulate call request",async()=>{let t=[];n.onNewCallRequest((e,i)=>t.push(i)),n.simulateCallRequest({guestId:"guest_1",name:"Guest User"}),(0,r.expect)(t).toHaveLength(1),(0,r.expect)(t[0].name).toBe("Guest User")})}),(0,r.describe)("configuration",()=>{(0,r.it)("should apply latency configuration",async()=>{let t=y({latencyMs:50});await t.registerUser("user","secret");let e=Date.now();await t.createRoom({language:"en",timezone:"UTC"});let i=Date.now()-e;(0,r.expect)(i).toBeGreaterThanOrEqual(45),await t.destroy()}),(0,r.it)("should support deterministic behavior with seed",async()=>{let t=y({seed:12345}),e=y({seed:12345}),i=t.getState().random(),s=e.getState().random();(0,r.expect)(i).toBe(s)}),(0,r.it)("should apply scenario configuration",()=>{let t=y({scenario:"slow_network"});(0,r.expect)(t.getConfig().latencyMs).toBe(500)}),(0,r.it)("should reset state",async()=>{await n.registerUser("user","secret"),await n.createRoom({language:"en",timezone:"UTC"}),await n.sendMessage("Test"),n.reset(),(0,r.expect)(n.getState().listRooms()).toHaveLength(0),(0,r.expect)(n.getEventHistory()).toHaveLength(0)})}),(0,r.describe)("error handling",()=>{(0,r.it)("should throw error for unauthorized registration",async()=>{let t=y({errorConfig:{unauthorized:!0}});await(0,r.expect)(t.registerUser("user","secret")).rejects.toThrow(m)}),(0,r.it)("should throw error for network issues",async()=>{let t=y({errorConfig:{networkError:!0}});await t.registerUser("user","secret"),await(0,r.expect)(t.createRoom({language:"en",timezone:"UTC"})).rejects.toThrow(m)}),(0,r.it)("should throw probabilistic errors based on error rate",async()=>{let t=y({errorConfig:{errorRate:100}});await t.registerUser("user","secret"),await(0,r.expect)(t.createRoom({language:"en",timezone:"UTC"})).rejects.toThrow()})}),(0,r.describe)("state persistence",()=>{(0,r.it)("should export state to JSON",async()=>{await n.registerUser("user","secret"),await n.createRoom({language:"en",timezone:"UTC"}),await n.sendMessage("Test message");let t=n.exportState();(0,r.expect)(t).toHaveProperty("rooms"),(0,r.expect)(t).toHaveProperty("participants"),(0,r.expect)(t).toHaveProperty("messages"),(0,r.expect)(t).toHaveProperty("eventHistory")}),(0,r.it)("should import state from JSON",async()=>{await n.registerUser("user","secret"),await n.createRoom({language:"en",timezone:"UTC"});let t=n.room.id,e=n.getState().toJSON();n.reset(),n.getState().fromJSON(e);let i=n.getState().listRooms();(0,r.expect)(i).toHaveLength(1),(0,r.expect)(i[0].id).toBe(t)})})});(0,r.describe)("ConversationServiceFactory",()=>{(0,r.it)("should create mock service with createMock",()=>{let n=b.createMock();(0,r.expect)(b.isMockService(n)).toBe(!0)}),(0,r.it)("should create deterministic mock",()=>{let n=b.createDeterministicMock(42);(0,r.expect)(n.getConfig().seed).toBe(42),(0,r.expect)(n.getConfig().strictMode).toBe(!0)}),(0,r.it)("should check if service is mock",()=>{let n=b.createMock();(0,r.expect)(b.isMockService(n)).toBe(!0)})});(0,r.describe)("fixtures",()=>{(0,r.it)("should create default room fixture",()=>{let n=G();(0,r.expect)(n.id).toBeDefined(),(0,r.expect)(n.name).toBeDefined(),(0,r.expect)(n.isActive).toBe(!0),(0,r.expect)(n.connectionState).toBe("connected")}),(0,r.it)("should create room with agent fixture",()=>{let{room:n,localParticipant:t,agent:e,agentParticipant:i}=pt();(0,r.expect)(n.participantIds).toContain(t.identity),(0,r.expect)(n.participantIds).toContain(i.identity),(0,r.expect)(e.status).toBe("running"),(0,r.expect)(i.role).toBe("agent")}),(0,r.it)("should create chat scenario fixture",()=>{let{room:n,user:t,agent:e,messages:i}=bt();(0,r.expect)(n).toBeDefined(),(0,r.expect)(t).toBeDefined(),(0,r.expect)(e).toBeDefined(),(0,r.expect)(i.length).toBeGreaterThan(0)}),(0,r.it)("should create video call scenario fixture",()=>{let{room:n,participant1:t,participant2:e,tracks:i}=Rt();(0,r.expect)(n).toBeDefined(),(0,r.expect)(t).toBeDefined(),(0,r.expect)(e).toBeDefined(),(0,r.expect)(i).toHaveLength(4)})});