@ably/ai-transport 0.1.0 → 0.3.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (221) hide show
  1. package/README.md +93 -111
  2. package/dist/ably-ai-transport.js +2401 -1387
  3. package/dist/ably-ai-transport.js.map +1 -1
  4. package/dist/ably-ai-transport.umd.cjs +1 -1
  5. package/dist/ably-ai-transport.umd.cjs.map +1 -1
  6. package/dist/constants.d.ts +116 -42
  7. package/dist/core/agent.d.ts +44 -0
  8. package/dist/core/channel-options.d.ts +57 -0
  9. package/dist/core/codec/codec-event.d.ts +9 -0
  10. package/dist/core/codec/decoder.d.ts +24 -24
  11. package/dist/core/codec/define-codec.d.ts +100 -0
  12. package/dist/core/codec/encoder.d.ts +10 -12
  13. package/dist/core/codec/field-bag.d.ts +85 -0
  14. package/dist/core/codec/fields.d.ts +141 -0
  15. package/dist/core/codec/index.d.ts +8 -2
  16. package/dist/core/codec/input-descriptor-decoder.d.ts +19 -0
  17. package/dist/core/codec/input-descriptor-encoder.d.ts +22 -0
  18. package/dist/core/codec/input-descriptors.d.ts +281 -0
  19. package/dist/core/codec/lifecycle-tracker.d.ts +10 -9
  20. package/dist/core/codec/output-descriptor-decoder.d.ts +29 -0
  21. package/dist/core/codec/output-descriptor-encoder.d.ts +31 -0
  22. package/dist/core/codec/output-descriptors.d.ts +237 -0
  23. package/dist/core/codec/types.d.ts +470 -119
  24. package/dist/core/codec/well-known-inputs.d.ts +52 -0
  25. package/dist/core/transport/agent-session.d.ts +10 -0
  26. package/dist/core/transport/agent-view.d.ts +296 -0
  27. package/dist/core/transport/client-session.d.ts +13 -0
  28. package/dist/core/transport/decode-fold.d.ts +55 -0
  29. package/dist/core/transport/headers.d.ts +121 -14
  30. package/dist/core/transport/index.d.ts +5 -6
  31. package/dist/core/transport/internal/bounded-map.d.ts +20 -0
  32. package/dist/core/transport/invocation.d.ts +74 -0
  33. package/dist/core/transport/load-history-pages.d.ts +71 -0
  34. package/dist/core/transport/load-history.d.ts +44 -0
  35. package/dist/core/transport/pipe-stream.d.ts +9 -9
  36. package/dist/core/transport/run-manager.d.ts +76 -0
  37. package/dist/core/transport/session-support.d.ts +55 -0
  38. package/dist/core/transport/tree.d.ts +523 -109
  39. package/dist/core/transport/types/agent.d.ts +375 -0
  40. package/dist/core/transport/types/client.d.ts +201 -0
  41. package/dist/core/transport/types/shared.d.ts +24 -0
  42. package/dist/core/transport/types/tree.d.ts +357 -0
  43. package/dist/core/transport/types/view.d.ts +249 -0
  44. package/dist/core/transport/types.d.ts +13 -553
  45. package/dist/core/transport/view.d.ts +390 -84
  46. package/dist/core/transport/wire-log.d.ts +102 -0
  47. package/dist/errors.d.ts +27 -10
  48. package/dist/index.d.ts +8 -9
  49. package/dist/logger.d.ts +12 -0
  50. package/dist/react/ably-ai-transport-react.js +1365 -1010
  51. package/dist/react/ably-ai-transport-react.js.map +1 -1
  52. package/dist/react/ably-ai-transport-react.umd.cjs +1 -1
  53. package/dist/react/ably-ai-transport-react.umd.cjs.map +1 -1
  54. package/dist/react/contexts/client-session-context.d.ts +37 -0
  55. package/dist/react/contexts/client-session-provider.d.ts +56 -0
  56. package/dist/react/create-session-hooks.d.ts +116 -0
  57. package/dist/react/index.d.ts +13 -12
  58. package/dist/react/internal/skipped-session.d.ts +8 -0
  59. package/dist/react/internal/use-resolved-session.d.ts +36 -0
  60. package/dist/react/use-ably-messages.d.ts +17 -14
  61. package/dist/react/use-client-session.d.ts +81 -0
  62. package/dist/react/use-create-view.d.ts +14 -13
  63. package/dist/react/use-tree.d.ts +30 -15
  64. package/dist/react/use-view.d.ts +81 -50
  65. package/dist/utils.d.ts +48 -71
  66. package/dist/vercel/ably-ai-transport-vercel.js +3257 -2499
  67. package/dist/vercel/ably-ai-transport-vercel.js.map +1 -1
  68. package/dist/vercel/ably-ai-transport-vercel.umd.cjs +1 -1
  69. package/dist/vercel/ably-ai-transport-vercel.umd.cjs.map +1 -1
  70. package/dist/vercel/codec/decode-lifecycle.d.ts +9 -0
  71. package/dist/vercel/codec/events.d.ts +50 -0
  72. package/dist/vercel/codec/fields.d.ts +44 -0
  73. package/dist/vercel/codec/fold-content.d.ts +16 -0
  74. package/dist/vercel/codec/fold-data.d.ts +16 -0
  75. package/dist/vercel/codec/fold-input.d.ts +67 -0
  76. package/dist/vercel/codec/fold-lifecycle.d.ts +16 -0
  77. package/dist/vercel/codec/fold-text.d.ts +16 -0
  78. package/dist/vercel/codec/fold-tool-input.d.ts +17 -0
  79. package/dist/vercel/codec/fold-tool-output.d.ts +16 -0
  80. package/dist/vercel/codec/index.d.ts +7 -20
  81. package/dist/vercel/codec/inputs.d.ts +11 -0
  82. package/dist/vercel/codec/outputs.d.ts +11 -0
  83. package/dist/vercel/codec/reducer-state.d.ts +121 -0
  84. package/dist/vercel/codec/reducer.d.ts +62 -0
  85. package/dist/vercel/codec/tool-transitions.d.ts +2 -8
  86. package/dist/vercel/codec/wire-data.d.ts +34 -0
  87. package/dist/vercel/index.d.ts +5 -5
  88. package/dist/vercel/react/ably-ai-transport-vercel-react.js +2859 -9705
  89. package/dist/vercel/react/ably-ai-transport-vercel-react.js.map +1 -1
  90. package/dist/vercel/react/ably-ai-transport-vercel-react.umd.cjs +1 -45
  91. package/dist/vercel/react/ably-ai-transport-vercel-react.umd.cjs.map +1 -1
  92. package/dist/vercel/react/contexts/chat-transport-context.d.ts +9 -7
  93. package/dist/vercel/react/contexts/chat-transport-provider.d.ts +53 -41
  94. package/dist/vercel/react/index.d.ts +1 -2
  95. package/dist/vercel/react/use-chat-transport.d.ts +30 -26
  96. package/dist/vercel/react/use-message-sync.d.ts +17 -30
  97. package/dist/vercel/run-end-reason.d.ts +84 -0
  98. package/dist/vercel/tool-part.d.ts +21 -0
  99. package/dist/vercel/transport/chat-transport.d.ts +41 -24
  100. package/dist/vercel/transport/index.d.ts +24 -20
  101. package/dist/vercel/transport/run-output-stream.d.ts +54 -0
  102. package/dist/version.d.ts +2 -0
  103. package/package.json +31 -24
  104. package/src/constants.ts +124 -51
  105. package/src/core/agent.ts +92 -0
  106. package/src/core/channel-options.ts +89 -0
  107. package/src/core/codec/codec-event.ts +27 -0
  108. package/src/core/codec/decoder.ts +202 -105
  109. package/src/core/codec/define-codec.ts +432 -0
  110. package/src/core/codec/encoder.ts +114 -107
  111. package/src/core/codec/field-bag.ts +142 -0
  112. package/src/core/codec/fields.ts +193 -0
  113. package/src/core/codec/index.ts +56 -6
  114. package/src/core/codec/input-descriptor-decoder.ts +97 -0
  115. package/src/core/codec/input-descriptor-encoder.ts +150 -0
  116. package/src/core/codec/input-descriptors.ts +373 -0
  117. package/src/core/codec/lifecycle-tracker.ts +10 -9
  118. package/src/core/codec/output-descriptor-decoder.ts +139 -0
  119. package/src/core/codec/output-descriptor-encoder.ts +101 -0
  120. package/src/core/codec/output-descriptors.ts +307 -0
  121. package/src/core/codec/types.ts +505 -126
  122. package/src/core/codec/well-known-inputs.ts +96 -0
  123. package/src/core/transport/agent-session.ts +1085 -0
  124. package/src/core/transport/agent-view.ts +738 -0
  125. package/src/core/transport/client-session.ts +780 -0
  126. package/src/core/transport/decode-fold.ts +101 -0
  127. package/src/core/transport/headers.ts +234 -22
  128. package/src/core/transport/index.ts +27 -27
  129. package/src/core/transport/internal/bounded-map.ts +27 -0
  130. package/src/core/transport/invocation.ts +98 -0
  131. package/src/core/transport/load-history-pages.ts +220 -0
  132. package/src/core/transport/load-history.ts +271 -0
  133. package/src/core/transport/pipe-stream.ts +63 -39
  134. package/src/core/transport/run-manager.ts +243 -0
  135. package/src/core/transport/session-support.ts +96 -0
  136. package/src/core/transport/tree.ts +1293 -308
  137. package/src/core/transport/types/agent.ts +434 -0
  138. package/src/core/transport/types/client.ts +247 -0
  139. package/src/core/transport/types/shared.ts +27 -0
  140. package/src/core/transport/types/tree.ts +393 -0
  141. package/src/core/transport/types/view.ts +288 -0
  142. package/src/core/transport/types.ts +13 -706
  143. package/src/core/transport/view.ts +1229 -450
  144. package/src/core/transport/wire-log.ts +189 -0
  145. package/src/errors.ts +29 -9
  146. package/src/event-emitter.ts +3 -2
  147. package/src/index.ts +86 -42
  148. package/src/logger.ts +14 -1
  149. package/src/react/contexts/client-session-context.ts +41 -0
  150. package/src/react/contexts/client-session-provider.tsx +222 -0
  151. package/src/react/create-session-hooks.ts +141 -0
  152. package/src/react/index.ts +24 -13
  153. package/src/react/internal/skipped-session.ts +62 -0
  154. package/src/react/internal/use-resolved-session.ts +63 -0
  155. package/src/react/use-ably-messages.ts +32 -22
  156. package/src/react/use-client-session.ts +178 -0
  157. package/src/react/use-create-view.ts +33 -29
  158. package/src/react/use-tree.ts +61 -30
  159. package/src/react/use-view.ts +138 -96
  160. package/src/utils.ts +83 -131
  161. package/src/vercel/codec/decode-lifecycle.ts +70 -0
  162. package/src/vercel/codec/events.ts +85 -0
  163. package/src/vercel/codec/fields.ts +58 -0
  164. package/src/vercel/codec/fold-content.ts +54 -0
  165. package/src/vercel/codec/fold-data.ts +46 -0
  166. package/src/vercel/codec/fold-input.ts +255 -0
  167. package/src/vercel/codec/fold-lifecycle.ts +85 -0
  168. package/src/vercel/codec/fold-text.ts +55 -0
  169. package/src/vercel/codec/fold-tool-input.ts +86 -0
  170. package/src/vercel/codec/fold-tool-output.ts +79 -0
  171. package/src/vercel/codec/index.ts +28 -21
  172. package/src/vercel/codec/inputs.ts +116 -0
  173. package/src/vercel/codec/outputs.ts +207 -0
  174. package/src/vercel/codec/reducer-state.ts +169 -0
  175. package/src/vercel/codec/reducer.ts +191 -0
  176. package/src/vercel/codec/tool-transitions.ts +3 -14
  177. package/src/vercel/codec/wire-data.ts +64 -0
  178. package/src/vercel/index.ts +7 -19
  179. package/src/vercel/react/contexts/chat-transport-context.ts +8 -7
  180. package/src/vercel/react/contexts/chat-transport-provider.tsx +87 -59
  181. package/src/vercel/react/index.ts +3 -5
  182. package/src/vercel/react/use-chat-transport.ts +44 -66
  183. package/src/vercel/react/use-message-sync.ts +75 -39
  184. package/src/vercel/run-end-reason.ts +157 -0
  185. package/src/vercel/tool-part.ts +25 -0
  186. package/src/vercel/transport/chat-transport.ts +380 -98
  187. package/src/vercel/transport/index.ts +38 -37
  188. package/src/vercel/transport/run-output-stream.ts +169 -0
  189. package/src/version.ts +2 -0
  190. package/dist/core/transport/client-transport.d.ts +0 -10
  191. package/dist/core/transport/decode-history.d.ts +0 -43
  192. package/dist/core/transport/server-transport.d.ts +0 -7
  193. package/dist/core/transport/stream-router.d.ts +0 -29
  194. package/dist/core/transport/turn-manager.d.ts +0 -37
  195. package/dist/react/contexts/transport-context.d.ts +0 -31
  196. package/dist/react/contexts/transport-provider.d.ts +0 -49
  197. package/dist/react/create-transport-hooks.d.ts +0 -124
  198. package/dist/react/use-active-turns.d.ts +0 -12
  199. package/dist/react/use-client-transport.d.ts +0 -80
  200. package/dist/vercel/codec/accumulator.d.ts +0 -21
  201. package/dist/vercel/codec/decoder.d.ts +0 -22
  202. package/dist/vercel/codec/encoder.d.ts +0 -41
  203. package/dist/vercel/react/use-staged-add-tool-approval-response.d.ts +0 -30
  204. package/dist/vercel/tool-approvals.d.ts +0 -124
  205. package/dist/vercel/tool-events.d.ts +0 -26
  206. package/src/core/transport/client-transport.ts +0 -977
  207. package/src/core/transport/decode-history.ts +0 -485
  208. package/src/core/transport/server-transport.ts +0 -612
  209. package/src/core/transport/stream-router.ts +0 -136
  210. package/src/core/transport/turn-manager.ts +0 -165
  211. package/src/react/contexts/transport-context.ts +0 -37
  212. package/src/react/contexts/transport-provider.tsx +0 -164
  213. package/src/react/create-transport-hooks.ts +0 -144
  214. package/src/react/use-active-turns.ts +0 -72
  215. package/src/react/use-client-transport.ts +0 -197
  216. package/src/vercel/codec/accumulator.ts +0 -588
  217. package/src/vercel/codec/decoder.ts +0 -618
  218. package/src/vercel/codec/encoder.ts +0 -410
  219. package/src/vercel/react/use-staged-add-tool-approval-response.ts +0 -87
  220. package/src/vercel/tool-approvals.ts +0 -380
  221. package/src/vercel/tool-events.ts +0 -53
@@ -1,2 +1,2 @@
1
- (function(e,t){typeof exports==`object`&&typeof module<`u`?t(exports,require(`react`),require(`ably`),require(`ably/react`),require(`react/jsx-runtime`)):typeof define==`function`&&define.amd?define([`exports`,`react`,`ably`,`ably/react`,`react/jsx-runtime`],t):(e=typeof globalThis<`u`?globalThis:e||self,t(e.AblyAiTransportReact={},e.React,e.Ably,e.AblyReact,e.ReactJsxRuntime))})(this,function(e,t,n,r,i){Object.defineProperty(e,Symbol.toStringTag,{value:`Module`});var a=Object.create,o=Object.defineProperty,s=Object.getOwnPropertyDescriptor,c=Object.getOwnPropertyNames,l=Object.getPrototypeOf,u=Object.prototype.hasOwnProperty,d=(e,t,n,r)=>{if(t&&typeof t==`object`||typeof t==`function`)for(var i=c(t),a=0,l=i.length,d;a<l;a++)d=i[a],!u.call(e,d)&&d!==n&&o(e,d,{get:(e=>t[e]).bind(null,d),enumerable:!(r=s(t,d))||r.enumerable});return e};n=((e,t,n)=>(n=e==null?{}:a(l(e)),d(t||!e||!e.__esModule?o(n,`default`,{value:e,enumerable:!0}):n,e)))(n,1);var f=(0,t.createContext)({}),p=(0,t.createContext)(void 0),m=`x-ably-status`,h=`x-ably-turn-id`,g=`x-ably-msg-id`,_=`x-ably-turn-client-id`,v=`x-ably-role`,y=`x-ably-amend`,b=`x-ably-cancel-turn-id`,x=`x-ably-cancel-own`,ee=`x-ably-cancel-all`,te=`x-ably-cancel-client-id`,S=`x-ably-parent`,C=`x-ably-fork-of`,w=`x-ably-cancel`,T=`x-ably-turn-start`,ne=`x-ably-turn-end`,E=function(e){return e[e.BadRequest=4e4]=`BadRequest`,e[e.InvalidArgument=40003]=`InvalidArgument`,e[e.EncoderRecoveryFailed=104e3]=`EncoderRecoveryFailed`,e[e.TransportSubscriptionError=104001]=`TransportSubscriptionError`,e[e.CancelListenerError=104002]=`CancelListenerError`,e[e.TurnLifecycleError=104003]=`TurnLifecycleError`,e[e.TransportClosed=104004]=`TransportClosed`,e[e.TransportSendFailed=104005]=`TransportSendFailed`,e[e.ChannelContinuityLost=104006]=`ChannelContinuityLost`,e[e.ChannelNotReady=104007]=`ChannelNotReady`,e[e.StreamError=104008]=`StreamError`,e}({}),D=e=>({logAction:(t,n,r)=>{e.error(n,{detail:r})},shouldLog:()=>!0}),re=n.Realtime.EventEmitter,O=class extends re{constructor(e){super(D(e))}},k=function(e){return e.Trace=`trace`,e.Debug=`debug`,e.Info=`info`,e.Warn=`warn`,e.Error=`error`,e.Silent=`silent`,e}({}),A=(e,t,n)=>{let r=n?`, context: ${JSON.stringify(n)}`:``,i=`[${new Date().toISOString()}] ${t.valueOf().toUpperCase()} ably-ai-transport: ${e}${r}`;switch(t){case k.Trace:case k.Debug:console.log(i);break;case k.Info:console.info(i);break;case k.Warn:console.warn(i);break;case k.Error:console.error(i);break;case k.Silent:break}},j=e=>new P(e.logHandler??A,e.logLevel),M=function(e){return e[e.Trace=0]=`Trace`,e[e.Debug=1]=`Debug`,e[e.Info=2]=`Info`,e[e.Warn=3]=`Warn`,e[e.Error=4]=`Error`,e[e.Silent=5]=`Silent`,e}(M||{}),N=new Map([[k.Trace,M.Trace],[k.Debug,M.Debug],[k.Info,M.Info],[k.Warn,M.Warn],[k.Error,M.Error],[k.Silent,M.Silent]]),P=class e{constructor(e,t,r){this._handler=e,this._context=r;let i=N.get(t);if(i===void 0)throw new n.ErrorInfo(`unable to create logger; invalid log level: ${t}`,E.InvalidArgument,400);this._levelNumber=i}trace(e,t){this._write(e,k.Trace,M.Trace,t)}debug(e,t){this._write(e,k.Debug,M.Debug,t)}info(e,t){this._write(e,k.Info,M.Info,t)}warn(e,t){this._write(e,k.Warn,M.Warn,t)}error(e,t){this._write(e,k.Error,M.Error,t)}withContext(t){let n=[...N.entries()].find(([,e])=>e===this._levelNumber)?.[0]??k.Error;return new e(this._handler,n,this._mergeContext(t))}_write(e,t,n,r){n>=this._levelNumber&&this._handler(e,t,this._mergeContext(r))}_mergeContext(e){return this._context?e?{...this._context,...e}:this._context:e??void 0}},F=e=>{let t=e.extras;if(!t||typeof t!=`object`)return{};let n=t.headers;return!n||typeof n!=`object`?{}:n},ie=e=>{let t={[v]:e.role,[h]:e.turnId,[g]:e.msgId};return e.turnClientId!==void 0&&(t[_]=e.turnClientId),e.parent&&(t[S]=e.parent),e.forkOf&&(t[C]=e.forkOf),e.amend&&(t[y]=e.amend),t},ae=class{constructor(e,t){this._turns=new Map,this._isTerminal=e,this._logger=t}createStream(e){this._logger.trace(`StreamRouter.createStream();`,{turnId:e});let t={},r=new ReadableStream({start(e){t.controller=e}});if(!t.controller)throw new n.ErrorInfo(`unable to create stream; ReadableStream start() was not called synchronously`,E.TransportSubscriptionError,500);return this._turns.set(e,{controller:t.controller,turnId:e}),r}closeStream(e){let t=this._turns.get(e);if(!t)return!1;this._logger.debug(`StreamRouter.closeStream(); closing stream`,{turnId:e});try{t.controller.close()}catch{}return this._turns.delete(e),!0}errorStream(e,t){let n=this._turns.get(e);if(!n)return!1;this._logger.debug(`StreamRouter.errorStream(); erroring stream`,{turnId:e});try{n.controller.error(t)}catch{}return this._turns.delete(e),!0}route(e,t){let n=this._turns.get(e);if(!n)return!1;try{n.controller.enqueue(t)}catch{return this._turns.delete(e),!1}return this._isTerminal(t)&&this.closeStream(e),!0}has(e){return this._turns.has(e)}},oe=(e,t)=>new ae(e,t),se=class{get structuralVersion(){return this._structuralVersion}constructor(e){this._nodeIndex=new Map,this._sortedList=[],this._parentIndex=new Map,this._turnClientIds=new Map,this._seqCounter=0,this._structuralVersion=0,this._logger=e,this._emitter=new O(e)}_compareNodes(e,t){let n=e.node.serial,r=t.node.serial;return n===void 0&&r===void 0?e.insertSeq-t.insertSeq:n===void 0?1:r===void 0||n<r?-1:n>r?1:e.insertSeq-t.insertSeq}_insertSorted(e){if(e.node.serial===void 0){this._sortedList.push(e);return}let t=0,n=this._sortedList.length;for(;t<n;){let r=t+n>>>1,i=this._sortedList[r];if(!i)break;this._compareNodes(i,e)<=0?t=r+1:n=r}this._sortedList.splice(t,0,e)}_removeSorted(e){let t=this._sortedList.indexOf(e);t!==-1&&this._sortedList.splice(t,1)}_addToParentIndex(e,t){let n=this._parentIndex.get(e);n||(n=new Set,this._parentIndex.set(e,n)),n.add(t)}_removeFromParentIndex(e,t){let n=this._parentIndex.get(e);n&&(n.delete(t),n.size===0&&this._parentIndex.delete(e))}_getSiblingGroup(e){let t=this._nodeIndex.get(e);if(!t)return[];let n=t.node,r=new Set([n.msgId]);for(;n.forkOf&&!r.has(n.forkOf);){let e=this._nodeIndex.get(n.forkOf);if(!e||e.node.parentId!==n.parentId)break;n=e.node,r.add(n.msgId)}let i=n.parentId,a=n.msgId,o=[],s=this._parentIndex.get(i);if(s)for(let e of s){let t=this._nodeIndex.get(e);t&&this._isSiblingOf(t.node,a)&&o.push(t)}return o.sort((e,t)=>this._compareNodes(e,t)),o.map(e=>e.node)}_isSiblingOf(e,t){if(e.msgId===t)return!0;let n=e,r=new Set([n.msgId]);for(;n.forkOf;){if(n.forkOf===t)return!0;if(r.has(n.forkOf))break;let e=this._nodeIndex.get(n.forkOf);if(!e)break;n=e.node,r.add(n.msgId)}return!1}getGroupRoot(e){let t=this._nodeIndex.get(e);if(!t)return e;let n=t.node,r=new Set([n.msgId]);for(;n.forkOf&&!r.has(n.forkOf);){let e=this._nodeIndex.get(n.forkOf);if(!e||e.node.parentId!==n.parentId)break;n=e.node,r.add(n.msgId)}return n.msgId}flattenNodes(e){this._logger.trace(`DefaultTree.flattenNodes();`);let t=[],n=new Set,r=new Map;for(let i of this._sortedList){let a=i.node,{msgId:o,parentId:s}=a;if(s!==void 0&&!n.has(s))continue;let c=this._getSiblingGroup(o);if(c.length>1){let t=this.getGroupRoot(o),n=r.get(t);if(n===void 0){let i=e.get(t);if(i&&c.some(e=>e.msgId===i))n=i;else{let e=c.at(-1);if(!e)break;n=e.msgId}r.set(t,n)}if(o!==n)continue}n.add(o),t.push(a)}return t}getSiblings(e){return this._logger.trace(`DefaultTree.getSiblings();`,{msgId:e}),this._getSiblingGroup(e).map(e=>e.message)}getSiblingNodes(e){return this._getSiblingGroup(e)}hasSiblings(e){return this._getSiblingGroup(e).length>1}getNode(e){return this._logger.trace(`DefaultTree.getNode();`,{msgId:e}),this._nodeIndex.get(e)?.node}getHeaders(e){return this._logger.trace(`DefaultTree.getHeaders();`,{msgId:e}),this._nodeIndex.get(e)?.node.headers}upsert(e,t,n,r){let i=n[`x-ably-parent`]??void 0,a=n[`x-ably-fork-of`]??void 0,o=this._nodeIndex.get(e);if(o){o.node.message=t,Object.keys(n).length>0&&(o.node.headers={...n}),r&&!o.node.serial&&(this._logger.debug(`Tree.upsert(); promoting serial`,{msgId:e,serial:r}),o.node.serial=r,this._removeSorted(o),this._insertSorted(o),this._structuralVersion++),this._emitter.emit(`update`);return}this._logger.trace(`Tree.upsert(); inserting new node`,{msgId:e,parentId:i,forkOf:a});let s={node:{kind:`message`,message:t,msgId:e,parentId:i,forkOf:a,headers:{...n},serial:r},insertSeq:this._seqCounter++};this._nodeIndex.set(e,s),this._addToParentIndex(i,e),this._insertSorted(s),this._structuralVersion++,this._emitter.emit(`update`)}delete(e){let t=this._nodeIndex.get(e);if(!t)return;this._logger.debug(`Tree.delete();`,{msgId:e});let{node:n}=t;this._removeFromParentIndex(n.parentId,e),this._removeSorted(t),this._nodeIndex.delete(e),this._structuralVersion++,this._emitter.emit(`update`)}getActiveTurnIds(){this._logger.trace(`DefaultTree.getActiveTurnIds();`);let e=new Map;for(let[t,n]of this._turnClientIds){let r=e.get(n);r||(r=new Set,e.set(n,r)),r.add(t)}return e}on(e,t){let n=t;return this._emitter.on(e,n),()=>{this._emitter.off(e,n)}}emitAblyMessage(e){this._logger.trace(`DefaultTree.emitAblyMessage();`),this._emitter.emit(`ably-message`,e)}emitTurn(e){this._logger.trace(`DefaultTree.emitTurn();`,{turnId:e.turnId}),this._emitter.emit(`turn`,e)}trackTurn(e,t){this._logger.trace(`DefaultTree.trackTurn();`,{turnId:e,clientId:t}),this._turnClientIds.set(e,t)}untrackTurn(e){this._logger.trace(`DefaultTree.untrackTurn();`,{turnId:e}),this._turnClientIds.delete(e)}},ce=e=>new se(e),I=e=>{let t=[...e.rawMessages].toReversed(),n=e.codec.createDecoder(),r=new Map,i=e.codec.createAccumulator(),a=0,o=new Map,s=new Map,c=[],l=[];for(let u of t){let t=n.decode(u),d=F(u),f=d[h],p=d[g],m=u.serial,_=d[y];if(_){for(let e of r.values())if(e.msgHeaders.has(_)){let n=[...e.msgHeaders.keys()].indexOf(_),r=n===-1?void 0:e.accumulator.messages[n];r&&e.accumulator.initMessage(_,r),e.accumulator.processOutputs(t),l.push({accumulator:e.accumulator,messageId:_});break}continue}if(f){let n=r.get(f);if(n||(n={accumulator:e.codec.createAccumulator(),firstSeen:a++,msgHeaders:new Map,msgSerials:new Map},r.set(f,n)),p){let e=n.msgHeaders.get(p);e?Object.keys(d).length>0&&Object.assign(e,d):(n.msgHeaders.set(p,{...d}),m&&n.msgSerials.set(p,m))}n.accumulator.processOutputs(t)}else{i.processOutputs(t);for(let e of t)if(e.kind===`message`&&p){c.push(p);let e=o.get(p);e?Object.keys(d).length>0&&Object.assign(e,d):(o.set(p,{...d}),m&&s.set(p,m))}}}for(let{accumulator:e,messageId:t}of l)e.completeMessage(t);let u=[];for(let[e,t]of i.completedMessages.entries()){let n=c[e];u.push({message:t,headers:n?o.get(n)??{}:{},serial:n?s.get(n)??``:``})}let d=[...r.values()].toSorted((e,t)=>e.firstSeen-t.firstSeen);for(let e of d){let t=[...e.msgHeaders.entries()],n=0;for(let r of e.accumulator.completedMessages){let i=t[n];if(i){let[t,a]=i;u.push({message:r,headers:a,serial:e.msgSerials.get(t)??``}),n++}else u.push({message:r,headers:{},serial:``})}}return u.toReversed()},L=e=>{if(e.cachedDecode&&e.cachedAtRawLength===e.rawMessages.length)return e.cachedDecode;let t=I(e);return e.cachedDecode=t,e.cachedAtRawLength=e.rawMessages.length,t},R=(e,t)=>{for(let n of t){let t=F(n),r=t[g];if(!r||t[`x-ably-amend`])continue;let i=n.action,a=i===`message.create`&&`x-ably-discrete`in t,o=t[`x-ably-stream`]===`true`&&(i===`message.create`||i===`message.update`||i===`message.append`),s=t[m],c=s===`finished`||s===`aborted`;(a||o)&&e.startedMsgIds.add(r),(a||c)&&e.terminatedMsgIds.add(r),e.startedMsgIds.has(r)&&e.terminatedMsgIds.has(r)&&e.completedMsgIds.add(r)}},z=async(e,t,n)=>{e.rawMessages.push(...t.items),e.lastAblyPage=t,R(e,t.items);let r=e.returnedCount+n;for(;e.completedMsgIds.size<r&&t.hasNext();){e.logger.debug(`decodeHistory.fetchUntilLimit(); fetching next page`,{collected:e.rawMessages.length,completed:e.completedMsgIds.size});let n=await t.next();if(!n)break;t=n,e.rawMessages.push(...n.items),e.lastAblyPage=n,R(e,n.items)}},B=(e,t)=>{let n=L(e),r=n.slice(e.returnedCount,e.returnedCount+t),i=[...r].toReversed();e.returnedCount+=r.length;let a=n.length>e.returnedCount,o=e.lastAblyPage?.hasNext()??!1,s=e.rawMessages.length-e.returnedRawCount>0?e.rawMessages.slice(e.returnedRawCount).toReversed():[];return e.returnedRawCount=e.rawMessages.length,{items:i.map(e=>({message:e.message,headers:e.headers,serial:e.serial})),rawMessages:s,hasNext:()=>a||o,next:async()=>{if(a)return B(e,t);if(!o||!e.lastAblyPage)return;let n=await e.lastAblyPage.next();if(n)return await z(e,n,t),B(e,t)}}},V=async(e,t,n,r)=>{let i=n?.limit??100,a={codec:t,rawMessages:[],returnedCount:0,returnedRawCount:0,lastAblyPage:void 0,cachedDecode:void 0,cachedAtRawLength:0,startedMsgIds:new Set,terminatedMsgIds:new Set,completedMsgIds:new Set,logger:r};r.trace(`decodeHistory();`,{limit:i});let o=i*10;return await e.attach(),await z(a,await e.history({untilAttach:!0,limit:o}),i),B(a,i)},H=class{constructor(e){this._branchSelections=new Map,this._withheldMsgIds=new Set,this._lastVisibleIds=[],this._lastVisibleMessages=[],this._lastVisibleTurnIds=new Set,this._hasMoreHistory=!1,this._withheldBuffer=[],this._unsubs=[],this._cachedNodes=[],this._lastStructuralVersion=-1,this._loadingOlder=!1,this._processingHistory=!1,this._closed=!1,this._tree=e.tree,this._channel=e.channel,this._codec=e.codec,this._sendDelegate=e.sendDelegate,this._onClose=e.onClose,this._logger=e.logger.withContext({component:`View`}),this._logger.trace(`DefaultView();`),this._emitter=new O(this._logger),this._cachedNodes=this._computeFlatNodes(),this._lastStructuralVersion=this._tree.structuralVersion,this._updateVisibleSnapshot(this._cachedNodes),this._unsubs.push(this._tree.on(`update`,()=>{this._onTreeUpdate()}),this._tree.on(`ably-message`,e=>{this._onTreeAblyMessage(e)}),this._tree.on(`turn`,e=>{this._onTreeTurn(e)}))}getMessages(){return this.flattenNodes().map(e=>e.message)}flattenNodes(){return this._cachedNodes}_computeFlatNodes(){let e=this._tree.flattenNodes(this._resolveSelections());return this._withheldMsgIds.size===0?e:e.filter(e=>!this._withheldMsgIds.has(e.msgId))}hasOlder(){return this._withheldBuffer.length>0||this._hasMoreHistory}async loadOlder(e=100){if(!(this._closed||this._loadingOlder)){this._loadingOlder=!0,this._logger.trace(`DefaultView.loadOlder();`,{limit:e});try{if(this._withheldBuffer.length>0){let t=this._withheldBuffer.splice(-e,e);this._releaseWithheld(t);return}if(!this._hasMoreHistory&&!this._lastHistoryPage){await this._loadFirstPage(e);return}if(!this._hasMoreHistory)return;if(!this._lastHistoryPage?.hasNext()){this._hasMoreHistory=!1;return}let t=await this._lastHistoryPage.next();if(this._closed||!t){t||(this._hasMoreHistory=!1);return}await this._loadAndReveal(t,e)}catch(e){throw this._logger.error(`DefaultView.loadOlder(); failed`,{error:e}),e}finally{this._loadingOlder=!1}}}select(e,t){this._logger.trace(`DefaultView.select();`,{msgId:e,index:t});let n=this._tree.getSiblingNodes(e);if(n.length<=1)return;let r=this._tree.getGroupRoot(e),i=Math.max(0,Math.min(t,n.length-1)),a=n[i];a&&(this._branchSelections.set(r,{kind:`user`,selectedId:a.msgId}),this._logger.debug(`DefaultView.select();`,{msgId:e,index:i,selectedId:a.msgId}),this._cachedNodes=this._computeFlatNodes(),this._updateVisibleSnapshot(this._cachedNodes),this._emitter.emit(`update`))}getSelectedIndex(e){this._logger.trace(`DefaultView.getSelectedIndex();`,{msgId:e});let t=this._tree.getSiblingNodes(e);if(t.length<=1)return 0;let n=this._tree.getGroupRoot(e),r=this._branchSelections.get(n);if(!r||r.kind===`pending`)return t.length-1;let i=t.findIndex(e=>e.msgId===r.selectedId);return i===-1?t.length-1:i}getSiblings(e){return this._tree.getSiblings(e)}hasSiblings(e){return this._tree.hasSiblings(e)}getNode(e){return this._tree.getNode(e)}async send(e,t){if(this._logger.trace(`DefaultView.send();`),this._closed)throw new n.ErrorInfo(`unable to send; view is closed`,E.InvalidArgument,400);let r=this.flattenNodes(),i=await this._sendDelegate(e,t,r);if(t?.forkOf){let e=this._tree.getGroupRoot(t.forkOf);if(i.optimisticMsgIds.length>0){let t=i.optimisticMsgIds.at(-1);t&&(this._branchSelections.set(e,{kind:`auto`,selectedId:t}),this._cachedNodes=this._computeFlatNodes(),this._updateVisibleSnapshot(this._cachedNodes),this._emitter.emit(`update`))}else{this._branchSelections.set(e,{kind:`pending`,turnId:i.turnId}),this._logger.debug(`DefaultView.send(); deferring fork auto-selection`,{forkOf:t.forkOf,groupRoot:e,turnId:i.turnId});let n=this._tree.on(`turn`,t=>{if(t.type!==`x-ably-turn-end`||t.turnId!==i.turnId)return;let r=this._branchSelections.get(e);r?.kind===`pending`&&r.turnId===i.turnId&&this._branchSelections.delete(e),n();let a=this._unsubs.indexOf(n);a!==-1&&this._unsubs.splice(a,1)});this._unsubs.push(n)}}return i}async regenerate(e,t){this._logger.trace(`DefaultView.regenerate();`,{messageId:e});let r=this._tree.getNode(e);if(!r)throw new n.ErrorInfo(`unable to regenerate; message not found in tree: ${e}`,E.InvalidArgument,400);let i=r.parentId;return this.send([],{...t,body:{history:this._getHistoryBefore(e),...t?.body},forkOf:e,parent:i})}async edit(e,t,r){this._logger.trace(`DefaultView.edit();`,{messageId:e});let i=this._tree.getNode(e);if(!i)throw new n.ErrorInfo(`unable to edit; message not found in tree: ${e}`,E.InvalidArgument,400);let a=i.parentId;return this.send(t,{...r,body:{history:this._getHistoryBefore(e),...r?.body},forkOf:e,parent:a})}async update(e,t,r){if(this._closed)throw new n.ErrorInfo(`unable to update; view is closed`,E.InvalidArgument,400);this._logger.trace(`DefaultView.update();`,{msgId:e,eventCount:t.length});let i=[{kind:`event`,msgId:e,events:t}];return this._sendDelegate([],r,this.flattenNodes(),i)}_getHistoryBefore(e){this._logger.trace(`DefaultView._getHistoryBefore();`,{messageId:e});let t=this.flattenNodes(),n=t.findIndex(t=>t.msgId===e);return n===-1?(this._logger.warn(`DefaultView._getHistoryBefore(); target not in visible nodes, returning full list`,{messageId:e}),t):t.slice(0,n)}getActiveTurnIds(){this._logger.trace(`DefaultView.getActiveTurnIds();`);let e=this._tree.getActiveTurnIds();if(this._withheldMsgIds.size===0)return e;let t=new Map;for(let[n,r]of e){let e=new Set;for(let t of r)this._lastVisibleTurnIds.has(t)&&e.add(t);e.size>0&&t.set(n,e)}return t}on(e,t){let n=t;return this._emitter.on(e,n),()=>{this._emitter.off(e,n)}}close(){this._logger.info(`DefaultView.close();`),this._closed=!0,this._loadingOlder=!1;for(let e of this._unsubs)e();this._unsubs.length=0,this._emitter.off(),this._branchSelections.clear(),this._withheldMsgIds.clear(),this._withheldBuffer.length=0,this._onClose?.()}async _loadFirstPage(e){let t=new Set(this._tree.flattenNodes(this._resolveSelections()).map(e=>e.msgId)),n=await V(this._channel,this._codec,{limit:e},this._logger);if(this._closed)return;let{newVisible:r,lastPage:i}=await this._loadUntilVisible(n,e,t);if(this._closed)return;this._lastHistoryPage=i,this._hasMoreHistory=i.hasNext();let a=r.slice(-e),o=r.slice(0,-e);for(let e of o)this._withheldMsgIds.add(e.msgId);this._withheldBuffer.push(...o),this._releaseWithheld(a)}async _loadAndReveal(e,t){let n=new Set(this._tree.flattenNodes(this._resolveSelections()).map(e=>e.msgId)),{newVisible:r,lastPage:i}=await this._loadUntilVisible(e,t,n);if(this._closed)return;this._lastHistoryPage=i,this._hasMoreHistory=i.hasNext();let a=r.slice(-t),o=r.slice(0,-t);for(let e of o)this._withheldMsgIds.add(e.msgId);this._withheldBuffer.push(...o),this._releaseWithheld(a)}_processHistoryPage(e){this._processingHistory=!0;try{for(let t of e.items){let e=t.headers[g];e&&this._tree.upsert(e,t.message,t.headers,t.serial)}for(let t of e.rawMessages)this._tree.emitAblyMessage(t)}finally{this._processingHistory=!1}}async _loadUntilVisible(e,t,n){this._processHistoryPage(e);let r=e,i=()=>{let e=0;for(let t of this._tree.flattenNodes(this._resolveSelections()))n.has(t.msgId)||e++;return e};for(;i()<t&&r.hasNext();){let e=await r.next();if(!e||this._closed)break;this._processHistoryPage(e),r=e}return{newVisible:this._tree.flattenNodes(this._resolveSelections()).filter(e=>!n.has(e.msgId)),lastPage:r}}_releaseWithheld(e){for(let t of e)this._withheldMsgIds.delete(t.msgId);e.length>0&&(this._cachedNodes=this._computeFlatNodes(),this._updateVisibleSnapshot(this._cachedNodes),this._emitter.emit(`update`))}_updateVisibleSnapshot(e){let t=e??this.flattenNodes();this._lastVisibleIds=t.map(e=>e.msgId),this._lastVisibleMessages=t.map(e=>e.message),this._lastVisibleTurnIds=new Set;for(let e of t){let t=e.headers[h];t&&this._lastVisibleTurnIds.add(t)}}_onTreeUpdate(){if(this._processingHistory)return;let e=this._tree.structuralVersion;if(e===this._lastStructuralVersion){this._cachedNodes.some((e,t)=>e.message!==this._lastVisibleMessages[t])&&(this._lastVisibleMessages=this._cachedNodes.map(e=>e.message),this._cachedNodes=[...this._cachedNodes],this._emitter.emit(`update`));return}this._lastStructuralVersion=e,this._pinBranchSelections(),this._resolvePendingSelections();let t=this._computeFlatNodes(),n=t.map(e=>e.msgId),r=t.map(e=>e.message);this._visibleChanged(n,r)&&(this._cachedNodes=t,this._updateVisibleSnapshot(t),this._emitter.emit(`update`))}_resolveSelections(){let e=new Map;for(let[t,n]of this._branchSelections)n.kind!==`pending`&&e.set(t,n.selectedId);return e}_pinBranchSelections(){for(let e of this._lastVisibleIds){if(!this._tree.hasSiblings(e))continue;let t=this._tree.getGroupRoot(e),n=this._branchSelections.get(t);if(n?.kind===`pending`){let r=this._tree.getSiblingNodes(e).at(-1);r&&r.msgId!==e&&r.headers[`x-ably-turn-id`]===n.turnId&&(this._logger.debug(`DefaultView._pinBranchSelections(); auto-selecting pending fork`,{msgId:e,newestId:r.msgId,turnId:n.turnId}),this._branchSelections.set(t,{kind:`auto`,selectedId:r.msgId}));continue}n||this._branchSelections.set(t,{kind:`pinned`,selectedId:e})}}_resolvePendingSelections(){for(let[e,t]of this._branchSelections){if(t.kind!==`pending`)continue;let n=this._tree.getSiblingNodes(e);if(n.length<=1)continue;let r=n.at(-1);!r||r.msgId===e||r.headers[`x-ably-turn-id`]===t.turnId&&(this._logger.debug(`DefaultView._resolvePendingSelections(); resolving off-branch pending`,{groupRoot:e,newestId:r.msgId,turnId:t.turnId}),this._branchSelections.set(e,{kind:`auto`,selectedId:r.msgId}))}}_onTreeAblyMessage(e){let t=F(e)[g];if(!t){this._emitter.emit(`ably-message`,e);return}this._lastVisibleIds.includes(t)&&this._emitter.emit(`ably-message`,e)}_onTreeTurn(e){if(this._lastVisibleTurnIds.has(e.turnId)){this._emitter.emit(`turn`,e);return}e.type===`x-ably-turn-start`&&this._isTurnStartVisible(e)&&(this._lastVisibleTurnIds.add(e.turnId),this._emitter.emit(`turn`,e))}_isTurnStartVisible(e){let{parent:t}=e;return t===void 0?!0:this._lastVisibleIds.includes(t)}_visibleChanged(e,t){if(e.length!==this._lastVisibleIds.length)return!0;for(let[t,n]of e.entries())if(n!==this._lastVisibleIds[t])return!0;for(let[e,n]of t.entries())if(n!==this._lastVisibleMessages[e])return!0;return!1}},U=e=>new H(e),W=()=>{},G=function(e){return e.READY=`ready`,e.CLOSED=`closed`,e}(G||{}),le=class{constructor(e){if(this._ownMsgIds=new Set,this._ownTurnIds=new Set,this._turnMsgIds=new Map,this._turnObservers=new Map,this._closeResolvers=[],this._views=new Set,this._state=G.READY,this._pendingLocalEvents=[],this._channel=e.channel,this._codec=e.codec,this._clientId=e.clientId,this._api=e.api,this._credentials=e.credentials,this._headersFn=typeof e.headers==`function`?e.headers:e.headers?()=>e.headers:void 0,this._bodyFn=typeof e.body==`function`?e.body:e.body?()=>e.body:void 0,this._fetchFn=e.fetch??globalThis.fetch.bind(globalThis),this._logger=(e.logger??j({logLevel:k.Silent})).withContext({component:`ClientTransport`}),this._emitter=new O(this._logger),this._hasAttachedOnce=this._channel.state===`attached`,this._tree=ce(this._logger),this._view=U({tree:this._tree,channel:this._channel,codec:this._codec,sendDelegate:this._internalSend.bind(this),logger:this._logger,onClose:()=>this._views.delete(this._view)}),this._router=oe(this._codec.isTerminal.bind(this._codec),this._logger),this._decoder=this._codec.createDecoder(),this._views.add(this._view),this.tree=this._tree,this.view=this._view,e.messages){let t;for(let n of e.messages){let e=crypto.randomUUID(),r={[g]:e};t&&(r[S]=t),this._tree.upsert(e,n,r),t=e}}this._onMessage=e=>{this._handleMessage(e)},this._attachPromise=this._channel.subscribe(this._onMessage),this._onChannelStateChange=e=>{this._handleChannelStateChange(e)},this._channel.on(this._onChannelStateChange)}_handleMessage(e){if(this._state!==G.CLOSED)try{if(e.name===`x-ably-turn-start`){let t=F(e),n=t[h],r=t[`x-ably-turn-client-id`]??``;if(n){this._tree.trackTurn(n,r);let e=t[S],i=t[C];this._tree.emitTurn({type:T,turnId:n,clientId:r,...e!==void 0&&{parent:e},...i!==void 0&&{forkOf:i}})}this._tree.emitAblyMessage(e);return}if(e.name===`x-ably-turn-end`){let t=F(e),n=t[h],r=t[`x-ably-turn-client-id`]??``,i=t[`x-ably-turn-reason`]??`complete`;if(n){this._router.closeStream(n),this._turnObservers.delete(n),this._tree.untrackTurn(n);let e=this._turnMsgIds.get(n);if(e){for(let t of e)this._ownMsgIds.delete(t);this._turnMsgIds.delete(n)}this._ownTurnIds.delete(n),this._tree.emitTurn({type:ne,turnId:n,clientId:r,reason:i})}this._tree.emitAblyMessage(e);return}let t=this._decoder.decode(e),n=F(e),r=e.serial,i=n[y];if(i){for(let e of t)e.kind===`event`&&this._handleAmendmentEvent(i,e);return}let a=n[h];a&&this._updateTurnObserverHeaders(a,n,r);for(let i of t)i.kind===`message`?this._handleMessageOutput(i.message,n,r,e.action):this._handleEventOutput(i,n);this._tree.emitAblyMessage(e)}catch(e){let t=e instanceof n.ErrorInfo?e:void 0;this._emitter.emit(`error`,new n.ErrorInfo(`unable to process channel message; ${e instanceof Error?e.message:String(e)}`,E.TransportSubscriptionError,500,t))}}_handleMessageOutput(e,t,n,r){let i=t[g];if(i&&this._ownMsgIds.has(i)){this._upsertAndNotify(e,t,n);return}r===`message.create`&&this._upsertAndNotify(e,t,n)}_handleEventOutput(e,t){if(e.kind!==`event`)return;let n=e.event,r=t[h];if(r){if(this._router.route(r,n)){this._accumulateAndEmit(r,e),this._codec.isTerminal(n)&&this._turnObservers.delete(r);return}this._ownTurnIds.has(r)&&!this._turnObservers.has(r)||(this._accumulateAndEmit(r,e),this._codec.isTerminal(n)&&this._turnObservers.delete(r))}}_handleAmendmentEvent(e,t){this._logger.trace(`ClientTransport._handleAmendmentEvent();`,{targetMsgId:e});let n=this._tree.getNode(e);if(!n){this._logger.debug(`ClientTransport._handleAmendmentEvent(); target not found, dropping`,{targetMsgId:e});return}let r=this._codec.createAccumulator();r.initMessage(e,n.message),r.processOutputs([t]);let i=r.messages.at(-1);i&&this._tree.upsert(e,i,n.headers,n.serial)}_handleChannelStateChange(e){if(this._state===G.CLOSED)return;let{current:t,resumed:r}=e;if(t===`attached`&&!this._hasAttachedOnce){this._hasAttachedOnce=!0;return}if(!(t===`failed`||t===`suspended`||t===`detached`||t===`attached`&&!r))return;this._logger.error(`ClientTransport._handleChannelStateChange(); channel continuity lost`,{current:t,resumed:r,previous:e.previous});let i=new n.ErrorInfo(`unable to deliver events; channel continuity lost (${t}${t===`attached`?`, resumed: false`:``})`,E.ChannelContinuityLost,500,e.reason);for(let e of this._ownTurnIds)this._router.errorStream(e,i);this._emitter.emit(`error`,i)}_upsertAndNotify(e,t,n){let r=t[g];r&&this._tree.upsert(r,e,t,n)}_updateTurnObserverHeaders(e,t,n){let r=this._turnObservers.get(e);r?(Object.keys(t).length>0&&Object.assign(r.headers,t),n!==void 0&&(r.serial=n)):this._turnObservers.set(e,{headers:{...t},serial:n,accumulator:this._codec.createAccumulator()})}_accumulateAndEmit(e,t){let n=this._turnObservers.get(e);if(!n)return;let r=n.headers[g];if(r){let e=this._tree.getNode(r);e&&n.accumulator.initMessage(r,e.message)}n.accumulator.processOutputs([t]);let i=n.accumulator.messages;if(i.length===0)return;let a;try{a=structuredClone(i.at(-1))}catch{a=i.at(-1)}if(a){let e=n.headers[g];e&&this._tree.upsert(e,a,{...n.headers},n.serial)}}async _publishCancel(e){this._logger.trace(`ClientTransport._publishCancel();`,{filter:e});let t={};e.turnId?t[b]=e.turnId:e.own?t[x]=`true`:e.clientId?t[te]=e.clientId:e.all&&(t[ee]=`true`),await this._channel.publish({name:w,extras:{headers:t}})}_closeMatchingTurnStreams(e){for(let t of this._getMatchingTurnIds(e))this._router.closeStream(t)}_getMatchingTurnIds(e){let t=new Set,n=this._tree.getActiveTurnIds();if(e.all)for(let e of n.values())for(let n of e)t.add(n);else if(e.own){let e=n.get(this._clientId??``);if(e)for(let n of e)t.add(n)}else if(e.clientId){let r=n.get(e.clientId);if(r)for(let e of r)t.add(e)}else if(e.turnId){for(let r of n.values())if(r.has(e.turnId)){t.add(e.turnId);break}}return t}createView(){if(this._state===G.CLOSED)throw new n.ErrorInfo(`unable to create view; transport is closed`,E.TransportClosed,400);this._logger.trace(`DefaultClientTransport.createView();`);let e=U({tree:this._tree,channel:this._channel,codec:this._codec,sendDelegate:this._internalSend.bind(this),logger:this._logger,onClose:()=>this._views.delete(e)});return this._views.add(e),e}async _internalSend(e,t,r,i){if(this._state===G.CLOSED||(await this._attachPromise,this._state===G.CLOSED))throw new n.ErrorInfo(`unable to send; transport is closed`,E.TransportClosed,400);let a=this._channel.state;if(a!==`attached`&&a!==`attaching`)throw new n.ErrorInfo(`unable to send; channel is ${a}`,E.ChannelNotReady,400);this._logger.trace(`ClientTransport._internalSend();`);let o=Array.isArray(e)?e:[e],s=crypto.randomUUID();this._ownTurnIds.add(s),this._tree.trackTurn(s,this._clientId??``);let c=this._pendingLocalEvents;this._pendingLocalEvents=[],i&&i.length>0&&this._applyEventsToTree(i);let l=[...c,...i??[]],u=new Set,d=[],f=r,p;if(t?.parent===void 0&&!t?.forkOf){let e=f.at(-1);e&&(p=e.msgId)}let m=t?.parent===void 0?p:t.parent;for(let e of o){let n=crypto.randomUUID();this._ownMsgIds.add(n),u.add(n);let r=t?.parent===void 0?p:t.parent,i=ie({role:`user`,turnId:s,msgId:n,turnClientId:this._clientId,parent:r,forkOf:t?.forkOf});this._upsertAndNotify(e,i),d.push({kind:`message`,message:e,msgId:n,parentId:r,forkOf:t?.forkOf,headers:i,serial:void 0}),t?.parent===void 0&&!t?.forkOf&&(p=n)}this._turnMsgIds.set(s,u);let h=this._router.createStream(s),g=this._headersFn?.()??{},_={...this._bodyFn?.()??{},history:f,...t?.body,turnId:s,clientId:this._clientId,messages:d,...t?.forkOf!==void 0&&{forkOf:t.forkOf},...m!==void 0&&{parent:m},...l.length>0&&{events:l}},v={...g,...t?.headers};return this._fetchFn(this._api,{method:`POST`,headers:{"Content-Type":`application/json`,...v},body:JSON.stringify(_),...this._credentials?{credentials:this._credentials}:{}}).then(e=>{if(!e.ok){let t=new n.ErrorInfo(`unable to send; HTTP POST to ${this._api} returned ${String(e.status)} ${e.statusText}`,E.TransportSendFailed,e.status);this._emitter.emit(`error`,t),this._router.errorStream(s,t)}}).catch(e=>{let t=e instanceof n.ErrorInfo?e:void 0,r=new n.ErrorInfo(`unable to send; HTTP POST to ${this._api} failed: ${e instanceof Error?e.message:String(e)}`,E.TransportSendFailed,500,t);this._emitter.emit(`error`,r),this._router.errorStream(s,r)}),{stream:h,turnId:s,cancel:async()=>this.cancel({turnId:s}),optimisticMsgIds:[...u]}}async cancel(e){if(this._state===G.CLOSED)return;let t=e??{own:!0};this._logger.debug(`ClientTransport.cancel();`,{filter:t}),await this._publishCancel(t),this._closeMatchingTurnStreams(t)}stageEvents(e,t){if(this._logger.trace(`ClientTransport.stageEvents();`,{msgId:e,eventCount:t.length}),this._state===G.CLOSED){this._logger.warn(`ClientTransport.stageEvents(); transport is closed`,{msgId:e});return}if(!this._tree.getNode(e)){this._logger.warn(`ClientTransport.stageEvents(); msgId not found in tree`,{msgId:e});return}if(t.length===0)return;let n={kind:`event`,msgId:e,events:t};this._applyEventsToTree([n]),this._pendingLocalEvents.push(n)}stageMessage(e,t){if(this._logger.trace(`ClientTransport.stageMessage();`,{msgId:e}),this._state===G.CLOSED){this._logger.warn(`ClientTransport.stageMessage(); transport is closed`,{msgId:e});return}let n=this._tree.getNode(e);if(!n){this._logger.warn(`ClientTransport.stageMessage(); msgId not found in tree`,{msgId:e});return}this._tree.upsert(e,t,n.headers,n.serial)}_applyEventsToTree(e){for(let t of e){let e=this._tree.getNode(t.msgId);if(!e)continue;let n=t.events.map(e=>({kind:`event`,event:e,messageId:t.msgId})),r=this._codec.createAccumulator();r.initMessage(t.msgId,e.message),r.processOutputs(n);let i=r.messages.at(-1);i&&this._tree.upsert(t.msgId,i,e.headers,e.serial)}}async waitForTurn(e){if(this._state===G.CLOSED)return;let t=e??{own:!0},n=this._getMatchingTurnIds(t);if(n.size!==0)return this._logger.debug(`ClientTransport.waitForTurn();`,{turnIds:[...n]}),new Promise(e=>{let t=!1,r=()=>{if(t)return;t=!0,i();let n=this._closeResolvers.indexOf(r);n!==-1&&this._closeResolvers.splice(n,1),e()},i=this._tree.on(`turn`,e=>{e.type===`x-ably-turn-end`&&(n.delete(e.turnId),n.size===0&&r())});this._closeResolvers.push(r)})}on(e,t){if(this._state===G.CLOSED)return W;let n=t;return this._emitter.on(e,n),()=>{this._emitter.off(e,n)}}async close(e){if(this._state!==G.CLOSED){if(this._state=G.CLOSED,this._logger.info(`ClientTransport.close();`),e?.cancel){try{await this._publishCancel(e.cancel)}catch{}this._closeMatchingTurnStreams(e.cancel)}this._channel.unsubscribe(this._onMessage),this._channel.off(this._onChannelStateChange);for(let e of this._ownTurnIds)this._router.closeStream(e);this._turnObservers.clear(),this._emitter.off();for(let e of this._views)e.close();this._views.clear();for(let e of this._closeResolvers)e();this._closeResolvers.length=0,this._ownTurnIds.clear(),this._ownMsgIds.clear(),this._turnMsgIds.clear()}}},ue=e=>new le(e),de=({channelName:e,children:a,...o})=>{let{channel:s}=(0,r.useChannel)({channelName:e}),c=(0,t.useRef)(void 0),l=(0,t.useRef)(e),u=(0,t.useRef)([]),d=(0,t.useRef)(!1),m=(0,t.useRef)(void 0);if(!(c.current||m.current)||l.current!==e){l.current=e,c.current&&u.current.push(c.current);try{c.current=ue({...o,channel:s}),m.current=void 0}catch(e){c.current=void 0,m.current=e instanceof n.ErrorInfo?e:new n.ErrorInfo(`Unknown error while creating transport`,E.BadRequest,400)}}let h=(0,t.useContext)(f),g=c.current,_=m.current,v=(0,t.useMemo)(()=>({transport:g,error:_}),[g,_]),y=(0,t.useMemo)(()=>({...h,[e]:v}),[e,h,v]);return(0,t.useEffect)(()=>()=>{for(let e of u.current)e.close()},[e]),(0,t.useEffect)(()=>(d.current=!1,()=>{d.current=!0,Promise.resolve().then(()=>{d.current&&c.current?.close()})}),[]),(0,i.jsx)(f.Provider,{value:y,children:(0,i.jsx)(p.Provider,{value:v,children:a})})},K=e=>(0,i.jsx)(r.ChannelProvider,{channelName:e.channelName,children:(0,i.jsx)(de,{...e})}),q=({transport:e,skip:n}={})=>{let r=(0,t.useContext)(p),i=n?void 0:e??r?.transport,[a,o]=(0,t.useState)([]),s=(0,t.useRef)([]);return(0,t.useEffect)(()=>{if(s.current=[],o([]),i)return i.tree.on(`ably-message`,e=>{let t=[...s.current,e];s.current=t,o(t)})},[i]),a},J=({transport:e}={})=>{let n=(0,t.useContext)(p),r=e??n?.transport,[i,a]=(0,t.useState)(()=>new Map);return(0,t.useEffect)(()=>{if(r)return a(r.tree.getActiveTurnIds()),r.tree.on(`turn`,e=>{a(t=>{let n=new Map(t);if(e.type===`x-ably-turn-start`){let t=new Set(n.get(e.clientId));t.add(e.turnId),n.set(e.clientId,t)}else{let t=n.get(e.clientId);if(t){let r=new Set(t);r.delete(e.turnId),r.size===0?n.delete(e.clientId):n.set(e.clientId,r)}}return n})})},[r]),i},Y={get tree(){throw new n.ErrorInfo(`unable to access tree; hook is skipped`,E.InvalidArgument,400)},get view(){throw new n.ErrorInfo(`unable to access view; hook is skipped`,E.InvalidArgument,400)},createView:()=>{throw new n.ErrorInfo(`unable to create view; hook is skipped`,E.InvalidArgument,400)},cancel:()=>{throw new n.ErrorInfo(`unable to cancel; hook is skipped`,E.InvalidArgument,400)},stageEvents:()=>{throw new n.ErrorInfo(`unable to stage events; hook is skipped`,E.InvalidArgument,400)},stageMessage:()=>{throw new n.ErrorInfo(`unable to stage message; hook is skipped`,E.InvalidArgument,400)},waitForTurn:()=>{throw new n.ErrorInfo(`unable to wait for turn; hook is skipped`,E.InvalidArgument,400)},on:()=>{throw new n.ErrorInfo(`unable to subscribe; hook is skipped`,E.InvalidArgument,400)},close:()=>{throw new n.ErrorInfo(`unable to close; hook is skipped`,E.InvalidArgument,400)}},X=({channelName:e,skip:r,onError:i}={})=>{let a=(0,t.useContext)(f),o=(0,t.useContext)(p),s=(0,t.useRef)(i);s.current=i;let c=r?void 0:e===void 0?o?.transport:a[e]?.transport;if((0,t.useEffect)(()=>{if(c)return c.on(`error`,e=>{s.current?.(e)})},[c]),r)return{transport:Y};if(e!==void 0){let t=a[e];return t?t.transport?{transport:t.transport}:{transport:Y,transportError:t.error}:{transport:Y,transportError:new n.ErrorInfo(`unable to use transport; no TransportProvider found for channelName "${e}"`,E.BadRequest,400)}}return o?o.transport?{transport:o.transport}:{transport:Y,transportError:o.error}:{transport:Y,transportError:new n.ErrorInfo(`unable to use transport; no TransportProvider found in the tree`,E.BadRequest,400)}},Z=({transport:e,view:r,limit:i,skip:a}={})=>{let o=(0,t.useContext)(p),s=a?void 0:e??o?.transport,c=a?void 0:r??s?.view,[l,u]=(0,t.useState)(()=>c?.flattenNodes()??[]),[d,f]=(0,t.useState)(()=>c?.hasOlder()??!1),[m,h]=(0,t.useState)(!1),[g,_]=(0,t.useState)(),v=(0,t.useRef)(!1),y=i!==void 0,b=(0,t.useRef)(!1);(0,t.useEffect)(()=>{if(!c){u([]),f(!1),_(void 0);return}return b.current=!1,u(c.flattenNodes()),f(c.hasOlder()),_(void 0),c.on(`update`,()=>{u(c.flattenNodes()),f(c.hasOlder())})},[c]);let x=(0,t.useCallback)(async()=>{if(!(!c||v.current)){v.current=!0,h(!0);try{await c.loadOlder(i),_(void 0)}catch(e){e instanceof n.ErrorInfo?_(e):_(new n.ErrorInfo(`Unknown error loading older messages`,E.BadRequest,400))}finally{v.current=!1,h(!1)}}},[c,i]);return(0,t.useEffect)(()=>{!y||b.current||!c||(b.current=!0,x())},[y,c,x]),{messages:(0,t.useMemo)(()=>l.map(e=>e.message),[l]),nodes:l,hasOlder:d,loading:m,loadError:g,loadOlder:x,select:(0,t.useCallback)((e,t)=>{c?.select(e,t)},[c]),getSelectedIndex:(0,t.useCallback)(e=>c?.getSelectedIndex(e)??0,[c]),getSiblings:(0,t.useCallback)(e=>c?.getSiblings(e)??[],[c]),hasSiblings:(0,t.useCallback)(e=>c?.hasSiblings(e)??!1,[c]),getNode:(0,t.useCallback)(e=>c?.getNode(e),[c]),send:(0,t.useCallback)(async(e,t)=>{if(!c)throw new n.ErrorInfo(`unable to send; view is not available`,E.InvalidArgument,400);return c.send(e,t)},[c]),regenerate:(0,t.useCallback)(async(e,t)=>{if(!c)throw new n.ErrorInfo(`unable to regenerate; view is not available`,E.InvalidArgument,400);return c.regenerate(e,t)},[c]),edit:(0,t.useCallback)(async(e,t,r)=>{if(!c)throw new n.ErrorInfo(`unable to edit; view is not available`,E.InvalidArgument,400);return c.edit(e,t,r)},[c]),update:(0,t.useCallback)(async(e,t,r)=>{if(!c)throw new n.ErrorInfo(`unable to update; view is not available`,E.InvalidArgument,400);return c.update(e,t,r)},[c])}},Q=({transport:e,limit:n,skip:r}={})=>{let i=(0,t.useContext)(p),a=r?void 0:e??i?.transport,[o,s]=(0,t.useState)();return(0,t.useEffect)(()=>{if(!a){s(void 0);return}let e=a.createView();return s(e),()=>{e.close()}},[a]),Z({view:o,limit:n,skip:r})},$=({transport:e}={})=>{let n=(0,t.useContext)(p),r=e??n?.transport;return{getSiblings:(0,t.useCallback)(e=>r?.tree.getSiblings(e)??[],[r]),hasSiblings:(0,t.useCallback)(e=>r?.tree.hasSiblings(e)??!1,[r]),getNode:(0,t.useCallback)(e=>r?.tree.getNode(e),[r])}};e.NearestTransportContext=p,e.TransportProvider=K,e.createTransportHooks=()=>({TransportProvider:K,useClientTransport:e=>X(e??{}),useView:e=>Z(e??{}),useActiveTurns:e=>J(e??{}),useTree:e=>$(e??{}),useAblyMessages:e=>q(e??{}),useCreateView:e=>Q(e??{})}),e.useAblyMessages=q,e.useActiveTurns=J,e.useClientTransport=X,e.useCreateView=Q,e.useTree=$,e.useView=Z});
1
+ (function(e,t){typeof exports==`object`&&typeof module<`u`?t(exports,require(`ably`),require(`ably/react`),require(`react`),require(`react/jsx-runtime`)):typeof define==`function`&&define.amd?define([`exports`,`ably`,`ably/react`,`react`,`react/jsx-runtime`],t):(e=typeof globalThis<`u`?globalThis:e||self,t(e.AblyAiTransportReact={},e.Ably,e.AblyReact,e.React,e.ReactJsxRuntime))})(this,function(e,t,n,r,i){Object.defineProperty(e,Symbol.toStringTag,{value:`Module`});var a=Object.create,o=Object.defineProperty,s=Object.getOwnPropertyDescriptor,c=Object.getOwnPropertyNames,l=Object.getPrototypeOf,u=Object.prototype.hasOwnProperty,d=(e,t,n,r)=>{if(t&&typeof t==`object`||typeof t==`function`)for(var i=c(t),a=0,l=i.length,d;a<l;a++)d=i[a],!u.call(e,d)&&d!==n&&o(e,d,{get:(e=>t[e]).bind(null,d),enumerable:!(r=s(t,d))||r.enumerable});return e};t=((e,t,n)=>(n=e==null?{}:a(l(e)),d(t||!e||!e.__esModule?o(n,`default`,{value:e,enumerable:!0}):n,e)))(t,1);var f=[`PUBLISH`,`SUBSCRIBE`,`PRESENCE`,`PRESENCE_SUBSCRIBE`,`ANNOTATION_PUBLISH`],p=[`OBJECT_SUBSCRIBE`,`OBJECT_PUBLISH`],m=[`PUBLISH`,`SUBSCRIBE`,`PRESENCE`,`PRESENCE_SUBSCRIBE`,`OBJECT_PUBLISH`,`OBJECT_SUBSCRIBE`,`ANNOTATION_PUBLISH`,`ANNOTATION_SUBSCRIBE`],h=e=>{if(e===void 0||e.length===0)return;let t=new Set([...f,...e]),n=m.filter(e=>t.has(e)),r=[...t].filter(e=>!m.includes(e)).toSorted();return[...n,...r]},g=`0.3.0`,_=`ai-transport-js`,v=(e,t)=>{let n=e;return n.options.agents={...n.options.agents,...t},{params:{agent:b(t)}}},y=e=>{let t=e?.adapterTag,n={[_]:g};return t&&(n[t]=g),n},b=e=>Object.entries(e).map(([e,t])=>`${e}/${t}`).join(` `),ee=e=>b(y(e)),te=(e,t)=>v(e,y(t)),x=`stream`,ne=`status`,S=`run-id`,re=`invocation-id`,C=`event-id`,w=`codec-message-id`,ie=`run-client-id`,ae=`input-client-id`,T=`role`,E=`parent`,D=`fork-of`,O=`msg-regenerate`,k=`input-codec-message-id`,oe=`error-code`,se=`ai-cancel`,A=function(e){return e[e.BadRequest=4e4]=`BadRequest`,e[e.InvalidArgument=40003]=`InvalidArgument`,e[e.InsufficientCapability=40160]=`InsufficientCapability`,e[e.EncoderRecoveryFailed=104e3]=`EncoderRecoveryFailed`,e[e.SessionSubscriptionError=104001]=`SessionSubscriptionError`,e[e.CancelListenerError=104002]=`CancelListenerError`,e[e.RunLifecycleError=104003]=`RunLifecycleError`,e[e.SessionClosed=104004]=`SessionClosed`,e[e.SessionSendFailed=104005]=`SessionSendFailed`,e[e.ChannelContinuityLost=104006]=`ChannelContinuityLost`,e[e.ChannelNotReady=104007]=`ChannelNotReady`,e[e.StreamError=104008]=`StreamError`,e[e.InputEventNotFound=104010]=`InputEventNotFound`,e[e.HistoryFetchFailed=104011]=`HistoryFetchFailed`,e}({}),ce=e=>({logAction:(t,n,r)=>{e.error(n,{detail:r})},shouldLog:()=>!0}),le=t.Realtime.EventEmitter,j=class extends le{constructor(e){super(ce(e))}},ue=function(e){return e.Trace=`trace`,e.Debug=`debug`,e.Info=`info`,e.Warn=`warn`,e.Error=`error`,e.Silent=`silent`,e}({}),de=(e,t,n)=>{let r=n?`, context: ${JSON.stringify(n)}`:``,i=`[${new Date().toISOString()}] ${t.valueOf().toUpperCase()} ably-ai-transport: ${e}${r}`;switch(t){case`trace`:case`debug`:console.log(i);break;case`info`:console.info(i);break;case`warn`:console.warn(i);break;case`error`:console.error(i);break;case`silent`:break}},fe=e=>new pe(e.logHandler??de,e.logLevel),M=new Map([[`trace`,0],[`debug`,1],[`info`,2],[`warn`,3],[`error`,4],[`silent`,5]]),pe=class e{constructor(e,n,r){this._handler=e,this._context=r;let i=M.get(n);if(i===void 0)throw new t.ErrorInfo(`unable to create logger; invalid log level: ${n}`,A.InvalidArgument,400);this._levelNumber=i}trace(e,t){this._write(e,`trace`,0,t)}debug(e,t){this._write(e,`debug`,1,t)}info(e,t){this._write(e,`info`,2,t)}warn(e,t){this._write(e,`warn`,3,t)}error(e,t){this._write(e,`error`,4,t)}withContext(t){let n=[...M.entries()].find(([,e])=>e===this._levelNumber)?.[0]??`error`;return new e(this._handler,n,this._mergeContext(t))}_write(e,t,n,r){n>=this._levelNumber&&this._handler(e,t,this._mergeContext(r))}_mergeContext(e){return this._context?e?{...this._context,...e}:this._context:e??void 0}},N=e=>e instanceof Error?e.message:String(e),P=e=>e instanceof t.ErrorInfo?e:void 0,me=(e,t)=>{let n=e.extras;if(!n||typeof n!=`object`)return{};let r=n.ai;if(!r||typeof r!=`object`)return{};let i=r[t];return!i||typeof i!=`object`?{}:i},F=e=>me(e,`transport`),he=e=>{let t={[T]:e.role,[w]:e.codecMessageId};return e.runId!==void 0&&(t[S]=e.runId),e.runClientId!==void 0&&(t[ie]=e.runClientId),e.parent&&(t[E]=e.parent),e.forkOf&&(t[D]=e.forkOf),e.regenerates&&(t[O]=e.regenerates),e.invocationId&&(t[re]=e.invocationId),e.inputClientId!==void 0&&(t[ae]=e.inputClientId),e.inputCodecMessageId!==void 0&&(t[k]=e.inputCodecMessageId),e.inputEventId&&(t[C]=e.inputEventId),t},ge=e=>e===`ai-run-start`||e===`ai-run-suspend`||e===`ai-run-resume`||e===`ai-run-end`,I=e=>{let n=e[oe],r=n===void 0?NaN:Number(n),i=Number.isFinite(r)?r:A.SessionSubscriptionError,a=e[`error-message`]??`agent reported an error`,o=i>=1e4&&i<6e4?Math.floor(i/100):500;return new t.ErrorInfo(a,i,o)},_e=(e,t,n,r)=>{let i=t[S];if(!i)return;let a=t[`run-client-id`]??``,o=r===void 0?{}:{timestamp:r};if(e===`ai-run-start`){let e=t[E],r=t[D],s=t[O];return{type:`start`,runId:i,clientId:a,serial:n,invocationId:t[`invocation-id`]??``,...o,...e!==void 0&&{parent:e},...r!==void 0&&{forkOf:r},...s!==void 0&&{regenerates:s}}}if(e===`ai-run-suspend`)return{type:`suspend`,runId:i,clientId:a,serial:n,invocationId:t[`invocation-id`]??``,...o};if(e===`ai-run-resume`)return{type:`resume`,runId:i,clientId:a,serial:n,invocationId:t[`invocation-id`]??``,...o};if(e===`ai-run-end`){let e=t[`run-reason`]??`complete`,r=t[`invocation-id`]??``;return e===`error`?{type:`end`,runId:i,clientId:a,serial:n,invocationId:r,reason:e,...o,error:I(t)}:{type:`end`,runId:i,clientId:a,serial:n,invocationId:r,reason:e,...o}}},ve=(e,t,n)=>{let r=F(n),i=n.serial,a=n.timestamp;if(ge(n.name)){let t=_e(n.name,r,i,a);return t&&e.applyRunLifecycle(t),t}let{inputs:o,outputs:s}=t.decode(n);(o.length>0||s.length>0||r[`run-id`])&&e.applyMessage({inputs:o,outputs:s},r,i,a,n.version.serial)},ye=(e,t)=>({apply:n=>ve(e,t,n)}),be=class e{constructor(e){this.inputEventId=e.inputEventId,this.sessionName=e.sessionName}static fromJSON(t){return new e(t)}toJSON(){return{inputEventId:this.inputEventId,sessionName:this.sessionName}}},xe=async(e,n)=>{if(!e)throw new t.ErrorInfo(`unable to ${n}; connect() must be called before ${n}()`,A.InvalidArgument,400);return e},Se=async(e,t,n,r)=>{if(t!==void 0)try{await e.detach()}catch(e){n?.debug(`${r}.close(); channel detach failed`,{error:e})}},Ce=e=>{let{current:t,resumed:n}=e;return t===`failed`||t===`suspended`||t===`detached`||t===`attached`&&!n},we=(e,n)=>{let{current:r}=e;return new t.ErrorInfo(`unable to ${n}; channel continuity lost (${r}${r===`attached`?`, resumed: false`:``})`,A.ChannelContinuityLost,500,e.reason)},L=e=>[...e.inputs.map(e=>({direction:`input`,event:e})),...e.outputs.map(e=>({direction:`output`,event:e}))],Te=class{constructor(){this._entries=[],this._swept=!1}get swept(){return this._swept}record(e,t,n,r,i){let a=this._recordEntry(e,t,this._swept?[]:n,r,i);return a===void 0?`dropped`:this._swept||a===this._entries.length-1?`incremental`:`refold`}replay(e){for(let t of this._entries)for(let n of t.events)e(n,t.serial,t.messageId)}sweep(){this._swept=!0;for(let e of this._entries)e.events.length=0}_recordEntry(e,t,n,r,i){for(let a=this._entries.length-1;a>=0;a--){let o=this._entries[a];if(!o)break;if(o.serial===e)return r!==void 0&&(r<=o.decodedThrough||!i)?void 0:(o.events.push(...n),r!==void 0&&(o.decodedThrough=r),a);if(o.serial<e)return this._entries.splice(a+1,0,{serial:e,messageId:t,events:[...n],decodedThrough:r??e}),a+1}return this._entries.unshift({serial:e,messageId:t,events:[...n],decodedThrough:r??e}),0}},R=e=>e.kind===`run`?e.runId:e.codecMessageId,z=e=>e.kind===`run`?e.startSerial:e.serial,B=(e,t,n)=>{let r=e.get(t);r||(r=new Set,e.set(t,r)),r.add(n)},V=(e,t,n)=>{let r=e.get(t);r&&(r.delete(n),r.size===0&&e.delete(t))},Ee=class{constructor(e,t){this._nodeIndex=new Map,this._codecMessageIdToNodeKey=new Map,this._sortedNodes=[],this._parentIndex=new Map,this._replyRunsByInput=new Map,this._seqCounter=0,this._structuralVersion=0,this._siblingCache=new Map,this._siblingCacheVersion=-1,this._eventIdIndex=new Map,this._clock=0,this._sweepQueue=[],this._codec=e,this._logger=t,this._emitter=new j(t)}_compareNodes(e,t){let n=z(e.node),r=z(t.node);return n===void 0&&r===void 0?e.insertSeq-t.insertSeq:n===void 0?1:r===void 0||n<r?-1:n>r?1:e.insertSeq-t.insertSeq}_insertSortedNode(e){if(z(e.node)===void 0){this._sortedNodes.push(e);return}let t=0,n=this._sortedNodes.length;for(;t<n;){let r=t+n>>>1,i=this._sortedNodes[r];if(!i)break;this._compareNodes(i,e)<=0?t=r+1:n=r}this._sortedNodes.splice(t,0,e)}_removeSortedNode(e){let t=this._sortedNodes.indexOf(e);t!==-1&&this._sortedNodes.splice(t,1)}_insertNode(e,t,n){this._nodeIndex.set(e,t),this._addToParentIndex(n,e),this._insertSortedNode(t),this._structuralVersion++}_promoteSerial(e){this._removeSortedNode(e),this._insertSortedNode(e),this._structuralVersion++}_foldInto(e,t,n,r){for(let i of t)try{e.node.projection=this._codec.fold(e.node.projection,i,{serial:n??``,messageId:r})}catch(t){this._logger.error(`Tree._foldInto(); fold threw`,{key:R(e.node),messageId:r,err:t})}}_recordAndFold(e,t,n,r,i,a){if(n===void 0||t.length===0){n===void 0&&t.length>0&&(e.optimistic=!0),this._foldInto(e,t,n,r);return}let o=e.log.record(n,r,t,i,a);if(o===`dropped`){this._logger.debug(`Tree._recordAndFold(); version guard dropped re-delivered wire`,{key:R(e.node),serial:n,version:i,swept:e.log.swept});return}if(e.optimistic&&!e.log.swept){e.optimistic=!1,this._refold(e);return}if(o===`refold`){this._refold(e);return}e.log.swept&&this._logger.warn(`Tree._recordAndFold(); late wire after log retention window; folding in arrival order`,{key:R(e.node),serial:n}),this._foldInto(e,t,n,r)}_refold(e){let t=this._codec.init();e.log.replay((n,r,i)=>{try{t=this._codec.fold(t,n,{serial:r,messageId:i})}catch(t){this._logger.error(`Tree._refold(); fold threw`,{key:R(e.node),messageId:i,err:t})}}),e.node.projection=t}_recordActivity(e,t){t!==void 0&&(t>e.lastActivityTs&&(e.lastActivityTs=t),t>this._clock&&(this._clock=t,this._drainSweepQueue()))}_maybeQueueSweep(e){let t=e.node;t.kind===`run`&&(e.log.swept||e.sweepQueued||e.runStartSeen&&(t.state.status===`active`||t.state.status===`suspended`||(e.sweepQueued=!0,this._sweepQueue.push(t.runId))))}_drainSweepQueue(){for(;this._sweepQueue.length>0;){let e=this._sweepQueue[0],t=e===void 0?void 0:this._nodeIndex.get(e);if(!t||t.log.swept){this._sweepQueue.shift();continue}if(t.lastActivityTs+12e4>=this._clock)return;this._sweepQueue.shift(),t.sweepQueued=!1,t.log.sweep(),this._logger.debug(`Tree._drainSweepQueue(); dropped event-log payloads, kept replay keys`,{key:e,lastActivityTs:t.lastActivityTs})}}_addToParentIndex(e,t){B(this._parentIndex,e,t)}_removeFromParentIndex(e,t){V(this._parentIndex,e,t)}_parentKeyOf(e){let t=e.parentCodecMessageId;return t===void 0?void 0:this._codecMessageIdToNodeKey.get(t)}_inputGroupRoot(e){let t=e,n=new Set([R(t)]);for(;t.forkOf!==void 0&&!n.has(t.forkOf);){let e=this._nodeIndex.get(t.forkOf);if(e?.node.kind!==`input`||e.node.parentCodecMessageId!==t.parentCodecMessageId)break;t=e.node,n.add(R(t))}return t}_getSiblingGroup(e){this._siblingCacheVersion!==this._structuralVersion&&(this._siblingCache.clear(),this._siblingCacheVersion=this._structuralVersion);let t=this._siblingCache.get(e);if(t)return t;let n=this._nodeIndex.get(e);if(!n)return[];let r=n.node;r.kind===`input`&&(r=this._inputGroupRoot(r));let i=r.parentCodecMessageId,a=[],o=this._parentIndex.get(i);if(o)for(let e of o){let t=this._nodeIndex.get(e);t&&this._isSiblingOf(t.node,r)&&a.push(t)}a.sort((e,t)=>this._compareNodes(e,t));for(let e of a)this._siblingCache.set(R(e.node),a);return this._siblingCache.set(e,a),a}_isSiblingOf(e,t){if(e.kind!==t.kind||e.parentCodecMessageId!==t.parentCodecMessageId)return!1;if(e.kind===`run`)return!0;let n=R(t);if(R(e)===n)return!0;let r=e,i=new Set([R(r)]);for(;r.kind===`input`&&r.forkOf!==void 0;){if(r.forkOf===n)return!0;if(i.has(r.forkOf))break;let e=this._nodeIndex.get(r.forkOf);if(!e)break;r=e.node,i.add(R(r))}return!1}getGroupRoot(e){let t=this._nodeIndex.get(e);if(!t)return e;if(t.node.kind===`input`)return R(this._inputGroupRoot(t.node));let n=this._getSiblingGroup(e)[0]?.node;return n?R(n):e}visibleNodes(e=new Map){this._logger.trace(`DefaultTree.visibleNodes();`);let t=[],n=new Set,r=new Map;for(let i of this._sortedNodes){let a=i.node,o=R(a),s=this._parentKeyOf(a);if(s!==void 0&&!n.has(s))continue;let c=this._getSiblingGroup(o);if(c.length>1){let t=this.getGroupRoot(o),n=r.get(t);if(n===void 0){let i=e.get(t);if(i!==void 0&&c.some(e=>R(e.node)===i))n=i;else{let e=c.at(-1);if(!e)break;n=R(e.node)}r.set(t,n)}if(o!==n)continue}n.add(o),t.push(a)}return t}getRunNode(e){this._logger.trace(`DefaultTree.getRunNode();`,{runId:e});let t=this._nodeIndex.get(e)?.node;return t?.kind===`run`?t:void 0}getNode(e){return this._logger.trace(`DefaultTree.getNode();`,{key:e}),this._nodeIndex.get(e)?.node}getNodeByCodecMessageId(e){this._logger.trace(`DefaultTree.getNodeByCodecMessageId();`,{codecMessageId:e});let t=this._codecMessageIdToNodeKey.get(e);return t===void 0?void 0:this._nodeIndex.get(t)?.node}getReplyRuns(e){let t=this._replyRunsByInput.get(e);if(!t)return[];let n=[];for(let e of t){let t=this._nodeIndex.get(e)?.node;t?.kind===`run`&&n.push(t)}return n}getSiblingNodes(e){return this._logger.trace(`DefaultTree.getSiblingNodes();`,{key:e}),this._getSiblingGroup(e).map(e=>e.node)}applyMessage(e,t,n,r,i){let a=t[S],o=t[w],s=a===void 0&&o!==void 0&&t.role===`user`&&e.inputs.length>0?o:void 0;if(a===void 0&&s===void 0){this._logger.warn(`Tree.applyMessage(); message has no run-id and is not a user input; skipping`);return}let c=L(e),l=s??a;if(c.length===0&&l!==void 0&&!this._nodeIndex.has(l))return;let u=this._structuralVersion;s===void 0?a!==void 0&&this._applyRunMessage(a,e,t,n,r,i):this._applyInputMessage(s,t,n,r,i,c),this._structuralVersion!==u&&this._emitter.emit(`update`)}_applyInputMessage(e,t,n,r,i,a){let o=this._nodeIndex.get(e);o?o.node.kind===`input`&&n&&!o.node.serial&&(this._logger.debug(`Tree.applyMessage(); promoting input serial`,{codecMessageId:e,serial:n}),o.node.serial=n,this._promoteSerial(o)):(o=this._createInputNodeFromHeaders(e,t,n),this._insertNode(e,o,o.node.parentCodecMessageId),this._codecMessageIdToNodeKey.set(e,e),this._logger.debug(`Tree.applyMessage(); created input node`,{codecMessageId:e})),this._recordActivity(o,r),this._recordAndFold(o,a,n,e,i,t[x]===`true`),this._emitter.emit(`output`,{runId:void 0,inputCodecMessageId:e,codecMessageId:e,serial:n,events:[]})}_applyRunMessage(e,t,n,r,i,a){let o=n[w],s=n[k],c=L(t),l=t.outputs,u=this._nodeIndex.get(e);if(!u&&o!==void 0){let e=this._codecMessageIdToNodeKey.get(o),t=e===void 0?void 0:this._nodeIndex.get(e);t?.node.kind===`run`&&t.node.startSerial===void 0&&(u=t)}u?r&&u.node.kind===`run`&&!u.node.startSerial&&(this._logger.debug(`Tree.applyMessage(); promoting startSerial`,{runId:e,serial:r}),u.node.startSerial=r,this._promoteSerial(u)):(u=this._createRunFromHeaders(e,n,r),this._insertNode(e,u,u.node.parentCodecMessageId),this._indexReplyRun(u.node,e),this._logger.debug(`Tree.applyMessage(); created new Run`,{runId:e}));let d=R(u.node);o&&this._codecMessageIdToNodeKey.set(o,d),this._recordActivity(u,i),this._recordAndFold(u,c,r,o,a,n[x]===`true`),this._emitter.emit(`output`,{runId:d,inputCodecMessageId:s,codecMessageId:o,serial:r,events:l})}_indexReplyRun(e,t){e.parentCodecMessageId!==void 0&&B(this._replyRunsByInput,e.parentCodecMessageId,t)}applyRunLifecycle(e){this._logger.trace(`DefaultTree.applyRunLifecycle();`,{type:e.type,runId:e.runId});let t=this._structuralVersion;switch(e.type){case`start`:this._applyRunStart(e);break;case`suspend`:this._applyRunSuspend(e);break;case`resume`:this._applyRunResume(e);break;case`end`:this._applyRunEnd(e);break}this._emitter.emit(`run`,e),this._structuralVersion!==t&&this._emitter.emit(`update`)}_applyRunStart(e){let t=this._nodeIndex.get(e.runId);if(t?.node.kind===`run`){let n=t.node;if(n.state.status===`suspended`&&(n.state={status:`active`}),e.serial&&!n.startSerial&&(n.startSerial=e.serial,this._promoteSerial(t)),n.parentCodecMessageId===void 0&&e.parent!==void 0&&(n.parentCodecMessageId=e.parent,this._removeFromParentIndex(void 0,e.runId),this._addToParentIndex(n.parentCodecMessageId,e.runId),this._indexReplyRun(n,e.runId),this._structuralVersion++),n.forkOf===void 0&&e.forkOf!==void 0){let t=this._codecMessageIdToNodeKey.get(e.forkOf);t!==void 0&&t!==e.runId&&(n.forkOf=t,this._structuralVersion++)}n.regeneratesCodecMessageId===void 0&&e.regenerates!==void 0&&(n.regeneratesCodecMessageId=e.regenerates,this._structuralVersion++),n.invocationId===``&&e.invocationId!==``&&(n.invocationId=e.invocationId),t.runStartSeen=!0,this._recordActivity(t,e.timestamp),this._maybeQueueSweep(t)}else if(!t){let t=this._createRunFromLifecycle(e);this._insertNode(e.runId,t,t.node.parentCodecMessageId),this._indexReplyRun(t.node,e.runId),this._recordActivity(t,e.timestamp)}}_applyRunSuspend(e){let t=this._nodeIndex.get(e.runId);t?.node.kind===`run`&&(t.node.state={status:`suspended`},t.node.endSerial=e.serial,this._recordActivity(t,e.timestamp))}_applyRunResume(e){let t=this._nodeIndex.get(e.runId);t?.node.kind===`run`&&t.node.state.status===`suspended`&&(t.node.state={status:`active`},this._recordActivity(t,e.timestamp))}_applyRunEnd(e){let t=this._nodeIndex.get(e.runId);t?.node.kind===`run`&&(t.node.state=e.reason===`error`?{status:`error`,error:e.error}:{status:e.reason},t.node.endSerial=e.serial,this._recordActivity(t,e.timestamp),this._maybeQueueSweep(t))}delete(e){let t=this._nodeIndex.get(e);t&&(this._logger.debug(`Tree.delete();`,{key:e}),this._removeFromParentIndex(t.node.parentCodecMessageId,e),this._removeSortedNode(t),this._nodeIndex.delete(e),t.node.kind===`run`&&t.node.parentCodecMessageId!==void 0&&V(this._replyRunsByInput,t.node.parentCodecMessageId,e),this._structuralVersion++,this._emitter.emit(`update`))}_createRunFromHeaders(e,t,n){let r=t[D];return this._buildRunNode({runId:e,parentCodecMessageId:t[E],forkOf:r?this._codecMessageIdToNodeKey.get(r):void 0,regeneratesCodecMessageId:t[O],clientId:t[`run-client-id`]??``,invocationId:t[`invocation-id`]??``,startSerial:n,runStartSeen:!1})}_wrapNode(e,t=!1){return{node:e,insertSeq:this._seqCounter++,log:new Te,lastActivityTs:0,runStartSeen:t,sweepQueued:!1,optimistic:!1}}_buildRunNode(e){let t={kind:`run`,runId:e.runId,parentCodecMessageId:e.parentCodecMessageId,forkOf:e.forkOf,regeneratesCodecMessageId:e.regeneratesCodecMessageId,clientId:e.clientId,invocationId:e.invocationId,state:{status:`active`},projection:this._codec.init(),startSerial:e.startSerial,endSerial:void 0};return this._wrapNode(t,e.runStartSeen)}_createInputNodeFromHeaders(e,t,n){let r=t[D],i={kind:`input`,codecMessageId:e,parentCodecMessageId:t[E],forkOf:r,projection:this._codec.init(),serial:n};return this._wrapNode(i)}_createRunFromLifecycle(e){let t=e.forkOf;return this._buildRunNode({runId:e.runId,parentCodecMessageId:e.parent,forkOf:t?this._codecMessageIdToNodeKey.get(t):void 0,regeneratesCodecMessageId:e.regenerates,clientId:e.clientId,invocationId:e.invocationId,startSerial:e.serial,runStartSeen:!0})}on(e,t){let n=t;return this._emitter.on(e,n),()=>{this._emitter.off(e,n)}}emitAblyMessage(e){this._logger.trace(`DefaultTree.emitAblyMessage();`);let t=F(e)[C];t!==void 0&&!this._eventIdIndex.has(t)&&this._eventIdIndex.set(t,e),this._emitter.emit(`ably-message`,e)}findAblyMessageByEventId(e){return this._eventIdIndex.get(e)}},De=(e,t)=>new Ee(e,t),Oe=(e,n)=>new Promise((r,i)=>{if(n?.aborted){i(new t.ErrorInfo(`unable to wait; signal aborted`,A.InvalidArgument,400));return}let a=setTimeout(()=>{n?.removeEventListener(`abort`,o),r()},e);typeof a==`object`&&a.unref();let o=()=>{clearTimeout(a),i(new t.ErrorInfo(`unable to wait; signal aborted`,A.InvalidArgument,400))};n?.addEventListener(`abort`,o,{once:!0})}),H=async(e,n,r,i,a)=>{let o;for(let s=0;s<=n;s++){if(i?.aborted)throw new t.ErrorInfo(`unable to fetch history page; signal aborted`,A.InvalidArgument,400,P(o));try{return await e()}catch(e){if(o=e,s===n)break;let t=r*2**s;a?.debug(`loadHistoryPages.fetchPageWithRetry(); page fetch failed, retrying`,{attempt:s+1,maxRetries:n,backoff:t}),await Oe(t,i)}}throw new t.ErrorInfo(`unable to fetch history page; ${N(o)}`,A.HistoryFetchFailed,500,P(o))},ke=async(e,n)=>{let{pageLimit:r,untilAttach:i=!0,signal:a,maxRetries:o=3,retryBackoffMs:s=100,logger:c}=n;if(a?.aborted)throw new t.ErrorInfo(`unable to load history; signal aborted`,A.InvalidArgument,400);await e.attach();let l={limit:r,untilAttach:i},u=await H(()=>e.history(l),o,s,a,c),d=!1;return{hasNext:()=>u===void 0||a?.aborted?!1:d?u.hasNext():!0,next:async()=>{if(u===void 0)return;if(a?.aborted)throw new t.ErrorInfo(`unable to load history; signal aborted`,A.InvalidArgument,400);if(!d)return d=!0,u.items;if(!u.hasNext()){u=void 0;return}let e=await H(async()=>await u?.next()??void 0,o,s,a,c);if(!e){u=void 0;return}return u=e,e.items}}},Ae=(e,t)=>{for(let n of t){let t=F(n),r=t[w];if(!r)continue;let i=n.action,a=i===`message.create`&&`discrete`in t,o=t.stream===`true`&&(i===`message.create`||i===`message.update`||i===`message.append`),s=t[ne],c=s===`complete`||s===`cancelled`;(a||o)&&e.startedCodecMessageIds.add(r),(a||c)&&e.terminatedCodecMessageIds.add(r),e.startedCodecMessageIds.has(r)&&e.terminatedCodecMessageIds.has(r)&&e.completedCodecMessageIds.add(r)}},U=async(e,t)=>{let n=e.returnedCount+t;for(;e.completedCodecMessageIds.size<n&&e.cursor.hasNext();){e.logger.debug(`loadHistory.fetchUntilLimit(); pulling next page`,{collected:e.rawMessages.length,completed:e.completedCodecMessageIds.size});let t=await e.cursor.next();if(!t)break;e.rawMessages.push(...t),Ae(e,t)}},W=(e,t)=>{let n=e.completedCodecMessageIds.size,r=Math.min(t,Math.max(0,n-e.returnedCount));e.returnedCount+=r;let i=n>e.returnedCount,a=e.cursor.hasNext(),o=e.rawMessages.length-e.returnedRawCount>0?e.rawMessages.slice(e.returnedRawCount).toReversed():[];return e.returnedRawCount=e.rawMessages.length,{rawMessages:o,hasNext:()=>i||a,next:async()=>{if(i)return W(e,t);if(a)return await U(e,t),W(e,t)}}},je=async(e,t,n)=>{let r=t?.limit??100;n.trace(`loadHistory();`,{limit:r});let i={cursor:await ke(e,{pageLimit:r*10,untilAttach:!0,logger:n}),rawMessages:[],returnedCount:0,returnedRawCount:0,startedCodecMessageIds:new Set,terminatedCodecMessageIds:new Set,completedCodecMessageIds:new Set,logger:n};return await U(i,r),W(i,r)},Me=e=>Array.isArray(e)?e:[e],G=e=>({runId:e.runId,clientId:e.clientId,invocationId:e.invocationId,...e.state}),Ne=class{constructor(e){this._branchSelections=new Map,this._regenSelections=new Map,this._nonHeadRegenSelections=new Map,this._withheldRunIds=new Set,this._lastVisibleNodeKeys=[],this._lastVisibleProjections=[],this._lastVisibleMessagePairs=[],this._lastVisibleNodeKeySet=new Set,this._hasMoreHistory=!1,this._withheldBuffer=[],this._hiddenMessageCount=0,this._unsubs=[],this._cachedNodes=[],this._loadingOlder=!1,this._processingHistory=!1,this._closed=!1,this._tree=e.tree,this._channel=e.channel,this._codec=e.codec,this._applier=e.applier,this._sendDelegate=e.sendDelegate,this._onClose=e.onClose,this._logger=e.logger.withContext({component:`View`}),this._logger.trace(`DefaultView();`),this._emitter=new j(this._logger),this._cachedNodes=this._computeFlatNodes(),this._updateVisibleSnapshot(this._cachedNodes),this._unsubs.push(this._tree.on(`update`,()=>{this._onTreeUpdate()}),this._tree.on(`ably-message`,e=>{this._onTreeAblyMessage(e)}),this._tree.on(`run`,e=>{this._onTreeRun(e)}),this._tree.on(`output`,e=>{this._onTreeOutput(e)}))}_onTreeOutput(e){this._processingHistory||(e.runId!==void 0&&this._lastVisibleNodeKeySet.has(e.runId)||e.inputCodecMessageId!==void 0&&this._lastVisibleNodeKeySet.has(e.inputCodecMessageId))&&(this._lastVisibleProjections=this._cachedNodes.map(e=>e.projection),this._lastVisibleMessagePairs=this._extractMessages(this._cachedNodes).slice(this._hiddenMessageCount),this._emitter.emit(`update`))}getMessages(){return this._lastVisibleMessagePairs}runs(){return this._cachedNodes.filter(e=>e.kind===`run`).map(e=>G(e))}_computeFlatNodes(){let e=this._treeVisibleNodes();return this._withheldRunIds.size===0?e:e.filter(e=>!this._withheldRunIds.has(R(e)))}_recomputeAndEmit(){this._cachedNodes=this._computeFlatNodes(),this._updateVisibleSnapshot(this._cachedNodes),this._emitter.emit(`update`)}_recomputeAndEmitIfChanged(){let e=this._computeFlatNodes();this._visibleChanged(e)&&(this._cachedNodes=e,this._updateVisibleSnapshot(e),this._emitter.emit(`update`))}_runByCodecMessageId(e){let t=this._tree.getNodeByCodecMessageId(e);return t?.kind===`run`?t:void 0}_nonHeadRegenerators(e,t){return this._tree.getReplyRuns(t).filter(t=>t.regeneratesCodecMessageId===e).toSorted((e,t)=>(e.startSerial??`￿`).localeCompare(t.startSerial??`￿`))}_selectedNonHeadMember(e,t,n){let r=this._nonHeadRegenSelections.get(e);return r&&r.kind!==`pending`&&[t,...n.map(e=>e.runId)].includes(r.selectedRunId)?r.selectedRunId:n.at(-1)?.runId??t}_extractMessages(e){let t=[],n=new Set;for(let r of e)r.kind===`run`&&n.has(r.runId)||this._emitNodeMessages(r,t,n);return t}_emitNodeMessages(e,t,n){let r=this._codec.getMessages(e.projection);if(e.kind!==`run`){t.push(...r);return}for(let i=0;i<r.length;i++){let a=r[i];if(!a)continue;let o=i>0?r[i-1]?.codecMessageId:void 0;if(o!==void 0){let r=this._nonHeadRegenerators(a.codecMessageId,o);if(r.length>0){for(let e of r)n.add(e.runId);let i=this._selectedNonHeadMember(a.codecMessageId,e.runId,r);if(i!==e.runId){let e=r.find(e=>e.runId===i);if(e){this._emitNodeMessages(e,t,n);return}}}}t.push(a)}}hasOlder(){return this._hiddenMessageCount>0||this._withheldBuffer.length>0||this._hasMoreHistory}async loadOlder(e=10){if(!(this._closed||this._loadingOlder)){this._loadingOlder=!0,this._logger.trace(`DefaultView.loadOlder();`,{limit:e});try{if(this._hiddenMessageCount>=e){this._hiddenMessageCount-=e,this._recomputeAndEmit();return}let t=e-this._hiddenMessageCount,n=this._extractMessages(this._computeFlatNodes()).length,r=()=>this._extractMessages(this._computeFlatNodes()).length-n;if(this._withheldBuffer.length>0){let e=this._messageTailSplitIndex(this._withheldBuffer,t),n=this._withheldBuffer.splice(e);this._releaseWithheld(n)}if(r()<t&&(await this._fetchOlder(t-r()),this._closed))return;let i=this._extractMessages(this._computeFlatNodes()).length;this._hiddenMessageCount=Math.max(0,this._hiddenMessageCount+(i-n)-e),this._recomputeAndEmit()}catch(e){throw this._logger.error(`DefaultView.loadOlder(); failed`,{error:e}),e}finally{this._loadingOlder=!1}}}async _fetchOlder(e){if(!this._hasMoreHistory&&!this._lastHistoryPage){await this._loadFirstPage(e);return}if(!this._hasMoreHistory)return;if(!this._lastHistoryPage?.hasNext()){this._hasMoreHistory=!1;return}let t=await this._lastHistoryPage.next();if(this._closed||!t){t||(this._hasMoreHistory=!1);return}await this._revealFromPage(t,e)}_messageTailSplitIndex(e,t){let n=0;for(let r=e.length-1;r>=0;r--){let i=e[r];if(i&&(n+=this._codec.getMessages(i.projection).length,n>=t))return r}return 0}runOf(e){this._logger.trace(`DefaultView.runOf();`,{codecMessageId:e});let t=this._tree.getNodeByCodecMessageId(e);if(!t)return;if(t.kind===`run`)return G(t);let n=this._selectedReplyRun(t.codecMessageId);return n?G(n):void 0}_selectedReplyRun(e){let t=this._tree.getReplyRuns(e);if(t.length===0)return;if(t.length===1)return t[0];let n=this._tree.getGroupRoot(t[0]?.runId??``),r=this._regenSelections.get(n),i=r&&r.kind!==`pending`?r.selectedRunId:void 0;if(i!==void 0){let e=t.find(e=>e.runId===i);if(e)return e}return t.toSorted((e,t)=>(e.startSerial??`￿`).localeCompare(t.startSerial??`￿`)).at(-1)}run(e){this._logger.trace(`DefaultView.run();`,{runId:e});let t=this._tree.getRunNode(e);return t?G(t):void 0}branchSelection(e){let t=this._resolveMessageBranchPoint(e);if(t){let e=t.members.flatMap(e=>{let t=this._tree.getNodeByCodecMessageId(e.representativeCodecMessageId);if(!t)return[];let n=this._codec.getMessages(t.projection).find(t=>t.codecMessageId===e.representativeCodecMessageId);return n?[n.message]:[]});if(e.length>0){let n=this._resolveSelectedIndex(t),r=Math.max(0,Math.min(n,e.length-1)),i=e[r];return{hasSiblings:e.length>1,siblings:e,index:r,selected:i}}}let n=this._tree.getNodeByCodecMessageId(e);if(n){let t=this._codec.getMessages(n.projection).find(t=>t.codecMessageId===e);if(t!==void 0)return{hasSiblings:!1,siblings:[t.message],index:0,selected:t.message}}return{hasSiblings:!1,siblings:[],index:0,selected:void 0}}selectSibling(e,t){this._logger.trace(`DefaultView.selectSibling();`,{codecMessageId:e,index:t});let n=this._resolveMessageBranchPoint(e);if(!n)return;let r=Math.max(0,Math.min(t,n.members.length-1)),i=n.members[r];i&&(n.kind===`fork-of`?(this._branchSelections.set(n.groupRoot,{kind:`user`,selectedKey:i.memberNodeKey}),this._logger.debug(`DefaultView.selectSibling(); fork-of`,{codecMessageId:e,index:r,selectedKey:i.memberNodeKey})):n.kind===`non-head-regen`?(this._nonHeadRegenSelections.set(n.groupRoot,{kind:`user`,selectedRunId:i.memberNodeKey}),this._logger.debug(`DefaultView.selectSibling(); non-head-regen`,{codecMessageId:e,index:r,selectedRunId:i.memberNodeKey,anchor:n.groupRoot})):(this._regenSelections.set(n.groupRoot,{kind:`user`,selectedRunId:i.memberNodeKey}),this._logger.debug(`DefaultView.selectSibling(); regenerate`,{codecMessageId:e,index:r,selectedRunId:i.memberNodeKey,groupRoot:n.groupRoot})),this._recomputeAndEmit())}_resolveSelectedIndex(e){if(e.kind===`fork-of`){let t=this._branchSelections.get(e.groupRoot);if(!t)return e.members.length-1;let n=e.members.findIndex(e=>e.memberNodeKey===t.selectedKey);return n===-1?e.members.length-1:n}let t=e.kind===`non-head-regen`?this._nonHeadRegenSelections.get(e.groupRoot):this._regenSelections.get(e.groupRoot);if(!t||t.kind===`pending`)return e.members.length-1;let n=e.members.findIndex(e=>e.memberNodeKey===t.selectedRunId);return n===-1?e.members.length-1:n}_resolveMessageBranchPoint(e){let t=this._tree.getNodeByCodecMessageId(e);if(!t)return;if(t.kind===`input`){let e=this._tree.getSiblingNodes(t.codecMessageId);return e.length>1?{kind:`fork-of`,groupRoot:this._tree.getGroupRoot(t.codecMessageId),members:this._nodeHeadMembers(e)}:void 0}let n=this._codec.getMessages(t.projection),r=this._resolveNonHeadBranchPoint(t,n,e);if(r)return r;let i=this._tree.getSiblingNodes(t.runId);if(i.length>1&&n.at(0)?.codecMessageId===e)return{kind:`regen`,groupRoot:this._tree.getGroupRoot(t.runId),members:this._nodeHeadMembers(i)}}_resolveNonHeadBranchPoint(e,t,n){if(t.at(0)?.codecMessageId===n&&e.regeneratesCodecMessageId!==void 0){let t=e.regeneratesCodecMessageId,n=this._runByCodecMessageId(t);if(n){let e=this._codec.getMessages(n.projection),r=e.findIndex(e=>e.codecMessageId===t),i=r>0?e[r-1]?.codecMessageId:void 0;if(i!==void 0)return this._buildNonHeadGroup(t,n.runId,i)}return}let r=t.findIndex(e=>e.codecMessageId===n),i=r>0?t[r-1]?.codecMessageId:void 0;if(i!==void 0)return this._buildNonHeadGroup(n,e.runId,i)}_buildNonHeadGroup(e,t,n){let r=this._nonHeadRegenerators(e,n);if(r.length===0)return;let i=[{memberNodeKey:t,representativeCodecMessageId:e}];for(let e of r){let t=this._codec.getMessages(e.projection).at(0);t&&i.push({memberNodeKey:e.runId,representativeCodecMessageId:t.codecMessageId})}return{kind:`non-head-regen`,groupRoot:e,members:i}}_nodeHeadMembers(e){let t=[];for(let n of e){let e=this._codec.getMessages(n.projection).at(0);e&&t.push({memberNodeKey:R(n),representativeCodecMessageId:e.codecMessageId})}return t}async send(e,n){if(this._logger.trace(`DefaultView.send();`),this._closed)throw new t.ErrorInfo(`unable to send; view is closed`,A.InvalidArgument,400);let r=Me(e),i=this._lastVisibleMessagePairs.at(-1)?.codecMessageId,a=await this._sendDelegate(r,n,i);return this._applyForkAutoSelect(a,n),a}_applyForkAutoSelect(e,t){if(!t?.forkOf)return;let n=e.optimisticCodecMessageIds.at(0);if(n===void 0)return;let r=this._tree.getGroupRoot(n);this._branchSelections.set(r,{kind:`auto`,selectedKey:n}),this._recomputeAndEmit()}_applyRegenerateAutoSelect(e,t){let n=this._runByCodecMessageId(t);if(!n)return;if(this._codec.getMessages(n.projection).at(0)?.codecMessageId!==t){this._nonHeadRegenSelections.set(t,{kind:`pending`,carrierCodecMessageId:e.inputCodecMessageId}),this._logger.debug(`DefaultView._applyRegenerateAutoSelect(); deferring non-head regenerate selection`,{anchorCodecMessageId:t,carrier:e.inputCodecMessageId}),this._resolvePendingNonHeadRegenSelections(),this._recomputeAndEmitIfChanged();return}let r=this._tree.getGroupRoot(n.runId);this._regenSelections.set(r,{kind:`pending`,carrierCodecMessageId:e.inputCodecMessageId}),this._logger.debug(`DefaultView._applyRegenerateAutoSelect(); deferring regenerate selection`,{anchorCodecMessageId:t,groupRoot:r,carrier:e.inputCodecMessageId}),this._resolvePendingRegenSelections(),this._recomputeAndEmitIfChanged()}async regenerate(e,n){if(this._logger.trace(`DefaultView.regenerate();`,{messageId:e}),this._closed)throw new t.ErrorInfo(`unable to regenerate; view is closed`,A.InvalidArgument,400);let r=this._runByCodecMessageId(e);if(!r)throw new t.ErrorInfo(`unable to regenerate; message not found in tree: ${e}`,A.InvalidArgument,400);let i=this._findParentMsgId(r,e);if(!i)throw new t.ErrorInfo(`unable to regenerate; parent user message not found for ${e}`,A.InvalidArgument,400);let a=e;r.regeneratesCodecMessageId!==void 0&&this._codec.getMessages(r.projection).at(0)?.codecMessageId===e&&(a=r.regeneratesCodecMessageId);let o={...n,parent:i},s=this._codec.createRegenerate(a,i),c=await this._sendDelegate([s],o,i);return this._applyRegenerateAutoSelect(c,a),c}async edit(e,n,r){if(this._logger.trace(`DefaultView.edit();`,{messageId:e}),this._closed)throw new t.ErrorInfo(`unable to edit; view is closed`,A.InvalidArgument,400);let i=this._tree.getNodeByCodecMessageId(e);if(!i)throw new t.ErrorInfo(`unable to edit; message not found in tree: ${e}`,A.InvalidArgument,400);let a=this._findParentMsgId(i,e);return this.send(n,{...r,forkOf:e,parent:a})}_findParentMsgId(e,t){let n=this._lastVisibleMessagePairs,r=n.findIndex(e=>e.codecMessageId===t);if(r>0)return n[r-1]?.codecMessageId;if(r===0)return;let i=this._codec.getMessages(e.projection),a=i.findIndex(e=>e.codecMessageId===t);if(a>0)return i[a-1]?.codecMessageId;if(a===0&&e.parentCodecMessageId!==void 0){let t=this._tree.getNodeByCodecMessageId(e.parentCodecMessageId);if(t)return this._codec.getMessages(t.projection).at(-1)?.codecMessageId}}on(e,t){let n=t;return this._emitter.on(e,n),()=>{this._emitter.off(e,n)}}close(){if(!this._closed){this._logger.info(`DefaultView.close();`),this._closed=!0,this._loadingOlder=!1;for(let e of this._unsubs)e();this._unsubs.length=0,this._emitter.off(),this._branchSelections.clear(),this._regenSelections.clear(),this._nonHeadRegenSelections.clear(),this._withheldRunIds.clear(),this._withheldBuffer.length=0,this._hiddenMessageCount=0,this._onClose?.()}}async _loadFirstPage(e){let t=await je(this._channel,{limit:e},this._logger);this._closed||await this._revealFromPage(t,e)}async _revealFromPage(e,t){let n=new Set(this._treeVisibleNodes().map(e=>R(e))),{newVisible:r,lastPage:i}=await this._loadUntilVisible(e,t,n);this._closed||(this._lastHistoryPage=i,this._hasMoreHistory=i.hasNext(),this._splitReveal(r,t))}_splitReveal(e,t){let n=this._messageTailSplitIndex(e,t),r=e.slice(n),i=e.slice(0,n);for(let e of i)this._withheldRunIds.add(R(e));this._withheldBuffer.push(...i),this._releaseWithheld(r)}_processHistoryPage(e){this._processingHistory=!0;try{for(let t of e.rawMessages)this._applier.apply(t);for(let t of e.rawMessages)this._tree.emitAblyMessage(t)}finally{this._processingHistory=!1}}async _loadUntilVisible(e,t,n){this._processHistoryPage(e);let r=e,i=()=>{let e=0;for(let t of this._treeVisibleNodes())n.has(R(t))||(e+=this._codec.getMessages(t.projection).length);return e};for(;i()<t&&r.hasNext();){let e=await r.next();if(!e||this._closed)break;this._processHistoryPage(e),r=e}return{newVisible:this._treeVisibleNodes().filter(e=>!n.has(R(e))),lastPage:r}}_releaseWithheld(e){for(let t of e)this._withheldRunIds.delete(R(t));e.length>0&&this._recomputeAndEmit()}_updateVisibleSnapshot(e){let t=e??this._cachedNodes;this._lastVisibleNodeKeys=t.map(e=>R(e)),this._lastVisibleNodeKeySet=new Set(this._lastVisibleNodeKeys),this._lastVisibleProjections=t.map(e=>e.projection),this._lastVisibleMessagePairs=this._extractMessages(t).slice(this._hiddenMessageCount)}_onTreeUpdate(){this._processingHistory||(this._pinBranchSelections(),this._resolvePendingRegenSelections(),this._resolvePendingNonHeadRegenSelections(),this._recomputeAndEmitIfChanged())}_resolveSelections(){let e=new Map;for(let[t,n]of this._branchSelections)e.set(t,n.selectedKey);for(let[t,n]of this._regenSelections)n.kind!==`pending`&&e.set(t,n.selectedRunId);return e}_treeVisibleNodes(){return this._tree.visibleNodes(this._resolveSelections())}_pinBranchSelections(){for(let e of this._lastVisibleNodeKeys){if(this._tree.getNode(e)?.kind!==`input`||this._tree.getSiblingNodes(e).length<=1)continue;let t=this._tree.getGroupRoot(e);this._branchSelections.get(t)||this._branchSelections.set(t,{kind:`pinned`,selectedKey:e})}}_resolvePendingRegenSelections(){for(let[e,t]of this._regenSelections){if(t.kind===`user`)continue;let n=this._tree.getSiblingNodes(e).filter(e=>e.kind===`run`);if(n.length<=1)continue;let r=n.at(-1);r&&this._regenSelections.set(e,{kind:`auto`,selectedRunId:r.runId})}}_resolvePendingNonHeadRegenSelections(){for(let[e,t]of this._nonHeadRegenSelections){if(t.kind===`user`)continue;let n=this._runByCodecMessageId(e);if(!n)continue;let r=this._codec.getMessages(n.projection),i=r.findIndex(t=>t.codecMessageId===e),a=i>0?r[i-1]?.codecMessageId:void 0;if(a===void 0)continue;let o=this._nonHeadRegenerators(e,a).at(-1);o&&this._nonHeadRegenSelections.set(e,{kind:`auto`,selectedRunId:o.runId})}}_onTreeAblyMessage(e){let t=F(e),n=t[w],r=t[S];if(!n&&!r){this._emitter.emit(`ably-message`,e);return}r&&this._lastVisibleNodeKeySet.has(r)&&this._emitter.emit(`ably-message`,e)}_onTreeRun(e){if(this._lastVisibleNodeKeySet.has(e.runId)){this._emitter.emit(`run`,e);return}e.type===`start`&&this._isRunStartVisible(e)&&(this._lastVisibleNodeKeySet.add(e.runId),this._emitter.emit(`run`,e))}_isRunStartVisible(e){let{parent:t}=e;if(t===void 0)return!0;let n=this._tree.getNodeByCodecMessageId(t);return n?this._lastVisibleNodeKeySet.has(R(n)):!0}_visibleChanged(e){if(e.length!==this._lastVisibleNodeKeys.length)return!0;for(let[t,n]of e.entries())if(R(n)!==this._lastVisibleNodeKeys[t]||n.projection!==this._lastVisibleProjections[t])return!0;return!1}},K=e=>new Ne(e),Pe=()=>{},Fe=class{constructor(e){this._views=new Set,this._state=`ready`,this._pendingRunStarts=new Map;let t=te(e.client,e.codec),n=h(e.channelModes);if(n&&(t.modes=n),this._channel=e.client.channels.get(e.channelName,t),this._client=e.client,this._codec=e.codec,this._logger=(e.logger??fe({logLevel:ue.Silent})).withContext({component:`ClientSession`}),this._emitter=new j(this._logger),this._hasAttachedOnce=this._channel.state===`attached`,this._tree=De(this._codec,this._logger),this._applier=ye(this._tree,this._codec.createDecoder()),this._view=K({tree:this._tree,channel:this._channel,codec:this._codec,applier:this._applier,sendDelegate:this._internalSend.bind(this),logger:this._logger,onClose:()=>this._views.delete(this._view)}),this._encoder=this._codec.createEncoder(this._channel),this._views.add(this._view),this.tree=this._tree,this.view=this._view,e.messages){let t;for(let n of e.messages){let e=crypto.randomUUID(),r={[w]:e,[T]:`user`};t&&(r[E]=t),this._tree.applyMessage({inputs:[this._codec.createUserMessage(n)],outputs:[]},r),t=e}}this._onMessage=e=>{this._handleMessage(e)},this._onChannelStateChange=e=>{this._handleChannelStateChange(e)},this._channel.on(this._onChannelStateChange)}get presence(){return this._channel.presence}get object(){return this._channel.object}connect(){return this._state===`closed`?Promise.reject(new t.ErrorInfo(`unable to connect; session is closed`,A.SessionClosed,400)):this._connectPromise?this._connectPromise:(this._logger.trace(`DefaultClientSession.connect();`),this._connectPromise=this._channel.subscribe(this._onMessage).then(()=>{this._logger.debug(`DefaultClientSession.connect(); subscribed and attached`)},e=>{let n=new t.ErrorInfo(`unable to subscribe to channel; ${N(e)}`,A.SessionSubscriptionError,500,P(e));throw this._logger.error(`DefaultClientSession.connect(); subscribe failed`),this._emitter.emit(`error`,n),n}),this._connectPromise)}_resolveClientId(){let e=this._client.auth.clientId;return e&&e!==`*`?e:void 0}async _requireConnected(e){return xe(this._connectPromise,e)}_handleMessage(e){if(this._state!==`closed`)try{if(e.name===`ai-run-end`){let t=F(e);if((t[`run-reason`]??`complete`)===`error`){let e=I(t);this._logger.error(`ClientSession._handleMessage(); agent error received`,{runId:t[S],invocationId:t[re],code:e.code}),this._emitter.emit(`error`,e)}}let t=this._applier.apply(e);if(t&&(t.type===`start`||t.type===`resume`)){let n=F(e)[k];if(n!==void 0){let e=this._pendingRunStarts.get(n);e&&(this._pendingRunStarts.delete(n),e.resolve(t.runId))}}this._tree.emitAblyMessage(e)}catch(e){this._emitter.emit(`error`,new t.ErrorInfo(`unable to process channel message; ${N(e)}`,A.SessionSubscriptionError,500,P(e)))}}_handleChannelStateChange(e){if(this._state===`closed`)return;let{current:t,resumed:n}=e;if(t===`attached`&&!this._hasAttachedOnce){this._hasAttachedOnce=!0;return}if(!Ce(e))return;this._logger.error(`ClientSession._handleChannelStateChange(); channel continuity lost`,{current:t,resumed:n,previous:e.previous});let r=we(e,`deliver events`);this._emitter.emit(`error`,r)}_cleanupFailedSend(e){for(let t of e){let e=this._tree.getNodeByCodecMessageId(t);e?.kind===`input`&&e.serial===void 0&&this._tree.delete(e.codecMessageId)}}createView(){if(this._state===`closed`)throw new t.ErrorInfo(`unable to create view; session is closed`,A.SessionClosed,400);this._logger.trace(`DefaultClientSession.createView();`);let e=K({tree:this._tree,channel:this._channel,codec:this._codec,applier:this._applier,sendDelegate:this._internalSend.bind(this),logger:this._logger,onClose:()=>this._views.delete(e)});return this._views.add(e),e}async _internalSend(e,n,r){if(this._state===`closed`||(await this._requireConnected(`send`),this._state===`closed`))throw new t.ErrorInfo(`unable to send; session is closed`,A.SessionClosed,400);let i=this._channel.state;if(i!==`attached`&&i!==`attaching`)throw new t.ErrorInfo(`unable to send; channel is ${i}`,A.ChannelNotReady,400);this._logger.trace(`ClientSession._internalSend();`);let a=n?.runId!==void 0,o=n?.runId,s;n?.parent===void 0&&!n?.forkOf&&(s=r);let c=new Set,l=[];for(let t of e){let e=crypto.randomUUID(),r=t.codecMessageId??crypto.randomUUID();c.add(r);let i=t.kind!==`user-message`&&(t.kind===`regenerate`||t.codecMessageId!==void 0),a=t.parent??(n?.parent===void 0?s:n.parent),u=n?.forkOf,d=t.kind===`regenerate`?t.target:void 0,f=he({role:`user`,runId:o,codecMessageId:r,runClientId:this._resolveClientId(),...a!==void 0&&{parent:a},...u!==void 0&&{forkOf:u},...d!==void 0&&{regenerates:d},inputEventId:e});i||this._tree.applyMessage({inputs:[t],outputs:[]},f),l.push({input:t,codecMessageId:r,inputEventId:e,headers:f,isWireOnly:i}),!i&&n?.parent===void 0&&!n?.forkOf&&t.parent===void 0&&(s=r)}let u=l.at(-1);if(u===void 0)throw new t.ErrorInfo(`unable to send; inputs array is empty (include at least one input)`,A.InvalidArgument,400);let d=u.inputEventId,f=u.codecMessageId,p=new Promise((e,t)=>{this._pendingRunStarts.set(f,{resolve:e,reject:t})});return p.catch(()=>{}),await(async()=>{try{for(let e of l)await this._encoder.publishInput(e.input,{extras:{headers:e.headers},messageId:e.codecMessageId})}catch(e){let n=P(e),r=n?.statusCode===401||n?.statusCode===403,i=new t.ErrorInfo(r?`unable to publish events; missing publish capability on the channel`:`unable to publish events; ${N(e)}`,r?A.InsufficientCapability:A.SessionSendFailed,r?401:500,n);throw this._emitter.emit(`error`,i),this._pendingRunStarts.delete(f),a||this._cleanupFailedSend([...c]),i}})(),{inputCodecMessageId:f,runId:p,inputEventId:d,cancel:async()=>{await this._publishCancel({inputCodecMessageId:f,...o!==void 0&&{runId:o}})},optimisticCodecMessageIds:[...c],toInvocation:()=>be.fromJSON({inputEventId:d,sessionName:this._channel.name})}}async cancel(e){return this._publishCancel({runId:e})}async _publishCancel(e){if(this._state===`closed`||(await this._requireConnected(`cancel`),this._state===`closed`))return;this._logger.debug(`ClientSession._publishCancel();`,{runId:e.runId,inputCodecMessageId:e.inputCodecMessageId});let t={[C]:crypto.randomUUID()};e.runId!==void 0&&(t[S]=e.runId),e.inputCodecMessageId!==void 0&&(t[k]=e.inputCodecMessageId),await this._channel.publish({name:se,extras:{ai:{transport:t}}})}on(e,t){if(this._state===`closed`)return Pe;let n=t;return this._emitter.on(e,n),()=>{this._emitter.off(e,n)}}async close(){if(this._state!==`closed`){this._state=`closed`,this._logger.info(`ClientSession.close();`),this._connectPromise&&this._channel.unsubscribe(this._onMessage),this._channel.off(this._onChannelStateChange),this._emitter.off();for(let e of this._views)e.close();if(this._views.clear(),this._pendingRunStarts.size>0){let e=new t.ErrorInfo(`unable to await run-start; session closed`,A.SessionClosed,400);for(let t of this._pendingRunStarts.values())t.reject(e);this._pendingRunStarts.clear()}try{await this._encoder.close()}catch{}await Se(this._channel,this._connectPromise,this._logger,`ClientSession`)}}},Ie=e=>new Fe(e),q=(0,r.createContext)({nearest:void 0,providers:{}}),J=({children:e,...a})=>{let o=(0,n.useAbly)(),{channelName:s}=a,c=(0,r.useMemo)(()=>{let e={params:{agent:ee(a.codec)}},t=h(a.channelModes);return t&&(e.modes=t),e},[a.codec,a.channelModes]),l=(0,r.useRef)(void 0),u=(0,r.useRef)(s),d=(0,r.useRef)([]),f=(0,r.useRef)(!1),p=(0,r.useRef)(void 0);if(!(l.current||p.current)||u.current!==s){u.current=s,l.current&&d.current.push(l.current);try{l.current=Ie({...a,client:o}),p.current=void 0}catch(e){l.current=void 0,p.current=e instanceof t.ErrorInfo?e:new t.ErrorInfo(`Unknown error while creating client session`,A.BadRequest,400)}}let m=(0,r.useContext)(q),g=l.current,_=p.current,v=(0,r.useMemo)(()=>({session:g,sessionError:_}),[g,_]),y=(0,r.useMemo)(()=>({nearest:v,providers:{...m.providers,[s]:v}}),[s,m,v]);return(0,r.useEffect)(()=>()=>{for(let e of d.current)e.close()},[s]),(0,r.useEffect)(()=>{l.current?.connect()},[s]),(0,r.useEffect)(()=>(f.current=!1,()=>{f.current=!0,Promise.resolve().then(()=>{f.current&&l.current?.close()})}),[]),(0,i.jsx)(q.Provider,{value:y,children:(0,i.jsx)(n.ChannelProvider,{channelName:s,options:c,children:e})})},Y=({session:e,skip:t}={})=>{let{nearest:n}=(0,r.useContext)(q),i=n?.session;if(!t&&e!==null)return e??i},X=({session:e,skip:t}={})=>{let n=Y({session:e,skip:t}),[i,a]=(0,r.useState)([]),o=(0,r.useRef)([]);return(0,r.useEffect)(()=>{if(o.current=[],a([]),n)return n.tree.on(`ably-message`,e=>{let t=[...o.current,e];o.current=t,a(t)})},[n]),i},Z=e=>new t.ErrorInfo(`unable to ${e}; hook is skipped`,A.InvalidArgument,400),Q=()=>({get tree(){throw Z(`access tree`)},get view(){throw Z(`access view`)},get presence(){throw Z(`access presence`)},get object(){throw Z(`access object`)},connect:()=>{throw Z(`connect`)},createView:()=>{throw Z(`create view`)},cancel:()=>{throw Z(`cancel`)},on:()=>{throw Z(`subscribe`)},close:()=>{throw Z(`close`)}}),Le=({channelName:e,skip:n,onError:i}={})=>{let{nearest:a,providers:o}=(0,r.useContext)(q),s=(0,r.useRef)(i);s.current=i;let c=n?void 0:e===void 0?a?.session:o[e]?.session;if((0,r.useEffect)(()=>{if(c)return c.on(`error`,e=>{s.current?.(e)})},[c]),n)return{session:Q()};if(e!==void 0){let n=o[e];return n?n.session?{session:n.session}:{session:Q(),sessionError:n.sessionError}:{session:Q(),sessionError:new t.ErrorInfo(`unable to use session; no ClientSessionProvider found for channelName "${e}"`,A.BadRequest,400)}}return a?a.session?{session:a.session}:{session:Q(),sessionError:a.sessionError}:{session:Q(),sessionError:new t.ErrorInfo(`unable to use session; no ClientSessionProvider found in the tree`,A.BadRequest,400)}},Re={hasSiblings:!1,siblings:[],index:0,selected:void 0},$=({session:e,view:n,limit:i,skip:a}={})=>{let o=Y({session:e,skip:a}),s=a?void 0:n??o?.view,[c,l]=(0,r.useState)(()=>s?.getMessages()??[]),[u,d]=(0,r.useState)(()=>s?.hasOlder()??!1),[f,p]=(0,r.useState)(!1),[m,h]=(0,r.useState)(),g=(0,r.useRef)(!1),_=i!==void 0,v=(0,r.useRef)(!1);(0,r.useEffect)(()=>{if(!s){l([]),d(!1),h(void 0);return}return v.current=!1,l(s.getMessages()),d(s.hasOlder()),h(void 0),s.on(`update`,()=>{l(s.getMessages()),d(s.hasOlder())})},[s]);let y=(0,r.useCallback)(async()=>{if(!(!s||g.current)){g.current=!0,p(!0);try{await s.loadOlder(i),h(void 0)}catch(e){e instanceof t.ErrorInfo?h(e):h(new t.ErrorInfo(`Unknown error loading older messages`,A.BadRequest,400))}finally{g.current=!1,p(!1)}}},[s,i]);return(0,r.useEffect)(()=>{!_||v.current||!s||(v.current=!0,y())},[_,s,y]),{messages:c,hasOlder:u,loading:f,loadError:m,loadOlder:y,runOf:(0,r.useCallback)(e=>s?.runOf(e),[s]),run:(0,r.useCallback)(e=>s?.run(e),[s]),runs:(0,r.useCallback)(()=>s?.runs()??[],[s]),branchSelection:(0,r.useCallback)(e=>s?.branchSelection(e)??Re,[s]),selectSibling:(0,r.useCallback)((e,t)=>{s?.selectSibling(e,t)},[s]),send:(0,r.useCallback)(async(e,n)=>{if(!s)throw new t.ErrorInfo(`unable to send; view is not available`,A.InvalidArgument,400);return s.send(e,n)},[s]),regenerate:(0,r.useCallback)(async(e,n)=>{if(!s)throw new t.ErrorInfo(`unable to regenerate; view is not available`,A.InvalidArgument,400);return s.regenerate(e,n)},[s]),edit:(0,r.useCallback)(async(e,n,r)=>{if(!s)throw new t.ErrorInfo(`unable to edit; view is not available`,A.InvalidArgument,400);return s.edit(e,n,r)},[s])}},ze=({session:e,limit:t,skip:n}={})=>{let i=Y({session:e,skip:n}),[a,o]=(0,r.useState)();return(0,r.useEffect)(()=>{if(!i){o(void 0);return}let e=i.createView();return o(e),()=>{e.close()}},[i]),$({view:a,limit:t,skip:n})},Be=({session:e}={})=>{let t=Y({session:e});return{getRunNode:(0,r.useCallback)(e=>t?.tree.getRunNode(e),[t]),getNodeByCodecMessageId:(0,r.useCallback)(e=>t?.tree.getNodeByCodecMessageId(e),[t]),getSiblingNodes:(0,r.useCallback)(e=>t?.tree.getSiblingNodes(e)??[],[t])}};e.ClientSessionProvider=J,e.OBJECT_MODES=p,e.createSessionHooks=()=>({ClientSessionProvider:J,useClientSession:e=>Le(e??{}),useView:e=>$(e??{}),useTree:e=>Be(e??{}),useAblyMessages:e=>X(e??{}),useCreateView:e=>ze(e??{})}),e.useAblyMessages=X,e.useClientSession=Le,e.useCreateView=ze,e.useTree=Be,e.useView=$});
2
2
  //# sourceMappingURL=ably-ai-transport-react.umd.cjs.map